commit | 2dea9ee94cb226e1d4512605ecd3eb6c10a23469 | [log] [tgz] |
---|---|---|
author | David Duarte <licorne@google.com> | Wed May 17 19:18:56 2023 +0000 |
committer | David Duarte <licorne@google.com> | Wed May 17 19:22:07 2023 +0000 |
tree | d725e96e470750305c0641249c69b100b9d5b697 | |
parent | a1da29d17fcc13ae915ced2050d8ff2ce6299f20 [diff] | |
parent | c7b8ceada4634a80871cbf4eda77fe19568c697d [diff] |
Merge udc_daily_340790070 into udc-dev Bug: 220105065 Bug: 236321914 Bug: 262336159 Bug: 264988156 Bug: 270652267 Bug: 273891623 Bug: 274741724 Bug: 274876266 Bug: 274945531 Bug: 277019596 Bug: 277241116 Bug: 277308810 Bug: 277337187 Bug: 277388611 Bug: 277977567 Bug: 278014948 Bug: 278132584 Bug: 278960455 Bug: 279365755 Bug: 279366294 Bug: 279566653 Bug: 279760920 Bug: 279936776 Bug: 279990836 Bug: 280227328 Bug: 260230151 Bug: 260079196 Bug: 269067986 Bug: 272783039 Bug: 273966636 Bug: 274617156 Bug: 277241116 Bug: 277557618 Bug: 278505039 Bug: 279233387 Bug: 279990836 Bug: 258816625 Bug: 260006855 Bug: 266433017 Bug: 267975031 Bug: 269253349 Bug: 270569106 Bug: 277578150 Bug: 279875784 Bug: 280813386 Bug: 281154401 Bug: 260726311 Bug: 262199042 Bug: 265582589 Bug: 268146835 Bug: 270529845 Bug: 273958309 Bug: 274493609 Bug: 274945531 Bug: 275551881 Bug: 278198192 Bug: 278514112 Bug: 278761210 Bug: 278915729 Bug: 279156642 Bug: 279355025 Bug: 279566660 Bug: 279875784 Bug: 279881847 Bug: 280390678 Bug: 280898961 Bug: 281065893 Bug: 281119807 Bug: 281346084 Ignore-AOSP-First: Merge changes from AOSP Change-Id: I01f53f69fbc645aed54c1d2522bcdceccba27cbe
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 \ 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.
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
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