Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Change Play Audio Device there is a chance that it will fail #2111

Open
lilinxiong opened this issue Oct 24, 2024 · 6 comments
Open

Change Play Audio Device there is a chance that it will fail #2111

lilinxiong opened this issue Oct 24, 2024 · 6 comments
Assignees
Labels

Comments

@lilinxiong
Copy link
Contributor

Android version(s): Android 13
Android device(s): Mi 11 Ultra
Oboe version: 1.9.2
App name used for testing:
(Please try to reproduce the issue using the OboeTester or an Oboe sample.)

Short description
(Please only report one bug per Issue. Do not combine multiple bugs.)
When I use the speaker to play, and then plug in the wired headphones, there is a probability that the headphones will fail to play.

Steps to reproduce

  1. Build an Oboe for playback, using speakers by default.
  2. Device changes are monitored through audioManager?.registerAudioDeviceCallback() in the application layer. When a wired headset is detected, stop and release of oboe are called in sequence to destroy the previous instance, and then reopen and start it again.

Expected behavior
Sound plays from headphones
Actual behavior
No sound from headphones
Device

Please list which devices have this bug.
If device specific, and you are on Linux or a Macintosh, connect the device and please share the result for the following script. This gets properties of the device.

for p in \
    ro.product.brand ro.product.manufacturer ro.product.model \
    ro.product.device ro.product.cpu.abi ro.build.description \
    ro.hardware ro.hardware.chipname ro.arch "| grep aaudio";
    do echo "$p = $(adb shell getprop $p)"; done

Any additional context

2024-10-24 11:53:01.326  1720-27007 MSPushStre...udioDevice      I  LivePushCC 27007:BiliAudioDevice.cpp:159 stop() stream_ state:Started
2024-10-24 11:53:01.326  1720-27007 AAudio                       D  AAudioStream_requestStop(s#3) called
2024-10-24 11:53:01.326  1720-27007 AAudioStream                 D  setState(s#3) from 4 to 9
2024-10-24 11:53:01.326  1720-27007 AudioTrack                   D  stop(sessionID=2761)
2024-10-24 11:53:01.326  1720-27007 AudioTrack                   D  stop(1210): prior state:STATE_ACTIVE
2024-10-24 11:53:01.327  1720-27007 AudioTrack                   D  stop(1210): called with 4172352 frames delivered
2024-10-24 11:53:01.327  1720-27007 AAudioStream                 D  setState(s#3) from 9 to 10
2024-10-24 11:53:01.327  1720-27007 MSPushStre...udioDevice      I  LivePushCC 27007:BiliAudioDevice.cpp:180 release() close....
2024-10-24 11:53:01.327  1720-27007 AAudio                       D  AAudioStream_requestStop(s#3) called
2024-10-24 11:53:01.335  1720-1720  DecorView[]                  D  onWindowFocusChanged hasWindowFocus false
2024-10-24 11:53:01.338  1720-27007 AAudio                       D  AAudioStream_close(s#3) called ---------------
2024-10-24 11:53:01.338  1720-27007 AAudioStream                 D  setState(s#3) from 10 to 11
2024-10-24 11:53:01.338  1720-27007 AudioTrack                   D  stop(sessionID=2761)
2024-10-24 11:53:01.338  1720-27007 AudioTrack                   D  stop(1210): prior state:STATE_STOPPED
2024-10-24 11:53:01.338  1720-1720  IntranetTrackPlugin          D  index: sky-eye-fps-android, msg: {current=55}
2024-10-24 11:53:01.339  1720-27007 AudioTrack                   D  ~AudioTrack(sessionID=2761)
2024-10-24 11:53:01.339  1720-27007 AudioTrack                   D  stop(sessionID=2761)
2024-10-24 11:53:01.340  1720-27007 AudioTrack                   D  stop(1210): prior state:STATE_STOPPED
2024-10-24 11:53:01.341  1720-27007 AAudioStream                 D  setState(s#3) from 11 to 12
2024-10-24 11:53:01.342  1720-27007 AAudioStream                 D  ~AudioStream(s#3) mPlayerBase strongCount = 2
2024-10-24 11:53:01.342  1720-27007 AAudio                       D  AAudioStream_close(s#3) returned 0 ---------
2024-10-24 11:53:01.342  1720-27007 MSPushStre...udioDevice      I  LivePushCC 27007:BiliAudioDevice.cpp:185 release() reset....
2024-10-24 11:53:01.342  1720-27007 OboeAudio                    D  Destructor for AudioStream at 0xb400007bb97eee80
2024-10-24 11:53:01.342  1720-27007 LiveStream...PlayOutput      I  nativeAudioDeviceStop, ret:0
2024-10-24 11:53:01.343  1720-27007 LiveStream...PlayOutput      I  openPlayStream, handler is zero?:false, streamConfig:nativeAPI:AAudio,BufferCapacityInFrames:0,FramesPerBurst:0,ChannelCount:2,ChannelMask:Stereo,DeviceId:1211,SessionId:-1,Format:PCM_Float,SampleRate:48000,SharingMode:shared,PerformanceMode:LL,InputPreset:VoiceRec,Usage:Media,ContentType:Music,FormatConversionAllowed:false,ChannelConversionAllowed:false,RateConversionQuality:None,HardwareChannelCount:0,HardwareSampleRate:0,HardwareFormat:0
2024-10-24 11:53:01.346  1720-27007 MSPushStre...udioDevice      I  LivePushCC 27007:BiliAudioDevice.cpp:81 open() openStream.... direction:OUTPUT, deviceID:1211
2024-10-24 11:53:01.347  1720-27007 OboeAudio                    I  openStreamInternal() OUTPUT -------- OboeVersion1.9.2 --------
2024-10-24 11:53:01.347  1720-27007 OboeAudio                    D  Constructor for AudioStream at 0xb400007bb97eee80
2024-10-24 11:53:01.347  1720-27007 AAudio                       I  AAudioStreamBuilder_openStream() called ----------------------------------------
2024-10-24 11:53:01.347  1720-27007 AudioStreamBuilder           I  rate   =  48000, channels  = 2, channelMask = 0x3, format   = 5, sharing = SH, dir = OUTPUT
2024-10-24 11:53:01.347  1720-27007 AudioStreamBuilder           I  device =   1211, sessionId = -1, perfMode = 12, callback: ON with frames = 0
2024-10-24 11:53:01.347  1720-27007 AudioStreamBuilder           I  usage  =      1, contentType = 2, inputPreset = 6, allowedCapturePolicy = 0
2024-10-24 11:53:01.347  1720-27007 AudioStreamBuilder           I  privacy sensitive = false, opPackageName = (null), attributionTag = (null)
2024-10-24 11:53:01.347  1720-1720  DecorView[]                  D  onWindowFocusChanged hasWindowFocus true
2024-10-24 11:53:01.347  1720-1720  HandWritingStubImpl          I  refreshLastKeyboardType: 1
2024-10-24 11:53:01.348  1720-1720  HandWritingStubImpl          I  getCurrentKeyboardType: 1
2024-10-24 11:53:01.349  1720-27007 li.bilibililive              D  PlayerBase::PlayerBase()
2024-10-24 11:53:01.350  1720-27007 AudioStreamTrack             D  open(), request notificationFrames = -8, frameCount = 0
2024-10-24 11:53:01.350  1720-27007 AudioTrack                   D  set(sessionId=0)
2024-10-24 11:53:01.350  1720-27007 AudioTrack                   D  set(): streamType -1, sampleRate 48000, format 0x5, channelMask 0x3, frameCount 0, flags #104, notificationFrames -8, sessionId 0, transferType 1, uid -1, pid -1
2024-10-24 11:53:01.367  1720-27007 AudioTrack                   I  createTrack_l(1210): AUDIO_OUTPUT_FLAG_FAST successful; frameCount 0 -> 1536
2024-10-24 11:53:01.368  1720-27007 AudioTrack                   I  AudioTrack::setVolume L:1.000000 R:1.000000 and the pakage is com.bilibili.bilibililive
2024-10-24 11:53:01.368  1720-27007 AudioTrack                   I  AudioTrack::setVolume L:1.000000 R:1.000000
2024-10-24 11:53:01.369  1720-27007 AudioStreamTrack             D  open() flags changed from 0x00000104 to 0x00000004
2024-10-24 11:53:01.370  1720-27007 AAudioStream                 D  setState(s#4) from 0 to 2
2024-10-24 11:53:01.372  1720-27007 AAudio                       I  AAudioStreamBuilder_openStream() returns 0 = AAUDIO_OK for s#4 ----------------
2024-10-24 11:53:01.372  1720-27007 OboeAudio                    D  AudioStreamAAudio.open() format=2, sampleRate=48000, capacity = 1536
2024-10-24 11:53:01.374  1720-27007 OboeAudio                    D  calculateDefaultDelayBeforeCloseMillis() default = 10
2024-10-24 11:53:01.374  1720-27007 OboeAudio                    D  AudioStreamAAudio.open: AAudioStream_Open() returned AAUDIO_OK = 0
2024-10-24 11:53:01.375  1720-27007 LiveStream...PlayOutput      I  nativeAudioDeviceOpen,ret:0
2024-10-24 11:53:01.378  1720-27007 MSPushStre...udioDevice      I  LivePushCC 27007:BiliAudioDevice.cpp:105 start() stream state:Unknown, start...
2024-10-24 11:53:01.378  1720-27007 AAudio                       D  AAudioStream_requestStart(s#4) called --------------
2024-10-24 11:53:01.378  1720-27007 AAudioStream                 D  setState(s#4) from 2 to 3
2024-10-24 11:53:01.378  1720-27007 AudioTrack                   D  start(1224): prior state:STATE_STOPPED
2024-10-24 11:53:01.400  1720-27007 AAudio                       D  AAudioStream_requestStart(s#4) returned 0 ---------
2024-10-24 11:53:01.400  1720-27218 MSPushStre...udioDevice      I  LivePushCC 27218:BiliAudioDevice.cpp:464 onAudioReady() onAudioDeviceDataReady.... direction:OUTPUT, currentSelectDeviceID:1211, streamState:Started
2024-10-24 11:53:01.401  1720-27007 LiveStream...PlayOutput      I  nativeAudioDeviceStart, ret:0
2024-10-24 11:53:01.406  1720-27218 AAudioStream                 D  setState(s#4) from 3 to 4
2024-10-24 11:53:01.690  1720-25554 BpBinder                     W  PerfMonitor binderTransact :  time=288ms interface=android.media.IAudioPolicyService code=44
2024-10-24 11:53:01.690  1720-25554 AudioStreamLegacy            D  onAudioDeviceUpdate(deviceId = 3)
2024-10-24 11:53:01.691  1720-25554 AudioStreamLegacy            D  onAudioDeviceUpdate() request DISCONNECT in data callback, device 1211 => 3
2024-10-24 11:53:01.691  1720-25554 AudioStreamLegacy            D  onAudioDeviceUpdate(deviceId = 1211)
2024-10-24 11:53:01.691  1720-25554 AudioStreamLegacy            D  onAudioDeviceUpdate() request DISCONNECT in data callback, device 3 => 1211
2024-10-24 11:53:01.694  1720-27218 AudioStreamLegacy            D  checkForDisconnectRequest() mRequestDisconnect acknowledged
2024-10-24 11:53:01.694  1720-27218 AAudioStream                 D  setState(s#4) from 4 to 13
2024-10-24 11:53:01.694  1720-27218 AudioStreamLegacy            W  onMoreData() data, stream disconnected
2024-10-24 11:53:01.694  1720-27218 AudioTrack                   E  processAudioBuffer(1224): EVENT_MORE_DATA requested 1536 bytes but callback returned -1 bytes
2024-10-24 11:53:01.694  1720-27219 OboeAudio                    D  oboe_aaudio_error_thread_proc_shared(,-899) - entering >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
2024-10-24 11:53:01.694  1720-27219 MSPushStre...orCallback      W  LivePushCC 27219:BiliAudioDevice.cpp:480 onError() onError!!! deviceId:1211, current direction is:OUTPUT, audioDevice, msg:AAUDIO_ERROR_DISCONNECTED: Unknown error -899
2024-10-24 11:53:01.694  1720-27219 LiveStream...PlayOutput      I  onError, message:AAUDIO_ERROR_DISCONNECTED: Unknown error -899, code:2
2024-10-24 11:53:01.694  1720-27219 AAudio                       D  AAudioStream_requestStop(s#4) called
2024-10-24 11:53:01.694  1720-27219 AAudioStream                 D  setState(s#4) from 13 to 9
2024-10-24 11:53:01.694  1720-27219 AAudioStream                 W  setState(4) tried to set to 9 but already DISCONNECTED
2024-10-24 11:53:01.694  1720-27219 AudioTrack                   D  stop(sessionID=2769)
2024-10-24 11:53:01.694  1720-27219 AudioTrack                   D  stop(1224): prior state:STATE_ACTIVE
2024-10-24 11:53:01.694  1720-27219 AudioTrack                   D  stop(1224): called with 7296 frames delivered
2024-10-24 11:53:01.695  1720-27219 AudioStreamLegacy            D  checkForDisconnectRequest() mRequestDisconnect acknowledged
2024-10-24 11:53:01.696  1720-27219 MSPushStre...orCallback      W  LivePushCC 27219:BiliAudioDevice.cpp:504 onErrorBeforeClose() onErrorBeforeClose!!! deviceId:1211, current direction is:OUTPUT, audioDevice, msg:AAUDIO_ERROR_DISCONNECTED: Unknown error -899
2024-10-24 11:53:01.696  1720-27219 LiveStream...PlayOutput      I  onErrorBeforeClose, message:AAUDIO_ERROR_DISCONNECTED: Unknown error -899, code:2
2024-10-24 11:53:01.696  1720-27219 AAudio                       D  AAudioStream_requestStop(s#4) called
2024-10-24 11:53:01.696  1720-27219 AAudioStream                 D  setState(s#4) from 13 to 9
2024-10-24 11:53:01.696  1720-27219 AAudioStream                 W  setState(4) tried to set to 9 but already DISCONNECTED
2024-10-24 11:53:01.696  1720-27219 AudioTrack                   D  stop(sessionID=2769)
2024-10-24 11:53:01.696  1720-27219 AudioTrack                   D  stop(1224): prior state:STATE_STOPPED
2024-10-24 11:53:01.699  1720-25871 AidlConversion               W  aidl2legacy_AudioChannelLayout_audio_channel_mask_t: no legacy output audio_channel_mask_t found for AudioChannelLayout{layoutMask: 16}
2024-10-24 11:53:01.706  1720-27219 AAudio                       D  AAudioStream_close(s#4) called ---------------
2024-10-24 11:53:01.706  1720-27219 AAudioStream                 D  setState(s#4) from 13 to 11
2024-10-24 11:53:01.706  1720-27219 AudioTrack                   D  stop(sessionID=2769)
2024-10-24 11:53:01.706  1720-27219 AudioTrack                   D  stop(1224): prior state:STATE_STOPPED
2024-10-24 11:53:01.706  1720-27219 AudioTrack                   D  ~AudioTrack(sessionID=2769)
2024-10-24 11:53:01.706  1720-27219 AudioTrack                   D  stop(sessionID=2769)
2024-10-24 11:53:01.706  1720-27219 AudioTrack                   D  stop(1224): prior state:STATE_STOPPED
2024-10-24 11:53:01.711  1720-27219 AAudioStream                 D  setState(s#4) from 11 to 12
2024-10-24 11:53:01.711  1720-27219 AAudioStream                 D  ~AudioStream(s#4) mPlayerBase strongCount = 2
2024-10-24 11:53:01.711  1720-27219 AAudio                       D  AAudioStream_close(s#4) returned 0 ---------
2024-10-24 11:53:01.712  1720-27219 MSPushStre...orCallback      W  LivePushCC 27219:BiliAudioDevice.cpp:492 onErrorAfterClose() onErrorAfterClose!!! deviceId:1211, current direction is:OUTPUT, audioDevice, msg:AAUDIO_ERROR_DISCONNECTED: Unknown error -899
2024-10-24 11:53:01.712  1720-27219 LiveStream...PlayOutput      I  onErrorAfterClose, message:AAUDIO_ERROR_DISCONNECTED: Unknown error -899, code:2
2024-10-24 11:53:01.712  1720-27219 OboeAudio                    D  oboe_aaudio_error_thread_proc_shared() - exiting <<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<

In the log, we can actually see that when the restart switched to wired headphones, it was successful:

2024-10-24 11:53:01.372  1720-27007 AAudio                       I  AAudioStreamBuilder_openStream() returns 0 = AAUDIO_OK for s#4 ----------------
2024-10-24 11:53:01.372  1720-27007 OboeAudio                    D  AudioStreamAAudio.open() format=2, sampleRate=48000, capacity = 1536
2024-10-24 11:53:01.374  1720-27007 OboeAudio                    D  calculateDefaultDelayBeforeCloseMillis() default = 10
2024-10-24 11:53:01.374  1720-27007 OboeAudio                    D  AudioStreamAAudio.open: AAudioStream_Open() returned AAUDIO_OK = 0
2024-10-24 11:53:01.375  1720-27007 LiveStream...PlayOutput      I  nativeAudioDeviceOpen,ret:0
2024-10-24 11:53:01.378  1720-27007 MSPushStre...udioDevice      I  LivePushCC 27007:BiliAudioDevice.cpp:105 start() stream state:Unknown, start...
2024-10-24 11:53:01.378  1720-27007 AAudio                       D  AAudioStream_requestStart(s#4) called --------------
2024-10-24 11:53:01.378  1720-27007 AAudioStream                 D  setState(s#4) from 2 to 3
2024-10-24 11:53:01.378  1720-27007 AudioTrack                   D  start(1224): prior state:STATE_STOPPED
2024-10-24 11:53:01.400  1720-27007 AAudio                       D  AAudioStream_requestStart(s#4) returned 0 ---------
2024-10-24 11:53:01.400  1720-27218 MSPushStre...udioDevice      I  LivePushCC 27218:BiliAudioDevice.cpp:464 onAudioReady() onAudioDeviceDataReady.... direction:OUTPUT, currentSelectDeviceID:1211, streamState:Started

But then there will be a callback from the bottom layer, as follows:

2024-10-24 11:53:01.690  1720-25554 AudioStreamLegacy            D  onAudioDeviceUpdate(deviceId = 3)
2024-10-24 11:53:01.691  1720-25554 AudioStreamLegacy            D  onAudioDeviceUpdate() request DISCONNECT in data callback, device 1211 => 3
2024-10-24 11:53:01.691  1720-25554 AudioStreamLegacy            D  onAudioDeviceUpdate(deviceId = 1211)
2024-10-24 11:53:01.691  1720-25554 AudioStreamLegacy            D  onAudioDeviceUpdate() request DISCONNECT in data callback, device 3 => 1211
2024-10-24 11:53:01.694  1720-27218 AudioStreamLegacy            D  checkForDisconnectRequest() mRequestDisconnect acknowledged
2024-10-24 11:53:01.694  1720-27218 AAudioStream                 D  setState(s#4) from 4 to 13
2024-10-24 11:53:01.694  1720-27218 AudioStreamLegacy            W  onMoreData() data, stream disconnected
2024-10-24 11:53:01.694  1720-27218 AudioTrack                   E  processAudioBuffer(1224): EVENT_MORE_DATA requested 1536 bytes but callback returned -1 bytes
2024-10-24 11:53:01.694  1720-27219 OboeAudio                    D  oboe_aaudio_error_thread_proc_shared(,-899) - entering >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
2024-10-24 11:53:01.694  1720-27219 MSPushStre...orCallback      W  LivePushCC 27219:BiliAudioDevice.cpp:480 onError() onError!!! deviceId:1211, current direction is:OUTPUT, audioDevice, msg:AAUDIO_ERROR_DISCONNECTED: Unknown error -899
2024-10-24 11:53:01.694  1720-27219 LiveStream...PlayOutput      I  onError, message:AAUDIO_ERROR_DISCONNECTED: Unknown error -899, code:2

At this time, the headset is not unplugged from the phone, but it receives the callback of onAudioDeviceUpdate. At this time, it will be from the device(1211) of the wired headset -> the device(3) of the speaker, and then there will be another one from the device(3) of the speaker -> the device(1211) of the wired headset. Then, because onError is thrown at this time, if onError returns false, then in oboe, it will stop and close it. At this time, there is no sound in the wired headset.

2024-10-24 11:53:01.690  1720-25554 AudioStreamLegacy            D  onAudioDeviceUpdate(deviceId = 3)
2024-10-24 11:53:01.691  1720-25554 AudioStreamLegacy            D  onAudioDeviceUpdate() request DISCONNECT in data callback, device 1211 => 3
2024-10-24 11:53:01.691  1720-25554 AudioStreamLegacy            D  onAudioDeviceUpdate(deviceId = 1211)
2024-10-24 11:53:01.691  1720-25554 AudioStreamLegacy            D  onAudioDeviceUpdate() request DISCONNECT in data callback, device 3 => 1211
2024-10-24 11:53:01.694  1720-27218 AudioStreamLegacy            D  checkForDisconnectRequest() mRequestDisconnect acknowledged
2024-10-24 11:53:01.694  1720-27218 AAudioStream                 D  setState(s#4) from 4 to 13
2024-10-24 11:53:01.694  1720-27218 AudioStreamLegacy            W  onMoreData() data, stream disconnected
2024-10-24 11:53:01.694  1720-27218 AudioTrack                   E  processAudioBuffer(1224): EVENT_MORE_DATA requested 1536 bytes but callback returned -1 bytes
2024-10-24 11:53:01.694  1720-27219 OboeAudio                    D  oboe_aaudio_error_thread_proc_shared(,-899) - entering >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
2024-10-24 11:53:01.694  1720-27219 MSPushStre...orCallback      W  LivePushCC 27219:BiliAudioDevice.cpp:480 onError() onError!!! deviceId:1211, current direction is:OUTPUT, audioDevice, msg:AAUDIO_ERROR_DISCONNECTED: Unknown error -899
2024-10-24 11:53:01.694  1720-27219 LiveStream...PlayOutput      I  onError, message:AAUDIO_ERROR_DISCONNECTED: Unknown error -899, code:2
2024-10-24 11:53:01.694  1720-27219 AAudio                       D  AAudioStream_requestStop(s#4) called
2024-10-24 11:53:01.694  1720-27219 AAudioStream                 D  setState(s#4) from 13 to 9
2024-10-24 11:53:01.694  1720-27219 AAudioStream                 W  setState(4) tried to set to 9 but already DISCONNECTED
2024-10-24 11:53:01.694  1720-27219 AudioTrack                   D  stop(sessionID=2769)
2024-10-24 11:53:01.694  1720-27219 AudioTrack                   D  stop(1224): prior state:STATE_ACTIVE
2024-10-24 11:53:01.694  1720-27219 AudioTrack                   D  stop(1224): called with 7296 frames delivered
2024-10-24 11:53:01.695  1720-27219 AudioStreamLegacy            D  checkForDisconnectRequest() mRequestDisconnect acknowledged
2024-10-24 11:53:01.696  1720-27219 MSPushStre...orCallback      W  LivePushCC 27219:BiliAudioDevice.cpp:504 onErrorBeforeClose() onErrorBeforeClose!!! deviceId:1211, current direction is:OUTPUT, audioDevice, msg:AAUDIO_ERROR_DISCONNECTED: Unknown error -899
2024-10-24 11:53:01.696  1720-27219 LiveStream...PlayOutput      I  onErrorBeforeClose, message:AAUDIO_ERROR_DISCONNECTED: Unknown error -899, code:2
2024-10-24 11:53:01.696  1720-27219 AAudio                       D  AAudioStream_requestStop(s#4) called
2024-10-24 11:53:01.696  1720-27219 AAudioStream                 D  setState(s#4) from 13 to 9
2024-10-24 11:53:01.696  1720-27219 AAudioStream                 W  setState(4) tried to set to 9 but already DISCONNECTED
2024-10-24 11:53:01.696  1720-27219 AudioTrack                   D  stop(sessionID=2769)
2024-10-24 11:53:01.696  1720-27219 AudioTrack                   D  stop(1224): prior state:STATE_STOPPED
2024-10-24 11:53:01.699  1720-25871 AidlConversion               W  aidl2legacy_AudioChannelLayout_audio_channel_mask_t: no legacy output audio_channel_mask_t found for AudioChannelLayout{layoutMask: 16}
2024-10-24 11:53:01.706  1720-27219 AAudio                       D  AAudioStream_close(s#4) called ---------------
2024-10-24 11:53:01.706  1720-27219 AAudioStream                 D  setState(s#4) from 13 to 11
2024-10-24 11:53:01.706  1720-27219 AudioTrack                   D  stop(sessionID=2769)
2024-10-24 11:53:01.706  1720-27219 AudioTrack                   D  stop(1224): prior state:STATE_STOPPED

I saw a similar question asked before. How to handle audio output device change?.
have seen: SimpleMultiPlayer::startStream and SimpleMultiPlayer::MyErrorCallback::onErrorAfterClose
Is this to avoid switching device failure?

Looking forward to your reply, thank you

If applicable, please attach a few seconds of an uncompressed recording of the sound in a WAV or AIFF file.

@lilinxiong lilinxiong added the bug label Oct 24, 2024
@philburk
Copy link
Collaborator

Handling the unplugging or plugging in of peripherals has been a major problem area.
One problem is that it can take a second or two for the device patches to switch at the lower level.
So you may open the old device instead of the new device.

Also sometimes the low level code may not repond to the headset being changed.
That is why some apps use registerAudioDeviceCallback(). But that can cause problems because then
that thread can conflict with the lower level onErrorCallback() and cause race conditions.

I recommend:

  • try not using the registerAudioDeviceCallback() and just use the onErrorCallback().
  • reopen your stream in the onErrorAfterClose() callback method,

@lilinxiong
Copy link
Contributor Author

Ok, thank you very much for your reply, but I have a question, if I don't use registerAudioDeviceCallback(), but only use onErrorCallback(), will oboe select the device for playback internally?
If playback is like this, then I can accept it, but what about audio recording? From your description, it seems that recording will also have this problem.
For recording, our scenario requires us to select the recording equipment.

@robertwu1
Copy link
Collaborator

After you get an onErrorCallback(), you should open a new stream.

You should get an onErrorCallback() when a headset is connected/disconnected.

@lilinxiong
Copy link
Contributor Author

After you get an onErrorCallback(), you should open a new stream.

You should get an onErrorCallback() when a headset is connected/disconnected.

emmm, Whether I switch playback devices or recording devices, should I reopen the stream in the onErrorCallback() ? And then, in the configuration of reopening the stream, do not fill in the deviceID, so that OBOE can select a device by itself?

@robertwu1
Copy link
Collaborator

That should be fine. Android should prioritize the external playback and recording devices over the built-in speaker/mic.

@znakeeye
Copy link

@philburk, I understand you are an expert at AAudio and all that low-level audio stuff.

I'm experiencing a similar issue in mackron/miniaudio#913, both with AAudio and OpenSL backends. It's actually quite easy to reproduce. When a breakpoint is hit, I quickly attach and detach my bluetooth earpods. Some moments later, audio is forever gone.

In logcat, I can see that AudioStreamLegacy is unhappy when audio is silenced:

AudioTrack  W  restartIfDisabled(7789): releaseBuffer() track 0xb40000750d6382b0 disabled due to previous underrun, restarting
AudioStreamLegacy       D  onAudioDeviceUpdate(deviceId = 3)

The AAudio stream reports that it is started, but no callbacks (like the one set in AAudioStreamBuilder_setErrorCallback) are called. Do you know of a way to detect this "restartIfDisabled" thing?

After a week of debugging, I'd say I'm facing an Android bug. Running Pixel 9 Pro and Android 15. I'll probably file an issue to Google.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

No branches or pull requests

4 participants