Commit 18d4decc authored by Mika Westerberg's avatar Mika Westerberg Committed by Greg Kroah-Hartman

net: thunderbolt: Unregister ThunderboltIP protocol handler when suspending

[ Upstream commit 9872760e ]

The XDomain protocol messages may start as soon as Thunderbolt control
channel is started. This means that if the other host starts sending
ThunderboltIP packets early enough they will be passed to the network
driver which then gets confused because its resume hook is not called
yet.

Fix this by unregistering the ThunderboltIP protocol handler when
suspending and registering it back on resume.
Signed-off-by: default avatarMika Westerberg <mika.westerberg@linux.intel.com>
Acked-by: default avatarDavid S. Miller <davem@davemloft.net>
Signed-off-by: default avatarSasha Levin <sashal@kernel.org>
parent e86a0475
...@@ -1282,6 +1282,7 @@ static int __maybe_unused tbnet_suspend(struct device *dev) ...@@ -1282,6 +1282,7 @@ static int __maybe_unused tbnet_suspend(struct device *dev)
tbnet_tear_down(net, true); tbnet_tear_down(net, true);
} }
tb_unregister_protocol_handler(&net->handler);
return 0; return 0;
} }
...@@ -1290,6 +1291,8 @@ static int __maybe_unused tbnet_resume(struct device *dev) ...@@ -1290,6 +1291,8 @@ static int __maybe_unused tbnet_resume(struct device *dev)
struct tb_service *svc = tb_to_service(dev); struct tb_service *svc = tb_to_service(dev);
struct tbnet *net = tb_service_get_drvdata(svc); struct tbnet *net = tb_service_get_drvdata(svc);
tb_register_protocol_handler(&net->handler);
netif_carrier_off(net->dev); netif_carrier_off(net->dev);
if (netif_running(net->dev)) { if (netif_running(net->dev)) {
netif_device_attach(net->dev); netif_device_attach(net->dev);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment