141 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			141 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /****************************************************************************
 | |
| 
 | |
| Copyright(c) 2019 by Aerospace C.Power (Chongqing) Microelectronics. ALL RIGHTS RESERVED.
 | |
| 
 | |
| This Information is proprietary to Aerospace C.Power (Chongqing) Microelectronics and MAY NOT
 | |
| be copied by any method or incorporated into another program without
 | |
| the express written consent of Aerospace C.Power. This Information or any portion
 | |
| thereof remains the property of Aerospace C.Power. The Information contained herein
 | |
| is believed to be accurate and Aerospace C.Power assumes no responsibility or
 | |
| liability for its use in any way and conveys no license or title under
 | |
| any patent or copyright and makes no representation or warranty that this
 | |
| Information is free from patent or copyright infringement.
 | |
| 
 | |
| ****************************************************************************/
 | |
| 
 | |
| #ifndef __PLC_CONN_LESS_H
 | |
| #define __PLC_CONN_LESS_H
 | |
| 
 | |
| /* os shim includes */
 | |
| #include "os_types.h"
 | |
| 
 | |
| #include "iot_config.h"
 | |
| #include "iot_utils_api.h"
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| extern "C" {
 | |
| #endif
 | |
| 
 | |
| #define PLC_CONN_LESS_APP_PORT              0x11
 | |
| #define PLC_CONN_LESS_APP_ID_CONFIG_ACK     0xFF02
 | |
| 
 | |
| /* define the priority of configuring ack messages */
 | |
| #define PLC_CONN_LESS_CONFIG_ACK_PRIO       3
 | |
| /* define the retry cnt of configuring ack messages */
 | |
| #define PLC_CONN_LESS_CONFIG_ACK_RETRY_CNT  5
 | |
| 
 | |
| /* defining function code */
 | |
| #define PLC_CONN_LESS_FN_CTRL               10
 | |
| #define PLC_CONN_LESS_FN_DATA_TRANS         11
 | |
| 
 | |
| 
 | |
| /* defining the minimum duration of configuring connectionless mode,
 | |
|  * uint is 1s.
 | |
|  */
 | |
| #define PLC_CONN_LESS_MODE_DUR_MIN          30
 | |
| 
 | |
| /* defining the duration of clearing msdu cache in connectionless mode,
 | |
|  * uint is 1ms.
 | |
|  */
 | |
| #define PLC_CONN_LESS_MODE_CLEAR_MSDU_DUR   (5 * 60 * 1000)
 | |
| 
 | |
| /* define target device type ID */
 | |
| #define PLC_CONN_LESS_TARGET_ID_CCO     0
 | |
| #define PLC_CONN_LESS_TARGET_ID_STA     1
 | |
| 
 | |
| /* defining target device type identifier mask */
 | |
| #define PLC_CONN_LESS_TARGET_ID_MSK_CCO (1 << PLC_CONN_LESS_TARGET_ID_CCO)
 | |
| #define PLC_CONN_LESS_TARGET_ID_MSK_STA (1 << PLC_CONN_LESS_TARGET_ID_STA)
 | |
| 
 | |
| /* pack for the structures in the whole file */
 | |
| #pragma pack(push)  /* save the pack status */
 | |
| #pragma pack(1)     /* 1 byte align */
 | |
| 
 | |
| /* connectionless data packet header */
 | |
| typedef struct _plc_conn_less_hdr {
 | |
|     /* source address */
 | |
|     uint8_t     src_mac[IOT_MAC_ADDR_LEN];
 | |
|     /* destination address */
 | |
|     uint8_t     dst_mac[IOT_MAC_ADDR_LEN];
 | |
|     /* function code */
 | |
|     uint16_t    fn      :4,
 | |
|     /* payload length */
 | |
|                 len     :12;
 | |
|     /* payload label */
 | |
|     uint8_t     data[0];
 | |
| } plc_conn_less_hdr_t;
 | |
| 
 | |
| typedef struct _plc_conn_less_ext_config {
 | |
|     /* flag to mark if rf_option and rf_channel config is available */
 | |
|     uint8_t     rf_valid            :1,
 | |
|     /* flag to mark if rf_tx_power config is available */
 | |
|                 rf_power_valid      :1,
 | |
|     /* flag to mark if hplc_tx_power config is available */
 | |
|                 hplc_power_valid    :1,
 | |
|     /* rf tx only for app */
 | |
|                 rf_tx_only          :1,
 | |
|     /* reserved for future */
 | |
|                 rsvd1               :4;
 | |
|     /* rf option, see IOT_PLC_RF_OPTION_XX */
 | |
|     uint8_t     rf_option;
 | |
|     /* rf channel, see IOT_PLC_OPTION1_CHANNEL_ID_XX */
 | |
|     uint8_t     rf_channel;
 | |
|     /* tx power of rf, unit is 1 dbm */
 | |
|     int8_t      rf_tx_power;
 | |
|     /* tx power of hplc, unit is 1 dbuv */
 | |
|     uint8_t     hplc_tx_power;
 | |
|     /* reserved for future */
 | |
|     uint8_t     rsvd2[5];
 | |
| } plc_conn_less_ext_config_t;
 | |
| 
 | |
| typedef struct _plc_conn_less_mode_config {
 | |
|     /* band ID to be configured, see BEACON_FREQ_BAND_ID_XXX */
 | |
|     uint8_t     band_id;
 | |
|     /* configuring effective duration, uint is 1s */
 | |
|     uint8_t     dur;
 | |
|     /* the target device ID group that needs to respond to this command.
 | |
|      * see PLC_CONN_LESS_TARGET_ID_MSK_XXX.
 | |
|      */
 | |
|     uint32_t    target_id_mask      :2,
 | |
|     /* reserved for future */
 | |
|                 reserved            :29,
 | |
|     /* flag to mark if ext config is enabled.
 | |
|      * 1 means enable, 0 means disable
 | |
|      */
 | |
|                 ext_cfg_en          :1;
 | |
|     /* ext configuration */
 | |
|     plc_conn_less_ext_config_t ext_cfg[0];
 | |
| } plc_conn_less_mode_config_t;
 | |
| 
 | |
| /* connectionless application protocol frame header */
 | |
| typedef struct _plc_conn_less_app_hdr {
 | |
|     uint8_t     port;
 | |
|     uint16_t    id;
 | |
|     uint8_t     data[0];
 | |
| } plc_conn_less_app_hdr_t;
 | |
| 
 | |
| /* configuration acknowledgement message */
 | |
| typedef struct _plc_conn_less_app_config_ack {
 | |
|     /* current working band ID */
 | |
|     uint8_t band_id;
 | |
| } plc_conn_less_app_config_ack_t;
 | |
| 
 | |
| #pragma pack(pop)
 | |
| 
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| }
 | |
| #endif
 | |
| 
 | |
| #endif
 |