No description
Find a file
2026-02-17 12:04:34 +01:00
android BondStateMachine: Check name for validity before access 2025-03-17 07:43:57 +00:00
apex SystemServer: One unique method to call Enable 2024-08-01 18:22:11 -07:00
flags Early flag removal for ble_scan_setting 2024-12-18 12:27:33 -08:00
floss Merge "floss: add image check and example use cases" into main 2024-09-14 03:37:06 +00:00
framework Merge "Formatting change in PairingTests.java" into main am: 6224ecd807 am: b57f9d21e3 2024-09-23 21:31:40 +00:00
pandora Merge "Avatar implement first HAP test" into main 2024-09-20 23:06:52 +00:00
service MigOS: Hard-lock Bluetooth activation when Master Privacy is active 2026-02-17 12:04:34 +01:00
sysprop Remove obsolete owner 2024-07-18 11:54:57 -07:00
system Android security 15.0.0 release 7 2025-04-15 05:48:45 -06:00
tools Actualize owners file 2024-09-18 16:05:23 -07:00
.clang-format Format: apply clang rules 2024-07-07 10:58:27 -07:00
.editorconfig Add .editorconfig 2023-12-01 23:31:42 +00:00
.gitignore gitignore: Add python cache files 2023-10-25 04:54:44 +00:00
.style.yapf
Android.bp Unify errorprone enforced rules 2024-09-18 19:20:24 -07:00
AndroidTestTemplate.xml
BUILD.gn
build.py floss: Fix build faliure: non-void function does not return a value 2024-08-23 13:34:41 +08:00
Cargo.toml Floss: add util to use featured to query chrome flags 2024-05-09 06:40:20 +00:00
checkstyle.xml Put back checkstyle to include more than format 2024-06-05 16:51:27 -07:00
checkstyle_suppressions.xml Put back checkstyle to include more than format 2024-06-05 16:51:27 -07:00
CPPLINT.cfg Cpplint bypass most common error 2024-09-05 23:51:46 +00:00
METADATA
MODULE_LICENSE_APACHE2
NOTICE
OWNERS Update OWNERS for BT java code, and remove obsolete OWNER from the top level. 2024-05-24 23:03:13 +00:00
OWNERS_automotive Update automotive owners 2024-03-20 22:47:01 +00:00
OWNERS_build Remove obsolete owner 2024-07-18 11:54:57 -07:00
OWNERS_chromeos Update OWNERS_chromeos 2024-08-07 17:14:07 +08:00
OWNERS_content add content profile owners 2024-05-31 17:10:42 +00:00
OWNERS_cs Demo app for the channel sounding test. 2024-05-10 19:38:06 +00:00
OWNERS_hearingaid Remove obsolete owner 2024-07-18 11:54:57 -07:00
OWNERS_leaudio Add new owner to le audio ownership and update ownership for LE audio files 2024-01-02 19:18:45 +00:00
PREUPLOAD.cfg Merge "Put back checkstyle to include more than format" into main 2024-06-07 07:56:47 +00:00
README.md system: fmtlib logger implementation 2024-02-06 00:59:45 +00:00
rustfmt.toml
TEST_MAPPING run bluetooth_test_gd_unit for system change only 2024-07-30 16:50:37 -07:00

Fluoride Bluetooth stack

Building and running on AOSP

Just build AOSP - Fluoride is there by default.

Building and running on Linux

Instructions for a Debian based distribution:

  • Debian Bullseye or newer
  • Ubuntu 20.10 or newer
  • Clang-11 or Clang-12
  • Flex 2.6.x
  • Bison 3.x.x (tested with 3.0.x, 3.2.x and 3.7.x)

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 libfmt-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 \
  libgtest-dev libgmock-dev libabsl-dev

You will also need a recent-ish version of Rust and Cargo. Please follow the instructions on Rustup to install a recent version.

Download source

mkdir ~/fluoride
cd ~/fluoride
git clone https://android.googlesource.com/platform/packages/modules/Bluetooth

Using --run-bootstrap on build.py

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.

Build dependencies

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.

  • libchrome
  • modp_b64

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

Rust dependencies

Note: Handled by --run-bootstrap option.

Run the following to install Rust dependencies:

cargo install cxxbridge-cmd

Stage your build environment

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

Build

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):

  • prepare - Generate the GN rules
  • tools - Generate host tools
  • rust - Build the rust portion of the build
  • main - Build all the C/C++ code
  • test - Build all targets and run the tests
  • clean - Clean the output directory

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).

Run

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