mbed library sources. Supersedes mbed-src.

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

Committer:
<>
Date:
Fri Sep 02 15:07:44 2016 +0100
Revision:
144:ef7eb2e8f9f7
Parent:
0:9b334a45a8ff
Child:
147:30b64687e01f
This updates the lib to the mbed lib v125

Who changed what in which revision?

UserRevisionLine numberNew contents of line
<> 144:ef7eb2e8f9f7 1 /* mbed Microcontroller Library
<> 144:ef7eb2e8f9f7 2 *******************************************************************************
<> 144:ef7eb2e8f9f7 3 * Copyright (c) 2014, STMicroelectronics
<> 144:ef7eb2e8f9f7 4 * All rights reserved.
<> 144:ef7eb2e8f9f7 5 *
<> 144:ef7eb2e8f9f7 6 * Redistribution and use in source and binary forms, with or without
<> 144:ef7eb2e8f9f7 7 * modification, are permitted provided that the following conditions are met:
<> 144:ef7eb2e8f9f7 8 *
<> 144:ef7eb2e8f9f7 9 * 1. Redistributions of source code must retain the above copyright notice,
<> 144:ef7eb2e8f9f7 10 * this list of conditions and the following disclaimer.
<> 144:ef7eb2e8f9f7 11 * 2. Redistributions in binary form must reproduce the above copyright notice,
<> 144:ef7eb2e8f9f7 12 * this list of conditions and the following disclaimer in the documentation
<> 144:ef7eb2e8f9f7 13 * and/or other materials provided with the distribution.
<> 144:ef7eb2e8f9f7 14 * 3. Neither the name of STMicroelectronics nor the names of its contributors
<> 144:ef7eb2e8f9f7 15 * may be used to endorse or promote products derived from this software
<> 144:ef7eb2e8f9f7 16 * without specific prior written permission.
<> 144:ef7eb2e8f9f7 17 *
<> 144:ef7eb2e8f9f7 18 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
<> 144:ef7eb2e8f9f7 19 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
<> 144:ef7eb2e8f9f7 20 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
<> 144:ef7eb2e8f9f7 21 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
<> 144:ef7eb2e8f9f7 22 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
<> 144:ef7eb2e8f9f7 23 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
<> 144:ef7eb2e8f9f7 24 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
<> 144:ef7eb2e8f9f7 25 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
<> 144:ef7eb2e8f9f7 26 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
<> 144:ef7eb2e8f9f7 27 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
<> 144:ef7eb2e8f9f7 28 *******************************************************************************
<> 144:ef7eb2e8f9f7 29 */
<> 144:ef7eb2e8f9f7 30 #ifndef MBED_PINNAMES_H
<> 144:ef7eb2e8f9f7 31 #define MBED_PINNAMES_H
<> 144:ef7eb2e8f9f7 32
<> 144:ef7eb2e8f9f7 33 #include "cmsis.h"
<> 144:ef7eb2e8f9f7 34
<> 144:ef7eb2e8f9f7 35 #ifdef __cplusplus
<> 144:ef7eb2e8f9f7 36 extern "C" {
<> 144:ef7eb2e8f9f7 37 #endif
<> 144:ef7eb2e8f9f7 38
<> 144:ef7eb2e8f9f7 39 // See stm32f4xx_hal_gpio.h and stm32f4xx_hal_gpio_ex.h for values of MODE, PUPD and AFNUM
<> 144:ef7eb2e8f9f7 40 #define STM_PIN_DATA(MODE, PUPD, AFNUM) ((int)(((AFNUM) << 7) | ((PUPD) << 4) | ((MODE) << 0)))
<> 144:ef7eb2e8f9f7 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)))
<> 144:ef7eb2e8f9f7 42 #define STM_PIN_MODE(X) (((X) >> 0) & 0x0F)
<> 144:ef7eb2e8f9f7 43 #define STM_PIN_PUPD(X) (((X) >> 4) & 0x07)
<> 144:ef7eb2e8f9f7 44 #define STM_PIN_AFNUM(X) (((X) >> 7) & 0x0F)
<> 144:ef7eb2e8f9f7 45 #define STM_PIN_CHANNEL(X) (((X) >> 11) & 0x0F)
<> 144:ef7eb2e8f9f7 46 #define STM_PIN_INVERTED(X) (((X) >> 15) & 0x01)
<> 144:ef7eb2e8f9f7 47 #define STM_MODE_INPUT (0)
<> 144:ef7eb2e8f9f7 48 #define STM_MODE_OUTPUT_PP (1)
<> 144:ef7eb2e8f9f7 49 #define STM_MODE_OUTPUT_OD (2)
<> 144:ef7eb2e8f9f7 50 #define STM_MODE_AF_PP (3)
<> 144:ef7eb2e8f9f7 51 #define STM_MODE_AF_OD (4)
<> 144:ef7eb2e8f9f7 52 #define STM_MODE_ANALOG (5)
<> 144:ef7eb2e8f9f7 53 #define STM_MODE_IT_RISING (6)
<> 144:ef7eb2e8f9f7 54 #define STM_MODE_IT_FALLING (7)
<> 144:ef7eb2e8f9f7 55 #define STM_MODE_IT_RISING_FALLING (8)
<> 144:ef7eb2e8f9f7 56 #define STM_MODE_EVT_RISING (9)
<> 144:ef7eb2e8f9f7 57 #define STM_MODE_EVT_FALLING (10)
<> 144:ef7eb2e8f9f7 58 #define STM_MODE_EVT_RISING_FALLING (11)
<> 144:ef7eb2e8f9f7 59 #define STM_MODE_IT_EVT_RESET (12)
<> 144:ef7eb2e8f9f7 60
<> 144:ef7eb2e8f9f7 61 // High nibble = port number (0=A, 1=B, 2=C, 3=D, 4=E, 5=F, 6=G, 7=H)
<> 144:ef7eb2e8f9f7 62 // Low nibble = pin number
<> 144:ef7eb2e8f9f7 63 #define STM_PORT(X) (((uint32_t)(X) >> 4) & 0xF)
<> 144:ef7eb2e8f9f7 64 #define STM_PIN(X) ((uint32_t)(X) & 0xF)
<> 144:ef7eb2e8f9f7 65
<> 144:ef7eb2e8f9f7 66 typedef enum {
<> 144:ef7eb2e8f9f7 67 PIN_INPUT,
<> 144:ef7eb2e8f9f7 68 PIN_OUTPUT
<> 144:ef7eb2e8f9f7 69 } PinDirection;
<> 144:ef7eb2e8f9f7 70
<> 144:ef7eb2e8f9f7 71 typedef enum {
<> 144:ef7eb2e8f9f7 72 PA_0 = 0x00, PA_1 = 0x01, PA_2 = 0x02, PA_3 = 0x03,
<> 144:ef7eb2e8f9f7 73 PA_4 = 0x04, PA_5 = 0x05, PA_6 = 0x06, PA_7 = 0x07,
<> 144:ef7eb2e8f9f7 74 PA_8 = 0x08, PA_9 = 0x09, PA_10 = 0x0A, PA_11 = 0x0B,
<> 144:ef7eb2e8f9f7 75 PA_12 = 0x0C, PA_13 = 0x0D, PA_14 = 0x0E, PA_15 = 0x0F,
<> 144:ef7eb2e8f9f7 76
<> 144:ef7eb2e8f9f7 77 PB_0 = 0x10, PB_1 = 0x11, PB_2 = 0x12, PB_3 = 0x13,
<> 144:ef7eb2e8f9f7 78 PB_4 = 0x14, PB_5 = 0x15, PB_6 = 0x16, PB_7 = 0x17,
<> 144:ef7eb2e8f9f7 79 PB_8 = 0x18, PB_9 = 0x19, PB_10 = 0x1A, PB_11 = 0x1B,
<> 144:ef7eb2e8f9f7 80 PB_12 = 0x1C, PB_13 = 0x1D, PB_14 = 0x1E, PB_15 = 0x1F,
<> 144:ef7eb2e8f9f7 81
<> 144:ef7eb2e8f9f7 82 PC_0 = 0x20, PC_1 = 0x21, PC_2 = 0x22, PC_3 = 0x23,
<> 144:ef7eb2e8f9f7 83 PC_4 = 0x24, PC_5 = 0x25, PC_6 = 0x26, PC_7 = 0x27,
<> 144:ef7eb2e8f9f7 84 PC_8 = 0x28, PC_9 = 0x29, PC_10 = 0x2A, PC_11 = 0x2B,
<> 144:ef7eb2e8f9f7 85 PC_12 = 0x2C, PC_13 = 0x2D, PC_14 = 0x2E, PC_15 = 0x2F,
<> 144:ef7eb2e8f9f7 86
<> 144:ef7eb2e8f9f7 87 PD_0 = 0x30, PD_1 = 0x31, PD_2 = 0x32, PD_3 = 0x33,
<> 144:ef7eb2e8f9f7 88 PD_4 = 0x34, PD_5 = 0x35, PD_6 = 0x36, PD_7 = 0x37,
<> 144:ef7eb2e8f9f7 89 PD_8 = 0x38, PD_9 = 0x39, PD_10 = 0x3A, PD_11 = 0x3B,
<> 144:ef7eb2e8f9f7 90 PD_12 = 0x3C, PD_13 = 0x3D, PD_14 = 0x3E, PD_15 = 0x3F,
<> 144:ef7eb2e8f9f7 91
<> 144:ef7eb2e8f9f7 92 PE_0 = 0x40, PE_1 = 0x41, PE_2 = 0x42, PE_3 = 0x43,
<> 144:ef7eb2e8f9f7 93 PE_4 = 0x44, PE_5 = 0x45, PE_6 = 0x46, PE_7 = 0x47,
<> 144:ef7eb2e8f9f7 94 PE_8 = 0x48, PE_9 = 0x49, PE_10 = 0x4A, PE_11 = 0x4B,
<> 144:ef7eb2e8f9f7 95 PE_12 = 0x4C, PE_13 = 0x4D, PE_14 = 0x4E, PE_15 = 0x4F,
<> 144:ef7eb2e8f9f7 96
<> 144:ef7eb2e8f9f7 97 PF_0 = 0x50, PF_1 = 0x51, PF_2 = 0x52, PF_3 = 0x53,
<> 144:ef7eb2e8f9f7 98 PF_4 = 0x54, PF_5 = 0x55, PF_6 = 0x56, PF_7 = 0x57,
<> 144:ef7eb2e8f9f7 99 PF_8 = 0x58, PF_9 = 0x59, PF_10 = 0x5A, PF_11 = 0x5B,
<> 144:ef7eb2e8f9f7 100 PF_12 = 0x5C, PF_13 = 0x5D, PF_14 = 0x5E, PF_15 = 0x5F,
<> 144:ef7eb2e8f9f7 101
<> 144:ef7eb2e8f9f7 102 PG_0 = 0x60, PG_1 = 0x61, PG_2 = 0x62, PG_3 = 0x63,
<> 144:ef7eb2e8f9f7 103 PG_4 = 0x64, PG_5 = 0x65, PG_6 = 0x66, PG_7 = 0x67,
<> 144:ef7eb2e8f9f7 104 PG_8 = 0x68, PG_9 = 0x69, PG_10 = 0x6A, PG_11 = 0x6B,
<> 144:ef7eb2e8f9f7 105 PG_12 = 0x6C, PG_13 = 0x6D, PG_14 = 0x6E, PG_15 = 0x6F,
<> 144:ef7eb2e8f9f7 106
<> 144:ef7eb2e8f9f7 107 PH_0 = 0x70, PH_1 = 0x71, PH_2 = 0x72, PH_3 = 0x73,
<> 144:ef7eb2e8f9f7 108 PH_4 = 0x74, PH_5 = 0x75, PH_6 = 0x76, PH_7 = 0x77,
<> 144:ef7eb2e8f9f7 109 PH_8 = 0x78, PH_9 = 0x79, PH_10 = 0x7A, PH_11 = 0x7B,
<> 144:ef7eb2e8f9f7 110 PH_12 = 0x7C, PH_13 = 0x7D, PH_14 = 0x7E, PH_15 = 0x7F,
<> 144:ef7eb2e8f9f7 111
<> 144:ef7eb2e8f9f7 112 // Module Pins
<> 144:ef7eb2e8f9f7 113 // A
<> 144:ef7eb2e8f9f7 114 P_A5 = PC_2, // UART-DTR
<> 144:ef7eb2e8f9f7 115 P_A6 = PF_2, // Switch-0
<> 144:ef7eb2e8f9f7 116 P_A7 = PE_0, // Red, Mode
<> 144:ef7eb2e8f9f7 117 P_A8 = PB_6, // Green, Switch-1
<> 144:ef7eb2e8f9f7 118 P_A9 = PB_8, // Blue
<> 144:ef7eb2e8f9f7 119 P_A10 = PA_11, // UART-CTS
<> 144:ef7eb2e8f9f7 120 P_A11 = PA_9, // UART-TXD
<> 144:ef7eb2e8f9f7 121 P_A12 = PA_12, // UART-RTS
<> 144:ef7eb2e8f9f7 122 P_A13 = PA_10, // UART-RXD
<> 144:ef7eb2e8f9f7 123 P_A14 = PD_9, // GPIO-0
<> 144:ef7eb2e8f9f7 124 P_A15 = PD_8, // GPIO-1
<> 144:ef7eb2e8f9f7 125 P_A16 = PD_11, // GPIO-2
<> 144:ef7eb2e8f9f7 126 P_A17 = PD_12, // GPIO-3
<> 144:ef7eb2e8f9f7 127 P_A18 = PA_3, // UART-DSR
<> 144:ef7eb2e8f9f7 128 // B
<> 144:ef7eb2e8f9f7 129 // C
<> 144:ef7eb2e8f9f7 130 P_C5 = PG_4, // SPI-IRQ
<> 144:ef7eb2e8f9f7 131 P_C6 = PE_13, // SPI-MISO
<> 144:ef7eb2e8f9f7 132 P_C8 = PE_12, // Res
<> 144:ef7eb2e8f9f7 133 P_C10 = PE_14, // SPI-MOSI
<> 144:ef7eb2e8f9f7 134 P_C11 = PE_11, // SPI-CS0
<> 144:ef7eb2e8f9f7 135 P_C12 = PE_9, // Res
<> 144:ef7eb2e8f9f7 136 P_C13 = PF_6, // GPIO-4
<> 144:ef7eb2e8f9f7 137 P_C14 = PC_1, // RMII-MDC
<> 144:ef7eb2e8f9f7 138 P_C15 = PA_2, // RMII-MDIO
<> 144:ef7eb2e8f9f7 139 P_C16 = PF_7, // GPIO-7
<> 144:ef7eb2e8f9f7 140 P_C17 = PF_1, // I2C-SCL
<> 144:ef7eb2e8f9f7 141 P_C18 = PF_0, // I2C-SDA
<> 144:ef7eb2e8f9f7 142 // D
<> 144:ef7eb2e8f9f7 143 P_D1 = PB_12, // RMII-TXD0
<> 144:ef7eb2e8f9f7 144 P_D2 = PB_13, // RMII-TXD1
<> 144:ef7eb2e8f9f7 145 P_D3 = PB_11, // RMII-TXEN
<> 144:ef7eb2e8f9f7 146 P_D4 = PA_7, // RMII-CRSDV
<> 144:ef7eb2e8f9f7 147 P_D5 = PC_4, // RMII-RXD0
<> 144:ef7eb2e8f9f7 148 P_D6 = PC_5, // RMII-RXD1
<> 144:ef7eb2e8f9f7 149 P_D8 = PA_1, // RMII-REFCLK
<> 144:ef7eb2e8f9f7 150 // TP
<> 144:ef7eb2e8f9f7 151 P_TP5 = PB_4, // NTRST
<> 144:ef7eb2e8f9f7 152 P_TP7 = PA_13, // TMS SWDIO
<> 144:ef7eb2e8f9f7 153 P_TP8 = PA_15, // TDI
<> 144:ef7eb2e8f9f7 154 P_TP9 = PA_14, // TCK SWCLK
<> 144:ef7eb2e8f9f7 155 P_TP10 = PB_3, // TDO
<> 144:ef7eb2e8f9f7 156 //P_TP11, // BOOT0
<> 144:ef7eb2e8f9f7 157
<> 144:ef7eb2e8f9f7 158 // Board Pins
<> 144:ef7eb2e8f9f7 159 // A0-A5
<> 144:ef7eb2e8f9f7 160 A0 = PF_6, // AI4
<> 144:ef7eb2e8f9f7 161 A1 = PA_3, // AI3
<> 144:ef7eb2e8f9f7 162 A2 = PC_2, // AI12
<> 144:ef7eb2e8f9f7 163 A3 = PF_7, // LPOCLK, not AI
<> 144:ef7eb2e8f9f7 164 A4 = PG_4, // not AI
<> 144:ef7eb2e8f9f7 165 A5 = PB_3, // not AI
<> 144:ef7eb2e8f9f7 166 // D0-D15
<> 144:ef7eb2e8f9f7 167 D0 = PD_9, // UART3-RX
<> 144:ef7eb2e8f9f7 168 D1 = PD_8, // UART3-TX
<> 144:ef7eb2e8f9f7 169 D2 = PA_10, // UART1-RX
<> 144:ef7eb2e8f9f7 170 D3 = PA_11, // CAN1-RX
<> 144:ef7eb2e8f9f7 171 D4 = PA_12, // CAN1-TX
<> 144:ef7eb2e8f9f7 172 D5 = PA_15,
<> 144:ef7eb2e8f9f7 173 D6 = PD_11, // UART3-CTS
<> 144:ef7eb2e8f9f7 174 D7 = PD_12, // UART3-RTS
<> 144:ef7eb2e8f9f7 175 D8 = PA_9, // UART1-TX
<> 144:ef7eb2e8f9f7 176 D9 = PE_9, // SDCard-CS
<> 144:ef7eb2e8f9f7 177 D10 = PE_11, // SSEL
<> 144:ef7eb2e8f9f7 178 D11 = PE_14, // MOSI
<> 144:ef7eb2e8f9f7 179 D12 = PE_13, // MISO
<> 144:ef7eb2e8f9f7 180 D13 = PE_12, // SCK
<> 144:ef7eb2e8f9f7 181 D14 = PF_0, // SDA
<> 144:ef7eb2e8f9f7 182 D15 = PF_1, // SCL
<> 144:ef7eb2e8f9f7 183 // Internal
<> 144:ef7eb2e8f9f7 184 LED_RED = PE_0, // Red / Mode
<> 144:ef7eb2e8f9f7 185 LED_GRE = PB_6, // Green / Switch-1
<> 144:ef7eb2e8f9f7 186 LED_BLU = PB_8, // Blue
<> 144:ef7eb2e8f9f7 187 SW0 = PF_2, // Switch-0
<> 144:ef7eb2e8f9f7 188 SW1 = PB_6, // Green / Switch-1
<> 144:ef7eb2e8f9f7 189 // ST-Link
<> 144:ef7eb2e8f9f7 190 USBRXD = PD_9,
<> 144:ef7eb2e8f9f7 191 USBTXD = PD_8,
<> 144:ef7eb2e8f9f7 192 SWDIO = PA_15,
<> 144:ef7eb2e8f9f7 193 SWCLK = PA_14,
<> 144:ef7eb2e8f9f7 194 NTRST = PB_4,
<> 144:ef7eb2e8f9f7 195
<> 144:ef7eb2e8f9f7 196 // Not connected
<> 144:ef7eb2e8f9f7 197 NC = (int)0xFFFFFFFF
<> 144:ef7eb2e8f9f7 198 } PinName;
<> 144:ef7eb2e8f9f7 199
<> 144:ef7eb2e8f9f7 200 typedef enum {
<> 144:ef7eb2e8f9f7 201 PullNone = 0,
<> 144:ef7eb2e8f9f7 202 PullUp = 1,
<> 144:ef7eb2e8f9f7 203 PullDown = 2,
<> 144:ef7eb2e8f9f7 204 OpenDrain = 3,
<> 144:ef7eb2e8f9f7 205 PullDefault = PullNone
<> 144:ef7eb2e8f9f7 206 } PinMode;
<> 144:ef7eb2e8f9f7 207
<> 144:ef7eb2e8f9f7 208 #ifdef __cplusplus
<> 144:ef7eb2e8f9f7 209 }
<> 144:ef7eb2e8f9f7 210 #endif
<> 144:ef7eb2e8f9f7 211
<> 144:ef7eb2e8f9f7 212 #endif