I am running GrapheneOS SQ3A.220705.003.A1.2022072000. I have both 'Turn on Wi-Fi automatically' and 'Turn off Wi-Fi automatically' turned on. 'Wi-Fi scanning' is turned on as well.

What I expected to happen with this setup is that the phone would turn off Wi-Fi when away from home (that part is working), and eventually turn on Wi-Fi again (and connect to my home network) when I am home. However, when I am at home the Wi-Fi never turns on by itself even after waiting for many hours.

Is this functionality supposed to be working? Is there anything else I may be missing here?

    MetropleX Yes, I am 200% sure they're on. I also enabled "verbose wi-fi logging" in developer settings and I can see the scans happening in logcat:

    D WakeupController: start()
    D WakeupController: Setting active to true
    D WakeupController: Saved networks in most recent scan:[]
    D WakeupLock: Lock set. Number of networks: 0
    D WakeupController: Incoming scan #1
    D WakeupLock: Initializing lock with networks: []
    I WifiService: isAutoWakeupEnabled uid=1000
    D WakeupController: Incoming scan #2
    D WakeupLock: Initializing lock with networks: []
    ...
    D WakeupController: Incoming scan #5
    D WakeupLock: Initializing lock with networks: []
    D WakeupLock: Lock initialized by handled scans. Scans: 5
    D WakeupLock: State of lock: {}
    D WakeupController: Incoming scan #6

    and so on.

    To make this test I configured the phone to turn off Wi-Fi after 30 seconds. I disabled Wi-Fi in my router and waited a minute and turned it back on and waited. The phone turns off Wi-Fi as configured, but then it never detects the network again nor turns on Wi-Fi, although the SSID is visible.

    I also tried resetting all network settings before this test. Nothing changed.

    Could it be possible the network isn't being detected with a high enough RSSI (signal strength indicator) to meet the 'high quality' as Google defines it to trigger auto connect?

    Turn on Wi-Fi automatically
    Users may disable Wi-Fi for a variety of reasons (e.g. a connection to a bad network) and can then forget to re-enable it when arriving back home, resulting in a bad experience (e.g. not being able to control home automation devices). The Turn on Wi-Fi automatically feature, introduced in Android 9, solves this issue by automatically re-enabling Wi-Fi whenever the device is near a Wi-Fi network that is both a saved network (i.e. one which the user explicitly connected to in the past) and has a sufficiently high RSSI.

    The feature can be enabled or disabled by the user using the Settings app at:

    Settings > Network & internet > Wi-Fi > Wi-Fi preferences > Turn on Wi-Fi automatically

    Wi-Fi Scanning (for Location) must be enabled for this feature to function. If Wi-Fi Scanning is not enabled the user is prompted for permission to enable it. Wi-Fi Scanning is required because scan results are used to determine whether the device is in the vicinity of a Wi-Fi network that meets the criteria to re-enable Wi-Fi connectivity.

    The feature avoids re-enabling Wi-Fi immediately after a user disables it, even if the device observes a saved Wi-Fi network of sufficient quality. For example, if the user is in the office and is connected to the office Wi-Fi (a saved network) and then disables Wi-Fi, the feature will not re-enable Wi-Fi until the user arrives at a different environment with a different saved network that meets the re-enabling criteria.

    From: https://source.android.com/devices/tech/connect/wifi-infrastructure

      Hmmm... I also found this in logcat:

      W vendor.google.wifi_ext@1.0-service-vendor: setScanModeInternal(1) not supported
      E WifiVendorHal: setScanMode(l.3312) failed {.code = ERROR_NOT_SUPPORTED, .description = }
      W WifiConnectivityManager: Ignoring call from non primary Mode Manager ConcreteClientModeManager{id=381413462 iface=wlan0 role=ROLE_CLIENT_SCAN_ONLY}
      W WifiConnectivityManager: java.lang.Throwable
      W WifiConnectivityManager: 	at com.android.server.wifi.WifiConnectivityManager.handleConnectionStateChanged(WifiConnectivityManager.java:2228)
      W WifiConnectivityManager: 	at com.android.server.wifi.ClientModeImpl$DisconnectedState.exit(ClientModeImpl.java:5838)
      W WifiConnectivityManager: 	at com.android.wifi.x.com.android.internal.util.StateMachine$SmHandler.invokeExitMethods(StateMachine.java:1022)
      W WifiConnectivityManager: 	at com.android.wifi.x.com.android.internal.util.StateMachine$SmHandler.performTransitions(StateMachine.java:878)
      W WifiConnectivityManager: 	at com.android.wifi.x.com.android.internal.util.StateMachine$SmHandler.handleMessage(StateMachine.java:820)
      W WifiConnectivityManager: 	at android.os.Handler.dispatchMessage(Handler.java:106)
      W WifiConnectivityManager: 	at android.os.Looper.loopOnce(Looper.java:201)
      W WifiConnectivityManager: 	at android.os.Looper.loop(Looper.java:288)
      W WifiConnectivityManager: 	at android.os.HandlerThread.run(HandlerThread.java:67)
      D WifiHandler.WifiScanningService: handleMessage Received message=159771 sendingUid=1000
      D WifiScanningService: replySucceeded replySucceeded recvdMessage=159771
      E SupplicantStaIfaceHal: Can't call listNetworks, ISupplicantStaIface is null for iface=wlan0
      E SupplicantStaIfaceHal: removeAllNetworks failed, got null networks
      E WifiClientModeImpl[wlan0]: Failed to remove networks on exiting connect mode
      E WifiVendorHal: stopRssiMonitoring(l.2617) failed {.code = ERROR_NOT_AVAILABLE, .description = }
      E SupplicantStaIfaceHal: Can't call setSuspendModeEnabled, ISupplicantStaIface is null for iface=wlan0
      E SupplicantStaIfaceHal: Can't call setPowerSave, ISupplicantStaIface is null for iface=wlan0
      E SupplicantStaIfaceHal: Can't call setBtCoexistenceMode, ISupplicantStaIface is null for iface=wlan0
      V WifiNative: Interface status unchanged on Iface:{Name=wlan0,Id=2,Type=STA_SCAN} from true, Ignoring...
      V WifiNative: Interface status unchanged on Iface:{Name=wlan0,Id=2,Type=STA_SCAN} from true, Ignoring...

      and

      W vendor.google.wifi_ext@1.0-service-vendor: setScanModeInternal(0) not supported
      I vendor.google.wifi_ext@1.0-service-vendor: Adding interface handle for wlan0
      I vendor.google.wifi_ext@1.0-service-vendor: Adding interface handle for aware_nmi0
      I vendor.google.wifi_ext@1.0-service-vendor: Adding interface handle for wlan1
      W vendor.google.wifi_ext@1.0-service-vendor: No active wlan interfaces in use! Using default
      I wificond: Unsubscribe scan result for interface with index: 47
      I wificond: tearDownClientInterface: erasing wiphy_index for iface_name wlan0
      I wificond: remove channel type 0 support at wiphy index 0
      I wificond: remove channel type 1 support at wiphy index 0
      I wificond: remove channel type 3 support at wiphy index 0
      D vendor.google.wifi_ext@1.0-service-vendor: Stopping legacy HAL
      I vendor.google.wifi_ext@1.0-service-vendor: Legacy HAL stop complete callback received
      D vendor.google.wifi_ext@1.0-service-vendor: Legacy HAL event loop terminated
      D vendor.google.wifi_ext@1.0-service-vendor: Legacy HAL stop complete
      I vendor.google.wifi_ext@1.0-service-vendor: Wifi HAL stopped
      W AlarmManager: Window length 1152921504606846975ms too long; limiting to 1 day

      I wonder if it is related?

      MetropleX Maybe, but I have a number of saved networks (home, work, etc.) and the phone never turned on for any of them. I think that the probability of all of them being poor is very low.

      Also: the phone is lying 20cm away from the router. RSSI = -23.

        MetropleX I am referring to how the RSSI is shown in the UI. It is customary to show signal strength as a negative number of dBm.

        -23 RSSI is an excellent signal.

        You are referring at how it is represented internally (unsigned byte) and I do not know the formula to map one scale to the other.

        4 months later

        Bummer, I turned that on yesterday expecting it to be a nice privacy feature. But then I realized just now, that my Wifi was not back on after being home again.

        a month later

        I just realized too, that this not working. Very bad.

        a year later

        With automation apps like Tasker or Macrodroid, you can set a geofence for where you want your wifi to turn on. Inconvenient to have to set up a 3rd party app, I know, but better than nothing.

        • de0u replied to this.
          4 months later

          Same problem here. A year later, is this working yet for anyone?

          • de0u replied to this.

            JovialIntellect I believe the status in the GitHub issue that was linked to above (lbschenkel) is still accurate, and I suspect the workaround described above (hemlockiv) may well still be accurate.

            The GrapheneOS project has expressed an interest in working with beaconDB on a fused geolocation provider which might well address this issue among others, but I am unaware of reportable progress on that front so far.

            People are welcome to subscribe to the GitHub issue (via the "Subscribe" button), and also welcome to express interest via reaction buttons (e.g., "thumbs up"), but are requested to not add "me too" comments to the issue, because that accomplishes nothing beyond spamming the developers, who are likely to lock the issue. That said, pull requests with high-quality code are in scope...

            Meanwhile, just leaving Wi-Fi on all the time works well for most people.