Deteksi waktu otomatis menerima saran waktu dari berbagai sumber, memilih opsi terbaik, lalu menyetel jam sistem di Android agar cocok. Rilis Android sebelumnya menyediakan dua cara untuk menyetel tanggal dan waktu, baik disetel secara manual per pengguna atau dengan deteksi waktu otomatis, dan disetel oleh salah satu opsi berikut:
telephony
menggunakan sinyal telepon Identitas Jaringan dan Zona Waktu (NITZ).network
menggunakan server waktu Network Time Protocol (NTP).
Setiap opsi memerlukan koneksi ke jaringan eksternal, yang tidak selalu tersedia di Android Automotive. Misalnya, di beberapa negara, beberapa mobil mungkin tidak memiliki telepon bawaan. Oleh karena itu, waktu Global Navigation Satellite System (GNSS) disediakan sebagai sumber waktu sistem yang dapat Anda gunakan saat konektivitas jaringan tidak tersedia.
Rilis Android mendatang ini menyediakan dua opsi lagi untuk mendeteksi dan menyetel waktu secara otomatis:
gnss
menggunakan Sistem Navigasi Satelit Global (GNSS).external
menggunakan properti VHAL atau System API.
Mengaktifkan deteksi waktu otomatis
Untuk mengaktifkan deteksi waktu otomatis, pastikan untuk memilih Setelan > Tanggal & Waktu > Tanggal & Waktu Otomatis:
Gambar 1. Pilih Tanggal & Waktu Otomatis
Mengonfigurasi sumber waktu
Untuk menentukan sumber waktu yang akan disertakan dalam deteksi waktu otomatis, dan prioritas
sumber waktu ini harus dipertimbangkan, Anda harus mengubah file konfigurasi
resource perangkat, core/res/res/values/config.xml
:
<!-- 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>telephony</item> <item>network</item> </string-array>
Dalam contoh ini, telephony
dan network
dipertimbangkan dalam
deteksi waktu otomatis dan saran waktu telephony
diprioritaskan
di depan saran waktu network
.
Secara umum, saran dari sumber dengan prioritas lebih tinggi akan diabaikan jika saran tersebut tidak valid atau jika saran tersebut sudah terlalu lama. Selain itu, jika saran valid dengan prioritas tertinggi cocok dengan waktu jam sistem perangkat saat ini dalam beberapa detik (nilai default adalah dua (2) detik), waktu tidak akan diubah.
Batas waktu yang lebih rendah
Android 12 menyediakan batas waktu yang lebih rendah baru untuk digunakan saat memvalidasi saran waktu. Sebelum fitur ini, deteksi waktu otomatis tidak akan memvalidasi waktu UTC masuk yang disarankan. Dengan fitur ini, waktu yang berlalu sebelum batas bawah dihapus.
Nilai batas bawah ditentukan dari tanggal yang berasal dari stempel waktu build. Hal ini berfungsi berdasarkan prinsip bahwa waktu yang valid tidak dapat terjadi sebelum image sistem dibuat. Android tidak menerapkan batas atas.
Saran waktu GNSS
Sumber waktu gnss
baru untuk Android 12 dan disediakan oleh sinyal GPS. Ini adalah
sumber yang andal untuk waktu saat telephony
dan network
tidak tersedia.
Opsi ini ditambahkan ke GnssTimeUpdateService
baru di
SystemServer yang secara pasif memproses pembaruan lokasi. Saat lokasi yang valid diterima,
GnssTimeUpdateService
akan memberikan saran ke TimeDetectorService
, yang
kemudian menentukan apakah jam sistem harus diperbarui.
Secara default, sumber waktu gnss
tidak diaktifkan di AOSP dan, oleh karena itu,
harus diaktifkan oleh partner:
<!-- 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>telephony</item> <item>network</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>
Untuk mengaktifkan fitur ini:
- Update
config_enableGnssTimeUpdateService
. Nilai untukconfig_enableGnssTimeUpdateService
harus ditetapkan ketrue
. - Update
config_autoTimeSourcesPriority
.gnss
harus ditambahkan ke daftar item untukconfig_autoTimeSourcesPriority
. Posisignss
dalam daftar prioritas menentukan prioritas yang diberikan ke saran GNSS, sehubungan dengan nilai dari sumber lain.
Dampak terhadap daya
GnssTimeUpdateService
memproses pembaruan lokasi secara pasif, yang berarti bahwa
tidak pernah secara aktif mengaktifkan GPS untuk menggunakan daya tambahan. Akibatnya, daya yang digunakan saat
sumber GNSS diaktifkan dapat diabaikan. Hal ini juga berarti bahwa kecuali jika aplikasi atau layanan lain dalam
sistem secara aktif meminta pembaruan lokasi, GnssTimeUpdateService
tidak akan mendapatkan pembaruan
lokasi dan menyarankan waktu GNSS.
Pengujian
Compatibility Test Suite (CTS)
Pengujian CTS disediakan untuk memverifikasi bahwa waktu yang disediakan GNSS tersedia. Untuk mengetahui detailnya, lihat
LocationShellCommand.java
.
Pengujian unit
Lihat pengujian unit dasar dalam file berikut:
atest frameworks/base/services/tests/servicestests/src/com/android/server/timedetector/GnssTimeUpdateServiceTest.java
Pengujian manual
Untuk menguji fitur ini, perintah baru telah ditambahkan ke
LocationShellCommand.java
. Gunakan perintah ini untuk menambahkan penyedia
pengujian yang dapat Anda gunakan untuk menentukan lokasi dan waktu GNSS terkait.
GnssTimeUpdateService
memproses pembaruan lokasi ini, dan secara berkala
memberikan saran.
Catatan: Antarmuka untuk perintah ini dapat berubah di antara rilis.
# 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 and will throw 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 earlier than the limit set by the lower bound.) adb shell cmd location providers set-test-provider-location gps --location <LATITUDE>,<LONGITUDE> --time <TIME>
Saran waktu eksternal
Saran waktu eksternal adalah cara lain untuk memberikan saran waktu otomatis ke Android. Opsi baru ini memungkinkan Anda memberikan saran waktu yang sepenuhnya disesuaikan ke Android, yang dapat berasal dari berbagai ECU yang, pada gilirannya, dapat menggunakan kombinasi jam real-time, GNSS, NITZ, atau sumber waktu lainnya.
Saran berikut tersedia di Android 12 untuk dipertimbangkan sebagai saran waktu
external
:
- Properti VHAL. Properti VHAL
baru bernama
EPOCH_TIME
disediakan. Properti ini menunjukkan jumlah milidetik yang telah berlalu sejak 1/1/1970 UTC. Nilainya dapat diteruskan keTimeManager
Android untuk menyarankan waktu sistem baru. Contoh implementasi VHAL yang memperbarui properti ini disediakan di implementasi referensi di bawah. - API Sistem. Metode baru yang disebut
suggestExternalTime()
tersedia di TimeManager untuk memberikan saran waktu eksternal kepada sistem. Jika sistem dikonfigurasi untuk mempertimbangkan saran waktu eksternal (menggunakanconfig_autoTimeSourcesPriority
dalam file konfigurasi), stempel waktu yang diteruskan ke metode ini digunakan untuk menyetel waktu sistem, jika tidak ada saran waktu prioritas yang lebih tinggi.
Anda dapat menerapkan solusi waktu eksternal seperti yang dijelaskan di bawah:
- Perbarui file konfigurasi resource (
core/res/res/values/config.xml
), lalu tambahkan nilaiexternal
keconfig_autoTimeSourcesPriority
:<string-array name="config_autoTimeSourcesPriority> <item>external</item> <item>gnss</item> </string-array>
Tindakan ini akan menginstruksikan Android untuk memberikan saran waktu eksternal dengan prioritas tertinggi saat menyetel jam sistem. Hardware di kendaraan menulis saran stempel waktu ke properti VHAL
EPOCH_TIME
baru. - Aplikasi yang disediakan vendor membaca properti ini dan memanggil
TimeManager.suggestExternal()
. Android kemudian dapat menggunakan stempel waktu yang diberikan sebagai nilai jam sistem baru.