xref: /btstack/port/archive/wiced-h5/README.md (revision 1182cb7ea894b41819446c5518b6753290421863)
1*1182cb7eSMatthias Ringwald# BTstack port for WICED platform using H5 transport and Broadcom/Cypress Bluetooth chipsets.
2*1182cb7eSMatthias Ringwald
3*1182cb7eSMatthias Ringwald# BTstack port for WICED platform
4*1182cb7eSMatthias Ringwald
5*1182cb7eSMatthias RingwaldTested with:
6*1182cb7eSMatthias Ringwald- WICED SDK 3.4-6.2.1
7*1182cb7eSMatthias Ringwald- [RedBear Duo](https://redbear.cc/product/wifi-ble/redbear-duo.html): Please install [RedBear WICED Add-On](https://github.com/redbear/WICED-SDK)
8*1182cb7eSMatthias Ringwald- [Inventek Systems ISM4334x](https://www.inventeksys.com/products-page/wifi-modules/serial-wifi/ism43341-m4g-l44-cu-embedded-serial-to-wifi-ble-nfc-module/) - Please contact Inventek Systems for WICED platform files
9*1182cb7eSMatthias Ringwald- [Inventek Systems ISM4343](https://www.inventeksys.com/wifi/wifi-modules/ism4343-wmb-l151/) (BCM43438 A1) - Please contact Inventek Systems for WICED platform files
10*1182cb7eSMatthias Ringwald
11*1182cb7eSMatthias RingwaldTo integrate BTstack into the WICED SDK, please move the BTstack project into WICED-SDK-6.2.1/libraries.
12*1182cb7eSMatthias Ringwald
13*1182cb7eSMatthias RingwaldThen create projects for BTstack examples in WICED/apps/btstack by running:
14*1182cb7eSMatthias Ringwald
15*1182cb7eSMatthias Ringwald	./create_examples.py
16*1182cb7eSMatthias Ringwald
17*1182cb7eSMatthias RingwaldNow, the BTstack examples can be build from the WICED root in the same way as other examples, e.g.:
18*1182cb7eSMatthias Ringwald
19*1182cb7eSMatthias Ringwald	./make btstack.spp_and_le_counter-RB_DUO
20*1182cb7eSMatthias Ringwald
21*1182cb7eSMatthias Ringwaldto build the SPP-and-LE-Counter example for the RedBear Duo (or use ISM43340_M4G_L44 / ISM4343_WBM_L151 for the Inventek Systems devices).
22*1182cb7eSMatthias Ringwald
23*1182cb7eSMatthias RingwaldSee WICED documentation about how to upload the firmware.
24*1182cb7eSMatthias Ringwald
25*1182cb7eSMatthias RingwaldIt should work with all WICED platforms that contain a Broadcom Bluetooth chipset.
26*1182cb7eSMatthias Ringwald
27*1182cb7eSMatthias RingwaldThe maximal baud rate is currenty limited to 1 mbps.
28*1182cb7eSMatthias Ringwald
29*1182cb7eSMatthias RingwaldThe port uses the generated WIFI address plus 1 as Bluetooth MAC address.
30*1182cb7eSMatthias RingwaldIt persists the LE Device DB and Classic Link Keys via the DCT mechanism.
31*1182cb7eSMatthias Ringwald
32*1182cb7eSMatthias RingwaldAll examples that rovide a GATT Server use the GATT DB in the .gatt file. Therefore you need to run ./update_gatt_db.sh in the apps/btstack/$(EXAMPLE) folder after modifying the .gatt file.
33*1182cb7eSMatthias Ringwald
34*1182cb7eSMatthias Ringwald
35*1182cb7eSMatthias Ringwald## Additional notes on the H5 port
36*1182cb7eSMatthias Ringwald
37*1182cb7eSMatthias RingwaldIf the CTR/RTS hardware control lines of the Bluetooth Controller is connected to your MCU, we recommend using the wiced-h4 port instead.
38*1182cb7eSMatthias RingwaldIf they are not connected, H5 is required to provide a reliable connection including retransmissions in both directions.
39*1182cb7eSMatthias Ringwald
40*1182cb7eSMatthias RingwaldThere are a few oddities so far that had to be worked around in H5 mode:
41*1182cb7eSMatthias Ringwald
42*1182cb7eSMatthias Ringwald- It does not seem possible to upload the FW Mini Driver a.k.a. patchram a.k.a. init script via H5. BTstack uses btstack_chipset_bcm_download_firmware.c to upload the FW Mini Driver via a minimal H4 implementation, before starting up in H5 mode. BCM/CYP chipsets are able to switch to H5.
43*1182cb7eSMatthias Ringwald
44*1182cb7eSMatthias Ringwald- With the AP6212A on the RedBear Duo and the FW Mini Driver from WICED-SDK-3.5.2/libraries/drivers/bluetooth/firmware/43438A1/26MHz/bt_firmware_image.c, the HCI LE Encrypt command to perform an AES128 encryption hangs in H5 (but works in H4). See [Bug Report in Community Forum](https://community.cypress.com/thread/8424) As a work around, BTstack was configured to use a CPU implementation of AES128 (#define HAVE_AES128).
45*1182cb7eSMatthias Ringwald
46