commit | 286fa983628a96d6275f4afcb38affd39b56f01c | [log] [tgz] |
---|---|---|
author | Venkata Jagadeesh Garaga <quic_vgaraga@quicinc.com> | Mon Jul 20 15:22:47 2020 +0530 |
committer | Chris Manton <cmanton@google.com> | Wed Apr 14 05:08:47 2021 +0000 |
tree | fa4b2ac2309cc601fb08e68092f39f5bec963c4d | |
parent | f7f31e4b9b8304c0b1809cf373ad12d81b788d2f [diff] |
Fix Stack-buffer-over-flow while accessing remote device name Issue: During authentication timeout, if remote device name is invalid. A two byte placeholder remote name is passed to callback to intimate authentication failure. Callback is trying to access 248 bytes of remote device name from the passed remote name which is of two bytes. Mismatch of length between passed remote name and accessed remote device name leads to buffer-over-flow Fix: Replaced remote device name to an array of 248 bytes from two bytes array. Test:Basic bluetooth pairing Test:gd/cert/run Bug: 161663998 Tag: #stability Sponsor:cmanton@ Change-Id: I0f45a0cf4b1a12c874c2c1fe4dc165c76dc5ae90
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 all required packages. Otherwise, you can use the following apt-get list:
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 lib32z-dev libncurses5 \ libgl1-mesa-dev libxml2-utils xsltproc unzip liblz4-tool libssl-dev \ libc++-dev libevent-dev \ flatbuffers-compiler libflatbuffers1 \ openssl openssl-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/system
Install dependencies (require sudo access). This adds some Ubuntu dependencies and also installs GN (which is the build tool we're using).
cd ~/fluoride/bt build/install_deps.sh
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.
TODO(abhishekpandit) - Provide a pre-packaged option for these or proper build instructions from source.
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.
./build.py --output ${OUTPUT_DIR} --platform-dir ${STAGING_DIR} --clang
This will build all targets to the output directory you've given. 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.
By default on Linux, we statically link libbluetooth so you can just run the binary directly:
cd ~/fluoride/bt/out/Default ./bluetoothtbd -create-ipc-socket=fluoride