تشخیص زمان GNSS

از اندروید 12، اندروید به صورت اختیاری می‌تواند از یک سیستم ماهواره‌ای ناوبری جهانی (GNSS) برای پیشنهاد زمان‌های یونیکس به سرویس time_detector استفاده کند. این به طور پیش فرض در AOSP فعال نیست.

وقتی تشخیص زمان GNSS فعال است، gnss_time_update_service به طور غیر فعال به به‌روزرسانی‌های مکان از منابع GNSS گوش می‌دهد و پیشنهادات GNSS را به سرویس time_detector ارسال می‌کند. سپس سرویس time_detector تعیین می کند که آیا ساعت سیستم را برای مطابقت با پیشنهاد به روز کند یا خیر.

تاثیر بر مصرف برق

AOSP gnss_time_update_service به طور منفعلانه به به‌روزرسانی‌های مکان گوش می‌دهد. این بدان معنی است که هرگز به طور فعال GPS را روشن نمی کند یا انرژی اضافی مصرف نمی کند. این همچنین به این معنی است که مگر اینکه برنامه یا سرویس دیگری در سیستم به‌طور فعال درخواست به‌روزرسانی مکان کند، gnss_time_update_service به‌روزرسانی مکان را دریافت نمی‌کند و زمان GNSS را پیشنهاد نمی‌کند.

پیاده سازی

برای فعال کردن تشخیص زمان GNSS، سازندگان دستگاه باید به صراحت gnss_time_update_service در سرور سیستم فعال کنند.

برای فعال کردن این ویژگی، هر دو مقدار config_enableGnssTimeUpdateService و config_autoTimeSourcesPriority در فایل core/res/res/values/config.xml باید به روز شوند. مقدار config_enableGnssTimeUpdateService را روی true تنظیم کنید و gnss به لیست آیتم برای config_autoTimeSourcesPriority اضافه کنید. موقعیت gnss در لیست اولویت، اولویتی را که به پیشنهادات GNSS نسبت به پیشنهادات سایر منابع داده می شود، تعیین می کند.

فایل زیر نمونه‌ای از فایل core/res/res/values/config.xml است که در آن تشخیص زمان GNSS فعال است و gnss بعد از network و 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>

اشکال زدایی و تست

برای آزمایش تشخیص زمان GNSS، می‌توانید از دستورات adb shell cmd location استفاده کنید. از این دستورات برای اضافه کردن ارائه دهندگان مکان آزمایشی استفاده کنید، جایی که می توانید یک مکان و زمان GNSS مرتبط را مشخص کنید. gnss_time_update_service به این به‌روزرسانی‌های مکان گوش می‌دهد و به‌صورت دوره‌ای پیشنهادهایی ارائه می‌دهد.

در زیر نمونه‌هایی از دستورات 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. 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 lower than the limit set by the lower bound.)
adb shell cmd location providers set-test-provider-location gps --location LATITUDE,LONGITUDE --time TIME