AOSP के अल्ट्रा-वाइडबैंड (यूडब्ल्यूबी) स्टैक में, एचएएल के प्लैटफ़ॉर्म के तौर पर FiRa के तय किए गए यूसीआई इंटरफ़ेस का इस्तेमाल किया जाता है. UWB कमांड इंटरफ़ेस (यूसीआई) के निर्देश, जवाब, और सूचनाएं भेजने और पाने के लिए, एचएएल इंटरफ़ेस, अपॉकी पाइप (IUwbChip::sendUciMessage()
और IUwbClientCallback::onUciMessage()
) का इस्तेमाल करता है.
सभी Android UWB वेंडर को, FiRa स्पेसिफ़िकेशन में बताए गए सभी मैसेज के साथ काम करना होगा. यूडब्ल्यूबी फ़्रेमवर्क, पुराने वर्शन के साथ काम करता है. साथ ही, यह डिवाइस पर यूडब्ल्यूबी वेंडर के लागू किए गए किसी भी यूसीआई वर्शन के साथ काम करता है. AOSP UWB फ़्रेमवर्क एक मॉड्यूल है. इसलिए, यह चुनिंदा तौर पर, बदलाव के मंज़ूर किए गए अनुरोधों (सीआर) के लिए सहायता जोड़ सकता है. ये अनुरोध, यूसीआई के ड्राफ़्ट स्पेसिफ़िकेशन से लिए जाते हैं. ये स्पेसिफ़िकेशन, FiRa के मुख्य स्टैंडर्ड रिलीज़ के लिए टारगेट किए जाते हैं. लागू किए गए ऐसे किसी भी ड्राफ़्ट सीआर में बदलाव किया जा सकता है.
इंटरफ़ेस की परिभाषा
UWB HAL इंटरफ़ेस को स्टैबल एआईडीएल का इस्तेमाल करके तय किया जाता है.
मुख्य इंटरफ़ेस, android.hardware.uwb
पैकेज का इस्तेमाल करता है.
android.hardware.uwb
पैकेज में ये दो मुख्य इंटरफ़ेस हैं.
IUwbChip.aidl
package android.hardware.uwb;
interface IUwbChip {
String getName();
void open(in android.hardware.uwb.IUwbClientCallback clientCallback);
void close();
void coreInit();
void sessionInit(int sessionId);
int getSupportedAndroidUciVersion();
int sendUciMessage(in byte[] data);
}
IUwbClientCallback.aidl
package android.hardware.uwb;
interface IUwbClientCallback {
oneway void onUciMessage(in byte[] data);
oneway void onHalEvent(in android.hardware.uwb.UwbEvent event, in android.hardware.uwb.UwbStatus status);
}
UWB फ़्रेमवर्क से HAL कॉल फ़्लो
यहां दी गई इमेज में, UWB स्टैक को शुरू करने, बंद करने, और UWB सेशन शुरू करने और बंद करने की प्रोसेस के लिए, UWB फ़्रेमवर्क से कॉल फ़्लो दिखाया गया है.
पहली इमेज. UWB स्टैक को शुरू करने का कॉल फ़्लो (UWB टॉगल चालू है)
दूसरी इमेज. UWB स्टैक को डिफ़ॉल्ट स्थिति पर सेट करने का कॉल फ़्लो (UWB टॉगल बंद है)
तीसरी इमेज. UWB सेशन शुरू/बंद करने का फ़्लो
UWB के लिए देश कोड का कॉन्फ़िगरेशन
जैसा कि फ़िगर 1 में दिखाया गया है, UWB फ़्रेमवर्क, UWB स्टैक के शुरू होने के दौरान, वेंडर-स्पेस यूसीआई कमांड ANDROID_SET_COUNTRY_CODE
(GID=0xC
, OID=0x1
) का इस्तेमाल करके, UWB देश कोड को कॉन्फ़िगर करता है. UWB फ़्रेमवर्क, नीचे दिए गए सोर्स का इस्तेमाल करके, UWB देश कोड का पता लगाने की कोशिश करता है. ये सोर्स प्राथमिकता के क्रम में दिए गए हैं. UWB फ़्रेमवर्क, उस पहले सोर्स पर रुक जाता है जहां देश कोड तय किया जाता है.
- देश कोड बदलना: adb shell कमांड के ज़रिए देश कोड बदलना (लोकल या ऑटोमेटेड टेस्टिंग).
- टेलीफ़ोन के लिए देश का कोड: मोबाइल नेटवर्क से मिला देश का कोड. अगर एक से ज़्यादा सिम कार्ड अलग-अलग कोड दिखाते हैं, तो चुना गया देश कोड तय नहीं होता.
- वाई-फ़ाई का देश कोड: वाई-फ़ाई (80211.ad) से मिला देश कोड.
- मोबाइल नेटवर्क से जुड़े डिवाइस का पिछला देश कोड: मोबाइल नेटवर्क से जुड़े डिवाइस का पिछला देश कोड, जिसे मोबाइल नेटवर्क से हासिल किया गया था. अगर एक से ज़्यादा सिम कार्ड अलग-अलग कोड दिखाते हैं, तो चुना गया देश कोड तय नहीं होता.
- जगह की जानकारी के लिए देश का कोड:
LocationManager
जगह की जानकारी देने वाली सेवा देने वाली कंपनी से मिला देश का कोड. - ओईएम का डिफ़ॉल्ट देश कोड: डिवाइस बनाने वाली कंपनी का सेट किया गया देश कोड.
अगर UWB फ़्रेमवर्क, UWB देश कोड का पता नहीं लगा पाता है, तो वह DEFAULT_COUNTRY_CODE ("00")
की वैल्यू के साथ ANDROID_SET_COUNTRY_CODE
यूसीआई कमांड को कॉल करता है. साथ ही, UWB ऐप्लिकेशन को सूचना देता है कि UWB स्टैक की स्थिति DISABLED
है. बाद में, जब UWB फ़्रेमवर्क किसी मान्य देश कोड का पता लगा लेता है, तो वह ANDROID_SET_COUNTRY_CODE
कमांड का इस्तेमाल करके नए देश कोड को कॉन्फ़िगर करता है. साथ ही, UWB ऐप्लिकेशन को सूचना देता है कि UWB स्टैक READY
है.
अगर किसी देश के स्थानीय कानूनों की वजह से, UWB का इस्तेमाल नहीं किया जा सकता, तो UWB कंट्रोलर STATUS_CODE_ANDROID_REGULATION_UWB_OFF
स्टेटस कोड दिखाता है. इसके बाद, यूडब्ल्यूबी फ़्रेमवर्क, यूडब्ल्यूबी ऐप्लिकेशन को सूचना देता है कि यूडब्ल्यूबी स्टैक की स्थिति DISABLED
है.
जब कोई उपयोगकर्ता किसी दूसरे देश में जाता है, तो UWB फ़्रेमवर्क ANDROID_SET_COUNTRY_CODE
यूसीआई निर्देश का इस्तेमाल करके, नया देश कोड कॉन्फ़िगर करता है. UWB कंट्रोलर से मिले स्टेटस कोड (नए देश में UWB के नियमों के आधार पर) के आधार पर, UWB स्टैक की स्थिति में बदलाव हो सकता है.
FIRA UCI स्पेसिफ़िकेशन के मुताबिक निर्देश का फ़ॉर्मैट
यूसीआई कंट्रोल पैकेट के फ़ॉर्मैट के लिए, यूसीआई स्पेसिफ़िकेशन का सेक्शन 4.4.2 देखें.
इंटरफ़ेस का वर्शन
यूसीआई स्पेसिफ़िकेशन की मदद से, UWB वेंडर, UCI_GET_DEVICE_INFO_RSP
और
UCI_GET_CAPS_INFO_RSP
कमांड का इस्तेमाल करके, डिवाइस पर लागू किए गए यूसीआई स्टैक का वर्शन दिखा सकते हैं. फ़्रेमवर्क इन निर्देशों का इस्तेमाल करके, डिवाइस का यूसीआई वर्शन फ़ेच करता है और उसके हिसाब से डिवाइस के व्यवहार में बदलाव करता है.
UWB मॉड्यूल के साथ काम करने वाले ड्राफ़्ट सीआर की सूची
FiRa 2.0 के लिए, नीचे दिए गए ड्राफ़्ट सीआर, UWB मॉड्यूल के वर्शन #330810000 के साथ काम करते हैं:
Android यूसीआई इंटरफ़ेस (FiRa वेंडर का हिस्सा)
यूसीआई स्पेसिफ़िकेशन में, स्पेसिफ़िकेशन में बताए गए सभी मैसेज के लिए, ग्रुप आइडेंटिफ़ायर (जीआईडी) और ऑपरेंड कोड आइडेंटिफ़ायर (ओआईडी) का एक सेट तय किया गया है. स्पेसिफ़िकेशन में, वीआईपी के इस्तेमाल के लिए खास तौर पर GID का एक सेट भी रिज़र्व किया जाता है. AOSP UWB स्टैक, Android के लिए खास तौर पर बनाए गए उन निर्देशों के लिए, वेंडर के कुछ GID और OID का इस्तेमाल करता है जिन्हें स्पेसिफ़िकेशन में नहीं बताया गया है. ज़्यादा जानकारी के लिए, यूसीआई के स्पेसिफ़िकेशन का सेक्शन 8.4 देखें.
Android के ज़रिए इस्तेमाल किए जाने वाले वेंडर मैसेज, android.hardware.uwb.fira_android
HAL पैकेज में तय किए गए हैं.
वेंडर इंटरफ़ेस का वर्शन
UWB वेंडर को IUwbChip.getSupportedAndroidUciVersion()
के ज़रिए, डिवाइस पर काम करने वाले android.hardware.uwb.fira_android
HAL पैकेज का वर्शन दिखाना होगा. फ़्रेमवर्क, पुराने सिस्टम के साथ काम करने की सुविधा को मैनेज करने के लिए, वर्शन की इस जानकारी का इस्तेमाल करता है.
Android GID और OID की सूची
यहां दी गई टेबल में, Android के लिए GID और OID की सूची दी गई है. GIDs 0xE
और 0xF
का इस्तेमाल, Android OEMs के लिए किया जाता है.
GID | ओआईडी | परिभाषा |
---|---|---|
ANDROID = 0xC |
ANDROID_GET_POWER_STATS = 0x0 |
UWB पावर से जुड़े आंकड़े पाने के लिए, कमांड और रिस्पॉन्स में इसका इस्तेमाल किया जाता है.
यह सिर्फ़ तब काम करता है, जब
UwbVendorCapabilityTlvTypes.SUPPORTED_POWER_STATS_QUERY
को 1 पर सेट किया गया हो. |
ANDROID_SET_COUNTRY_CODE = 0x1 |
इसका इस्तेमाल, देश के मौजूदा रेगुलेटरी कोड को सेट करने के लिए किया जाता है. यह कोड, सिम या वाई-फ़ाई का इस्तेमाल करके तय किया जाता है या OEM ने इसे हार्डकोड किया होता है. देश का कोड, आईएसओ-3166 देश कोड के हिसाब से, दो बाइट की वैल्यू के तौर पर भेजा जाता है. |
|
ANDROID_RANGE_DIAGNOSTICS = 0x2 |
UWB रेंजिंग डाइग्नोस्टिक्स के आंकड़े पाने के लिए, सूचना में इसका इस्तेमाल किया जाता है.
यह सिर्फ़ तब काम करता है, जब
UwbVendorCapabilityTlvTypes.SUPPORTED_DIAGNOSTICS को 1 पर सेट किया गया हो.
|
|
OEM = 0xE,0xF |
0x00 - 0x3F |
ओईएम के इस्तेमाल के लिए रिज़र्व किया गया. |
यूसीआई (यूरोपीय संघ के कानून) के स्पेसिफ़िकेशन में बताए गए मैसेज के लिए वेंडर एक्सटेंशन
इस सेक्शन में, यूसीआई के स्पेसिफ़िकेशन के मुताबिक मैसेज में वेंडर एक्सटेंशन की जानकारी दी गई है.
SESSION_SET_APP_CONFIG_[CMD|RSP] और SESSION_GET_APP_CONFIG_[CMD|RSP]
APP_CONFIG
में, टीएलवी के वेंडर के लिए रिज़र्व किए गए हिस्से में, AOSP स्टैक की तय की गई टाइप की लंबाई की वैल्यू (टीएलवी) यहां दी गई हैं:
- GID: 0001b (UWB सेशन कॉन्फ़िगरेशन ग्रुप)
- OID: 000011b (
SESSION_SET_APP_CONFIG_CMD
) - OID: 000100b (
SESSION_GET_APP_CONFIG_CMD
)
नीचे दी गई टेबल में, UWB सेशन कॉन्फ़िगरेशन मैसेज के पैरामीटर की सूची दी गई है.
पैरामीटर का नाम | लंबाई (ऑक्टेट) |
टैग (आईडी) |
वेंडर इंटरफ़ेस का वर्शन | ब्यौरा |
---|---|---|---|---|
NB_OF_RANGE_MEASUREMENTS |
1 | 0xE3 |
1 | इंटरलेविंग रेशियो, अगर AOA_RESULT_REQ को 0xF0 पर सेट किया गया है. सिर्फ़ तब काम करती है, जब
UwbVendorCapabilityTlvTypes.SUPPORTED_AOA_RESULT_REQ_ANTENNA_INTERLEAVING
1 पर सेट हो. |
NB_OF_AZIMUTH_MEASUREMENTS |
1 | 0xE4 |
1 | |
NB_OF_ELEVATION_MEASUREMENTS |
1 | 0xE5 |
1 | |
ENABLE_DIAGNOSTICS |
1 | 0xE8 |
2 | गड़बड़ी की जानकारी देने वाली रिपोर्टिंग को चालू या बंद करने के लिए, एक बाइट की वैल्यू.
इस पैरामीटर को सिर्फ़ तब कॉन्फ़िगर करें, जब वैल्यू:
|
DIAGRAMS_FRAME_REPORTS_FIELDS |
1 या 4 | 0xE9 |
2 | गड़बड़ी की रिपोर्टिंग कॉन्फ़िगर करने के लिए, 1-बाइट या 4-बाइट बिटमास्क. यह बिटमास्क, Android 14 या उसके बाद के वर्शन में 1 बाइट और Android 13 या उससे पहले के वर्शन में 4 बाइट का होता है. इस पैरामीटर को सिर्फ़ तब कॉन्फ़िगर करें, जब
बिट की परिभाषाएं:
|
CORE_GET_CAPS_INFO_RSP
CAPS_INFO
में, वेंडर के लिए रिज़र्व किए गए टीएलवी के हिस्से में, AOSP स्टैक के ज़रिए तय किए गए टीएलवी यहां दिए गए हैं:
- GID: 0000b (यूडब्ल्यूबी कोर ग्रुप)
- OID: 000011b (
CORE_GET_CAPS_INFO_RSP
)
यहां दी गई टेबल में, UWB की सुविधा वाले मैसेज के पैरामीटर दिए गए हैं.
पैरामीटर का नाम | लंबाई (ऑक्टेट) |
टैग (आईडी) |
वेंडर इंटरफ़ेस का वर्शन | ब्यौरा |
---|---|---|---|---|
SUPPORTED_POWER_STATS_QUERY |
1 | 0xC0 |
1 | एक बाइट की वैल्यू, जो बताती है कि पावर के आंकड़े वाली क्वेरी के साथ काम किया जा सकता है. वैल्यू:
|
SUPPORTED_AOA_RESULT_REQ_ANTENNA_INTERLEAVING |
1 | 0xE3 |
1 | एक बाइट की वैल्यू, जो ऐंटेना इंटरलेविंग की सुविधा के साथ काम करने की जानकारी देती है. वैल्यू:
|
SUPPORTED_MIN_RANGING_INTERVAL_MS |
4 | 0xE4 |
2 | चार बाइट की वैल्यू, जो मिलीसेकंड में, रेंजिंग के लिए इस्तेमाल किए जा सकने वाले कम से कम इंटरवल की जानकारी देती है. |
SUPPORTED_RANGE_DATA_NTF_CONFIG |
4 | 0xE5 |
2 | इस्तेमाल की जा सकने वाली
RANGE_DATA_NTF_CONFIG वैल्यू दिखाने वाला चार बाइट का बिटमास्क.
बिटमास्क, जहां हर बिट SET_APP_CFG_CMD में इस्तेमाल की गई वैल्यू से मेल खाता है
RANGE_DATA_NTF_CONFIG . |
SUPPORTED_RSSI_REPORTING |
1 | 0xE6 |
2 | आरएसएसआई रिपोर्टिंग की सुविधा के काम करने की जानकारी देने वाली एक बाइट की वैल्यू. वैल्यू:
|
SUPPORTED_DIAGNOSTICS |
1 | 0xE7 |
2 | गड़बड़ी की जानकारी देने वाली रिपोर्टिंग की सुविधा के काम करने की जानकारी देने वाली एक बाइट की वैल्यू. वैल्यू:
|
SUPPORTED_MIN_SLOT_DURATION_RSTU |
4 | 0xE8 |
2 | चार बाइट की वैल्यू, जो RSTU में इस्तेमाल की जा सकने वाली स्लॉट की कम से कम अवधि दिखाती है. |
SUPPORTED_MAX_RANGING_SESSION_NUMBER |
4 | 0xE9 |
2 | चार बाइट की वैल्यू, जो FiRa रेंजिंग के लिए इस्तेमाल किए जा सकने वाले सबसे ज़्यादा सेशन की संख्या दिखाती है. |
SUPPORTED_CHANNELS_AOA |
2 | 0xEA |
2 | AoA के साथ काम करने वाले चैनलों के बारे में बताने के लिए, दो बाइट का बिटमास्क. बिटमास्क में मौजूद हर
वैल्यू:
|
स्टेटस कोड
वेंडर स्पेस में स्टेटस कोड यहां दिए गए हैं. ये यूडब्ल्यूबी सबसिस्टम (यूडब्ल्यूबीएस) की मदद से, यूसीआई रिस्पॉन्स (जैसे कि SESSION_START_RSP
) में दिखाए जाते हैं.
स्टेटस कोड | वैल्यू | ब्यौरा |
---|---|---|
STATUS_ERROR_STOPPED_DUE_TO_OTHER_SESSION_CONFLICT |
0x52 |
यह स्टेटस कोड तब दिखता है, जब अन्य सीसीसी या FiRa रेंजिंग सेशन के साथ होने वाले संघर्ष की वजह से, मौजूदा रेंजिंग सेशन शुरू नहीं किया जा सकता. |
STATUS_REGULATION_UWB_OFF |
0x53 |
UWB से जुड़े नियमों की वजह से, मौजूदा रेंजिंग सेशन शुरू न हो पाने पर दिखने वाला स्टेटस कोड. |
SESSION_STATUS_NTF में, स्थिति में बदलाव की वजह का कोड
SESSION_STATUS_NTF
में UWBS से मिले स्टेटस फ़ील्ड के लिए, वेंडर स्पेस में स्टेटस बदलने की वजह के कोड यहां दिए गए हैं. जब रेंजिंग सेशन की स्थिति बदलती है, तब UWBS से यह सूचना भेजी जाती है. उदाहरण के लिए, ACTIVE
से IDLE
पर.
स्थिति बदलने की वजह का कोड | वैल्यू | ब्यौरा |
---|---|---|
REASON_ERROR_INVALID_CHANNEL_WITH_AOA |
0x80 |
कॉन्फ़िगर किया गया चैनल, AoA रेंजिंग के साथ काम नहीं करता. इसलिए, सेशन की स्थिति बदल गई. |
REASON_ERROR_STOPPED_DUE_TO_OTHER_SESSION_CONFLICT |
0x81 |
अन्य सीसीसी या FiRa रेंजिंग सेशन के साथ होने वाली गड़बड़ी की वजह से, सेशन की स्थिति बदल गई. |
REASON_REGULATION_UWB_OFF |
0x82 |
सेशन की स्थिति बदल गई, क्योंकि नियमों के उल्लंघन की वजह से UWB को बंद करना ज़रूरी है. |