1# OpenThread POSIX app 2 3OpenThread supports running its core on POSIX and transmits radio frames through a radio transceiver. 4 5Currently most platforms in [examples/platforms](../../examples/platforms) support transceiver mode. 6 7The figure below shows the architecture of OpenThread running in transceiver mode. 8 9``` 10+-------------------------+ 11| MLE TMF UDP IP | 12| MeshForwarder 6LoWPAN | 13| _ _ _ _ _ _ _ _ _ _ _ _ | spinel +------------------+ 14| OpenThread Core | <----------------> | OpenThread Radio | 15+-------------------------+ UART|SPI +------------------+ 16 POSIX Chip 17``` 18 19## Build POSIX CLI 20 21```sh 22./script/cmake-build posix 23``` 24 25If built successfully, the binary should be found at: `build/posix/src/posix/ot-cli`. 26 27## Transceivers on different platforms 28 29### Simulation 30 31OpenThread provides an implementation on the simulation platform which enables running a simulated transceiver on the host. 32 33#### Build 34 35```sh 36# Only build RCP so that it goes faster 37./script/cmake-build simulation -DOT_APP_CLI=OFF -DOT_APP_NCP=OFF -DOT_FTD=OFF -DOT_MTD=OFF 38``` 39 40#### Run 41 42**NOTE** Assuming the build system is 64bit Linux, you can use the normal OpenThread CLI as described in the [command line document](../../src/cli/README.md). You can also perform radio diagnostics using the command [diag](../../src/core/diags/README.md). 43 44```sh 45./build/posix/src/posix/ot-cli 'spinel+hdlc+forkpty://build/simulation/examples/apps/ncp/ot-rcp?forkpty-arg=1' 46``` 47 48### Nordic Semiconductor nRF52840 49 50The nRF example platform driver can be found in the [ot-nrf528xx](https://github.com/openthread/ot-nrf528xx) repo. 51 52#### Build 53 54To build and program the device with RCP application, complete the following steps: 55 561. Clone the OpenThread nRF528xx platform repository into the current directory: 57 58 ```sh 59 git clone --recursive https://github.com/openthread/ot-nrf528xx.git 60 ``` 61 622. Enter the `ot-nrf528xx` directory: 63 64 ```sh 65 cd ot-nrf528xx 66 ``` 67 683. Install the OpenThread dependencies: 69 70 ```sh 71 ./script/bootstrap 72 ``` 73 744. Build the RCP example for the hardware platform and the transport of your choice: 75 76 a. nRF52840 Dongle (USB transport) 77 78 ```sh 79 rm -rf build 80 script/build nrf52840 USB_trans -DOT_BOOTLOADER=USB 81 ``` 82 83 b. For nRF52840 Development Kit 84 85 ```sh 86 rm -rf build 87 script/build nrf52840 UART_trans 88 ``` 89 90 This creates an RCP image at `build/bin/ot-rcp`. 91 925. Generate the HEX image: 93 94 ```sh 95 arm-none-eabi-objcopy -O ihex build/bin/ot-rcp build/bin/ot-rcp.hex 96 ``` 97 986. Depending on the hardware platform, complete the following steps to program the device: 99 100 a. nRF52840 Dongle (USB transport) 101 102 ```sh 103 # Install nRF Util: 104 python3 -m pip install -U nrfutil 105 106 # Generate the RCP firmware package: 107 nrfutil pkg generate --hw-version 52 --sd-req=0x00 \ 108 --application build/bin/ot-rcp.hex --application-version 1 build/bin/ot-rcp.zip 109 ``` 110 111 Connect the nRF52840 Dongle to the USB port and press the **RESET** button on the dongle to put it into the DFU mode. The LED on the dongle starts blinking red. 112 113 ```sh 114 # Install the RCP firmware package onto the dongle 115 nrfutil dfu usb-serial -pkg build/bin/ot-rcp.zip -p /dev/ttyACM0 116 ``` 117 118 b. nRF52840 Development Kit 119 120 ```sh 121 # Program the image using the nrfjprog utility. 122 nrfjprog -f nrf52 --chiperase --program build/bin/ot-rcp.hex --reset 123 ``` 124 125 Disable the Mass Storage feature on the device, so that it does not interfere with the core RCP functionalities: 126 127 ```sh 128 JLinkExe -device NRF52840_XXAA -if SWD -speed 4000 -autoconnect 1 129 J-Link>MSDDisable 130 Probe configured successfully. 131 J-Link>exit 132 ``` 133 134 Power-cycle the device to apply the changes. 135 136#### Run 137 138```sh 139./build/posix/src/posix/ot-cli 'spinel+hdlc+uart:///dev/ttyACM0?uart-baudrate=115200' 140``` 141 142## Daemon Mode 143 144OpenThread Posix Daemon mode uses a unix socket as input and output, so that OpenThread core can run as a service. And a client can communicate with it by connecting to the socket. The protocol is OpenThread CLI. 145 146``` 147# build daemon mode core stack for POSIX 148./script/cmake-build posix -DOT_DAEMON=ON 149# Daemon with simulation 150./build/posix/src/posix/ot-daemon 'spinel+hdlc+forkpty://build/simulation/examples/apps/ncp/ot-rcp?forkpty-arg=1' 151# Daemon with real device 152./build/posix/src/posix/ot-daemon 'spinel+hdlc+uart:///dev/ttyACM0?uart-baudrate=115200' 153# Built-in controller 154./build/posix/src/posix/ot-ctl 155``` 156