btstack/doc/manual/docs/integration.md
2017-02-20 15:22:57 +01:00

74 lines
3.5 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

While the run loop provided by BTstack is sufficient for new designs,
BTstack is often used with or added to existing projects. In this case,
the run loop, data sources, and timers may need to be adapted. The
following two sections provides a guideline for single and
multi-threaded environments.
To simplify the discussion, well consider an application split into
“Main ”, “Communication Logic”, and “BTstack”. The Communication Logic
contains the packet handler (PH) that handles all asynchronous events
and data packets from BTstack. The Main Application makes use of the
Communication Logic for its Bluetooth communication.
## Adapting BTstack for Single-Threaded Environments {#sec:singlethreadingIntegration}
In a single-threaded environment, all application components run on the
same (single) thread and use direct function calls as shown in
Figure {@fig:BTstackSingle}.
![BTstack in single-threaded environment.](picts/singlethreading-btstack.png) {#fig:BTstackSingle}
BTstack provides a basic run loop that supports the concept of data
sources and timers, which can be registered centrally. This works well
when working with a small MCU and without an operating system. To adapt
to a basic operating system or a different scheduler, BTstacks run loop
can be implemented based on the functions and mechanism of the existing
system.
Currently, we have two examples for this:
- *btstack_run_loop_posix.c* is an implementation for POSIX compliant
systems. The data sources are modeled as file descriptors and
managed in a linked list. Then, the *select* function is used to wait
for the next file descriptor to become ready or timer to expire.
- *btstack_run_loop_cocoa.c* is an implementation for the CoreFoundation
Framework used in OS X and iOS. All run loop functions are
implemented in terms of CoreFoundation calls, data sources and
timers are modeled as CFSockets and CFRunLoopTimer respectively.
- *btstack_run_loop_windows* is an implementation for Windows environment.
The data sources are modeled with Event objects and managed in a linked list.
Then, the *WaitForMultipleObjects* is used to wait for the next Event to
becomre ready or timer to expire.
## Adapting BTstack for Multi-Threaded Environments {#sec:multithreadingIntegration}
The basic execution model of BTstack is a general while loop. Aside from
interrupt-driven UART and timers, everything happens in sequence. When
using BTstack in a multi-threaded environment, this assumption has to
stay valid - at least with respect to BTstack. For this, there are two
common options:
- The Communication Logic is implemented on a dedicated BTstack
thread, and the Main Application communicates with the BTstack
thread via application-specific messages over an Interprocess
Communication (IPC) as depicted in Figure {@fig:MTMonolithic}.
This option results in less code and quick adaption.
![BTstack in multi-threaded environment - monolithic solution.](picts/multithreading-monolithic.png) {#fig:MTMonolithic}
- BTstack must be extended to run standalone, i.e, as a Daemon, on a
dedicated thread and the Main Application controls this daemon via
BTstack extended HCI command over IPC - this is used for the
non-embedded version of BTstack e.g., on the iPhone and it is depicted
in Figure {@fig:MTDaemon}. This option requires more code but provides
more flexibility.
![BTstack in multi-threaded environment - solution with daemon.](picts/multithreading-btdaemon.png) {#fig:MTDaemon}