All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] rtw88: pci: Power cycle device during shutdown
@ 2020-08-24  9:32 Kai-Heng Feng
  2020-08-26  0:27 ` Brian Norris
  2020-09-28 16:55 ` [PATCH v2] " Kai-Heng Feng
  0 siblings, 2 replies; 5+ messages in thread
From: Kai-Heng Feng @ 2020-08-24  9:32 UTC (permalink / raw)
  To: yhchuang, kvalo
  Cc: Kai-Heng Feng, David S. Miller, Jakub Kicinski,
	open list:REALTEK WIRELESS DRIVER (rtw88),
	open list:NETWORKING DRIVERS, open list

Sometimes system freeze on cold/warm boot when rtw88 is probing.

According to [1], platform firmware may not properly power manage the
device during shutdown. I did some expirements and putting the device to
D3 can workaround the issue.

So let's power cycle the device by putting the device to D3 at shutdown
to prevent the issue from happening.

[1] https://bugzilla.kernel.org/show_bug.cgi?id=206411#c9

Signed-off-by: Kai-Heng Feng <kai.heng.feng@canonical.com>
---
 drivers/net/wireless/realtek/rtw88/pci.c | 2 ++
 1 file changed, 2 insertions(+)

diff --git a/drivers/net/wireless/realtek/rtw88/pci.c b/drivers/net/wireless/realtek/rtw88/pci.c
index 3413973bc475..7f1f5073b9f4 100644
--- a/drivers/net/wireless/realtek/rtw88/pci.c
+++ b/drivers/net/wireless/realtek/rtw88/pci.c
@@ -1599,6 +1599,8 @@ void rtw_pci_shutdown(struct pci_dev *pdev)
 
 	if (chip->ops->shutdown)
 		chip->ops->shutdown(rtwdev);
+
+	pci_set_power_state(pdev, PCI_D3hot);
 }
 EXPORT_SYMBOL(rtw_pci_shutdown);
 
-- 
2.17.1


^ permalink raw reply related	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2020-10-01 13:29 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2020-08-24  9:32 [PATCH] rtw88: pci: Power cycle device during shutdown Kai-Heng Feng
2020-08-26  0:27 ` Brian Norris
2020-09-09 14:00   ` Kai-Heng Feng
2020-09-28 16:55 ` [PATCH v2] " Kai-Heng Feng
2020-10-01 13:28   ` Kalle Valo

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.