1.. _arduino_giga_r1_board: 2 3Arduino GIGA R1 WiFi 4#################### 5 6Overview 7******** 8 9Arduino GIGA R1 WiFi is a development board by Arduino based on the 10STM32H747XI, a dual core ARM Cortex-M7 + Cortex-M4 MCU, with 2MBytes of Flash 11memory and 1MB SRAM. 12 13The board features: 14 15- RGB LED 16- Reset and Boot buttons 17- USB-C device 18- USB Host 19- 16MB external QSPI flash 20- 8MB external SDRAM 21- Murata Type 1DX Bluetooth + WiFi module (CYW4343W based) 22- Audio jack 23- ATECC608A secure element 24 25.. image:: img/arduino_giga_r1.jpg 26 :align: center 27 :alt: Arduino GIGA R1 WiFi 28 29More information about the board, including the datasheet, pinout and 30schematics, can be found at the `Arduino GIGA website`_. 31 32More information about STM32H747XIH6 can be found here: 33 34- `STM32H747XI on www.st.com`_ 35- `STM32H747xx reference manual`_ 36- `STM32H747xx datasheet`_ 37 38Supported Features 39================== 40 41The current Zephyr ``arduino_giga_r1_m7`` board configuration supports the 42following hardware features: 43 44+-----------+------------+-------------------------------------+ 45| Interface | Controller | Driver/Component | 46+===========+============+=====================================+ 47| NVIC | on-chip | nested vector interrupt controller | 48+-----------+------------+-------------------------------------+ 49| UART | on-chip | serial port-polling; | 50| | | serial port-interrupt | 51+-----------+------------+-------------------------------------+ 52| PINMUX | on-chip | pinmux | 53+-----------+------------+-------------------------------------+ 54| GPIO | on-chip | gpio | 55+-----------+------------+-------------------------------------+ 56| FLASH | on-chip | flash memory | 57+-----------+------------+-------------------------------------+ 58| RNG | on-chip | True Random number generator | 59+-----------+------------+-------------------------------------+ 60| I2C | on-chip | i2c | 61+-----------+------------+-------------------------------------+ 62| SPI | on-chip | spi | 63+-----------+------------+-------------------------------------+ 64| IPM | on-chip | virtual mailbox based on HSEM | 65+-----------+------------+-------------------------------------+ 66| FMC | on-chip | memc (SDRAM) | 67+-----------+------------+-------------------------------------+ 68| QSPI | on-chip | QSPI flash | 69+-----------+------------+-------------------------------------+ 70| RADIO | Murata 1DX | WiFi and Bluetooth module | 71+-----------+------------+-------------------------------------+ 72 73Other hardware features are not yet supported on Zephyr port. 74 75Fetch Binary Blobs 76****************** 77 78The board Bluetooth/WiFi module requires fetching some binary blob files, to do 79that run the command: 80 81.. code-block:: console 82 83 west blobs fetch hal_infineon 84 85.. note:: Only Bluetooth functionality is currently supported. 86 87Resources sharing 88================= 89 90The dual core nature of STM32H747 SoC requires sharing HW resources between the 91two cores. This is done in 3 ways: 92 93- **Compilation**: Clock configuration is only accessible to M7 core. M4 core only 94 has access to bus clock activation and deactivation. 95- **Static pre-compilation assignment**: Peripherals such as a UART are assigned in 96 devicetree before compilation. The user must ensure peripherals are not assigned 97 to both cores at the same time. 98- **Run time protection**: Interrupt-controller and GPIO configurations could be 99 accessed by both cores at run time. Accesses are protected by a hardware semaphore 100 to avoid potential concurrent access issues. 101 102Programming and Debugging 103************************* 104 105Applications for the ``arduino_giga_r1`` board should be built per core target, 106using either ``arduino_giga_r1/stm32h747xx/m7`` or ``arduino_giga_r1/stm32h747xx/m4`` as the target. 107 108See :ref:`build_an_application` for more information about application builds. 109 110Flashing 111======== 112 113This board can be flashed either using dfu-util, or with an external debugging 114probe, such as a J-Link or Black Magic Probe, connected to the on board MIPI-10 115SWD port marked as "JTAG". 116 117.. note:: 118 119 The board ships with a custom Arduino bootloader programmed in the first 120 flash page that can be triggered by double clicking the ``RST`` button. This 121 bootloader is USB-DFU compatible and supports programming both the internal 122 and external flash and is the one used by ``west flash`` by default. The 123 internal STM32 ROM bootloader can also be used by pressing ``RST`` while 124 holding the ``BOOT0`` button, this also supports USB-DFU but can only 125 program the internal flash and can overwrite the Arduino bootloader. More 126 details can be found in the "Boot0" section of the `Arduino GIGA Cheat 127 Sheet`_. 128 129First, connect the Arduino GIGA R1 board to your host computer using the USB 130port to prepare it for flashing. Double click the ``RST`` button to put the 131board into the Arduino Bootloader mode. Then build and flash your application. 132 133Here is an example for the :zephyr:code-sample:`hello_world` application. 134 135.. zephyr-app-commands:: 136 :zephyr-app: samples/hello_world 137 :board: arduino_giga_r1/stm32h747xx/m7 138 :goals: build flash 139 140Run a serial host program to connect with your board: 141 142.. code-block:: console 143 144 $ minicom -D /dev/ttyACM0 145 146You should see the following message on the console: 147 148.. code-block:: console 149 150 Hello World! arduino_giga_r1 151 152Similarly, you can build and flash samples on the M4 target. 153 154Here is an example for the :zephyr:code-sample:`blinky` application on M4 core. 155 156.. zephyr-app-commands:: 157 :zephyr-app: samples/basic/blinky 158 :board: arduino_giga_r1/stm32h747xx/m4 159 :goals: build flash 160 161Debugging 162========= 163 164Debugging is supported by using ``west debug`` with an external probe such as a 165J-Link or Black Magic Probe, connected to the on board MIPI-10 SWD port marked 166as "JTAG". For example:: 167 168 west debug -r jlink 169 170.. _Arduino GIGA website: 171 https://docs.arduino.cc/hardware/giga-r1-wifi 172 173.. _Arduino GIGA Cheat Sheet: 174 https://docs.arduino.cc/tutorials/giga-r1-wifi/cheat-sheet 175 176.. _STM32H747XI on www.st.com: 177 https://www.st.com/content/st_com/en/products/microcontrollers-microprocessors/stm32-32-bit-arm-cortex-mcus/stm32-high-performance-mcus/stm32h7-series/stm32h747-757/stm32h747xi.html 178 179.. _STM32H747xx reference manual: 180 https://www.st.com/resource/en/reference_manual/dm00176879.pdf 181 182.. _STM32H747xx datasheet: 183 https://www.st.com/resource/en/datasheet/stm32h747xi.pdf 184 185.. _dfu-util: 186 http://dfu-util.sourceforge.net/build.html 187