| Title | LinuxのLinux KernelにおけるNULL ポインタデリファレンスに関する脆弱性 |
|---|---|
| Summary | Linuxカーネルにおいて、以下の脆弱性が修正されました。perf/x86のx86_pmu_enable()関数内でイベントポインタの設定を早期に移動しました。AMD EPYC製品の環境において、PMUのNMIハンドラでNULLポインタ参照が発生し、システムクラッシュが起きていました。これは、x86_perf_event_update()内の「if (unlikely(!hwc-event_base))」条件判定部で、イベントがNULLの状態でアクセスされたことに起因します。vmcoreの検査により、cpuc-active_maskとcpuc-events[]の間に不整合が確認されました。具体的には、active_maskのビット2はセットされている一方でevents[2]はNULLでした。この原因は、コミット7e772a93eb61("perf/x86: Fix NULL event access and potential PEBS record loss")により、cpuc-events[idx]の割当てがx86_pmu_start()からx86_pmu_enable()のステップ2に移動され、PERF_HES_ARCHチェック後に行われるようになったためです。その結果、x86_pmu_enable()を経由せずにpmu-start()を呼び出すパス(特に非スロットル経路)がevents[]を適切に設定しなくなりました。競合シーケンスは、(1) perfイベントのグループスロットリング開始、(2) スロットル中のx86_pmu_enable()の実行によるイベントの再スケジューリング、(3) スロットル解除時のpmu-start()呼び出しによるevents[]未設定状態のままactive_mask更新、(4) PMCオーバーフローNMIの発生とハンドラにおけるNULLイベント参照という流れです。対策として、x86_pmu_enable()内でcpuc-events[hwc-idx]の割当てをPERF_HES_ARCHチェックより前に移動し、即時開始されないイベントでもevents[]が適切に設定されるようにしました。これにより、pmu-start()経由の非スロットル経路でも常に有効なイベントポインタが存在する状態となりました。 |
| Possible impacts | 当該ソフトウェアが扱う情報について、外部への漏えいは発生しません。 また、当該ソフトウェアが扱う情報について、書き換えは発生しません。 さらに、当該ソフトウェアが完全に停止する可能性があります。 そして、この脆弱性を悪用した攻撃の影響は、他のソフトウェアには及びません。 |
| Solution | リリース情報、またはパッチ情報が公開されています。参考情報を参照して適切な対策を実施してください。 |
| Publication Date | April 3, 2026, midnight |
| Registration Date | April 27, 2026, 11:24 a.m. |
| Last Update | April 27, 2026, 11:24 a.m. |
| CVSS3.0 : 警告 | |
| Score | 5.5 |
|---|---|
| Vector | CVSS:3.0/AV:L/AC:L/PR:L/UI:N/S:U/C:N/I:N/A:H |
| Linux |
| Linux Kernel 6.17.13 以上 6.18 未満 |
| Linux Kernel 6.18.2 以上 6.18.20 未満 |
| Linux Kernel 6.19 |
| Linux Kernel 6.19.1 以上 6.19.10 未満 |
| Linux Kernel 7.0 |
| No | Changed Details | Date of change |
|---|---|---|
| 1 | [2026年04月27日] 掲載 |
April 27, 2026, 11:24 a.m. |
| Summary | In the Linux kernel, the following vulnerability has been resolved: perf/x86: Move event pointer setup earlier in x86_pmu_enable() A production AMD EPYC system crashed with a NULL pointer dereference BUG: kernel NULL pointer dereference, address: 0000000000000198 The faulting instruction is `cmpq $0x0, 0x198(%rdi)` with RDI=0, drgn inspection of the vmcore on CPU 106 showed a mismatch between active_mask: 0x1e (bits 1, 2, 3, 4) The event that should occupy events[2] was found in event_list[2] Another event (event_list[0]) had hw.state=0x7 (STOPPED|UPTODATE|ARCH), The root cause is commit 7e772a93eb61 ("perf/x86: Fix NULL event access perf_adjust_freq_unthr_events() The race sequence is: 1. A group of perf events overflows, triggering group throttle via 2. While still throttled (PERF_HES_STOPPED), x86_pmu_enable() runs 3. The timer tick unthrottles the group via pmu->start(). Since 4. A PMC overflow NMI fires. The handler iterates active counters, Move the cpuc->events[hwc->idx] assignment in x86_pmu_enable() to |
|---|---|
| Publication Date | April 4, 2026, 1:16 a.m. |
| Registration Date | April 15, 2026, 11:24 a.m. |
| Last Update | April 24, 2026, 5:59 a.m. |
| Configuration1 | or higher | or less | more than | less than | |
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 6.17.13 | 6.18 | |||
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 6.18.2 | 6.18.20 | |||
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 6.19.1 | 6.19.10 | |||
| cpe:2.3:o:linux:linux_kernel:6.19:-:*:*:*:*:*:* | |||||
| cpe:2.3:o:linux:linux_kernel:7.0:rc1:*:*:*:*:*:* | |||||
| cpe:2.3:o:linux:linux_kernel:7.0:rc2:*:*:*:*:*:* | |||||
| cpe:2.3:o:linux:linux_kernel:7.0:rc3:*:*:*:*:*:* | |||||
| cpe:2.3:o:linux:linux_kernel:7.0:rc4:*:*:*:*:*:* | |||||
| cpe:2.3:o:linux:linux_kernel:7.0:rc5:*:*:*:*:*:* | |||||
| cpe:2.3:o:linux:linux_kernel:7.0:rc6:*:*:*:*:*:* | |||||
| cpe:2.3:o:linux:linux_kernel:7.0:rc7:*:*:*:*:*:* | |||||