Detección de tiempo GNSS

A partir de Android 12, Android puede usar opcionalmente un sistema de navegación global por satélite (GNSS) para sugerir épocas de Unix al servicio time_detector . Esto no está habilitado de forma predeterminada en AOSP.

Cuando la detección de hora GNSS está habilitada, gnss_time_update_service escucha pasivamente las actualizaciones de ubicación de fuentes GNSS y envía sugerencias GNSS al servicio time_detector . Luego, el servicio time_detector determina si se 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 escucha pasivamente las actualizaciones de ubicación. Esto significa que nunca enciende activamente el GPS ni consume energía adicional. Esto también significa que, a menos que otra aplicación o servicio en el sistema solicite activamente actualizaciones de ubicación, gnss_time_update_service no obtendrá una actualización de ubicación ni sugerirá una hora GNSS.

Implementación

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

Tanto los valores config_enableGnssTimeUpdateService como config_autoTimeSourcesPriority en el archivo core/res/res/values/config.xml deben actualizarse para habilitar esta característica. Establezca el valor de config_enableGnssTimeUpdateService en true y agregue gnss a la lista de elementos de config_autoTimeSourcesPriority . La posición de gnss en la lista de prioridades determina la prioridad otorgada a las sugerencias de GNSS con respecto a las de otras fuentes.

El siguiente es un ejemplo de archivo core/res/res/values/config.xml donde la detección de hora GNSS está habilitada y gnss ocupa el tercer lugar 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 prueba

Para probar la detección de hora GNSS, puede utilizar los comandos adb shell cmd location . Utilice estos comandos para agregar proveedores de ubicación de prueba donde pueda especificar una ubicación y la hora GNSS asociada. El 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. Will throw 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