Skip to content

An example for connecting the Microchip SAM-IoT Wx board to Azure IoT using the Azure SDK for C.

License

Notifications You must be signed in to change notification settings

crypto-lars/Microchip-SAM-IoT-Wx

 
 

Repository files navigation

Provisioning the Microchip SAM-IoT WG Development Board (Part No. EV75S95A) for Azure IoT Services

Introduction

This document describes how to connect the SAM-IoT WG Development Board (featuring a 32-bit ATSAMD21G18A MCU, ATECC608B secure element, and ATWINC1510 Wi-Fi network controller module) to Azure IoT Central and/or Hub which leverages Microsoft’s Azure IoT Embedded C SDK. The SAM-IoT WG Development Board will be provisioned for use with Azure IoT services using self-signed X.509 certificate-based authentication.

Table of Contents

Background Knowledge

SAM-IoT WG Development Board Overview & Features (SMART | CONNECTED | SECURE)

Download the SAM-IoT WG Development Board User Guide for more details including the schematics for the board (do not follow the setup procedure in the document as it is for a Google Cloud demo)

Microchip “Provisioning” vs. Microsoft “Provisioning”

The term “provisioning” is used throughout this document (e.g. IoT Provisioning Tool, provisioning key, provisioning device, Device Provisioning Service, etc.). On the Microchip side, the provisioning process is to securely inject certificates into the hardware. From the context of Microsoft, provisioning is defined as the relationship between the hardware and the Cloud (Azure). Azure IoT Hub Device Provisioning Service (DPS) allows the hardware to be provisioned securely to the right IoT Hub.

High Level Architecture between the Client (SAM-IoT) and the Cloud (Azure)

This high-level architecture description summarizes the interactions between the SAM-IoT board and Azure. These are the major puzzle pieces that make up this enablement work of connecting SAM-IoT WG Developoment Board to Azure through DPS using X.509-based authentication:

  • ATECC608B: a secure element from the Microchip CryptoAuthentication portfolio. It securely stores a private key that is used to authenticate the hardware with cloud providers to uniquely identify every board

  • ATWINC1510: a low-power consumption Wi-Fi module that has access to the device certificate, signer CA certificate, and public key for mutual TLS handshaking between the board and the cloud

  • IoT Provisioning Tool: Microchip-provided tool for provisioning self-signed certificate utilizing the unique serial number and private key stored in the ATECC608B secure element

  • Azure IoT Embedded C SDK: Microsoft-provided API designed to allow small, low-cost embedded IoT devices to communicate with Azure services, serving as translation logic between the application code and transport client

  • Azure IoT Central: IoT Central is an IoT application platform that reduces the burden and cost of developing, managing, and maintaining enterprise-grade IoT solutions

  • Azure IoT Hub: IoT Hub is a managed service, hosted in the Cloud, that acts as a central message hub for bi-directional communication between your IoT application and the devices it manages

  • Device Provisioning Service (DPS): a helper service for IoT Hub that enables zero-touch, just-in-time provisioning to the right IoT Hub without requiring human intervention, allowing customers to automatically provision millions of devices in a secure and scalable manner

In a nutshell, we will use Microchip’s IoT Provisioning Tool to send a Certificate Signing Request (CSR) to the ATECC608B to generate a self-signed certificate chain which is then obtained by the ATWINC1510 Wi-Fi module to perform a TLS mutual handshake between the client (SAM-IoT board) and the server (Azure), specifically using DPS.

On successful authentication, the SAM-IoT board will be provisioned to the correct IoT Hub that is pre-linked to DPS during the setup process. We can then leverage Azure IoT Central or IoT Explorer (the web and graphical tools used for interacting with and testing your IoT devices, respectively). Note that the ATECC608B only contains the private key. The self-signed certificate chain including root CA, signer CA (or intermediate CA), and device is stored in the ATWINC1510 Wi-Fi module used for the TLS handshake.

Azure IoT Embedded C SDK

This is the high-level view of the Embedded C SDK which translates the application code into Azure-friendly logic that can be easily understood by Azure IoT Hub. Note that Microsoft is only responsible for the logic in the green box; it is up to the IoT Developer to provide the remaining layers of application code, Transport Client, TLS, and Socket. In the provided demo project, Microchip provides the layers in blue. Please reference the Azure SDK for Embedded C document for more details.

TLS connection

The TLS connection performs both authentication and encryption. Authentication consists of two parts:

  • Server authentication; the board authenticates the server
  • Client authentication; the server authenticates the board

Server authentication happens transparently to the user since the ATWINC1510 on the SAM-IoT board comes preloaded with the required CA certificate. During client authentication the client private key must be used, but since this is stored inside the ATECC608B chip and cannot be extracted, all calculations must be done inside the ATECC608B. The ATWINC1510 library offers an API to delegate the TLS calculations to the main application. The main application will in turn call the ATECC608B library API’s to perform the calculations. Before the TLS connection is complete, a shared secret key must be negotiated between the server and the client. This key is used to encrypt all future communications during the connection.

MQTT Connection

After successfully connecting on the TLS level, the board starts establishing the MQTT connection. Since the TLS handles authentication and security, MQTT does not have to provide a username or password.

Create an Azure Account and Subscription

Before connecting to Azure, you must first create a user account with a valid subscription. The Azure free account includes free access to popular Azure products for 12 months, $200 USD credit to spend for the first 30 days, and access to more than 25 products that are always free. This is an excellent way for new users to get started and explore.

To sign up, you need to have a phone number, a credit card, and a Microsoft or GitHub account. Credit card information is used for identity verification only. You won't be charged for any services unless you upgrade. Starting is free, plus you get $200 USD credit to spend during the first 30 days and free amounts of services. At the end of your first 30 days or after you spend your $200 USD credit (whichever comes first), you'll only pay for what you use beyond the free monthly amounts of services. To keep getting free services after 30 days, you can move to pay-as-you-go pricing. If you don't move to the pay-as-you-go plan, you can't purchase Azure services beyond your $200 USD credit — and eventually your account and services will be disabled. For additional details regarding the free account, check out the Azure free account FAQs.

When you sign up, an Azure subscription is created by default. An Azure subscription is a logical container used to provision resources in Azure. It holds the details of all your resources like virtual machines (VMs), databases, and more. When you create an Azure resource like a VM, you identify the subscription it belongs to. As you use the VM, the usage of the VM is aggregated and billed monthly. You can create multiple subscriptions for different purposes.

Sign up for a free Azure account for evaluation purposes by following the process outlined in the Microsoft Azure online tutorial. It is highly recommended to go through the entire section of the tutorial so that you fully understand what billing and support plans are available and how they all work.

Should you encounter any issues with your account or subscription, submit a technical support ticket.

Program the SAM-IoT WG Development Board

1. Install the Development Tools

Embedded software development tools from Microchip need to be pre-installed in order to properly program the SAM-IoT WG Development Board and provision it for use with Microsoft Azure IoT services.

Click this link for the setup procedure: Development Tools Installation

2. Provision the Development Board

Download and run Microchip's IoT Provisioning Tool which is used to (1) generate the security certificates used for authentication and (2) store them into the ATWINC1510 Wi-Fi controller module by executing the following steps:

  • Connect the Microchip SAM-IoT Development Board to the Host PC using a standard micro-USB cable

  • Confirm that a device named CURIOSITY shows up as a disk drive on the Desktop or in a File Explorer window

  • Launch a Command Prompt or PowerShell window (click on Start > type PowerShell in the Search field > Open)

  • Using the command line, navigate to the directory where the iotprovision-bin executable file resides (<my_path>\iotprovision-bin-2\windows64\)

  • Execute the following command line to launch the provisioning script

    .\iotprovision-bin.exe -c azure

3. Connect to Azure IoT Services

Azure IoT technologies and services provide you with options to create a wide variety of IoT solutions that enable digital transformation for your organization. For example, you can choose to use one of the following paths:

  • Use Azure IoT Central, a managed IoT application platform, to build and deploy a secure, enterprise-grade IoT solution. IoT Central features a collection of industry-specific application templates, such as retail and healthcare, to accelerate your solution development process

  • Use Azure IoT platform services such as Azure IoT Hub and the Azure IoT device SDKs to build a custom IoT solution from scratch

Click here for a good overview of the different IoT options on Azure. In summary, here are a couple of tables highlighting the differences between IoT Central and IoT Hub:

A screenshot of a cell phone Description automatically generated

  • a. IoT Central (Recommended)

    Azure IoT Central is an IoT application platform that reduces the burden and cost of developing, managing, and maintaining enterprise-grade IoT solutions. Choosing to build with IoT Central gives you the opportunity to focus time, money, and energy on transforming your business with IoT data, rather than just maintaining and updating a complex and continually evolving IoT infrastructure.

    The web UI lets you quickly connect devices, monitor device conditions, create rules, and manage millions of devices and their data throughout their life cycle. Furthermore, it enables you to act on device insights by extending IoT intelligence into line-of-business applications.

    Click this link for the programming procedure: Connecting the SAM-IoT WG Development Board to Azure IoT Central

  • b. IoT Hub

    Azure IoT Hub is a managed service, hosted in the Cloud, that acts as a central message hub for bi-directional communication between your IoT application and the devices it manages. You can use Azure IoT Hub to build IoT solutions with reliable and secure communications between millions of IoT devices and a Cloud-hosted solution backend. You can connect virtually any device to IoT Hub.

    IoT Hub supports communications both from the device to the cloud and from the cloud to the device. IoT Hub supports multiple messaging patterns such as device-to-cloud telemetry, file upload from devices, and request-reply methods to control your devices from the cloud. IoT Hub monitoring helps you maintain the health of your solution by tracking events such as device creation, device failures, and device connections.

    IoT Hub's capabilities help you build scalable, full-featured IoT solutions such as managing industrial equipment used in manufacturing, tracking valuable assets in healthcare, and monitoring office building usage.

    Click this link for the programming procedure: Connecting the Microchip SAM-IoT Wx Development Board to Azure IoT Hub

Frequently Asked Questions

Having issues with connecting the board with Azure IoT services? Check out the FAQ section

SAM-IoT as a Cloud Agent for an External Application Processor

The SAM-IoT-WM Version 2 device model adds interfaces for an external application processor to implement its own set of telemetry, properties, and commands. This allows for an existing application processor to relay its own data to the cloud, using the SAM-IoT as a cloud agent to handle all cloud operations. For example, an external application processor can report its own telemetry or read/write its own set of properties using commands implemented as part of the Command Line Interface. For larger burst-type telemetry reporting (e.g. > 100-byte chunks of data), an additional Dedicated Telemetry Interface (DTI) can be used by the external application processor to bypass the CLI (i.e. using SPI mode to send larger telemetry updates using data frames). Refer to the procedure for setting up the SAM-IoT as a cloud agent for connection to an external application processor.

References

Refer to the following links for additional information for IoT Explorer, IoT Hub, DPS, Plug and Play model, and IoT Central

Manage cloud device messaging with Azure-IoT-Explorer

Import the Plug and Play model

Configure to connect to IoT Hub

How to use IoT Explorer to interact with the device

Azure IoT Central - All Documentation

Create an Azure IoT Central application

Manage devices in your Azure IoT Central application

How to connect devices with X.509 certificates for IoT Central

Configure the IoT Central application dashboard

Customize the IoT Central UI

Conclusion

You are now able to connect SAM-IoT to Azure IoT services using self-signed X.509 certificate-based authentication and have deeper knowledge of how all the pieces of the puzzle fit together from the ATECC608B secure element, ATWINC1510 Wi-Fi, Azure Embedded C SDK, and Azure IoT Hub/Central/DPS. Let’s start thinking out of the box and see how you can apply this project to provision securely and quickly a massive number of Microchip devices to Azure and safely manage them through the entire product life cycle.

About

An example for connecting the Microchip SAM-IoT Wx board to Azure IoT using the Azure SDK for C.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C 90.2%
  • Makefile 9.8%