Detección de hora de GNSS

A partir de Android 12, Android puede usar de manera opcional un Sistema global de navegación satelital (GNSS) para sugerir tiempos de épocas Unix al time_detector. Esta opción no está habilitada de forma predeterminada en el AOSP.

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

Impacto en el consumo de energía

gnss_time_update_service de AOSP escucha de forma pasiva actualizaciones de ubicación. Esta significa que nunca enciende el GPS de forma activa ni consume energía adicional. Esta también significa que, a menos que otra aplicación o servicio en el sistema solicita actualizaciones de ubicación, gnss_time_update_service no obtendrá una ubicación actualizar y sugerir una hora GNSS.

Implementación

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

Tanto config_enableGnssTimeUpdateService como Valores config_autoTimeSourcesPriority en core/res/res/values/config.xml debe actualizarse para habilitar esta función. Establece el valor para config_enableGnssTimeUpdateService a true y agrega gnss a la lista de elementos para config_autoTimeSourcesPriority. La posición de gnss en la prioridad list determina la prioridad que se le da a las sugerencias de GNSS con respecto a aquellas de otras fuentes.

El siguiente es un ejemplo de archivo core/res/res/values/config.xml en el que se usan GNSS la detección de tiempo está habilitada y gnss es la tercera en la lista de prioridades 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

Puedes usar comandos adb shell cmd location para probar la detección de hora del GNSS. Usa estos comandos para agregar proveedores de ubicación de prueba, en los que puedes especificar una y la hora de 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:

# Enable Master Location Switch in the foreground user (usually user 10 on automotive). If you just flashed, this can be done through setup wizard.
adb shell cmd location set-location-enabled true --user 10

# Add GPS test provider (This usually fails the first time. Throws a SecurityException with "android from <SOME_UID> not allowed to perform MOCK_LOCATION".)
adb shell cmd location providers add-test-provider gps

# Enable mock location permissions for previous UID
adb shell appops set UID_PRINTED_IN_PREVIOUS_ERROR android:mock_location allow

# Add GPS test provider (Should work with no errors.)
adb shell cmd location providers add-test-provider gps

# Enable GPS test provider
adb shell cmd location providers set-test-provider-enabled gps true

# Set location with time (Time can't be lower than the limit set by the lower bound.)
adb shell cmd location providers set-test-provider-location gps --location LATITUDE,LONGITUDE --time TIME