diff options
| -rw-r--r-- | drivers/firmware/dmi_scan.c | 13 |
1 files changed, 7 insertions, 6 deletions
diff --git a/drivers/firmware/dmi_scan.c b/drivers/firmware/dmi_scan.c index c5f7b4e9eb6c..a44b87c7b45c 100644 --- a/drivers/firmware/dmi_scan.c +++ b/drivers/firmware/dmi_scan.c | |||
| @@ -93,12 +93,6 @@ static void dmi_table(u8 *buf, int len, int num, | |||
| 93 | const struct dmi_header *dm = (const struct dmi_header *)data; | 93 | const struct dmi_header *dm = (const struct dmi_header *)data; |
| 94 | 94 | ||
| 95 | /* | 95 | /* |
| 96 | * 7.45 End-of-Table (Type 127) [SMBIOS reference spec v3.0.0] | ||
| 97 | */ | ||
| 98 | if (dm->type == DMI_ENTRY_END_OF_TABLE) | ||
| 99 | break; | ||
| 100 | |||
| 101 | /* | ||
| 102 | * We want to know the total length (formatted area and | 96 | * We want to know the total length (formatted area and |
| 103 | * strings) before decoding to make sure we won't run off the | 97 | * strings) before decoding to make sure we won't run off the |
| 104 | * table in dmi_decode or dmi_string | 98 | * table in dmi_decode or dmi_string |
| @@ -108,6 +102,13 @@ static void dmi_table(u8 *buf, int len, int num, | |||
| 108 | data++; | 102 | data++; |
| 109 | if (data - buf < len - 1) | 103 | if (data - buf < len - 1) |
| 110 | decode(dm, private_data); | 104 | decode(dm, private_data); |
| 105 | |||
| 106 | /* | ||
| 107 | * 7.45 End-of-Table (Type 127) [SMBIOS reference spec v3.0.0] | ||
| 108 | */ | ||
| 109 | if (dm->type == DMI_ENTRY_END_OF_TABLE) | ||
| 110 | break; | ||
| 111 | |||
| 111 | data += 2; | 112 | data += 2; |
| 112 | i++; | 113 | i++; |
| 113 | } | 114 | } |
