التعرّف التلقائي على الوقت

يتلقى اكتشاف الوقت التلقائي اقتراحات الوقت من مصادر مختلفة، ويحدد الخيار الأفضل، ثم تضبط ساعة النظام في Android لتتطابق مع هذه الساعة. توفير إصدارات سابقة من Android طريقتين لتحديد التاريخ والوقت، إما يدويًا لكل مستخدم أو عن طريق اكتشاف الوقت التلقائي، باستخدام أحد الخيارات التالية:

  • يستخدم telephony إشارات الاتصال الهاتفي التي تتعلّق بهوية الشبكة والمنطقة الزمنية (NITZ).
  • يستخدم network خوادم وقت بروتوكول وقت الشبكة (NTP).

يتطلب كل خيار اتصالات بشبكات خارجية لا تتوفر دائمًا في نظام Android. السيارات. على سبيل المثال، في بعض البلدان، قد لا تحتوي بعض السيارات على خدمة هاتفية مدمجة. ولذلك، يتم تقديم وقت أنظمة التنقل عبر القمر الصناعي العالمية (GNSS) كمصدر للنظام الوقت الذي يمكنك استخدامه عند عدم توفر الاتصال بالشبكة.

يوفّر إصدار Android القادم هذا خيارَين إضافيَّين لرصد الوقت وضبطه تلقائيًا:

  • يستخدم gnss القمر الصناعي العالمي أنظمة التنقل (GNSS).
  • استخدامان (external) إحدى خصائص VHAL أو System API.

تفعيل ميزة "الرصد التلقائي للوقت"

لتفعيل ميزة "الرصد التلقائي للوقت"، تأكَّد من اختيار الإعدادات > التاريخ الوقت > التاريخ التلقائي الوقت:

الشكل 1. اختَر "التاريخ التلقائي". مدة

إعداد مصادر الوقت

لتحديد مصادر الوقت المراد تضمينها في رصد الوقت التلقائي، وأولوية الذي يجب أخذ فيه مصادر الوقت هذه في الاعتبار، يجب تعديل مورد الجهاز ملف الإعداد، 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>

في هذا المثال، تشمل القيمتان telephony وnetwork. يتم منح الأولوية لميزة "رصد الوقت" التلقائي و"اقتراحات زمنية" واحدة (telephony). قبل اقتراحين (network) للوقت.

بشكل عام، يتم تجاهل الاقتراحات الواردة من مصدر ذي أولوية أعلى إذا كان الاقتراح إما أنه غير صالح أو إذا كان الاقتراح قديمًا جدًا. كذلك، إذا كان الاقتراح الصالح ذو الأولوية الأعلى تطابق وقت ساعة النظام الحالي في الجهاز خلال عدة ثوانٍ (القيمة التلقائية ثانيتان (2)، فلن يتغير الوقت.

أدنى وقت محدد

يوفّر Android 12 حدودًا زمنية أقل جديدة لاستخدامها في الحالات التي والتحقق من صحة اقتراحات الوقت. قبل هذه الميزة، لم يكن كشف الوقت التلقائي للتحقق من صحة اقترح ذلك التوقيت العالمي المتفق عليه. وباستخدام هذه الميزة، تكون الأوقات المنقضية قبل الحد الأدنى تم تجاهله.

ويتم تحديد قيمة الحد الأدنى من تاريخ مشتق من الطابع الزمني للإصدار. هذا يعمل على مبدأ أنه لا يمكن أن يحدث وقت صالح قبل إنشاء صورة النظام. ولا يعمل Android فرض حد أعلى.

اقتراحات الوقت في GNSS

مصدر الوقت "gnss" جديد في نظام Android 12 ويتم توفيره من خلال إشارات نظام تحديد المواقع العالمي (GPS). هذا هو مصدر موثوق به للوقت عند عدم توفّر telephony وnetwork. تتم إضافة هذا الخيار إلى GnssTimeUpdateService الجديدة في SystemServer الذي يستمع بشكل سلبي إلى تحديثات الموقع الجغرافي. عند تلقّي موقع جغرافي صالح، يتم اقتراح اقتراح من قِبل GnssTimeUpdateService على TimeDetectorService، والذي ثم تحدد ما إذا كان يجب تحديث ساعة النظام أم لا.

لا يكون مصدر الوقت gnss مفعّلاً تلقائيًا في AOSP، وبالتالي يجب أن يفعّلها الشركاء:

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

لتفعيل هذه الميزة:

  1. يتوفّر تحديث لجهاز config_enableGnssTimeUpdateService قيمة يجب ضبط config_enableGnssTimeUpdateService على true.
  2. يتوفّر تحديث لجهاز config_autoTimeSourcesPriority يجب إضافة gnss إلى قائمة العناصر لـ config_autoTimeSourcesPriority. موضع gnss في قائمة الأولويات الأولوية الممنوحة لاقتراحات GNSS، في ما يتعلق بالقيم من مصادر أخرى.

التأثير على الطاقة

يستمع تطبيق "GnssTimeUpdateService" بشكل سلبي إلى تعديلات الموقع الجغرافي، ما يعني أنّ الجهاز يرصد ذلك. مطلقًا تشغيل نظام تحديد المواقع العالمي (GPS) لاستهلاك المزيد من الطاقة. وبناءً على ذلك، يمكن أن تكون الطاقة المستهلكة تفعيل مصدر GNSS ضئيل. وهذا يعني أيضًا أنه ما لم يكن هناك تطبيق أو خدمة أخرى في يطلب النظام إجراء تعديلات على الموقع الجغرافي بشكل نشط، لا يحصل GnssTimeUpdateService على موقع جغرافي. تحديث واقتراح وقت GNSS.

الاختبار

مجموعة اختبار التوافق (CTS)

يتم تقديم اختبار CTS للتحقّق من توفُّر الوقت الذي توفّره GNSS. للحصول على التفاصيل، يمكنك مراجعة LocationShellCommand.java

اختبارات الوحدات

اطّلِع على اختبارات الوحدة الأساسية في الملف التالي:

atest frameworks/base/services/tests/servicestests/src/com/android/server/timedetector/GnssTimeUpdateServiceTest.java

الاختبارات اليدوية

ولاختبار هذه الميزة، تمّت إضافة أوامر جديدة إلى LocationShellCommand.java يمكنك استخدام هذه الأوامر لإضافة اختبار الجهات التي يمكنك تحديد الموقع الجغرافي والوقت المرتبط بها على نظام GNSS. يتم الاستماع إلى إشعارات الموقع الجغرافي هذه بشكل دوري من قِبل GnssTimeUpdateService ويقدمون الاقتراحات.

ملاحظة: قد تتغير واجهة هذه الأوامر من إصدار لآخر.

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

اقتراحات الوقت الخارجية

اقتراحات الوقت الخارجية هي طريقة أخرى لتقديم اقتراحات وقت تلقائية Android تتيح لكم هذه الخيارات الجديدة تقديم اقتراحات زمنية مخصّصة بالكامل لنظام التشغيل Android. التي يمكن أن تنشأ من وحدات إقراضية متعددة (ECUs) يمكن أن تستخدم بدورها مزيجًا من الساعة في الوقت الفعلي GNSS أو NITZ أو أي مصدر وقت آخر.

تتوفّر الاقتراحات التالية في الإصدار 12 من نظام Android والتي يمكن استخدامها باسم "external" اقتراحات الوقت:

  • خصائص VHAL: تحوّل في سمة VHAL اسم EPOCH_TIME. تشير هذه السمة إلى عدد بالمللي ثانية التي انقضت منذ 1/1/1970 بالتوقيت العالمي المنسق. ويمكن تمرير قيمتها إلى الإصدار TimeManager من نظام التشغيل Android لاقتراح وقت جديد للنظام. نموذج VHAL عملية تنفيذ التعديلات التي تم إجراؤها على هذا الموقع، يتم توفيرها في تنفيذ المرجع أدناه.
  • واجهات برمجة تطبيقات النظام: طريقة جديدة تُسمى suggestExternalTime() هي أداة متوفرة في "مدير الوقت" لتزويد النظام باقتراح وقت خارجي. إذا تم ضبط النظام ليأخذ في الاعتبار اقتراحات الوقت الخارجية (باستخدام config_autoTimeSourcesPriorityفي ملف الإعداد)، والطابع الزمني يتم تمريرها إلى هذه الطريقة لتعيين وقت النظام، إذا لم تكن هناك تتوفّر اقتراحات ذات أولوية زمنية.

يمكنك تنفيذ حل خارجي للوقت كما هو موضّح أدناه:

  1. تعديل ملف إعداد المورد (core/res/res/values/config.xml) ثم أضف القيمة external إلى config_autoTimeSourcesPriority:
    <string-array name="config_autoTimeSourcesPriority>
            <item>external</item>
            <item>gnss</item>
    </string-array>

    يؤدي إجراء ذلك إلى توجيه Android إلى إعطاء الأولوية القصوى لاقتراحات الوقت الخارجية عند ضبط الإعدادات. ساعة النظام. يكتب الجهاز في المركبة اقتراحًا بالطابع الزمني إلى الوحدة الجديدة EPOCH_TIME سمة VHAL:

  2. يقرأ التطبيق الذي يوفّره المورّد هذا الموقع ويتصل TimeManager.suggestExternal() ويمكن لنظام Android بعد ذلك استخدام الطابع الزمني المقدَّم. كقيمة ساعة النظام الجديدة.