Dans Android 12 et versions ultérieures, Android peut éventuellement utiliser un système mondial de navigation par satellite (GNSS) pour suggérer des heures Unix au service time_detector
.
Cette option n'est pas activée par défaut dans AOSP.
Lorsque la détection de l'heure GNSS est activée, gnss_time_update_service
écoute passivement les mises à jour de localisation provenant de sources GNSS et envoie des suggestions GNSS au service time_detector
. Le service time_detector
détermine ensuite s'il faut mettre à jour l'horloge système pour qu'elle corresponde à la suggestion.
Impact sur la consommation d'énergie
gnss_time_update_service
AOSP écoute passivement les mises à jour de position. Cela signifie qu'il n'active jamais activement le GPS ni ne consomme d'énergie supplémentaire. Cela signifie également que, sauf si une autre application ou un autre service du système demande activement des mises à jour de la position, gnss_time_update_service
ne recevra pas de mise à jour de la position et ne suggérera pas d'heure GNSS.
Implémentation
Pour activer la détection de l'heure GNSS, les fabricants d'appareils doivent activer explicitement gnss_time_update_service
dans le serveur système.
Pour activer cette fonctionnalité, vous devez mettre à jour les valeurs config_enableGnssTimeUpdateService
et config_autoTimeSourcesPriority
dans le fichier core/res/res/values/config.xml
. Définissez la valeur de config_enableGnssTimeUpdateService
sur true
et ajoutez gnss
à la liste d'éléments pour config_autoTimeSourcesPriority
. La position de gnss
dans la liste de priorité détermine la priorité accordée aux suggestions GNSS par rapport à celles provenant d'autres sources.
Voici un exemple de fichier core/res/res/values/config.xml
dans lequel la détection de l'heure GNSS est activée et gnss
est en troisième position dans la liste des priorités après network
et 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>
Débogage et test
Pour tester la détection de l'heure GNSS, vous pouvez utiliser les commandes adb shell cmd location
.
Utilisez ces commandes pour ajouter des fournisseurs de localisation de test où vous pouvez spécifier une position et l'heure GNSS associée. gnss_time_update_service
écoute ces mises à jour de localisation et fait des suggestions périodiquement.
Voici des exemples de commandes 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