Commit 01c3a392 authored by Matt Carlson's avatar Matt Carlson Committed by David S. Miller

tg3: Fix NVRAM selftest

The tg3 NVRAM selftest actually fails when validating the checksum of
the legacy NVRAM format.  However, the test still reported success
because the last update of the return code was a success from the NVRAM
reads.  This patch fixes the code so that the error return code defaults
to a failure status.  Then the patch fixes the reason why the checsum
validation failed.
Signed-off-by: default avatarMatt Carlson <mcarlson@broadcom.com>
Reviewed-by: default avatarMichael Chan <mchan@broadcom.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent bb18bb94
...@@ -10487,14 +10487,16 @@ static int tg3_test_nvram(struct tg3 *tp) ...@@ -10487,14 +10487,16 @@ static int tg3_test_nvram(struct tg3 *tp)
goto out; goto out;
} }
err = -EIO;
/* Bootstrap checksum at offset 0x10 */ /* Bootstrap checksum at offset 0x10 */
csum = calc_crc((unsigned char *) buf, 0x10); csum = calc_crc((unsigned char *) buf, 0x10);
if (csum != be32_to_cpu(buf[0x10/4])) if (csum != le32_to_cpu(buf[0x10/4]))
goto out; goto out;
/* Manufacturing block starts at offset 0x74, checksum at 0xfc */ /* Manufacturing block starts at offset 0x74, checksum at 0xfc */
csum = calc_crc((unsigned char *) &buf[0x74/4], 0x88); csum = calc_crc((unsigned char *) &buf[0x74/4], 0x88);
if (csum != be32_to_cpu(buf[0xfc/4])) if (csum != le32_to_cpu(buf[0xfc/4]))
goto out; goto out;
err = 0; err = 0;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment