firmware_loader: Expand Firmware upload error codes with firmware invalid error
authorKory Maincent <kory.maincent@bootlin.com>
Wed, 22 Nov 2023 13:52:43 +0000 (14:52 +0100)
committerJakub Kicinski <kuba@kernel.org>
Sat, 25 Nov 2023 02:09:19 +0000 (18:09 -0800)
No error code are available to signal an invalid firmware content.
Drivers that can check the firmware content validity can not return this
specific failure to the user-space

Expand the firmware error code with an additional code:
- "firmware invalid" code which can be used when the provided firmware
  is invalid

Sync lib/test_firmware.c file accordingly.

Acked-by: Luis Chamberlain <mcgrof@kernel.org>
Acked-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: Kory Maincent <kory.maincent@bootlin.com>
Reviewed-by: Simon Horman <horms@kernel.org>
Link: https://lore.kernel.org/r/20231122-feature_firmware_error_code-v3-1-04ec753afb71@bootlin.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
drivers/base/firmware_loader/sysfs_upload.c
include/linux/firmware.h
lib/test_firmware.c

index a0af8f5f13d888641201eea1cf3a9b1071922e12..829270067d1632f92656859fb9143e3fa9635670 100644 (file)
@@ -27,6 +27,7 @@ static const char * const fw_upload_err_str[] = {
        [FW_UPLOAD_ERR_INVALID_SIZE] = "invalid-file-size",
        [FW_UPLOAD_ERR_RW_ERROR]     = "read-write-error",
        [FW_UPLOAD_ERR_WEAROUT]      = "flash-wearout",
+       [FW_UPLOAD_ERR_FW_INVALID]   = "firmware-invalid",
 };
 
 static const char *fw_upload_progress(struct device *dev,
index de7fea3bca51e51162956abee79bcb9d5aad290f..0311858b46cef2d0b966e7420159f580187f95bc 100644 (file)
@@ -27,6 +27,7 @@ struct firmware {
  * @FW_UPLOAD_ERR_INVALID_SIZE: invalid firmware image size
  * @FW_UPLOAD_ERR_RW_ERROR: read or write to HW failed, see kernel log
  * @FW_UPLOAD_ERR_WEAROUT: FLASH device is approaching wear-out, wait & retry
+ * @FW_UPLOAD_ERR_FW_INVALID: invalid firmware file
  * @FW_UPLOAD_ERR_MAX: Maximum error code marker
  */
 enum fw_upload_err {
@@ -38,6 +39,7 @@ enum fw_upload_err {
        FW_UPLOAD_ERR_INVALID_SIZE,
        FW_UPLOAD_ERR_RW_ERROR,
        FW_UPLOAD_ERR_WEAROUT,
+       FW_UPLOAD_ERR_FW_INVALID,
        FW_UPLOAD_ERR_MAX
 };
 
index add4699fc6cd4577c693e1473db3b1b9b2003d9f..9cfdcd6d21db533881830a9f3744e71c02c4c602 100644 (file)
@@ -1132,6 +1132,7 @@ static const char * const fw_upload_err_str[] = {
        [FW_UPLOAD_ERR_INVALID_SIZE] = "invalid-file-size",
        [FW_UPLOAD_ERR_RW_ERROR]     = "read-write-error",
        [FW_UPLOAD_ERR_WEAROUT]      = "flash-wearout",
+       [FW_UPLOAD_ERR_FW_INVALID]   = "firmware-invalid",
 };
 
 static void upload_err_inject_error(struct test_firmware_upload *tst,