149 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
		
		
			
		
	
	
			149 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
|   | /**********************************************************************
 | ||
|  | * $Id$      lpc17xx_nvic.c              2010-05-21 | ||
|  | *//**
 | ||
|  | * @file     lpc17xx_nvic.c | ||
|  | * @brief    Contains all expansion functions support for | ||
|  | *           NVIC firmware library on LPC17xx. The main | ||
|  | *           NVIC functions are defined in core_cm3.h | ||
|  | * @version  2.0 | ||
|  | * @date     21. May. 2010 | ||
|  | * @author   NXP MCU SW Application Team | ||
|  | * | ||
|  | * Copyright(C) 2010, NXP Semiconductor | ||
|  | * All rights reserved. | ||
|  | * | ||
|  | *********************************************************************** | ||
|  | * Software that is described herein is for illustrative purposes only | ||
|  | * which provides customers with programming information regarding the | ||
|  | * products. This software is supplied "AS IS" without any warranties. | ||
|  | * NXP Semiconductors assumes no responsibility or liability for the | ||
|  | * use of the software, conveys no license or title under any patent, | ||
|  | * copyright, or mask work right to the product. NXP Semiconductors | ||
|  | * reserves the right to make changes in the software without | ||
|  | * notification. NXP Semiconductors also make no representation or | ||
|  | * warranty that such application will be suitable for the specified | ||
|  | * use without further testing or modification. | ||
|  | * Permission to use, copy, modify, and distribute this software and its | ||
|  | * documentation is hereby granted, under NXP Semiconductors' | ||
|  | * relevant copyright in the software, without fee, provided that it | ||
|  | * is used in conjunction with NXP Semiconductors microcontrollers.  This | ||
|  | * copyright, permission, and disclaimer notice must appear in all copies of | ||
|  | * this code. | ||
|  | **********************************************************************/ | ||
|  | 
 | ||
|  | /* Peripheral group ----------------------------------------------------------- */ | ||
|  | /** @addtogroup NVIC
 | ||
|  |  * @{ | ||
|  |  */ | ||
|  | 
 | ||
|  | /* Includes ------------------------------------------------------------------- */ | ||
|  | #include "lpc17xx_nvic.h"
 | ||
|  | 
 | ||
|  | 
 | ||
|  | /* Private Macros ------------------------------------------------------------- */ | ||
|  | /** @addtogroup NVIC_Private_Macros
 | ||
|  |  * @{ | ||
|  |  */ | ||
|  | 
 | ||
|  | /* Vector table offset bit mask */ | ||
|  | #define NVIC_VTOR_MASK              0x3FFFFF80
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @} | ||
|  |  */ | ||
|  | 
 | ||
|  | 
 | ||
|  | /* Public Functions ----------------------------------------------------------- */ | ||
|  | /** @addtogroup NVIC_Public_Functions
 | ||
|  |  * @{ | ||
|  |  */ | ||
|  | 
 | ||
|  | 
 | ||
|  | /*****************************************************************************//**
 | ||
|  |  * @brief       De-initializes the NVIC peripheral registers to their default | ||
|  |  *              reset values. | ||
|  |  * @param       None | ||
|  |  * @return      None | ||
|  |  * | ||
|  |  * These following NVIC peripheral registers will be de-initialized: | ||
|  |  * - Disable Interrupt (32 IRQ interrupt sources that matched with LPC17xx) | ||
|  |  * - Clear all Pending Interrupts (32 IRQ interrupt source that matched with LPC17xx) | ||
|  |  * - Clear all Interrupt Priorities (32 IRQ interrupt source that matched with LPC17xx) | ||
|  |  *******************************************************************************/ | ||
|  | void NVIC_DeInit(void) | ||
|  | { | ||
|  |     uint8_t tmp; | ||
|  | 
 | ||
|  |     /* Disable all interrupts */ | ||
|  |     NVIC->ICER[0] = 0xFFFFFFFF; | ||
|  |     NVIC->ICER[1] = 0x00000001; | ||
|  |     /* Clear all pending interrupts */ | ||
|  |     NVIC->ICPR[0] = 0xFFFFFFFF; | ||
|  |     NVIC->ICPR[1] = 0x00000001; | ||
|  | 
 | ||
|  |     /* Clear all interrupt priority */ | ||
|  |     for (tmp = 0; tmp < 32; tmp++) { | ||
|  |         NVIC->IP[tmp] = 0x00; | ||
|  |     } | ||
|  | } | ||
|  | 
 | ||
|  | /*****************************************************************************//**
 | ||
|  |  * @brief           De-initializes the SCB peripheral registers to their default | ||
|  |  *                  reset values. | ||
|  |  * @param           none | ||
|  |  * @return          none | ||
|  |  * | ||
|  |  * These following SCB NVIC peripheral registers will be de-initialized: | ||
|  |  * - Interrupt Control State register | ||
|  |  * - Interrupt Vector Table Offset register | ||
|  |  * - Application Interrupt/Reset Control register | ||
|  |  * - System Control register | ||
|  |  * - Configuration Control register | ||
|  |  * - System Handlers Priority Registers | ||
|  |  * - System Handler Control and State Register | ||
|  |  * - Configurable Fault Status Register | ||
|  |  * - Hard Fault Status Register | ||
|  |  * - Debug Fault Status Register | ||
|  |  *******************************************************************************/ | ||
|  | void NVIC_SCBDeInit(void) | ||
|  | { | ||
|  |     uint8_t tmp; | ||
|  | 
 | ||
|  |     SCB->ICSR = 0x0A000000; | ||
|  |     SCB->VTOR = 0x00000000; | ||
|  |     SCB->AIRCR = 0x05FA0000; | ||
|  |     SCB->SCR = 0x00000000; | ||
|  |     SCB->CCR = 0x00000000; | ||
|  | 
 | ||
|  |     for (tmp = 0; tmp < 32; tmp++) { | ||
|  |         SCB->SHP[tmp] = 0x00; | ||
|  |     } | ||
|  | 
 | ||
|  |     SCB->SHCSR = 0x00000000; | ||
|  |     SCB->CFSR = 0xFFFFFFFF; | ||
|  |     SCB->HFSR = 0xFFFFFFFF; | ||
|  |     SCB->DFSR = 0xFFFFFFFF; | ||
|  | } | ||
|  | 
 | ||
|  | 
 | ||
|  | /*****************************************************************************//**
 | ||
|  |  * @brief       Set Vector Table Offset value | ||
|  |  * @param       offset Offset value | ||
|  |  * @return      None | ||
|  |  *******************************************************************************/ | ||
|  | void NVIC_SetVTOR(uint32_t offset) | ||
|  | { | ||
|  | //  SCB->VTOR  = (offset & NVIC_VTOR_MASK);
 | ||
|  |     SCB->VTOR  = offset; | ||
|  | } | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @} | ||
|  |  */ | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @} | ||
|  |  */ | ||
|  | 
 | ||
|  | /* --------------------------------- End Of File ------------------------------ */ |