[GPL] epicBT - Call Audio Router ( Epic4G ) - bluetooth/wired conflict hotfix - 11/26

Search This thread

cicada

Senior Member
Nov 7, 2009
173
153
Denver, CO
This application is a hotfix for a really annoying (and potentially unsafe!) bug in the Epic4G:

http://code.google.com/p/android/issues/detail?id=11372
http://forum.sdx-developers.com/epi...audio-routing-on-epic-4g/msg115990/#msg115990

The long and sort of it is that when anything is plugged into the 3.5mm headphone jack, the phone will only play call audio over that jack.

In order to route the audio through the earpiece, bluetooth or speakerphone, you must pull the plug out of the jack. This is at the very least annoying, and at the very worst potentially dangerous if, for example, you're driving.

How-To

Download the APK attached below for your android version.
Install like any other APK using adb or your favorite file manager.




What it does

This simple application allows you to pick the audio device to use for call audio to override this behavior, and can be changed on the fly.

All in-call audio will be routed to the device you specify when something is plugged into the 3.5mm headphone jack. If nothing is in the jack, the default behavior for the phone applies.

This also allows you to use the Speaker Phone when the headphone jack is occupied, even though the button on the call screen is disabled!

Your configuration should persist between reboots.


What it doesn't do

This app does not route any other type of audio. Your music, notifications, etc will still play over the headphone jack or phone speaker.


Again, this *only* affects in-call voice audio, and only when something is plugged into the headphone jack.




Notes

This app completely overrides the options on the call page! If you want to switch outputs during a call, you will have to do it from this app - your call will not be dropped when changing the output device.

In order to route the call audio properly, the system's mediaserver service must be restarted, however.

This means that any other audio you have playing when you apply the change will be disrupted, and related services may force close. For example, Pandora will skip to the next song. Other applications may not behave that well.



Disclaimer

This app modifies files in the /system partition, so use this at your own risk! I am not responsible for any problems that arise from this hotfix on your device!

This is currently for the EPIC4G *ONLY* - Do not use this on any other device. Please contact me if you have a different phone which experiences this bug and I will see if I can get it working for you as well.

This is *BETA* software, a work in progress, please post here if you experience any issues, but I cannot guarantee it will work for you!

ROM DEVs, feel free to bake this into your roms in whole or part, I encourage it as this provides a workaround for a safety issue, but please give credit if you use or derive from this application.


Special thanks to UberPinguin - his initiative, debugging, code-diving and testing helped make this happen every step of the way!

Many, many thanks to everyone in #samsung-epic for helping me test and work this out.


Be sure to download the APK for the right android version on your phone!

epicBT - v0.3.5 (Froyo)
* Fixed crash/reboot when applying settings in DK17 roms

epicBT - v0.3
* Layout cleanup when root is unavailable

epicBT - v0.2
* Requires root!
* Superuser compatible
* auto-remounts /system RW if necessary
* Sends call audio to wired device ( default ), speaker phone, or bluetooth

Sources
https://github.com/cicada/epicBT
 

Attachments

  • epicBT-eclair-0.3.apk
    23.3 KB · Views: 187
  • epicBT-froyo-0.3.5.apk
    23.7 KB · Views: 717
Last edited:

bigdbag

Senior Member
Oct 5, 2009
381
34
If this works as described above I will be so f-ing happy. One of my biggest gripes, solved.
 

bigfloppydb

Member
Sep 4, 2007
15
0
No sh#t! I was just about to start searching the Market for an app like this! Downloading now to test.

Thank you!
 

sinman02

Senior Member
Nov 4, 2008
251
18
First of all,...Thank you, Thank you, Thank you for working on this... This was one of my biggest gripes with this phone and I couldn't understand why the "geniuses" at Samsung/Sprint couldn't get this right.

I've done some extensive testing in my car for the Eclair version and wanted to share my results:

For the most part, the app does what it's supposed to...but I did notice that:

1) the "on the fly" feature doesn't work so well. That is, when changing from one mode to the other, I had to reboot the phone to get the new setting to take effect. This feature would be great with an app like Tasker, which could automatically open up the app and ask you which setting you want to use when a headset/aux jack is plugged in,...thus giving you the flexibility to use the best option depending on your situation. Is there a way to tweak the app to recognize the switch without rebooting by resetting something like the mediashare service?

2) For some reason, the mic volume (volume heard on the opposite end of call) on the bluetooth setting is lower when the headset/aux jack is plugged in. I'm not sure whether the regular phone mic, speaker phone mic, or the bluetooth mic is utilized in this setting, but the volume is definitely harder to hear on the other end than when the headset jack is unplugged. I would guess about 20-25% lower. I tested this effect during the call as well by plugging and unplugging the jack while counting 1 to 10 and it's the same. Is there away to increase the sensitivity of the bluetooth mic when the headset jack is plugged in?


Donation coming if you can get this working! Thanks again.
 

cicada

Senior Member
Nov 7, 2009
173
153
Denver, CO
1) the "on the fly" feature doesn't work so well. That is, when changing from one mode to the other, I had to reboot the phone to get the new setting to take effect.

Strange, it works well for me - it takes a second to switch outputs while mediaserver is restarting, but never had to reboot. I'll look into this, may have accidentally tweaked something in the last build.

UberPinguin and I are still looking at the sources to find a better fix that works the way it's supposed to - the trouble seems to be that Phone.apk is actually selecting the 'correct' source and setting options appropriately, but the underlying OS isn't switching outputs. Restarting mediaserver was the only workaround I could find for this.

2) For some reason, the mic volume (volume heard on the opposite end of call) on the bluetooth setting is lower when the headset/aux jack is plugged in. I'm not sure whether the regular phone mic, speaker phone mic, or the bluetooth mic is utilized in this setting, but the volume is definitely harder to hear on the other end than when the headset jack is unplugged. I would guess about 20-25% lower. I tested this effect during the call as well by plugging and unplugging the jack while counting 1 to 10 and it's the same. Is there away to increase the sensitivity of the bluetooth mic when the headset jack is plugged in?

I hadn't noticed any volume issues but truthfully I haven't been using the BT often because of this bug - I've just been letting my calls go to VM instead of crashing my car ;) Volume selection should be working properly so I'll see if I can add something to select volume as well.

To be clear on the MIC, input should always be the proper input for whichever mode you choose - phone MIC for speakerphone and BT mic for BT HP/HS.

If you're on stock then the phone mic should be used when your wired device doesn't have it's own, however this is broken in all of our custom community kernels - Wired Headset mode should only be used when you actually have a wired headset with a MIC of it's own if you're using one of these, otherwise the phone doesn't enable any MIC at all.
 

sinman02

Senior Member
Nov 4, 2008
251
18
I should note, that all my tests were conducted on outgoing phone calls. I don't know if incoming calls are any different. I am using the Syndicate rom.

If you can get the bluetooth volume issue resolved, I'll likely leave it there, but it would be nice to be able to switch on the fly to speakerphone mode when bluetooth isn't handy.

Question: Does the froyo version have the same implementation?

Please keep up the good work!

Sent from my SPH-D700 using XDA App
 

getmoney2xl

Member
Oct 28, 2009
12
0
This application is a hotfix for a really annoying (and potentially unsafe!) bug in the Epic4G:

The long and sort of it is that when anything is plugged into the 3.5mm headphone jack, the phone will only play call audio over that jack.

In order to route the audio through the earpiece, bluetooth or speakerphone, you must pull the plug out of the jack. This is at the very least annoying, and at the very worst potentially dangerous if, for example, you're driving.

...So this should work on for Sip/VOIP apps like Sipdroid, 3CX, and Fring? I managed to pick up 3CX and Sipdroid through my bluetooth headset but no mic...meaning the other end could not hear me... There aren't that many good sip/voip soft wares out there for the Android today.. I rated Fring the BEST but with no bluetooth support.

EDIT: Nevermind... I read the post again.. I don't think this will do the job other than support for the actual phone.. but it would be nice to have that option for sip/voip as well.
 

cicada

Senior Member
Nov 7, 2009
173
153
Denver, CO
The SIP/VoIP stuff may work better in Froyo considering there are dedicated PCM devices listed in the asound.conf - however I've never used any of these applications, so this is pure speculation.

You're correct, this does only effect in-call phone audio, those applications would be handling (or in this case, not) the bluetooth audio routing directly. I've found lots of other similar quirks with BT on the Epic4G, such as the << and >> buttons on my A2DP headphones not working.
 

getmoney2xl

Member
Oct 28, 2009
12
0
The SIP/VoIP stuff may work better in Froyo considering there are dedicated PCM devices listed in the asound.conf - however I've never used any of these applications, so this is pure speculation.

You're correct, this does only effect in-call phone audio, those applications would be handling (or in this case, not) the bluetooth audio routing directly. I've found lots of other similar quirks with BT on the Epic4G, such as the << and >> buttons on my A2DP headphones not working.

I am using Froyo the DJ29 Build on the epic... Dare I try?
 

biscojams

Senior Member
Oct 1, 2010
117
6
****ing yea! Thanks, downloading now. This has been my biggest complaint with the phone

Sent from my SPH-D700 using XDA App
 

fsp48

Member
Jan 30, 2009
18
3
Hell Yea! You rock! I Threw out a fairly long search sentence in google and actually found your post here. No sooner did I install and set it up that my phone rang while plugged into the car audio and FINALLY I can use my friggin BT headset without yelling hold on hold on I gotta unplug the stereo cable. This has really peeved me off since I got the phone. Now what I don't get is why this obvious flaw has been ignored by Samsung and Sprint. Nice job on making it work like it should. BTW running stock 2.1 with root. No bugs so far.
 

dwallersv

Senior Member
Dec 10, 2007
618
102
California
I hadn't noticed any volume issues but truthfully I haven't been using the BT often because of this bug - I've just been letting my calls go to VM instead of crashing my car ;) Volume selection should be working properly so I'll see if I can add something to select volume as well.

To be clear on the MIC, input should always be the proper input for whichever mode you choose - phone MIC for speakerphone and BT mic for BT HP/HS.

If you're on stock then the phone mic should be used when your wired device doesn't have it's own, however this is broken in all of our custom community kernels - Wired Headset mode should only be used when you actually have a wired headset with a MIC of it's own if you're using one of these, otherwise the phone doesn't enable any MIC at all.
As others, I'm very grateful for this fix. After trying it out, if it works for me, donation on the way.

Regarding the MIC: My experience, all the way back to pure stock (IIRC) is that there is no MIC at all when a two-channel, stereo plug is inserted (headphones, cassette adapter, etc.). Every time I've been driving, listening to something via the headset jack, when a call comes in I can hear the other party, but they can't hear me at all until I unplug from the jack. So, even though there was no mic plugged in and the device was correctly sending 2-channel audio out through the jack (usually to a cass adapter, so I can listen via my car stereo), but doesn't "do the right thing" with the mic, even though the hardware and drivers are capable of detecting the absence of the mic.

It should, of course, default to the BT mic if there is a BT connection, or the built-in mic otherwise. For some reason this simple flow-diagram logic eludes Samsung.
 

m5james

Senior Member
Aug 27, 2010
601
17
So I got my first experience with this today...worked great. I was streaming Pandora, phone call came in, music was paused and I answered the call. Once I finished the call, the music continued playing. Minor detail, but since I was on WiFi, is there anyway that the music could have kept on playing while I was still on the call for the sake of my guys who were still working while I was taking the call? It's great that the music paused and resumed by itself, but it would have been cooler to have it keep going while I was on the call.
 

m5james

Senior Member
Aug 27, 2010
601
17
I've got a hacked version of Pandora that allows unlimited skips, I'll have to ask the guy who did it to see if they can tweak that as well. Come to think of it, it'd be nice to have it keep going for the times I'm driving down the road as well so whoevers in the car doesn't have to sit there and listen to me blah blah blah.
 

Top Liked Posts

  • There are no posts matching your filters.
  • 4
    This application is a hotfix for a really annoying (and potentially unsafe!) bug in the Epic4G:

    http://code.google.com/p/android/issues/detail?id=11372
    http://forum.sdx-developers.com/epi...audio-routing-on-epic-4g/msg115990/#msg115990

    The long and sort of it is that when anything is plugged into the 3.5mm headphone jack, the phone will only play call audio over that jack.

    In order to route the audio through the earpiece, bluetooth or speakerphone, you must pull the plug out of the jack. This is at the very least annoying, and at the very worst potentially dangerous if, for example, you're driving.

    How-To

    Download the APK attached below for your android version.
    Install like any other APK using adb or your favorite file manager.




    What it does

    This simple application allows you to pick the audio device to use for call audio to override this behavior, and can be changed on the fly.

    All in-call audio will be routed to the device you specify when something is plugged into the 3.5mm headphone jack. If nothing is in the jack, the default behavior for the phone applies.

    This also allows you to use the Speaker Phone when the headphone jack is occupied, even though the button on the call screen is disabled!

    Your configuration should persist between reboots.


    What it doesn't do

    This app does not route any other type of audio. Your music, notifications, etc will still play over the headphone jack or phone speaker.


    Again, this *only* affects in-call voice audio, and only when something is plugged into the headphone jack.




    Notes

    This app completely overrides the options on the call page! If you want to switch outputs during a call, you will have to do it from this app - your call will not be dropped when changing the output device.

    In order to route the call audio properly, the system's mediaserver service must be restarted, however.

    This means that any other audio you have playing when you apply the change will be disrupted, and related services may force close. For example, Pandora will skip to the next song. Other applications may not behave that well.



    Disclaimer

    This app modifies files in the /system partition, so use this at your own risk! I am not responsible for any problems that arise from this hotfix on your device!

    This is currently for the EPIC4G *ONLY* - Do not use this on any other device. Please contact me if you have a different phone which experiences this bug and I will see if I can get it working for you as well.

    This is *BETA* software, a work in progress, please post here if you experience any issues, but I cannot guarantee it will work for you!

    ROM DEVs, feel free to bake this into your roms in whole or part, I encourage it as this provides a workaround for a safety issue, but please give credit if you use or derive from this application.


    Special thanks to UberPinguin - his initiative, debugging, code-diving and testing helped make this happen every step of the way!

    Many, many thanks to everyone in #samsung-epic for helping me test and work this out.


    Be sure to download the APK for the right android version on your phone!

    epicBT - v0.3.5 (Froyo)
    * Fixed crash/reboot when applying settings in DK17 roms

    epicBT - v0.3
    * Layout cleanup when root is unavailable

    epicBT - v0.2
    * Requires root!
    * Superuser compatible
    * auto-remounts /system RW if necessary
    * Sends call audio to wired device ( default ), speaker phone, or bluetooth

    Sources
    https://github.com/cicada/epicBT
    1
    updated OP with source link
    1
    Works perfect on ec05.... used with bonsai and superheroes[bonsai based]. It doesn't allow u to hit the bluetooth button from the in call screen but it works automatically. Awesome fix

    Any word on how it works on ec05?



    Sent from my SPH-D700 using XDA App
    1
    i have this problem on fascinate and a guy suggested this and it worked!:

    it looks like all you'd have to do is edit the pcm.AndroidPlayback_Headphone_incall section, line 487, in /system/etc/asound.conf, and changing it from reading {name "Voice Call Path" value 4} to {name "Voice Call Path" value 5}. Here's the values, from the comments in the config file: # 0:OFF 1:RCV 2:SPK 3:HP 4:HP_NO_MIC 5:BT