Rilevamento tempo GNSS

A partire da Android 12, Android può utilizzare facoltativamente una GNSS (Global Navigation Satellite System) per suggerire i tempi di Unix al time_detector. Questa opzione non è abilitata per impostazione predefinita in AOSP.

Quando il rilevamento del tempo GNSS è abilitato, gnss_time_update_service passivamente ascolta gli aggiornamenti sulla posizione da fonti GNSS e invia i suggerimenti GNSS a il servizio time_detector. Il servizio time_detector determina quindi se per aggiornare l'orologio di sistema in modo che corrisponda al suggerimento.

Impatto sul consumo energetico

L'AOSP gnss_time_update_service ascolta passivamente gli aggiornamenti sulla posizione. Questo indica che non accende mai attivamente il GPS e non consuma più energia. Questo significa anche che, a meno che un'altra app o un altro servizio nel sistema non stia attivamente richiedendo aggiornamenti sulla posizione, gnss_time_update_service non riceverà una posizione aggiornare e suggerire un orario GNSS.

Implementazione

Per abilitare il rilevamento dell'ora GNSS, i produttori dei dispositivi devono abilitare esplicitamente il parametro gnss_time_update_service nel server di sistema.

Sia config_enableGnssTimeUpdateService che Valori di config_autoTimeSourcesPriority in core/res/res/values/config.xml devi aggiornare il file per abilitare questa funzione. Imposta il valore per config_enableGnssTimeUpdateService a true e aggiungi gnss all'elenco di articoli per config_autoTimeSourcesPriority. La posizione di gnss nella priorità determina la priorità data ai suggerimenti GNSS rispetto a quelli provenienti da altre fonti.

Di seguito è riportato un esempio di file core/res/res/values/config.xml in cui GNSS il rilevamento dell'ora è abilitato e gnss è al terzo posto nell'elenco di priorità dopo network e 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>

Debug e test

Per testare il rilevamento del tempo GNSS, puoi usare i comandi adb shell cmd location. Utilizza questi comandi per aggiungere fornitori di località di test in cui puoi specificare un località e l'ora GNSS associata. gnss_time_update_service sta ascoltando la posizione si aggiorna e fornisce suggerimenti periodicamente.

Di seguito sono riportati esempi di comandi 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