In Android 12 und höher kann Android optional ein Global Navigation Satellite System (GNSS) verwenden, um dem time_detector
-Dienst Unix-Epochenzeiten vorzuschlagen.
Diese Funktion ist in AOSP nicht standardmäßig aktiviert.
Wenn die GNSS-Zeiterkennung aktiviert ist, empfängt gnss_time_update_service
passiv Standortaktualisierungen von GNSS-Quellen und sendet GNSS-Vorschläge an den time_detector
-Dienst. Der time_detector
-Dienst entscheidet dann, ob die Systemuhr entsprechend dem Vorschlag aktualisiert werden soll.
Auswirkungen auf den Stromverbrauch
Das AOSP-gnss_time_update_service
empfängt Standortaktualisierungen passiv. Das bedeutet, dass das GPS nie aktiv eingeschaltet wird und kein zusätzlicher Strom verbraucht wird. Das bedeutet auch, dass gnss_time_update_service
nur dann ein Standort-Update erhält und eine GNSS-Zeit vorschlägt, wenn eine andere App oder ein anderer Dienst im System aktiv Standort-Updates anfordert.
Implementierung
Damit die GNSS-Zeiterkennung aktiviert werden kann, müssen Gerätehersteller gnss_time_update_service
explizit auf dem Systemserver aktivieren.
Sowohl die config_enableGnssTimeUpdateService
- als auch die config_autoTimeSourcesPriority
-Werte in der Datei core/res/res/values/config.xml
müssen aktualisiert werden, damit diese Funktion aktiviert werden kann. 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 zugewiesen 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
an dritter Stelle in der Prioritätsliste 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. Die gnss_time_update_service
reagiert auf 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 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