commit | 7b315b335567fa898d1a364b0381e7b61c72e76f | [log] [tgz] |
---|---|---|
author | Jack He <siyuanh@google.com> | Wed Jun 07 16:44:30 2017 -0700 |
committer | Andre Eisenbach <eisenbach@google.com> | Fri Jun 09 00:33:57 2017 +0000 |
tree | 835bc73c4732eccb0aaa8b1b7fa22fb5b2bd77c4 | |
parent | 7c14d52c74320cb01102dc19484ca220d72f49a2 [diff] |
eSCO: Limit number of retries after mSBC connection failure * When peer device supports mSBC and codec negotiation, Fluoride stack will try to do the following when establishing a eSCO/SCO connection: 1) Negotiate to mSBC by sending +BCS:2 2) Try establishing eSCO/SCO connection using mSBC T2 settings 3) If that failed, downgrade to mSBC T1 settings and retry 4) If that failed, re-negotiate codec to CVSD, by sending +BCS:1 5) Retry using CVSD S4 (HFP 1.7 and above) or S3 settings 6) If this failed stop trying and report failure to upper stack * Retry is achieved by: * Retry is only possible when inuse_codec = BTA_AG_CODEC_MSBC * Set codec_msbc_settings to BTA_AG_SCO_MSBC_SETTINGS_T1 when T2 failed to connect in step 3 above * Set codec_fallback to true when T1 failed so that CVSD is used in step 4 above * Retry stop is achieved by: * Set inuse_codec = BTA_AG_CODEC_CVSD * Set codec_msbc_settings back to BTA_AG_SCO_MSBC_SETTINGS_T2 * Set codec_fallback to false and codec_updated to true so that the stack is ready for the next application triggerred SCO connection attempt * Removed retry_with_sco_only as both Setup Synchronous Connection Command (0x0028) and Enhanced Setup Synchronous Connection Command (0x003D) fall back to SCO connection if eSCO is not supported. See page 858/2772 and 895/2772 of BT4.2 specification document * Besides both code paths are the same for retry_with_sco_only after eSCO changes went in Bug: 62426841 Test: make, HFP regression, testplans/91406 Change-Id: I205311c55e8763c48b6eb43c27f242927384036e
Just build AOSP - Fluoride is there by default.
Instructions for Ubuntu, tested on 14.04 with Clang 3.5.0 and 16.10 with Clang 3.8.0
mkdir ~/fluoride cd ~/fluoride git clone https://android.googlesource.com/platform/packages/modules/Bluetooth/system
Install dependencies (require sudo access):
cd ~/fluoride/bt build/install_deps.sh
Then fetch third party dependencies:
cd ~/fluoride/bt mkdir third_party cd third_party git clone https://github.com/google/googletest.git git clone https://android.googlesource.com/platform/external/aac git clone https://android.googlesource.com/platform/external/libchrome git clone https://android.googlesource.com/platform/external/libldac git clone https://android.googlesource.com/platform/external/modp_b64 git clone https://android.googlesource.com/platform/external/tinyxml2 git clone https://android.googlesource.com/platform/hardware/libhardware
And third party dependencies of third party dependencies:
cd fluoride/bt/third_party/libchrome/base/third_party mkdir valgrind cd valgrind curl https://chromium.googlesource.com/chromium/src/base/+/master/third_party/valgrind/valgrind.h?format=TEXT | base64 -d > valgrind.h curl https://chromium.googlesource.com/chromium/src/base/+/master/third_party/valgrind/memcheck.h?format=TEXT | base64 -d > memcheck.h
NOTE: If packages/modules/Bluetooth/system is checked out under AOSP, then create symbolic links instead of downloading sources
cd packages/modules/Bluetooth/system mkdir third_party cd third_party ln -s ../../../external/aac aac ln -s ../../../external/libchrome libchrome ln -s ../../../external/libldac libldac ln -s ../../../external/modp_b64 modp_b64 ln -s ../../../external/tinyxml2 tinyxml2 ln -s ../../../hardware/libhardware libhardware ln -s ../../../external/googletest googletest
cd ~/fluoride/bt gn gen out/Default
cd ~/fluoride/bt ninja -C out/Default all
This will build all targets (the shared library, executables, tests, etc) and put them in out/Default. To build an individual target, replace "all" with the target of your choice, e.g. ninja -C out/Default net_test_osi
.
cd ~/fluoride/bt/out/Default LD_LIBRARY_PATH=./ ./bluetoothtbd -create-ipc-socket=fluoride
Follows the Chromium project Eclipse Setup Instructions until "Optional: Building inside Eclipse" section (don't do that section, we will set it up differently)
Generate Eclipse settings:
cd packages/modules/Bluetooth/system gn gen --ide=eclipse out/Default
In Eclipse, do File->Import->C/C++->C/C++ Project Settings, choose the XML location under packages/modules/Bluetooth/system/out/Default
Right click on the project. Go to Preferences->C/C++ Build->Builder Settings. Uncheck "Use default build command", but instead using "ninja -C out/Default"
Goto Behaviour tab, change clean command to "-t clean"