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
Child:
188:bcfe06ba3d64
mbed-dev library. Release version 163

Who changed what in which revision?

UserRevisionLine numberNew contents of line
AnnaBridge 187:0387e8f68319 1 /* mbed Microcontroller Library
AnnaBridge 187:0387e8f68319 2 * Copyright (c) 2017-2018 Nuvoton
AnnaBridge 187:0387e8f68319 3 *
AnnaBridge 187:0387e8f68319 4 * Licensed under the Apache License, Version 2.0 (the "License");
AnnaBridge 187:0387e8f68319 5 * you may not use this file except in compliance with the License.
AnnaBridge 187:0387e8f68319 6 * You may obtain a copy of the License at
AnnaBridge 187:0387e8f68319 7 *
AnnaBridge 187:0387e8f68319 8 * http://www.apache.org/licenses/LICENSE-2.0
AnnaBridge 187:0387e8f68319 9 *
AnnaBridge 187:0387e8f68319 10 * Unless required by applicable law or agreed to in writing, software
AnnaBridge 187:0387e8f68319 11 * distributed under the License is distributed on an "AS IS" BASIS,
AnnaBridge 187:0387e8f68319 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
AnnaBridge 187:0387e8f68319 13 * See the License for the specific language governing permissions and
AnnaBridge 187:0387e8f68319 14 * limitations under the License.
AnnaBridge 187:0387e8f68319 15 */
AnnaBridge 187:0387e8f68319 16 #ifndef MBED_PINNAMES_H
AnnaBridge 187:0387e8f68319 17 #define MBED_PINNAMES_H
AnnaBridge 187:0387e8f68319 18
AnnaBridge 187:0387e8f68319 19 #include "cmsis.h"
AnnaBridge 187:0387e8f68319 20 #include "partition_M2351.h"
AnnaBridge 187:0387e8f68319 21
AnnaBridge 187:0387e8f68319 22 #ifdef __cplusplus
AnnaBridge 187:0387e8f68319 23 extern "C" {
AnnaBridge 187:0387e8f68319 24 #endif
AnnaBridge 187:0387e8f68319 25
AnnaBridge 187:0387e8f68319 26 #define NU_PININDEX_Pos 0
AnnaBridge 187:0387e8f68319 27 #define NU_PININDEX_Msk (0xFFul << NU_PININDEX_Pos)
AnnaBridge 187:0387e8f68319 28 #define NU_PINPORT_Pos 8
AnnaBridge 187:0387e8f68319 29 #define NU_PINPORT_Msk (0xFul << NU_PINPORT_Pos)
AnnaBridge 187:0387e8f68319 30 #define NU_PIN_MODINDEX_Pos 12
AnnaBridge 187:0387e8f68319 31 #define NU_PIN_MODINDEX_Msk (0xFul << NU_PIN_MODINDEX_Pos)
AnnaBridge 187:0387e8f68319 32 #define NU_PIN_BIND_Pos 16
AnnaBridge 187:0387e8f68319 33 #define NU_PIN_BIND_Msk (0x1ul << NU_PIN_BIND_Pos)
AnnaBridge 187:0387e8f68319 34
AnnaBridge 187:0387e8f68319 35 #define NU_PININDEX(PINNAME) (((unsigned int)(PINNAME) & NU_PININDEX_Msk) >> NU_PININDEX_Pos)
AnnaBridge 187:0387e8f68319 36 #define NU_PINPORT(PINNAME) (((unsigned int)(PINNAME) & NU_PINPORT_Msk) >> NU_PINPORT_Pos)
AnnaBridge 187:0387e8f68319 37 #define NU_PIN_BIND(PINNAME) (((unsigned int)(PINNAME) & NU_PIN_BIND_Msk) >> NU_PIN_BIND_Pos)
AnnaBridge 187:0387e8f68319 38 #define NU_PIN_MODINDEX(PINNAME) (((unsigned int)(PINNAME) & NU_PIN_MODINDEX_Msk) >> NU_PIN_MODINDEX_Pos)
AnnaBridge 187:0387e8f68319 39 #define NU_PINNAME(PORT, PIN) ((((unsigned int) (PORT)) << (NU_PINPORT_Pos)) | (((unsigned int) (PIN)) << NU_PININDEX_Pos))
AnnaBridge 187:0387e8f68319 40 #define NU_PINNAME_BIND(PINNAME, modname) ((PinName) NU_PINNAME_BIND_(NU_PINPORT(PINNAME), NU_PININDEX(PINNAME), modname))
AnnaBridge 187:0387e8f68319 41 #define NU_PINNAME_BIND_(PORT, PIN, modname) ((((unsigned int)(PORT)) << NU_PINPORT_Pos) | (((unsigned int)(PIN)) << NU_PININDEX_Pos) | (NU_MODINDEX(modname) << NU_PIN_MODINDEX_Pos) | NU_PIN_BIND_Msk)
AnnaBridge 187:0387e8f68319 42
AnnaBridge 187:0387e8f68319 43 /* Revise NU_PORT_BASE to be TrustZone-aware */
AnnaBridge 187:0387e8f68319 44 __STATIC_INLINE GPIO_T *NU_PORT_BASE(uint32_t PORT)
AnnaBridge 187:0387e8f68319 45 {
AnnaBridge 187:0387e8f68319 46 uint32_t port_base = ((uint32_t) GPIOA_BASE) + 0x40 * PORT;
AnnaBridge 187:0387e8f68319 47
AnnaBridge 187:0387e8f68319 48 #if defined(SCU_INIT_IONSSET_VAL)
AnnaBridge 187:0387e8f68319 49 if (SCU_INIT_IONSSET_VAL & (1 << (PORT + 0))) {
AnnaBridge 187:0387e8f68319 50 port_base += NS_OFFSET;
AnnaBridge 187:0387e8f68319 51 }
AnnaBridge 187:0387e8f68319 52 #endif
AnnaBridge 187:0387e8f68319 53
AnnaBridge 187:0387e8f68319 54 return ((GPIO_T *) port_base);
AnnaBridge 187:0387e8f68319 55 }
AnnaBridge 187:0387e8f68319 56
AnnaBridge 187:0387e8f68319 57 #define NU_MFP_POS(pin) ((pin % 8) * 4)
AnnaBridge 187:0387e8f68319 58 #define NU_MFP_MSK(pin) (0xful << NU_MFP_POS(pin))
AnnaBridge 187:0387e8f68319 59
AnnaBridge 187:0387e8f68319 60 /* TrustZone-aware version of GPIO_PIN_DATA to get GPIO pin data */
AnnaBridge 187:0387e8f68319 61 __STATIC_INLINE uint32_t NU_GET_GPIO_PIN_DATA(uint32_t PORT, uint32_t PIN)
AnnaBridge 187:0387e8f68319 62 {
AnnaBridge 187:0387e8f68319 63 #if defined(SCU_INIT_IONSSET_VAL)
AnnaBridge 187:0387e8f68319 64 if (SCU_INIT_IONSSET_VAL & (1 << (PORT + 0))) {
AnnaBridge 187:0387e8f68319 65 return GPIO_PIN_DATA_NS(PORT, PIN);
AnnaBridge 187:0387e8f68319 66 }
AnnaBridge 187:0387e8f68319 67 #endif
AnnaBridge 187:0387e8f68319 68
AnnaBridge 187:0387e8f68319 69 return GPIO_PIN_DATA(PORT, PIN);
AnnaBridge 187:0387e8f68319 70 }
AnnaBridge 187:0387e8f68319 71
AnnaBridge 187:0387e8f68319 72 /* TrustZone-aware version of GPIO_PIN_DATA to set GPIO pin data */
AnnaBridge 187:0387e8f68319 73 __STATIC_INLINE void NU_SET_GPIO_PIN_DATA(uint32_t PORT, uint32_t PIN, uint32_t VALUE)
AnnaBridge 187:0387e8f68319 74 {
AnnaBridge 187:0387e8f68319 75 #if defined(SCU_INIT_IONSSET_VAL)
AnnaBridge 187:0387e8f68319 76 if (SCU_INIT_IONSSET_VAL & (1 << (PORT + 0))) {
AnnaBridge 187:0387e8f68319 77 GPIO_PIN_DATA_NS(PORT, PIN) = VALUE;
AnnaBridge 187:0387e8f68319 78 return;
AnnaBridge 187:0387e8f68319 79 }
AnnaBridge 187:0387e8f68319 80 #endif
AnnaBridge 187:0387e8f68319 81
AnnaBridge 187:0387e8f68319 82 GPIO_PIN_DATA(PORT, PIN) = VALUE;
AnnaBridge 187:0387e8f68319 83 }
AnnaBridge 187:0387e8f68319 84
AnnaBridge 187:0387e8f68319 85 // LEGACY
AnnaBridge 187:0387e8f68319 86 #define NU_PINNAME_TO_PIN(PINNAME) NU_PININDEX(PINNAME)
AnnaBridge 187:0387e8f68319 87 #define NU_PINNAME_TO_PORT(PINNAME) NU_PINPORT(PINNAME)
AnnaBridge 187:0387e8f68319 88 #define NU_PINNAME_TO_MODSUBINDEX(PINNAME) NU_PIN_MODINDEX(PINNAME)
AnnaBridge 187:0387e8f68319 89 #define NU_PORT_N_PIN_TO_PINNAME(PORT, PIN) NU_PINNAME((PORT), (PIN))
AnnaBridge 187:0387e8f68319 90
AnnaBridge 187:0387e8f68319 91 typedef enum {
AnnaBridge 187:0387e8f68319 92 PIN_INPUT,
AnnaBridge 187:0387e8f68319 93 PIN_OUTPUT
AnnaBridge 187:0387e8f68319 94 } PinDirection;
AnnaBridge 187:0387e8f68319 95
AnnaBridge 187:0387e8f68319 96 typedef enum {
AnnaBridge 187:0387e8f68319 97 PullNone = 0,
AnnaBridge 187:0387e8f68319 98 PullDown,
AnnaBridge 187:0387e8f68319 99 PullUp,
AnnaBridge 187:0387e8f68319 100
AnnaBridge 187:0387e8f68319 101 PushPull,
AnnaBridge 187:0387e8f68319 102 OpenDrain,
AnnaBridge 187:0387e8f68319 103 Quasi,
AnnaBridge 187:0387e8f68319 104
AnnaBridge 187:0387e8f68319 105 PullDefault = PullUp,
AnnaBridge 187:0387e8f68319 106 } PinMode;
AnnaBridge 187:0387e8f68319 107
AnnaBridge 187:0387e8f68319 108 typedef enum {
AnnaBridge 187:0387e8f68319 109 // Not connected
AnnaBridge 187:0387e8f68319 110 NC = (int)0xFFFFFFFF,
AnnaBridge 187:0387e8f68319 111
AnnaBridge 187:0387e8f68319 112 // Generic naming
AnnaBridge 187:0387e8f68319 113 PA_0 = NU_PORT_N_PIN_TO_PINNAME(0, 0), PA_1, PA_2, PA_3, PA_4, PA_5, PA_6, PA_7, PA_8, PA_9, PA_10, PA_11, PA_12, PA_13, PA_14, PA_15,
AnnaBridge 187:0387e8f68319 114 PB_0 = NU_PORT_N_PIN_TO_PINNAME(1, 0), PB_1, PB_2, PB_3, PB_4, PB_5, PB_6, PB_7, PB_8, PB_9, PB_10, PB_11, PB_12, PB_13, PB_14, PB_15,
AnnaBridge 187:0387e8f68319 115 PC_0 = NU_PORT_N_PIN_TO_PINNAME(2, 0), PC_1, PC_2, PC_3, PC_4, PC_5, PC_6, PC_7, PC_8, PC_9, PC_10, PC_11, PC_12, PC_13,
AnnaBridge 187:0387e8f68319 116 PD_0 = NU_PORT_N_PIN_TO_PINNAME(3, 0), PD_1, PD_2, PD_3, PD_4, PD_5, PD_6, PD_7, PD_8, PD_9, PD_10, PD_11, PD_12, PD_13, PD_14,
AnnaBridge 187:0387e8f68319 117 PE_0 = NU_PORT_N_PIN_TO_PINNAME(4, 0), PE_1, PE_2, PE_3, PE_4, PE_5, PE_6, PE_7, PE_8, PE_9, PE_10, PE_11, PE_12, PE_13, PE_14, PE_15,
AnnaBridge 187:0387e8f68319 118 PF_0 = NU_PORT_N_PIN_TO_PINNAME(5, 0), PF_1, PF_2, PF_3, PF_4, PF_5, PF_6, PF_7, PF_8, PF_9, PF_10, PF_11,
AnnaBridge 187:0387e8f68319 119 PG_0 = NU_PORT_N_PIN_TO_PINNAME(6, 0), PG_1, PG_2, PG_3, PG_4, PG_5, PG_6, PG_7, PG_8, PG_9, PG_10, PG_11, PG_12, PG_13, PG_14, PG_15,
AnnaBridge 187:0387e8f68319 120 PH_0 = NU_PORT_N_PIN_TO_PINNAME(7, 0), PH_1, PH_2, PH_3, PH_4, PH_5, PH_6, PH_7, PH_8, PH_9, PH_10, PH_11,
AnnaBridge 187:0387e8f68319 121
AnnaBridge 187:0387e8f68319 122 // Arduino UNO naming
AnnaBridge 187:0387e8f68319 123 A0 = PB_11,
AnnaBridge 187:0387e8f68319 124 A1 = PB_10,
AnnaBridge 187:0387e8f68319 125 A2 = PB_9,
AnnaBridge 187:0387e8f68319 126 A3 = PB_8,
AnnaBridge 187:0387e8f68319 127 A4 = PB_7,
AnnaBridge 187:0387e8f68319 128 A5 = PB_6,
AnnaBridge 187:0387e8f68319 129
AnnaBridge 187:0387e8f68319 130 D0 = PA_8,
AnnaBridge 187:0387e8f68319 131 D1 = PA_9,
AnnaBridge 187:0387e8f68319 132 D2 = PB_5,
AnnaBridge 187:0387e8f68319 133 D3 = PB_4,
AnnaBridge 187:0387e8f68319 134 D4 = PB_3,
AnnaBridge 187:0387e8f68319 135 D5 = PB_2,
AnnaBridge 187:0387e8f68319 136 D6 = PC_12,
AnnaBridge 187:0387e8f68319 137 D7 = PC_11,
AnnaBridge 187:0387e8f68319 138 D8 = PC_9,
AnnaBridge 187:0387e8f68319 139 D9 = PC_10,
AnnaBridge 187:0387e8f68319 140 D10 = PF_9,
AnnaBridge 187:0387e8f68319 141 D11 = PF_6,
AnnaBridge 187:0387e8f68319 142 D12 = PF_7,
AnnaBridge 187:0387e8f68319 143 D13 = PF_8,
AnnaBridge 187:0387e8f68319 144 D14 = PG_3,
AnnaBridge 187:0387e8f68319 145 D15 = PG_2,
AnnaBridge 187:0387e8f68319 146
AnnaBridge 187:0387e8f68319 147 // Other board-specific naming
AnnaBridge 187:0387e8f68319 148
AnnaBridge 187:0387e8f68319 149 // UART naming
AnnaBridge 187:0387e8f68319 150 USBTX = PB_13,
AnnaBridge 187:0387e8f68319 151 USBRX = PB_12,
AnnaBridge 187:0387e8f68319 152 STDIO_UART_TX = USBTX,
AnnaBridge 187:0387e8f68319 153 STDIO_UART_RX = USBRX,
AnnaBridge 187:0387e8f68319 154
AnnaBridge 187:0387e8f68319 155 // I2C naming
AnnaBridge 187:0387e8f68319 156 I2C_SCL = D15,
AnnaBridge 187:0387e8f68319 157 I2C_SDA = D14,
AnnaBridge 187:0387e8f68319 158
AnnaBridge 187:0387e8f68319 159 // LED naming
AnnaBridge 187:0387e8f68319 160 LED1 = PA_10,
AnnaBridge 187:0387e8f68319 161 LED2 = PA_11,
AnnaBridge 187:0387e8f68319 162 LED3 = PA_10, // No real LED. Just for passing ATS.
AnnaBridge 187:0387e8f68319 163 LED4 = PA_11, // No real LED. Just for passing ATS.
AnnaBridge 187:0387e8f68319 164 LED_GREEN = LED2,
AnnaBridge 187:0387e8f68319 165
AnnaBridge 187:0387e8f68319 166 // Button naming
AnnaBridge 187:0387e8f68319 167 SW2 = PB_0,
AnnaBridge 187:0387e8f68319 168 SW3 = PB_1,
AnnaBridge 187:0387e8f68319 169
AnnaBridge 187:0387e8f68319 170 } PinName;
AnnaBridge 187:0387e8f68319 171
AnnaBridge 187:0387e8f68319 172 #ifdef __cplusplus
AnnaBridge 187:0387e8f68319 173 }
AnnaBridge 187:0387e8f68319 174 #endif
AnnaBridge 187:0387e8f68319 175
AnnaBridge 187:0387e8f68319 176 #endif // MBED_PINNAMES_H