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