x86, microcode, AMD: Correct buf references
Both the equivalence table and the microcode patch types are u32. Access them properly through the buf-ptr. Signed-off-by: Borislav Petkov <borislav.petkov@amd.com>
This commit is contained in:
parent
2c53b436a3
commit
86b445676d
@ -157,7 +157,7 @@ static int apply_microcode_amd(int cpu)
|
|||||||
static unsigned int verify_ucode_size(int cpu, const u8 *buf, unsigned int size)
|
static unsigned int verify_ucode_size(int cpu, const u8 *buf, unsigned int size)
|
||||||
{
|
{
|
||||||
struct cpuinfo_x86 *c = &cpu_data(cpu);
|
struct cpuinfo_x86 *c = &cpu_data(cpu);
|
||||||
unsigned int max_size, actual_size;
|
u32 max_size, actual_size;
|
||||||
|
|
||||||
#define F1XH_MPB_MAX_SIZE 2048
|
#define F1XH_MPB_MAX_SIZE 2048
|
||||||
#define F14H_MPB_MAX_SIZE 1824
|
#define F14H_MPB_MAX_SIZE 1824
|
||||||
@ -175,7 +175,7 @@ static unsigned int verify_ucode_size(int cpu, const u8 *buf, unsigned int size)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
actual_size = buf[4] + (buf[5] << 8);
|
actual_size = *(u32 *)(buf + 4);
|
||||||
|
|
||||||
if (actual_size > size || actual_size > max_size) {
|
if (actual_size > size || actual_size > max_size) {
|
||||||
pr_err("section size mismatch\n");
|
pr_err("section size mismatch\n");
|
||||||
@ -191,7 +191,7 @@ get_next_ucode(int cpu, const u8 *buf, unsigned int size, unsigned int *mc_size)
|
|||||||
struct microcode_header_amd *mc = NULL;
|
struct microcode_header_amd *mc = NULL;
|
||||||
unsigned int actual_size = 0;
|
unsigned int actual_size = 0;
|
||||||
|
|
||||||
if (buf[0] != UCODE_UCODE_TYPE) {
|
if (*(u32 *)buf != UCODE_UCODE_TYPE) {
|
||||||
pr_err("invalid type field in container file section header\n");
|
pr_err("invalid type field in container file section header\n");
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user