Detección de tiempo GNSS

En Android 12 y versiones posteriores, Android puede usar de forma opcional un sistema global de navegación por satélite (GNSS) para sugerir tiempos de época de Unix al servicio time_detector. Esta opción no está habilitada de forma predeterminada en AOSP.

Cuando la detección de tiempo GNSS está habilitada, gnss_time_update_service escucha de forma pasiva las actualizaciones de ubicación de las fuentes GNSS y envía sugerencias de GNSS al servicio time_detector. Luego, el servicio time_detector determina si debe actualizar el reloj del sistema para que coincida con la sugerencia.

Impacto en el uso de energía

El AOSP gnss_time_update_service detecta de forma pasiva las actualizaciones de ubicación. Esto significa que el servicio nunca activa el GPS de forma activa ni consume energía adicional. Esto también significa que, a menos que otra app o servicio del sistema solicite de forma activa actualizaciones de la ubicación, gnss_time_update_service no recibirá una actualización de la ubicación ni sugerirá una hora del GNSS.

Implementación

Para habilitar la detección de hora del GNSS, los fabricantes de dispositivos deben habilitar de forma explícita gnss_time_update_service en el servidor del sistema.

Los valores config_enableGnssTimeUpdateService y config_autoTimeSourcesPriority del archivo core/res/res/values/config.xml deben actualizarse para habilitar esta función. Establece el valor de config_enableGnssTimeUpdateService en true y agrega gnss a la lista de elementos de config_autoTimeSourcesPriority. La posición de gnss en la lista de prioridad determina la prioridad que se les otorga a las sugerencias del GNSS en comparación con las de otras fuentes.

A continuación, se muestra un ejemplo de un archivo core/res/res/values/config.xml en el que se habilita la detección de la hora del GNSS y gnss ocupa el tercer lugar en la lista de prioridad después de network y telephony:

<!-- Specifies priority of automatic time sources. Suggestions from higher entries in the list
         take precedence over lower ones.
         See com.android.server.timedetector.TimeDetectorStrategy for available sources. -->
    <string-array name="config_autoTimeSourcesPriority">
        <item>network</item>
        <item>telephony</item>
        <item>gnss</item>
    </string-array>

    <!-- Enables the GnssTimeUpdate service. This is the global switch for enabling Gnss time based
         suggestions to TimeDetector service. See also config_autoTimeSourcesPriority. -->
    <bool name="config_enableGnssTimeUpdateService">true</bool>

Depuración y pruebas

Para probar la detección de hora del GNSS, usa los comandos adb shell cmd location. Usa estos comandos para agregar proveedores de ubicación de prueba en los que puedes especificar una ubicación y la hora del GNSS asociada. gnss_time_update_service escucha estas actualizaciones de ubicación y hace sugerencias periódicamente.

A continuación, se muestran ejemplos de comandos adb shell cmd location:

  • Habilita el interruptor de ubicación principal para el usuario en primer plano (por lo general, el usuario 10 en el automóvil). Si acabas de instalar el software, puedes hacerlo a través del asistente de configuración.

    adb shell cmd location set-location-enabled true --user 10
  • Agrega el proveedor de pruebas de GPS (por lo general, falla la primera vez y arroja una excepción de seguridad con android from <SOME_UID> not allowed to perform MOCK_LOCATION).

    adb shell cmd location providers add-test-provider gps
  • Habilita los permisos de ubicación simulada para el UID anterior

    adb shell appops set UID_PRINTED_IN_PREVIOUS_ERROR android:mock_location allow
  • Agrega un proveedor de pruebas de GPS (debería funcionar sin errores)

    adb shell cmd location providers set-test-provider-enabled gps true
  • Habilita el proveedor de pruebas de GPS

    adb shell cmd location providers set-test-provider-enabled gps true
  • Establece la ubicación con la hora (la hora no puede ser inferior al límite establecido por el límite inferior).

    adb shell cmd location providers set-test-provider-location gps --location LATITUDE,LONGITUDE --time TIME