Détection de l'heure GNSS

À partir d'Android 12, Android peut éventuellement utiliser un Global Navigation Satellite System (GNSS) pour suggérer des heures d'epoch Unix aux time_detector. Cette option n'est pas activée par défaut dans AOSP.

Lorsque la détection de temps GNSS est activée, le gnss_time_update_service est passivement écoute les mises à jour de position à partir de sources GNSS et envoie des suggestions GNSS à le service time_detector. Le service time_detector détermine ensuite si pour mettre à jour l'horloge système en fonction de la suggestion.

Impact sur la consommation d'énergie

L'AOSP gnss_time_update_service écoute passivement les mises à jour de la position. Ce signifie que le GPS n'est jamais activé et qu'il ne consomme jamais d'énergie supplémentaire. Ce Cela signifie aussi que, sauf si une autre application ou un autre service du système demandant des mises à jour de la position géographique, l'gnss_time_update_service ne recevra pas de position et suggérer une heure GNSS.

Implémentation

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

Les config_enableGnssTimeUpdateService et Valeurs config_autoTimeSourcesPriority dans le core/res/res/values/config.xml doit être mis à jour pour activer cette fonctionnalité. Définissez la valeur de De config_enableGnssTimeUpdateService à true et d'ajouter gnss à la liste des éléments pour config_autoTimeSourcesPriority. La position de gnss dans la priorité détermine la priorité accordée aux suggestions GNSS par rapport à ces provenant d'autres sources.

Voici un exemple de fichier core/res/res/values/config.xml où GNSS la détection de l'heure est activée et gnss est en troisième position après le classement 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 vous permettant de spécifier un le lieu et l'heure GNSS associée. Le gnss_time_update_service écoute ces mises à jour de la position géographique et envoie régulièrement des suggestions.

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 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