mbed library sources. Supersedes mbed-src.

Dependents:   Nucleo_Hello_Encoder BLE_iBeaconScan AM1805_DEMO DISCO-F429ZI_ExportTemplate1 ... more

Committer:
AnnaBridge
Date:
Thu Sep 06 13:40:20 2018 +0100
Revision:
187:0387e8f68319
Parent:
186:707f6e361f3e
Child:
188:bcfe06ba3d64
mbed-dev library. Release version 163

Who changed what in which revision?

UserRevisionLine numberNew contents of line
<> 149:156823d33999 1 /* mbed Microcontroller Library
<> 149:156823d33999 2 *******************************************************************************
Anna Bridge 186:707f6e361f3e 3 * Copyright (c) 2018, STMicroelectronics
<> 149:156823d33999 4 * All rights reserved.
<> 149:156823d33999 5 *
<> 149:156823d33999 6 * Redistribution and use in source and binary forms, with or without
<> 149:156823d33999 7 * modification, are permitted provided that the following conditions are met:
<> 149:156823d33999 8 *
<> 149:156823d33999 9 * 1. Redistributions of source code must retain the above copyright notice,
<> 149:156823d33999 10 * this list of conditions and the following disclaimer.
<> 149:156823d33999 11 * 2. Redistributions in binary form must reproduce the above copyright notice,
<> 149:156823d33999 12 * this list of conditions and the following disclaimer in the documentation
<> 149:156823d33999 13 * and/or other materials provided with the distribution.
<> 149:156823d33999 14 * 3. Neither the name of STMicroelectronics nor the names of its contributors
<> 149:156823d33999 15 * may be used to endorse or promote products derived from this software
<> 149:156823d33999 16 * without specific prior written permission.
<> 149:156823d33999 17 *
<> 149:156823d33999 18 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
<> 149:156823d33999 19 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
<> 149:156823d33999 20 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
<> 149:156823d33999 21 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
<> 149:156823d33999 22 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
<> 149:156823d33999 23 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
<> 149:156823d33999 24 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
<> 149:156823d33999 25 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
<> 149:156823d33999 26 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
<> 149:156823d33999 27 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
<> 149:156823d33999 28 *******************************************************************************
<> 149:156823d33999 29 */
Anna Bridge 186:707f6e361f3e 30
<> 149:156823d33999 31 #ifndef MBED_PINNAMES_H
<> 149:156823d33999 32 #define MBED_PINNAMES_H
<> 149:156823d33999 33
<> 149:156823d33999 34 #include "cmsis.h"
<> 157:ff67d9f36b67 35 #include "PinNamesTypes.h"
<> 149:156823d33999 36
<> 149:156823d33999 37 #ifdef __cplusplus
<> 149:156823d33999 38 extern "C" {
<> 149:156823d33999 39 #endif
<> 149:156823d33999 40
<> 149:156823d33999 41 typedef enum {
Anna Bridge 186:707f6e361f3e 42 ALT0 = 0x100,
Anna Bridge 186:707f6e361f3e 43 ALT1 = 0x200,
Anna Bridge 186:707f6e361f3e 44 ALT2 = 0x300,
Anna Bridge 186:707f6e361f3e 45 ALT3 = 0x400
Anna Bridge 186:707f6e361f3e 46 } ALTx;
Anna Bridge 186:707f6e361f3e 47
Anna Bridge 186:707f6e361f3e 48 typedef enum {
<> 149:156823d33999 49 PA_0 = 0x00, // On P1/P2 connectors
AnnaBridge 187:0387e8f68319 50 PA_0_ALT0 = PA_0 | ALT0,
<> 149:156823d33999 51 PA_1 = 0x01, // On P1/P2 connectors
AnnaBridge 187:0387e8f68319 52 PA_1_ALT0 = PA_1 | ALT0,
<> 149:156823d33999 53 PA_2 = 0x02, // On P1/P2 connectors
AnnaBridge 187:0387e8f68319 54 PA_2_ALT0 = PA_2 | ALT0,
<> 149:156823d33999 55 PA_3 = 0x03, // On P1/P2 connectors
AnnaBridge 187:0387e8f68319 56 PA_3_ALT0 = PA_3 | ALT0,
<> 149:156823d33999 57 PA_4 = 0x04,
AnnaBridge 187:0387e8f68319 58 PA_4_ALT0 = PA_4 | ALT0,
<> 149:156823d33999 59 PA_5 = 0x05, // On P1/P2 connectors
AnnaBridge 187:0387e8f68319 60 PA_5_ALT0 = PA_5 | ALT0,
<> 149:156823d33999 61 PA_6 = 0x06,
AnnaBridge 187:0387e8f68319 62 PA_6_ALT0 = PA_6 | ALT0,
<> 149:156823d33999 63 PA_7 = 0x07,
AnnaBridge 187:0387e8f68319 64 PA_7_ALT0 = PA_7 | ALT0,
AnnaBridge 187:0387e8f68319 65 PA_7_ALT1 = PA_7 | ALT1,
AnnaBridge 187:0387e8f68319 66 PA_7_ALT2 = PA_7 | ALT2,
<> 149:156823d33999 67 PA_8 = 0x08,
<> 149:156823d33999 68 PA_9 = 0x09,
<> 149:156823d33999 69 PA_10 = 0x0A,
<> 149:156823d33999 70 PA_11 = 0x0B,
<> 149:156823d33999 71 PA_12 = 0x0C,
<> 149:156823d33999 72 PA_13 = 0x0D,
<> 149:156823d33999 73 PA_14 = 0x0E,
<> 149:156823d33999 74 PA_15 = 0x0F,
AnnaBridge 187:0387e8f68319 75 PA_15_ALT0 = PA_15 | ALT0,
<> 149:156823d33999 76
<> 149:156823d33999 77 PB_0 = 0x10,
AnnaBridge 187:0387e8f68319 78 PB_0_ALT0 = PB_0 | ALT0,
AnnaBridge 187:0387e8f68319 79 PB_0_ALT1 = PB_0 | ALT1,
<> 149:156823d33999 80 PB_1 = 0x11,
AnnaBridge 187:0387e8f68319 81 PB_1_ALT0 = PB_1 | ALT0,
AnnaBridge 187:0387e8f68319 82 PB_1_ALT1 = PB_1 | ALT1,
<> 149:156823d33999 83 PB_2 = 0x12, // On P1/P2 connectors
<> 149:156823d33999 84 PB_3 = 0x13, // On P1/P2 connectors
AnnaBridge 187:0387e8f68319 85 PB_3_ALT0 = PB_3 | ALT0,
<> 149:156823d33999 86 PB_4 = 0x14,
AnnaBridge 187:0387e8f68319 87 PB_4_ALT0 = PB_4 | ALT0,
<> 149:156823d33999 88 PB_5 = 0x15,
AnnaBridge 187:0387e8f68319 89 PB_5_ALT0 = PB_5 | ALT0,
<> 149:156823d33999 90 PB_6 = 0x16,
AnnaBridge 187:0387e8f68319 91 PB_6_ALT0 = PB_6 | ALT0,
<> 149:156823d33999 92 PB_7 = 0x17,
AnnaBridge 187:0387e8f68319 93 PB_7_ALT0 = PB_7 | ALT0,
<> 149:156823d33999 94 PB_8 = 0x18, // On P1/P2 connectors
AnnaBridge 187:0387e8f68319 95 PB_8_ALT0 = PB_8 | ALT0,
<> 149:156823d33999 96 PB_9 = 0x19, // On P1/P2 connectors
AnnaBridge 187:0387e8f68319 97 PB_9_ALT0 = PB_9 | ALT0,
<> 149:156823d33999 98 PB_10 = 0x1A,
<> 149:156823d33999 99 PB_11 = 0x1B,
<> 149:156823d33999 100 PB_12 = 0x1C,
<> 149:156823d33999 101 PB_13 = 0x1D,
AnnaBridge 187:0387e8f68319 102 PB_13_ALT0 = PB_13 | ALT0,
<> 149:156823d33999 103 PB_14 = 0x1E,
AnnaBridge 187:0387e8f68319 104 PB_14_ALT0 = PB_14 | ALT0,
AnnaBridge 187:0387e8f68319 105 PB_14_ALT1 = PB_14 | ALT1,
<> 149:156823d33999 106 PB_15 = 0x1F,
AnnaBridge 187:0387e8f68319 107 PB_15_ALT0 = PB_15 | ALT0,
AnnaBridge 187:0387e8f68319 108 PB_15_ALT1 = PB_15 | ALT1,
<> 149:156823d33999 109
<> 149:156823d33999 110 PC_0 = 0x20,
AnnaBridge 187:0387e8f68319 111 PC_0_ALT0 = PC_0 | ALT0,
AnnaBridge 187:0387e8f68319 112 PC_0_ALT1 = PC_0 | ALT1,
<> 149:156823d33999 113 PC_1 = 0x21,
AnnaBridge 187:0387e8f68319 114 PC_1_ALT0 = PC_1 | ALT0,
AnnaBridge 187:0387e8f68319 115 PC_1_ALT1 = PC_1 | ALT1,
<> 149:156823d33999 116 PC_2 = 0x22,
AnnaBridge 187:0387e8f68319 117 PC_2_ALT0 = PC_2 | ALT0,
AnnaBridge 187:0387e8f68319 118 PC_2_ALT1 = PC_2 | ALT1,
<> 149:156823d33999 119 PC_3 = 0x23,
AnnaBridge 187:0387e8f68319 120 PC_3_ALT0 = PC_3 | ALT0,
AnnaBridge 187:0387e8f68319 121 PC_3_ALT1 = PC_3 | ALT1,
<> 149:156823d33999 122 PC_4 = 0x24,
AnnaBridge 187:0387e8f68319 123 PC_4_ALT0 = PC_4 | ALT0,
<> 149:156823d33999 124 PC_5 = 0x25,
AnnaBridge 187:0387e8f68319 125 PC_5_ALT0 = PC_5 | ALT0,
<> 149:156823d33999 126 PC_6 = 0x26,
AnnaBridge 187:0387e8f68319 127 PC_6_ALT0 = PC_6 | ALT0,
<> 149:156823d33999 128 PC_7 = 0x27,
AnnaBridge 187:0387e8f68319 129 PC_7_ALT0 = PC_7 | ALT0,
<> 149:156823d33999 130 PC_8 = 0x28,
AnnaBridge 187:0387e8f68319 131 PC_8_ALT0 = PC_8 | ALT0,
<> 149:156823d33999 132 PC_9 = 0x29,
AnnaBridge 187:0387e8f68319 133 PC_9_ALT0 = PC_9 | ALT0,
<> 149:156823d33999 134 PC_10 = 0x2A,
AnnaBridge 187:0387e8f68319 135 PC_10_ALT0 = PC_10 | ALT0,
<> 149:156823d33999 136 PC_11 = 0x2B,
AnnaBridge 187:0387e8f68319 137 PC_11_ALT0 = PC_11 | ALT0,
<> 149:156823d33999 138 PC_12 = 0x2C,
<> 149:156823d33999 139 PC_13 = 0x2D,
<> 149:156823d33999 140 PC_14 = 0x2E, // On P1/P2 connectors
<> 149:156823d33999 141 PC_15 = 0x2F, // On P1/P2 connectors
<> 149:156823d33999 142
<> 149:156823d33999 143 PD_0 = 0x30, // On P1/P2 connectors
<> 149:156823d33999 144 PD_1 = 0x31,
<> 149:156823d33999 145 PD_2 = 0x32,
<> 149:156823d33999 146 PD_3 = 0x33,
<> 149:156823d33999 147 PD_4 = 0x34,
<> 149:156823d33999 148 PD_5 = 0x35,
<> 149:156823d33999 149 PD_6 = 0x36,
<> 149:156823d33999 150 PD_7 = 0x37,
<> 149:156823d33999 151 PD_8 = 0x38,
<> 149:156823d33999 152 PD_9 = 0x39,
<> 149:156823d33999 153 PD_10 = 0x3A,
<> 149:156823d33999 154 PD_11 = 0x3B,
<> 149:156823d33999 155 PD_12 = 0x3C,
<> 149:156823d33999 156 PD_13 = 0x3D,
<> 149:156823d33999 157 PD_14 = 0x3E,
<> 149:156823d33999 158 PD_15 = 0x3F,
<> 149:156823d33999 159
<> 149:156823d33999 160 PE_0 = 0x40,
<> 149:156823d33999 161 PE_1 = 0x41,
<> 149:156823d33999 162 PE_2 = 0x42,
<> 149:156823d33999 163 PE_3 = 0x43,
<> 149:156823d33999 164 PE_4 = 0x44,
<> 149:156823d33999 165 PE_5 = 0x45,
<> 149:156823d33999 166 PE_6 = 0x46,
<> 149:156823d33999 167 PE_7 = 0x47,
<> 149:156823d33999 168 PE_8 = 0x48, // On P1/P2 connectors
<> 149:156823d33999 169 PE_9 = 0x49,
<> 149:156823d33999 170 PE_10 = 0x4A, // On P1/P2 connectors
<> 149:156823d33999 171 PE_11 = 0x4B, // On P1/P2 connectors
<> 149:156823d33999 172 PE_12 = 0x4C, // On P1/P2 connectors
<> 149:156823d33999 173 PE_13 = 0x4D, // On P1/P2 connectors
<> 149:156823d33999 174 PE_14 = 0x4E, // On P1/P2 connectors
<> 149:156823d33999 175 PE_15 = 0x4F, // On P1/P2 connectors
<> 149:156823d33999 176
<> 149:156823d33999 177 PH_0 = 0x70, // On P1/P2 connectors
<> 149:156823d33999 178 PH_1 = 0x71, // On P1/P2 connectors
<> 149:156823d33999 179
<> 149:156823d33999 180 // ADC internal channels
<> 149:156823d33999 181 ADC_TEMP = 0xF0,
<> 149:156823d33999 182 ADC_VREF = 0xF1,
<> 149:156823d33999 183 ADC_VBAT = 0xF2,
<> 149:156823d33999 184
AnnaBridge 181:57724642e740 185 // STDIO for console print
AnnaBridge 181:57724642e740 186 #ifdef MBED_CONF_TARGET_STDIO_UART_TX
AnnaBridge 181:57724642e740 187 STDIO_UART_TX = MBED_CONF_TARGET_STDIO_UART_TX,
AnnaBridge 181:57724642e740 188 #else
AnnaBridge 181:57724642e740 189 STDIO_UART_TX = PD_5,
AnnaBridge 181:57724642e740 190 #endif
AnnaBridge 181:57724642e740 191 #ifdef MBED_CONF_TARGET_STDIO_UART_RX
AnnaBridge 181:57724642e740 192 STDIO_UART_RX = MBED_CONF_TARGET_STDIO_UART_RX,
AnnaBridge 181:57724642e740 193 #else
AnnaBridge 181:57724642e740 194 STDIO_UART_RX = PD_6,
AnnaBridge 181:57724642e740 195 #endif
AnnaBridge 181:57724642e740 196
<> 149:156823d33999 197 // Generic signals namings
<> 149:156823d33999 198 LED1 = PE_8, // LD5 Green
<> 149:156823d33999 199 LED2 = PB_2, // LD4 Red
<> 149:156823d33999 200 LED3 = LED1,
<> 149:156823d33999 201 LED4 = LED2,
<> 149:156823d33999 202 JOYSTICK_CENTER = PA_0,
<> 149:156823d33999 203 JOYSTICK_LEFT = PA_1,
<> 149:156823d33999 204 JOYSTICK_RIGHT = PA_2,
<> 149:156823d33999 205 JOYSTICK_UP = PA_3,
<> 149:156823d33999 206 JOYSTICK_DOWN = PA_5,
<> 149:156823d33999 207 USER_BUTTON = JOYSTICK_CENTER,
Anna Bridge 164:289d4deac6e4 208 // Standardized button names
Anna Bridge 164:289d4deac6e4 209 BUTTON1 = USER_BUTTON,
Anna Bridge 164:289d4deac6e4 210 BUTTON2 = JOYSTICK_LEFT,
Anna Bridge 164:289d4deac6e4 211 BUTTON3 = JOYSTICK_RIGHT,
AnnaBridge 187:0387e8f68319 212 BUTTON4 = JOYSTICK_UP,
Anna Bridge 164:289d4deac6e4 213 BUTTON5 = JOYSTICK_DOWN,
Anna Bridge 164:289d4deac6e4 214
AnnaBridge 181:57724642e740 215 SERIAL_TX = STDIO_UART_TX,
AnnaBridge 181:57724642e740 216 SERIAL_RX = STDIO_UART_RX,
AnnaBridge 181:57724642e740 217 USBTX = STDIO_UART_TX,
AnnaBridge 181:57724642e740 218 USBRX = STDIO_UART_RX,
<> 149:156823d33999 219
<> 149:156823d33999 220 I2C_SCL = PB_8,
<> 149:156823d33999 221 I2C_SDA = PB_9,
<> 149:156823d33999 222 SPI_MOSI = PA_7,
<> 149:156823d33999 223 SPI_MISO = PA_6,
<> 149:156823d33999 224 SPI_SCK = PA_5,
<> 149:156823d33999 225 SPI_CS = PA_4,
<> 149:156823d33999 226 PWM_OUT = PB_3,
<> 149:156823d33999 227
AnnaBridge 187:0387e8f68319 228 /**** USB pins ****/
Anna Bridge 186:707f6e361f3e 229 USB_OTG_FS_DM = PA_11,
Anna Bridge 186:707f6e361f3e 230 USB_OTG_FS_DP = PA_12,
Anna Bridge 186:707f6e361f3e 231 USB_OTG_FS_ID = PA_10,
Anna Bridge 186:707f6e361f3e 232 USB_OTG_FS_NOE = PC_9,
Anna Bridge 186:707f6e361f3e 233 USB_OTG_FS_NOE_ALT0 = PA_13,
AnnaBridge 168:9672193075cf 234 USB_OTG_FS_SOF = PA_8,
AnnaBridge 168:9672193075cf 235 USB_OTG_FS_VBUS = PA_9,
Anna Bridge 186:707f6e361f3e 236
AnnaBridge 187:0387e8f68319 237 /**** OSCILLATOR pins ****/
Anna Bridge 186:707f6e361f3e 238 RCC_OSC32_IN = PC_14,
Anna Bridge 186:707f6e361f3e 239 RCC_OSC32_OUT = PC_15,
Anna Bridge 186:707f6e361f3e 240 RCC_OSC_IN = PH_0,
Anna Bridge 186:707f6e361f3e 241 RCC_OSC_OUT = PH_1,
Anna Bridge 186:707f6e361f3e 242
AnnaBridge 187:0387e8f68319 243 /**** DEBUG pins ****/
Anna Bridge 186:707f6e361f3e 244 SYS_JTCK_SWCLK = PA_14,
Anna Bridge 186:707f6e361f3e 245 SYS_JTDI = PA_15,
Anna Bridge 186:707f6e361f3e 246 SYS_JTDO_SWO = PB_3,
Anna Bridge 186:707f6e361f3e 247 SYS_JTMS_SWDIO = PA_13,
Anna Bridge 186:707f6e361f3e 248 SYS_JTRST = PB_4,
Anna Bridge 186:707f6e361f3e 249 SYS_PVD_IN = PB_7,
Anna Bridge 186:707f6e361f3e 250 SYS_TRACECLK = PE_2,
Anna Bridge 186:707f6e361f3e 251 SYS_TRACED0 = PE_3,
Anna Bridge 186:707f6e361f3e 252 SYS_TRACED1 = PE_4,
Anna Bridge 186:707f6e361f3e 253 SYS_TRACED2 = PE_5,
Anna Bridge 186:707f6e361f3e 254 SYS_TRACED3 = PE_6,
Anna Bridge 186:707f6e361f3e 255 SYS_WKUP1 = PA_0,
Anna Bridge 186:707f6e361f3e 256 SYS_WKUP2 = PC_13,
Anna Bridge 186:707f6e361f3e 257 SYS_WKUP3 = PE_6,
Anna Bridge 186:707f6e361f3e 258 SYS_WKUP4 = PA_2,
Anna Bridge 186:707f6e361f3e 259 SYS_WKUP5 = PC_5,
AnnaBridge 168:9672193075cf 260
<> 149:156823d33999 261 // Not connected
<> 149:156823d33999 262 NC = (int)0xFFFFFFFF
<> 149:156823d33999 263 } PinName;
<> 149:156823d33999 264
<> 149:156823d33999 265 #ifdef __cplusplus
<> 149:156823d33999 266 }
<> 149:156823d33999 267 #endif
<> 149:156823d33999 268
<> 149:156823d33999 269 #endif