2013-01-08 21:05:02 +08:00
|
|
|
/*
|
|
|
|
* This file is only used for doxygen document generation.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @defgroup bsp Hardware Related Package
|
|
|
|
*
|
|
|
|
* @brief Hardware Related Package includes board support package(BSP) and CSP(Chip
|
|
|
|
* Support Package).
|
|
|
|
*
|
|
|
|
* Board Support Package(BSP) is the hardware related wrapper, for example, peripherals
|
|
|
|
* in board, the pinmux setting etc. In RT-Thread RTOS, the bsp is placed under bsp
|
|
|
|
* directory.
|
|
|
|
*
|
|
|
|
* Chip Support Package (CSP) is a software set that contains chip specific software.
|
|
|
|
* A CSP usually includes operating system porting and peripheral device drivers inside
|
|
|
|
* chip. In RT-Thread RTOS, the csp is placed under libcpu directory.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @addtogroup bsp
|
|
|
|
*/
|
|
|
|
/*@{*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This function will return current system interrupt status and disable system
|
|
|
|
* interrupt.
|
|
|
|
*
|
|
|
|
* @return the current system interrupt status
|
|
|
|
*/
|
|
|
|
rt_base_t rt_hw_interrupt_disable(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This function will set the specified interrupt status, which shall saved by
|
|
|
|
* rt_hw_intterrupt_disable function. If the saved interrupt status is interrupt
|
|
|
|
* opened, this function will open system interrupt status.
|
|
|
|
*/
|
|
|
|
void rt_hw_interrupt_enable(rt_base_t level);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This function initializes interrupt.
|
|
|
|
*/
|
|
|
|
void rt_hw_interrupt_init(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This function masks the specified interrupt.
|
|
|
|
*
|
|
|
|
* @param vector the interrupt number to be masked.
|
|
|
|
*
|
|
|
|
* @note not all of platform provide this function.
|
|
|
|
*/
|
|
|
|
void rt_hw_interrupt_mask(int vector);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This function umasks the specified interrupt.
|
|
|
|
*
|
|
|
|
* @param vector the interrupt number to be unmasked.
|
|
|
|
*
|
|
|
|
* @note not all of platform provide this function.
|
|
|
|
*/
|
|
|
|
void rt_hw_interrupt_umask(int vector);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This function will install specified interrupt handler.
|
|
|
|
*
|
|
|
|
* @param vector the interrupt number to be installed.
|
|
|
|
* @param new_handler the new interrupt handler.
|
|
|
|
* @param old_handler the old interrupt handler. This parameter can be RT_NULL.
|
|
|
|
*
|
|
|
|
* @note not all of platform provide this function.
|
|
|
|
*/
|
|
|
|
void rt_hw_interrupt_install(int vector, rt_isr_handler_t new_handler,
|
|
|
|
rt_isr_handler_t *old_handler);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This function will reset whole platform.
|
|
|
|
*/
|
|
|
|
void rt_hw_cpu_reset(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This function will halt whole platform.
|
|
|
|
*/
|
|
|
|
void rt_hw_cpu_shutdown(void);
|
|
|
|
|
|
|
|
/*@}*/
|