Page MenuHomeFreeBSD

iwx: fix and clean up suspend/resume path
ClosedPublic

Authored by adrian on Wed, Nov 12, 9:04 PM.
Referenced Files
Unknown Object (File)
Tue, Dec 2, 5:04 PM
Unknown Object (File)
Mon, Dec 1, 8:25 AM
Unknown Object (File)
Fri, Nov 28, 12:30 PM
Unknown Object (File)
Tue, Nov 18, 10:17 PM
Unknown Object (File)
Sun, Nov 16, 9:40 AM
Unknown Object (File)
Sun, Nov 16, 5:53 AM
Unknown Object (File)
Sun, Nov 16, 3:47 AM
Unknown Object (File)
Sun, Nov 16, 3:47 AM
Subscribers

Details

Summary

I noticed a couple of things were happening:

  • during suspend, I'd get a timeout in the NIC lock path (which sets a bit on the NIC to say that the host wants to talk to it);
  • resume wouldn't come back - scan commands would fail, and you'd have to reinit the NIC again for it to work.

The thing is:

  • the suspend path should already shut down the NIC by shutting down all the VAPs (and the last VAP should call ic_parent to bring it down), and
  • the resume path should already bring up the NIC by bringing up each VAP, and the first VAP to be brought up calls ic_parent to bring it up.

So instead, I've shuffled around the code to just double check the
hardware state is consistent /before/ ieee80211_suspend_all() and
ieee80211_resume_all() is called.

This both fixes the errant hardware timeout during suspend, and it
fixes resume to work.

Locally tested:

  • AX210, STA mode, both hardware ACPI suspend/resume and devctl suspend and devctl resume

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Not Applicable
Unit
Tests Not Applicable