aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJean Delvare <jdelvare@suse.de>2015-06-25 03:06:56 -0400
committerJean Delvare <jdelvare@suse.de>2015-06-25 03:06:56 -0400
commit6e0ad59e3d838a2887e7aa657baee5896030d009 (patch)
treef28be09d52fab1cbc528db8d485370b25cc17317
parenteb4c5ea50e60aa8faaf6aae762cb06ee1c8e0b8e (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.c15
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
127static phys_addr_t dmi_base; 131static 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