net/sfc/base: simplify verify result handling
authorAndy Moreton <amoreton@solarflare.com>
Thu, 16 Nov 2017 08:03:52 +0000 (08:03 +0000)
committerFerruh Yigit <ferruh.yigit@intel.com>
Tue, 16 Jan 2018 17:47:49 +0000 (18:47 +0100)
Simplify verify result handling in NVRAM update finish

Signed-off-by: Andy Moreton <amoreton@solarflare.com>
Signed-off-by: Andrew Rybchenko <arybchenko@solarflare.com>
drivers/net/sfc/base/efx_nvram.c

index 14ff829..7d4c9a0 100644 (file)
@@ -944,24 +944,23 @@ efx_mcdi_nvram_update_finish(
                goto fail1;
        }
 
-       if (encp->enc_fw_verified_nvram_update_required == B_FALSE) {
-               /* Report success if verified updates are not supported. */
-               result = MC_CMD_NVRAM_VERIFY_RC_SUCCESS;
-       } else {
-               /* Firmware-verified NVRAM updates are required */
-               if (req.emr_out_length_used <
-                   MC_CMD_NVRAM_UPDATE_FINISH_V2_OUT_LEN) {
+       if (req.emr_out_length_used < MC_CMD_NVRAM_UPDATE_FINISH_V2_OUT_LEN) {
+               result = MC_CMD_NVRAM_VERIFY_RC_UNKNOWN;
+               if (encp->enc_fw_verified_nvram_update_required) {
+                       /* Mandatory verification result is missing */
                        rc = EMSGSIZE;
                        goto fail2;
                }
+       } else {
                result =
                    MCDI_OUT_DWORD(req, NVRAM_UPDATE_FINISH_V2_OUT_RESULT_CODE);
+       }
 
-               if (result != MC_CMD_NVRAM_VERIFY_RC_SUCCESS) {
-                       /* Mandatory verification failed */
-                       rc = EINVAL;
-                       goto fail3;
-               }
+       if ((encp->enc_fw_verified_nvram_update_required) &&
+           (result != MC_CMD_NVRAM_VERIFY_RC_SUCCESS)) {
+               /* Mandatory verification failed */
+               rc = EINVAL;
+               goto fail3;
        }
 
        if (resultp != NULL)