In the Linux kernel, a vulnerability was discovered and subsequently fixed. The issue is related to the illegal access of rmb_desc in the SMC-D connection dump which could lead to a crash when dumping SMC-D connections.
Run an nginx/wrk test using the commands
smc_run nginx
smc_run wrk -t 16 -c 100 -d <duration> -H 'Connection: Close' <URL>
Continuously dump SMC-D connections in parallel using the command
watch -n 1 'smcss -D'
This would lead to a NULL pointer dereference crash in the kernel with a call trace as follows
BUG: kernel NULL pointer dereference, address: 000000000000003
<call_trace_info>
It has been observed that the connection being dumped might still be in the process of being established. It is assumed that the connection has been registered in a link group using the smc_conn_create() function, but the rmb_desc has not been initialized by the smc_buf_create() function, thus causing the illegal access to conn->rmb_desc.
In order to fix the issue, a check should be added before the dump to prevent illegal access. The related initiative to fix this vulnerability can be found on the Linux kernel mailing list.
Timeline
Published on: 03/11/2024 18:15:19 UTC
Last modified on: 12/12/2024 15:31:02 UTC