Skip to content

Latest commit

 

History

History
129 lines (108 loc) · 9.55 KB

contrl_path.md

File metadata and controls

129 lines (108 loc) · 9.55 KB

Index

Control Path

  • Control path is intended to set up all configurations at ESP side. These configurations could be related to services like
    • Connect host with external AP (Wi-Fi router)
    • Get configurations of external AP which host is connected
    • Set maximum Wi-Fi transmit power of ESP
    • Find out current Wi-Fi power of ESP
  • Control path command could be considered as first step before you can establish data path
  • It is a way to verify if ESP-Hosted transport like SPI, SDIO is set up correctly
  • Control path is a sole way to control and manage ESP
  • It is responsive medium in between end user and ESP, which will facilitate user for any changes to be done at ESP and which will notify user for any important events
  • The following sections will detail overall control path design and easy setup of control path using demo application

1. Host Serial Driver

  • Prerequisite for host serial driver is that the hosted transport like SPI, SDIO is set up
  • Host serial driver consists of two elements
    • Virtual Serial Interface
    • Serial Driver
  • host Serial driver is used in the following way
    Demo App -> Control API -> Hosted Control Library -> Virtual Serial Interface ->
    Serial Driver -> ESP-Hosted transport like SPI/SDIO \

    Layer Remarks Access
    Demo App Control path application
    Control path API Interface in between Demo app and Hosted Control Library
    Hosted Control Library Platform and transport agnostic library to configure and manage ESP chipset from host
    Virtual Serial Interface Platform independent thin abstraction of serial driver
    Serial Driver Platform specific abstraction to serial character driver
    ESP-Hosted transport Ex. SPI, SDIO etc

1.1 Virtual serial interface

1.2 Serial Driver

  • Serial driver is implemented specific to platform.
  • Reason is that every platform serial interface could be differently available
    For example, MPU represents serial driver using serial character driver file like /dev/esps0 but in case of MCU, it will be more of virtual entity.
  • Code for MPU based serial driver is at platform_wrapper.h
  • Serial Driver exposes Serial Driver APIs for Virtual Serial Interface

2. Types of control messages

Control messages divided into three type,

  • Control Request
  • Control Response
  • Control Event

A Control request is a request to be served and sent from host to ESP. Demo application with help of hosted control lib, triggers control request. When this request reaches ESP, it is protobuf decoded and responded as control response. Control events are based on subscriber-notification model. Basically demo application when subscribed to a specific event with a function callback, the function would be called when the event is triggered. Heartbeat is one example of a control event, which will simply let us know the ESP is alive periodically.

3. Design

ESP-Hosted Control Path Design

  • Above detailed diagram showcases how all the control messages are handled at host side
  • The Demo application is at the top, which uses control path APIs exposed by Hosted control library. Hosted control lib in turn uses the virtual serial interface exposed by Host serial driver
  • Host serial driver implements virtual serial interface which is abstraction to lower level functionalities like open/read/write/close functions
  • Although the diagram does not showcase how control path messages are used in ESP, they are pretty similar to that of host
  • ESP side code uses protocom which is ready usable IDF component which leverages protobuf encoding and decoding functionalities

3.1 Control path components

There are two components in control path. Hosted control lib and Demo app. Demo App uses control APIs to communicate to hosted control lib.

3.1.1 Hosted Control Lib
  • Hosted control library is available as base library which exposes control APIs so that user application could be easily integrated
  • It is responsible for Protobuf encoding and decoding
  • Control path APIs are exposed in ctrl_api.h file
  • Control path library is implemented with source files, ctrl_api.c and ctrl_core.c which interact with platform
  • Hosted control lib works over Host Serial Driver
  • If the need be, the user can add a new control path message. Protobuf encoding and decoding of new control message to be added as part of this library
3.1.2 Demo App
  • Demo App is sample user application developed on top of hosted control library
  • This way, the end user can create the expected application with minimal or no change to hosted control library
  • Demo application creates control message using structures exposed in ctrl_api.h. These structures are used along with control path APIs to send a control request and parse a control response or a control event
  • We will take liberty to refer demo app as application in upcoming chapters

4. API documentation

The structures and API functions are documented in Control APIs. These APIs are common for MCU and MPU based hosts.

5. Kick-start using Control path

To set up control path, C based demo app and Python based demo app are already bundled which use control APIs. In these applications, API implementation is showcased, with some APIs implemented as asynchronous and rest APIs implemented as synchronous. Either of these could be used to test control path API.

5.1 Synchronous and Asynchronous communication

  • Control path is said to be complete when the response is received for a control request. But handling the control response could be done either synchronous or asynchronous.
  • As discussed in API documentation, a structure, ctrl_cmd_t is the main structure that the application will make use of to work on any control message.
  • Every control API could be used as synchronous or asynchronous by application
  • Any synchronous API could easily be converted into asynchronous and vice versa
5.1.1 Synchronous
  • When the control request is created using ctrl_cmd_t and when ctrl_resp_cb function from structure pointer is set to NULL while using control API, it is regarded as synchronous usage
  • In synchronous communication, when a request is sent, the application would be blocked till the response is received
  • The control API used as synchronous, API function would return control response populated as ctrl_cmd_t * and application would be responsible to parse the response
5.1.2 Asynchronous
  • Asynchronous Response handling

    • When the control request is created using ctrl_cmd_t and when ctrl_resp_cb function from structure pointer is set to valid function pointer while using control API, it is regarded as asynchronous usage
    • In asynchronous communication, application would define a function, which would be automatically called as a callback when hosted control library receives a control response from ESP
    • As a difference, when API is used as asynchronous, will return immediately after sending the control request without blocking for the response
    • When control API is used as asynchronous, API function call returns NULL
    • Note
      • In case of asynchronous, a timer is started of command timeout value. In case response not received within command timeout time, response callback function would be called with failure status
      • Application should wait at least till the command timeout duration after firing control request
  • Event handling

    • Control events are always asynchronous in nature as there will not be any control request associated with them
    • Application has choice to which events it wants to subscribe using control API set_event_callback with specific event id and an event callback function
    • When hosted control lib receives an event from ESP, it will invoke event callback function registered

6. Limitations

  • Serial interface can handle a single control request at a time
  • UART transport is not supported for control path