GNSS-Zeiterkennung

Ab Android 12 kann Android optional ein globales Navigationssatellitensystem (Global Navigation Satellite System, GNSS) verwenden, um dem Dienst time_detector Unix-Epochenzeiten vorzuschlagen. Diese Funktion ist in AOSP nicht standardmäßig aktiviert.

Wenn die GNSS-Zeiterkennung aktiviert ist, gnss_time_update_service liest passiv Standortaktualisierungen von GNSS-Quellen und sendet GNSS-Vorschläge an den time_detector-Dienst. Der time_detector-Dienst bestimmt dann, ob die Systemuhr entsprechend dem Vorschlag aktualisiert werden soll.

Auswirkungen auf den Stromverbrauch

Das AOSP gnss_time_update_service überwacht passiv Standortaktualisierungen. Das bedeutet, dass das GPS nie aktiv eingeschaltet wird und auch nicht mehr Strom verbraucht. Das bedeutet auch, dass die gnss_time_update_service keinen Standortaktualisierungen erhält und keine GNSS-Zeit vorschlägt, es sei denn, eine andere App oder ein anderer Dienst im System fordert aktiv Standortaktualisierungen an.

Implementierung

Um die GNSS-Zeiterkennung zu aktivieren, müssen Gerätehersteller die gnss_time_update_service auf dem Systemserver explizit aktivieren.

Die Werte config_enableGnssTimeUpdateService und config_autoTimeSourcesPriority in der Datei core/res/res/values/config.xml müssen aktualisiert werden, um dieses Feature zu aktivieren. Legen Sie den Wert für config_enableGnssTimeUpdateService auf true fest und fügen Sie gnss der Artikelliste für config_autoTimeSourcesPriority hinzu. Die Position von gnss in der Prioritätsliste bestimmt die Priorität, die GNSS-Vorschlägen im Vergleich zu Vorschlägen aus anderen Quellen eingeräumt wird.

Das folgende Beispiel zeigt eine core/res/res/values/config.xml-Datei, in der die GNSS-Zeiterkennung aktiviert ist und gnss nach network und telephony in der Prioritätenliste an dritter Stelle steht.

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

Debugging und Tests

Zum Testen der GNSS-Zeiterkennung können Sie adb shell cmd location-Befehle verwenden. Mit diesen Befehlen können Sie Teststandortanbieter hinzufügen, bei denen Sie einen Standort und die zugehörige GNSS-Zeit angeben können. Der gnss_time_update_service überwacht diese Standortaktualisierungen und macht regelmäßig Vorschläge.

Im Folgenden finden Sie Beispiele für adb shell cmd location-Befehle:

# 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