commit | b2224d227a79454f6776f2022d506ef6e064bfa6 | [log] [tgz] |
---|---|---|
author | Łukasz Rymanowski <rlukasz@google.com> | Wed Feb 23 12:25:43 2022 +0000 |
committer | Łukasz Rymanowski <rlukasz@google.com> | Wed Feb 23 12:38:56 2022 +0000 |
tree | e5ad8fee80e12063d3fd95f793e97f29a91a08ef | |
parent | dec97f0ace4480922c1fad553ddf377087198803 [diff] |
leaudio: Fix the time of creating CIG According to the BAP specification, CIG shall be created before sending QoS Config to ASE. This patch fixes that: > ACL Data RX: Handle 65 flags 0x02 dlen 51 #2632 52.932831 ATT: Handle Value Notification (0x1b) len 46 Handle: 0x1105 Data: 01010002051400204e00409c00204e00409c0006000000001302010802020105030200000003047800020501 ASCS: Audio Stream Sink Endpoint (Handle: 0x1105) ASE ID: 1 Codec configure state Codec ID: LC3 Codec ID Company ID: 0x00 Vendor ID: 0x00 Framing properties: 0x0000 LE PHY (0x02) LE 2M PHY Retransmission number: 5 Transport latency max: 20 ms Presentation delay min: 20000 Presentation delay max: 40000 Preferred presentation delay min: 20000 Preferred presentation delay max: 40000 codec specific configuration length: 19 Codec specific configuration: 0x02010802020105030200000003047800020501 ASCS: Sampling Frequency (0x01) val 0x0008 len 1 Sampling frequency: 48 kHz ASCS: Frame duration (0x02) val 0x01 len 1 Frame duration: use 10 ms codec frames ASCS: Audio channel allocation (0x03) val 0x02 len 4 Front right ASCS: Octets per codec frame (0x04) val 0x78 len 2 Value: 120 ASCS: LC3 blocks per SDU (0x05) val 0x01 len 1 Value: 1 < HCI Command: LE Set Connected Isochr.. (0x08|0x0062) plen 33 #2633 52.933679 CIG ID: 0x02 Master to Slave SDU Interval: 10000 us (0x002710) Slave to Master SDU Interval: 0 us (0x000000) SCA: 151 - 200 ppm (0x01) Packing: Sequential (0x00) Framing: Unframed (0x00) Master to Slave Maximum Latency: 20 ms (0x0014) Slave to Master Maximum Latency: 5 ms (0x0005) Number of CIS: 2 CIS ID: 0x00 Master to Slave Maximum SDU Size: 120 Slave to Master Maximum SDU Size: 0 Master to Slave PHY: 0x02 LE 2M Slave to Master PHY: 0x03 LE 1M LE 2M Master to Slave Retransmission attempts: 0x05 Slave to Master Retransmission attempts: 0x00 CIS ID: 0x01 Master to Slave Maximum SDU Size: 120 Slave to Master Maximum SDU Size: 0 Master to Slave PHY: 0x02 LE 2M Slave to Master PHY: 0x03 LE 1M LE 2M Master to Slave Retransmission attempts: 0x05 Slave to Master Retransmission attempts: 0x00 Bug: 209943235 Bug: 150670922 sponsor: @jpawlowski Test: atest --host bluetooth_le_audio_test Change-Id: I069031356692ee652c26b8e53c617525a429530d
Just build AOSP - Fluoride is there by default.
Instructions for a Debian based distribution:
You'll want to download some pre-requisite packages as well. If you're currently configured for AOSP development, you should have most required packages. Otherwise, you can use the following apt-get list or use the --run-bootstrap
option on build.py
(see below) to get a list of packages missing on your system:
sudo apt-get install repo git-core gnupg flex bison gperf build-essential \ zip curl zlib1g-dev gcc-multilib g++-multilib \ x11proto-core-dev libx11-dev libncurses5 \ libgl1-mesa-dev libxml2-utils xsltproc unzip liblz4-tool libssl-dev \ libc++-dev libevent-dev \ flatbuffers-compiler libflatbuffers1 openssl \ libflatbuffers-dev libtinyxml2-dev \ libglib2.0-dev libevent-dev libnss3-dev libdbus-1-dev \ libprotobuf-dev ninja-build generate-ninja protobuf-compiler \ libre2-9 debmake \ llvm libc++abi-dev \ libre2-dev libdouble-conversion-dev
You will also need a recent-ish version of Rust and Cargo. Please follow the instructions on Rustup to install a recent version.
mkdir ~/fluoride cd ~/fluoride git clone https://android.googlesource.com/platform/packages/modules/Bluetooth
build.py
is the helper script used to build Fluoride for Linux (i.e. Floss). It accepts a --run-bootstrap
option that will set up your build staging directory and also make sure you have all required system packages to build (should work on Debian and Ubuntu). You will still need to build some unpackaged dependencies (like libchrome, modp_b64, googletest, etc).
To use it:
./build.py --run-bootstrap
This will install your bootstrapped build environment to ~/.floss
. If you want to change this, just pass in --bootstrap-dir
to the script.
The following third-party dependencies are necessary but currently unavailable via a package manager. You may have to build these from source and install them to your local environment.
We provide a script to produce debian packages for those components. Please see the instructions in build/dpkg/README.txt for more details.
cd system/build/dpkg mkdir -p outdir/{modp_b64,libchrome} # Build and install modp_b64 pushd modp_b64 ./gen-src-pkg.sh $(readlink -f ../outdir/modp_b64) popd sudo dpkg -i outdir/modp_b64/*.deb # Build and install libchrome pushd libchrome ./gen-src-pkg.sh $(readlink -f ../outdir/libchrome) popd sudo dpkg -i outdir/libchrome/*.deb
The googletest packages provided by Debian/Ubuntu (libgmock-dev and libgtest-dev) do not provide pkg-config files, so you can build your own googletest using the steps below:
git clone https://github.com/google/googletest.git -b release-1.10.0 cd googletest # Main directory of the cloned repository. mkdir build # Create a directory to hold the build output. cd build cmake .. # Generate native build scripts for GoogleTest. sudo make install -DCMAKE_INSTALL_PREFIX=/usr # Optional steps if pkgconfig isn't installed to desired location # Modify the source (/usr/lib/x86_64-linux-gnu) and target (/usr/lib) based on # your local installation. for f in $(ls /usr/lib/x86_64-linux-gnu/pkgconfig/{gtest,gmock}*); do \ ln -sf $f /usr/lib/pkgconfig/$(basename $f); done
Note: Handled by --run-bootstrap
option.
Run the following to install Rust dependencies:
cargo install cxxbridge-cmd
Note: Handled by --run-bootstrap
option.
For host build, we depend on a few other repositories:
Clone these all somewhere and create your staging environment.
export STAGING_DIR=path/to/your/staging/dir mkdir ${STAGING_DIR} mkdir -p ${STAGING_DIR}/external ln -s $(readlink -f ${PLATFORM2_DIR}/common-mk) ${STAGING_DIR}/common-mk ln -s $(readlink -f ${PLATFORM2_DIR}/.gn) ${STAGING_DIR}/.gn ln -s $(readlink -f ${RUST_CRATE_DIR}) ${STAGING_DIR}/external/rust ln -s $(readlink -f ${PROTO_LOG_DIR}) ${STAGING_DIR}/external/proto_logging
We provide a build script to automate building assuming you've staged your build environment already as above. At this point, make sure you have all the pre-requisites installed (i.e. bootstrap option and other dependencies above) or you will see failures. In addition, you may need to set a --libdir=
if your libraries are not stored in /usr/lib
by default.
./build.py
This will build all targets to the output directory at --bootstrap-dir
(which defaults to ~/.floss
). You can also build each stage separately (if you want to iterate on something specific):
You can choose to run only a specific stage by passing an arg via --target
.
Currently, Rust builds are a separate stage that uses Cargo to build. See gd/rust/README.md for more information. If you are iterating on Rust code and want to add new crates, you may also want to use the --no-vendored-rust
option (which will let you use crates.io instead of using a pre-populated vendored crates repo).
By default on Linux, we statically link libbluetooth so you can just run the binary directly. By default, it will try to run on hci0 but you can pass it --hci=N, where N corresponds to /sys/class/bluetooth/hciN.
$OUTPUT_DIR/debug/btadapterd --hci=$HCI INIT_gd_hci=true