| /******************** (C) COPYRIGHT 2006 STMicroelectronics ******************** | |
| * File Name : 75x_eic.c | |
| * Author : MCD Application Team | |
| * Date First Issued : 03/10/2006 | |
| * Description : This file provides all the EIC software functions. | |
| ******************************************************************************** | |
| * History: | |
| * 07/17/2006 : V1.0 | |
| * 03/10/2006 : V0.1 | |
| ******************************************************************************** | |
| * THE PRESENT SOFTWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS | |
| * WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE TIME. | |
| * AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY DIRECT, | |
| * INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING FROM THE | |
| * CONTENT OF SUCH SOFTWARE AND/OR THE USE MADE BY CUSTOMERS OF THE CODING | |
| * INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS. | |
| *******************************************************************************/ | |
| /* Includes ------------------------------------------------------------------*/ | |
| #include "75x_eic.h" | |
| /* Private typedef -----------------------------------------------------------*/ | |
| /* Private define ------------------------------------------------------------*/ | |
| #define EIC_IRQEnable_Mask 0x00000001 | |
| #define EIC_IRQDisable_Mask 0xFFFFFFFE | |
| #define EIC_FIQEnable_Mask 0x00000002 | |
| #define EIC_FIQDisable_Mask 0xFFFFFFFD | |
| #define EIC_SIPL_Mask 0x0000000F | |
| #define EIC_SIPL_Reset_Mask 0xFFFFFFF0 | |
| /* Private macro -------------------------------------------------------------*/ | |
| /* Private variables ---------------------------------------------------------*/ | |
| /* Private function prototypes -----------------------------------------------*/ | |
| /* Private functions ---------------------------------------------------------*/ | |
| /******************************************************************************* | |
| * Function Name : EIC_DeInit | |
| * Description : Deinitializes the EIC peripheral registers to their default | |
| * reset values. | |
| * Input : None | |
| * Output : None | |
| * Return : None | |
| *******************************************************************************/ | |
| void EIC_DeInit(void) | |
| { | |
| EIC->ICR = 0x00; | |
| EIC->CIPR = 0x00; | |
| EIC->FIR = 0x0C; | |
| EIC->IER = 0x00; | |
| EIC->IPR = 0xFFFFFFFF; | |
| } | |
| /******************************************************************************* | |
| * Function Name : EIC_IRQInit | |
| * Description : Configures the IRQ channels according to the specified | |
| * parameters in the EIC_IRQInitStruct. | |
| * Input : EIC_IRQInitStruct: pointer to a EIC_IRQInitTypeDef structure. | |
| * Output : None | |
| * Return : None | |
| *******************************************************************************/ | |
| void EIC_IRQInit(EIC_IRQInitTypeDef* EIC_IRQInitStruct) | |
| { | |
| u32 Tmp = 0; | |
| if(EIC_IRQInitStruct->EIC_IRQChannelCmd == ENABLE) | |
| { | |
| /* Enable the selected IRQ channel */ | |
| EIC->IER |= 1 << EIC_IRQInitStruct->EIC_IRQChannel; | |
| /* Configure the selected IRQ channel priority ***************************/ | |
| /* Clear SIPL[3:0] bits */ | |
| EIC->SIRn[EIC_IRQInitStruct->EIC_IRQChannel] &= EIC_SIPL_Reset_Mask; | |
| /* Configure SIPL[3:0] bits according to EIC_IRQChannelPriority parameter */ | |
| Tmp = EIC_IRQInitStruct->EIC_IRQChannelPriority & EIC_SIPL_Mask; | |
| EIC->SIRn[EIC_IRQInitStruct->EIC_IRQChannel] |= Tmp; | |
| } | |
| else | |
| { | |
| /* Disable the select IRQ channel */ | |
| EIC->IER &=~ (1 << EIC_IRQInitStruct->EIC_IRQChannel); | |
| } | |
| } | |
| /******************************************************************************* | |
| * Function Name : EIC_FIQInit | |
| * Description : Configures the FIQ channels according to the specified | |
| * parameters in the EIC_FIQInitStruct. | |
| * Input : EIC_FIQInitStruct: pointer to a EIC_FIQInitTypeDef structure. | |
| * Output : None | |
| * Return : None | |
| *******************************************************************************/ | |
| void EIC_FIQInit(EIC_FIQInitTypeDef* EIC_FIQInitStruct) | |
| { | |
| if(EIC_FIQInitStruct->EIC_FIQChannelCmd == ENABLE) | |
| { | |
| /* Enable the selected FIQ channel */ | |
| EIC->FIER |= EIC_FIQInitStruct->EIC_FIQChannel ; | |
| } | |
| else | |
| { | |
| /* Disable the selected FIQ channel */ | |
| EIC->FIER &= ~EIC_FIQInitStruct->EIC_FIQChannel; | |
| } | |
| } | |
| /******************************************************************************* | |
| * Function Name : EIC_IRQStructInit | |
| * Description : Fills each EIC_IRQInitStruct member with its default value. | |
| * Input : EIC_IRQInitStruct: pointer to a EIC_IRQInitTypeDef structure | |
| * which will be initialized. | |
| * Output : None | |
| * Return : None | |
| *******************************************************************************/ | |
| void EIC_IRQStructInit(EIC_IRQInitTypeDef* EIC_IRQInitStruct) | |
| { | |
| EIC_IRQInitStruct->EIC_IRQChannel = 0x1F; | |
| EIC_IRQInitStruct->EIC_IRQChannelPriority = 0; | |
| EIC_IRQInitStruct->EIC_IRQChannelCmd = DISABLE; | |
| } | |
| /******************************************************************************* | |
| * Function Name : EIC_FIQStructInit | |
| * Description : Fills each EIC_FIQInitStruct member with its default value. | |
| * Input : EIC_FIQInitStruct: pointer to a EIC_FIQInitTypeDef structure | |
| * which will be initialized. | |
| * Output : None | |
| * Return : None | |
| *******************************************************************************/ | |
| void EIC_FIQStructInit(EIC_FIQInitTypeDef* EIC_FIQInitStruct) | |
| { | |
| EIC_FIQInitStruct->EIC_FIQChannel = 0x03; | |
| EIC_FIQInitStruct->EIC_FIQChannelCmd = DISABLE; | |
| } | |
| /******************************************************************************* | |
| * Function Name : EIC_IRQCmd | |
| * Description : Enables or disables EIC IRQ output request to CPU. | |
| * Input : NewState: new state of the EIC IRQ output request to CPU. | |
| * This parameter can be: ENABLE or DISABLE. | |
| * Output : None | |
| * Return : None | |
| *******************************************************************************/ | |
| void EIC_IRQCmd(FunctionalState NewState) | |
| { | |
| if(NewState == ENABLE) | |
| { | |
| /* Enable EIC IRQ output request to CPU */ | |
| EIC->ICR |= EIC_IRQEnable_Mask; | |
| } | |
| else | |
| { | |
| /* Disable EIC IRQ output request to CPU */ | |
| EIC->ICR &= EIC_IRQDisable_Mask; | |
| } | |
| } | |
| /******************************************************************************* | |
| * Function Name : EIC_FIQCmd | |
| * Description : Enables or disables EIC FIQ output request to CPU. | |
| * Input : NewState: new state of the EIC FIQ output request to CPU. | |
| * This parameter can be: ENABLE or DISABLE. | |
| * Output : None | |
| * Return : None | |
| *******************************************************************************/ | |
| void EIC_FIQCmd(FunctionalState NewState) | |
| { | |
| if(NewState == ENABLE) | |
| { | |
| /* Enable EIC FIQ output request to CPU */ | |
| EIC->ICR |= EIC_FIQEnable_Mask; | |
| } | |
| else | |
| { | |
| /* Disable EIC FIQ output request to CPU */ | |
| EIC->ICR &= EIC_FIQDisable_Mask; | |
| } | |
| } | |
| /******************************************************************************* | |
| * Function Name : EIC_GetCurrentIRQChannel | |
| * Description : Returns the current served IRQ channel identifier. | |
| * Input : None | |
| * Output : None | |
| * Return : The current served IRQ channel. | |
| *******************************************************************************/ | |
| u8 EIC_GetCurrentIRQChannel(void) | |
| { | |
| /* Read and return the CIC[4:0] bits of CICR register */ | |
| return ((u8) (EIC->CICR)); | |
| } | |
| /******************************************************************************* | |
| * Function Name : EIC_GetCurrentIRQChannelPriority | |
| * Description : Returns the priority level of the current served IRQ channel. | |
| * Input : None | |
| * Output : None | |
| * Return : The priority level of the current served IRQ channel. | |
| *******************************************************************************/ | |
| u8 EIC_GetCurrentIRQChannelPriority(void) | |
| { | |
| /* Read and return the CIP[3:0] bits of CIPR register */ | |
| return ((u8) (EIC->CIPR)); | |
| } | |
| /******************************************************************************* | |
| * Function Name : EIC_CurrentIRQPriorityConfig | |
| * Description : Changes the priority of the current served IRQ channel. | |
| * The new priority value must be higher, or equal, than the | |
| * priority value associated to the interrupt channel currently | |
| * serviced. | |
| * Input : NewPriority: new priority value of the IRQ interrupt routine | |
| * currently serviced. | |
| * Output : None | |
| * Return : None | |
| *******************************************************************************/ | |
| void EIC_CurrentIRQPriorityConfig(u8 NewPriority) | |
| { | |
| /* Disable EIC IRQ output request to CPU */ | |
| EIC->ICR &= EIC_IRQDisable_Mask; | |
| /* Change the current priority */ | |
| EIC->CIPR = NewPriority; | |
| /* Enable EIC IRQ output request to CPU */ | |
| EIC->ICR |= EIC_IRQEnable_Mask; | |
| } | |
| /******************************************************************************* | |
| * Function Name : EIC_GetCurrentFIQChannel | |
| * Description : Returns the current served FIQ channel identifier. | |
| * Input : None | |
| * Output : None | |
| * Return : The current served FIQ channel. | |
| *******************************************************************************/ | |
| u8 EIC_GetCurrentFIQChannel(void) | |
| { | |
| /* Read and return the FIP[1:0] bits of FIPR register */ | |
| return ((u8) (EIC->FIPR)); | |
| } | |
| /******************************************************************************* | |
| * Function Name : EIC_ClearFIQPendingBit | |
| * Description : Clears the pending bit of the selected FIQ Channel. | |
| * Input : EIC_FIQChannel: specifies the FIQ channel to clear its | |
| * pending bit. | |
| * Output : None | |
| * Return : None | |
| *******************************************************************************/ | |
| void EIC_ClearFIQPendingBit(u8 EIC_FIQChannel) | |
| { | |
| /* Clear the correspondent FIQ pending bit */ | |
| EIC->FIPR = EIC_FIQChannel ; | |
| } | |
| /******************* (C) COPYRIGHT 2006 STMicroelectronics *****END OF FILE****/ |