View previous topic :: View next topic |
Author |
Message |
ConiKost Developer
Joined: 11 Jan 2005 Posts: 1369
|
Posted: Wed Jan 08, 2025 12:05 am Post subject: early and late microcode loading does not work |
|
|
I am having troble to get my intel microcode updated. I am out of ideas, what could go wrong.
CPU: Xeon E3-1275v6
Kernel: 6.12.8
Default microcode from BIOS seems:
Code: | [ 17.182429] microcode: Current revision: 0x000000f8 |
Needed options are enabled:
Code: | CONFIG_EXTRA_FIRMWARE="i915/kbl_dmc_ver1_04.bin i915/kbl_guc_70.1.1.bin i915/kbl_huc_4.0.0.bin intel-ucode/06-9e-09 intel-ucode/06-9e-0a intel-ucode/06-9e-0b intel-ucode/06-9e-0c intel-ucode/06-9e-0d"
CONFIG_EXTRA_FIRMWARE_DIR="/lib/firmware"
CONFIG_MICROCODE=y
CONFIG_MICROCODE_LATE_LOADING=y |
According to kernel documentation, loading early microcode via including it in kernel should work: The Linux Microcode Loader (23.4. Builtin microcode).
Correct files are also present:
Code: | $ ls -la /lib/firmware/intel-ucode
-rw-r--r-- 1 root root 108544 7. Jan 18:22 06-9e-09
-rw-r--r-- 1 root root 105472 7. Jan 18:22 06-9e-0a
-rw-r--r-- 1 root root 106496 7. Jan 18:22 06-9e-0b
-rw-r--r-- 1 root root 106496 7. Jan 18:22 06-9e-0c
-rw-r--r-- 1 root root 106496 7. Jan 18:22 06-9e-0d |
According to iucode_tool, files are correct:
Code: | $ iucode_tool -lS /lib/firmware/intel-ucode
iucode_tool: system has processor(s) with signature 0x000906e9
microcode bundle 1: /lib/firmware/intel-ucode/06-9e-0d
microcode bundle 2: /lib/firmware/intel-ucode/06-9e-0a
microcode bundle 3: /lib/firmware/intel-ucode/06-9e-09
microcode bundle 4: /lib/firmware/intel-ucode/06-9e-0b
microcode bundle 5: /lib/firmware/intel-ucode/06-9e-0c
selected microcodes:
003/001: sig 0x000906e9, pf_mask 0x2a, 2023-09-28, rev 0x00f8, size 108544
002/001: sig 0x000906ea, pf_mask 0x22, 2024-02-01, rev 0x00f8, size 105472
004/001: sig 0x000906eb, pf_mask 0x02, 2024-02-01, rev 0x00f6, size 106496
005/001: sig 0x000906ec, pf_mask 0x22, 2024-02-01, rev 0x00f8, size 106496
001/001: sig 0x000906ed, pf_mask 0x22, 2024-02-05, rev 0x0100, size 106496
|
Yet it does not work. I am not seing any message in "dmesg" which could say, that microcode has been early updated. Even "cat /proc/cpuinfo" confirms, that only stock microcode is enabled.
While discouraged by upsteam, I also wanted to test loading "late" microcode. This also fails for me.
Code: | $ ls -la /sys/devices/system/cpu/microcode/reload
--w------- 1 root root 4096 8. Jan 01:03 /sys/devices/system/cpu/microcode/reload
$ echo 1 > /sys/devices/system/cpu/microcode/reload
echo: write error: no such file or directory
|
But 'dmesg' producde a single log output:
Code: | [ 1789.362419] Loading firmware: intel-ucode/06-9e-09 |
The file is clearly there. So what I am missing here? IMHO all is correct according documentation and should work. |
|
Back to top |
|
|
pietinger Moderator
Joined: 17 Oct 2006 Posts: 5292 Location: Bavaria
|
|
Back to top |
|
|
ConiKost Developer
Joined: 11 Jan 2005 Posts: 1369
|
Posted: Wed Jan 08, 2025 7:04 am Post subject: |
|
|
Are you really sure, that this is correct? I have my doubts. But before I explain, I have a question: Do all the same CPU models should always get the same current microcode?
I have a different system, which means not the same mainboard, but the same CPU. But not running Gentoo, but instead Arch Linux.
CPU: E3-1275v6
Mainboard: Fujitsu D3417-B2
Code: | [ 6.919330] microcode: Current revision: 0x000000fa
[ 6.919333] microcode: Updated early from: 0x000000ca |
You can see, that even the initial microcode 0xca is older than 0xf8 on my other mainboard but updated to 0xfa.
And it is the same cpu:
Code: | $ cat /proc/cpuinfo|grep name
model name : Intel(R) Xeon(R) CPU E3-1275 v6 @ 3.80GHz
$ cat /proc/cpuinfo|grep microcode
microcode : 0xfa
|
So how can be explained that? Based on that I would also expect, that 000000f8 is also being updated to 000000fa?
The system, where it's not updated is a Supermicro X11SSi-LN4F, but same cpu.
Code: | $ cat /proc/cpuinfo|grep name
model name : Intel(R) Xeon(R) CPU E3-1275 v6 @ 3.80GHz
$ cat /proc/cpuinfo|grep microcode
microcode : 0xf8
|
pietinger wrote: |
Code: | [ 9.323217] microcode: Current revision: 0x0000012b
[ 9.323219] microcode: Updated early from: 0x00000113 |
Be aware that the old message at timestamp 0.0000 does not exist anymore (see the Update in: https://forums.gentoo.org/viewtopic-t-1065464.html)
|
Yes, I know.
--------
Update: I just checked newest sys-firmware/intel-microcode-20241112_p20241103. This includes 000000fa.
Code: | $ iucode_tool -lS /lib/firmware/intel-ucode
iucode_tool: system has processor(s) with signature 0x000906e9
microcode bundle 1: /lib/firmware/intel-ucode/06-9e-0d
microcode bundle 2: /lib/firmware/intel-ucode/06-9e-0a
microcode bundle 3: /lib/firmware/intel-ucode/06-9e-09
microcode bundle 4: /lib/firmware/intel-ucode/06-9e-0b
microcode bundle 5: /lib/firmware/intel-ucode/06-9e-0c
selected microcodes:
003/001: sig 0x000906e9, pf_mask 0x2a, 2024-03-07, rev 0x00fa, size 106496
002/001: sig 0x000906ea, pf_mask 0x22, 2024-02-01, rev 0x00f8, size 105472
004/001: sig 0x000906eb, pf_mask 0x02, 2024-02-01, rev 0x00f6, size 106496
005/001: sig 0x000906ec, pf_mask 0x22, 2024-02-01, rev 0x00f8, size 106496
001/001: sig 0x000906ed, pf_mask 0x22, 2024-02-05, rev 0x0100, size 106496 |
But it's not being loaded. As reported, no early and not late. No update message during early and same error message for late loading. |
|
Back to top |
|
|
pietinger Moderator
Joined: 17 Oct 2006 Posts: 5292 Location: Bavaria
|
Posted: Wed Jan 08, 2025 12:28 pm Post subject: |
|
|
ConiKost wrote: | Are you really sure, that this is correct? I have my doubts. But before I explain, I have a question: Do all the same CPU models should always get the same current microcode? |
Yes, the - exact - same CPU models use the same microcode ... but a CPU can have different steppings. What happens if you make the following query for all “identical” CPUs:
Code: | # dmesg | grep stepping |
Is it really the same ..-..-09 (stepping) for your other CPU?
(You get the same information also with "lscpu" and "cat /proc/cpuinfo"; but here it is in decimal and NOT in hexadecimal; from my station:
Code: | [ 4.376483] smpboot: CPU0: 13th Gen Intel(R) Core(TM) i9-13900K (family: 0x6, model: 0xb7, stepping: 0x1)
<=>
cpu family : 6
model : 183
stepping : 1
=> 183dec == b7hex
and therefore I have/use:
CONFIG_EXTRA_FIRMWARE="intel-ucode/06-b7-01 i915/adls_dmc_ver2_01.bin rtl_nic/rtl8125b-2.fw i915/tgl_guc_70.bin i915/tgl_huc.bin" |
BTW: You need only ONE microcode file in your CONFIG_EXTRA_FIRMWARE
... and I really dont't recommend "late loading".
.. and I am not a fan of "iucode_tool" ... because it confuse people _________________ https://wiki.gentoo.org/wiki/User:Pietinger |
|
Back to top |
|
|
pietinger Moderator
Joined: 17 Oct 2006 Posts: 5292 Location: Bavaria
|
Posted: Wed Jan 08, 2025 1:38 pm Post subject: |
|
|
I have checked it again: The last update for THIS CPU (-09) was on 20240312 (from previously f4) to f8. Since then there have only been updates for the other CPUs (-0a,-0b,0c and -0d) on 20240813 ... but there are also unofficial updates ... maybe ARCH uses them? _________________ https://wiki.gentoo.org/wiki/User:Pietinger |
|
Back to top |
|
|
ConiKost Developer
Joined: 11 Jan 2005 Posts: 1369
|
Posted: Wed Jan 08, 2025 1:47 pm Post subject: |
|
|
pietinger wrote: | Yes, the - exact - same CPU models use the same microcode ... but a CPU can have different steppings. What happens if you make the following query for all “identical” CPUs:
Code: | # dmesg | grep stepping |
|
Well, so 0xfa should be the latest Microcode for my CPU.
pietinger wrote: |
Is it really the same ..-..-09 (stepping) for your other CPU?
|
Yes, I just checked. Both machines are stepping 9.
pietinger wrote: |
(You get the same information also with "lscpu" and "cat /proc/cpuinfo"; but here it is in decimal and NOT in hexadecimal; from my station:
[code][ 4.376483] smpboot: CPU0: 13th Gen Intel(R) Core(TM) i9-13900K (family: 0x6, model: 0xb7, stepping: 0x1)
<=>
cpu family : 6
model : 183
stepping : 1
=> 183dec == b7hex
|
I can't say, why your is other. But your CPU is much newer than my Xeon (Kaby Lake 7th Gen).
pietinger wrote: |
BTW: You need only ONE microcode file in your CONFIG_EXTRA_FIRMWARE
|
Thats a good hint, thank you!
pietinger wrote: | ... and I really dont't recommend "late loading".
.. and I am not a fan of "iucode_tool" ... because it confuse people |
I know. It was meant as last resort for testing. Still: Why does it not work? At least I would expect, that this works. |
|
Back to top |
|
|
Zucca Moderator
Joined: 14 Jun 2007 Posts: 3843 Location: Rasi, Finland
|
Posted: Wed Jan 08, 2025 3:00 pm Post subject: |
|
|
Side note:CONFIG_MICROCODE_LATE_LOADING is (being?) deprecated, since it has some issues. _________________ ..: Zucca :..
My gentoo installs: | init=/sbin/openrc-init
-systemd -logind -elogind seatd |
Quote: | I am NaN! I am a man! |
|
|
Back to top |
|
|
pietinger Moderator
Joined: 17 Oct 2006 Posts: 5292 Location: Bavaria
|
Posted: Wed Jan 08, 2025 3:01 pm Post subject: |
|
|
ConiKost wrote: | I know. It was meant as last resort for testing. Still: Why does it not work? At least I would expect, that this works. |
Have you checked the file /lib/firmware/intel-ucode/06-9e-09 from ARCH with our Gentoo for equality?
If yes,
Now comes a very “simple” question - I would like to say in advance that there are two ways to do an (early) microcode update:
1. as a “built-in” file “in” the kernel, or
2. as a file located in an initramfs (if you have a kernel with initramfs).
If you use (1), you MUST of course also recompile the kernel, SO that the microcode file is also copied “IN” the kernel (yes, I know it's a PE file).
With (2) “only” the initramfs has to be rebuilt == the microcode file has to be copied into the initramfs, and not the complete kernel.
The file /lib/firmware/intel-ucode/06-9e-09 itself is never loaded directly (during early loading). _________________ https://wiki.gentoo.org/wiki/User:Pietinger |
|
Back to top |
|
|
pietinger Moderator
Joined: 17 Oct 2006 Posts: 5292 Location: Bavaria
|
Posted: Wed Jan 08, 2025 3:13 pm Post subject: |
|
|
I thought about it again ... and because the mainboard is a Supermicro ... do you perhaps have an option in the BIOS that “protects” the CPU ... from an update? (I'm not familiar with these mainboards; but that's the last possibility I can (logically) see; because your kernel options are really correct). _________________ https://wiki.gentoo.org/wiki/User:Pietinger |
|
Back to top |
|
|
Zucca Moderator
Joined: 14 Jun 2007 Posts: 3843 Location: Rasi, Finland
|
Posted: Wed Jan 08, 2025 4:14 pm Post subject: |
|
|
pietinger wrote: | With (2) “only” the initramfs has to be rebuilt == the microcode file has to be copied into the initramfs, and not the complete kernel. | Side note 2:For kernel being able to load microcode early from initramfs image, the image needs to be uncompressed. That why it's common to have microcode as a separate cpio image or simply concatenated along with (compressed) main initramfs image like the following: Code: | cat ucode.img initramfs.img.gz > combined.img | I have actually tested this and it works. _________________ ..: Zucca :..
My gentoo installs: | init=/sbin/openrc-init
-systemd -logind -elogind seatd |
Quote: | I am NaN! I am a man! |
|
|
Back to top |
|
|
ConiKost Developer
Joined: 11 Jan 2005 Posts: 1369
|
Posted: Wed Jan 08, 2025 11:29 pm Post subject: |
|
|
Zucca wrote: | Side note:CONFIG_MICROCODE_LATE_LOADING is (being?) deprecated, since it has some issues. |
Sure, config option is enabled in kernel and the interface is there. Anyway, it's not the goal I want to achieve, only testing.
pietinger wrote: |
Have you checked the file /lib/firmware/intel-ucode/06-9e-09 from ARCH with our Gentoo for equality?
|
Yes, checked by hashsum, same file.
pietinger wrote: |
If yes,
Now comes a very “simple” question - I would like to say in advance that there are two ways to do an (early) microcode update:
1. as a “built-in” file “in” the kernel, or
2. as a file located in an initramfs (if you have a kernel with initramfs).
If you use (1), you MUST of course also recompile the kernel, SO that the microcode file is also copied “IN” the kernel (yes, I know it's a PE file).
|
Yes, I am aware of this. I compiled everytime the kernel new. So I can rule out this.
pietinger wrote: |
With (2) “only” the initramfs has to be rebuilt == the microcode file has to be copied into the initramfs, and not the complete kernel.
|
Also aware of this. Since I do have my own initeramfs (cpio uncompressed!), I also tried to append together with intel-uc.bin, but no luck.
pietinger wrote: |
The file /lib/firmware/intel-ucode/06-9e-09 itself is never loaded directly (during early loading). |
Yes. This is only taken by CONFIG_EXTRA_FIRMWARE during kernel compilation.
pietinger wrote: | I thought about it again ... and because the mainboard is a Supermicro ... do you perhaps have an option in the BIOS that “protects” the CPU ... from an update? (I'm not familiar with these mainboards; but that's the last possibility I can (logically) see; because your kernel options are really correct). |
No, there is no such option to prevent microcode updates "in memory". Only UEFI/BIOS updates itself, but this option is disabled.
Zucca wrote: | Side note 2:For kernel being able to load microcode early from initramfs image, the image needs to be uncompressed. That why it's common to have microcode as a separate cpio image or simply concatenated along with (compressed) main initramfs image like the following: Code: | cat ucode.img initramfs.img.gz > combined.img | I have actually tested this and it works. |
Thats why I am out of ideas. I also did tested this, but it just does not work. My cpio initramfs is uncompressed build into the kernel. Before doing that, ucode.img is included into that, like in your example. |
|
Back to top |
|
|
pietinger Moderator
Joined: 17 Oct 2006 Posts: 5292 Location: Bavaria
|
Posted: Thu Jan 09, 2025 12:16 am Post subject: |
|
|
Hmm ... what happens if you boot with our GentooLiveCD?
... and do a "dmesg | grep microcode". Is there a message like we want?
If not, the same questions: What happens if you boot with (the newest) UbuntuLiveCD? ... ?
I just had a crazy idea/question ... you said you have ALSO an initramfs WITH the microcode-file - together with the BUILT-IN microcode-file ... how does the system react, if there are two (identical) microcode-files available? What happens if you clear the EXTRA_FIRMWARE (only microcode; no firmware for other hardware) (and recompile the kernel) and use only the microcode from your initramfs? What happens if you provide the microcode the other way around? _________________ https://wiki.gentoo.org/wiki/User:Pietinger |
|
Back to top |
|
|
|
|
You cannot post new topics in this forum You cannot reply to topics in this forum You cannot edit your posts in this forum You cannot delete your posts in this forum You cannot vote in polls in this forum
|
|