81 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
		
		
			
		
	
	
			81 lines
		
	
	
		
			1.8 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 _IRQ_H
							 | 
						||
| 
								 | 
							
								#define _IRQ_H
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#include "os_types.h"
							 | 
						||
| 
								 | 
							
								#include "iot_config.h"
							 | 
						||
| 
								 | 
							
								#if HW_PLATFORM > HW_PLATFORM_SIMU
							 | 
						||
| 
								 | 
							
								#include "irq_hw.h"
							 | 
						||
| 
								 | 
							
								#endif
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#ifdef __cplusplus
							 | 
						||
| 
								 | 
							
								extern "C" {
							 | 
						||
| 
								 | 
							
								#endif
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/*
							 | 
						||
| 
								 | 
							
								* interrupt priority
							 | 
						||
| 
								 | 
							
								*/
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								typedef enum {
							 | 
						||
| 
								 | 
							
								    HAL_INTR_PRI_0  = 0,
							 | 
						||
| 
								 | 
							
								    HAL_INTR_PRI_1,
							 | 
						||
| 
								 | 
							
								    HAL_INTR_PRI_2,
							 | 
						||
| 
								 | 
							
								    HAL_INTR_PRI_3,
							 | 
						||
| 
								 | 
							
								    HAL_INTR_PRI_4,
							 | 
						||
| 
								 | 
							
								    HAL_INTR_PRI_5,
							 | 
						||
| 
								 | 
							
								    HAL_INTR_PRI_6,
							 | 
						||
| 
								 | 
							
								    HAL_INTR_PRI_7,
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    HAL_INTR_PRI_MAX
							 | 
						||
| 
								 | 
							
								}IOT_INTR_PRIORITY;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/*
							 | 
						||
| 
								 | 
							
								 * interrupt's cpu core
							 | 
						||
| 
								 | 
							
								*/
							 | 
						||
| 
								 | 
							
								typedef enum{
							 | 
						||
| 
								 | 
							
								    HAL_INTR_CPU_0 = 0,
							 | 
						||
| 
								 | 
							
								    HAL_INTR_CPU_1,
							 | 
						||
| 
								 | 
							
								    HAL_INTR_CPU_2,
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    HAL_INTR_CPU_MAX
							 | 
						||
| 
								 | 
							
								}IOT_INTR_CPU;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								typedef iot_addrword_t iot_irq_t;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/*
							 | 
						||
| 
								 | 
							
								* interrupt service routine prototype.
							 | 
						||
| 
								 | 
							
								*/
							 | 
						||
| 
								 | 
							
								typedef uint32_t iot_isr_t( uint32_t vector, iot_addrword_t data);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								typedef struct iot_interrupt
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
								    uint8_t         vector;
							 | 
						||
| 
								 | 
							
								    uint8_t         priority;
							 | 
						||
| 
								 | 
							
								    uint8_t         cpu;
							 | 
						||
| 
								 | 
							
								    uint8_t         rsvd;
							 | 
						||
| 
								 | 
							
								    iot_isr_t       *isr;
							 | 
						||
| 
								 | 
							
								    iot_addrword_t  data;
							 | 
						||
| 
								 | 
							
								} iot_interrupt;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								void hal_deliver_interrupt( uint32_t vector );
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#ifdef __cplusplus
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								#endif
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#endif //_IRQ_H
							 |