Wykrywanie czasu GNSS

W Androidzie 12 i nowszym system może opcjonalnie używać globalnego systemu nawigacji satelitarnej (GNSS), aby sugerować czasy epoki systemu Unix usłudze time_detector. W AOSP ta funkcja nie jest domyślnie włączona.

Gdy wykrywanie czasu GNSS jest włączone, gnss_time_update_service pasywnie nasłuchuje aktualizacji lokalizacji ze źródeł GNSS i przesyła sugestie GNSS do usługi time_detector. Usługa time_detector określa następnie, czy zaktualizować zegar systemowy zgodnie z sugestią.

Wpływ na zużycie energii

AOSP gnss_time_update_service pasywnie nasłuchuje aktualizacji lokalizacji. Oznacza to, że usługa nigdy aktywnie nie włącza GPS-u ani nie zużywa dodatkowej energii. Oznacza to również, że dopóki inna aplikacja lub usługa w systemie nie będzie aktywnie żądać aktualizacji lokalizacji, gnss_time_update_service nie otrzyma aktualizacji lokalizacji i nie zaproponuje czasu GNSS.

Implementacja

Aby włączyć wykrywanie czasu GNSS, producenci urządzeń muszą wyraźnie włączyć gnss_time_update_service na serwerze systemowym.

Aby włączyć tę funkcję, musisz zaktualizować wartości config_enableGnssTimeUpdateServiceconfig_autoTimeSourcesPriority w pliku core/res/res/values/config.xml. Ustaw wartość config_enableGnssTimeUpdateService na true i dodaj gnss do listy produktów dla config_autoTimeSourcesPriority. Pozycja gnss na liście priorytetów określa priorytet sugestii GNSS w stosunku do sugestii z innych źródeł.

Poniżej znajduje się przykład pliku core/res/res/values/config.xml, w którym włączone jest wykrywanie czasu GNSS, a gnss jest trzecim elementem na liście priorytetów po networktelephony:

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

Debugowanie i testowanie

Aby przetestować wykrywanie czasu GNSS, użyj poleceń adb shell cmd location. Użyj tych poleceń, aby dodać dostawców informacji o lokalizacji testowej, w których możesz określić lokalizację i powiązany z nią czas GNSS. gnss_time_update_service słucha tych aktualizacji lokalizacji i okresowo podaje sugestie.

Poniżej znajdziesz przykłady poleceń adb shell cmd location:

  • Włącz przełącznik głównej lokalizacji dla użytkownika na pierwszym planie (zwykle użytkownika 10 w przypadku samochodów). Jeśli właśnie przeprowadzono flashowanie, można to zrobić za pomocą kreatora konfiguracji.

    adb shell cmd location set-location-enabled true --user 10
  • Dodaj dostawcę testu GPS (zwykle za pierwszym razem się nie udaje i wyświetla wyjątek związany z bezpieczeństwem z kodem android from <SOME_UID> not allowed to perform MOCK_LOCATION).

    adb shell cmd location providers add-test-provider gps
  • Włączanie uprawnień do pozorowania lokalizacji dla poprzedniego identyfikatora UID

    adb shell appops set UID_PRINTED_IN_PREVIOUS_ERROR android:mock_location allow
  • Dodaj dostawcę testu GPS (powinien działać bez błędów)

    adb shell cmd location providers set-test-provider-enabled gps true
  • Włącz dostawcę testu GPS

    adb shell cmd location providers set-test-provider-enabled gps true
  • Ustaw lokalizację z czasem (czas nie może być niższy niż limit ustawiony przez dolną granicę)

    adb shell cmd location providers set-test-provider-location gps --location LATITUDE,LONGITUDE --time TIME