| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285 | 
							- /**
 
-   ******************************************************************************
 
-   * @file    Project/STM32F4xx_StdPeriph_Templates/stm32f4xx_it.c 
 
-   * @author  MCD Application Team
 
-   * @version V1.5.0
 
-   * @date    06-March-2015
 
-   * @brief   Main Interrupt Service Routines.
 
-   *          This file provides template for all exceptions handler and 
 
-   *          peripherals interrupt service routine.
 
-   ******************************************************************************
 
-   * @attention
 
-   *
 
-   * <h2><center>© COPYRIGHT 2015 STMicroelectronics</center></h2>
 
-   *
 
-   * Licensed under MCD-ST Liberty SW License Agreement V2, (the "License");
 
-   * You may not use this file except in compliance with the License.
 
-   * You may obtain a copy of the License at:
 
-   *
 
-   *        http://www.st.com/software_license_agreement_liberty_v2
 
-   *
 
-   * Unless required by applicable law or agreed to in writing, software 
 
-   * distributed under the License is distributed on an "AS IS" BASIS, 
 
-   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 
-   * See the License for the specific language governing permissions and
 
-   * limitations under the License.
 
-   *
 
-   ******************************************************************************
 
-   */
 
- /* Includes ------------------------------------------------------------------*/
 
- #include "stm32f4xx_it.h"
 
- //#include "usart.h"
 
- /* Scheduler includes */
 
- #include "FreeRTOS.h"
 
- #include "task.h"
 
- #include "queue.h"
 
- #include "semphr.h"
 
- extern SemaphoreHandle_t s_xSemaphore;
 
- /* We can use Web only with libc stdio (PRINTF=stdlib) */
 
- #include "stm32f4x7_eth.h"
 
- /* lwip includes */
 
- #include "lwip/sys.h"
 
- #ifdef PRINTF_STDLIB
 
- #include <stdio.h>
 
- #endif
 
- #ifdef PRINTF_CUSTOM
 
- #include "tinystdio.h"
 
- #endif
 
- /** @addtogroup Template_Project
 
-   * @{
 
-   */
 
- /* Private typedef -----------------------------------------------------------*/
 
- /* Private define ------------------------------------------------------------*/
 
- /* Private macro -------------------------------------------------------------*/
 
- /* Private variables ---------------------------------------------------------*/
 
- /* Private function prototypes -----------------------------------------------*/
 
- /* Private functions ---------------------------------------------------------*/
 
- /******************************************************************************/
 
- /*            Cortex-M4 Processor Exceptions Handlers                         */
 
- /******************************************************************************/
 
- /**
 
-   * @brief  This function handles NMI exception.
 
-   * @param  None
 
-   * @retval None
 
-   */
 
- void NMI_Handler(void)
 
- {
 
- }
 
- void HardFault_Output(uint32_t *sp)
 
- {
 
-     uint32_t r0  = sp[0];
 
-     uint32_t r1  = sp[1];
 
-     uint32_t r2  = sp[2];
 
-     uint32_t r3  = sp[3];
 
-     uint32_t r12 = sp[4];
 
-     uint32_t lr  = sp[5];
 
-     uint32_t pc  = sp[6];
 
-     uint32_t psr = sp[7];
 
-     printf("HardFault:\n\r");
 
-     /* Print CFSR register */
 
-     /* Print CPU registers */
 
-     printf("\n\rRegisters:\n\r");
 
-     printf("SP          0x%08lx\n\r", (uint32_t)sp);
 
-     printf("R0          0x%08lx\n\r", r0);
 
-     printf("R1          0x%08lx\n\r", r1);
 
-     printf("R2          0x%08lx\n\r", r2);
 
-     printf("R3          0x%08lx\n\r", r3);
 
-     printf("R12         0x%08lx\n\r", r12);
 
-     printf("LR          0x%08lx\n\r", lr);
 
-     printf("PC          0x%08lx\n\r", pc);
 
-     printf("PSR         0x%08lx\n\r", psr);
 
-     /* Go to infinite loop when Hard Fault exception occurs */
 
-     while(1);
 
- }
 
- /**
 
-   * @brief  This function handles Hard Fault exception.
 
-   * @param  None
 
-   * @retval None
 
-   */
 
- #if defined ( __GNUC__ ) 
 
- __attribute__( (naked) )
 
- void HardFault_Handler(void)
 
- {
 
- __asm volatile
 
-     (
 
-         "tst lr, #4                                    \n"
 
-         "ite eq                                        \n"
 
-         "mrseq r0, msp                                 \n"
 
-         "mrsne r0, psp                                 \n"
 
-         "ldr r1, debugHardfault_address                \n"
 
-         "bx r1                                         \n"
 
-         "debugHardfault_address: .word HardFault_Output  \n"
 
-     );
 
- }
 
- #endif
 
- /**
 
-   * @brief  This function handles Memory Manage exception.
 
-   * @param  None
 
-   * @retval None
 
-   */
 
- void MemManage_Handler(void)
 
- {
 
-   /* Go to infinite loop when Memory Manage exception occurs */
 
-   while (1)
 
-   {
 
-   }
 
- }
 
- /*void TIM8_UP_TIM13_IRQHandler(void)
 
- {
 
- 	TIM_ClearITPendingBit(TIM13, TIM_IT_Update);
 
- }*/
 
- /**
 
-   * @brief  This function handles Bus Fault exception.
 
-   * @param  None
 
-   * @retval None
 
-   */
 
- void BusFault_Handler(void)
 
- {
 
-   /* Go to infinite loop when Bus Fault exception occurs */
 
-   while (1)
 
-   {
 
-   }
 
- }
 
- /**
 
-   * @brief  This function handles Usage Fault exception.
 
-   * @param  None
 
-   * @retval None
 
-   */
 
- void UsageFault_Handler(void)
 
- {
 
-   /* Go to infinite loop when Usage Fault exception occurs */
 
-   while (1)
 
-   {
 
-   }
 
- }
 
- /**
 
-   * @brief  This function handles SVCall exception.
 
-   * @param  None
 
-   * @retval None
 
-   */
 
- /*
 
- void SVC_Handler(void)
 
- {
 
- }
 
- */
 
- /**
 
-   * @brief  This function handles Debug Monitor exception.
 
-   * @param  None
 
-   * @retval None
 
-   */
 
- void DebugMon_Handler(void)
 
- {
 
- }
 
- /**
 
-   * @brief  This function handles PendSVC exception.
 
-   * @param  None
 
-   * @retval None
 
-   */
 
- /*void PendSV_Handler(void)
 
- {
 
- }
 
- */
 
- /**
 
-   * @brief  This function handles SysTick Handler.
 
-   * @param  None
 
-   * @retval None
 
-   */
 
- /*void SysTick_Handler(void)
 
- {
 
-   TimingDelay_Decrement();
 
- }
 
- */
 
- /******************************************************************************/
 
- /*                 STM32F4xx Peripherals Interrupt Handlers                   */
 
- /*  Add here the Interrupt Handler for the used peripheral(s) (PPP), for the  */
 
- /*  available peripheral interrupt handler's name please refer to the startup */
 
- /*  file (startup_stm32f4xx.s).                                               */
 
- /******************************************************************************/
 
- /**
 
-   * @brief  This function handles PPP interrupt request.
 
-   * @param  None
 
-   * @retval None
 
-   */
 
- /*void PPP_IRQHandler(void)
 
- {
 
- }*/
 
- void SDIO_IRQHandler(void)
 
- {
 
-   /* Process All SDIO Interrupt Sources */
 
-  // SD_ProcessIRQSrc();
 
- }
 
- /**
 
-   * @brief  This function handles DMA2 Stream3 or DMA2 Stream6 global interrupts
 
-   *         requests.
 
-   * @param  None
 
-   * @retval None
 
-   */
 
- void SD_SDIO_DMA_IRQHANDLER(void)
 
- {
 
-   /* Process DMA2 Stream3 or DMA2 Stream6 Interrupt Sources */
 
- //  SD_ProcessDMAIRQ();
 
- }
 
- //#ifdef OS_FREERTOS
 
- /**
 
-   * @brief  This function handles ethernet DMA interrupt request.
 
-   * @param  None
 
-   * @retval None
 
-   */
 
- void ETH_IRQHandler(void)
 
- {
 
-   portBASE_TYPE xHigherPriorityTaskWoken = pdFALSE;
 
-   /* Frame received */
 
-   if ( ETH_GetDMAFlagStatus(ETH_DMA_FLAG_R) == SET)
 
-   {
 
-     /* Give the semaphore to wakeup LwIP task */
 
-     xSemaphoreGiveFromISR( s_xSemaphore, &xHigherPriorityTaskWoken );
 
-   }
 
-   /* Clear the interrupt flags. */
 
-   /* Clear the Eth DMA Rx IT pending bits */
 
-   ETH_DMAClearITPendingBit(ETH_DMA_IT_R);
 
-   ETH_DMAClearITPendingBit(ETH_DMA_IT_NIS);
 
-   // Switch tasks if necessary. */
 
-   if( xHigherPriorityTaskWoken != pdFALSE )
 
-   {
 
-     portEND_SWITCHING_ISR( xHigherPriorityTaskWoken );
 
-   }
 
- }
 
- //#endif
 
- //#endif
 
- /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/
 
 
  |