1.. _inventek_eswifi_shield: 2 3Inventek es-WIFI Shield 4####################### 5 6Overview 7******** 8 9The es-WIFI (embedded Serial-to-WiFi) modules are devices developed by Inventek 10Systems. It integrates WIFI and optionally Bluetooth Low Energy. The es-WIFI 11devices can run Cypress WICED or Inventek's IWIN (Inventek Systems Wireless 12Interoperability Network) AT commands set. The current es-WIFI driver is able 13to use one of two serial interfaces: SPI or UART. 14 15The Zephyr es-WIFI drivers was implemented using ISM43362-M3G-L44 with SPI 16interface. The UART was implemented with ISM4343-WBM-L151. Besides that, 17user can reprogram the modules to switch from one interface type to another 18by the JTAG pin header. 19 20 21ISMART4343C-EVB 22=============== 23 24The `ISMART4343C-EVB`_ is a development Kit with Arduino Uno R3 compatible 25shield. It allows evaluate es-WIFI modules with SPI or UART interface. For 26UART interface the `inventek_eswifi_arduino_uart`_ must be selected. For 27SPI interface the `inventek_eswifi_arduino_spi`_ must be enabled. The EVB 28can use 5V from Arduino header, if board provide it, J17 position 1-2. 29Otherwise, J17 2-3 will select USB-5V. More information can be found at 30`ISMART4343C-EVB Users Manual`_. 31 32.. note:: 33 The Inventek's EVBs signals are 3.3V only. 34 35.. image:: ismart4343c-evb.jpg 36 :align: center 37 :alt: ISMART4343C-EVB 38 39Pins Assignment of the ISMART EVBs 40================================== 41 42The below table presents signals by interface. The UART switch SW3 must be on 43position 3 to enable RX/TX signals when using es-WIFI with UART firmware. 44 45To enable full control by Arduino header user should do some manual wiring. 46The signals from D3 up to D7 are not connected by default on the Inventek's 47shield. These signals marked as optional can help on development. The current 48driver do not handle that signals and are simple suggestions and can be left 49as is. Some arduino boards don't have NRST pin connected to a GPIO pin. The 50recommendation is bend the NRST pin and make a wire to D6. WAKE-UP signal is 51available at header J26 pin 1 and shield configuration uses D7 to control that 52signal, user need do a wire connecting these two terminals. On the below 53image is possible see suggested wiring connections. 54 55.. image:: ismart4343c-evb-wiring.jpg 56 :align: center 57 :alt: ISMART4343C-EVB Wiring 58 59+-----------------------+-----------+---------------------+ 60| Arduino Connector Pin | Function | Serial Connection | 61+=======================+===========+=====================+ 62| D0 | UART RX | UART | 63+-----------------------+-----------+---------------------+ 64| D1 | UART TX | UART | 65+-----------------------+-----------+---------------------+ 66| D3 | CFG-1 | UART/SPI [optional] | 67+-----------------------+-----------+---------------------+ 68| D4 | CFG-0 | UART/SPI [optional] | 69+-----------------------+-----------+---------------------+ 70| D5 | BOOT-0 | UART/SPI [optional] | 71+-----------------------+-----------+---------------------+ 72| D6 | NRST | UART/SPI [wiring] | 73+-----------------------+-----------+---------------------+ 74| D7 | WAKE-UP | UART/SPI [wiring] | 75+-----------------------+-----------+---------------------+ 76| D9 | CMD/RDY | SPI | 77+-----------------------+-----------+---------------------+ 78| D10 | SPI CS | SPI | 79+-----------------------+-----------+---------------------+ 80| D11 | SPI MOSI | SPI | 81+-----------------------+-----------+---------------------+ 82| D12 | SPI MISO | SPI | 83+-----------------------+-----------+---------------------+ 84| D13 | SPI SCK | SPI | 85+-----------------------+-----------+---------------------+ 86 87 88Supported variations 89==================== 90 91The below table suggests shield variation accordingly with end user 92application. When a standard Arduino R3 connector is available on board, user 93should select the matching shield configuration based on the serial interface 94(SERIAL or SPI). The inventek_eswifi is available to allow users testing a 95built-in module with dedicated <board>.overlay and <board>.defconfig files. 96 97+-----------------------------+---------------------------------+-----------+ 98| Connector Standard | Shield Designation | Variation | 99+=============================+=================================+===========+ 100| Without standard (overlay) | `inventek_eswifi`_ | 1 | 101+-----------------------------+---------------------------------+-----------+ 102| Arduino by UART | `inventek_eswifi_arduino_uart`_ | 2 | 103+-----------------------------+---------------------------------+-----------+ 104| Arduino by SPI | `inventek_eswifi_arduino_spi`_ | 3 | 105+-----------------------------+---------------------------------+-----------+ 106 107Requirements 108************ 109 110This shield requires a board which provides a configuration that allows an 111UART or SPI interface and two or three GPIO. (see :ref:`shields` for more 112details). 113 114.. note:: 115 Some boards may already have a network interface: Check network 116 documentation to understand how properly configure both interfaces. 117 To keep simple, you can keep only the WIFI interface enabled at 118 Networking -> Link Layer Options. This will avoid problems running 119 Zephyr samples. 120 121Tested Boards 122============= 123 124+------------------------------+------------------------------+-----------+ 125| Board | Disabled Interface | Variation | 126+==============================+==============================+===========+ 127| ATMEL sam_v71_xult/samv71q21 | Ethernet | 2 , 3 | 128+------------------------------+------------------------------+-----------+ 129| ST nucleo_f767zi | Ethernet | 2 , 3 | 130+------------------------------+------------------------------+-----------+ 131| ST disco_l475_iot1 | | - | 132+------------------------------+------------------------------+-----------+ 133 134.. note:: 135 ST disco_l475_iot1 already have an ISM43362 module with IWIN SPI 136 firmware. It doesn't need this shield to expose es-WIFI. It is only 137 used here as reference to demonstrate how configure an on-board 138 module. 139 140Sample usage 141************ 142 143The reference sample for WIFI is :zephyr:code-sample:`wifi-shell`. It allows you to use WIFI 144shell to scan local Wireless networks. With the password you can pick, 145connect and send ping. 146 147Build and Programming 148********************* 149 150Set ``--shield <shield designator>`` when you invoke ``west build``. 151 152.. zephyr-app-commands:: 153 :zephyr-app: samples/net/wifi 154 :host-os: unix 155 :board: [sam_v71_xult/samv71q21 | nucleo_f767zi] 156 :shield: inventek_eswifi_arduino_uart 157 :goals: build flash 158 :compact: 159 160.. zephyr-app-commands:: 161 :zephyr-app: samples/net/wifi 162 :host-os: unix 163 :board: [sam_v71_xult/samv71q21 | nucleo_f767zi] 164 :shield: inventek_eswifi_arduino_spi 165 :goals: build flash 166 :compact: 167 168.. zephyr-app-commands:: 169 :zephyr-app: samples/net/wifi 170 :host-os: unix 171 :board: disco_l475_iot1 172 :goals: build flash 173 :compact: 174 175 176References 177********** 178 179.. target-notes:: 180 181.. _ISMART4343C-EVB: 182 https://www.inventeksys.com/ismart4343-c-arduino-shield-wi-fi-2ghz-bluetooth-ble/ 183 184.. _ISMART4343C-EVB Users Manual: 185 https://www.inventeksys.com/wp-content/uploads/IoT-EVB-Users-Manual.pdf 186 187.. _inventek_eswifi: 188 https://github.com/zephyrproject-rtos/zephyr/blob/master/boards/shields/inventek_eswifi/inventek_eswifi.overlay 189 190.. _inventek_eswifi_arduino_uart: 191 https://github.com/zephyrproject-rtos/zephyr/blob/master/boards/shields/inventek_eswifi/inventek_eswifi_arduino_uart.overlay 192 193.. _inventek_eswifi_arduino_spi: 194 https://github.com/zephyrproject-rtos/zephyr/blob/master/boards/shields/inventek_eswifi/inventek_eswifi_arduino_spi.overlay 195