Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Dependents: LPCXpresso1769_blinky
Fork of mbed-dev by
targets/hal/TARGET_STM/TARGET_STM32F4/TARGET_MTS_MDOT_F411RE/PinNames.h@0:9b334a45a8ff, 2015-10-01 (annotated)
- Committer:
- bogdanm
- Date:
- Thu Oct 01 15:25:22 2015 +0300
- Revision:
- 0:9b334a45a8ff
- Child:
- 2:6d3776d23548
Initial commit on mbed-dev
Replaces mbed-src (now inactive)
Who changed what in which revision?
| User | Revision | Line number | New contents of line |
|---|---|---|---|
| bogdanm | 0:9b334a45a8ff | 1 | /* mbed Microcontroller Library |
| bogdanm | 0:9b334a45a8ff | 2 | ******************************************************************************* |
| bogdanm | 0:9b334a45a8ff | 3 | * Copyright (c) 2014, STMicroelectronics |
| bogdanm | 0:9b334a45a8ff | 4 | * All rights reserved. |
| bogdanm | 0:9b334a45a8ff | 5 | * |
| bogdanm | 0:9b334a45a8ff | 6 | * Redistribution and use in source and binary forms, with or without |
| bogdanm | 0:9b334a45a8ff | 7 | * modification, are permitted provided that the following conditions are met: |
| bogdanm | 0:9b334a45a8ff | 8 | * |
| bogdanm | 0:9b334a45a8ff | 9 | * 1. Redistributions of source code must retain the above copyright notice, |
| bogdanm | 0:9b334a45a8ff | 10 | * this list of conditions and the following disclaimer. |
| bogdanm | 0:9b334a45a8ff | 11 | * 2. Redistributions in binary form must reproduce the above copyright notice, |
| bogdanm | 0:9b334a45a8ff | 12 | * this list of conditions and the following disclaimer in the documentation |
| bogdanm | 0:9b334a45a8ff | 13 | * and/or other materials provided with the distribution. |
| bogdanm | 0:9b334a45a8ff | 14 | * 3. Neither the name of STMicroelectronics nor the names of its contributors |
| bogdanm | 0:9b334a45a8ff | 15 | * may be used to endorse or promote products derived from this software |
| bogdanm | 0:9b334a45a8ff | 16 | * without specific prior written permission. |
| bogdanm | 0:9b334a45a8ff | 17 | * |
| bogdanm | 0:9b334a45a8ff | 18 | * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" |
| bogdanm | 0:9b334a45a8ff | 19 | * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE |
| bogdanm | 0:9b334a45a8ff | 20 | * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE |
| bogdanm | 0:9b334a45a8ff | 21 | * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE |
| bogdanm | 0:9b334a45a8ff | 22 | * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL |
| bogdanm | 0:9b334a45a8ff | 23 | * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR |
| bogdanm | 0:9b334a45a8ff | 24 | * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER |
| bogdanm | 0:9b334a45a8ff | 25 | * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, |
| bogdanm | 0:9b334a45a8ff | 26 | * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
| bogdanm | 0:9b334a45a8ff | 27 | * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| bogdanm | 0:9b334a45a8ff | 28 | ******************************************************************************* |
| bogdanm | 0:9b334a45a8ff | 29 | */ |
| bogdanm | 0:9b334a45a8ff | 30 | #ifndef MBED_PINNAMES_H |
| bogdanm | 0:9b334a45a8ff | 31 | #define MBED_PINNAMES_H |
| bogdanm | 0:9b334a45a8ff | 32 | |
| bogdanm | 0:9b334a45a8ff | 33 | #include "cmsis.h" |
| bogdanm | 0:9b334a45a8ff | 34 | |
| bogdanm | 0:9b334a45a8ff | 35 | #ifdef __cplusplus |
| bogdanm | 0:9b334a45a8ff | 36 | extern "C" { |
| bogdanm | 0:9b334a45a8ff | 37 | #endif |
| bogdanm | 0:9b334a45a8ff | 38 | |
| bogdanm | 0:9b334a45a8ff | 39 | // See stm32f4xx_hal_gpio.h and stm32f4xx_hal_gpio_ex.h for values of MODE, PUPD and AFNUM |
| bogdanm | 0:9b334a45a8ff | 40 | #define STM_PIN_DATA(MODE, PUPD, AFNUM) ((int)(((AFNUM) << 7) | ((PUPD) << 4) | ((MODE) << 0))) |
| bogdanm | 0:9b334a45a8ff | 41 | #define STM_PIN_DATA_EXT(MODE, PUPD, AFNUM, CHANNEL, INVERTED) ((int)(((INVERTED & 0x01) << 15) | ((CHANNEL & 0x0F) << 11) | ((AFNUM & 0x0F) << 7) | ((PUPD & 0x07) << 4) | ((MODE & 0x0F) << 0))) |
| bogdanm | 0:9b334a45a8ff | 42 | #define STM_PIN_MODE(X) (((X) >> 0) & 0x0F) |
| bogdanm | 0:9b334a45a8ff | 43 | #define STM_PIN_PUPD(X) (((X) >> 4) & 0x07) |
| bogdanm | 0:9b334a45a8ff | 44 | #define STM_PIN_AFNUM(X) (((X) >> 7) & 0x0F) |
| bogdanm | 0:9b334a45a8ff | 45 | #define STM_PIN_CHANNEL(X) (((X) >> 11) & 0x0F) |
| bogdanm | 0:9b334a45a8ff | 46 | #define STM_PIN_INVERTED(X) (((X) >> 15) & 0x01) |
| bogdanm | 0:9b334a45a8ff | 47 | #define STM_MODE_INPUT (0) |
| bogdanm | 0:9b334a45a8ff | 48 | #define STM_MODE_OUTPUT_PP (1) |
| bogdanm | 0:9b334a45a8ff | 49 | #define STM_MODE_OUTPUT_OD (2) |
| bogdanm | 0:9b334a45a8ff | 50 | #define STM_MODE_AF_PP (3) |
| bogdanm | 0:9b334a45a8ff | 51 | #define STM_MODE_AF_OD (4) |
| bogdanm | 0:9b334a45a8ff | 52 | #define STM_MODE_ANALOG (5) |
| bogdanm | 0:9b334a45a8ff | 53 | #define STM_MODE_IT_RISING (6) |
| bogdanm | 0:9b334a45a8ff | 54 | #define STM_MODE_IT_FALLING (7) |
| bogdanm | 0:9b334a45a8ff | 55 | #define STM_MODE_IT_RISING_FALLING (8) |
| bogdanm | 0:9b334a45a8ff | 56 | #define STM_MODE_EVT_RISING (9) |
| bogdanm | 0:9b334a45a8ff | 57 | #define STM_MODE_EVT_FALLING (10) |
| bogdanm | 0:9b334a45a8ff | 58 | #define STM_MODE_EVT_RISING_FALLING (11) |
| bogdanm | 0:9b334a45a8ff | 59 | #define STM_MODE_IT_EVT_RESET (12) |
| bogdanm | 0:9b334a45a8ff | 60 | |
| bogdanm | 0:9b334a45a8ff | 61 | // High nibble = port number (0=A, 1=B, 2=C, 3=D, 4=E, 5=F, 6=G, 7=H) |
| bogdanm | 0:9b334a45a8ff | 62 | // Low nibble = pin number |
| bogdanm | 0:9b334a45a8ff | 63 | #define STM_PORT(X) (((uint32_t)(X) >> 4) & 0xF) |
| bogdanm | 0:9b334a45a8ff | 64 | #define STM_PIN(X) ((uint32_t)(X) & 0xF) |
| bogdanm | 0:9b334a45a8ff | 65 | |
| bogdanm | 0:9b334a45a8ff | 66 | typedef enum { |
| bogdanm | 0:9b334a45a8ff | 67 | PIN_INPUT, |
| bogdanm | 0:9b334a45a8ff | 68 | PIN_OUTPUT |
| bogdanm | 0:9b334a45a8ff | 69 | } PinDirection; |
| bogdanm | 0:9b334a45a8ff | 70 | |
| bogdanm | 0:9b334a45a8ff | 71 | typedef enum { |
| bogdanm | 0:9b334a45a8ff | 72 | PA_0 = 0x00, |
| bogdanm | 0:9b334a45a8ff | 73 | PA_1 = 0x01, |
| bogdanm | 0:9b334a45a8ff | 74 | PA_2 = 0x02, |
| bogdanm | 0:9b334a45a8ff | 75 | PA_3 = 0x03, |
| bogdanm | 0:9b334a45a8ff | 76 | PA_4 = 0x04, |
| bogdanm | 0:9b334a45a8ff | 77 | PA_5 = 0x05, |
| bogdanm | 0:9b334a45a8ff | 78 | PA_6 = 0x06, |
| bogdanm | 0:9b334a45a8ff | 79 | PA_7 = 0x07, |
| bogdanm | 0:9b334a45a8ff | 80 | PA_8 = 0x08, |
| bogdanm | 0:9b334a45a8ff | 81 | PA_9 = 0x09, |
| bogdanm | 0:9b334a45a8ff | 82 | PA_10 = 0x0A, |
| bogdanm | 0:9b334a45a8ff | 83 | PA_11 = 0x0B, |
| bogdanm | 0:9b334a45a8ff | 84 | PA_12 = 0x0C, |
| bogdanm | 0:9b334a45a8ff | 85 | PA_13 = 0x0D, |
| bogdanm | 0:9b334a45a8ff | 86 | PA_14 = 0x0E, |
| bogdanm | 0:9b334a45a8ff | 87 | PA_15 = 0x0F, |
| bogdanm | 0:9b334a45a8ff | 88 | |
| bogdanm | 0:9b334a45a8ff | 89 | PB_0 = 0x10, |
| bogdanm | 0:9b334a45a8ff | 90 | PB_1 = 0x11, |
| bogdanm | 0:9b334a45a8ff | 91 | PB_2 = 0x12, |
| bogdanm | 0:9b334a45a8ff | 92 | PB_3 = 0x13, |
| bogdanm | 0:9b334a45a8ff | 93 | PB_4 = 0x14, |
| bogdanm | 0:9b334a45a8ff | 94 | PB_5 = 0x15, |
| bogdanm | 0:9b334a45a8ff | 95 | PB_6 = 0x16, |
| bogdanm | 0:9b334a45a8ff | 96 | PB_7 = 0x17, |
| bogdanm | 0:9b334a45a8ff | 97 | PB_8 = 0x18, |
| bogdanm | 0:9b334a45a8ff | 98 | PB_9 = 0x19, |
| bogdanm | 0:9b334a45a8ff | 99 | PB_10 = 0x1A, |
| bogdanm | 0:9b334a45a8ff | 100 | PB_12 = 0x1C, |
| bogdanm | 0:9b334a45a8ff | 101 | PB_13 = 0x1D, |
| bogdanm | 0:9b334a45a8ff | 102 | PB_14 = 0x1E, |
| bogdanm | 0:9b334a45a8ff | 103 | PB_15 = 0x1F, |
| bogdanm | 0:9b334a45a8ff | 104 | |
| bogdanm | 0:9b334a45a8ff | 105 | PC_0 = 0x20, |
| bogdanm | 0:9b334a45a8ff | 106 | PC_1 = 0x21, |
| bogdanm | 0:9b334a45a8ff | 107 | PC_2 = 0x22, |
| bogdanm | 0:9b334a45a8ff | 108 | PC_3 = 0x23, |
| bogdanm | 0:9b334a45a8ff | 109 | PC_4 = 0x24, |
| bogdanm | 0:9b334a45a8ff | 110 | PC_5 = 0x25, |
| bogdanm | 0:9b334a45a8ff | 111 | PC_6 = 0x26, |
| bogdanm | 0:9b334a45a8ff | 112 | PC_7 = 0x27, |
| bogdanm | 0:9b334a45a8ff | 113 | PC_8 = 0x28, |
| bogdanm | 0:9b334a45a8ff | 114 | PC_9 = 0x29, |
| bogdanm | 0:9b334a45a8ff | 115 | PC_10 = 0x2A, |
| bogdanm | 0:9b334a45a8ff | 116 | PC_11 = 0x2B, |
| bogdanm | 0:9b334a45a8ff | 117 | PC_12 = 0x2C, |
| bogdanm | 0:9b334a45a8ff | 118 | PC_13 = 0x2D, |
| bogdanm | 0:9b334a45a8ff | 119 | PC_14 = 0x2E, |
| bogdanm | 0:9b334a45a8ff | 120 | PC_15 = 0x2F, |
| bogdanm | 0:9b334a45a8ff | 121 | |
| bogdanm | 0:9b334a45a8ff | 122 | PD_2 = 0x32, |
| bogdanm | 0:9b334a45a8ff | 123 | |
| bogdanm | 0:9b334a45a8ff | 124 | PH_0 = 0x70, |
| bogdanm | 0:9b334a45a8ff | 125 | PH_1 = 0x71, |
| bogdanm | 0:9b334a45a8ff | 126 | |
| bogdanm | 0:9b334a45a8ff | 127 | // Generic signals namings |
| bogdanm | 0:9b334a45a8ff | 128 | XBEE_DOUT = PA_2, |
| bogdanm | 0:9b334a45a8ff | 129 | XBEE_DIN = PA_3, |
| bogdanm | 0:9b334a45a8ff | 130 | XBEE_AD0 = PB_1, |
| bogdanm | 0:9b334a45a8ff | 131 | XBEE_AD1 = PB_0, |
| bogdanm | 0:9b334a45a8ff | 132 | XBEE_AD2 = PA_5, |
| bogdanm | 0:9b334a45a8ff | 133 | XBEE_AD3 = PA_4, |
| bogdanm | 0:9b334a45a8ff | 134 | XBEE_AD4 = PA_7, |
| bogdanm | 0:9b334a45a8ff | 135 | XBEE_AD5 = PC_1, |
| bogdanm | 0:9b334a45a8ff | 136 | XBEE_AD6 = PA_1, |
| bogdanm | 0:9b334a45a8ff | 137 | XBEE_DIO0 = PB_1, |
| bogdanm | 0:9b334a45a8ff | 138 | XBEE_DIO1 = PB_0, |
| bogdanm | 0:9b334a45a8ff | 139 | XBEE_DIO2 = PA_5, |
| bogdanm | 0:9b334a45a8ff | 140 | XBEE_DIO3 = PA_4, |
| bogdanm | 0:9b334a45a8ff | 141 | XBEE_DIO4 = PA_7, |
| bogdanm | 0:9b334a45a8ff | 142 | XBEE_DIO5 = PC_1, |
| bogdanm | 0:9b334a45a8ff | 143 | XBEE_DIO6 = PA_1, |
| bogdanm | 0:9b334a45a8ff | 144 | XBEE_DO8 = PA_6, |
| bogdanm | 0:9b334a45a8ff | 145 | XBEE_DI8 = PA_11, |
| bogdanm | 0:9b334a45a8ff | 146 | XBEE_PWM0 = PA_8, |
| bogdanm | 0:9b334a45a8ff | 147 | XBEE_PWM1 = PC_9, |
| bogdanm | 0:9b334a45a8ff | 148 | XBEE_CTS = PA_0, |
| bogdanm | 0:9b334a45a8ff | 149 | XBEE_RTS = PA_1, |
| bogdanm | 0:9b334a45a8ff | 150 | XBEE_DTR = PA_11, |
| bogdanm | 0:9b334a45a8ff | 151 | XBEE_RSSI = PA_8, |
| bogdanm | 0:9b334a45a8ff | 152 | XBEE_SLEEPRQ = PA_11, |
| bogdanm | 0:9b334a45a8ff | 153 | XBEE_ON_SLEEP = PC_13, |
| bogdanm | 0:9b334a45a8ff | 154 | XBEE_ASSOCIATE = PC_1, |
| bogdanm | 0:9b334a45a8ff | 155 | XBEE_USB_RES = PA_12, |
| bogdanm | 0:9b334a45a8ff | 156 | |
| bogdanm | 0:9b334a45a8ff | 157 | // needed for mbed to build tests |
| bogdanm | 0:9b334a45a8ff | 158 | LED1 = PA_0, |
| bogdanm | 0:9b334a45a8ff | 159 | |
| bogdanm | 0:9b334a45a8ff | 160 | // XBEE_DOUT/DIN, RS232 port on UDK board |
| bogdanm | 0:9b334a45a8ff | 161 | SERIAL_TX = PA_2, |
| bogdanm | 0:9b334a45a8ff | 162 | SERIAL_RX = PA_3, |
| bogdanm | 0:9b334a45a8ff | 163 | |
| bogdanm | 0:9b334a45a8ff | 164 | // DB_TX/RX, USB port on UDK board |
| bogdanm | 0:9b334a45a8ff | 165 | DB_TX = PA_9, |
| bogdanm | 0:9b334a45a8ff | 166 | DB_RX = PA_10, |
| bogdanm | 0:9b334a45a8ff | 167 | USBTX = PA_9, |
| bogdanm | 0:9b334a45a8ff | 168 | USBRX = PA_10, |
| bogdanm | 0:9b334a45a8ff | 169 | |
| bogdanm | 0:9b334a45a8ff | 170 | // Multiplexed with XBEE pins |
| bogdanm | 0:9b334a45a8ff | 171 | I2C_SCL = PA_8, |
| bogdanm | 0:9b334a45a8ff | 172 | I2C_SDA = PC_9, |
| bogdanm | 0:9b334a45a8ff | 173 | SPI1_MOSI = PA_7, |
| bogdanm | 0:9b334a45a8ff | 174 | SPI1_MISO = PA_6, |
| bogdanm | 0:9b334a45a8ff | 175 | SPI1_SCK = PA_5, |
| bogdanm | 0:9b334a45a8ff | 176 | SPI1_CS = PA_4, |
| bogdanm | 0:9b334a45a8ff | 177 | |
| bogdanm | 0:9b334a45a8ff | 178 | // SPI flash |
| bogdanm | 0:9b334a45a8ff | 179 | SPI3_MOSI = PC_12, |
| bogdanm | 0:9b334a45a8ff | 180 | SPI3_MISO = PC_11, |
| bogdanm | 0:9b334a45a8ff | 181 | SPI3_SCK = PC_10, |
| bogdanm | 0:9b334a45a8ff | 182 | SPI3_CS = PC_6, |
| bogdanm | 0:9b334a45a8ff | 183 | FLASH_HOLD = PC_7, |
| bogdanm | 0:9b334a45a8ff | 184 | FLASH_WP = PC_8, |
| bogdanm | 0:9b334a45a8ff | 185 | |
| bogdanm | 0:9b334a45a8ff | 186 | // LoRa |
| bogdanm | 0:9b334a45a8ff | 187 | LORA_RESET = PC_0, |
| bogdanm | 0:9b334a45a8ff | 188 | LORA_RXCTL = PC_2, |
| bogdanm | 0:9b334a45a8ff | 189 | LORA_TXCTL = PC_3, |
| bogdanm | 0:9b334a45a8ff | 190 | LORA_DIO0 = PB_5, |
| bogdanm | 0:9b334a45a8ff | 191 | LORA_DIO1 = PB_6, |
| bogdanm | 0:9b334a45a8ff | 192 | LORA_DIO2 = PB_7, |
| bogdanm | 0:9b334a45a8ff | 193 | LORA_DIO3 = PB_8, |
| bogdanm | 0:9b334a45a8ff | 194 | LORA_DIO4 = PB_9, |
| bogdanm | 0:9b334a45a8ff | 195 | LORA_DIO5 = PB_10, |
| bogdanm | 0:9b334a45a8ff | 196 | // LoRa/SPI2 |
| bogdanm | 0:9b334a45a8ff | 197 | LORA_NSS = PB_12, |
| bogdanm | 0:9b334a45a8ff | 198 | LORA_SCK = PB_13, |
| bogdanm | 0:9b334a45a8ff | 199 | LORA_MISO = PB_14, |
| bogdanm | 0:9b334a45a8ff | 200 | LORA_MOSI = PB_15, |
| bogdanm | 0:9b334a45a8ff | 201 | |
| bogdanm | 0:9b334a45a8ff | 202 | // Not connected |
| bogdanm | 0:9b334a45a8ff | 203 | NC = (int)0xFFFFFFFF |
| bogdanm | 0:9b334a45a8ff | 204 | } PinName; |
| bogdanm | 0:9b334a45a8ff | 205 | |
| bogdanm | 0:9b334a45a8ff | 206 | typedef enum { |
| bogdanm | 0:9b334a45a8ff | 207 | PullNone = 0, |
| bogdanm | 0:9b334a45a8ff | 208 | PullUp = 1, |
| bogdanm | 0:9b334a45a8ff | 209 | PullDown = 2, |
| bogdanm | 0:9b334a45a8ff | 210 | OpenDrain = 3, |
| bogdanm | 0:9b334a45a8ff | 211 | PullDefault = PullNone |
| bogdanm | 0:9b334a45a8ff | 212 | } PinMode; |
| bogdanm | 0:9b334a45a8ff | 213 | |
| bogdanm | 0:9b334a45a8ff | 214 | #ifdef __cplusplus |
| bogdanm | 0:9b334a45a8ff | 215 | } |
| bogdanm | 0:9b334a45a8ff | 216 | #endif |
| bogdanm | 0:9b334a45a8ff | 217 | |
| bogdanm | 0:9b334a45a8ff | 218 | #endif |
