Bluetooth: Central UART¶
The Central UART sample demonstrates how to use the Nordic UART Service (NUS) Client. It uses the NUS Client to send data back and forth between a UART connection and a Bluetooth LE connection, emulating a serial port over Bluetooth LE.
Overview¶
When connected, the sample forwards any data received on the RX pin of the UART 1 peripheral to the Bluetooth LE unit. On Nordic Semiconductor’s development kits, the UART 1 peripheral is typically gated through the SEGGER chip to a USB CDC virtual serial port.
Any data sent from the Bluetooth LE unit is sent out of the UART 1 peripheral’s TX pin.
Debugging¶
In this sample, a UART console is used to send and read data over the NUS Client. Debug messages are not displayed in the UART console, but are printed by the RTT logger instead.
If you want to view the debug messages, follow the procedure in Connecting via RTT.
Requirements¶
The sample supports the following development kits:
Hardware platforms |
PCA |
Board name |
Build target |
---|---|---|---|
PCA10095 |
|
||
PCA10056 |
|
||
PCA10040 |
|
||
PCA10010 |
|
||
PCA10100 |
|
The sample also requires another development kit running a compatible application (see Bluetooth: Peripheral UART).
Building and running¶
This sample can be found under samples/bluetooth/central_uart
in the nRF Connect SDK folder structure.
See Building and programming a sample application for information about how to build and program the application.
Testing¶
After programming the sample to your board, test it by performing the following steps:
Connect the board to the computer using a USB cable. The board is assigned a COM port (Windows) or ttyACM device (Linux), which is visible in the Device Manager.
Connect to the kit that runs this sample with a terminal emulator (for example, PuTTY). See How to connect with PuTTY for the required settings.
Optionally, connect the RTT console to display debug messages. See Debugging.
Reset the board.
Observe that the text “Starting NUS Client example” is printed on the COM listener running on the computer and the device starts scanning for Peripheral boards with NUS.
Program the Bluetooth: Peripheral UART sample to the second board. See the documentation for that sample for detailed instructions.
Observe that the boards connect. When service discovery is completed, the event logs are printed on the Central board’s terminal.
Now you can send data between the two boards. To do so, type some characters in the terminal of one of the boards and hit Enter. Observe that the data is displayed on the UART on the other board.
Disconnect the devices by, for example, pressing the Reset button on the Central board. Observe that the boards automatically reconnect and that it is again possible to send data between the two boards.
Dependencies¶
This sample uses the following nRF Connect SDK libraries:
In addition, it uses the following Zephyr libraries:
include/zephyr/types.h
boards/arm/nrf*/board.h
-
include/kernel.h
-
include/uart.h
-
include/bluetooth/bluetooth.h
include/bluetooth/gatt.h
include/bluetooth/hci.h
include/bluetooth/uuid.h