2016-09-28 6 views
9

उपयोग करने के लिए क्या आवश्यक है, मैं अपने ऐप को अन्य ऐप पर ऑडियो खिलाने के लिए एक नया एंड्रॉइड ऑडियो एचएएल लिख रहा हूं, ताकि मेरे हैंडहेल्ड रिमोट माइक्रोफोन इनपुट को Google ऐप तक पहुंचने की अनुमति मिल सके। अनिवार्य रूप से, एक वर्चुअल ऑडियो केबल।एंड्रॉइड को एक नया ऑडियो एचएएल

इसका एक काम प्रगति पर है। मैं शायद AUDIO_DEVICE_IN_BACK_MIC को ओवरराइड कर रहा हूं, लेकिन यह सुझावों के लिए खुला है।

मुझे यह सुनिश्चित करने के लिए संदेह है कि एंड्रॉइड इनपुट के लिए इस एचएएल का उपयोग कैसे करता है।

क्या मुझे audio.primary.default.so को प्रतिस्थापित करने की आवश्यकता है या क्या मुझे इसे audio.vcable.default.so के रूप में छोड़ना चाहिए?

अधिक विशेष रूप से: यदि मैं प्राथमिक स्थान नहीं ले रहा हूं, तो एंड्रॉइड प्राथमिक के बजाय मेरे एचएएल का उपयोग कैसे करेगा?


अद्यतन:

मैं वास्तव में इस काम में किसी भी मदद इस्तेमाल कर सकते हैं। कोई संकेतक उपयोगी हैं।

मैंने एक ऑडियो एचएएल मॉड्यूल लिखा है। AudioFlinger.cpp

को

global_configuration { 
    attached_output_devices AUDIO_DEVICE_OUT_SPEAKER|**AUDIO_DEVICE_OUT_LINE** 
    default_output_device AUDIO_DEVICE_OUT_SPEAKER 
    attached_input_devices AUDIO_DEVICE_IN_BUILTIN_MIC|AUDIO_DEVICE_IN_BACK_MIC|AUDIO_DEVICE_IN_REMOTE_SUBMIX|**AUDIO_DEVICE_IN_LINE** 
} 

और निम्न (बोल्ड) audio_hw_modules

vloop { 
    inputs { 
     vloop { 
     sampling_rates 16000 
     channel_masks AUDIO_CHANNEL_IN_MONO 
     formats AUDIO_FORMAT_PCM_16_BIT 
     devices AUDIO_DEVICE_IN_LINE 
     } 
    } 
    outputs { 
     vloop { 
     sampling_rates 16000 
     channel_masks AUDIO_CHANNEL_OUT_STEREO 
     formats AUDIO_FORMAT_PCM_16_BIT 
     devices AUDIO_DEVICE_OUT_LINE 
     flags AUDIO_OUTPUT_FLAG_DIRECT 
     } 
    } 
    } 

मैं यह भी कहा के तहत: मैं (बोल्ड आइटम) निम्नलिखित को शामिल किया है audio_policy.conf रहे हैं:

वैश्विक

static const char * const audio_interfaces[] = { 
    AUDIO_HARDWARE_MODULE_ID_PRIMARY, 
    AUDIO_HARDWARE_MODULE_ID_A2DP, 
    AUDIO_HARDWARE_MODULE_ID_USB, 
    **AUDIO_HARDWARE_MODULE_ID_VLOOP** 
}; 

मैं देख सकता हूं कि बूट के दौरान, मेरा एचएएल लोड हो जाता है, और मुझे ये लॉग मिलते हैं:

10-06 06:14:40.365 194-194/? I/AudioFlinger: Using default 3000 mSec as standby time. 
10-06 06:14:46.664 194-194/? I/AudioPolicyService: AudioPolicyService CSTOR in new mode 
10-06 06:14:46.673 194-194/? I/APM::ConfigParsingUtils: loadAudioPolicyConfig() loaded /system/etc/audio_policy.conf 
10-06 06:14:46.681 194-194/? D/audio_hw_primary: adev_open: enter 
10-06 06:14:46.797 194-194/? I/AudioFlinger: loadHwModule() Loaded primary audio interface from QCOM Audio HAL (audio) handle 1 
10-06 06:14:46.797 194-194/? I/AudioFlinger: openOutput(), module 1 Device 2, SamplingRate 48000, Format 0x000001, Channels 3, flags 2 
10-06 06:14:46.797 194-194/? I/AudioFlinger: AudioStreamOut::open(), mHalFormatIsLinearPcm = 1 
10-06 06:14:46.798 194-194/? I/AudioFlinger: HAL output buffer size 240 frames, normal sink buffer size 960 frames 
10-06 06:14:46.813 194-194/? I/AudioFlinger: Using module 1 has the primary audio interface 
10-06 06:14:46.816 194-607/? I/AudioFlinger: AudioFlinger's thread 0xb4140000 ready to run 
10-06 06:14:46.816 194-607/? D/audio_hw_primary: out_set_parameters: enter: usecase(1: low-latency-playback) kvpairs: routing=2 
10-06 06:14:46.818 194-194/? I/AudioFlinger: openOutput(), module 1 Device 2, SamplingRate 48000, Format 0x000001, Channels 3, flags 8 
10-06 06:14:46.818 194-194/? I/AudioFlinger: AudioStreamOut::open(), mHalFormatIsLinearPcm = 1 
10-06 06:14:46.818 194-194/? I/AudioFlinger: HAL output buffer size 960 frames, normal sink buffer size 960 frames 
10-06 06:14:46.818 194-608/? I/AudioFlinger: AudioFlinger's thread 0xb3dc0000 ready to run 
10-06 06:14:46.818 194-607/? E/AudioFlinger: no wake lock to update! 
10-06 06:14:46.818 194-608/? D/audio_hw_primary: out_set_parameters: enter: usecase(0: deep-buffer-playback) kvpairs: routing=2 
10-06 06:14:46.818 194-608/? E/AudioFlinger: no wake lock to update! 
10-06 06:14:46.820 194-609/? I/AudioFlinger: AudioFlinger's thread 0xb3c40000 ready to run 
10-06 06:14:46.823 194-194/? I/AudioFlinger: loadHwModule() Loaded a2dp audio interface from A2DP Audio HW HAL (audio) handle 7 
10-06 06:14:46.828 194-194/? I/AudioFlinger: loadHwModule() Loaded usb audio interface from USB audio HW HAL (audio) handle 8 
10-06 06:14:46.832 194-194/? I/r_submix: adev_open(name=audio_hw_if) 
10-06 06:14:46.832 194-194/? I/AudioFlinger: loadHwModule() Loaded r_submix audio interface from Wifi Display audio HAL (audio) handle 9 
10-06 06:14:46.832 194-194/? D/r_submix: submix_audio_device_create_pipe_l(addr=0, idx=9) 
10-06 06:14:46.833 194-610/? I/AudioFlinger: AudioFlinger's thread 0xb3bc0000 ready to run 
10-06 06:14:46.833 194-194/? D/r_submix: submix_audio_device_release_pipe_l(idx=9) addr=0 
10-06 06:14:46.833 194-194/? D/r_submix: submix_audio_device_destroy_pipe_l(): pipe destroyed 
10-06 06:14:46.835 194-194/? D/audio_vloop: adev_open: audio_hw_if 
10-06 06:14:46.835 194-194/? D/audio_vloop: adev_open(): 1678 
10-06 06:14:46.835 194-194/? D/audio_vloop: adev_open(): 1685 
10-06 06:14:46.835 194-194/? D/audio_vloop: adev_open(): 1688 
10-06 06:14:46.835 194-194/? D/audio_vloop: adev_open(): 1722 
10-06 06:14:46.835 194-194/? D/audio_vloop: adev_init_check(): 1252 
10-06 06:14:46.835 194-194/? D/audio_vloop: adev_set_master_volume: 1.000000 
10-06 06:14:46.835 194-194/? D/audio_vloop: adev_set_master_mute: 0 
10-06 06:14:46.835 194-194/? I/AudioFlinger: loadHwModule() Loaded vloop audio interface from UI_audio_HW_HAL (audio) handle 11 
10-06 06:14:46.835 194-194/? D/audio_vloop: adev_open_input_stream(): 1490 
10-06 06:14:46.835 194-194/? D/audio_vloop: in_get_sample_rate(): 979 
10-06 06:14:46.835 194-194/? D/audio_vloop: in_get_channels(): 1017 
10-06 06:14:46.835 194-194/? D/audio_vloop: in_get_channels: 0x00000001 
10-06 06:14:46.835 194-194/? D/audio_vloop: in_get_format(): 1029 
10-06 06:14:46.836 194-194/? D/audio_vloop: in_get_format: 0x00000001 
10-06 06:14:46.836 194-194/? D/audio_vloop: in_get_format(): 1029 
10-06 06:14:46.836 194-194/? D/audio_vloop: in_get_format: 0x00000001 
10-06 06:14:46.836 194-194/? D/audio_vloop: in_get_channels(): 1017 
10-06 06:14:46.836 194-194/? D/audio_vloop: in_get_channels: 0x00000001 
10-06 06:14:46.836 194-194/? D/audio_vloop: in_get_buffer_size(): 1005 
10-06 06:14:46.836 194-194/? D/audio_vloop: in_get_buffer_size: 1600 
10-06 06:14:46.836 194-194/? D/audio_vloop: in_get_buffer_size(): 1005 
10-06 06:14:46.836 194-194/? D/audio_vloop: in_get_buffer_size: 1600 
10-06 06:14:46.836 194-194/? D/audio_vloop: in_get_format(): 1029 
10-06 06:14:46.836 194-194/? D/audio_vloop: in_get_format: 0x00000001 
10-06 06:14:46.836 194-194/? D/audio_vloop: in_get_sample_rate(): 979 
10-06 06:14:46.836 194-194/? D/audio_vloop: in_get_channels(): 1017 
10-06 06:14:46.836 194-194/? D/audio_vloop: in_get_channels: 0x00000001 
10-06 06:14:46.838 194-613/? I/AudioFlinger: AudioFlinger's thread 0xb3bc0000 ready to run 
10-06 06:14:46.838 194-194/? D/audio_vloop: adev_close_input_stream(): 1570 
10-06 06:14:46.839 194-194/? W/APM::AudioPolicyManager: Input device 00020000 unreachable 
10-06 06:14:46.839 194-611/? D/audio_vloop: looper_thread(): 216: Entered 
10-06 06:14:46.839 194-611/? D/audio_vloop: looper_thread(): 366: Exiting 
10-06 06:15:07.137 616-616/? I/InputManager: Initializing input manager, mUseDevInputEventForAudioJack=false 
10-06 06:15:10.155 616-616/? I/SystemServer: Audio Service 
10-06 06:15:10.222 194-607/? E/AudioFlinger: no wake lock to update! 
10-06 06:15:10.222 194-608/? E/AudioFlinger: no wake lock to update! 
10-06 06:15:10.224 194-614/? D/audio_hw_primary: adev_set_mic_mute: state 0 
10-06 06:15:10.224 194-614/? D/audio_vloop: adev_set_mic_mute: 0 
10-06 06:15:14.061 194-614/? D/audio_hw_primary: adev_set_parameters: enter: A2dpSuspended=false 
10-06 06:15:14.061 194-614/? D/audio_vloop: adev_set_parameters(): [A2dpSuspended=false] 
10-06 06:15:14.084 194-194/? I/AudioFlinger: systemReady 
10-06 06:15:16.308 194-194/? D/audio_hw_primary: adev_set_mic_mute: state 0 
10-06 06:15:16.308 194-194/? D/audio_vloop: adev_set_mic_mute: 0 
10-06 06:15:17.072 194-194/? D/audio_hw_primary: adev_set_parameters: enter: A2dpSuspended=false 
10-06 06:15:17.072 194-194/? D/audio_vloop: adev_set_parameters(): [A2dpSuspended=false] 
10-06 06:15:25.023 733-733/? W/AudioTrack: AUDIO_OUTPUT_FLAG_FAST denied by client; transfer 4, track 44100 Hz, output 48000 Hz 
10-06 06:15:25.032 194-607/? D/audio_hw_primary: out_set_parameters: enter: usecase(1: low-latency-playback) kvpairs: routing=2 
10-06 06:15:25.043 194-607/? D/audio_hw_primary: select_devices: out_snd_device(2: speaker) in_snd_device(0: none) 
10-06 06:15:25.043 194-607/? D/audio_hw_primary: enable_snd_device: snd_device(2: speaker) 
10-06 06:15:25.050 194-607/? D/audio_hw_primary: enable_audio_route: apply and update mixer path: low-latency-playback 
10-06 06:15:26.431 1150-1298/? I/MicrophoneInputStream: mic_starting [email protected] 
10-06 06:15:26.443 194-1585/? I/AudioFlinger: AudioFlinger's thread 0xb3bc0000 ready to run 
10-06 06:15:26.447 1150-1298/? I/MicrophoneInputStream: mic_started [email protected] 
10-06 06:15:26.457 194-1585/? D/audio_hw_primary: select_devices: out_snd_device(0: none) in_snd_device(38: voice-rec-mic) 
10-06 06:15:26.457 194-1585/? D/audio_hw_primary: enable_snd_device: snd_device(38: voice-rec-mic) 
10-06 06:15:26.460 194-1585/? D/audio_hw_primary: enable_audio_route: apply and update mixer path: audio-record 
10-06 06:15:26.942 1150-1271/? I/AudioController: internalShutdown 
10-06 06:15:26.943 1150-1271/? I/MicrophoneInputStream: mic_close [email protected] 
10-06 06:15:26.943 1150-1298/? E/AudioRecord-JNI: Error -4 during AudioRecord native read 
10-06 06:15:26.986 194-1585/? D/audio_hw_primary: disable_audio_route: reset and update mixer path: audio-record 
10-06 06:15:26.987 194-1585/? D/audio_hw_primary: disable_snd_device: snd_device(38: voice-rec-mic) 
10-06 06:15:27.066 194-607/? D/audio_hw_primary: out_set_parameters: enter: usecase(1: low-latency-playback) kvpairs: routing=2 
10-06 06:15:27.100 194-607/? D/AudioFlinger: mixer(0xb4140000) throttle end: throttle time(7) 
10-06 06:15:30.257 194-607/? D/audio_hw_primary: disable_audio_route: reset and update mixer path: low-latency-playback 
10-06 06:15:30.257 194-607/? D/audio_hw_primary: disable_snd_device: snd_device(2: speaker) 
10-06 06:15:30.262 194-607/? D/audio_hw_primary: out_set_parameters: enter: usecase(1: low-latency-playback) kvpairs: routing=2 
10-06 06:15:30.272 194-607/? D/audio_hw_primary: select_devices: out_snd_device(2: speaker) in_snd_device(0: none) 
10-06 06:15:30.273 194-607/? D/audio_hw_primary: enable_snd_device: snd_device(2: speaker) 
10-06 06:15:30.280 194-607/? D/audio_hw_primary: enable_audio_route: apply and update mixer path: low-latency-playback 
10-06 06:15:30.347 194-607/? D/AudioFlinger: mixer(0xb4140000) throttle end: throttle time(10) 
10-06 06:15:31.517 194-607/? D/audio_hw_primary: out_set_parameters: enter: usecase(1: low-latency-playback) kvpairs: routing=2 
10-06 06:15:31.751 1150-1298/? I/MicrophoneInputStream: mic_starting [email protected] 
10-06 06:15:31.762 194-1826/? I/AudioFlinger: AudioFlinger's thread 0xb3bc0000 ready to run 
10-06 06:15:31.771 1150-1298/? I/MicrophoneInputStream: mic_started [email protected] 
10-06 06:15:31.780 194-1826/? D/audio_hw_primary: select_devices: out_snd_device(0: none) in_snd_device(38: voice-rec-mic) 
10-06 06:15:31.780 194-1826/? D/audio_hw_primary: enable_snd_device: snd_device(38: voice-rec-mic) 
10-06 06:15:31.783 194-1826/? D/audio_hw_primary: enable_audio_route: apply and update mixer path: audio-record 
10-06 06:15:34.695 194-607/? D/audio_hw_primary: disable_audio_route: reset and update mixer path: low-latency-playback 
10-06 06:15:34.695 194-607/? D/audio_hw_primary: disable_snd_device: snd_device(2: speaker) 
10-06 06:15:34.850 1150-1271/? I/AudioController: internalShutdown 
10-06 06:15:34.851 1150-1271/? I/MicrophoneInputStream: mic_close [email protected] 
10-06 06:15:34.851 1150-1298/? E/AudioRecord-JNI: Error -4 during AudioRecord native read 
10-06 06:15:34.885 194-1826/? D/audio_hw_primary: disable_audio_route: reset and update mixer path: audio-record 
10-06 06:15:34.885 194-1826/? D/audio_hw_primary: disable_snd_device: snd_device(38: voice-rec-mic) 

मेरा ऑडियो_vloop है। मैं देख सकता हूं कि एंड्रॉइड मेरा डिवाइस खोलता है, फिर इनपुट स्ट्रीम खोलता है, और फिर इनपुट स्ट्रीम बंद कर देता है। यह कभी भी आउटपुट स्ट्रीम खोलने का प्रयास नहीं करता है। audio_vloop इनपुट और आउटपुट स्ट्रीम दोनों लागू करता है। इसके बाद, एंड्रॉइड द्वारा ऑडियो_व्लोप में कभी भी कुछ भी नहीं लगाया जाता है।

मैंने एक छोटा ऐप बनाया जो ऑडियो चलाता है (अब के लिए एक पीसीएम फ़ाइल से)। मैं इस आउटपुट को अपने एचएएल पर रीडायरेक्ट करना चाहता हूं। इसे प्राप्त करने के लिए, मेरा मानना ​​है कि मुझे अपने ऑडियो ट्रैक पर ऑडियोट्रैक.सेट प्रीपेरडेडवाइस() करने की आवश्यकता है। मैंने पाया कि ऑडियो प्रबंधक में सभी ऑडियो उपकरणों की एक सूची होनी चाहिए।

तो मैं फोन:

10-06 06:37:01.962 3295-3663/? D/AudioPlayer: Have [1] devices 
10-06 06:37:01.964 3295-3663/? D/AudioPlayer: devInfo[0]: [Landroid.media.AudioDeviceInfo;@90bd9da 
10-06 06:37:01.965 3295-3663/? D/AudioPlayer: getProductName()AOSP on Flo 
10-06 06:37:01.965 3295-3663/? D/AudioPlayer: getType()2 
10-06 06:37:01.966 3295-3663/? D/AudioPlayer: isSink()true 
10-06 06:37:01.966 3295-3663/? D/AudioPlayer: isSource()false 

यह प्रतीत होता है audioPort जो मैं लागू नहीं किया है से है:

AudioDeviceInfo aDevInfo[] = am.getDevices(AudioManager.GET_DEVICES_OUTPUTS); 

यह केवल 1 डिवाइस, इस डिवाइस के बारे में अधिक जानकारी पाता है। तो यह मेरे एचएएल से नहीं है।

एंड्रॉइड मेरे ऐप को मेरे डिवाइस से बात करने की अनुमति देने से पहले मैंने एक या एक से अधिक कदमों को याद किया है।

मुझे अपने ऐप से अपने एचएएल में ऑडियो भेजने में सक्षम होना चाहिए। बाद में, मुझे अपने एचएएल (ऑडियो रिकॉर्डॉर्ड आदि के माध्यम से) प्राप्त करने में भी सक्षम होना चाहिए।

एंड्रॉइड में मेरे एचएएल को एकीकृत करने में मुझे क्या याद आया? क्या मुझे ऑडियो पोर्ट्स को लागू करने की आवश्यकता है? क्या कुछ और आवश्यक है?


अद्यतन 2

मैंने पाया AOSP लिखने में कोई गलती नहीं है [email protected]

के बजाय

Output में, यह प्रिंट Input

मैं इस लॉग AudioPolicyManager: Input device 00020000 unreachable था जो मैं यह सोचते हैं की अवहेलना यह है बीटी/ए 2 डीडी इनपुट डिवाइस के बारे में बात करते हुए।

मैंने अपने डिवाइस के लिए लॉग तय किया है, और यह लाइन आउट डिवाइस बन गया है जिसे हम उपयोग करना चाहते हैं। मैं अब इस दिशा को डीबग कर रहा हूं।

+1

आपको अपना खुद का [ऑडियो मॉड्यूल] (https://android.googlesource.com/platform/hardware/libhardware/+/master/modules/usbaudio) लागू करना होगा, और इसे 'PRODUCT_PACKAGES' में जोड़ें आपका डिवाइस मेकफ़ाइल। आपको शायद इसे [ऑडियोफ्लिंगर'] (https://android.googlesource.com/platform/frameworks/av/+/master/services/audioflinger/AudioFlinger.cpp#279) में भी जोड़ना होगा। अन्य बदलाव हो सकते हैं जो आवश्यक होंगे, यह थोड़ी देर हो गया है क्योंकि मैंने इस तरह के सामान के साथ काम किया था। – Michael

+0

यह भी देखें [मेरा पुराना जवाब] (http://stackoverflow.com/questions/21024851/redirecting-audio-creating-alternate-sound-paths-in-android/21217919#21217919) जहां मैं जाता हूं कि कोई कैसे जा सकता है एक नए 'ऑडियोसोर्स 'को लागू करें जो कुछ क्वालकॉम प्लेटफ़ॉर्म पर वर्तमान ऑडियो आउटपुट को पकड़ लेता है। – Michael

+0

ढूंढता है SuitableHwDev_l() अंततः किस ऑडियो हेल का उपयोग करने के लिए चुनते हैं? यदि हां, तो मैं ऑडियो इनपुट के लिए हमेशा अपने मॉड्यूल का चयन करने के लिए संशोधित कर सकता हूं। सूचक के लिए धन्यवाद। – GPS

उत्तर

4

उत्तर मिला।

बाहर धारा के लिए:

  1. आउटपुट कि AUDIO_CHANNEL_OUT_STEREO का समर्थन नहीं करते एंड्रॉयड
  2. द्वारा खोला जा रहा नहीं कर रहे हैं
  3. आउटपुट कि झंडा AUDIO_OUTPUT_FLAG_DIRECT उल्लेख स्वचालित रूप से एंड्रॉयड द्वारा खोला नहीं कर रहे हैं। इस प्रोग्राम के में उन्हें खोलने के लिए एक रास्ता हो सकता है से here

AudioPolicyManager.cpp

if ((outProfile->mFlags & AUDIO_OUTPUT_FLAG_DIRECT) != 0) { 
     continue; 
    } 

में निम्न कोड में स्पष्ट है, लेकिन मैं इसका जवाब नहीं मिला है।

ये दो, एक बार निश्चित रूप से एंड्रॉइड के लिए मेरी आउट स्ट्रीम का उपयोग शुरू करने के लिए पर्याप्त थे।

धारा में के लिए:

धारा में पहले से ही AudioManager.getDevices()

के परिणामों का एक हिस्सा तो यह AudioTrack.setPreferredDevice() के बाद धारा में vloop से पढ़ने के लिए संभव था।

यह सुनिश्चित करने के लिए कि अन्य ऐप्स vloop से माइक्रो इनपुट पढ़ेंगे, मुझे इसे AUDIO_DEVICE_IN_BUILTIN_MIC लागू करने के लिए घोषित करना था। इसके लिए काम करने के लिए, मैंने में प्राथमिक एचएएल से AUDIO_DEVICE_IN_BUILTIN_MIC भी हटा दिया।

इसके अतिरिक्त, मैंने धारा स्ट्रीम बफर प्रारूप के साथ संगतता बनाए रखने के लिए केवल स्ट्रीम स्टीरियो में बनाया है।

इन परिवर्तनों के बाद, मुझे लगता है कि निरंतर पढ़ने और लिखने के लिए कॉल जारी हैं।

अद्यतन:

मैं बाद में पाया गया कि ऊपर उल्लेख किया है व्यवहार ऑडियो नीति प्रबंधक कार्यान्वयन पर निर्भर है। उनमें से ज्यादातर एक ही तरीके से व्यवहार करते हैं, (उदा।VOICE_RECOGNITION इनपुट के लिए सबसे खुले INBUILT_MIC) लेकिन कुछ (इन्हें नेक्सस प्लेयर) इन आउटलाइजर्स के लिए, या तो उनके एपीएम को खोलने के लिए लागू नहीं होते हैं, या आपके एचएएल उपकरण को खोलने के लिए एपीएम संशोधित करते हैं।

संबंधित मुद्दे