Skip to content

WINC1500 Module

This module implements the winc1500 wifi driver. At the moment some functionalities are missing:

  • wifi ap mode
  • wifi direct p2p mode
  • internal firmware ota upgrade

It can be used to enable Arduino/Genuino MKR1000 wifi capabilities or with any other device mounting Microchip WINC1500 IEEE 802.11 network controller.

Zerynth driver current implementation supports only communication with the chip through standard SPI interface.

Note

Zerynth driver is based on Microchip driver version 19.5.4 provided with Advanced Software Framework version 3.37.0 requiring the internal Firmware to be upgraded at least to version 19.5.4. For the upgrading procedure follow this guide: Firmware Updater.

The WINC1500 chip supports secure connections through tls v1.2. To take advantage of this feature import the ssl module or simply try https requests with Zerynth requests module.

Note

To access securely specific websites root certificates must be loaded on the chip: Certificate Uploading.

To use the module expand on the following example:

from microchip.winc1500 import winc1500 as wifi_driver
from wireless import wifi

wifi_driver.auto_init()
for retry in range(10):
    try:
        wifi.link("Network-SSID", wifi.WIFI_WPA2, "password")
        break
    except Exception as e:
        print(e)

if not wifi.is_linked():
    raise IOError
init

init(spidrv, cs, int_pin, rst, enable, wake, clock)

To initialize the driver the following parameters are needed:

  • MCU SPI circuitry spidrv (one of SPI0, SPI1, … check pinmap for details);
  • chip select pin cs;
  • interrupt pin int_pin;
  • reset pin rst;
  • enable pin enable;
  • wake pin wake (can be not set);
  • clock clock, default at 8MHz.

Note

For supported boards (e.g. Arduino/Genuino MKR1000), auto_init function is available with preset params.