guo ecf2d82159
sync branch rt-smart. (#6641)
* Synchronize the code of the rt mart branch to the master branch.
  * TTY device
  * Add lwP code from rt-smart
  * Add vnode in DFS, but DFS will be re-write for rt-smart
  * There are three libcpu for rt-smart:
    * arm/cortex-a, arm/aarch64
    * riscv64

Co-authored-by: Rbb666 <zhangbingru@rt-thread.com>
Co-authored-by: zhkag <zhkag@foxmail.com>
2022-12-03 12:07:44 +08:00

147 lines
5.3 KiB
C

/*
*********************************************************************************************************
* AR100 SYSTEM
* AR100 Software System Develop Kits
* interrupt module
*
* (c) Copyright 2012-2016, Sunny China
* All Rights Reserved
*
* File : intc.h
* By : Sunny
* Version : v1.0
* Date : 2012-4-27
* Descript: interrupt controller public header.
* Update : date auther ver notes
* 2012-4-27 10:52:56 Sunny 1.0 Create this file.
*********************************************************************************************************
*/
#ifndef __INTC_H__
#define __INTC_H__
#include <hal_interrupt.h>
#include <sunxi_hal_common.h>
/*
*********************************************************************************************************
* INIT INTERRUPT MANAGER
*
* Description: initialize interrupt manager.
*
* Arguments : none.
*
* Returns : OK if initialize interrupt manager succeeded, others if failed.
*********************************************************************************************************
*/
s32 interrupt_init(void);
/*
*********************************************************************************************************
* EXIT INTERRUPT MANAGER
*
* Description: exit interrupt manager.
*
* Arguments : none.
*
* Returns : OK if exit interrupt manager succeeded, others if failed.
*********************************************************************************************************
*/
s32 interrupt_exit(void);
/*
*********************************************************************************************************
* ENABLE INTERRUPT
*
* Description: enable a specific interrupt.
*
* Arguments : intno : the number of interrupt which we want to enable.
*
* Returns : OK if enable interrupt succeeded, others if failed.
*********************************************************************************************************
*/
s32 interrupt_enable(u32 intno);
/*
*********************************************************************************************************
* DISABLE INTERRUPT
*
* Description: disable a specific interrupt.
*
* Arguments : intno : the number of interrupt which we want to disable.
*
* Returns : OK if disable interrupt succeeded, others if failed.
*********************************************************************************************************
*/
s32 interrupt_disable(u32 intno);
/*
*********************************************************************************************************
* SET NMI TRIGGER
*
* Description: set nmi trigger.
*
* Arguments : type : the trigger type.
*
* Returns : OK if set trigger type succeeded, others if failed.
*********************************************************************************************************
*/
s32 interrupt_set_nmi_trigger(u32 type);
s32 interrupt_set_mask(u32 intno, u32 mask);
s32 interrupt_set_group_config(u32 grp_irq_num, u32 mask);
/*
*********************************************************************************************************
* INSTALL ISR
*
* Description: install ISR for a specific interrupt.
*
* Arguments : intno : the number of interrupt which we want to install ISR.
* pisr : the ISR which to been install.
* parg : the argument for the ISR.
*
* Returns : OK if install ISR succeeded, others if failed.
*
* Note : the ISR execute entironment : CPU disable interrupt response.
*********************************************************************************************************
*/
s32 install_isr(u32 intno, __pISR_hdle_t pisr, void *parg);
/*
*********************************************************************************************************
* UNINSTALL ISR
*
* Description: uninstall ISR for a specific interrupt.
*
* Arguments : intno : the number of interrupt which we want to uninstall ISR.
* pisr : the ISR which to been uninstall.
*
* Returns : OK if uninstall ISR succeeded, others if failed.
*********************************************************************************************************
*/
s32 uninstall_isr(u32 intno, __pISR_hdle_t pisr);
/*
*********************************************************************************************************
* INTERRUPT ENTRY
*
* Description: the entry of CPU IRQ, mainly for CPU IRQ exception.
*
* Arguments : none.
*
* Returns : OK if process CPU IRQ succeeded, others if failed.
*********************************************************************************************************
*/
s32 interrupt_entry(void);
s32 interrupt_query_pending(u32 intno);
s32 interrupt_clear_pending(u32 intno);
u32 interrupt_get_current_intno(void);
s32 interrupt_standby_enter(void);
s32 interrupt_standby_exit(void);
#endif /* __INTC_H__ */