| 
									
										
										
										
											2024-09-28 14:24:04 +08:00
										 |  |  | /****************************************************************************
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 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; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-22 14:20:46 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | // 差分模式的差异 是对比的二进制差异
 | 
					
						
							| 
									
										
										
										
											2024-09-28 14:24:04 +08:00
										 |  |  | 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
 |