Reconocimiento de Wi-Fi

La función de Reconocimiento de Wi-Fi que se agregó en Android 8.0 permite que los dispositivos compatibles se descubran, se conecten y alcancen el rango (agregado en Android 9) entre sí directamente a través del protocolo de reconocimiento de Wi-Fi sin acceso a Internet o a la red móvil. Esta función, compilada según la especificación de reconocimiento de Wi-Fi de Wi-Fi Alliance (WFA) (versiones 2.0, 3.0, 3.1 y 4.0), permite compartir fácilmente datos de alta capacidad de procesamiento entre dispositivos y apps de confianza 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 del proveedor de Wi-Fi. En Android 14 y versiones posteriores, la interfaz de la HAL del proveedor se define con el AIDL. En el caso de Android 13 y versiones anteriores, la interfaz de la HAL del proveedor se define con el HIDL.

Sigue la interfaz de Wi-Fi para emplear la función de reconocimiento de Wi-Fi. Según la interfaz que se implemente, esto sucederá:

  • 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 AIDL y HIDL: hardware/libhardware_legacy/+/main/include/hardware_legacy/wifi_nan.h.

Implementación

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

  • Marco de trabajo:
    • Código del AOSP
    • Habilita el reconocimiento: Requiere una marca de función y una marca de compilación.
  • Compatibilidad con HAL de Wi-Fi Aware (NAN) (lo que implica compatibilidad con firmware)

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

  • En BoardConfig.mk o BoardConfig-common.mk, ubicado 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 de reconocimiento de Wi-Fi:

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

El reconocimiento de Wi-Fi incluye el rango de dispositivos con intercambio de tráfico a través del protocolo IEEE 802.11mc, también conocido como tiempo de ida y vuelta (RTT). Esta subfunción de reconocimiento de Wi-Fi es condicional en el dispositivo que admite la función Wi-Fi RTT. Es decir, requiere que el dispositivo admita tanto reconocimiento de Wi-Fi como Wi-Fi RTT. Para obtener más información, consulta Wi-Fi RTT.

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

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 del descubrimiento de reconocimiento de Wi-Fi (NMI) y las interfaces de datos (NDP) sean aleatorias y no sean idénticas a la verdadera dirección MAC del dispositivo. Las direcciones MAC deben ser las siguientes:

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

Suspender y reanudar

En Android 14 y versiones posteriores, el reconocimiento de Wi-Fi admite que las apps con privilegios puedan suspender y reanudar 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 reconocimiento de Wi-Fi cuando una app con privilegios suspende la sesión de descubrimiento. Cuando una sesión de descubrimiento se encuentra en estado suspendido, el dispositivo no transmite ni recibe tramas para esa sesión, incluidos los NDP activos en esa sesión. Si se suspenden todas las sesiones de descubrimiento, el dispositivo no transmite ni recibe tramas de reconocimiento de Wi-Fi.

Cuando una app con privilegios 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 activar el reconocimiento de Wi-Fi y crear una sesión de descubrimiento nueva.

Para admitir la capacidad de suspender y reanudar las sesiones de descubrimiento, 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 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 de CTS para validar la función de reconocimiento de Wi-Fi. 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 reconocimiento de Wi-Fi se ejecutan de la siguiente manera:

Pruebas de servicio:

atest com.android.server.wifi.aware

Pruebas del administrador:

atest android.net.wifi.aware

Pruebas del Conjunto de pruebas de compatibilidad (CTS)

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

Las pruebas del CTS se pueden activar usando lo siguiente:

atest SingleDeviceTest

Pruebas del verificador del CTS

Las pruebas del verificador del CTS validan el comportamiento de reconocimiento de Wi-Fi mediante dos dispositivos: uno de prueba y uno bien conocido. Para ejecutar las pruebas, abre el verificador del CTS y ve a la sección titulada Pruebas de reconocimiento de Wi-Fi.