mbed library sources. Supersedes mbed-src.

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

Revision:
187:0387e8f68319
Child:
188:bcfe06ba3d64
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/targets/TARGET_NUVOTON/TARGET_M2351/PinNames.h	Thu Sep 06 13:40:20 2018 +0100
@@ -0,0 +1,176 @@
+/* mbed Microcontroller Library
+ * Copyright (c) 2017-2018 Nuvoton
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ *     http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+#ifndef MBED_PINNAMES_H
+#define MBED_PINNAMES_H
+
+#include "cmsis.h"
+#include "partition_M2351.h"
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+#define NU_PININDEX_Pos                             0
+#define NU_PININDEX_Msk                             (0xFFul << NU_PININDEX_Pos)
+#define NU_PINPORT_Pos                              8
+#define NU_PINPORT_Msk                              (0xFul << NU_PINPORT_Pos)
+#define NU_PIN_MODINDEX_Pos                         12
+#define NU_PIN_MODINDEX_Msk                         (0xFul << NU_PIN_MODINDEX_Pos)
+#define NU_PIN_BIND_Pos                             16
+#define NU_PIN_BIND_Msk                             (0x1ul << NU_PIN_BIND_Pos)
+
+#define NU_PININDEX(PINNAME)                        (((unsigned int)(PINNAME) & NU_PININDEX_Msk) >> NU_PININDEX_Pos)
+#define NU_PINPORT(PINNAME)                         (((unsigned int)(PINNAME) & NU_PINPORT_Msk) >> NU_PINPORT_Pos)
+#define NU_PIN_BIND(PINNAME)                        (((unsigned int)(PINNAME) & NU_PIN_BIND_Msk) >> NU_PIN_BIND_Pos)
+#define NU_PIN_MODINDEX(PINNAME)                    (((unsigned int)(PINNAME) & NU_PIN_MODINDEX_Msk) >> NU_PIN_MODINDEX_Pos)
+#define NU_PINNAME(PORT, PIN)                       ((((unsigned int) (PORT)) << (NU_PINPORT_Pos)) | (((unsigned int) (PIN)) << NU_PININDEX_Pos))
+#define NU_PINNAME_BIND(PINNAME, modname)           ((PinName) NU_PINNAME_BIND_(NU_PINPORT(PINNAME), NU_PININDEX(PINNAME), modname))
+#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)
+
+/* Revise NU_PORT_BASE to be TrustZone-aware */
+__STATIC_INLINE GPIO_T *NU_PORT_BASE(uint32_t PORT)
+{
+    uint32_t port_base = ((uint32_t) GPIOA_BASE) + 0x40 * PORT;
+    
+#if defined(SCU_INIT_IONSSET_VAL)
+    if (SCU_INIT_IONSSET_VAL & (1 << (PORT + 0))) {
+        port_base += NS_OFFSET;
+    } 
+#endif
+
+    return ((GPIO_T *) port_base);
+}
+
+#define NU_MFP_POS(pin)                             ((pin % 8) * 4)
+#define NU_MFP_MSK(pin)                             (0xful << NU_MFP_POS(pin))
+
+/* TrustZone-aware version of GPIO_PIN_DATA to get GPIO pin data */
+__STATIC_INLINE uint32_t NU_GET_GPIO_PIN_DATA(uint32_t PORT, uint32_t PIN)
+{
+#if defined(SCU_INIT_IONSSET_VAL)
+    if (SCU_INIT_IONSSET_VAL & (1 << (PORT + 0))) {
+        return GPIO_PIN_DATA_NS(PORT, PIN);
+    } 
+#endif
+    
+    return GPIO_PIN_DATA(PORT, PIN);
+}
+
+/* TrustZone-aware version of GPIO_PIN_DATA to set GPIO pin data */
+__STATIC_INLINE void NU_SET_GPIO_PIN_DATA(uint32_t PORT, uint32_t PIN, uint32_t VALUE)
+{
+#if defined(SCU_INIT_IONSSET_VAL)
+    if (SCU_INIT_IONSSET_VAL & (1 << (PORT + 0))) {
+        GPIO_PIN_DATA_NS(PORT, PIN) = VALUE;
+        return;
+    }
+#endif
+    
+    GPIO_PIN_DATA(PORT, PIN) = VALUE;
+}
+
+// LEGACY
+#define NU_PINNAME_TO_PIN(PINNAME)                  NU_PININDEX(PINNAME)
+#define NU_PINNAME_TO_PORT(PINNAME)                 NU_PINPORT(PINNAME)
+#define NU_PINNAME_TO_MODSUBINDEX(PINNAME)          NU_PIN_MODINDEX(PINNAME)
+#define NU_PORT_N_PIN_TO_PINNAME(PORT, PIN)         NU_PINNAME((PORT), (PIN))
+
+typedef enum {
+    PIN_INPUT,
+    PIN_OUTPUT
+} PinDirection;
+
+typedef enum {
+    PullNone = 0,
+    PullDown,
+    PullUp,
+    
+    PushPull,
+    OpenDrain,
+    Quasi,
+    
+    PullDefault = PullUp,
+} PinMode;
+
+typedef enum {
+    // Not connected
+    NC = (int)0xFFFFFFFF,
+    
+    // Generic naming
+    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,
+    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,
+    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,
+    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,
+    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,
+    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,
+    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,
+    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,
+   
+    // Arduino UNO naming
+    A0 = PB_11,
+    A1 = PB_10,
+    A2 = PB_9,
+    A3 = PB_8,
+    A4 = PB_7,
+    A5 = PB_6,
+
+    D0 = PA_8,
+    D1 = PA_9,
+    D2 = PB_5,
+    D3 = PB_4,
+    D4 = PB_3,
+    D5 = PB_2,
+    D6 = PC_12,
+    D7 = PC_11,
+    D8 = PC_9,
+    D9 = PC_10,
+    D10 = PF_9,
+    D11 = PF_6,
+    D12 = PF_7,
+    D13 = PF_8,
+    D14 = PG_3,
+    D15 = PG_2,
+    
+    // Other board-specific naming
+    
+    // UART naming
+    USBTX = PB_13,
+    USBRX = PB_12,
+    STDIO_UART_TX   = USBTX,
+    STDIO_UART_RX   = USBRX,
+    
+    // I2C naming
+    I2C_SCL = D15,
+    I2C_SDA = D14,
+    
+    // LED naming
+    LED1 = PA_10,
+    LED2 = PA_11,
+    LED3 = PA_10,  // No real LED. Just for passing ATS.
+    LED4 = PA_11,  // No real LED. Just for passing ATS.
+    LED_GREEN = LED2,
+    
+    // Button naming
+    SW2 = PB_0,
+    SW3 = PB_1,
+    
+} PinName;
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif // MBED_PINNAMES_H