CVE-2022-50459

MEDIUM

Linux Kernel 5.8.14-5.9 - NULL Pointer Dereference in iSCSI TCP Socket Handling

Title source: llm
STIX 2.1

Description

In the Linux kernel, the following vulnerability has been resolved: scsi: iscsi: iscsi_tcp: Fix null-ptr-deref while calling getpeername() Fix a NULL pointer crash that occurs when we are freeing the socket at the same time we access it via sysfs. The problem is that: 1. iscsi_sw_tcp_conn_get_param() and iscsi_sw_tcp_host_get_param() take the frwd_lock and do sock_hold() then drop the frwd_lock. sock_hold() does a get on the "struct sock". 2. iscsi_sw_tcp_release_conn() does sockfd_put() which does the last put on the "struct socket" and that does __sock_release() which sets the sock->ops to NULL. 3. iscsi_sw_tcp_conn_get_param() and iscsi_sw_tcp_host_get_param() then call kernel_getpeername() which accesses the NULL sock->ops. Above we do a get on the "struct sock", but we needed a get on the "struct socket". Originally, we just held the frwd_lock the entire time but in commit bcf3a2953d36 ("scsi: iscsi: iscsi_tcp: Avoid holding spinlock while calling getpeername()") we switched to refcount based because the network layer changed and started taking a mutex in that path, so we could no longer hold the frwd_lock. Instead of trying to maintain multiple refcounts, this just has us use a mutex for accessing the socket in the interface code paths.

Scores

CVSS v3 5.5
EPSS 0.0015
EPSS Percentile 4.8%
Attack Vector LOCAL
CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:N/I:N/A:H

Details

CWE
CWE-476
Status published
Products (16)
Linux/Linux < 5.9
Linux/Linux 5.10.150 - 5.10.*
Linux/Linux 5.15.75 - 5.15.*
Linux/Linux 5.19.17 - 5.19.*
Linux/Linux 5.8.14 - 5.9
Linux/Linux 5.9
Linux/Linux 6.0.3 - 6.0.*
Linux/Linux 6.1
Linux/Linux 7d29e950766327f658cb92722b9445ac3b3ae023
Linux/Linux bcf3a2953d36bbfb9bd44ccb3db0897d935cc485 - 0a0b861fce2657ba08ec356a74346b37ca4b2008
... and 6 more
Published Oct 01, 2025
Tracked Since Feb 18, 2026