2015-03-27 16:21:51 +01:00
|
|
|
# Welcome to BTstack
|
|
|
|
|
2015-04-10 10:48:53 +02:00
|
|
|
BTstack is [BlueKitchen's](http://bluekitchen-gmbh.com) implementation of the official Bluetooth stack.
|
|
|
|
It is well suited for small, resource-constraint devices
|
2015-03-27 16:21:51 +01:00
|
|
|
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 different Bluetooth HCI transport layers (e.g., HCI H4 UART and
|
|
|
|
H5 the "Tree-Wire" protocol). The 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.0 Low Energy specification.
|
|
|
|
It can be configures as both a single mode or a dual mode stack.
|
|
|
|
|
2015-04-10 11:33:16 +02:00
|
|
|
For starters, download the [BTstack Manual](https://github.com/bluekitchen/btstack/raw/master/docs/manual/btstack-manual.pdf)
|
2015-03-27 16:21:51 +01:00
|
|
|
and look for an Architecture overview and the Getting started example for MSP430.
|
|
|
|
|
2015-04-10 12:08:48 +02:00
|
|
|
BTstack is free for non-commercial use. For commercial use, <a href="mailto:contact@bluekitchen-gmbh.com">tell us</a>
|
2015-03-27 16:21:51 +01:00
|
|
|
a bit about your project to get a quote.
|
|
|
|
The Serial Port Profile (SPP) and the Bluetooth 4.0 Low Energy Peripheral role (LE Peripheral) have been qualified with
|
|
|
|
the Bluetooth SIG (QD ID 54558). This summer, we plan to qualify for Bluetooth Core 4.2,
|
|
|
|
together with LE Central, PAN/BNEP and HSP.
|
|
|
|
|
|
|
|
## Supported Protocols
|
2015-04-10 10:48:53 +02:00
|
|
|
* L2CAP
|
|
|
|
* RFCOMM
|
|
|
|
* SDP
|
|
|
|
* BNEP
|
|
|
|
* ATT
|
|
|
|
* SM
|
|
|
|
|
2015-03-27 16:21:51 +01:00
|
|
|
|
|
|
|
## Supported Profiles
|
2015-04-10 10:48:53 +02:00
|
|
|
* GAP
|
|
|
|
* IOP
|
|
|
|
* SPP
|
|
|
|
* PAN
|
|
|
|
* GATT
|
|
|
|
|
|
|
|
Coming soon: HSP, HFP, and more.
|
|
|
|
|
2015-04-27 18:37:44 +02:00
|
|
|
## Evaluation Platforms
|
2015-04-10 11:33:16 +02:00
|
|
|
|
|
|
|
#### Embedded Platforms:
|
2015-04-10 12:08:48 +02:00
|
|
|
* [EZ430-RF256x Bluetooth Evaluation Tool for MSP430](http://www.ti.com/tool/ez430-rf256x)
|
|
|
|
* [MSP430F5438 Experimenter Board for MSP430](http://www.ti.com/tool/msp-exp430f5438) with [Bluetooth CC2564 Module Evaluation Board](http://www.ti.com/tool/cc2564modnem)
|
|
|
|
* [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
|
2015-04-23 12:02:11 +02:00
|
|
|
* [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
|
2015-04-10 12:08:48 +02:00
|
|
|
* [Microchip's PIC32 Bluetooth Audio Development Kit](http://www.microchip.com/Developmenttools/ProductDetails.aspx?PartNO=DV320032)
|
2015-04-10 11:33:16 +02:00
|
|
|
|
|
|
|
#### Other Platforms:
|
2015-04-10 12:08:48 +02:00
|
|
|
* posix: Unix-based system talking to Bluetooth module via serial port
|
|
|
|
* libusb: Unix-based system talking via USB Bluetooth dongle
|
|
|
|
* daemon: TCP and Unix domain named socket client-server architecture supporting multiple clients
|
|
|
|
* java: Java wrapper for daemon
|
|
|
|
* iOS: daemon for iOS jailbreak devices, C client-server API
|
|
|
|
* mtk: daemon for rooted Android devices, based on Mediatek MT65xx processor, Java and C client-server API
|
2015-04-10 11:33:16 +02:00
|
|
|
|
2015-04-10 10:48:53 +02:00
|
|
|
|
|
|
|
## Supported Chipsets
|
|
|
|
Chipsets | Status
|
|
|
|
-------------- | ------
|
2015-04-16 17:15:07 +02:00
|
|
|
TI CC256x, WL183x | complete incl. eHCIll support (chipset-cc256x)
|
|
|
|
CSR 8811, 8510 | H4 only (chipset-csr)
|
2015-04-17 16:27:29 +02:00
|
|
|
STM STLC2500D | working, no support for custom deep sleep management (chipset-stlc2500d)
|
2015-04-16 17:15:07 +02:00
|
|
|
EM 9301 | experimental use on Arduino Shield (chipset-em9301)
|
2015-04-10 10:48:53 +02:00
|
|
|
CSR USB Dongles | complete
|
|
|
|
Broadcom USB Dongles | complete
|
|
|
|
|
2015-04-17 16:27:29 +02:00
|
|
|
## Discussion and Community Support
|
|
|
|
[BTstack Google Group](http://groups.google.com/group/btstack-dev)
|