mbed library sources. Supersedes mbed-src.

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

Committer:
AnnaBridge
Date:
Thu Nov 08 11:46:34 2018 +0000
Revision:
188:bcfe06ba3d64
Parent:
181:57724642e740
mbed-dev library. Release version 164

Who changed what in which revision?

UserRevisionLine numberNew contents of line
AnnaBridge 181:57724642e740 1 /* mbed Microcontroller Library
AnnaBridge 181:57724642e740 2 *******************************************************************************
AnnaBridge 181:57724642e740 3 * Copyright (c) 2017, STMicroelectronics
AnnaBridge 181:57724642e740 4 * All rights reserved.
AnnaBridge 181:57724642e740 5 *
AnnaBridge 181:57724642e740 6 * Redistribution and use in source and binary forms, with or without
AnnaBridge 181:57724642e740 7 * modification, are permitted provided that the following conditions are met:
AnnaBridge 181:57724642e740 8 *
AnnaBridge 181:57724642e740 9 * 1. Redistributions of source code must retain the above copyright notice,
AnnaBridge 181:57724642e740 10 * this list of conditions and the following disclaimer.
AnnaBridge 181:57724642e740 11 * 2. Redistributions in binary form must reproduce the above copyright notice,
AnnaBridge 181:57724642e740 12 * this list of conditions and the following disclaimer in the documentation
AnnaBridge 181:57724642e740 13 * and/or other materials provided with the distribution.
AnnaBridge 181:57724642e740 14 * 3. Neither the name of STMicroelectronics nor the names of its contributors
AnnaBridge 181:57724642e740 15 * may be used to endorse or promote products derived from this software
AnnaBridge 181:57724642e740 16 * without specific prior written permission.
AnnaBridge 181:57724642e740 17 *
AnnaBridge 181:57724642e740 18 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
AnnaBridge 181:57724642e740 19 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
AnnaBridge 181:57724642e740 20 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
AnnaBridge 181:57724642e740 21 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
AnnaBridge 181:57724642e740 22 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
AnnaBridge 181:57724642e740 23 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
AnnaBridge 181:57724642e740 24 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
AnnaBridge 181:57724642e740 25 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
AnnaBridge 181:57724642e740 26 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
AnnaBridge 181:57724642e740 27 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
AnnaBridge 181:57724642e740 28 *******************************************************************************
AnnaBridge 181:57724642e740 29 */
AnnaBridge 181:57724642e740 30
AnnaBridge 181:57724642e740 31 #include "PeripheralPins.h"
AnnaBridge 181:57724642e740 32
AnnaBridge 181:57724642e740 33 // =====
AnnaBridge 181:57724642e740 34 // Note: Commented lines are alternative possibilities which are not used per default.
AnnaBridge 181:57724642e740 35 // If you change them, you will have also to modify the corresponding xxx_api.c file
AnnaBridge 181:57724642e740 36 // for pwmout, analogin, analogout, ...
AnnaBridge 181:57724642e740 37 // =====
AnnaBridge 181:57724642e740 38
AnnaBridge 181:57724642e740 39 //*** ADC ***
AnnaBridge 181:57724642e740 40
AnnaBridge 181:57724642e740 41 const PinMap PinMap_ADC[] = {
AnnaBridge 181:57724642e740 42 {PA_0, ADC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 0, 0)}, // BLUE-LED
AnnaBridge 181:57724642e740 43 {PA_2, ADC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 2, 0)}, // POT
AnnaBridge 181:57724642e740 44 {PA_3, ADC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 3, 0)}, // BUTTON
AnnaBridge 181:57724642e740 45 {PA_4, ADC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 4, 0)}, // RED-LED
AnnaBridge 181:57724642e740 46 {PA_5, ADC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 5, 0)}, // GREEN-LED
AnnaBridge 181:57724642e740 47 {NC, NC, 0}
AnnaBridge 181:57724642e740 48 };
AnnaBridge 181:57724642e740 49
AnnaBridge 181:57724642e740 50 const PinMap PinMap_ADC_Internal[] = {
AnnaBridge 188:bcfe06ba3d64 51 {ADC_VREF, ADC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 17, 0)}, // ADC_IN17 // VREFINT
AnnaBridge 188:bcfe06ba3d64 52 {ADC_TEMP, ADC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 18, 0)}, // ADC_IN18 // VSENSE
AnnaBridge 181:57724642e740 53 {NC, NC, 0}
AnnaBridge 181:57724642e740 54 };
AnnaBridge 181:57724642e740 55
AnnaBridge 181:57724642e740 56 //*** DAC ***
AnnaBridge 181:57724642e740 57
AnnaBridge 181:57724642e740 58 const PinMap PinMap_DAC[] = {
AnnaBridge 181:57724642e740 59 {PA_4, DAC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 1, 0)}, // RED-LED
AnnaBridge 181:57724642e740 60 {PA_5, DAC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 2, 0)}, // GREEN-LED
AnnaBridge 181:57724642e740 61 {NC, NC, 0}
AnnaBridge 181:57724642e740 62 };
AnnaBridge 181:57724642e740 63
AnnaBridge 181:57724642e740 64 //*** I2C ***
AnnaBridge 181:57724642e740 65
AnnaBridge 181:57724642e740 66 const PinMap PinMap_I2C_SDA[] = {
AnnaBridge 181:57724642e740 67 {PA_10, I2C_1, STM_PIN_DATA(STM_MODE_AF_OD, GPIO_NOPULL, GPIO_AF6_I2C1)},
AnnaBridge 181:57724642e740 68 {PB_7, I2C_1, STM_PIN_DATA(STM_MODE_AF_OD, GPIO_NOPULL, GPIO_AF1_I2C1)},
AnnaBridge 181:57724642e740 69 {PB_9, I2C_1, STM_PIN_DATA(STM_MODE_AF_OD, GPIO_NOPULL, GPIO_AF4_I2C1)}, // SDA
AnnaBridge 181:57724642e740 70 {PB_14, I2C_2, STM_PIN_DATA(STM_MODE_AF_OD, GPIO_NOPULL, GPIO_AF5_I2C2)},
AnnaBridge 181:57724642e740 71 {NC, NC, 0}
AnnaBridge 181:57724642e740 72 };
AnnaBridge 181:57724642e740 73
AnnaBridge 181:57724642e740 74 const PinMap PinMap_I2C_SCL[] = {
AnnaBridge 181:57724642e740 75 {PA_9, I2C_1, STM_PIN_DATA(STM_MODE_AF_OD, GPIO_NOPULL, GPIO_AF6_I2C1)},
AnnaBridge 181:57724642e740 76 {PB_6, I2C_1, STM_PIN_DATA(STM_MODE_AF_OD, GPIO_NOPULL, GPIO_AF1_I2C1)},
AnnaBridge 181:57724642e740 77 {PB_8, I2C_1, STM_PIN_DATA(STM_MODE_AF_OD, GPIO_NOPULL, GPIO_AF4_I2C1)}, // SCL
AnnaBridge 181:57724642e740 78 {PB_13, I2C_2, STM_PIN_DATA(STM_MODE_AF_OD, GPIO_NOPULL, GPIO_AF5_I2C2)},
AnnaBridge 181:57724642e740 79 {NC, NC, 0}
AnnaBridge 181:57724642e740 80 };
AnnaBridge 181:57724642e740 81
AnnaBridge 181:57724642e740 82 //*** PWM ***
AnnaBridge 181:57724642e740 83 // Pins using TIM21 cannot be used as TIM21 is already used by ticker.
AnnaBridge 181:57724642e740 84 const PinMap PinMap_PWM[] = {
AnnaBridge 181:57724642e740 85 {PA_0, PWM_2, STM_PIN_DATA_EXT(STM_MODE_AF_PP, GPIO_PULLUP, GPIO_AF2_TIM2, 1, 0)}, // TIM2_CH1
AnnaBridge 181:57724642e740 86 // {PA_2, PWM_21, STM_PIN_DATA_EXT(STM_MODE_AF_PP, GPIO_PULLUP, GPIO_AF0_TIM21, 1, 0)}, // TIM21_CH1
AnnaBridge 181:57724642e740 87 {PA_2_ALT0, PWM_2, STM_PIN_DATA_EXT(STM_MODE_AF_PP, GPIO_PULLUP, GPIO_AF2_TIM2, 3, 0)}, // TIM2_CH3
AnnaBridge 181:57724642e740 88 // {PA_3, PWM_21, STM_PIN_DATA_EXT(STM_MODE_AF_PP, GPIO_PULLUP, GPIO_AF0_TIM21, 2, 0)}, // TIM21_CH2
AnnaBridge 181:57724642e740 89 {PA_3_ALT0, PWM_2, STM_PIN_DATA_EXT(STM_MODE_AF_PP, GPIO_PULLUP, GPIO_AF2_TIM2, 4, 0)}, // TIM2_CH4
AnnaBridge 181:57724642e740 90 {PA_5, PWM_2, STM_PIN_DATA_EXT(STM_MODE_AF_PP, GPIO_PULLUP, GPIO_AF5_TIM2, 1, 0)}, // TIM2_CH1
AnnaBridge 181:57724642e740 91 {PB_2, PWM_2, STM_PIN_DATA_EXT(STM_MODE_AF_PP, GPIO_PULLUP, GPIO_AF2_LPTIM1, 0, 0)}, // TIM2_CH2
AnnaBridge 181:57724642e740 92 {PB_5, PWM_22, STM_PIN_DATA_EXT(STM_MODE_AF_PP, GPIO_PULLUP, GPIO_AF4_TIM22, 2, 0)}, // TIM22_CH2
AnnaBridge 181:57724642e740 93 {PB_5_ALT0, PWM_3, STM_PIN_DATA_EXT(STM_MODE_AF_PP, GPIO_PULLUP, GPIO_AF4_TIM3, 2, 0)}, // TIM3_CH2
AnnaBridge 181:57724642e740 94 // {PB_13, PWM_21, STM_PIN_DATA_EXT(STM_MODE_AF_PP, GPIO_PULLUP, GPIO_AF6_TIM21, 1, 0)}, // TIM21_CH1
AnnaBridge 181:57724642e740 95 // {PB_14, PWM_21, STM_PIN_DATA_EXT(STM_MODE_AF_PP, GPIO_PULLUP, GPIO_AF6_TIM21, 2, 0)}, // TIM21_CH2
AnnaBridge 181:57724642e740 96 {NC, NC, 0}
AnnaBridge 181:57724642e740 97 };
AnnaBridge 181:57724642e740 98
AnnaBridge 181:57724642e740 99 //*** SERIAL ***
AnnaBridge 181:57724642e740 100
AnnaBridge 181:57724642e740 101 const PinMap PinMap_UART_TX[] = {
AnnaBridge 181:57724642e740 102 {PA_2, UART_2, STM_PIN_DATA(STM_MODE_AF_PP, GPIO_PULLUP, GPIO_AF4_USART2)},
AnnaBridge 181:57724642e740 103 {PA_2_ALT0, LPUART_1, STM_PIN_DATA(STM_MODE_AF_PP, GPIO_PULLUP, GPIO_AF6_LPUART1)},
AnnaBridge 181:57724642e740 104 {PA_9, UART_1, STM_PIN_DATA(STM_MODE_AF_PP, GPIO_PULLUP, GPIO_AF4_USART1)},
AnnaBridge 181:57724642e740 105 {PA_14, UART_2, STM_PIN_DATA(STM_MODE_AF_PP, GPIO_PULLUP, GPIO_AF4_USART2)},
AnnaBridge 181:57724642e740 106 {PA_14_ALT0, LPUART_1, STM_PIN_DATA(STM_MODE_AF_PP, GPIO_PULLUP, GPIO_AF6_LPUART1)}, // SWCLK
AnnaBridge 181:57724642e740 107 {PB_6, UART_1, STM_PIN_DATA(STM_MODE_AF_PP, GPIO_PULLUP, GPIO_AF4_USART1)},
AnnaBridge 181:57724642e740 108 {NC, NC, 0}
AnnaBridge 181:57724642e740 109 };
AnnaBridge 181:57724642e740 110
AnnaBridge 181:57724642e740 111 const PinMap PinMap_UART_RX[] = {
AnnaBridge 181:57724642e740 112 {PA_1, UART_4, STM_PIN_DATA(STM_MODE_AF_PP, GPIO_PULLUP, GPIO_AF6_USART4)},
AnnaBridge 181:57724642e740 113 {PA_3, UART_2, STM_PIN_DATA(STM_MODE_AF_PP, GPIO_PULLUP, GPIO_AF4_USART2)},
AnnaBridge 181:57724642e740 114 {PA_3_ALT0, LPUART_1, STM_PIN_DATA(STM_MODE_AF_PP, GPIO_PULLUP, GPIO_AF6_LPUART1)},
AnnaBridge 181:57724642e740 115 {PA_10, UART_1, STM_PIN_DATA(STM_MODE_AF_PP, GPIO_PULLUP, GPIO_AF4_USART1)},
AnnaBridge 181:57724642e740 116 {PA_13, LPUART_1, STM_PIN_DATA(STM_MODE_AF_PP, GPIO_PULLUP, GPIO_AF6_LPUART1)}, // SWDIO
AnnaBridge 181:57724642e740 117 {PB_7, UART_1, STM_PIN_DATA(STM_MODE_AF_PP, GPIO_PULLUP, GPIO_AF4_USART1)},
AnnaBridge 181:57724642e740 118 {NC, NC, 0}
AnnaBridge 181:57724642e740 119 };
AnnaBridge 181:57724642e740 120
AnnaBridge 181:57724642e740 121 const PinMap PinMap_UART_RTS[] = {
AnnaBridge 181:57724642e740 122 {PA_12, UART_1, STM_PIN_DATA(STM_MODE_AF_PP, GPIO_PULLUP, GPIO_AF4_USART1)},
AnnaBridge 181:57724642e740 123 {PB_12, LPUART_1, STM_PIN_DATA(STM_MODE_AF_PP, GPIO_PULLUP, GPIO_AF4_LPUART1)},
AnnaBridge 181:57724642e740 124 {PB_14, LPUART_1, STM_PIN_DATA(STM_MODE_AF_PP, GPIO_PULLUP, GPIO_AF4_LPUART1)},
AnnaBridge 181:57724642e740 125 {NC, NC, 0}
AnnaBridge 181:57724642e740 126 };
AnnaBridge 181:57724642e740 127
AnnaBridge 181:57724642e740 128 const PinMap PinMap_UART_CTS[] = {
AnnaBridge 181:57724642e740 129 {PA_0, UART_2, STM_PIN_DATA(STM_MODE_AF_PP, GPIO_PULLUP, GPIO_AF4_USART2)},
AnnaBridge 181:57724642e740 130 {PA_11, UART_1, STM_PIN_DATA(STM_MODE_AF_PP, GPIO_PULLUP, GPIO_AF4_USART1)},
AnnaBridge 181:57724642e740 131 {PB_13, LPUART_1, STM_PIN_DATA(STM_MODE_AF_PP, GPIO_PULLUP, GPIO_AF4_LPUART1)},
AnnaBridge 181:57724642e740 132 {NC, NC, 0}
AnnaBridge 181:57724642e740 133 };
AnnaBridge 181:57724642e740 134
AnnaBridge 181:57724642e740 135 //*** SPI ***
AnnaBridge 181:57724642e740 136
AnnaBridge 181:57724642e740 137 const PinMap PinMap_SPI_MOSI[] = {
AnnaBridge 181:57724642e740 138 {PA_7, SPI_1, STM_PIN_DATA(STM_MODE_AF_PP, GPIO_PULLUP, GPIO_AF0_SPI1)}, // MOSI
AnnaBridge 181:57724642e740 139 {PA_12, SPI_1, STM_PIN_DATA(STM_MODE_AF_PP, GPIO_PULLUP, GPIO_AF0_SPI1)},
AnnaBridge 181:57724642e740 140 {PB_5, SPI_1, STM_PIN_DATA(STM_MODE_AF_PP, GPIO_PULLUP, GPIO_AF0_SPI1)},
AnnaBridge 181:57724642e740 141 {PB_15, SPI_2, STM_PIN_DATA(STM_MODE_AF_PP, GPIO_PULLUP, GPIO_AF0_SPI2)}, // MOSI
AnnaBridge 181:57724642e740 142 {NC, NC, 0}
AnnaBridge 181:57724642e740 143 };
AnnaBridge 181:57724642e740 144
AnnaBridge 181:57724642e740 145 const PinMap PinMap_SPI_MISO[] = {
AnnaBridge 181:57724642e740 146 {PA_6, SPI_1, STM_PIN_DATA(STM_MODE_AF_PP, GPIO_PULLUP, GPIO_AF0_SPI1)},
AnnaBridge 181:57724642e740 147 {PA_11, SPI_1, STM_PIN_DATA(STM_MODE_AF_PP, GPIO_PULLUP, GPIO_AF0_SPI1)},
AnnaBridge 181:57724642e740 148 {PB_14, SPI_2, STM_PIN_DATA(STM_MODE_AF_PP, GPIO_PULLUP, GPIO_AF0_SPI2)}, // MISO
AnnaBridge 181:57724642e740 149 {NC, NC, 0}
AnnaBridge 181:57724642e740 150 };
AnnaBridge 181:57724642e740 151
AnnaBridge 181:57724642e740 152 const PinMap PinMap_SPI_SCLK[] = {
AnnaBridge 181:57724642e740 153 {PA_5, SPI_1, STM_PIN_DATA(STM_MODE_AF_PP, GPIO_PULLUP, GPIO_AF0_SPI1)},
AnnaBridge 181:57724642e740 154 {PB_3, SPI_1, STM_PIN_DATA(STM_MODE_AF_PP, GPIO_PULLUP, GPIO_AF0_SPI1)}, // SCK
AnnaBridge 181:57724642e740 155 {PB_13, SPI_2, STM_PIN_DATA(STM_MODE_AF_PP, GPIO_PULLUP, GPIO_AF0_SPI2)}, // SCK
AnnaBridge 181:57724642e740 156 {NC, NC, 0}
AnnaBridge 181:57724642e740 157 };
AnnaBridge 181:57724642e740 158
AnnaBridge 181:57724642e740 159 const PinMap PinMap_SPI_SSEL[] = {
AnnaBridge 181:57724642e740 160 {PA_4, SPI_1, STM_PIN_DATA(STM_MODE_AF_PP, GPIO_PULLUP, GPIO_AF0_SPI1)},
AnnaBridge 181:57724642e740 161 {PA_15, SPI_1, STM_PIN_DATA(STM_MODE_AF_PP, GPIO_PULLUP, GPIO_AF0_SPI1)},
AnnaBridge 181:57724642e740 162 {PB_9, SPI_2, STM_PIN_DATA(STM_MODE_AF_PP, GPIO_PULLUP, GPIO_AF5_SPI2)},
AnnaBridge 181:57724642e740 163 {PB_12, SPI_2, STM_PIN_DATA(STM_MODE_AF_PP, GPIO_PULLUP, GPIO_AF0_SPI2)}, // /SD_CS
AnnaBridge 181:57724642e740 164 {NC, NC, 0}
AnnaBridge 181:57724642e740 165 };