A partir de Android 12, Android puede usar, de manera 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 se habilita la detección de tiempo GNSS, gnss_time_update_service
escucha de forma pasiva las actualizaciones de ubicación de las fuentes de GNSS y envía sugerencias de 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 gnss_time_update_service
de AOSP escucha de forma pasiva las actualizaciones de ubicación. Esto significa que nunca enciende 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 actualizaciones de ubicación de forma activa, gnss_time_update_service
no recibirá una actualización de ubicación ni sugerirá una hora del GNSS.
Implementación
Para habilitar la detección de la hora GNSS, los fabricantes de dispositivos deben habilitar explícitamente el gnss_time_update_service
en el servidor del sistema.
Para habilitar esta función, se deben actualizar los valores config_enableGnssTimeUpdateService
y config_autoTimeSourcesPriority
del archivo core/res/res/values/config.xml
. 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 prioridades determina la prioridad que se les otorga a las sugerencias de GNSS en relación con las de otras fuentes.
El siguiente es un ejemplo de archivo core/res/res/values/config.xml
en el que está habilitada la detección de hora del GNSS y gnss
es el tercero 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
Para probar la detección de hora del GNSS, puedes usar los comandos adb shell cmd location
.
Usa estos comandos para agregar proveedores de ubicaciones de prueba en los que puedes especificar una ubicación 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 UIDadb 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 provideradb 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