2018-06-28 17:45:41 +02:00
|
|
|
// Copyright 2015-2016 Espressif Systems (Shanghai) PTE LTD
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
|
|
|
|
// mbcontroller.h
|
|
|
|
// Implementation of the MbController
|
|
|
|
|
|
|
|
#ifndef _MODBUS_CONTROLLER
|
|
|
|
#define _MODBUS_CONTROLLER
|
|
|
|
|
|
|
|
#include <stdint.h> // for standard int types definition
|
|
|
|
#include <stddef.h> // for NULL and std defines
|
|
|
|
#include "soc/soc.h" // for BITN definitions
|
|
|
|
#include "sdkconfig.h" // for KConfig options
|
|
|
|
#include "driver/uart.h" // for uart port number defines
|
|
|
|
|
|
|
|
/* ----------------------- Defines ------------------------------------------*/
|
|
|
|
#define MB_INST_MIN_SIZE (2) // The minimal size of Modbus registers area in bytes
|
2019-01-07 11:33:20 +01:00
|
|
|
#define MB_INST_MAX_SIZE (65535 * 2) // The maximum size of Modbus area in bytes
|
2018-06-28 17:45:41 +02:00
|
|
|
|
|
|
|
#define MB_CONTROLLER_STACK_SIZE (CONFIG_MB_CONTROLLER_STACK_SIZE) // Stack size for Modbus controller
|
|
|
|
#define MB_CONTROLLER_PRIORITY (CONFIG_MB_SERIAL_TASK_PRIO - 1) // priority of MB controller task
|
|
|
|
#define MB_CONTROLLER_NOTIFY_QUEUE_SIZE (CONFIG_MB_CONTROLLER_NOTIFY_QUEUE_SIZE) // Number of messages in parameter notification queue
|
|
|
|
#define MB_CONTROLLER_NOTIFY_TIMEOUT (pdMS_TO_TICKS(CONFIG_MB_CONTROLLER_NOTIFY_TIMEOUT)) // notification timeout
|
|
|
|
|
|
|
|
// Default port defines
|
|
|
|
#define MB_DEVICE_ADDRESS (1) // Default slave device address in Modbus
|
|
|
|
#define MB_DEVICE_SPEED (115200) // Default Modbus speed for now hard defined
|
|
|
|
#define MB_UART_PORT (UART_NUM_2) // Default UART port number
|
|
|
|
#define MB_PAR_INFO_TOUT (10) // Timeout for get parameter info
|
|
|
|
#define MB_PARITY_NONE (UART_PARITY_DISABLE)
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Event group for parameters notification
|
|
|
|
*/
|
|
|
|
typedef enum
|
|
|
|
{
|
|
|
|
MB_EVENT_NO_EVENTS = 0x00,
|
|
|
|
MB_EVENT_HOLDING_REG_WR = BIT0, /*!< Modbus Event Write Holding registers. */
|
|
|
|
MB_EVENT_HOLDING_REG_RD = BIT1, /*!< Modbus Event Read Holding registers. */
|
|
|
|
MB_EVENT_INPUT_REG_RD = BIT3, /*!< Modbus Event Read Input registers. */
|
|
|
|
MB_EVENT_COILS_WR = BIT4, /*!< Modbus Event Write Coils. */
|
|
|
|
MB_EVENT_COILS_RD = BIT5, /*!< Modbus Event Read Coils. */
|
|
|
|
MB_EVENT_DISCRETE_RD = BIT6, /*!< Modbus Event Read Discrete bits. */
|
|
|
|
MB_EVENT_STACK_STARTED = BIT7 /*!< Modbus Event Stack started */
|
|
|
|
} mb_event_group_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Type of Modbus parameter
|
|
|
|
*/
|
|
|
|
typedef enum
|
|
|
|
{
|
|
|
|
MB_PARAM_HOLDING, /*!< Modbus Holding register. */
|
|
|
|
MB_PARAM_INPUT, /*!< Modbus Input register. */
|
|
|
|
MB_PARAM_COIL, /*!< Modbus Coils. */
|
|
|
|
MB_PARAM_DISCRETE, /*!< Modbus Discrete bits. */
|
|
|
|
MB_PARAM_COUNT,
|
|
|
|
MB_PARAM_UNKNOWN = 0xFF
|
|
|
|
} mb_param_type_t;
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* \brief Modbus serial transmission modes (RTU/ASCII).
|
|
|
|
*/
|
|
|
|
typedef enum
|
|
|
|
{
|
|
|
|
MB_MODE_RTU, /*!< RTU transmission mode. */
|
|
|
|
MB_MODE_ASCII, /*!< ASCII transmission mode. */
|
|
|
|
MB_MODE_TCP /*!< TCP mode. */
|
|
|
|
} mb_mode_type_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Parameter access event information type
|
|
|
|
*/
|
|
|
|
typedef struct {
|
|
|
|
uint32_t time_stamp; /*!< Timestamp of Modbus Event (uS)*/
|
|
|
|
uint16_t mb_offset; /*!< Modbus register offset */
|
|
|
|
mb_event_group_t type; /*!< Modbus event type */
|
|
|
|
uint8_t* address; /*!< Modbus data storage address */
|
|
|
|
size_t size; /*!< Modbus event register size (number of registers)*/
|
|
|
|
} mb_param_info_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Parameter storage area descriptor
|
|
|
|
*/
|
|
|
|
typedef struct {
|
|
|
|
uint16_t start_offset; /*!< Modbus start address for area descriptor */
|
|
|
|
mb_param_type_t type; /*!< Type of storage area descriptor */
|
|
|
|
void* address; /*!< Instance address for storage area descriptor */
|
|
|
|
size_t size; /*!< Instance size for area descriptor (bytes) */
|
|
|
|
} mb_register_area_descriptor_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Device communication parameters
|
|
|
|
*/
|
|
|
|
typedef struct {
|
|
|
|
mb_mode_type_t mode; /*!< Modbus communication mode */
|
|
|
|
uint8_t slave_addr; /*!< Modbus Slave Address */
|
|
|
|
uart_port_t port; /*!< Modbus communication port (UART) number */
|
|
|
|
uint32_t baudrate; /*!< Modbus baudrate */
|
|
|
|
uart_parity_t parity; /*!< Modbus UART parity settings */
|
|
|
|
} mb_communication_info_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Initialize modbus controller and stack
|
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* - ESP_OK Success
|
|
|
|
* - ESP_FAIL Parameter error
|
|
|
|
*/
|
|
|
|
esp_err_t mbcontroller_init(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Destroy Modbus controller and stack
|
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* - ESP_OK Success
|
|
|
|
* - ESP_FAIL Parameter error
|
|
|
|
*/
|
|
|
|
esp_err_t mbcontroller_destroy(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Start Modbus communication stack
|
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* - ESP_OK Success
|
|
|
|
* - ESP_ERR_INVALID_ARG Modbus stack start error
|
|
|
|
*/
|
|
|
|
esp_err_t mbcontroller_start(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Set Modbus communication parameters for the controller
|
|
|
|
*
|
|
|
|
* @param comm_info Communication parameters structure.
|
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* - ESP_OK Success
|
|
|
|
* - ESP_ERR_INVALID_ARG Incorrect parameter data
|
|
|
|
*/
|
|
|
|
esp_err_t mbcontroller_setup(mb_communication_info_t comm_info);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Wait for specific event on parameter change.
|
|
|
|
*
|
|
|
|
* @param group Group event bit mask to wait for change
|
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* - mb_event_group_t event bits triggered
|
|
|
|
*/
|
|
|
|
mb_event_group_t mbcontroller_check_event(mb_event_group_t group);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Get parameter information
|
|
|
|
*
|
|
|
|
* @param[out] reg_info parameter info structure
|
|
|
|
* @param timeout Timeout in milliseconds to read information from
|
|
|
|
* parameter queue
|
|
|
|
* @return
|
|
|
|
* - ESP_OK Success
|
|
|
|
* - ESP_ERR_TIMEOUT Can not get data from parameter queue
|
|
|
|
* or queue overflow
|
|
|
|
*/
|
|
|
|
esp_err_t mbcontroller_get_param_info(mb_param_info_t* reg_info, uint32_t timeout);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Set Modbus area descriptor
|
|
|
|
*
|
|
|
|
* @param descr_data Modbus registers area descriptor structure
|
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* - ESP_OK: The appropriate descriptor is set
|
|
|
|
* - ESP_ERR_INVALID_ARG: The argument is incorrect
|
|
|
|
*/
|
|
|
|
esp_err_t mbcontroller_set_descriptor(mb_register_area_descriptor_t descr_data);
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|