Android 13 और उससे पहले के वर्शन में, ऑडियो एचएएल इंटरफ़ेस को एचआईडीएल एचएएल फ़ाइलों (एक्सटेंशन .hal
के साथ) में एचआईडीएल का इस्तेमाल करके और कॉन्फ़िगरेशन फ़ाइलों के लिए एक्सएसडी स्कीमा का इस्तेमाल करके तय किया जाता है. इन फ़ाइलों के बारे में यहां बताया गया है.
पहली इमेज. ऑडियो एचएएल इंटरफ़ेस.
कॉन्फ़िगरेशन फ़ाइलें
ऑडियो नीति और ऑडियो इफ़ेक्ट की एक्सएमएल कॉन्फ़िगरेशन फ़ाइलों को ऑडियो एचआईडीएल एचएएल इंटरफ़ेस का हिस्सा माना जाता है. ये फ़ाइलें अपने स्कीमा के मुताबिक होनी चाहिए. साथ ही, इनके स्कीमा के मुताबिक होने की पुष्टि, VTS टेस्ट से की जाती है.
ऑडियो HIDL HAL लागू करने के लिए, आपको एक ऐसी ऑडियो नीति कॉन्फ़िगरेशन फ़ाइल बनानी होगी जिसमें ऑडियो टोपोलॉजी के बारे में बताया गया हो. फ़्रेमवर्क का इस्तेमाल करने के लिए, ऑडियो एचएएल की सुविधाओं के बारे में audio_policy_configuration.xml
फ़ाइल में एलान किया जाना चाहिए.
Audio HIDL HAL API
इस सेक्शन में, HIDL के लिए कोर, इफ़ेक्ट, और सामान्य एचएएल एपीआई के बारे में बताया गया है.
कोर HAL
एचआईडीएल का इस्तेमाल करने वाले, कोर एचएएल के कुछ मुख्य इंटरफ़ेस यहां दिए गए हैं:
IDeviceFactory.hal
, एपीआई का एंट्री पॉइंट है.IDevice.hal
औरIPrimaryDevice.hal
मेंsetMasterVolume
याopenInputStream
जैसे तरीके शामिल होते हैं.- स्ट्रीम एकतरफ़ा होती हैं. इनका इस्तेमाल AudioFlinger करता है, ताकि
IStream.hal
,IStreamOut.hal
, औरIStreamIn.hal
के ज़रिए HAL से ऑडियो भेजा या पाया जा सके.
इस टेबल में, काम के Core HAL HIDL कॉम्पोनेंट की जगह की जानकारी दी गई है:
मुख्य एचएएल कॉम्पोनेंट | जगह की जानकारी |
---|---|
एपीआई का सबसे नया वर्शन | /hardware/interfaces/audio/6.0
|
Core HAL API के नए वर्शन के लिए खास टाइप | /hardware/interfaces/audio/6.0/types.hal
|
ऑडियो नीति कॉन्फ़िगरेशन फ़ाइल का XSD स्कीमा | /hardware/interfaces/audio/6.0/config/audio_policy_configuration.xsd
|
Core HAL API (/hardware/interfaces/audio/core/all-versions/default/
) को डिफ़ॉल्ट रूप से लागू करने का तरीका, Treble HAL के लागू होने से पहले के तरीके के आस-पास एक रैपर है. इसमें लेगसी शेयर की गई लाइब्रेरी का इस्तेमाल किया जाता है.
डिफ़ॉल्ट तौर पर लागू करने की सुविधा को, ऑडियो एचएएल के नए वर्शन लागू करते समय रेफ़रंस के तौर पर भी इस्तेमाल किया जा सकता है. ये वर्शन, सीधे कर्नेल ड्राइवर के साथ इंटरैक्ट करते हैं.
इफ़ेक्ट एचएएल
नीचे दी गई टेबल में, एचआईडीएल का इस्तेमाल करने वाले काम के इफ़ेक्ट एचएएल कॉम्पोनेंट की जगह की जानकारी दी गई है:
इफ़ेक्ट एचएएल कॉम्पोनेंट | जगह की जानकारी |
---|---|
एपीआई का सबसे नया वर्शन | /hardware/interfaces/audio/effect/6.0/
|
इफ़ेक्ट कॉन्फ़िगरेशन फ़ाइल का XSD स्कीमा | /hardware/interfaces/audio/effect/6.0/xml/audio_effects_conf.xsd
|
ज़्यादा जानकारी के लिए, /hardware/interfaces/audio/effect/all-versions/default/
पर Effects HAL API के लागू होने का सैंपल और ऑडियो इफ़ेक्ट सेक्शन देखें.
कॉमन एचएएल
एचआईडीएल का इस्तेमाल करने वाले Common HAL API में ये चीज़ें शामिल हैं:
- Core और Effect API के साथ शेयर की गई परिभाषाएं (
/hardware/interfaces/audio/common/6.0/types.hal
). - यूटिलिटी (
/hardware/interfaces/audio/common/all-versions
), जिन्हें लागू करने, क्लाइंट, और टेस्ट के लिए, HIDL एपीआई के हिसाब से कोडिंग में मदद करने के लिए इस्तेमाल किया जाता है.
Audio HAL V7 में किए गए अपडेट
Android 12 में, ऑडियो एचएएल के वर्शन 7 में अहम बदलाव किए गए हैं. इनके बारे में इस सेक्शन में बताया गया है. Audio HAL V7 ये काम करता है:
- फ़्रेमवर्क और HAL के इस्तेमाल किए गए डेटा मॉडल को एक साथ जोड़ता है.
- ऑडियो नीति के कॉन्फ़िगरेशन के लिए इस्तेमाल किए गए एक्सएमएल स्कीमा और HIDL डेटा टाइप (एन्सम) के बीच डुप्लीकेट डेटा को कम करता है.
खास तौर पर, Audio HAL V7 में इन हिस्सों में बदलाव किए गए हैं:
इन बदलावों के बारे में, उनके सेक्शन में ज़्यादा जानकारी दी गई है.
एनुमरेशन
Audio HAL V7 से, ऑडियो नीति कॉन्फ़िगरेशन फ़ाइल में इस्तेमाल किए गए एनोटेट किए गए टाइप, सिर्फ़ XSD स्कीमा में तय किए जाते हैं, न कि HIDL में.
Audio HAL V6 में, types.hal
में मौजूद वैल्यू, जैसे कि AudioFormat
को ऑडियो नीति कॉन्फ़िगरेशन फ़ाइल के XSD स्कीमा में भी तय किया गया है. इससे डुप्लीकेट वैल्यू बनती हैं. V7 में इस समस्या से बचने के लिए, एनम टाइप को string
में बदल दिया गया है. साथ ही, सभी संभावित एनमेशन वैल्यू को XSD स्कीमा में शामिल किया गया है.
दूसरे चित्र में, V7 में AudioFormat
enum टाइप में किए गए कुछ बदलावों की तुलना की गई है:
दूसरी इमेज. AudioFormat एनम में किए गए कुछ बदलावों की तुलना.
string
में बदले गए वैल्यू के टाइप के बारे में जानने के लिए, नीचे दी गई सूची देखें:
AudioChannelMask
AudioContentType
AudioDevice
: वेंडर एक्सटेंसिबलAudioFormat
: वेंडर एक्सटेंसिबलAudioGainMode
AudioSource
AudioStreamType
AudioUsage
स्ट्रिंग की enum वैल्यू पास करना
स्ट्रिंग वैल्यू का इस्तेमाल, एचएएल इंटरफ़ेस की सीमा के पार, जानकारी को एनिमेंशन वैल्यू के तौर पर ट्रांसफ़र करने के लिए किया जाता है. फ़्रेमवर्क और एचएएल रैपर, दोनों ही कारोबारी लॉजिक को लागू करने के लिए, पूर्णांक की वैल्यू का इस्तेमाल करते हैं. साथ ही, तीसरी इमेज में दिखाए गए कन्वर्ज़न के तरीके का इस्तेमाल करते हैं:
तीसरी इमेज. स्ट्रिंग के तौर पर enum वैल्यू पास करना.
उदाहरण के लिए, फ़्रेमवर्क से वेंडर को ऑडियो फ़ॉर्मैट टाइप की वैल्यू पास करने के लिए:
AudioFormat
की वैल्यू कोlibaudiohal
में स्ट्रिंग वैल्यू में बदला जाता है और इसे HAL को पास किया जाता है.- HAL की ओर से, डिफ़ॉल्ट रैपर स्ट्रिंग को एक सूची वाली वैल्यू में बदल देता है. इसे लेगसी HAL को पास किया जाता है.
एक्सएमएल स्कीमा में हुए बदलाव
एक्सएमएल स्कीमा डेफ़िनिशन (एक्सएसडी) में, सूची में शामिल वैल्यू की पूरी सूची होने पर, ऑडियो नीति कॉन्फ़िगरेशन की एक्सएमएल फ़ाइल की पुष्टि, वीटीएस की मदद से बेहतर तरीके से की जा सकती है. हमने एचएएल V7 के साथ इस्तेमाल की जाने वाली ऑडियो नीति कॉन्फ़िगरेशन फ़ाइल में बदलाव किए हैं, ताकि एक्सएसडी का पालन किया जा सके.
वर्शन 7 में, एट्रिब्यूट (जैसे, सैंपलिंग रेट, चैनल मास्क, और फ़्लैग) की वैल्यू की सूचियों को अलग करने के लिए, स्टैंडर्ड ␣
(स्पेस) वर्ण का इस्तेमाल किया जाता है. यह वर्शन 6 और उससे पहले के वर्शन में इस्तेमाल किए गए ,
(कॉमा) और |
(वर्टिकल बार) सिंबल के बजाय इस्तेमाल किया जाता है. नीचे दिए गए उदाहरण में, channelMasks
के लिए वैल्यू की सूची को अलग करने के लिए, स्पेस का इस्तेमाल किया गया है:
<profile channelMasks="AUDIO_CHANNEL_OUT_STEREO AUDIO_CHANNEL_OUT_MONO" … />
सिंबल में बदलाव करने के लिए, update_audio_policy_config.sh
नाम की ऑटोमैटिक कन्वर्ज़न स्क्रिप्ट का इस्तेमाल करें. Pixel 5 (Redfin) डिवाइस के लिए, ऑडियो नीति की V6 कॉन्फ़िगरेशन फ़ाइल को V7 वर्शन में बदलने के लिए, यह कमांड देखें:
hardware/interfaces/audio/7.0/config/update_audio_policy_config.sh \
device/google/redfin/audio/audio_policy_configuration.xml 6.0
डेटा टाइप
हमने डुप्लीकेट परिभाषाओं को कम करने के लिए, V7 में कुछ डेटा स्ट्रक्चर को फिर से तय किया है. डेटा आइटम के दोहराए गए टपल को फिर से इस्तेमाल किए जा सकने वाले स्ट्रक्चर में एक साथ ग्रुप किया जाता है. ये डेटा स्ट्रक्चर, सेफ़ यूनियन जैसी नई HIDL सुविधाओं का इस्तेमाल करते हैं.
उदाहरण के लिए, V6 और उससे पहले के वर्शन में, HIDL इंटरफ़ेस और टाइप में अक्सर <format, sampling rate, channel mask>
के तीन बार इस्तेमाल किया जाता है. इस गड़बड़ी को ठीक करने के लिए, V7 में AudioConfigBase
डेटा टाइप और अन्य डेटा टाइप को इस तरह से तय किया गया है:
AudioConfigBase := <format, sampling rate, channel mask>
AudioConfigBaseOptional := <[fmt], [sampl. rate], [chan. mask]>
AudioConfig
,AudioOffloadInfo
,AudioPortConfig
ने इस्तेमाल कियाAudioProfile := <format, {sampling rates}, {channel masks}>
AudioPort/PortConfig
में मौजूद अलग-अलग कलेक्शन को बदलता हैAudioPortExtendedInfo := device | mix | session
AudioPort/PortConfig
में यूनियन की जगह लेता है
वेंडर टैग
डिवाइस टाइप और फ़ॉर्मैट के अलावा, वेंडर ऑडियो ट्रैक के मेटाडेटा के लिए कस्टम टैग जोड़ सकते हैं.
ट्रैक के मेटाडेटा को चलाने और रिकॉर्ड करने के लिए, वेंडर अपने टैग पास कर सकते हैं. इन टैग का इस्तेमाल, ऐप्लिकेशन से HAL तक ऑडियो I/O स्ट्रीम में एट्रिब्यूट जोड़ने के लिए किया जाता है.
यहां दिए गए उदाहरण में दिखाया गया है कि वीडियो चलाने के लिए इस्तेमाल किए जाने वाले ट्रैक के मेटाडेटा के लिए वेंडर टैग कैसे जोड़े जाते हैं:
struct PlaybackTrackMetadata {
…
/** Tags from AudioTrack audio attributes */
vec<AudioTag> tags;
};
RecordTrackMetadata
स्ट्रक्चर को रिकॉर्डिंग ट्रैक के मेटाडेटा के लिए खास टैग जोड़कर, इसी तरह लागू किया जाता है.
वेंडर एक्सटेंशन के लिए नेमस्पेस
एचएएल V7 से, वेंडर एक्सटेंशन के लिए एक अतिरिक्त {vendor}
प्रीफ़िक्स की ज़रूरत होती है. यह प्रीफ़िक्स, V6 में ज़रूरी नहीं है. {vendor}
प्रीफ़िक्स मान्य होने के लिए, इसमें अक्षर और अंक मिलाकर तीन या इससे ज़्यादा वर्ण होने चाहिए.
V7 में इस फ़ॉर्मैट का इस्तेमाल करें:
VX_{vendor}_{letters/numbers}
यहां V7 वेंडर एक्सटेंशन के मान्य वर्शन के कुछ उदाहरण दिए गए हैं:
VX_GOOGLE_VR
VX_QCI_AMBIENT_MIC
वर्शन की जानकारी
नीचे दी गई टेबल में, हर Android रिलीज़ के लिए HAL वर्शन नंबर की सूची दी गई है:
Android वर्शन | HIDL HAL वर्शन |
---|---|
Android 13 | 7.1 |
Android 12 | 7.0 |
Android 11 | 6.0 |
Android 10 | 5.0 |
Android 9 | 4.0 |
Android 8 | 2.0 |