fork of the tinygo bluetooth library with some bad ideas implemented
转到文件
Ayke van Laethem 15b3e8e3e2
nrf: add GATT client
This is not entirely complete (some errors are not handled properly) but
it's a start.
2020-06-28 00:21:40 +02:00
.circleci Move to github.com/tinygo-org/bluetooth 2020-05-31 16:45:26 +02:00
examples nrf: add GATT client 2020-06-28 00:21:40 +02:00
rawterm examples/nusserver: refactor terminal handling 2020-06-11 15:46:08 +02:00
s110_nrf51_8.0.0 Add S110 version 8.0.0 SoftDevice for nrf51822 2020-05-31 15:40:57 +02:00
s132_nrf52_6.1.1 Initial commit 2019-11-08 10:58:02 +01:00
s140_nrf52_7.0.1 Port current codebase to S140 softdevice 2020-03-06 14:24:50 +01:00
winbt Add initial Windows support 2020-05-30 21:51:27 +02:00
.gitattributes Initial commit 2019-11-08 10:58:02 +01:00
.gitignore Add smoke tests that run in CI 2020-05-24 19:19:37 +02:00
LICENSE Initial commit 2019-11-08 10:58:02 +01:00
Makefile nrf: add GATT client 2020-06-28 00:21:40 +02:00
README.md nrf: add GATT client 2020-06-28 00:21:40 +02:00
adapter.go all: replace GAP events with auto-restarting advertisements 2020-06-01 23:29:31 +02:00
adapter_linux.go linux: include IsRandom bit in Address type 2020-06-11 15:53:36 +02:00
adapter_nrf51.go all: add support for sending notifications 2020-06-03 19:42:21 +02:00
adapter_nrf528xx.go nrf: add GATT client 2020-06-28 00:21:40 +02:00
adapter_s110.c nrf: add GATT client 2020-06-28 00:21:40 +02:00
adapter_s110.go Add S110 version 8.0.0 SoftDevice for nrf51822 2020-05-31 15:40:57 +02:00
adapter_s132.c nrf: add GATT client 2020-06-28 00:21:40 +02:00
adapter_s132.go softdevice: make code more flexible for other SoftDevices 2020-03-06 13:46:42 +01:00
adapter_s140.c nrf: add GATT client 2020-06-28 00:21:40 +02:00
adapter_s140.go Port current codebase to S140 softdevice 2020-03-06 14:24:50 +01:00
adapter_sd.go nrf: add GATT client 2020-06-28 00:21:40 +02:00
adapter_windows.go all: fix bug that caused a copied DefaultAdapter 2020-06-03 01:13:46 +02:00
error_sd.go softdevice: make code more flexible for other SoftDevices 2020-03-06 13:46:42 +01:00
gap.go nrf: add GATT client 2020-06-28 00:21:40 +02:00
gap_linux.go linux: include IsRandom bit in Address type 2020-06-11 15:53:36 +02:00
gap_nrf51.go all: change advertisement interval type 2020-06-06 20:47:05 +02:00
gap_nrf528xx.go nrf: add GATT client 2020-06-28 00:21:40 +02:00
gap_windows.go all: distinguish between public and random addresses 2020-06-04 14:12:14 +02:00
gattc_sd.go nrf: add GATT client 2020-06-28 00:21:40 +02:00
gatts.go all: add support for sending notifications 2020-06-03 19:42:21 +02:00
gatts_linux.go all: add support for sending notifications 2020-06-03 19:42:21 +02:00
gatts_other.go all: add support for sending notifications 2020-06-03 19:42:21 +02:00
gatts_sd.go nrf: add GATT client 2020-06-28 00:21:40 +02:00
go.mod all: add support for sending notifications 2020-06-03 19:42:21 +02:00
go.sum all: add support for sending notifications 2020-06-03 19:42:21 +02:00
mac.go all: support HasServiceUUID on advertisement payloads 2020-06-04 19:23:25 +02:00
uuid.go all: support HasServiceUUID on advertisement payloads 2020-06-04 19:23:25 +02:00
uuid_sd.go softdevice: make code more flexible for other SoftDevices 2020-03-06 13:46:42 +01:00
uuid_test.go linux: add support for services 2019-11-16 19:11:59 +00:00

Go Bluetooth

CircleCI GoDoc

This package attempts to build a cross-platform Bluetooth Low Energy module for Go. It currently supports the following systems:

Windows Linux Nordic chips
API used WinRT BlueZ (over D-Bus) SoftDevice
Scanning ✔️ ✔️ ✔️
Connect to peripheral ✔️
Write peripheral characteristics ✔️
Receive notifications ✔️
Advertisement ✔️ ✔️
Local services ✔️ ✔️
Local characteristics ✔️ ✔️
Send notifications ✔️ ✔️

Baremetal support

As you can see above, there is support for some chips from Nordic Semiconductors. At the moment the following chips are supported:

  • The nRF52832 with the S132 SoftDevice (version 6).
  • The nRF52840 with the S140 SoftDevice (version 7).
  • The nRF51822 with the S110 SoftDevice (version 8). This SoftDevice does not support all features (e.g. scanning).

These chips are supported through TinyGo.

The SoftDevice is a binary blob that implements the BLE stack. There are other (open source) BLE stacks, but the SoftDevices are pretty solid and have all the qualifications you might need. Other BLE stacks might be added in the future.

Flashing the SoftDevice

Flashing the SoftDevice can be tricky. If you have nrfjprog installed, you can erase the flash and flash the new BLE firmware using the following commands. Replace the path to the hex file with the correct SoftDevice, for example s132_nrf52_6.1.1/s132_nrf52_6.1.1_softdevice.hex for S132 version 6.

nrfjprog -f nrf52 --eraseall
nrfjprog -f nrf52 --program path/to/softdevice.hex

After that, don't reset the board but instead flash a new program to it. For example, you can flash the Heart Rate Sensor example using tinygo (modify the -target flag as needed for your board):

tinygo flash -target=pca10040-s132v6 ./examples/heartrate

Flashing will normally reset the board.

For boards that use the CMSIS-DAP interface (such as the BBC micro:bit), this works a bit different. Flashing the SoftDevice is done by simply copying the .hex file to the device, for example (on Linux):

cp path/to/softdevice.hex /media/yourusername/MICROBIT/

Flashing will then need to be done a bit differently, using the CMSIS-DAP interface instead of the mass-storage interface normally used by TinyGo:

tinygo flash -target=microbit-s110v8 -programmer=cmsis-dap ./examples/heartrate

API stability

The API is not stable! Because many features are not yet implemented and some platforms (e.g. MacOS) are not yet supported, it's hard to say what a good API will be. Therefore, if you want stability you should pick a particular git commit and use that. Go modules can be useful for this purpose.

Some things that will probably change:

  • Add options to the Scan method, for example to filter on UUID.
  • Extra options to the Enable function, to request particular features (such as the number of peripheral connections supported).

This package will probably remain unstable until the following has been implemented:

  • Scan filters. For example, to filter on service UUID.
  • Bonding and private addresses.
  • Usable support on at least two desktop operating systems.
  • Maybe some Bluetooth Classic support, such as A2DP.

License

This project is licensed under the BSD 3-clause license, see the LICENSE file for details.

The SoftDevices from Nordic are licensed under a different license, check the license file in the SoftDevice source directory.