Równoczesne korzystanie z punktów dostępu Wi-Fi

Android 12 wprowadza współbieżność punktów dostępu Wi-Fi, która umożliwia urządzeniom tworzenie 2 interfejsów punktów dostępu. Ta funkcja umożliwia urządzeniom obsługę tetheringu za pomocą dwupasmowego, jednoczesnego (DBS) hotspotu Wi-Fi (miękki punkt dostępu). Więcej informacji o obsłudze tetheringu za pomocą jednego hotspotu Wi-Fi znajdziesz w sekcji Hotspot Wi-Fi (Soft AP).

Na tej stronie opisujemy działanie urządzenia, gdy ta funkcja jest włączona, oraz szczegóły implementacji dla producentów i dostawców urządzeń.

Jak to działa

Gdy obsługiwana jest funkcja jednoczesnego działania punktu dostępu Wi-Fi, urządzenie może utworzyć 2 interfejsy punktu dostępu, np.jeden działający w paśmie 2,4 GHz, a drugi w paśmie 5 GHz. Klienci mogą następnie połączyć się z każdym interfejsem punktu dostępu.

Warstwa HAL Wi-Fi generuje pojedynczy interfejs pomostowy z 2 interfejsami punktu dostępu i udostępnia go stosowi Wi-Fi i łączności, gdy stos włącza programowy punkt dostępu. Po włączeniu programowego punktu dostępu interfejs HAL Wi-Fi wskazuje, że dostępne są 2 interfejsy, i aktualizuje informacje (takie jak kanał operacyjny, pasmo i identyfikator BSSID) dla każdego punktu dostępu.

Aby oszczędzać energię, platforma wyłącza nieużywany punkt dostępu (2, 4 GHz, 5 GHz lub 6 GHz) po pewnym okresie nieaktywności. Gdy żaden klient nie jest połączony, platforma uznaje punkt dostępu za nieaktywny. Producenci urządzeń mogą dostosować długość tego okresu nieaktywności. Więcej informacji znajdziesz w artykule Dostosowywanie okresu nieaktywności.

Urządzenia obsługują współbieżność punktu dostępu Wi-Fi/punktu dostępu, korzystając z jednej z tych konfiguracji mostkowego programowego punktu dostępu:

  • Konfigurowanie 2 pasm (kanał jest wybierany automatycznie przez platformę lub sterownik)
  • Konfigurowanie 2 kanałów na dwupasmowym punkcie dostępu

Wymagania

Aby zaimplementować współbieżność punktu dostępu Wi-Fi, urządzenia muszą spełniać te wymagania:

  • Chip Wi-Fi lub oprogramowanie sprzętowe musi obsługiwać 2 jednoczesne połączenia z punktem dostępu. Oprogramowanie musi obsługiwać wszystkie kombinacje kanałów i pasm w przypadku obu połączeń. Aby uniknąć problemów z wydajnością, zalecamy używanie układu Wi-Fi obsługującego DBS w konfiguracji 2x2+2x2.

  • Urządzenie musi obsługiwać te metody w warstwie HAL dostawcy Wi-Fi:

    • IWifiChip.createBridgedApIface()
    • IWifiChip.removeIfaceInstanceFromBridgedApIface()
    • IWifiApIface.resetToFactoryMacAddress()
    • IWifiApIface.getBridgedInstances()

Implementacja

Aby wdrożyć współbieżność punktów dostępu Wi-Fi, wykonaj te czynności:

  1. Włącz co najmniej jedną z tych funkcji (domyślnie wyłączonych) za pomocą nakładek na zasoby środowiska wykonawczego:

    • config_wifiBridgedSoftApSupported: obsługuje wiele punktów dostępu połączonych ze sobą w trybie bridge.
    • config_wifiStaWithBridgedSoftApConcurrencySupported: Obsługuje jednoczesne połączenie stacji (STA) i wielu połączonych mostem punktów dostępu.
  2. W przypadku urządzeń korzystających z AIDL Wi-Fi HAL lub HIDL Wi-Fi HAL 1.6 zdefiniuj AP_BRIDGED w kombinacji interfejsów Wi-Fi HAL. Więcej informacji znajdziesz w artykule Współbieżność wielu interfejsów Wi-Fi.

  3. Skonfiguruj mostkową konfigurację programowego punktu dostępu, wywołując jedną z tych metod:

  4. Zarejestruj wywołanie zwrotne, aby uzyskać możliwości urządzenia za pomocą funkcji WifiManager#registerSoftApCallback. SoftApCallback Wywołanie zwrotne udostępnia te metody konfiguracji połączonego programowego punktu dostępu:

Dostosowywanie okresu nieaktywności

Aby dostosować długość okresu nieaktywności, skonfiguruj tę nakładkę, którą znajdziesz w packages/modules/Wifi/service/ServiceWifiResources/res/values/config.xml:

  • config_wifiFrameworkSoftApShutDownIdleInstanceInBridgedModeTimeoutMillisecond: Domyślny interwał limitu czasu wyłączenia. Obowiązuje tylko wtedy, gdy włączona jest funkcja SoftApConfiguration#setBridgedModeOpportunisticShutdownEnabled.

  • (Dostępne od wersji 13) config_wifiFrameworkSoftApDisableBridgedModeShutdownIdleInstanceWhenCharging: Określa, czy wyłączyć timer wyłączania z powodu bezczynności podczas ładowania.