1# Welcome to BTstack 2 3BTstack is [BlueKitchen's](http://bluekitchen-gmbh.com) implementation of the official Bluetooth stack. 4It is well suited for small, resource-constraint devices 5such as 8 or 16 bit embedded systems as it is highly configurable and comes with an ultra small memory footprint. 6A minimal configuration for an SPP server on a MSP430 can run in 32 kB FLASH and only 4 kB of RAM. 7 8It connects to the Bluetooth modules via different Bluetooth HCI transport layers (e.g., HCI H4 UART and 9H5 the "Tree-Wire" protocol). The various platforms can be easily targeted by providing the necessary 10UART, CPU, and CLOCK implementations. 11 12On smaller embedded systems, a minimal run loop implementation allows to use BTstack without a Real Time OS (RTOS). 13If a RTOS is already provided, BTstack can be integrated and run as a single thread. 14 15On larger systems, BTstack provides a daemon that connects to a Bluetooth module. 16Multiple applications can communicate with this daemon over different inter-process communication methods. 17 18BTstack supports both, the Central and the Peripheral Role of Bluetooth 4.0 Low Energy specification. 19It can be configures as both a single mode or a dual mode stack. 20 21BTstack is free for non-commercial use. For commercial use, <a href="mailto:[email protected]">tell us</a> 22a bit about your project to get a quote. 23The Serial Port Profile (SPP) and the Bluetooth 4.0 Low Energy Peripheral role (LE Peripheral) have been qualified with 24the Bluetooth SIG (QD ID 54558). This summer, we plan to qualify for Bluetooth Core 4.2, 25together with LE Central, PAN/BNEP and HSP. 26 27## Documentation 28For starters, check the BTstack Manual 29- [HTML](http://bluekitchen-gmbh.com/btstack/) 30- [PDF](http://bluekitchen-gmbh.com/btstack.pdf) 31 32## Supported Protocols 33* L2CAP 34* RFCOMM 35* SDP 36* BNEP 37* ATT 38* SM 39 40 41## Supported Profiles 42* GAP 43* IOP 44* SPP 45* PAN 46* GATT 47 48Coming soon: HSP, HFP, and more. 49 50## Evaluation Platforms 51 52#### Embedded Platforms: 53Status | Platform 54-------------- | ------ 55 | [EZ430-RF256x Bluetooth Evaluation Tool for MSP430](http://www.ti.com/tool/ez430-rf256x) 56 | [MSP430F5438 Experimenter Board for MSP430](http://www.ti.com/tool/msp-exp430f5438) with [Bluetooth CC2564 Module Evaluation Board](http://www.ti.com/tool/cc2564modnem) 57 | [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 58 | [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 59 | [Microchip's PIC32 Bluetooth Audio Development Kit](http://www.microchip.com/Developmenttools/ProductDetails.aspx?PartNO=DV320032) 60 | [RedBear Duo](https://github.com/redbear/WICED-SDK) with Broadcom BCM43438 A1 61 62 63#### Other Platforms: 64Status | Platform 65-------------- | ------ 66| posix: Unix-based system talking to Bluetooth module via serial port 67| libusb: Unix-based system talking via USB Bluetooth dongle 68| daemon: TCP and Unix domain named socket client-server architecture supporting multiple clients 69| java: Java wrapper for daemon 70| iOS: daemon for iOS jailbreak devices, C client-server API 71| mtk: daemon for rooted Android devices, based on Mediatek MT65xx processor, Java and C client-server API 72 |wiced: Broadcom platforms that support the WICED SDK 73 74## Supported Chipsets 75Chipsets | Status 76-------------- | ------ 77TI CC256x, WL183x | complete incl. eHCIll support (chipset-cc256x) 78CSR 8811, 8510 | H4 only (chipset-csr) 79STM STLC2500D | working, no support for custom deep sleep management (chipset-stlc2500d) 80EM 9301 | used on Arduino Shield (chipset-em9301) 81CSR USB Dongles | complete 82Broadcom USB Dongles | complete 83Broadcom BCM43438 | complete. UART baudrate limited to 3 mbps 84 85## Source Tree Overview 86Path | Description 87--------------------|--------------- 88binding | Language bindings for BTstack, e.g. Java client/server 89chipset | Support for individual Bluetooth chipsets 90doc | Sources for BTstack documentation 91example | Example applications available for different ports 92platform | Support for special OSs and/or MCU architectures 93port | Complete port for a MCU + Chipset combinations 94src | Bluetooth stack implementation 95test | Unit and PTS tests 96tool | Helper tools for BTstack 97 98## Discussion and Community Support 99[BTstack Google Group](http://groups.google.com/group/btstack-dev) 100