mbed library sources. Supersedes mbed-src.
Dependents: Nucleo_Hello_Encoder BLE_iBeaconScan AM1805_DEMO DISCO-F429ZI_ExportTemplate1 ... more
targets/TARGET_NUVOTON/TARGET_M480/TARGET_NUMAKER_PFM_M487/PinNames.h@182:a56a73fd2a6f, 2018-03-20 (annotated)
- Committer:
- AnnaBridge
- Date:
- Tue Mar 20 16:56:18 2018 +0000
- Revision:
- 182:a56a73fd2a6f
- Parent:
- 172:7d866c31b3c5
- Child:
- 184:08ed48f1de7f
mbed-dev library. Release version 160
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
AnnaBridge | 172:7d866c31b3c5 | 1 | /* mbed Microcontroller Library |
AnnaBridge | 172:7d866c31b3c5 | 2 | * Copyright (c) 2015-2016 Nuvoton |
AnnaBridge | 172:7d866c31b3c5 | 3 | * |
AnnaBridge | 172:7d866c31b3c5 | 4 | * Licensed under the Apache License, Version 2.0 (the "License"); |
AnnaBridge | 172:7d866c31b3c5 | 5 | * you may not use this file except in compliance with the License. |
AnnaBridge | 172:7d866c31b3c5 | 6 | * You may obtain a copy of the License at |
AnnaBridge | 172:7d866c31b3c5 | 7 | * |
AnnaBridge | 172:7d866c31b3c5 | 8 | * http://www.apache.org/licenses/LICENSE-2.0 |
AnnaBridge | 172:7d866c31b3c5 | 9 | * |
AnnaBridge | 172:7d866c31b3c5 | 10 | * Unless required by applicable law or agreed to in writing, software |
AnnaBridge | 172:7d866c31b3c5 | 11 | * distributed under the License is distributed on an "AS IS" BASIS, |
AnnaBridge | 172:7d866c31b3c5 | 12 | * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
AnnaBridge | 172:7d866c31b3c5 | 13 | * See the License for the specific language governing permissions and |
AnnaBridge | 172:7d866c31b3c5 | 14 | * limitations under the License. |
AnnaBridge | 172:7d866c31b3c5 | 15 | */ |
AnnaBridge | 172:7d866c31b3c5 | 16 | #ifndef MBED_PINNAMES_H |
AnnaBridge | 172:7d866c31b3c5 | 17 | #define MBED_PINNAMES_H |
AnnaBridge | 172:7d866c31b3c5 | 18 | |
AnnaBridge | 172:7d866c31b3c5 | 19 | #include "cmsis.h" |
AnnaBridge | 172:7d866c31b3c5 | 20 | |
AnnaBridge | 172:7d866c31b3c5 | 21 | #ifdef __cplusplus |
AnnaBridge | 172:7d866c31b3c5 | 22 | extern "C" { |
AnnaBridge | 172:7d866c31b3c5 | 23 | #endif |
AnnaBridge | 172:7d866c31b3c5 | 24 | |
AnnaBridge | 172:7d866c31b3c5 | 25 | #define NU_PININDEX_Pos 0 |
AnnaBridge | 172:7d866c31b3c5 | 26 | #define NU_PININDEX_Msk (0xFFul << NU_PININDEX_Pos) |
AnnaBridge | 172:7d866c31b3c5 | 27 | #define NU_PINPORT_Pos 8 |
AnnaBridge | 172:7d866c31b3c5 | 28 | #define NU_PINPORT_Msk (0xFul << NU_PINPORT_Pos) |
AnnaBridge | 172:7d866c31b3c5 | 29 | #define NU_PIN_MODINDEX_Pos 12 |
AnnaBridge | 172:7d866c31b3c5 | 30 | #define NU_PIN_MODINDEX_Msk (0xFul << NU_PIN_MODINDEX_Pos) |
AnnaBridge | 172:7d866c31b3c5 | 31 | #define NU_PIN_BIND_Pos 16 |
AnnaBridge | 172:7d866c31b3c5 | 32 | #define NU_PIN_BIND_Msk (0x1ul << NU_PIN_BIND_Pos) |
AnnaBridge | 172:7d866c31b3c5 | 33 | |
AnnaBridge | 172:7d866c31b3c5 | 34 | #define NU_PININDEX(PINNAME) (((unsigned int)(PINNAME) & NU_PININDEX_Msk) >> NU_PININDEX_Pos) |
AnnaBridge | 172:7d866c31b3c5 | 35 | #define NU_PINPORT(PINNAME) (((unsigned int)(PINNAME) & NU_PINPORT_Msk) >> NU_PINPORT_Pos) |
AnnaBridge | 172:7d866c31b3c5 | 36 | #define NU_PIN_BIND(PINNAME) (((unsigned int)(PINNAME) & NU_PIN_BIND_Msk) >> NU_PIN_BIND_Pos) |
AnnaBridge | 172:7d866c31b3c5 | 37 | #define NU_PIN_MODINDEX(PINNAME) (((unsigned int)(PINNAME) & NU_PIN_MODINDEX_Msk) >> NU_PIN_MODINDEX_Pos) |
AnnaBridge | 172:7d866c31b3c5 | 38 | #define NU_PINNAME(PORT, PIN) ((((unsigned int) (PORT)) << (NU_PINPORT_Pos)) | (((unsigned int) (PIN)) << NU_PININDEX_Pos)) |
AnnaBridge | 172:7d866c31b3c5 | 39 | #define NU_PINNAME_BIND(PINNAME, modname) ((PinName) NU_PINNAME_BIND_(NU_PINPORT(PINNAME), NU_PININDEX(PINNAME), modname)) |
AnnaBridge | 172:7d866c31b3c5 | 40 | #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 | 172:7d866c31b3c5 | 41 | |
AnnaBridge | 172:7d866c31b3c5 | 42 | #define NU_PORT_BASE(PORT) ((GPIO_T *)(((uint32_t) GPIOA_BASE) + 0x40 * PORT)) |
AnnaBridge | 172:7d866c31b3c5 | 43 | #define NU_MFP_POS(PIN) ((PIN % 8) * 4) |
AnnaBridge | 172:7d866c31b3c5 | 44 | #define NU_MFP_MSK(PIN) (0xful << NU_MFP_POS(PIN)) |
AnnaBridge | 172:7d866c31b3c5 | 45 | |
AnnaBridge | 172:7d866c31b3c5 | 46 | // LEGACY |
AnnaBridge | 172:7d866c31b3c5 | 47 | #define NU_PINNAME_TO_PIN(PINNAME) NU_PININDEX(PINNAME) |
AnnaBridge | 172:7d866c31b3c5 | 48 | #define NU_PINNAME_TO_PORT(PINNAME) NU_PINPORT(PINNAME) |
AnnaBridge | 172:7d866c31b3c5 | 49 | #define NU_PINNAME_TO_MODSUBINDEX(PINNAME) NU_PIN_MODINDEX(PINNAME) |
AnnaBridge | 172:7d866c31b3c5 | 50 | #define NU_PORT_N_PIN_TO_PINNAME(PORT, PIN) NU_PINNAME((PORT), (PIN)) |
AnnaBridge | 172:7d866c31b3c5 | 51 | |
AnnaBridge | 172:7d866c31b3c5 | 52 | typedef enum { |
AnnaBridge | 172:7d866c31b3c5 | 53 | PIN_INPUT, |
AnnaBridge | 172:7d866c31b3c5 | 54 | PIN_OUTPUT |
AnnaBridge | 172:7d866c31b3c5 | 55 | } PinDirection; |
AnnaBridge | 172:7d866c31b3c5 | 56 | |
AnnaBridge | 172:7d866c31b3c5 | 57 | typedef enum { |
AnnaBridge | 172:7d866c31b3c5 | 58 | PullNone = 0, |
AnnaBridge | 172:7d866c31b3c5 | 59 | PullDown, |
AnnaBridge | 172:7d866c31b3c5 | 60 | PullUp, |
AnnaBridge | 172:7d866c31b3c5 | 61 | |
AnnaBridge | 172:7d866c31b3c5 | 62 | PushPull, |
AnnaBridge | 172:7d866c31b3c5 | 63 | OpenDrain, |
AnnaBridge | 172:7d866c31b3c5 | 64 | Quasi, |
AnnaBridge | 172:7d866c31b3c5 | 65 | |
AnnaBridge | 172:7d866c31b3c5 | 66 | PullDefault = PullUp, |
AnnaBridge | 172:7d866c31b3c5 | 67 | } PinMode; |
AnnaBridge | 172:7d866c31b3c5 | 68 | |
AnnaBridge | 172:7d866c31b3c5 | 69 | typedef enum { |
AnnaBridge | 172:7d866c31b3c5 | 70 | // Not connected |
AnnaBridge | 172:7d866c31b3c5 | 71 | NC = (int)0xFFFFFFFF, |
AnnaBridge | 172:7d866c31b3c5 | 72 | |
AnnaBridge | 172:7d866c31b3c5 | 73 | // Generic naming |
AnnaBridge | 172:7d866c31b3c5 | 74 | 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 | 172:7d866c31b3c5 | 75 | 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 | 172:7d866c31b3c5 | 76 | 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, PC_14, |
AnnaBridge | 172:7d866c31b3c5 | 77 | 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 | 172:7d866c31b3c5 | 78 | 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 | 172:7d866c31b3c5 | 79 | 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 | 172:7d866c31b3c5 | 80 | 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 | 172:7d866c31b3c5 | 81 | 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 | 172:7d866c31b3c5 | 82 | |
AnnaBridge | 172:7d866c31b3c5 | 83 | // Arduino UNO naming |
AnnaBridge | 172:7d866c31b3c5 | 84 | A0 = PB_6, |
AnnaBridge | 172:7d866c31b3c5 | 85 | A1 = PB_7, |
AnnaBridge | 172:7d866c31b3c5 | 86 | A2 = PB_8, |
AnnaBridge | 172:7d866c31b3c5 | 87 | A3 = PB_3, |
AnnaBridge | 172:7d866c31b3c5 | 88 | A4 = PB_4, |
AnnaBridge | 172:7d866c31b3c5 | 89 | A5 = PB_5, |
AnnaBridge | 172:7d866c31b3c5 | 90 | |
AnnaBridge | 172:7d866c31b3c5 | 91 | D0 = PH_9, |
AnnaBridge | 172:7d866c31b3c5 | 92 | D1 = PH_8, |
AnnaBridge | 172:7d866c31b3c5 | 93 | D2 = PB_9, |
AnnaBridge | 172:7d866c31b3c5 | 94 | D3 = PF_11, |
AnnaBridge | 172:7d866c31b3c5 | 95 | D4 = PG_4, |
AnnaBridge | 172:7d866c31b3c5 | 96 | D5 = PC_11, |
AnnaBridge | 172:7d866c31b3c5 | 97 | D6 = PC_12, |
AnnaBridge | 172:7d866c31b3c5 | 98 | D7 = PC_13, |
AnnaBridge | 172:7d866c31b3c5 | 99 | D8 = PA_5, |
AnnaBridge | 172:7d866c31b3c5 | 100 | D9 = PA_4, |
AnnaBridge | 172:7d866c31b3c5 | 101 | D10 = PA_3, |
AnnaBridge | 172:7d866c31b3c5 | 102 | D11 = PA_0, |
AnnaBridge | 172:7d866c31b3c5 | 103 | D12 = PA_1, |
AnnaBridge | 172:7d866c31b3c5 | 104 | D13 = PA_2, |
AnnaBridge | 172:7d866c31b3c5 | 105 | D14 = PG_3, |
AnnaBridge | 172:7d866c31b3c5 | 106 | D15 = PG_2, |
AnnaBridge | 172:7d866c31b3c5 | 107 | |
AnnaBridge | 182:a56a73fd2a6f | 108 | I2C_SCL = D15, |
AnnaBridge | 182:a56a73fd2a6f | 109 | I2C_SDA = D14, |
AnnaBridge | 182:a56a73fd2a6f | 110 | |
AnnaBridge | 172:7d866c31b3c5 | 111 | // Note: board-specific |
AnnaBridge | 172:7d866c31b3c5 | 112 | // UART naming |
AnnaBridge | 172:7d866c31b3c5 | 113 | USBTX = PD_3, |
AnnaBridge | 172:7d866c31b3c5 | 114 | USBRX = PD_2, |
AnnaBridge | 172:7d866c31b3c5 | 115 | STDIO_UART_TX = USBTX, |
AnnaBridge | 172:7d866c31b3c5 | 116 | STDIO_UART_RX = USBRX, |
AnnaBridge | 182:a56a73fd2a6f | 117 | SERIAL_TX = USBTX, |
AnnaBridge | 182:a56a73fd2a6f | 118 | SERIAL_RX = USBRX, |
AnnaBridge | 172:7d866c31b3c5 | 119 | // LED naming |
AnnaBridge | 172:7d866c31b3c5 | 120 | LED_RED = PH_0, |
AnnaBridge | 172:7d866c31b3c5 | 121 | LED_YELLOW = PH_1, |
AnnaBridge | 172:7d866c31b3c5 | 122 | LED_GREEN = PH_2, |
AnnaBridge | 172:7d866c31b3c5 | 123 | LED1 = LED_RED, |
AnnaBridge | 172:7d866c31b3c5 | 124 | LED2 = LED_YELLOW, |
AnnaBridge | 172:7d866c31b3c5 | 125 | LED3 = LED_GREEN, |
AnnaBridge | 172:7d866c31b3c5 | 126 | LED4 = LED1, // No real LED. Just for passing ATS. |
AnnaBridge | 172:7d866c31b3c5 | 127 | // Button naming |
AnnaBridge | 172:7d866c31b3c5 | 128 | SW2 = PC_10, |
AnnaBridge | 172:7d866c31b3c5 | 129 | SW3 = PC_9, |
AnnaBridge | 172:7d866c31b3c5 | 130 | |
AnnaBridge | 172:7d866c31b3c5 | 131 | } PinName; |
AnnaBridge | 172:7d866c31b3c5 | 132 | |
AnnaBridge | 172:7d866c31b3c5 | 133 | #ifdef __cplusplus |
AnnaBridge | 172:7d866c31b3c5 | 134 | } |
AnnaBridge | 172:7d866c31b3c5 | 135 | #endif |
AnnaBridge | 172:7d866c31b3c5 | 136 | |
AnnaBridge | 172:7d866c31b3c5 | 137 | #endif // MBED_PINNAMES_H |