mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-11-30 06:16:46 +07:00
x86/microcode/AMD: Sanitize apply_microcode_early_amd()
Make it simply return bool to denote whether it found a container or not and return the pointer to the container and its size in the handed-in container pointer instead, as returning a struct was just silly. Signed-off-by: Borislav Petkov <bp@suse.de> Cc: Jürgen Gross <jgross@suse.com> Cc: Boris Ostrovsky <boris.ostrovsky@oracle.com> Link: http://lkml.kernel.org/r/20161218164414.9649-3-bp@alien8.de Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
This commit is contained in:
parent
8feaa64a9a
commit
200d355316
@ -216,17 +216,18 @@ static int __apply_microcode_amd(struct microcode_amd *mc_amd)
|
|||||||
* and on 32-bit during save_microcode_in_initrd_amd() -- we can call
|
* and on 32-bit during save_microcode_in_initrd_amd() -- we can call
|
||||||
* load_microcode_amd() to save equivalent cpu table and microcode patches in
|
* load_microcode_amd() to save equivalent cpu table and microcode patches in
|
||||||
* kernel heap memory.
|
* kernel heap memory.
|
||||||
|
*
|
||||||
|
* Returns true if container found (sets @ret_cont), false otherwise.
|
||||||
*/
|
*/
|
||||||
static struct container
|
static bool apply_microcode_early_amd(void *ucode, size_t size, bool save_patch,
|
||||||
apply_microcode_early_amd(void *ucode, size_t size, bool save_patch)
|
struct container *ret_cont)
|
||||||
{
|
{
|
||||||
struct container ret = { NULL, 0 };
|
|
||||||
u8 (*patch)[PATCH_MAX_SIZE];
|
u8 (*patch)[PATCH_MAX_SIZE];
|
||||||
|
u32 rev, *header, *new_rev;
|
||||||
|
struct container ret;
|
||||||
int offset, left;
|
int offset, left;
|
||||||
u32 rev, *header;
|
|
||||||
u8 *data;
|
|
||||||
u16 eq_id = 0;
|
u16 eq_id = 0;
|
||||||
u32 *new_rev;
|
u8 *data;
|
||||||
|
|
||||||
#ifdef CONFIG_X86_32
|
#ifdef CONFIG_X86_32
|
||||||
new_rev = (u32 *)__pa_nodebug(&ucode_new_rev);
|
new_rev = (u32 *)__pa_nodebug(&ucode_new_rev);
|
||||||
@ -237,11 +238,11 @@ apply_microcode_early_amd(void *ucode, size_t size, bool save_patch)
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (check_current_patch_level(&rev, true))
|
if (check_current_patch_level(&rev, true))
|
||||||
return (struct container){ NULL, 0 };
|
return false;
|
||||||
|
|
||||||
eq_id = find_proper_container(ucode, size, &ret);
|
eq_id = find_proper_container(ucode, size, &ret);
|
||||||
if (!eq_id)
|
if (!eq_id)
|
||||||
return (struct container){ NULL, 0 };
|
return false;
|
||||||
|
|
||||||
this_equiv_id = eq_id;
|
this_equiv_id = eq_id;
|
||||||
header = (u32 *)ret.data;
|
header = (u32 *)ret.data;
|
||||||
@ -275,7 +276,11 @@ apply_microcode_early_amd(void *ucode, size_t size, bool save_patch)
|
|||||||
data += offset;
|
data += offset;
|
||||||
left -= offset;
|
left -= offset;
|
||||||
}
|
}
|
||||||
return ret;
|
|
||||||
|
if (ret_cont)
|
||||||
|
*ret_cont = ret;
|
||||||
|
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool get_builtin_microcode(struct cpio_data *cp, unsigned int family)
|
static bool get_builtin_microcode(struct cpio_data *cp, unsigned int family)
|
||||||
@ -319,7 +324,7 @@ void __init load_ucode_amd_bsp(unsigned int family)
|
|||||||
/* Get BSP's CPUID.EAX(1), needed in load_microcode_amd() */
|
/* Get BSP's CPUID.EAX(1), needed in load_microcode_amd() */
|
||||||
uci->cpu_sig.sig = cpuid_eax(1);
|
uci->cpu_sig.sig = cpuid_eax(1);
|
||||||
|
|
||||||
apply_microcode_early_amd(cp.data, cp.size, true);
|
apply_microcode_early_amd(cp.data, cp.size, true, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef CONFIG_X86_32
|
#ifdef CONFIG_X86_32
|
||||||
@ -351,7 +356,7 @@ void load_ucode_amd_ap(unsigned int family)
|
|||||||
* This would set amd_ucode_patch above so that the following APs can
|
* This would set amd_ucode_patch above so that the following APs can
|
||||||
* use it directly instead of going down this path again.
|
* use it directly instead of going down this path again.
|
||||||
*/
|
*/
|
||||||
apply_microcode_early_amd(cp.data, cp.size, true);
|
apply_microcode_early_amd(cp.data, cp.size, true, NULL);
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
void load_ucode_amd_ap(unsigned int family)
|
void load_ucode_amd_ap(unsigned int family)
|
||||||
@ -389,8 +394,7 @@ void load_ucode_amd_ap(unsigned int family)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
cont = apply_microcode_early_amd(cp.data, cp.size, false);
|
if (!apply_microcode_early_amd(cp.data, cp.size, false, &cont)) {
|
||||||
if (!(cont.data && cont.size)) {
|
|
||||||
cont.size = -1;
|
cont.size = -1;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user