100 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			100 lines
		
	
	
		
			4.0 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 IOT_OEM_STRUCT_V1_H
 | |
| #define IOT_OEM_STRUCT_V1_H
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| extern "C" {
 | |
| #endif
 | |
| 
 | |
| /* pack for the structures in the whole file */
 | |
| #pragma pack(push)  // save the pack status
 | |
| #pragma pack(1)     // 1 byte align
 | |
| 
 | |
| /* ================= board information structures version 1 ================= */
 | |
| /* defines most peripherals resource allocation, supports differential saving
 | |
|  * of different resource tables, differential data is saved after the oem structure.
 | |
|  */
 | |
| 
 | |
| /* define the number of hardware resource */
 | |
| #define IOT_PIN_MAX_NUM_V1         62  //gpio connected to pins, 42(kl3) + 20(resv)
 | |
| #define IOT_UART_MAX_NUM_V1        8
 | |
| #define IOT_PWM_MAX_NUM_V1         (6 * 2)  //channel number
 | |
| #define IOT_ADC_MAX_NUM_V1         (2 * 10)  //channel number
 | |
| #define IOT_LEDC_MAX_NUM_V1        8
 | |
| #define IOT_SPI_MAX_NUM_V1         4   //mseter * 3, slaver * 1
 | |
| #define IOT_I2C_MAX_NUM_V1         4
 | |
| #define IOT_SPINLOCK_MAX_NUM_V1    16
 | |
| #define IOT_DMA_MAX_NUM_V1         (11 + 10 + 4)  //channel number
 | |
| #define IOT_GPTIMER_MAX_NUM_V1     (3 * 4)
 | |
| #define IOT_MAILBOX_MAX_NUM_V1     6
 | |
| #define IOT_WDG_MAX_NUM_V1         3
 | |
| 
 | |
| typedef struct _iot_pin_cfg_v1_t{
 | |
|     uint8_t gpio;   //gpio number
 | |
|     uint8_t core;   //which core is gpio used by
 | |
|     uint8_t func;   //pin function
 | |
|     uint8_t inid;   //input signal number
 | |
|     uint8_t outid;  //output signal number
 | |
|     uint8_t purpose;    //purpose of gpio, see iot_board_api.h/GPIO_XXX
 | |
| } iot_pin_cfg_v1_t;
 | |
| 
 | |
| typedef struct _iot_peripheral_cfg_v1_t {
 | |
|     uint8_t core;   //which core is peripheral used by
 | |
|     uint8_t purpose;    //purpose of peripheral
 | |
| } iot_peripheral_cfg_v1_t;
 | |
| 
 | |
| typedef struct _iot_oem_rc_hdr_v1_t {
 | |
|     uint32_t crc;   //crc of the current complete resource table
 | |
|     uint32_t hw_version;    //hardware version of current resource table
 | |
|     uint32_t diff_hw_ver;   //hardware version of difference resource table
 | |
|     uint16_t length;   //resource length, not include hdr_t
 | |
|     uint16_t mode        : 2,    //diff mode or not
 | |
|              have_next   : 1,    //have next resource or not
 | |
|              resv        : 13;
 | |
| } iot_oem_rc_hdr_v1_t;
 | |
| 
 | |
| typedef struct _iot_oem_rc_diff_v1_t {
 | |
|     uint16_t offset;    //diff beginning offset, respect to iot_board_info_v1_t
 | |
|     uint16_t length;    //current diff block length
 | |
|     uint8_t data[0];    //diff data
 | |
| } iot_oem_rc_diff_v1_t;
 | |
| 
 | |
| typedef struct _iot_board_info_v1_t {
 | |
|     iot_oem_rc_hdr_v1_t hdr;
 | |
|     iot_pin_cfg_v1_t pin[IOT_PIN_MAX_NUM_V1];
 | |
|     iot_peripheral_cfg_v1_t uart[IOT_UART_MAX_NUM_V1];
 | |
|     iot_peripheral_cfg_v1_t pwm[IOT_PWM_MAX_NUM_V1];
 | |
|     iot_peripheral_cfg_v1_t adc[IOT_ADC_MAX_NUM_V1];
 | |
|     iot_peripheral_cfg_v1_t ledc[IOT_LEDC_MAX_NUM_V1];
 | |
|     iot_peripheral_cfg_v1_t spi[IOT_SPI_MAX_NUM_V1];
 | |
|     iot_peripheral_cfg_v1_t i2c[IOT_I2C_MAX_NUM_V1];
 | |
|     iot_peripheral_cfg_v1_t spinlock[IOT_SPINLOCK_MAX_NUM_V1];
 | |
|     iot_peripheral_cfg_v1_t dma[IOT_DMA_MAX_NUM_V1];
 | |
|     iot_peripheral_cfg_v1_t gptimer[IOT_GPTIMER_MAX_NUM_V1];
 | |
|     iot_peripheral_cfg_v1_t mailbox[IOT_MAILBOX_MAX_NUM_V1];
 | |
|     iot_peripheral_cfg_v1_t wdg[IOT_WDG_MAX_NUM_V1];
 | |
|     uint8_t padding[18];  //642 - 608(rc) - 16(hdr)
 | |
| } iot_board_info_v1_t;
 | |
| 
 | |
| #pragma pack(pop)   // restore the pack status
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| }
 | |
| #endif
 | |
| 
 | |
| #endif
 |