Skip to content

WIZnet-ioNIC/WIZnet-PICO-AWS-C

Repository files navigation

Getting Started Guide for AWS IoT Core

1. Document information

1.1 Document revision history

Version Date Description
1.0.0 2021-11-2 Initial Version
2.0.0 2024-11-7 Updated

1.2 Applicable operating systems for this guide

These examples were tested after configuring the development environment on Windows. Please refer to 'Chapter 3: Installing the Raspberry Pi Pico VS Code Extension' in the document below and configure accordingly.

Visual Studio Code was used during development and testing of AWS IoT SDK examples, the guide document in each directory was prepared also base on development with Visual Studio Code. Please refer to corresponding document.

2. Overview

The AWS IoT SDK examples use Raspberry Pi Pico and WIZnet Ethernet HAT - ethernet I/O module built on WIZnet's W5100S ethernet chip, W5100S-EVB-Pico - ethernet I/O module built on RP2040 and WIZnet's W5100S ethernet chip, W5500-EVB-Pico and W55RP20-EVB-Pico - ethernet I/O module built on RP2040 and WIZnet's W5500 ethernet chip, W5100S-EVB-Pico2 - ethernet I/O module built on RP2350 and WIZnet's W5100S ethernet chip or W5100S-EVB-Pico2 - ethernet I/O module built on RP2350 and WIZnet's W5100S ethernet chip.

3. Hardware description

3.1 Datasheet

Please refer to the Datasheet section on the page linked above.

3.2 Standard kit contents

Please refer to the How to Buy section on the page linked above.

3.3 User Provided items

Raspberry Pi Pico, W5100S-EVB-Pico, or W5500-EVB-Pico require a 5-pin micro USB cable, while W55RP20-EVB-Pico, W5100S-EVB-Pico2, or W5500-EVB-Pico2 require a USB Type-C cable.

3.4 3rd party purchasable items

Not applicable.

4. Set up your Development Environment

Please refer to the Applicable operating systems for this guide.

5. Set up device hardware

Please refer to the Hardware description.

6. Set up your AWS account and permissions

If you do not have an existing AWS account and user, refer to the online AWS documentation at Set up your AWS Account. To get started, follow the steps outlined in the sections below:

7. Create resources in AWS IoT

Refer to the online AWS documentation at Create AWS IoT Resources. Follow the steps outlined in these sections to provision resources for your device:

8. Provision the Device with credentials

Please refer to Step 4: Setup Connect AWS IoT through MQTT Example at the How to Test Connect to AWS IoT through MQTT Example.

9. Build and Run

9.1 AWS IoT SDK example structure

Examples are available at 'WIZnet-PICO-AWS-C/examples/' directory. As of now, following examples are provided.

Note that ioLibrary_Driver, mbedtls, aws-iot-device-sdk-embedded-C, pico-sdk are needed to run AWS IoT SDK examples.

  • ioLibrary_Driver library is applicable to WIZnet's W5x00 ethernet chip.
  • mbedtls library supports additional algorithms and support related to TLS and SSL connections.
  • aws-iot-device-sdk-embedded-C library is embedded C (C-SDK) is a collection of C source files that can be used in embedded applications to securely connect IoT devices to AWS IoT Core.
  • pico-sdk is made available by Pico to enable developers to build software applications for the Pico platform.
  • pico-extras has additional libraries that are not yet ready for inclusion the Pico SDK proper, or are just useful but don't necessarily belong in the Pico SDK.

Libraries are located in the 'WIZnet-PICO-AWS-C/libraries/' directory.

If you want to modify the code that MCU-dependent and use a MCU other than RP2040, you can modify it in the WIZnet-PICO-AWS-C/port/ directory.

The structure of this WIZnet-PICO-AWS-C 2.0.0 version or higher has changed a lot compared to the previous version. If you want to refer to the previous version, please refer to the link below.

9.2 AWS IoT SDK example testing

  1. Download

If the AWS IoT SDK examples are cloned, the library set as a submodule is an empty directory. Therefore, if you want to download the library set as a submodule together, clone the AWS IoT SDK examples with the following Git command.

/* Change directory */
// change to the directory to clone
cd [user path]

// e.g.
cd D:/RP2040

/* Clone */
git clone --recurse-submodules https://github.com/WIZnet-ioNIC/WIZnet-PICO-AWS-C.git

With Visual Studio Code, the library set as a submodule is automatically downloaded, so it doesn't matter whether the library set as a submodule is an empty directory or not, so refer to it.

  1. Setup Board

Setup the Board in 'CMakeLists.txt' in 'WIZnet-PICO-AWS-C/' directory according to the evaluation board to be used referring to the following.

  • WIZnet Ethernet HAT
  • W5100S-EVB-Pico
  • W5500-EVB-Pico
  • W55RP20-EVB-Pico
  • W5100S-EVB-Pico2
  • W5500-EVB-Pico2

For example, when using WIZnet Ethernet HAT :

# Set board
set(BOARD_NAME WIZnet_Ethernet_HAT)

When using W5500-EVB-Pico :

# Set board
set(BOARD_NAME W5500_EVB_PICO)

When using W55RP20-EVB-Pico :

# Set board
set(BOARD_NAME W55RP20_EVB_PICO)

When using W5100S-EVB-Pico2 :

# Set board
set(BOARD_NAME W5100S_EVB_PICO2)

When using W5500-EVB-Pico2 :

# Set board
set(BOARD_NAME W5500_EVB_PICO2)
  1. Test

Please refer to 'README.md' in each example directory to find detail guide for testing AWS IoT SDK examples.

※ If the board pauses when rebooting using W55RP20-EVB-Pico, patch it as follows.

// Patch
git apply ./patches/0001_pico_sdk_clocks.patch

9.3 How to use port directory

We moved the MCU dependent code to the port directory. The tree of port is shown below.

WIZnet-PICO-AWS-C
┣ port
    ┣ aws-iot-device-sdk-embedded-C
    ┃   ┣ inc
    ┃   ┃   ┣ core_http_config.h
    ┃   ┃   ┣ core_mqtt_config.h
    ┃   ┃   ┣ dns_config.h
    ┃   ┃   ┣ dns_interface.h
    ┃   ┃   ┣ http_transport_interface.h
    ┃   ┃   ┣ mqtt_transport_interface.h
    ┃   ┃   ┣ ssl_transport_interface.h
    ┃   ┃   ┣ timer_interface.h
    ┃   ┃   ┗ util.h
    ┃   ┗ src
    ┃   ┃   ┣ dns_interface.c
    ┃   ┃   ┣ http_transport_interface.c
    ┃   ┃   ┣ mqtt_transport_interface.c
    ┃   ┃   ┣ ssl_transport_interface.c
    ┃   ┃   ┣ timer_interface.c
    ┃   ┃   ┗ util.c
    ┣ ioLibrary_Driver
    ┃   ┣ inc
    ┃   ┃   ┣ w5x00_gpio_irq.h
    ┃   ┃   ┣ w5x00_spi.h
    ┃   ┃   ┣ wiznet_spi_pio.h
    ┃   ┃   ┗ wiznet_spi.h
    ┃   ┗ src
    ┃   ┃   ┣ w5x00_gpio_irq.c
    ┃   ┃   ┣ w5x00_spi.c
    ┃   ┃   ┣ wiznet_spi_pio.c
    ┃   ┃   ┗ wiznet_spi_pio.pio
    ┣ mbedtls
    ┃   ┗ inc
    ┃   ┃   ┗ ssl_config.h
    ┣ timer
    ┃   ┣ timer.c
    ┃   ┗ timer.h
    ┣ CMakeLists.txt
    ┗ port_common.h
  • ioLibrary_Driver

If you want to change things related to SPI, such as the SPI port number and SPI read/write function, or GPIO port number and function related to interrupt or use a different MCU without using the RP2040, you need to change the code in the 'WIZnet-PICO-AWS-C/port/ioLibrary_Driver/' directory. Here is information about functions.

/* W5x00 */
/*! \brief Set CS pin
 *  \ingroup w5x00_spi
 *
 *  Set chip select pin of spi0 to low(Active low).
 *
 *  \param none
 */
static inline void wizchip_select(void);

/*! \brief Set CS pin
 *  \ingroup w5x00_spi
 *
 *  Set chip select pin of spi0 to high(Inactive high).
 *
 *  \param none
 */
static inline void wizchip_deselect(void);

/*! \brief Read from an SPI device, blocking
 *  \ingroup w5x00_spi
 *
 *  Set spi_read_blocking function.
 *  Read byte from SPI to rx_data buffer.
 *  Blocks until all data is transferred. No timeout, as SPI hardware always transfers at a known data rate.
 *
 *  \param none
 */
static uint8_t wizchip_read(void);

/*! \brief Write to an SPI device, blocking
 *  \ingroup w5x00_spi
 *
 *  Set spi_write_blocking function.
 *  Write byte from tx_data buffer to SPI device.
 *  Blocks until all data is transferred. No timeout, as SPI hardware always transfers at a known data rate.
 *
 *  \param tx_data Buffer of data to write
 */
static void wizchip_write(uint8_t tx_data);

#ifdef USE_SPI_DMA
/*! \brief Configure all DMA parameters and optionally start transfer
 *  \ingroup w5x00_spi
 *
 *  Configure all DMA parameters and read from DMA
 *
 *  \param pBuf Buffer of data to read
 *  \param len element count (each element is of size transfer_data_size)
 */
static void wizchip_read_burst(uint8_t *pBuf, uint16_t len);

/*! \brief Configure all DMA parameters and optionally start transfer
 *  \ingroup w5x00_spi
 *
 *  Configure all DMA parameters and write to DMA
 *
 *  \param pBuf Buffer of data to write
 *  \param len element count (each element is of size transfer_data_size)
 */
static void wizchip_write_burst(uint8_t *pBuf, uint16_t len);
#endif

/*! \brief Enter a critical section
 *  \ingroup w5x00_spi
 *
 *  Set ciritical section enter blocking function.
 *  If the spin lock associated with this critical section is in use, then this
 *  method will block until it is released.
 *
 *  \param none
 */
static void wizchip_critical_section_lock(void);

/*! \brief Release a critical section
 *  \ingroup w5x00_spi
 *
 *  Set ciritical section exit function.
 *  Release a critical section.
 *
 *  \param none
 */
static void wizchip_critical_section_unlock(void);

/*! \brief Initialize SPI instances and Set DMA channel
 *  \ingroup w5x00_spi
 *
 *  Set GPIO to spi0.
 *  Puts the SPI into a known state, and enable it.
 *  Set DMA channel completion channel.
 *
 *  \param none
 */
void wizchip_spi_initialize(void);

/*! \brief Initialize a critical section structure
 *  \ingroup w5x00_spi
 *
 *  The critical section is initialized ready for use.
 *  Registers callback function for critical section for WIZchip.
 *
 *  \param none
 */
void wizchip_cris_initialize(void);

/*! \brief W5x00 chip reset
 *  \ingroup w5x00_spi
 *
 *  Set a reset pin and reset.
 *
 *  \param none
 */
void wizchip_reset(void);

/*! \brief Initialize WIZchip
 *  \ingroup w5x00_spi
 *
 *  Set callback function to read/write byte using SPI.
 *  Set callback function for WIZchip select/deselect.
 *  Set memory size of W5x00 chip and monitor PHY link status.
 *
 *  \param none
 */
void wizchip_initialize(void);

/*! \brief Check chip version
 *  \ingroup w5x00_spi
 *
 *  Get version information.
 *
 *  \param none
 */
void wizchip_check(void);

/* Network */
/*! \brief Initialize network
 *  \ingroup w5x00_spi
 *
 *  Set network information.
 *
 *  \param net_info network information.
 */
void network_initialize(wiz_NetInfo net_info);

/*! \brief Print network information
 *  \ingroup w5x00_spi
 *
 *  Print network information about MAC address, IP address, Subnet mask, Gateway, DHCP and DNS address.
 *
 *  \param net_info network information.
 */
void print_network_information(wiz_NetInfo net_info);
/* GPIO */
/*! \brief Initialize w5x00 gpio interrupt callback function
 *  \ingroup w5x00_gpio_irq
 *
 *  Add a w5x00 interrupt callback.
 *
 *  \param socket socket number
 *  \param callback the gpio interrupt callback function
 */
void wizchip_gpio_interrupt_initialize(uint8_t socket, void (*callback)(void));

/*! \brief Assign gpio interrupt callback function
 *  \ingroup w5x00_gpio_irq
 *
 *  GPIO interrupt callback function.
 *
 *  \param gpio Which GPIO caused this interrupt
 *  \param events Which events caused this interrupt. See \ref gpio_set_irq_enabled for details.
 */
static void wizchip_gpio_interrupt_callback(uint gpio, uint32_t events);
  • timer

If you want to change things related to the timer. Also, if you use a different MCU without using the RP2040, you need to change the code in the 'WIZnet-PICO-AWS-C/port/timer/' directory. Here is information about functions.

/* Timer */
/*! \brief Initialize timer callback function
 *  \ingroup timer
 *
 *  Add a repeating timer that is called repeatedly at the specified interval in microseconds.
 *
 *  \param callback the repeating timer callback function
 */
void wizchip_1ms_timer_initialize(void (*callback)(void));

/*! \brief Assign timer callback function
 *  \ingroup timer
 *
 *  1ms timer callback function.
 *
 *  \param t Information about a repeating timer
 */
bool wizchip_1ms_timer_callback(struct repeating_timer *t);

/* Delay */
/*! \brief Wait for the given number of milliseconds before returning
 *  \ingroup timer
 *
 *  This method attempts to perform a lower power sleep (using WFE) as much as possible.
 *
 *  \param ms the number of milliseconds to sleep
 */
void wizchip_delay_ms(uint32_t ms);

10. Verify messages in AWS IoT Core

Please refer to Step 6: Upload and Run at the How to Test Connect to AWS IoT through MQTT Example.

11. Troubleshooting

If any problems occur and the data is not displayed on the serial terminal, first check if the board setup was done correctly, or if the Ethernet cable is connected.

If the 'PUBLISH OK' message is not displayed, check if the AWS IoT configuration was set up correctly and if the device certificate and key were properly configured.

If you are still having problems, Check related category in our WIZnet Forum.