diff options
| author | Jean Delvare <jdelvare@suse.de> | 2015-06-25 03:06:56 -0400 |
|---|---|---|
| committer | Jean Delvare <jdelvare@suse.de> | 2015-06-25 03:06:56 -0400 |
| commit | 6e0ad59e3d838a2887e7aa657baee5896030d009 (patch) | |
| tree | f28be09d52fab1cbc528db8d485370b25cc17317 | |
| parent | eb4c5ea50e60aa8faaf6aae762cb06ee1c8e0b8e (diff) | |
firmware: dmi_scan: Trim DMI table length before exporting it
The SMBIOS v3 entry points specify a maximum length for the DMI table,
not the exact length. Thus there may be garbage after the end-of-table
marker, which we don't want to export to user-space. Adjust dmi_len
when we find the end-of-table marker, so that only the actual table
payload is exported.
Signed-off-by: Jean Delvare <jdelvare@suse.de>
Cc: Ivan Khoronzhuk <ivan.khoronzhuk@globallogic.com>
| -rw-r--r-- | drivers/firmware/dmi_scan.c | 15 |
1 files changed, 10 insertions, 5 deletions
diff --git a/drivers/firmware/dmi_scan.c b/drivers/firmware/dmi_scan.c index 14a89123cb7c..7fdf2868a276 100644 --- a/drivers/firmware/dmi_scan.c +++ b/drivers/firmware/dmi_scan.c | |||
| @@ -108,6 +108,9 @@ static void dmi_decode_table(u8 *buf, | |||
| 108 | if (data - buf < dmi_len - 1) | 108 | if (data - buf < dmi_len - 1) |
| 109 | decode(dm, private_data); | 109 | decode(dm, private_data); |
| 110 | 110 | ||
| 111 | data += 2; | ||
| 112 | i++; | ||
| 113 | |||
| 111 | /* | 114 | /* |
| 112 | * 7.45 End-of-Table (Type 127) [SMBIOS reference spec v3.0.0] | 115 | * 7.45 End-of-Table (Type 127) [SMBIOS reference spec v3.0.0] |
| 113 | * For tables behind a 64-bit entry point, we have no item | 116 | * For tables behind a 64-bit entry point, we have no item |
| @@ -118,10 +121,11 @@ static void dmi_decode_table(u8 *buf, | |||
| 118 | */ | 121 | */ |
| 119 | if (!dmi_num && dm->type == DMI_ENTRY_END_OF_TABLE) | 122 | if (!dmi_num && dm->type == DMI_ENTRY_END_OF_TABLE) |
| 120 | break; | 123 | break; |
| 121 | |||
| 122 | data += 2; | ||
| 123 | i++; | ||
| 124 | } | 124 | } |
| 125 | |||
| 126 | /* Trim DMI table length if needed */ | ||
| 127 | if (dmi_len > data - buf) | ||
| 128 | dmi_len = data - buf; | ||
| 125 | } | 129 | } |
| 126 | 130 | ||
| 127 | static phys_addr_t dmi_base; | 131 | static phys_addr_t dmi_base; |
| @@ -130,8 +134,9 @@ static int __init dmi_walk_early(void (*decode)(const struct dmi_header *, | |||
| 130 | void *)) | 134 | void *)) |
| 131 | { | 135 | { |
| 132 | u8 *buf; | 136 | u8 *buf; |
| 137 | u32 orig_dmi_len = dmi_len; | ||
| 133 | 138 | ||
| 134 | buf = dmi_early_remap(dmi_base, dmi_len); | 139 | buf = dmi_early_remap(dmi_base, orig_dmi_len); |
| 135 | if (buf == NULL) | 140 | if (buf == NULL) |
| 136 | return -1; | 141 | return -1; |
| 137 | 142 | ||
| @@ -139,7 +144,7 @@ static int __init dmi_walk_early(void (*decode)(const struct dmi_header *, | |||
| 139 | 144 | ||
| 140 | add_device_randomness(buf, dmi_len); | 145 | add_device_randomness(buf, dmi_len); |
| 141 | 146 | ||
| 142 | dmi_early_unmap(buf, dmi_len); | 147 | dmi_early_unmap(buf, orig_dmi_len); |
| 143 | return 0; | 148 | return 0; |
| 144 | } | 149 | } |
| 145 | 150 | ||
