【活用ガイド】

JVNDB-2026-005625

LinuxのLinux KernelにおけるNULL ポインタデリファレンスに関する脆弱性

概要

Linuxカーネルにおいて、以下の脆弱性が修正されました。net/mlx5eにおいて、mlx5e_devのdevlinkプライベートにmlx5e_privを保存しないようにしました。mlx5e_privは不安定な構造体であり、プロファイルのアタッチに失敗するとmemset(0)される可能性があります。mlx5e_devのdevlinkプライベートにあるmlx5e_privは、その構造体に関連するnetdevおよびmdevへの参照に使用されていました。代わりに、netdevを直接mlx5e_devに保存し、mdevは包含するmlx5_adevの補助デバイス構造体から取得します。これにより、スイッチドモードがプロファイル変更に失敗した場合に発生するmlx5e_removeでのカーネルオープスが修正されます。以下のような操作例が挙げられます。$ devlink dev eswitch set pci/0000:00:03.0 mode switchdev 実行時に「エラー: mlx5_core: eswitchをオフロードに設定できませんでした。」と表示され、dmesgログには次のような例があります。workqueue: wq "mlx5e"のレスキューkthread作成失敗: -EINTR mlx5_core 0012:03:00.1: mlx5e_netdev_init_profile:6214:(pid 37199): mlx5e_priv_init失敗, err=-12 mlx5_core 0012:03:00.1 gpu3rdma1: mlx5e_netdev_change_profile: 新プロファイル初期化失敗, -12 さらにworkqueueでレスキューkthread作成失敗が繰り返されます。カーネルオープスの例としては、$ devlink dev reload pci/0000:00:03.0 実行時にBUG: kernel NULL pointer dereference 対象アドレス: 0000000000000520 #PF: カーネルモードのスーパーバイザ読み取りアクセス #PF: エラーコード(0x0000) - 未存在ページが発生します。問題はmlx5e_remove関数内で発生し、該当デバイスの解除時にNULLポインタ参照が引き起こされていました。この修正により、mlx5e_privへの不適切な参照が排除され、安定したデバイス管理が可能になりました。
CVSS による深刻度 (CVSS とは?)

CVSS v3 による深刻度
基本値: 5.5 (警告) [NVD値]
  • 攻撃元区分: ローカル
  • 攻撃条件の複雑さ: 低
  • 攻撃に必要な特権レベル: 低
  • 利用者の関与: 不要
  • 影響の想定範囲: 変更なし
  • 機密性への影響(C): なし
  • 完全性への影響(I): なし
  • 可用性への影響(A): 高
影響を受けるシステム


Linux
  • Linux Kernel 5.12 以上 6.12.67 未満
  • Linux Kernel 6.13 以上 6.18.7 未満
  • Linux Kernel 6.19

想定される影響

当該ソフトウェアが扱う情報について、外部への漏えいは発生しません。
また、当該ソフトウェアが扱う情報について、書き換えは発生しません。
さらに、当該ソフトウェアが完全に停止する可能性があります。
そして、この脆弱性を悪用した攻撃の影響は、他のソフトウェアには及びません。
対策

リリース情報、またはパッチ情報が公開されています。参考情報を参照して適切な対策を実施してください。
ベンダ情報

CWEによる脆弱性タイプ一覧  CWEとは?

  1. NULL ポインタデリファレンス(CWE-476) [NVD評価]
共通脆弱性識別子(CVE)  CVEとは?

  1. CVE-2026-22996
参考情報

  1. National Vulnerability Database (NVD) : CVE-2026-22996
  2. 関連文書 : net/mlx5e: Don't store mlx5e_priv in mlx5e_dev devlink priv - kernel/git/stable/linux.git - Linux kernel stable tree (https://git.kernel.org/stable/c/a3d4f87d41f5140f1cf5c02fce5cdad2637f6244)
  3. 関連文書 : net/mlx5e: Don't store mlx5e_priv in mlx5e_dev devlink priv - kernel/git/stable/linux.git - Linux kernel stable tree (https://git.kernel.org/stable/c/dcb2ad755a16cb0ecd2dc98234d71a6e216ae7fe)
  4. 関連文書 : net/mlx5e: Don't store mlx5e_priv in mlx5e_dev devlink priv - kernel/git/stable/linux.git - Linux kernel stable tree (https://git.kernel.org/stable/c/123eda2e5b1638e298e3a66bb1e64a8da92de5e1)
更新履歴

  • [2026年03月02日]
      掲載