1.. _v2m_beetle_board: 2 3ARM V2M Beetle 4############## 5 6Overview 7******** 8 9The v2m_beetle board configuration is used by Zephyr applications that run on 10the V2M Beetle board. It provides support for the Beetle ARM Cortex-M3 CPU and 11the following devices: 12 13- Nested Vectored Interrupt Controller (NVIC) 14- System Tick System Clock (SYSTICK) 15- Cortex-M System Design Kit GPIO 16- Cortex-M System Design Kit UART 17 18.. image:: img/v2m_beetle.jpg 19 :align: center 20 :alt: ARM V2M Beetle 21 22More information about the board can be found at the `V2M Beetle Website`_. 23 24Hardware 25******** 26 27ARM V2M BEETLE provides the following hardware components: 28 29- ARM Cortex-M3 30- ARM IoT Subsystem for Cortex-M 31- CORDIO Bluetooth Smart radio 32- Memory 33 34 - 256KB of embedded flash 35 - 128KB SRAM 36 - 2MB of external QSPI flash. 37 38- Debug 39 40 - JTAG, SWD & 4 bit TRACE 41 - CMSIS-DAP with a virtual UART port 42 43- Arduino interface 44 45 - GPIO, UART, SPI, I2C 46 - Analog signals 47 48 49Supported Features 50=================== 51 52The v2m_beetle board configuration supports the following hardware features: 53 54+-----------+------------+-------------------------------------+ 55| Interface | Controller | Driver/Component | 56+===========+============+=====================================+ 57| NVIC | on-chip | nested vector interrupt controller | 58+-----------+------------+-------------------------------------+ 59| SYSTICK | on-chip | systick | 60+-----------+------------+-------------------------------------+ 61| UART | on-chip | serial port-polling; | 62| | | serial port-interrupt | 63+-----------+------------+-------------------------------------+ 64| PINMUX | on-chip | pinmux | 65+-----------+------------+-------------------------------------+ 66| GPIO | on-chip | gpio | 67+-----------+------------+-------------------------------------+ 68| WATCHDOG | on-chip | watchdog | 69+-----------+------------+-------------------------------------+ 70| TIMER | on-chip | timer | 71+-----------+------------+-------------------------------------+ 72 73Other hardware features are not currently supported by the port. 74See the `V2M Beetle Website`_ for a complete list of V2M Beetle board hardware 75features. 76 77The default configuration can be found in the defconfig file: 78 79.. code-block:: console 80 81 boards/arm/v2m_beetle/v2m_beetle_defconfig 82 83Interrupt Controller 84==================== 85 86Beetle is a Cortex-M3 based SoC and has 15 fixed exceptions and 45 IRQs. 87 88A Cortex-M3/4-based board uses vectored exceptions. This means each exception 89calls a handler directly from the vector table. 90 91Handlers are provided for exceptions 1-6, 11-12, and 14-15. The table here 92identifies the handlers used for each exception. 93 94+------+------------+----------------+--------------------------+ 95| Exc# | Name | Remarks | Used by Zephyr Kernel | 96+======+============+================+==========================+ 97| 1 | Reset | | system initialization | 98+------+------------+----------------+--------------------------+ 99| 2 | NMI | | system fatal error | 100+------+------------+----------------+--------------------------+ 101| 3 | Hard fault | | system fatal error | 102+------+------------+----------------+--------------------------+ 103| 4 | MemManage | MPU fault | system fatal error | 104+------+------------+----------------+--------------------------+ 105| 5 | Bus | | system fatal error | 106+------+------------+----------------+--------------------------+ 107| 6 | Usage | undefined | system fatal error | 108| | fault | instruction, | | 109| | | or switch | | 110| | | attempt to ARM | | 111| | | mode | | 112+------+------------+----------------+--------------------------+ 113| 11 | SVC | | system calls, kernel | 114| | | | run-time exceptions, | 115| | | | and IRQ offloading | 116+------+------------+----------------+--------------------------+ 117| 12 | Debug | | system fatal error | 118| | monitor | | | 119+------+------------+----------------+--------------------------+ 120| 14 | PendSV | | context switch | 121+------+------------+----------------+--------------------------+ 122| 15 | SYSTICK | | system clock | 123+------+------------+----------------+--------------------------+ 124 125Pin Mapping 126=========== 127 128The ARM V2M Beetle Board has 4 GPIO controllers. These controllers are responsible for pin muxing, input/output, pull-up, etc. 129 130All GPIO controller pins are exposed via the following sequence of pin numbers: 131 132- Pins 0 - 15 are for GPIO 0 133- Pins 16 - 31 are for GPIO 1 134 135Mapping from the ARM V2M Beetle Board pins to GPIO controllers: 136 137.. rst-class:: rst-columns 138 139 - D0 : P0_0 140 - D1 : P0_1 141 - D2 : P0_2 142 - D3 : P0_3 143 - D4 : P0_4 144 - D5 : P0_5 145 - D6 : P0_6 146 - D7 : P0_7 147 - D8 : P0_8 148 - D9 : P0_9 149 - D10 : P0_10 150 - D11 : P0_11 151 - D12 : P0_12 152 - D13 : P0_13 153 - D14 : P0_14 154 - D15 : P0_15 155 - D16 : P1_0 156 - D17 : P1_1 157 - D18 : P1_2 158 - D19 : P1_3 159 - D20 : P1_4 160 - D21 : P1_5 161 - D22 : P1_6 162 - D23 : P1_7 163 - D24 : P1_8 164 - D25 : P1_9 165 - D26 : P1_10 166 - D27 : P1_11 167 - D28 : P1_12 168 - D29 : P1_13 169 - D30 : P1_14 170 - D31 : P1_15 171 172Peripheral Mapping: 173 174.. rst-class:: rst-columns 175 176 - UART_0_RX : D0 177 - UART_0_TX : D1 178 - SPI_0_CS : D10 179 - SPI_0_MOSI : D11 180 - SPI_0_MISO : D12 181 - SPI_0_SCLK : D13 182 - I2C_0_SCL : D14 183 - I2C_0_SDA : D15 184 - UART_1_RX : D16 185 - UART_1_TX : D17 186 - SPI_1_CS : D18 187 - SPI_1_MOSI : D19 188 - SPI_1_MISO : D20 189 - SPI_1_SCK : D21 190 - I2C_1_SDA : D22 191 - I2C_1_SCL : D23 192 193For more details please refer to `Beetle Technical Reference Manual (TRM)`_. 194 195System Clock 196============ 197 198V2M Beetle has one external and two on-chip oscillators. The slow clock is 19932.768 kHz, and the main clock is 24 MHz. The processor can set up PLL to drive 200the master clock. 201 202Serial Port 203=========== 204 205The ARM Beetle processor has two UARTs. Both the UARTs have only two wires for 206RX/TX and no flow control (CTS/RTS) or FIFO. The Zephyr console output, by 207default, is utilizing UART1. 208 209Programming and Debugging 210************************* 211 212Flashing 213======== 214 215CMSIS DAP 216--------- 217 218V2M Beetle provides: 219 220- A USB connection to the host computer, which exposes a Mass Storage and an 221 USB Serial Port. 222- A Serial Flash device, which implements the USB flash disk file storage. 223- A physical UART connection which is relayed over interface USB Serial port. 224 225This interfaces are exposed via CMSIS DAP. For more details please refer 226to `CMSIS-DAP Website`_. 227 228Flashing an application to V2M Beetle 229------------------------------------- 230 231You can build applications in the usual way. Here is an example for 232the :zephyr:code-sample:`hello_world` application. 233 234.. zephyr-app-commands:: 235 :zephyr-app: samples/hello_world 236 :board: v2m_beetle 237 :goals: build 238 239Connect the V2M Beetle to your host computer using the USB port and you should 240see a USB connection which exposes a Mass Storage (MBED) and a USB Serial Port. 241Copy the generated zephyr.bin in the MBED drive. 242Reset the board and you should be able to see on the corresponding Serial Port 243the following message: 244 245.. code-block:: console 246 247 Hello World! arm 248 249 250.. _V2M Beetle Website: 251 https://developer.arm.com/Tools%20and%20Software/Beetle%20IoT%20Evaluation%20Platform 252 253.. _Beetle Technical Reference Manual (TRM): 254 https://developer.arm.com/documentation/100417/latest/ 255 256.. _CMSIS-DAP Website: 257 https://arm-software.github.io/CMSIS_5/DAP/html/index.html 258