t

Fork of mbed-dev by mbed official

Committer:
<>
Date:
Fri Sep 02 15:07:44 2016 +0100
Revision:
144:ef7eb2e8f9f7
Parent:
23:ee8ca7052b3c
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) 2015, 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)(((MODE & 0x0F) << 0) |\
<> 144:ef7eb2e8f9f7 41 ((PUPD & 0x07) << 4) |\
<> 144:ef7eb2e8f9f7 42 ((AFNUM & 0x0F) << 7)))
<> 144:ef7eb2e8f9f7 43
<> 144:ef7eb2e8f9f7 44 #define STM_PIN_DATA_EXT(MODE, PUPD, AFNUM, CHANNEL, INVERTED) ((int)(((MODE & 0x0F) << 0) |\
<> 144:ef7eb2e8f9f7 45 ((PUPD & 0x07) << 4) |\
<> 144:ef7eb2e8f9f7 46 ((AFNUM & 0x0F) << 7) |\
<> 144:ef7eb2e8f9f7 47 ((CHANNEL & 0x0F) << 11) |\
<> 144:ef7eb2e8f9f7 48 ((INVERTED & 0x01) << 15)))
<> 144:ef7eb2e8f9f7 49
<> 144:ef7eb2e8f9f7 50 #define STM_PIN_MODE(X) (((X) >> 0) & 0x0F)
<> 144:ef7eb2e8f9f7 51 #define STM_PIN_PUPD(X) (((X) >> 4) & 0x07)
<> 144:ef7eb2e8f9f7 52 #define STM_PIN_AFNUM(X) (((X) >> 7) & 0x0F)
<> 144:ef7eb2e8f9f7 53 #define STM_PIN_CHANNEL(X) (((X) >> 11) & 0x0F)
<> 144:ef7eb2e8f9f7 54 #define STM_PIN_INVERTED(X) (((X) >> 15) & 0x01)
<> 144:ef7eb2e8f9f7 55 #define STM_MODE_INPUT (0)
<> 144:ef7eb2e8f9f7 56 #define STM_MODE_OUTPUT_PP (1)
<> 144:ef7eb2e8f9f7 57 #define STM_MODE_OUTPUT_OD (2)
<> 144:ef7eb2e8f9f7 58 #define STM_MODE_AF_PP (3)
<> 144:ef7eb2e8f9f7 59 #define STM_MODE_AF_OD (4)
<> 144:ef7eb2e8f9f7 60 #define STM_MODE_ANALOG (5)
<> 144:ef7eb2e8f9f7 61 #define STM_MODE_IT_RISING (6)
<> 144:ef7eb2e8f9f7 62 #define STM_MODE_IT_FALLING (7)
<> 144:ef7eb2e8f9f7 63 #define STM_MODE_IT_RISING_FALLING (8)
<> 144:ef7eb2e8f9f7 64 #define STM_MODE_EVT_RISING (9)
<> 144:ef7eb2e8f9f7 65 #define STM_MODE_EVT_FALLING (10)
<> 144:ef7eb2e8f9f7 66 #define STM_MODE_EVT_RISING_FALLING (11)
<> 144:ef7eb2e8f9f7 67 #define STM_MODE_IT_EVT_RESET (12)
<> 144:ef7eb2e8f9f7 68
<> 144:ef7eb2e8f9f7 69 // High nibble = port number (0=A, 1=B, 2=C, 3=D, 4=E, 5=F, 6=G, 7=H)
<> 144:ef7eb2e8f9f7 70 // Low nibble = pin number
<> 144:ef7eb2e8f9f7 71 #define STM_PORT(X) (((uint32_t)(X) >> 4) & 0xF)
<> 144:ef7eb2e8f9f7 72 #define STM_PIN(X) ((uint32_t)(X) & 0xF)
<> 144:ef7eb2e8f9f7 73
<> 144:ef7eb2e8f9f7 74 typedef enum {
<> 144:ef7eb2e8f9f7 75 PIN_INPUT,
<> 144:ef7eb2e8f9f7 76 PIN_OUTPUT
<> 144:ef7eb2e8f9f7 77 } PinDirection;
<> 144:ef7eb2e8f9f7 78
<> 144:ef7eb2e8f9f7 79 typedef enum {
<> 144:ef7eb2e8f9f7 80 PA_0 = 0x00,
<> 144:ef7eb2e8f9f7 81 PA_1 = 0x01,
<> 144:ef7eb2e8f9f7 82 PA_2 = 0x02,
<> 144:ef7eb2e8f9f7 83 PA_3 = 0x03,
<> 144:ef7eb2e8f9f7 84 PA_4 = 0x04,
<> 144:ef7eb2e8f9f7 85 PA_5 = 0x05,
<> 144:ef7eb2e8f9f7 86 PA_6 = 0x06,
<> 144:ef7eb2e8f9f7 87 PA_7 = 0x07,
<> 144:ef7eb2e8f9f7 88 PA_8 = 0x08,
<> 144:ef7eb2e8f9f7 89 PA_9 = 0x09,
<> 144:ef7eb2e8f9f7 90 PA_10 = 0x0A,
<> 144:ef7eb2e8f9f7 91 PA_11 = 0x0B,
<> 144:ef7eb2e8f9f7 92 PA_12 = 0x0C,
<> 144:ef7eb2e8f9f7 93 PA_13 = 0x0D,
<> 144:ef7eb2e8f9f7 94 PA_14 = 0x0E,
<> 144:ef7eb2e8f9f7 95 PA_15 = 0x0F,
<> 144:ef7eb2e8f9f7 96
<> 144:ef7eb2e8f9f7 97 PB_0 = 0x10,
<> 144:ef7eb2e8f9f7 98 PB_1 = 0x11,
<> 144:ef7eb2e8f9f7 99 PB_2 = 0x12,
<> 144:ef7eb2e8f9f7 100 PB_3 = 0x13,
<> 144:ef7eb2e8f9f7 101 PB_4 = 0x14,
<> 144:ef7eb2e8f9f7 102 PB_5 = 0x15,
<> 144:ef7eb2e8f9f7 103 PB_6 = 0x16,
<> 144:ef7eb2e8f9f7 104 PB_7 = 0x17,
<> 144:ef7eb2e8f9f7 105 PB_8 = 0x18,
<> 144:ef7eb2e8f9f7 106 PB_9 = 0x19,
<> 144:ef7eb2e8f9f7 107 PB_10 = 0x1A,
<> 144:ef7eb2e8f9f7 108 PB_11 = 0x1B,
<> 144:ef7eb2e8f9f7 109 PB_12 = 0x1C,
<> 144:ef7eb2e8f9f7 110 PB_13 = 0x1D,
<> 144:ef7eb2e8f9f7 111 PB_14 = 0x1E,
<> 144:ef7eb2e8f9f7 112 PB_15 = 0x1F,
<> 144:ef7eb2e8f9f7 113
<> 144:ef7eb2e8f9f7 114 PC_0 = 0x20,
<> 144:ef7eb2e8f9f7 115 PC_1 = 0x21,
<> 144:ef7eb2e8f9f7 116 PC_2 = 0x22,
<> 144:ef7eb2e8f9f7 117 PC_3 = 0x23,
<> 144:ef7eb2e8f9f7 118 PC_4 = 0x24,
<> 144:ef7eb2e8f9f7 119 PC_5 = 0x25,
<> 144:ef7eb2e8f9f7 120 PC_6 = 0x26,
<> 144:ef7eb2e8f9f7 121 PC_7 = 0x27,
<> 144:ef7eb2e8f9f7 122 PC_8 = 0x28,
<> 144:ef7eb2e8f9f7 123 PC_9 = 0x29,
<> 144:ef7eb2e8f9f7 124 PC_10 = 0x2A,
<> 144:ef7eb2e8f9f7 125 PC_11 = 0x2B,
<> 144:ef7eb2e8f9f7 126 PC_12 = 0x2C,
<> 144:ef7eb2e8f9f7 127 PC_13 = 0x2D,
<> 144:ef7eb2e8f9f7 128 PC_14 = 0x2E,
<> 144:ef7eb2e8f9f7 129 PC_15 = 0x2F,
<> 144:ef7eb2e8f9f7 130
<> 144:ef7eb2e8f9f7 131 PD_0 = 0x30,
<> 144:ef7eb2e8f9f7 132 PD_1 = 0x31,
<> 144:ef7eb2e8f9f7 133 PD_2 = 0x32,
<> 144:ef7eb2e8f9f7 134 PD_3 = 0x33,
<> 144:ef7eb2e8f9f7 135 PD_4 = 0x34,
<> 144:ef7eb2e8f9f7 136 PD_5 = 0x35,
<> 144:ef7eb2e8f9f7 137 PD_6 = 0x36,
<> 144:ef7eb2e8f9f7 138 PD_7 = 0x37,
<> 144:ef7eb2e8f9f7 139 PD_8 = 0x38,
<> 144:ef7eb2e8f9f7 140 PD_9 = 0x39,
<> 144:ef7eb2e8f9f7 141 PD_10 = 0x3A,
<> 144:ef7eb2e8f9f7 142 PD_11 = 0x3B,
<> 144:ef7eb2e8f9f7 143 PD_12 = 0x3C,
<> 144:ef7eb2e8f9f7 144 PD_13 = 0x3D,
<> 144:ef7eb2e8f9f7 145 PD_14 = 0x3E,
<> 144:ef7eb2e8f9f7 146 PD_15 = 0x3F,
<> 144:ef7eb2e8f9f7 147
<> 144:ef7eb2e8f9f7 148 PE_0 = 0x40,
<> 144:ef7eb2e8f9f7 149 PE_1 = 0x41,
<> 144:ef7eb2e8f9f7 150 PE_2 = 0x42,
<> 144:ef7eb2e8f9f7 151 PE_3 = 0x43,
<> 144:ef7eb2e8f9f7 152 PE_4 = 0x44,
<> 144:ef7eb2e8f9f7 153 PE_5 = 0x45,
<> 144:ef7eb2e8f9f7 154 PE_6 = 0x46,
<> 144:ef7eb2e8f9f7 155 PE_7 = 0x47,
<> 144:ef7eb2e8f9f7 156 PE_8 = 0x48,
<> 144:ef7eb2e8f9f7 157 PE_9 = 0x49,
<> 144:ef7eb2e8f9f7 158 PE_10 = 0x4A,
<> 144:ef7eb2e8f9f7 159 PE_11 = 0x4B,
<> 144:ef7eb2e8f9f7 160 PE_12 = 0x4C,
<> 144:ef7eb2e8f9f7 161 PE_13 = 0x4D,
<> 144:ef7eb2e8f9f7 162 PE_14 = 0x4E,
<> 144:ef7eb2e8f9f7 163 PE_15 = 0x4F,
<> 144:ef7eb2e8f9f7 164
<> 144:ef7eb2e8f9f7 165
<> 144:ef7eb2e8f9f7 166 PF_0 = 0x50,
<> 144:ef7eb2e8f9f7 167 PF_1 = 0x51,
<> 144:ef7eb2e8f9f7 168 PF_2 = 0x52,
<> 144:ef7eb2e8f9f7 169 PF_3 = 0x53,
<> 144:ef7eb2e8f9f7 170 PF_4 = 0x54,
<> 144:ef7eb2e8f9f7 171 PF_5 = 0x55,
<> 144:ef7eb2e8f9f7 172 PF_6 = 0x56,
<> 144:ef7eb2e8f9f7 173 PF_7 = 0x57,
<> 144:ef7eb2e8f9f7 174 PF_8 = 0x58,
<> 144:ef7eb2e8f9f7 175 PF_9 = 0x59,
<> 144:ef7eb2e8f9f7 176 PF_10 = 0x5A,
<> 144:ef7eb2e8f9f7 177 PF_11 = 0x5B,
<> 144:ef7eb2e8f9f7 178 PF_12 = 0x5C,
<> 144:ef7eb2e8f9f7 179 PF_13 = 0x5D,
<> 144:ef7eb2e8f9f7 180 PF_14 = 0x5E,
<> 144:ef7eb2e8f9f7 181 PF_15 = 0x5F,
<> 144:ef7eb2e8f9f7 182
<> 144:ef7eb2e8f9f7 183
<> 144:ef7eb2e8f9f7 184 PG_0 = 0x60,
<> 144:ef7eb2e8f9f7 185 PG_1 = 0x61,
<> 144:ef7eb2e8f9f7 186 PG_2 = 0x62,
<> 144:ef7eb2e8f9f7 187 PG_3 = 0x63,
<> 144:ef7eb2e8f9f7 188 PG_4 = 0x64,
<> 144:ef7eb2e8f9f7 189 PG_5 = 0x65,
<> 144:ef7eb2e8f9f7 190 PG_6 = 0x66,
<> 144:ef7eb2e8f9f7 191 PG_7 = 0x67,
<> 144:ef7eb2e8f9f7 192 PG_8 = 0x68,
<> 144:ef7eb2e8f9f7 193 PG_9 = 0x69,
<> 144:ef7eb2e8f9f7 194 PG_10 = 0x6A,
<> 144:ef7eb2e8f9f7 195 PG_11 = 0x6B,
<> 144:ef7eb2e8f9f7 196 PG_12 = 0x6C,
<> 144:ef7eb2e8f9f7 197 PG_13 = 0x6D,
<> 144:ef7eb2e8f9f7 198 PG_14 = 0x6E,
<> 144:ef7eb2e8f9f7 199 PG_15 = 0x6F,
<> 144:ef7eb2e8f9f7 200
<> 144:ef7eb2e8f9f7 201
<> 144:ef7eb2e8f9f7 202 PH_0 = 0x70,
<> 144:ef7eb2e8f9f7 203 PH_1 = 0x71,
<> 144:ef7eb2e8f9f7 204
<> 144:ef7eb2e8f9f7 205 // Generic signals namings
<> 144:ef7eb2e8f9f7 206 LED1 = PG_13, // Corresponds to LD3 on MB1075B
<> 144:ef7eb2e8f9f7 207 LED2 = PG_14, // Corresponds to LD4 on MB1075B
<> 144:ef7eb2e8f9f7 208 LED3 = PG_13,
<> 144:ef7eb2e8f9f7 209 LED4 = PG_14,
<> 144:ef7eb2e8f9f7 210 USER_BUTTON = PA_0,
<> 144:ef7eb2e8f9f7 211 SERIAL_TX = PA_9,
<> 144:ef7eb2e8f9f7 212 SERIAL_RX = PA_10,
<> 144:ef7eb2e8f9f7 213 USBTX = PA_9,
<> 144:ef7eb2e8f9f7 214 USBRX = PA_10,
<> 144:ef7eb2e8f9f7 215 SPI_MOSI = PA_7,
<> 144:ef7eb2e8f9f7 216 SPI_MISO = PA_6,
<> 144:ef7eb2e8f9f7 217 SPI_SCK = PA_5,
<> 144:ef7eb2e8f9f7 218 SPI_CS = PB_6,
<> 144:ef7eb2e8f9f7 219
<> 144:ef7eb2e8f9f7 220 // Not connected
<> 144:ef7eb2e8f9f7 221 NC = (int)0xFFFFFFFF
<> 144:ef7eb2e8f9f7 222 } PinName;
<> 144:ef7eb2e8f9f7 223
<> 144:ef7eb2e8f9f7 224 typedef enum {
<> 144:ef7eb2e8f9f7 225 PullNone = 0,
<> 144:ef7eb2e8f9f7 226 PullUp = 1,
<> 144:ef7eb2e8f9f7 227 PullDown = 2,
<> 144:ef7eb2e8f9f7 228 OpenDrain = 3,
<> 144:ef7eb2e8f9f7 229 PullDefault = PullNone
<> 144:ef7eb2e8f9f7 230 } PinMode;
<> 144:ef7eb2e8f9f7 231
<> 144:ef7eb2e8f9f7 232 #ifdef __cplusplus
<> 144:ef7eb2e8f9f7 233 }
<> 144:ef7eb2e8f9f7 234 #endif
<> 144:ef7eb2e8f9f7 235
<> 144:ef7eb2e8f9f7 236 #endif