Damodharam Ammepalli
7eb0a0072f
ethtool: cmis_cdb: use correct rpl size in ethtool_cmis_module_poll()
[ Upstream commit f3fdd4fba1 ]
rpl is passed as a pointer to ethtool_cmis_module_poll(), so the correct
size of rpl is sizeof(*rpl) which should be just 1 byte. Using the
pointer size instead can cause stack corruption:
Kernel panic - not syncing: stack-protector: Kernel stack is corrupted in: ethtool_cmis_wait_for_cond+0xf4/0x100
CPU: 72 UID: 0 PID: 4440 Comm: kworker/72:2 Kdump: loaded Tainted: G OE 6.11.0 #24
Tainted: [O]=OOT_MODULE, [E]=UNSIGNED_MODULE
Hardware name: Dell Inc. PowerEdge R760/04GWWM, BIOS 1.6.6 09/20/2023
Workqueue: events module_flash_fw_work
Call Trace:
<TASK>
panic+0x339/0x360
? ethtool_cmis_wait_for_cond+0xf4/0x100
? __pfx_status_success+0x10/0x10
? __pfx_status_fail+0x10/0x10
__stack_chk_fail+0x10/0x10
ethtool_cmis_wait_for_cond+0xf4/0x100
ethtool_cmis_cdb_execute_cmd+0x1fc/0x330
? __pfx_status_fail+0x10/0x10
cmis_cdb_module_features_get+0x6d/0xd0
ethtool_cmis_cdb_init+0x8a/0xd0
ethtool_cmis_fw_update+0x46/0x1d0
module_flash_fw_work+0x17/0xa0
process_one_work+0x179/0x390
worker_thread+0x239/0x340
? __pfx_worker_thread+0x10/0x10
kthread+0xcc/0x100
? __pfx_kthread+0x10/0x10
ret_from_fork+0x2d/0x50
? __pfx_kthread+0x10/0x10
ret_from_fork_asm+0x1a/0x30
</TASK>
Fixes: a39c84d796 ("ethtool: cmis_cdb: Add a layer for supporting CDB commands")
Reviewed-by: Andy Gospodarek <andrew.gospodarek@broadcom.com>
Reviewed-by: Simon Horman <horms@kernel.org>
Reviewed-by: Ido Schimmel <idosch@nvidia.com>
Signed-off-by: Damodharam Ammepalli <damodharam.ammepalli@broadcom.com>
Signed-off-by: Michael Chan <michael.chan@broadcom.com>
Link: https://patch.msgid.link/20250409173312.733012-1-michael.chan@broadcom.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
2025-04-25 10:50:52 +02:00
..
2024-12-04 18:54:43 -08:00
2020-03-12 15:32:32 -07:00
2025-03-04 17:12:01 -08:00
2024-08-09 21:52:13 -07:00
2025-04-25 10:50:52 +02:00
2024-10-13 18:02:50 +01:00
2025-04-20 10:22:21 +02:00
2024-07-01 13:43:50 +01:00
2025-04-20 10:22:17 +02:00
2025-02-24 14:15:42 -08:00
2023-08-15 15:01:03 -07:00
2024-02-28 12:18:05 +00:00
2024-07-04 15:45:15 -07:00
2024-01-18 13:21:06 +01:00
2023-08-15 15:01:03 -07:00
2025-02-24 14:15:42 -08:00
2024-11-18 18:52:11 -08:00
2024-11-18 18:52:11 -08:00
2025-03-04 17:12:01 -08:00
2024-12-16 12:51:41 +00:00
2023-08-15 15:01:03 -07:00
2024-06-28 10:48:23 +01:00
2024-07-13 15:37:36 -07:00
2025-04-20 10:22:18 +02:00
2025-03-04 17:12:01 -08:00
2023-08-15 15:01:03 -07:00
2023-08-15 15:01:03 -07:00
2025-03-04 17:12:01 -08:00
2025-03-04 17:12:01 -08:00
2023-08-15 15:01:03 -07:00
2025-03-04 17:12:01 -08:00
2025-02-24 14:15:42 -08:00
2025-02-03 18:38:52 -08:00
2025-03-04 17:12:01 -08:00
2025-03-04 17:12:01 -08:00
2024-12-16 12:51:41 +00:00
2025-02-06 16:35:21 -08:00
2025-03-10 13:14:25 -07:00
2023-08-15 15:00:45 -07:00
2024-06-28 18:53:17 -07:00