diff options
Diffstat (limited to 'arch/x86/kernel/microcode_amd.c')
-rw-r--r-- | arch/x86/kernel/microcode_amd.c | 17 |
1 files changed, 8 insertions, 9 deletions
diff --git a/arch/x86/kernel/microcode_amd.c b/arch/x86/kernel/microcode_amd.c index 62058e9c8b4e..829415208ff8 100644 --- a/arch/x86/kernel/microcode_amd.c +++ b/arch/x86/kernel/microcode_amd.c | |||
@@ -263,21 +263,20 @@ static void * get_next_ucode(u8 *buf, unsigned int size, | |||
263 | unsigned int *mc_size) | 263 | unsigned int *mc_size) |
264 | { | 264 | { |
265 | unsigned int total_size; | 265 | unsigned int total_size; |
266 | #define UCODE_UNKNOWN_HDR 8 | 266 | #define UCODE_CONTAINER_SECTION_HDR 8 |
267 | u8 hdr[UCODE_UNKNOWN_HDR]; | 267 | u8 section_hdr[UCODE_CONTAINER_SECTION_HDR]; |
268 | void *mc; | 268 | void *mc; |
269 | 269 | ||
270 | if (get_ucode_data(hdr, buf, UCODE_UNKNOWN_HDR)) | 270 | if (get_ucode_data(section_hdr, buf, UCODE_CONTAINER_SECTION_HDR)) |
271 | return NULL; | 271 | return NULL; |
272 | 272 | ||
273 | if (hdr[0] != UCODE_UCODE_TYPE) { | 273 | if (section_hdr[0] != UCODE_UCODE_TYPE) { |
274 | printk(KERN_ERR "microcode: error! " | 274 | printk(KERN_ERR "microcode: error! " |
275 | "Wrong microcode payload type field\n"); | 275 | "Wrong microcode payload type field\n"); |
276 | return NULL; | 276 | return NULL; |
277 | } | 277 | } |
278 | 278 | ||
279 | /* FIXME! dimm: Why not by means of get_totalsize(hdr)? */ | 279 | total_size = (unsigned long) (section_hdr[4] + (section_hdr[5] << 8)); |
280 | total_size = (unsigned long) (hdr[4] + (hdr[5] << 8)); | ||
281 | 280 | ||
282 | printk(KERN_INFO "microcode: size %u, total_size %u\n", | 281 | printk(KERN_INFO "microcode: size %u, total_size %u\n", |
283 | size, total_size); | 282 | size, total_size); |
@@ -290,13 +289,13 @@ static void * get_next_ucode(u8 *buf, unsigned int size, | |||
290 | mc = vmalloc(UCODE_MAX_SIZE); | 289 | mc = vmalloc(UCODE_MAX_SIZE); |
291 | if (mc) { | 290 | if (mc) { |
292 | memset(mc, 0, UCODE_MAX_SIZE); | 291 | memset(mc, 0, UCODE_MAX_SIZE); |
293 | if (get_ucode_data(mc, buf + UCODE_UNKNOWN_HDR, total_size)) { | 292 | if (get_ucode_data(mc, buf + UCODE_CONTAINER_SECTION_HDR, total_size)) { |
294 | vfree(mc); | 293 | vfree(mc); |
295 | mc = NULL; | 294 | mc = NULL; |
296 | } else | 295 | } else |
297 | *mc_size = total_size + UCODE_UNKNOWN_HDR; | 296 | *mc_size = total_size + UCODE_CONTAINER_SECTION_HDR; |
298 | } | 297 | } |
299 | #undef UCODE_UNKNOWN_HDR | 298 | #undef UCODE_CONTAINER_SECTION_HDR |
300 | return mc; | 299 | return mc; |
301 | } | 300 | } |
302 | 301 | ||