x86/microcode/AMD: Use find_microcode_in_initrd()
authorBorislav Petkov <bp@suse.de>
Fri, 20 Jan 2017 20:29:49 +0000 (21:29 +0100)
committerThomas Gleixner <tglx@linutronix.de>
Mon, 23 Jan 2017 09:02:48 +0000 (10:02 +0100)
Use the generic helper instead of semi-open-coding the procedure.

Signed-off-by: Borislav Petkov <bp@suse.de>
Reviewed-by: Thomas Gleixner <tglx@linutronix.de>
Link: http://lkml.kernel.org/r/20170120202955.4091-11-bp@alien8.de
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
arch/x86/kernel/cpu/microcode/amd.c

index 4cbfe70cf458e89b85d3a9698eb1ebfe84567de5..7727f278de58ba16950d14709d2b73547f02514b 100644 (file)
@@ -337,17 +337,15 @@ void load_ucode_amd_ap(unsigned int cpuid_1_eax)
 
        /* First AP hasn't cached it yet, go through the blob. */
        if (!cont.data) {
-               struct cpio_data cp = { NULL, 0, "" };
+               struct cpio_data cp;
 
                if (cont.size == -1)
                        return;
 
 reget:
                if (!get_builtin_microcode(&cp, x86_family(cpuid_1_eax))) {
-#ifdef CONFIG_BLK_DEV_INITRD
-                       cp = find_cpio_data(ucode_path, (void *)initrd_start,
-                                           initrd_end - initrd_start, NULL);
-#endif
+                       cp = find_microcode_in_initrd(ucode_path, false);
+
                        if (!(cp.data && cp.size)) {
                                /*
                                 * Mark it so that other APs do not scan again
@@ -401,13 +399,9 @@ int __init save_microcode_in_initrd_amd(unsigned int cpuid_1_eax)
 
        if (!cont.data) {
                if (IS_ENABLED(CONFIG_X86_32) && (cont.size != -1)) {
-                       struct cpio_data cp = { NULL, 0, "" };
-
-#ifdef CONFIG_BLK_DEV_INITRD
-                       cp = find_cpio_data(ucode_path, (void *)initrd_start,
-                                           initrd_end - initrd_start, NULL);
-#endif
+                       struct cpio_data cp;
 
+                       cp = find_microcode_in_initrd(ucode_path, false);
                        if (!(cp.data && cp.size)) {
                                cont.size = -1;
                                return -EINVAL;