t

Fork of mbed-dev by mbed official

Committer:
mbed_official
Date:
Tue Nov 17 14:45:12 2015 +0000
Revision:
23:ee8ca7052b3c
Parent:
0:9b334a45a8ff
Child:
144:ef7eb2e8f9f7
Synchronized with git revision 3e0c18b60af0653c7afeafd1fcf52da94bc5f4db

Full URL: https://github.com/mbedmicro/mbed/commit/3e0c18b60af0653c7afeafd1fcf52da94bc5f4db/

DISCO_F429ZI - discof429zi

Who changed what in which revision?

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