זיהוי זמן GNSS

ב-Android מגרסה 12 ואילך, מערכת Android יכולה להשתמש באופן אופציונלי במערכת גלובלית לניווט לווייני (GNSS) כדי להציע זמני תקופת Unix לשירות 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:

  • הפעלת המתג הראשי למיקום עבור המשתמש בחזית (בדרך כלל משתמש 10 במערכות לרכב). אם הרגע ביצעתם פלאשינג, תוכלו לעשות זאת באמצעות אשף ההגדרה.

    adb shell cmd location set-location-enabled true --user 10
  • הוספה של ספק בדיקת GPS (בדרך כלל נכשלת בפעם הראשונה ומופיע חריג אבטחה עם android from <SOME_UID> not allowed to perform MOCK_LOCATION)

    adb shell cmd location providers add-test-provider gps
  • הפעלת הרשאות הדמיית מיקום עבור UID קודם

    adb shell appops set UID_PRINTED_IN_PREVIOUS_ERROR android:mock_location allow
  • הוספת ספק בדיקת GPS (אמור לפעול ללא שגיאות)

    adb shell cmd location providers set-test-provider-enabled gps true
  • הפעלת ספק בדיקות GPS

    adb shell cmd location providers set-test-provider-enabled gps true
  • הגדרת מיקום עם זמן (הזמן לא יכול להיות נמוך מהמגבלה שהוגדרה על ידי הגבול התחתון)

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