AMD EPYC microcode update bug?
From: Gabriel C
Date: Tue Jan 09 2018 - 17:29:27 EST
Hello ,
I'm testing an EPYC system right now with 2 EPYC 7281 16-Core Processors.
I'm on 4.15.0-rc7 and tested an update to microcode_amd_fam17h.bin.
First run was made by using the early microcode option with dracut[1]
so loading from a initrd. the driver reported 63 updated CPUs while CPU0
got still old microcode.
snip
crazy@ant:~/fw$ dmesg | grep microcode
[ 2.615876] microcode: microcode updated early to new patch_level=0x08001213
[ 2.615906] microcode: CPU0: patch_level=0x08001207
[ 2.615920] microcode: CPU1: patch_level=0x08001213
...
crazy@ant:~/fw$ cat /proc/cpuinfo | head -n 30
processor : 0
vendor_id : AuthenticAMD
cpu family : 23
model : 1
model name : AMD EPYC 7281 16-Core Processor
stepping : 2
microcode : 0x8001207
....
After reloading the microcode with
echo 1 > /sys/devices/system/cpu/microcode/reload
CPU0 got new microcode too.
Now I tested the same but without initrd early microcode loading
and CONFIG_EXTRA_FIRMWARE set like this:
CONFIG_EXTRA_FIRMWARE="amd-ucode/microcode_amd.bin
amd-ucode/microcode_amd_fam15h.bin amd-ucode/microcode_amd_fam16h.bin
amd-ucode/microcode_amd_fam17h.bin"
This time all CPUs got update fine without the need of reloading the microcode.
Is that some sort timing problem ?
Also I notice on a Intel system the 'early updating' means that , is
the first I see on dmesg
while on AMD system it seems to fire up much later. Why is that ?
Regards,
Gabriel C
1. Fix for Fam17 micrcode :
https://github.com/dracutdevs/dracut/commit/19453dc8744e6a59725c43b61b2e3db01cb4c57c#diff-bf0c6db1d4aaaa22a88b2649ddbfcd2a