I'm trying to port GRBL 1.1 to the STM32F746 chip. Tell me the solution, thanks.

Committer:
Sergunb
Date:
Mon Sep 04 12:03:42 2017 +0000
Revision:
0:f1834a63f7c1
Initial commit

Who changed what in which revision?

UserRevisionLine numberNew contents of line
Sergunb 0:f1834a63f7c1 1 /**
Sergunb 0:f1834a63f7c1 2 ******************************************************************************
Sergunb 0:f1834a63f7c1 3 * @file stm32f10x_exti.h
Sergunb 0:f1834a63f7c1 4 * @author MCD Application Team
Sergunb 0:f1834a63f7c1 5 * @version V3.5.0
Sergunb 0:f1834a63f7c1 6 * @date 11-March-2011
Sergunb 0:f1834a63f7c1 7 * @brief This file contains all the functions prototypes for the EXTI firmware
Sergunb 0:f1834a63f7c1 8 * library.
Sergunb 0:f1834a63f7c1 9 ******************************************************************************
Sergunb 0:f1834a63f7c1 10 * @attention
Sergunb 0:f1834a63f7c1 11 *
Sergunb 0:f1834a63f7c1 12 * THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
Sergunb 0:f1834a63f7c1 13 * WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
Sergunb 0:f1834a63f7c1 14 * TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
Sergunb 0:f1834a63f7c1 15 * DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
Sergunb 0:f1834a63f7c1 16 * FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
Sergunb 0:f1834a63f7c1 17 * CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
Sergunb 0:f1834a63f7c1 18 *
Sergunb 0:f1834a63f7c1 19 * <h2><center>&copy; COPYRIGHT 2011 STMicroelectronics</center></h2>
Sergunb 0:f1834a63f7c1 20 ******************************************************************************
Sergunb 0:f1834a63f7c1 21 */
Sergunb 0:f1834a63f7c1 22
Sergunb 0:f1834a63f7c1 23 /* Define to prevent recursive inclusion -------------------------------------*/
Sergunb 0:f1834a63f7c1 24 #ifndef __STM32F10x_EXTI_H
Sergunb 0:f1834a63f7c1 25 #define __STM32F10x_EXTI_H
Sergunb 0:f1834a63f7c1 26
Sergunb 0:f1834a63f7c1 27 #ifdef __cplusplus
Sergunb 0:f1834a63f7c1 28 extern "C" {
Sergunb 0:f1834a63f7c1 29 #endif
Sergunb 0:f1834a63f7c1 30
Sergunb 0:f1834a63f7c1 31 /* Includes ------------------------------------------------------------------*/
Sergunb 0:f1834a63f7c1 32 #include "stm32f10x.h"
Sergunb 0:f1834a63f7c1 33
Sergunb 0:f1834a63f7c1 34 /** @addtogroup STM32F10x_StdPeriph_Driver
Sergunb 0:f1834a63f7c1 35 * @{
Sergunb 0:f1834a63f7c1 36 */
Sergunb 0:f1834a63f7c1 37
Sergunb 0:f1834a63f7c1 38 /** @addtogroup EXTI
Sergunb 0:f1834a63f7c1 39 * @{
Sergunb 0:f1834a63f7c1 40 */
Sergunb 0:f1834a63f7c1 41
Sergunb 0:f1834a63f7c1 42 /** @defgroup EXTI_Exported_Types
Sergunb 0:f1834a63f7c1 43 * @{
Sergunb 0:f1834a63f7c1 44 */
Sergunb 0:f1834a63f7c1 45
Sergunb 0:f1834a63f7c1 46 /**
Sergunb 0:f1834a63f7c1 47 * @brief EXTI mode enumeration
Sergunb 0:f1834a63f7c1 48 */
Sergunb 0:f1834a63f7c1 49
Sergunb 0:f1834a63f7c1 50 typedef enum
Sergunb 0:f1834a63f7c1 51 {
Sergunb 0:f1834a63f7c1 52 EXTI_Mode_Interrupt = 0x00,
Sergunb 0:f1834a63f7c1 53 EXTI_Mode_Event = 0x04
Sergunb 0:f1834a63f7c1 54 }EXTIMode_TypeDef;
Sergunb 0:f1834a63f7c1 55
Sergunb 0:f1834a63f7c1 56 #define IS_EXTI_MODE(MODE) (((MODE) == EXTI_Mode_Interrupt) || ((MODE) == EXTI_Mode_Event))
Sergunb 0:f1834a63f7c1 57
Sergunb 0:f1834a63f7c1 58 /**
Sergunb 0:f1834a63f7c1 59 * @brief EXTI Trigger enumeration
Sergunb 0:f1834a63f7c1 60 */
Sergunb 0:f1834a63f7c1 61
Sergunb 0:f1834a63f7c1 62 typedef enum
Sergunb 0:f1834a63f7c1 63 {
Sergunb 0:f1834a63f7c1 64 EXTI_Trigger_Rising = 0x08,
Sergunb 0:f1834a63f7c1 65 EXTI_Trigger_Falling = 0x0C,
Sergunb 0:f1834a63f7c1 66 EXTI_Trigger_Rising_Falling = 0x10
Sergunb 0:f1834a63f7c1 67 }EXTITrigger_TypeDef;
Sergunb 0:f1834a63f7c1 68
Sergunb 0:f1834a63f7c1 69 #define IS_EXTI_TRIGGER(TRIGGER) (((TRIGGER) == EXTI_Trigger_Rising) || \
Sergunb 0:f1834a63f7c1 70 ((TRIGGER) == EXTI_Trigger_Falling) || \
Sergunb 0:f1834a63f7c1 71 ((TRIGGER) == EXTI_Trigger_Rising_Falling))
Sergunb 0:f1834a63f7c1 72 /**
Sergunb 0:f1834a63f7c1 73 * @brief EXTI Init Structure definition
Sergunb 0:f1834a63f7c1 74 */
Sergunb 0:f1834a63f7c1 75
Sergunb 0:f1834a63f7c1 76 typedef struct
Sergunb 0:f1834a63f7c1 77 {
Sergunb 0:f1834a63f7c1 78 uint32_t EXTI_Line; /*!< Specifies the EXTI lines to be enabled or disabled.
Sergunb 0:f1834a63f7c1 79 This parameter can be any combination of @ref EXTI_Lines */
Sergunb 0:f1834a63f7c1 80
Sergunb 0:f1834a63f7c1 81 EXTIMode_TypeDef EXTI_Mode; /*!< Specifies the mode for the EXTI lines.
Sergunb 0:f1834a63f7c1 82 This parameter can be a value of @ref EXTIMode_TypeDef */
Sergunb 0:f1834a63f7c1 83
Sergunb 0:f1834a63f7c1 84 EXTITrigger_TypeDef EXTI_Trigger; /*!< Specifies the trigger signal active edge for the EXTI lines.
Sergunb 0:f1834a63f7c1 85 This parameter can be a value of @ref EXTIMode_TypeDef */
Sergunb 0:f1834a63f7c1 86
Sergunb 0:f1834a63f7c1 87 FunctionalState EXTI_LineCmd; /*!< Specifies the new state of the selected EXTI lines.
Sergunb 0:f1834a63f7c1 88 This parameter can be set either to ENABLE or DISABLE */
Sergunb 0:f1834a63f7c1 89 }EXTI_InitTypeDef;
Sergunb 0:f1834a63f7c1 90
Sergunb 0:f1834a63f7c1 91 /**
Sergunb 0:f1834a63f7c1 92 * @}
Sergunb 0:f1834a63f7c1 93 */
Sergunb 0:f1834a63f7c1 94
Sergunb 0:f1834a63f7c1 95 /** @defgroup EXTI_Exported_Constants
Sergunb 0:f1834a63f7c1 96 * @{
Sergunb 0:f1834a63f7c1 97 */
Sergunb 0:f1834a63f7c1 98
Sergunb 0:f1834a63f7c1 99 /** @defgroup EXTI_Lines
Sergunb 0:f1834a63f7c1 100 * @{
Sergunb 0:f1834a63f7c1 101 */
Sergunb 0:f1834a63f7c1 102
Sergunb 0:f1834a63f7c1 103 #define EXTI_Line0 ((uint32_t)0x00001) /*!< External interrupt line 0 */
Sergunb 0:f1834a63f7c1 104 #define EXTI_Line1 ((uint32_t)0x00002) /*!< External interrupt line 1 */
Sergunb 0:f1834a63f7c1 105 #define EXTI_Line2 ((uint32_t)0x00004) /*!< External interrupt line 2 */
Sergunb 0:f1834a63f7c1 106 #define EXTI_Line3 ((uint32_t)0x00008) /*!< External interrupt line 3 */
Sergunb 0:f1834a63f7c1 107 #define EXTI_Line4 ((uint32_t)0x00010) /*!< External interrupt line 4 */
Sergunb 0:f1834a63f7c1 108 #define EXTI_Line5 ((uint32_t)0x00020) /*!< External interrupt line 5 */
Sergunb 0:f1834a63f7c1 109 #define EXTI_Line6 ((uint32_t)0x00040) /*!< External interrupt line 6 */
Sergunb 0:f1834a63f7c1 110 #define EXTI_Line7 ((uint32_t)0x00080) /*!< External interrupt line 7 */
Sergunb 0:f1834a63f7c1 111 #define EXTI_Line8 ((uint32_t)0x00100) /*!< External interrupt line 8 */
Sergunb 0:f1834a63f7c1 112 #define EXTI_Line9 ((uint32_t)0x00200) /*!< External interrupt line 9 */
Sergunb 0:f1834a63f7c1 113 #define EXTI_Line10 ((uint32_t)0x00400) /*!< External interrupt line 10 */
Sergunb 0:f1834a63f7c1 114 #define EXTI_Line11 ((uint32_t)0x00800) /*!< External interrupt line 11 */
Sergunb 0:f1834a63f7c1 115 #define EXTI_Line12 ((uint32_t)0x01000) /*!< External interrupt line 12 */
Sergunb 0:f1834a63f7c1 116 #define EXTI_Line13 ((uint32_t)0x02000) /*!< External interrupt line 13 */
Sergunb 0:f1834a63f7c1 117 #define EXTI_Line14 ((uint32_t)0x04000) /*!< External interrupt line 14 */
Sergunb 0:f1834a63f7c1 118 #define EXTI_Line15 ((uint32_t)0x08000) /*!< External interrupt line 15 */
Sergunb 0:f1834a63f7c1 119 #define EXTI_Line16 ((uint32_t)0x10000) /*!< External interrupt line 16 Connected to the PVD Output */
Sergunb 0:f1834a63f7c1 120 #define EXTI_Line17 ((uint32_t)0x20000) /*!< External interrupt line 17 Connected to the RTC Alarm event */
Sergunb 0:f1834a63f7c1 121 #define EXTI_Line18 ((uint32_t)0x40000) /*!< External interrupt line 18 Connected to the USB Device/USB OTG FS
Sergunb 0:f1834a63f7c1 122 Wakeup from suspend event */
Sergunb 0:f1834a63f7c1 123 #define EXTI_Line19 ((uint32_t)0x80000) /*!< External interrupt line 19 Connected to the Ethernet Wakeup event */
Sergunb 0:f1834a63f7c1 124
Sergunb 0:f1834a63f7c1 125 #define IS_EXTI_LINE(LINE) ((((LINE) & (uint32_t)0xFFF00000) == 0x00) && ((LINE) != (uint16_t)0x00))
Sergunb 0:f1834a63f7c1 126 #define IS_GET_EXTI_LINE(LINE) (((LINE) == EXTI_Line0) || ((LINE) == EXTI_Line1) || \
Sergunb 0:f1834a63f7c1 127 ((LINE) == EXTI_Line2) || ((LINE) == EXTI_Line3) || \
Sergunb 0:f1834a63f7c1 128 ((LINE) == EXTI_Line4) || ((LINE) == EXTI_Line5) || \
Sergunb 0:f1834a63f7c1 129 ((LINE) == EXTI_Line6) || ((LINE) == EXTI_Line7) || \
Sergunb 0:f1834a63f7c1 130 ((LINE) == EXTI_Line8) || ((LINE) == EXTI_Line9) || \
Sergunb 0:f1834a63f7c1 131 ((LINE) == EXTI_Line10) || ((LINE) == EXTI_Line11) || \
Sergunb 0:f1834a63f7c1 132 ((LINE) == EXTI_Line12) || ((LINE) == EXTI_Line13) || \
Sergunb 0:f1834a63f7c1 133 ((LINE) == EXTI_Line14) || ((LINE) == EXTI_Line15) || \
Sergunb 0:f1834a63f7c1 134 ((LINE) == EXTI_Line16) || ((LINE) == EXTI_Line17) || \
Sergunb 0:f1834a63f7c1 135 ((LINE) == EXTI_Line18) || ((LINE) == EXTI_Line19))
Sergunb 0:f1834a63f7c1 136
Sergunb 0:f1834a63f7c1 137
Sergunb 0:f1834a63f7c1 138 /**
Sergunb 0:f1834a63f7c1 139 * @}
Sergunb 0:f1834a63f7c1 140 */
Sergunb 0:f1834a63f7c1 141
Sergunb 0:f1834a63f7c1 142 /**
Sergunb 0:f1834a63f7c1 143 * @}
Sergunb 0:f1834a63f7c1 144 */
Sergunb 0:f1834a63f7c1 145
Sergunb 0:f1834a63f7c1 146 /** @defgroup EXTI_Exported_Macros
Sergunb 0:f1834a63f7c1 147 * @{
Sergunb 0:f1834a63f7c1 148 */
Sergunb 0:f1834a63f7c1 149
Sergunb 0:f1834a63f7c1 150 /**
Sergunb 0:f1834a63f7c1 151 * @}
Sergunb 0:f1834a63f7c1 152 */
Sergunb 0:f1834a63f7c1 153
Sergunb 0:f1834a63f7c1 154 /** @defgroup EXTI_Exported_Functions
Sergunb 0:f1834a63f7c1 155 * @{
Sergunb 0:f1834a63f7c1 156 */
Sergunb 0:f1834a63f7c1 157
Sergunb 0:f1834a63f7c1 158 void EXTI_DeInit(void);
Sergunb 0:f1834a63f7c1 159 void EXTI_Init(EXTI_InitTypeDef* EXTI_InitStruct);
Sergunb 0:f1834a63f7c1 160 void EXTI_StructInit(EXTI_InitTypeDef* EXTI_InitStruct);
Sergunb 0:f1834a63f7c1 161 void EXTI_GenerateSWInterrupt(uint32_t EXTI_Line);
Sergunb 0:f1834a63f7c1 162 FlagStatus EXTI_GetFlagStatus(uint32_t EXTI_Line);
Sergunb 0:f1834a63f7c1 163 void EXTI_ClearFlag(uint32_t EXTI_Line);
Sergunb 0:f1834a63f7c1 164 ITStatus EXTI_GetITStatus(uint32_t EXTI_Line);
Sergunb 0:f1834a63f7c1 165 void EXTI_ClearITPendingBit(uint32_t EXTI_Line);
Sergunb 0:f1834a63f7c1 166
Sergunb 0:f1834a63f7c1 167 #ifdef __cplusplus
Sergunb 0:f1834a63f7c1 168 }
Sergunb 0:f1834a63f7c1 169 #endif
Sergunb 0:f1834a63f7c1 170
Sergunb 0:f1834a63f7c1 171 #endif /* __STM32F10x_EXTI_H */
Sergunb 0:f1834a63f7c1 172 /**
Sergunb 0:f1834a63f7c1 173 * @}
Sergunb 0:f1834a63f7c1 174 */
Sergunb 0:f1834a63f7c1 175
Sergunb 0:f1834a63f7c1 176 /**
Sergunb 0:f1834a63f7c1 177 * @}
Sergunb 0:f1834a63f7c1 178 */
Sergunb 0:f1834a63f7c1 179
Sergunb 0:f1834a63f7c1 180 /**
Sergunb 0:f1834a63f7c1 181 * @}
Sergunb 0:f1834a63f7c1 182 */
Sergunb 0:f1834a63f7c1 183
Sergunb 0:f1834a63f7c1 184 /******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/