1.. zephyr:board:: cc1352p1_launchxl 2 3Overview 4******** 5 6The Texas Instruments CC1352P LaunchPad |trade| (LAUNCHXL-CC1352P1) is a 7development kit for the SimpleLink |trade| multi-Standard CC1352P wireless MCU. 8 9See the `TI CC1352P LaunchPad Product Page`_ for details. 10 11Hardware 12******** 13 14The CC1352P LaunchPad |trade| development kit features the CC1352P wireless MCU. 15The board is equipped with two LEDs, two push buttons, antenna switch and 16BoosterPack connectors for expansion. It also includes an integrated (XDS110) 17debugger. 18 19The CC1352P wireless MCU has a 48 MHz Arm |reg| Cortex |reg|-M4F SoC and an 20integrated sub-1GHz and 2.4 GHz transceiver with integrated 20dBm power amplifier 21(PA) supporting multiple protocols including Bluetooth |reg| Low Energy and IEEE 22|reg| 802.15.4. 23 24See the `TI CC1352P Product Page`_ for additional details. 25 26Supported Features 27================== 28 29The CC1352P LaunchPad board configuration supports the following hardware 30features: 31 32+-----------+------------+----------------------+ 33| Interface | Controller | Driver/Component | 34+===========+============+======================+ 35| GPIO | on-chip | gpio | 36+-----------+------------+----------------------+ 37| MPU | on-chip | arch/arm | 38+-----------+------------+----------------------+ 39| NVIC | on-chip | arch/arm | 40+-----------+------------+----------------------+ 41| PINMUX | on-chip | pinmux | 42+-----------+------------+----------------------+ 43| UART | on-chip | serial | 44+-----------+------------+----------------------+ 45| I2C | on-chip | i2c | 46+-----------+------------+----------------------+ 47| SPI | on-chip | spi | 48+-----------+------------+----------------------+ 49| WDT | on-chip | watchdog | 50+-----------+------------+----------------------+ 51| HWINFO | on-chip | hwinfo | 52+-----------+------------+----------------------+ 53 54Other hardware features have not been enabled yet for this board. 55 56Connections and IOs 57=================== 58 59All I/O signals are accessible from the BoosterPack connectors. Pin function 60aligns with the LaunchPad standard. 61 62+-------+-----------+---------------------+ 63| Pin | Function | Usage | 64+=======+===========+=====================+ 65| DIO3 | GPIO | | 66+-------+-----------+---------------------+ 67| DIO4 | I2C_MSSCL | I2C SCL | 68+-------+-----------+---------------------+ 69| DIO5 | I2C_MSSDA | I2C SDA | 70+-------+-----------+---------------------+ 71| DIO6 | GPIO | Red LED | 72+-------+-----------+---------------------+ 73| DIO7 | GPIO | Green LED | 74+-------+-----------+---------------------+ 75| DIO8 | SSI0_RX | SPI MISO | 76+-------+-----------+---------------------+ 77| DIO9 | SSI0_TX | SPI MOSI | 78+-------+-----------+---------------------+ 79| DIO10 | SSI0_CLK | SPI CLK | 80+-------+-----------+---------------------+ 81| DIO11 | SSIO_CS | SPI CS | 82+-------+-----------+---------------------+ 83| DIO12 | UART0_RX | UART RXD | 84+-------+-----------+---------------------+ 85| DIO13 | UART0_TX | UART TXD | 86+-------+-----------+---------------------+ 87| DIO14 | GPIO | Button 2 | 88+-------+-----------+---------------------+ 89| DIO15 | GPIO | Button 1 | 90+-------+-----------+---------------------+ 91| DIO16 | | JTAG TDO | 92+-------+-----------+---------------------+ 93| DIO17 | | JTAG TDI | 94+-------+-----------+---------------------+ 95| DIO18 | UART0_RTS | UART RTS / JTAG SWO | 96+-------+-----------+---------------------+ 97| DIO19 | UART0_CTS | UART CTS | 98+-------+-----------+---------------------+ 99| DIO20 | GPIO | Flash CS | 100+-------+-----------+---------------------+ 101| DIO21 | GPIO | | 102+-------+-----------+---------------------+ 103| DIO22 | GPIO | | 104+-------+-----------+---------------------+ 105| DIO23 | AUX_IO | A0 | 106+-------+-----------+---------------------+ 107| DIO24 | AUX_IO | A1 | 108+-------+-----------+---------------------+ 109| DIO25 | AUX_IO | A2 | 110+-------+-----------+---------------------+ 111| DIO26 | AUX_IO | A3 | 112+-------+-----------+---------------------+ 113| DIO27 | AUX_IO | A4 | 114+-------+-----------+---------------------+ 115| DIO28 | AUX_IO | A5 | 116+-------+-----------+---------------------+ 117| DIO29 | AUX_IO | A6 | 118+-------+-----------+---------------------+ 119| DIO30 | AUX_IO | A7 | 120+-------+-----------+---------------------+ 121 122Programming and Debugging 123************************* 124 125Before flashing or debugging ensure the RESET, TMS, TCK, TDO, and TDI jumpers 126are in place. Also place jumpers on the TXD and RXD signals for a serial 127console using the XDS110 application serial port. 128 129Prerequisites: 130============== 131 132#. Ensure the XDS-110 emulation firmware on the board is updated. 133 134 Download and install the latest `XDS-110 emulation package`_. 135 136 Follow these `xds110 firmware update directions 137 <http://software-dl.ti.com/ccs/esd/documents/xdsdebugprobes/emu_xds110.html#updating-the-xds110-firmware>`_ 138 139 Note that the emulation package install may place the xdsdfu utility 140 in ``<install_dir>/ccs_base/common/uscif/xds110/``. 141 142#. Install OpenOCD 143 144 You can obtain OpenOCD by following these 145 :ref:`installing the latest Zephyr SDK instructions <toolchain_zephyr_sdk>`. 146 147 After the installation, add the directory containing the OpenOCD executable 148 to your environment's PATH variable. For example, use this command in Linux: 149 150 .. code-block:: console 151 152 export PATH=$ZEPHYR_SDK_INSTALL_DIR/sysroots/x86_64-pokysdk-linux/usr/bin/openocd:$PATH 153 154Flashing 155======== 156 157Applications for the ``CC1352P LaunchPad`` board configuration can be built and 158flashed in the usual way (see :ref:`build_an_application` and 159:ref:`application_run` for more details). 160 161Here is an example for the :zephyr:code-sample:`hello_world` application. 162 163First, run your favorite terminal program to listen for output. 164 165.. code-block:: console 166 167 $ screen <tty_device> 115200 168 169Replace :code:`<tty_device>` with the port where the XDS110 application 170serial device can be found. For example, :code:`/dev/ttyACM0`. 171 172Then build and flash the application in the usual way. 173 174.. zephyr-app-commands:: 175 :zephyr-app: samples/hello_world 176 :board: cc1352p1_launchxl 177 :goals: build flash 178 179Debugging 180========= 181 182You can debug an application in the usual way. Here is an example for the 183:zephyr:code-sample:`hello_world` application. 184 185.. zephyr-app-commands:: 186 :zephyr-app: samples/hello_world 187 :board: cc1352p1_launchxl 188 :maybe-skip-config: 189 :goals: debug 190 191Bootloader 192========== 193 194The ROM bootloader on CC13x2 and CC26x2 devices is enabled by default. The 195bootloader will start if there is no valid application image in flash or the 196so-called backdoor is enabled (via option 197:kconfig:option:`CONFIG_CC13X2_CC26X2_BOOTLOADER_BACKDOOR_ENABLE`) and BTN-1 is held 198down during reset. See the bootloader documentation in chapter 10 of the `TI 199CC13x2 / CC26x2 Technical Reference Manual`_ for additional information. 200 201Power Management and UART 202========================= 203 204System and device power management are supported on this platform, and 205can be enabled via the standard Kconfig options in Zephyr, such as 206:kconfig:option:`CONFIG_PM`, :kconfig:option:`CONFIG_PM_DEVICE`. 207 208When system power management is turned on (CONFIG_PM=y), 209sleep state 2 (standby mode) is allowed, and polling is used to retrieve input 210by calling uart_poll_in(), it is possible for characters to be missed if the 211system enters standby mode between calls to uart_poll_in(). This is because 212the UART is inactive while the system is in standby mode. The workaround is to 213disable sleep state 2 while polling: 214 215.. code-block:: c 216 217 pm_policy_state_lock_get(PM_STATE_STANDBY, PM_ALL_SUBSTATES); 218 <code that calls uart_poll_in() and expects input at any point in time> 219 pm_policy_state_lock_put(PM_STATE_STANDBY, PM_ALL_SUBSTATES); 220 221 222References 223********** 224 225CC1352P1 LaunchPad Quick Start Guide: 226 http://www.ti.com/lit/pdf/swru525 227 228.. _TI CC1352P LaunchPad Product Page: 229 https://www.ti.com/tool/LAUNCHXL-CC1352P 230 231.. _TI CC1352P Product Page: 232 https://www.ti.com/product/CC1352P 233 234.. _TI CC13x2 / CC26x2 Technical Reference Manual: 235 http://www.ti.com/lit/pdf/swcu185 236 237.. _XDS-110 emulation package: 238 http://processors.wiki.ti.com/index.php/XDS_Emulation_Software_Package#XDS_Emulation_Software_.28emupack.29_Download 239