mbed(SerialHalfDuplex入り)

Fork of mbed by mbed official

Committer:
bogdanm
Date:
Mon Apr 07 18:28:36 2014 +0100
Revision:
82:6473597d706e
Child:
84:0b3ab51c8877
Release 82 of the mbed library

Main changes:

- support for K64F
- Revisited Nordic code structure
- Test infrastructure improvements
- various bug fixes

Who changed what in which revision?

UserRevisionLine numberNew contents of line
bogdanm 82:6473597d706e 1 /* mbed Microcontroller Library
bogdanm 82:6473597d706e 2 * Copyright (c) 2006-2013 ARM Limited
bogdanm 82:6473597d706e 3 *
bogdanm 82:6473597d706e 4 * Licensed under the Apache License, Version 2.0 (the "License");
bogdanm 82:6473597d706e 5 * you may not use this file except in compliance with the License.
bogdanm 82:6473597d706e 6 * You may obtain a copy of the License at
bogdanm 82:6473597d706e 7 *
bogdanm 82:6473597d706e 8 * http://www.apache.org/licenses/LICENSE-2.0
bogdanm 82:6473597d706e 9 *
bogdanm 82:6473597d706e 10 * Unless required by applicable law or agreed to in writing, software
bogdanm 82:6473597d706e 11 * distributed under the License is distributed on an "AS IS" BASIS,
bogdanm 82:6473597d706e 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
bogdanm 82:6473597d706e 13 * See the License for the specific language governing permissions and
bogdanm 82:6473597d706e 14 * limitations under the License.
bogdanm 82:6473597d706e 15 */
bogdanm 82:6473597d706e 16 #ifndef MBED_PINNAMES_H
bogdanm 82:6473597d706e 17 #define MBED_PINNAMES_H
bogdanm 82:6473597d706e 18
bogdanm 82:6473597d706e 19 #include "cmsis.h"
bogdanm 82:6473597d706e 20
bogdanm 82:6473597d706e 21 #ifdef __cplusplus
bogdanm 82:6473597d706e 22 extern "C" {
bogdanm 82:6473597d706e 23 #endif
bogdanm 82:6473597d706e 24
bogdanm 82:6473597d706e 25 typedef enum {
bogdanm 82:6473597d706e 26 PIN_INPUT,
bogdanm 82:6473597d706e 27 PIN_OUTPUT
bogdanm 82:6473597d706e 28 } PinDirection;
bogdanm 82:6473597d706e 29
bogdanm 82:6473597d706e 30 #define PORT_SHIFT 5
bogdanm 82:6473597d706e 31
bogdanm 82:6473597d706e 32 typedef enum {
bogdanm 82:6473597d706e 33 // LPC Pin Names
bogdanm 82:6473597d706e 34 P0_0 = LPC_GPIO0_BASE,
bogdanm 82:6473597d706e 35 P0_1, P0_2, P0_3, P0_4, P0_5, P0_6, P0_7, P0_8, P0_9, P0_10, P0_11, P0_12, P0_13, P0_14, P0_15, P0_16, P0_17, P0_18, P0_19, P0_20, P0_21, P0_22, P0_23, P0_24, P0_25, P0_26, P0_27, P0_28, P0_29, P0_30, P0_31,
bogdanm 82:6473597d706e 36 P1_0, P1_1, P1_2, P1_3, P1_4, P1_5, P1_6, P1_7, P1_8, P1_9, P1_10, P1_11, P1_12, P1_13, P1_14, P1_15, P1_16, P1_17, P1_18, P1_19, P1_20, P1_21, P1_22, P1_23, P1_24, P1_25, P1_26, P1_27, P1_28, P1_29, P1_30, P1_31,
bogdanm 82:6473597d706e 37 P2_0, P2_1, P2_2, P2_3, P2_4, P2_5, P2_6, P2_7, P2_8, P2_9, P2_10, P2_11, P2_12, P2_13, P2_14, P2_15, P2_16, P2_17, P2_18, P2_19, P2_20, P2_21, P2_22, P2_23, P2_24, P2_25, P2_26, P2_27, P2_28, P2_29, P2_30, P2_31,
bogdanm 82:6473597d706e 38 P3_0, P3_1, P3_2, P3_3, P3_4, P3_5, P3_6, P3_7, P3_8, P3_9, P3_10, P3_11, P3_12, P3_13, P3_14, P3_15, P3_16, P3_17, P3_18, P3_19, P3_20, P3_21, P3_22, P3_23, P3_24, P3_25, P3_26, P3_27, P3_28, P3_29, P3_30, P3_31,
bogdanm 82:6473597d706e 39 P4_0, P4_1, P4_2, P4_3, P4_4, P4_5, P4_6, P4_7, P4_8, P4_9, P4_10, P4_11, P4_12, P4_13, P4_14, P4_15, P4_16, P4_17, P4_18, P4_19, P4_20, P4_21, P4_22, P4_23, P4_24, P4_25, P4_26, P4_27, P4_28, P4_29, P4_30, P4_31,
bogdanm 82:6473597d706e 40
bogdanm 82:6473597d706e 41 // Arduino Pin Names
bogdanm 82:6473597d706e 42
bogdanm 82:6473597d706e 43 // PIN header connector
bogdanm 82:6473597d706e 44 // for standard-based form factor with expansion board
bogdanm 82:6473597d706e 45 // -----------------------------------------------------------
bogdanm 82:6473597d706e 46 // PMW = Pulswidth Modulator
bogdanm 82:6473597d706e 47 // EINT = External Interrupt
bogdanm 82:6473597d706e 48 // AOUT = Analog Output
bogdanm 82:6473597d706e 49
bogdanm 82:6473597d706e 50 // Analog Ports (A0-A5)
bogdanm 82:6473597d706e 51 A0 = P0_23, // I2S_CLK
bogdanm 82:6473597d706e 52 A1 = P0_24, // I2S_WS
bogdanm 82:6473597d706e 53 A2 = P0_25, // I2S_SDA
bogdanm 82:6473597d706e 54 A3 = P0_26, // AOUT
bogdanm 82:6473597d706e 55 A4 = P1_30, //
bogdanm 82:6473597d706e 56 A5 = P1_31, //
bogdanm 82:6473597d706e 57 // Digital Port (D0-D7)
bogdanm 82:6473597d706e 58 D0 = P4_29, // TXD
bogdanm 82:6473597d706e 59 D1 = P4_28, // RXD
bogdanm 82:6473597d706e 60 D2 = P2_13, // EINT
bogdanm 82:6473597d706e 61 D3 = P2_0, // PWM
bogdanm 82:6473597d706e 62 D4 = P2_12, // EINT
bogdanm 82:6473597d706e 63 D5 = P2_1, // PWM
bogdanm 82:6473597d706e 64 D6 = P2_2, // PWM
bogdanm 82:6473597d706e 65 D7 = P2_11, // EINT
bogdanm 82:6473597d706e 66 // Digital Port (D8-D13)
bogdanm 82:6473597d706e 67 D8 = P2_4, // PWM
bogdanm 82:6473597d706e 68 D9 = P2_3, // PWM
bogdanm 82:6473597d706e 69 D10 = P1_21, // PWM SSEL
bogdanm 82:6473597d706e 70 D11 = P1_24, // PWM MOSI
bogdanm 82:6473597d706e 71 D12 = P1_23, // PWM MISO
bogdanm 82:6473597d706e 72 D13 = P1_20, // PWM SCK
bogdanm 82:6473597d706e 73 // GND
bogdanm 82:6473597d706e 74 // AREF
bogdanm 82:6473597d706e 75 SDA = P0_0,
bogdanm 82:6473597d706e 76 D14 = SDA,
bogdanm 82:6473597d706e 77 SCL = P0_1,
bogdanm 82:6473597d706e 78 D15 = SCL,
bogdanm 82:6473597d706e 79
bogdanm 82:6473597d706e 80 // I2C (shared with LISA/SARA)
bogdanm 82:6473597d706e 81 GPSSDA = P0_27,
bogdanm 82:6473597d706e 82 GPSSCL = P0_28,
bogdanm 82:6473597d706e 83 // UART
bogdanm 82:6473597d706e 84 GPSTXD = P0_10,
bogdanm 82:6473597d706e 85 GPSRXD = P0_11,
bogdanm 82:6473597d706e 86 // Control
bogdanm 82:6473597d706e 87 GPSRST = P1_18, // Reset (input to GPS, active low)
bogdanm 82:6473597d706e 88 GPSPPS = P1_19, // 1PPS Timepulse (output from GPS)
bogdanm 82:6473597d706e 89 GPSINT = P1_22, // Interrupt (input to GPS)
bogdanm 82:6473597d706e 90 GPSEN = P1_29, // Supply Control (high = enabled)
bogdanm 82:6473597d706e 91
bogdanm 82:6473597d706e 92 // u-blox LISA/SARA cellular modem
bogdanm 82:6473597d706e 93 // http://www.u-blox.com/wireless-modules.html
bogdanm 82:6473597d706e 94 // -----------------------------------------------------------
bogdanm 82:6473597d706e 95 // UART (LPC1768 = DTE, LISA/SARA = DCE)
bogdanm 82:6473597d706e 96 MDMTXD = P0_15, // Transmit Data
bogdanm 82:6473597d706e 97 MDMRXD = P0_16, // Receive Data
bogdanm 82:6473597d706e 98 MDMCTS = P0_17, // Clear to Send
bogdanm 82:6473597d706e 99 MDMDCD = P0_18, // Data Carrier Detect
bogdanm 82:6473597d706e 100 MDMDSR = P0_19, // Data Set Ready
bogdanm 82:6473597d706e 101 MDMDTR = P0_20, // Data Terminal Ready (set high or use handshake)
bogdanm 82:6473597d706e 102 MDMRI = P0_21, // Ring Indicator
bogdanm 82:6473597d706e 103 MDMRTS = P0_22, // Request to Send (set high or use handshake)
bogdanm 82:6473597d706e 104
bogdanm 82:6473597d706e 105 // USB (not available on C27-G35)
bogdanm 82:6473597d706e 106 MDMUSBDP = P0_29, // USB D+
bogdanm 82:6473597d706e 107 MDMUSBDN = P0_30, // USB D-
bogdanm 82:6473597d706e 108 MDMUSBCON = P2_9, // USB Connect
bogdanm 82:6473597d706e 109 MDMUSBDET = P0_7, // USB Detect (n/a on REV.A board)
bogdanm 82:6473597d706e 110 // Control
bogdanm 82:6473597d706e 111 MDMEN = P2_5, // Supply Control (high = enabled)
bogdanm 82:6473597d706e 112 MDMPWRON = P2_6, //
bogdanm 82:6473597d706e 113 MDMGPIO1 = P2_7, // GPIO1, Network status
bogdanm 82:6473597d706e 114 MDMRST = P2_8, // Reset (active low, set as open drain!)
bogdanm 82:6473597d706e 115 MDMLVLOE = P0_9, // Serial/GPIO Level Shifter Output Enable (n/a on REV.A board)
bogdanm 82:6473597d706e 116 MDMILVLOE = P0_8, // I2C Level Shifter Output Enable (n/a on REV.A board)
bogdanm 82:6473597d706e 117
bogdanm 82:6473597d706e 118 // CAN (TJA1040)
bogdanm 82:6473597d706e 119 // -----------------------------------------------------------
bogdanm 82:6473597d706e 120 CANRD = P0_4,
bogdanm 82:6473597d706e 121 CANTD = P0_5,
bogdanm 82:6473597d706e 122 CANS = P0_6, // standby (low=normal, high=standby/rxonly)
bogdanm 82:6473597d706e 123
bogdanm 82:6473597d706e 124 // Ethernet (DP83848)
bogdanm 82:6473597d706e 125 // -----------------------------------------------------------
bogdanm 82:6473597d706e 126 ETHTXD0 = P1_0,
bogdanm 82:6473597d706e 127 ETHTXD1 = P1_1,
bogdanm 82:6473597d706e 128 ETHTXEN = P1_4,
bogdanm 82:6473597d706e 129 ETHCRS = P1_8,
bogdanm 82:6473597d706e 130 ETHRXD0 = P1_9,
bogdanm 82:6473597d706e 131 ETHRXD1 = P1_10,
bogdanm 82:6473597d706e 132 ETHRXEN = P1_14,
bogdanm 82:6473597d706e 133 ETHREFCLK = P1_15,
bogdanm 82:6473597d706e 134 ETHMDC = P1_16,
bogdanm 82:6473597d706e 135 ETHMDIO = P1_17,
bogdanm 82:6473597d706e 136 ETHOSCEN = P1_27,
bogdanm 82:6473597d706e 137 ETHRST = P1_28,
bogdanm 82:6473597d706e 138 ETHLINK = P1_25, // LED_LINK
bogdanm 82:6473597d706e 139 ETHSPEED = P1_26, // LED_SPEED
bogdanm 82:6473597d706e 140
bogdanm 82:6473597d706e 141 // ISP port
bogdanm 82:6473597d706e 142 // -----------------------------------------------------------
bogdanm 82:6473597d706e 143 ISP = P2_10,
bogdanm 82:6473597d706e 144
bogdanm 82:6473597d706e 145 // Other mbed Pin Names
bogdanm 82:6473597d706e 146 LED = P3_25,
bogdanm 82:6473597d706e 147 LED1 = LED,
bogdanm 82:6473597d706e 148 LED_RED = LED,
bogdanm 82:6473597d706e 149
bogdanm 82:6473597d706e 150 // mbed / debug IF (LPC11)
bogdanm 82:6473597d706e 151 // -----------------------------------------------------------
bogdanm 82:6473597d706e 152 // Serial Port
bogdanm 82:6473597d706e 153 USBTX = P0_2,
bogdanm 82:6473597d706e 154 USBRX = P0_3,
bogdanm 82:6473597d706e 155 USBTXD = USBTX, // identical USBTX
bogdanm 82:6473597d706e 156 USBRXD = USBRX, // identical USBRX
bogdanm 82:6473597d706e 157
bogdanm 82:6473597d706e 158 // Not connected
bogdanm 82:6473597d706e 159 NC = (int)0xFFFFFFFF
bogdanm 82:6473597d706e 160 } PinName;
bogdanm 82:6473597d706e 161
bogdanm 82:6473597d706e 162 typedef enum {
bogdanm 82:6473597d706e 163 PullUp = 0,
bogdanm 82:6473597d706e 164 PullDown = 3,
bogdanm 82:6473597d706e 165 PullNone = 2,
bogdanm 82:6473597d706e 166 OpenDrain = 4,
bogdanm 82:6473597d706e 167 PullDefault = PullDown
bogdanm 82:6473597d706e 168 } PinMode;
bogdanm 82:6473597d706e 169
bogdanm 82:6473597d706e 170 // version of PINCON_TypeDef using register arrays
bogdanm 82:6473597d706e 171 typedef struct {
bogdanm 82:6473597d706e 172 __IO uint32_t PINSEL[11];
bogdanm 82:6473597d706e 173 uint32_t RESERVED0[5];
bogdanm 82:6473597d706e 174 __IO uint32_t PINMODE[10];
bogdanm 82:6473597d706e 175 __IO uint32_t PINMODE_OD[5];
bogdanm 82:6473597d706e 176 } PINCONARRAY_TypeDef;
bogdanm 82:6473597d706e 177
bogdanm 82:6473597d706e 178 #define PINCONARRAY ((PINCONARRAY_TypeDef *)LPC_PINCON_BASE)
bogdanm 82:6473597d706e 179
bogdanm 82:6473597d706e 180 //Additional C027 stuff
bogdanm 82:6473597d706e 181 #define GPSADR (66<<1) // GPS I2C Address
bogdanm 82:6473597d706e 182 #define GPSBAUD 9600 // Default GPS Baud Rate
bogdanm 82:6473597d706e 183 #define MDMBAUD 115200 // Default Modem Baud Rate
bogdanm 82:6473597d706e 184
bogdanm 82:6473597d706e 185 #ifdef __cplusplus
bogdanm 82:6473597d706e 186 }
bogdanm 82:6473597d706e 187 #endif
bogdanm 82:6473597d706e 188
bogdanm 82:6473597d706e 189 #endif