mbed library sources. Supersedes mbed-src.
Dependents: Nucleo_Hello_Encoder BLE_iBeaconScan AM1805_DEMO DISCO-F429ZI_ExportTemplate1 ... more
targets/TARGET_NUVOTON/TARGET_M2351/PinNames.h@188:bcfe06ba3d64, 2018-11-08 (annotated)
- Committer:
- AnnaBridge
- Date:
- Thu Nov 08 11:46:34 2018 +0000
- Revision:
- 188:bcfe06ba3d64
- Parent:
- 187:0387e8f68319
mbed-dev library. Release version 164
Who changed what in which revision?
User | Revision | Line number | New 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 | 188:bcfe06ba3d64 | 97 | /* Input pull mode */ |
AnnaBridge | 187:0387e8f68319 | 98 | PullNone = 0, |
AnnaBridge | 187:0387e8f68319 | 99 | PullDown, |
AnnaBridge | 187:0387e8f68319 | 100 | PullUp, |
AnnaBridge | 187:0387e8f68319 | 101 | |
AnnaBridge | 188:bcfe06ba3d64 | 102 | /* I/O mode */ |
AnnaBridge | 188:bcfe06ba3d64 | 103 | InputOnly, |
AnnaBridge | 188:bcfe06ba3d64 | 104 | PushPullOutput, |
AnnaBridge | 187:0387e8f68319 | 105 | OpenDrain, |
AnnaBridge | 188:bcfe06ba3d64 | 106 | QuasiBidirectional, |
AnnaBridge | 187:0387e8f68319 | 107 | |
AnnaBridge | 188:bcfe06ba3d64 | 108 | /* Default input pull mode */ |
AnnaBridge | 188:bcfe06ba3d64 | 109 | PullDefault = PullUp |
AnnaBridge | 187:0387e8f68319 | 110 | } PinMode; |
AnnaBridge | 187:0387e8f68319 | 111 | |
AnnaBridge | 187:0387e8f68319 | 112 | typedef enum { |
AnnaBridge | 187:0387e8f68319 | 113 | // Not connected |
AnnaBridge | 187:0387e8f68319 | 114 | NC = (int)0xFFFFFFFF, |
AnnaBridge | 187:0387e8f68319 | 115 | |
AnnaBridge | 187:0387e8f68319 | 116 | // Generic naming |
AnnaBridge | 187:0387e8f68319 | 117 | 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 | 118 | 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 | 119 | 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 | 120 | 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 | 121 | 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 | 122 | 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 | 123 | 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 | 124 | 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 | 125 | |
AnnaBridge | 187:0387e8f68319 | 126 | // Arduino UNO naming |
AnnaBridge | 187:0387e8f68319 | 127 | A0 = PB_11, |
AnnaBridge | 187:0387e8f68319 | 128 | A1 = PB_10, |
AnnaBridge | 187:0387e8f68319 | 129 | A2 = PB_9, |
AnnaBridge | 187:0387e8f68319 | 130 | A3 = PB_8, |
AnnaBridge | 188:bcfe06ba3d64 | 131 | A4 = PB_4, |
AnnaBridge | 188:bcfe06ba3d64 | 132 | A5 = PB_5, |
AnnaBridge | 187:0387e8f68319 | 133 | |
AnnaBridge | 187:0387e8f68319 | 134 | D0 = PA_8, |
AnnaBridge | 187:0387e8f68319 | 135 | D1 = PA_9, |
AnnaBridge | 188:bcfe06ba3d64 | 136 | D2 = PB_7, |
AnnaBridge | 188:bcfe06ba3d64 | 137 | D3 = PB_6, |
AnnaBridge | 187:0387e8f68319 | 138 | D4 = PB_3, |
AnnaBridge | 187:0387e8f68319 | 139 | D5 = PB_2, |
AnnaBridge | 187:0387e8f68319 | 140 | D6 = PC_12, |
AnnaBridge | 187:0387e8f68319 | 141 | D7 = PC_11, |
AnnaBridge | 187:0387e8f68319 | 142 | D8 = PC_9, |
AnnaBridge | 187:0387e8f68319 | 143 | D9 = PC_10, |
AnnaBridge | 187:0387e8f68319 | 144 | D10 = PF_9, |
AnnaBridge | 187:0387e8f68319 | 145 | D11 = PF_6, |
AnnaBridge | 187:0387e8f68319 | 146 | D12 = PF_7, |
AnnaBridge | 187:0387e8f68319 | 147 | D13 = PF_8, |
AnnaBridge | 187:0387e8f68319 | 148 | D14 = PG_3, |
AnnaBridge | 187:0387e8f68319 | 149 | D15 = PG_2, |
AnnaBridge | 187:0387e8f68319 | 150 | |
AnnaBridge | 187:0387e8f68319 | 151 | // Other board-specific naming |
AnnaBridge | 187:0387e8f68319 | 152 | |
AnnaBridge | 187:0387e8f68319 | 153 | // UART naming |
AnnaBridge | 187:0387e8f68319 | 154 | USBTX = PB_13, |
AnnaBridge | 187:0387e8f68319 | 155 | USBRX = PB_12, |
AnnaBridge | 187:0387e8f68319 | 156 | STDIO_UART_TX = USBTX, |
AnnaBridge | 187:0387e8f68319 | 157 | STDIO_UART_RX = USBRX, |
AnnaBridge | 187:0387e8f68319 | 158 | |
AnnaBridge | 187:0387e8f68319 | 159 | // I2C naming |
AnnaBridge | 187:0387e8f68319 | 160 | I2C_SCL = D15, |
AnnaBridge | 187:0387e8f68319 | 161 | I2C_SDA = D14, |
AnnaBridge | 187:0387e8f68319 | 162 | |
AnnaBridge | 187:0387e8f68319 | 163 | // LED naming |
AnnaBridge | 187:0387e8f68319 | 164 | LED1 = PA_10, |
AnnaBridge | 187:0387e8f68319 | 165 | LED2 = PA_11, |
AnnaBridge | 187:0387e8f68319 | 166 | LED3 = PA_10, // No real LED. Just for passing ATS. |
AnnaBridge | 187:0387e8f68319 | 167 | LED4 = PA_11, // No real LED. Just for passing ATS. |
AnnaBridge | 188:bcfe06ba3d64 | 168 | LED_GREEN = LED1, |
AnnaBridge | 187:0387e8f68319 | 169 | |
AnnaBridge | 187:0387e8f68319 | 170 | // Button naming |
AnnaBridge | 187:0387e8f68319 | 171 | SW2 = PB_0, |
AnnaBridge | 187:0387e8f68319 | 172 | SW3 = PB_1, |
AnnaBridge | 187:0387e8f68319 | 173 | |
AnnaBridge | 187:0387e8f68319 | 174 | } PinName; |
AnnaBridge | 187:0387e8f68319 | 175 | |
AnnaBridge | 187:0387e8f68319 | 176 | #ifdef __cplusplus |
AnnaBridge | 187:0387e8f68319 | 177 | } |
AnnaBridge | 187:0387e8f68319 | 178 | #endif |
AnnaBridge | 187:0387e8f68319 | 179 | |
AnnaBridge | 187:0387e8f68319 | 180 | #endif // MBED_PINNAMES_H |