Détection de l'heure GNSS

À partir d'Android 12, Android peut éventuellement utiliser un système global de navigation par satellite (GNSS) pour suggérer des heures d'époque Unix au service time_detector . Ceci n'est pas activé par défaut dans AOSP.

Lorsque la détection de l'heure GNSS est activée, le gnss_time_update_service écoute passivement les mises à jour de localisation des sources GNSS et soumet des suggestions GNSS au service time_detector . Le service time_detector détermine ensuite s'il convient de mettre à jour l'horloge système pour qu'elle corresponde à la suggestion.

Impact sur la consommation d'énergie

L'AOSP gnss_time_update_service écoute passivement les mises à jour de localisation. Cela signifie qu’il n’allume jamais activement le GPS ni ne consomme d’énergie supplémentaire. Cela signifie également qu'à moins qu'une autre application ou un autre service du système ne demande activement des mises à jour de localisation, le gnss_time_update_service ne recevra pas de mise à jour de localisation et ne suggérera pas d'heure GNSS.

Mise en œuvre

Pour activer la détection de l'heure GNSS, les fabricants d'appareils doivent explicitement activer le gnss_time_update_service sur le serveur système.

Les valeurs config_enableGnssTimeUpdateService et config_autoTimeSourcesPriority dans le fichier core/res/res/values/config.xml doivent être mises à jour pour activer cette fonctionnalité. Définissez la valeur de config_enableGnssTimeUpdateService sur true et ajoutez gnss à la liste d'éléments pour config_autoTimeSourcesPriority . La position du gnss dans la liste des priorités détermine la priorité accordée aux suggestions GNSS par rapport à celles provenant d'autres sources.

Ce qui suit est 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 le troisième 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 tests

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 d'emplacement de test où vous pouvez spécifier un emplacement et l'heure GNSS associée. Le gnss_time_update_service écoute ces mises à jour de localisation et fait des suggestions périodiquement.

Ce qui suit montre 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. 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