mirror of
https://github.com/bluekitchen/btstack.git
synced 2025-01-06 07:00:59 +00:00
100 lines
6.3 KiB
Markdown
100 lines
6.3 KiB
Markdown
# Welcome to BTstack
|
|
|
|
BTstack is [BlueKitchen's](http://bluekitchen-gmbh.com) implementation of the official Bluetooth stack.
|
|
It is well suited for small, resource-constraint devices
|
|
such as 8 or 16 bit embedded systems as it is highly configurable and comes with an ultra small memory footprint.
|
|
A minimal configuration for an SPP server on a MSP430 can run in 32 kB FLASH and only 4 kB of RAM.
|
|
|
|
It connects to the Bluetooth modules via a different Bluetooth HCI transport layers (e.g., HCI H4 UART and
|
|
H5 the "Tree-Wire" protocol, HCI H2 USB). Various platforms can be easily targeted by providing the necessary
|
|
UART, CPU, and CLOCK implementations.
|
|
|
|
On smaller embedded systems, a minimal run loop implementation allows to use BTstack without a Real Time OS (RTOS).
|
|
If a RTOS is already provided, BTstack can be integrated and run as a single thread.
|
|
|
|
On larger systems, BTstack provides a daemon that connects to a Bluetooth module.
|
|
Multiple applications can communicate with this daemon over different inter-process communication methods.
|
|
|
|
BTstack supports both, the Central and the Peripheral Role of Bluetooth 4.2 Low Energy specification.
|
|
It can be configures as both a single mode or a dual mode stack.
|
|
|
|
BTstack is free for non-commercial use. For commercial use, <a href="mailto:contact@bluekitchen-gmbh.com">tell us</a>
|
|
a bit about your project to get a quote.
|
|
It has been qualified with the the Bluetooth SIG for GAP, IOP, HFP, HSP, SPP, PAN profiles and
|
|
GATT, SM of the Bluetooth 4.2 LE Central and Peripheral roles (QD ID 25340).
|
|
|
|
## Documentation
|
|
- [HTML](http://bluekitchen-gmbh.com/btstack/v1.0)
|
|
- [PDF](http://bluekitchen-gmbh.com/btstack_v1.0.pdf)
|
|
|
|
## Supported Protocols
|
|
* L2CAP
|
|
* RFCOMM
|
|
* SDP
|
|
* BNEP
|
|
* ATT
|
|
* SM
|
|
|
|
|
|
## Supported Profiles
|
|
* GAP
|
|
* IOP
|
|
* HFP
|
|
* HSP
|
|
* SPP
|
|
* PAN
|
|
* GATT
|
|
|
|
Coming next: HID, HOGP, A2DP, and more.
|
|
|
|
## Evaluation Platforms
|
|
|
|
#### Embedded Platforms:
|
|
Status | Platform
|
|
-------------- | ------
|
|
![buildstatus](http://buildbot.bluekitchen-gmbh.com/btstack/badge.png?builder=port-ez430-rf2560-develop) | [EZ430-RF256x Bluetooth Evaluation Tool for MSP430](http://www.ti.com/tool/ez430-rf256x)
|
|
![buildstatus](http://buildbot.bluekitchen-gmbh.com/btstack/badge.png?builder=port-msp-exp430f5438-cc2564b-develop) | [MSP430F5438 Experimenter Board for MSP430](http://www.ti.com/tool/msp-exp430f5438) with [Bluetooth CC2564 Module Evaluation Board](http://www.ti.com/tool/cc2564modnem)
|
|
![buildstatus](http://buildbot.bluekitchen-gmbh.com/btstack/badge.png?builder=port-msp430f5229lp-cc2564b-develop) | [MSP-EXP430F5529LP LaunchPad](http://www.ti.com/ww/en/launchpad/launchpads-msp430-msp-exp430f5529lp.html#tabs) with [Bluetooth CC2564 Module Evaluation Board](http://www.ti.com/tool/cc2564modnem) and [EM Adapter BoosterPack](http://www.ti.com/tool/boost-ccemadapter) with additional 32768Hz quartz oscillator
|
|
![buildstatus](http://buildbot.bluekitchen-gmbh.com/btstack/badge.png?builder=port-stm32-f103rb-nucleo-develop) | [STM32 Nucleo development board NUCLEO-F103RB](http://www.st.com/web/catalog/tools/FM116/SC959/SS1532/LN1847/PF259875) with [Bluetooth CC2564 Module Evaluation Board](http://www.ti.com/tool/cc2564modnem) and [EM Adapter BoosterPack](http://www.ti.com/tool/boost-ccemadapter) with additional 32768Hz quartz oscillator
|
|
![buildstatus](http://buildbot.bluekitchen-gmbh.com/btstack/badge.png?builder=port-pic32-harmony-develop) | [Microchip's PIC32 Bluetooth Audio Development Kit](http://www.microchip.com/Developmenttools/ProductDetails.aspx?PartNO=DV320032)
|
|
![buildstatus](http://buildbot.bluekitchen-gmbh.com/btstack/badge.png?builder=port-wiced-develop) | [RedBear Duo](https://github.com/redbear/WICED-SDK) with Broadcom BCM43438 A1
|
|
|
|
|
|
#### Other Platforms:
|
|
Status | Platform
|
|
-------------- | ------
|
|
![buildstatus](http://buildbot.bluekitchen-gmbh.com/btstack/badge.png?builder=port-posix-h4-develop)| posix: Unix-based system talking to Bluetooth module via serial port
|
|
![buildstatus](http://buildbot.bluekitchen-gmbh.com/btstack/badge.png?builder=port-libusb-develop)| libusb: Unix-based system talking via USB Bluetooth dongle
|
|
![buildstatus](http://buildbot.bluekitchen-gmbh.com/btstack/badge.png?builder=port-daemon-develop)| daemon: TCP and Unix domain named socket client-server architecture supporting multiple clients
|
|
![buildstatus](http://buildbot.bluekitchen-gmbh.com/btstack/badge.png?builder=java-develop)| java: Java wrapper for daemon
|
|
![buildstatus](http://buildbot.bluekitchen-gmbh.com/btstack/badge.png?builder=port-ios-develop)| iOS: daemon for iOS jailbreak devices, C client-server API
|
|
![buildstatus](http://buildbot.bluekitchen-gmbh.com/btstack/badge.png?builder=port-mtk-develop)| mtk: daemon for rooted Android devices, based on Mediatek MT65xx processor, Java and C client-server API
|
|
![buildstatus](http://buildbot.bluekitchen-gmbh.com/btstack/badge.png?builder=port-wiced-develop) | wiced: Broadcom platforms that support the WICED SDK
|
|
|
|
## Supported Chipsets
|
|
Chipsets | Status
|
|
-------------- | ------
|
|
TI CC256x, WL183x | complete incl. eHCIll support and SCO-over-HCI (chipset/cc256x)
|
|
CSR 8x10, 8x11 | H4 only (chipset-csr), SCO-over-HCI missing (chipset/csr)
|
|
STM STLC2500D | working, no support for custom deep sleep management (chipset/stlc2500d)
|
|
TC35661 | working, BLE patches missing (chipset/tc3566x)
|
|
EM 9301 (LE-only) | working, used on Arduino Shield (chipset/em9301)
|
|
CSR USB Dongles | complete, incl. SCO-over-HCI
|
|
Broadcom USB Dongles | complete, SCO-over-HCI not missing
|
|
Broadcom BCM43438 | complete. UART baudrate limited to 3 mbps, SCO-over-HCI not missing
|
|
|
|
## Source Tree Overview
|
|
Path | Description
|
|
--------------------|---------------
|
|
chipset | Support for individual Bluetooth chipsets
|
|
doc | Sources for BTstack documentation
|
|
example | Example applications available for all ports
|
|
platform | Support for special OSs and/or MCU architectures
|
|
port | Complete port for a MCU + Chipset combinations
|
|
src | Bluetooth stack implementation
|
|
test | Unit and PTS tests
|
|
tool | Helper tools for BTstack
|
|
|
|
## Discussion and Community Support
|
|
[BTstack Google Group](http://groups.google.com/group/btstack-dev)
|