Jie Wang
2cf2461435
net: hns3: fix kernel crash when 1588 is sent on HIP08 devices
Currently, HIP08 devices does not register the ptp devices, so the
hdev->ptp is NULL. But the tx process would still try to set hardware time
stamp info with SKBTX_HW_TSTAMP flag and cause a kernel crash.
[ 128.087798] Unable to handle kernel NULL pointer dereference at virtual address 0000000000000018
...
[ 128.280251] pc : hclge_ptp_set_tx_info+0x2c/0x140 [hclge]
[ 128.286600] lr : hclge_ptp_set_tx_info+0x20/0x140 [hclge]
[ 128.292938] sp : ffff800059b93140
[ 128.297200] x29: ffff800059b93140 x28: 0000000000003280
[ 128.303455] x27: ffff800020d48280 x26: ffff0cb9dc814080
[ 128.309715] x25: ffff0cb9cde93fa0 x24: 0000000000000001
[ 128.315969] x23: 0000000000000000 x22: 0000000000000194
[ 128.322219] x21: ffff0cd94f986000 x20: 0000000000000000
[ 128.328462] x19: ffff0cb9d2a166c0 x18: 0000000000000000
[ 128.334698] x17: 0000000000000000 x16: ffffcf1fc523ed24
[ 128.340934] x15: 0000ffffd530a518 x14: 0000000000000000
[ 128.347162] x13: ffff0cd6bdb31310 x12: 0000000000000368
[ 128.353388] x11: ffff0cb9cfbc7070 x10: ffff2cf55dd11e02
[ 128.359606] x9 : ffffcf1f85a212b4 x8 : ffff0cd7cf27dab0
[ 128.365831] x7 : 0000000000000a20 x6 : ffff0cd7cf27d000
[ 128.372040] x5 : 0000000000000000 x4 : 000000000000ffff
[ 128.378243] x3 : 0000000000000400 x2 : ffffcf1f85a21294
[ 128.384437] x1 : ffff0cb9db520080 x0 : ffff0cb9db500080
[ 128.390626] Call trace:
[ 128.393964] hclge_ptp_set_tx_info+0x2c/0x140 [hclge]
[ 128.399893] hns3_nic_net_xmit+0x39c/0x4c4 [hns3]
[ 128.405468] xmit_one.constprop.0+0xc4/0x200
[ 128.410600] dev_hard_start_xmit+0x54/0xf0
[ 128.415556] sch_direct_xmit+0xe8/0x634
[ 128.420246] __dev_queue_xmit+0x224/0xc70
[ 128.425101] dev_queue_xmit+0x1c/0x40
[ 128.429608] ovs_vport_send+0xac/0x1a0 [openvswitch]
[ 128.435409] do_output+0x60/0x17c [openvswitch]
[ 128.440770] do_execute_actions+0x898/0x8c4 [openvswitch]
[ 128.446993] ovs_execute_actions+0x64/0xf0 [openvswitch]
[ 128.453129] ovs_dp_process_packet+0xa0/0x224 [openvswitch]
[ 128.459530] ovs_vport_receive+0x7c/0xfc [openvswitch]
[ 128.465497] internal_dev_xmit+0x34/0xb0 [openvswitch]
[ 128.471460] xmit_one.constprop.0+0xc4/0x200
[ 128.476561] dev_hard_start_xmit+0x54/0xf0
[ 128.481489] __dev_queue_xmit+0x968/0xc70
[ 128.486330] dev_queue_xmit+0x1c/0x40
[ 128.490856] ip_finish_output2+0x250/0x570
[ 128.495810] __ip_finish_output+0x170/0x1e0
[ 128.500832] ip_finish_output+0x3c/0xf0
[ 128.505504] ip_output+0xbc/0x160
[ 128.509654] ip_send_skb+0x58/0xd4
[ 128.513892] udp_send_skb+0x12c/0x354
[ 128.518387] udp_sendmsg+0x7a8/0x9c0
[ 128.522793] inet_sendmsg+0x4c/0x8c
[ 128.527116] __sock_sendmsg+0x48/0x80
[ 128.531609] __sys_sendto+0x124/0x164
[ 128.536099] __arm64_sys_sendto+0x30/0x5c
[ 128.540935] invoke_syscall+0x50/0x130
[ 128.545508] el0_svc_common.constprop.0+0x10c/0x124
[ 128.551205] do_el0_svc+0x34/0xdc
[ 128.555347] el0_svc+0x20/0x30
[ 128.559227] el0_sync_handler+0xb8/0xc0
[ 128.563883] el0_sync+0x160/0x180
Fixes: 0bf5eb7885 ("net: hns3: add support for PTP")
Signed-off-by: Jie Wang <wangjie125@huawei.com>
Signed-off-by: Jijie Shao <shaojijie@huawei.com>
Signed-off-by: Paolo Abeni <pabeni@redhat.com>
2024-10-31 11:15:43 +01:00
..
2024-10-07 16:49:43 -07:00
2024-10-15 09:59:20 -07:00
2024-09-03 15:28:57 -07:00
2024-07-31 18:59:46 -07:00
2024-09-12 18:01:17 -07:00
2024-10-09 12:45:51 +01:00
2024-09-12 20:35:04 -07:00
2024-09-06 18:05:53 -07:00
2024-09-13 19:53:47 -07:00
2024-10-19 16:16:25 -05:00
2024-10-15 10:40:47 -07:00
2024-09-09 17:44:41 -07:00
2024-09-06 09:34:18 +01:00
2024-09-23 06:58:37 +00:00
2024-09-13 21:17:12 -07:00
2024-08-27 14:26:04 -07:00
2024-10-02 17:23:23 -04:00
2024-08-14 12:20:55 +01:00
2024-10-19 16:06:08 -05:00
2024-09-03 15:17:48 -07:00
2024-10-09 17:56:55 -07:00
2024-10-21 10:50:16 +02:00
2024-09-09 17:44:41 -07:00
2024-08-19 17:48:20 -07:00
2024-10-31 11:15:43 +01:00
2024-08-13 11:59:37 +02:00
2024-10-19 16:04:20 -05:00
2024-10-09 19:27:09 -07:00
2024-10-29 15:24:53 +01:00
2024-10-19 16:20:07 -05:00
2024-10-30 18:26:24 -07:00
2024-10-30 18:24:39 -07:00
2024-10-02 17:23:23 -04:00
2024-10-15 18:39:00 -07:00
2024-09-19 11:12:49 +02:00
2024-09-09 17:44:41 -07:00
2024-10-02 17:23:23 -04:00
2024-10-02 17:23:23 -04:00
2024-09-03 11:36:43 +02:00
2024-09-09 19:18:15 -07:00
2024-09-11 16:00:54 -07:00
2024-09-03 11:36:43 +02:00
2024-10-23 15:41:27 +02:00
2024-10-15 18:41:10 -07:00
2024-09-03 11:36:43 +02:00
2024-09-19 15:17:30 +02:00
2024-10-03 15:42:00 -07:00
2024-10-02 17:23:23 -04:00
2024-10-29 11:37:10 +01:00
2024-08-12 13:25:38 +01:00
2024-09-03 11:36:43 +02:00
2024-10-09 12:18:01 +01:00
2024-09-03 11:36:43 +02:00
2024-08-29 11:39:35 -07:00
2024-09-23 14:34:19 -07:00
2024-10-15 10:59:23 -07:00
2024-09-09 17:44:42 -07:00
2024-08-11 04:41:15 +01:00
2024-09-11 20:53:42 -07:00
2024-10-01 10:58:07 +02:00
2024-09-11 20:53:42 -07:00
2024-09-11 20:53:45 -07:00