Advertisement
icis4

hardfault stm32f7xx

May 19th, 2021
924
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C 2.14 KB | None | 0 0
  1. **
  2.   * @brief This function handles Hard fault interrupt.
  3.   */
  4. void HardFault_Handler(void)
  5. {
  6.   /* USER CODE BEGIN HardFault_IRQn 0 */
  7.     __asm volatile
  8.         (
  9.             " tst lr, #4                                                \n"
  10.             " ite eq                                                    \n"
  11.             " mrseq r0, msp                                             \n"
  12.             " mrsne r0, psp                                             \n"
  13.             " ldr r1, [r0, #24]                                         \n"
  14.             " ldr r2, =prvGetRegistersFromStack                         \n"
  15.             " bx r2                                                     \n"
  16.         );
  17.   /* USER CODE END HardFault_IRQn 0 */
  18.   while (1)
  19.   {
  20.     /* USER CODE BEGIN W1_HardFault_IRQn 0 */
  21.       __asm volatile("NOP\n");
  22.     /* USER CODE END W1_HardFault_IRQn 0 */
  23.   }
  24. }
  25.  
  26. ...
  27.  
  28. /* USER CODE BEGIN 1 */
  29. void prvGetRegistersFromStack( uint32_t *pulFaultStackAddress )
  30. {
  31. /* These are volatile to try and prevent the compiler/linker optimising them
  32. away as the variables never actually get used.  If the debugger won't show the
  33. values of the variables, make them global my moving their declaration outside
  34. of this function. */
  35. volatile uint32_t r0  __unused;
  36. volatile uint32_t r1  __unused;
  37. volatile uint32_t r2  __unused;
  38. volatile uint32_t r3  __unused;
  39. volatile uint32_t r12 __unused;
  40. volatile uint32_t lr  __unused; /* Link register. */
  41. volatile uint32_t pc  __unused; /* Program counter. */
  42. volatile uint32_t psr __unused;/* Program status register. */
  43.  
  44.     r0 =  pulFaultStackAddress[ 0 ];
  45.     r1 =  pulFaultStackAddress[ 1 ];
  46.     r2 =  pulFaultStackAddress[ 2 ];
  47.     r3 =  pulFaultStackAddress[ 3 ];
  48.  
  49.     r12 = pulFaultStackAddress[ 4 ];
  50.     lr =  pulFaultStackAddress[ 5 ];
  51.     pc =  pulFaultStackAddress[ 6 ];
  52.     psr = pulFaultStackAddress[ 7 ];
  53.  
  54.     /* When the following line is hit, the variables contain the register values. */
  55.  
  56.     for( uint32_t i = 0; i < 1000; i++) {
  57.         BSP_LedSetAll(GPIO_PIN_SET);
  58.         BSP_DelayMicros(500000);
  59.         BSP_LedSetAll(GPIO_PIN_RESET);
  60.         BSP_DelayMicros(500000);
  61.     }
  62.  
  63.     //TODO: Set reset reason;
  64.     NVIC_SystemReset();
  65. }
  66.  
  67. /* USER CODE END 1 */
  68.  
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement