CVE-2021-47414
Severity CVSS v4.0:
Pending analysis
Type:
Unavailable / Other
Publication date:
21/05/2024
Last modified:
25/09/2025
Description
In the Linux kernel, the following vulnerability has been resolved:<br />
<br />
riscv: Flush current cpu icache before other cpus<br />
<br />
On SiFive Unmatched, I recently fell onto the following BUG when booting:<br />
<br />
[ 0.000000] ftrace: allocating 36610 entries in 144 pages<br />
[ 0.000000] Oops - illegal instruction [#1]<br />
[ 0.000000] Modules linked in:<br />
[ 0.000000] CPU: 0 PID: 0 Comm: swapper Not tainted 5.13.1+ #5<br />
[ 0.000000] Hardware name: SiFive HiFive Unmatched A00 (DT)<br />
[ 0.000000] epc : riscv_cpuid_to_hartid_mask+0x6/0xae<br />
[ 0.000000] ra : __sbi_rfence_v02+0xc8/0x10a<br />
[ 0.000000] epc : ffffffff80007240 ra : ffffffff80009964 sp : ffffffff81803e10<br />
[ 0.000000] gp : ffffffff81a1ea70 tp : ffffffff8180f500 t0 : ffffffe07fe30000<br />
[ 0.000000] t1 : 0000000000000004 t2 : 0000000000000000 s0 : ffffffff81803e60<br />
[ 0.000000] s1 : 0000000000000000 a0 : ffffffff81a22238 a1 : ffffffff81803e10<br />
[ 0.000000] a2 : 0000000000000000 a3 : 0000000000000000 a4 : 0000000000000000<br />
[ 0.000000] a5 : 0000000000000000 a6 : ffffffff8000989c a7 : 0000000052464e43<br />
[ 0.000000] s2 : ffffffff81a220c8 s3 : 0000000000000000 s4 : 0000000000000000<br />
[ 0.000000] s5 : 0000000000000000 s6 : 0000000200000100 s7 : 0000000000000001<br />
[ 0.000000] s8 : ffffffe07fe04040 s9 : ffffffff81a22c80 s10: 0000000000001000<br />
[ 0.000000] s11: 0000000000000004 t3 : 0000000000000001 t4 : 0000000000000008<br />
[ 0.000000] t5 : ffffffcf04000808 t6 : ffffffe3ffddf188<br />
[ 0.000000] status: 0000000200000100 badaddr: 0000000000000000 cause: 0000000000000002<br />
[ 0.000000] [] riscv_cpuid_to_hartid_mask+0x6/0xae<br />
[ 0.000000] [] sbi_remote_fence_i+0x1e/0x26<br />
[ 0.000000] [] flush_icache_all+0x12/0x1a<br />
[ 0.000000] [] patch_text_nosync+0x26/0x32<br />
[ 0.000000] [] ftrace_init_nop+0x52/0x8c<br />
[ 0.000000] [] ftrace_process_locs.isra.0+0x29c/0x360<br />
[ 0.000000] [] ftrace_init+0x80/0x130<br />
[ 0.000000] [] start_kernel+0x5c4/0x8f6<br />
[ 0.000000] ---[ end trace f67eb9af4d8d492b ]---<br />
[ 0.000000] Kernel panic - not syncing: Attempted to kill the idle task!<br />
[ 0.000000] ---[ end Kernel panic - not syncing: Attempted to kill the idle task! ]---<br />
<br />
While ftrace is looping over a list of addresses to patch, it always failed<br />
when patching the same function: riscv_cpuid_to_hartid_mask. Looking at the<br />
backtrace, the illegal instruction is encountered in this same function.<br />
However, patch_text_nosync, after patching the instructions, calls<br />
flush_icache_range. But looking at what happens in this function:<br />
<br />
flush_icache_range -> flush_icache_all<br />
-> sbi_remote_fence_i<br />
-> __sbi_rfence_v02<br />
-> riscv_cpuid_to_hartid_mask<br />
<br />
The icache and dcache of the current cpu are never synchronized between the<br />
patching of riscv_cpuid_to_hartid_mask and calling this same function.<br />
<br />
So fix this by flushing the current cpu&#39;s icache before asking for the other<br />
cpus to do the same.
Impact
Base Score 3.x
5.50
Severity 3.x
MEDIUM
Vulnerable products and versions
| CPE | From | Up to |
|---|---|---|
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 4.15 (including) | 5.10.73 (excluding) |
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 5.11 (including) | 5.14.12 (excluding) |
| cpe:2.3:o:linux:linux_kernel:5.15:rc1:*:*:*:*:*:* | ||
| cpe:2.3:o:linux:linux_kernel:5.15:rc2:*:*:*:*:*:* | ||
| cpe:2.3:o:linux:linux_kernel:5.15:rc3:*:*:*:*:*:* | ||
| cpe:2.3:o:linux:linux_kernel:5.15:rc4:*:*:*:*:*:* |
To consult the complete list of CPE names with products and versions, see this page
References to Advisories, Solutions, and Tools
- https://git.kernel.org/stable/c/427faa29e06f0709476ea1bd59758f997ec8b64e
- https://git.kernel.org/stable/c/bb8958d5dc79acbd071397abb57b8756375fe1ce
- https://git.kernel.org/stable/c/f1c7aa87c423e765e3862349c2f095fdfccdd9b3
- https://git.kernel.org/stable/c/427faa29e06f0709476ea1bd59758f997ec8b64e
- https://git.kernel.org/stable/c/bb8958d5dc79acbd071397abb57b8756375fe1ce
- https://git.kernel.org/stable/c/f1c7aa87c423e765e3862349c2f095fdfccdd9b3



