Reconocimiento de Wi-Fi

La función Wi-Fi Aware agregada en Android 8.0 permite que los dispositivos compatibles se descubran, se conecten y se midan (agregado en Android 9) entre sí directamente con el protocolo Wi-Fi Aware sin acceso a Internet ni a la red móvil. Esta función, basada en la especificación Wi-Fi Aware (versiones 2.0, 3.0, 3.1 y 4.0) de la Wi-Fi Alliance (WFA), permite compartir fácilmente datos de alta capacidad de procesamiento entre dispositivos y apps confiables que de otro modo estarían fuera de la red.

Ejemplos y fuente

Para usar esta función, los fabricantes de dispositivos deben implementar la HAL de proveedores de Wi-Fi. En Android 14 y versiones posteriores, la interfaz de la HAL del proveedor se define con AIDL. En Android 13 y versiones anteriores, la interfaz de la HAL del proveedor se define con HIDL.

Sigue la interfaz de Wi-Fi para usar la función de reconocimiento de Wi-Fi. Según la interfaz que se implemente, puede ser una de las siguientes opciones:

  • AIDL: hardware/interfaces/wifi/aidl
  • HIDL: hardware/interfaces/wifi/1.2 o posterior

Puedes consultar la HAL de Wi-Fi heredada para ver cómo se correlaciona con las interfaces de AIDL y HIDL: hardware/libhardware_legacy/+/android16-release/include/hardware_legacy/wifi_nan.h.

Implementación

Los fabricantes de dispositivos deben proporcionar compatibilidad con el framework y con la HAL o el firmware:

  • Framework:
    • Código del AOSP
    • Habilitar Aware: Requiere una marca de función y una marca de compilación
  • Compatibilidad con la HAL de Wi-Fi Aware (NAN) (lo que implica compatibilidad con el firmware)

Para implementar esta función, los fabricantes de dispositivos implementan la interfaz de Wi-Fi y habilitan dos marcas de funciones:

  • En BoardConfig.mk o BoardConfig-common.mk, ubicados en device/<oem>/<device>, agrega la siguiente marca:

    WIFI_HIDL_FEATURE_AWARE := true
    
  • En device.mk, ubicado en device/<oem>/<device>, modifica la variable de entorno PRODUCT_COPY_FILES para incluir compatibilidad con la función Wi-Fi Aware:

    PRODUCT_COPY_FILES +=
    frameworks/native/data/etc/android.hardware.wifi.aware.xml:$(TARGET_COPY_OUT_VENDOR)/etc/permissions/android.hardware.wifi.aware.xml
    

Wi-Fi Aware incluye el rango de dispositivos pares con el protocolo IEEE 802.11mc, también conocido como tiempo de ida y vuelta (RTT). Esta subfunción de Wi-Fi Aware depende de que el dispositivo admita la función de Wi-Fi RTT, es decir, requiere que el dispositivo admita tanto Wi-Fi Aware como Wi-Fi RTT. Para obtener más detalles, consulta RTT de Wi-Fi.

De lo contrario, AOSP incluye todo lo necesario para esta función.

La marca WIFI_HIDL_FEATURE_AWARE se ignora si se especifica la marca WIFI_HAL_INTERFACE_COMBINATIONS. Para obtener más información, consulta Simultaneidad de varias interfaces de Wi-Fi.

Aleatorización de MAC

Android requiere que la dirección MAC de las interfaces de descubrimiento (NMI) y de datos (NDP) de Wi-Fi Aware se aleatorice y no sea idéntica a la dirección MAC real del dispositivo. Las direcciones MAC deben cumplir con los siguientes requisitos:

  • Se aleatoriza cada vez que se habilita o se vuelve a habilitar el reconocimiento de Wi-Fi.
  • Cuando Wi-Fi Aware está habilitado, la dirección MAC debe aleatorizarse en un intervalo regular configurado por el parámetro NanConfigRequest.macAddressRandomizationIntervalSec. El framework lo configura de forma predeterminada en 30 minutos.

Suspender y reanudar

En Android 14 y versiones posteriores, Wi-Fi Aware permite que las apps con privilegios suspendan y reanuden las sesiones de descubrimiento activas (incluidas todas las rutas de datos asociadas con esas sesiones). La compatibilidad con esta capacidad permite que los dispositivos reanuden las sesiones de descubrimiento más rápido y usen menos energía, ya que las sesiones de descubrimiento se pueden suspender.

Si un dispositivo admite esta capacidad de suspensión y reanudación, el firmware suspende la sesión de Wi-Fi Aware cuando una app con privilegios suspende la sesión de reconocimiento. Cuando una sesión de detección está en estado suspendido, el dispositivo no transmite ni recibe ningún fotograma para esa sesión, incluidos los NDP activos en ella. Si se suspenden todas las sesiones de detección, el dispositivo no transmite ni recibe ningún fotograma de Wi-Fi Aware.

Cuando una app privilegiada reanuda una sesión de descubrimiento suspendida, el framework devuelve la sesión a su estado anterior, incluidas todas las sesiones de NDP asociadas. Reanudar una sesión de descubrimiento suspendida es más rápido que iniciar el reconocimiento de Wi-Fi y crear una sesión de descubrimiento nueva.

Para admitir la capacidad de suspender y reanudar las sesiones de detección, los fabricantes de dispositivos deben proporcionar compatibilidad con HAL y firmware. Para obtener más información, consulta IWifiNanIface.java.

Los fabricantes de dispositivos pueden usar comunicaciones fuera de banda (por ejemplo, BLE) para sincronizar la suspensión y la reanudación en varios dispositivos.

Validación

Android proporciona un conjunto de pruebas de unidades, pruebas del Conjunto de pruebas de compatibilidad (CTS) y pruebas del Verificador del CTS para validar la función de Wi-Fi Aware. El reconocimiento de Wi-Fi también se puede probar con el Conjunto de pruebas de proveedores (VTS).

Pruebas de unidades

Las pruebas del paquete de Wi-Fi Aware se ejecutan con lo siguiente:

Pruebas de servicio:

atest com.android.server.wifi.aware

Pruebas de administrador:

atest android.net.wifi.aware

Pruebas del Conjunto de pruebas de compatibilidad (CTS)

Usa las pruebas de CTS para validar la función de Wi-Fi Aware. El CTS detecta cuando la función está habilitada y, automáticamente, incluye las pruebas asociadas.

Las pruebas de CTS se pueden activar con lo siguiente:

atest SingleDeviceTest

Pruebas del verificador del CTS

Las pruebas del verificador del CTS validan el comportamiento de Wi-Fi Aware con dos dispositivos: un dispositivo de prueba y un dispositivo correcto conocido. Para ejecutar las pruebas, abre CTS Verifier y navega a la sección titulada Wi-Fi Aware Tests.