mbed library sources. Supersedes mbed-src.

Fork of mbed by teralytic

Committer:
<>
Date:
Fri Sep 02 15:07:44 2016 +0100
Revision:
144:ef7eb2e8f9f7
Parent:
0:9b334a45a8ff
This updates the lib to the mbed lib v125

Who changed what in which revision?

UserRevisionLine numberNew contents of line
<> 144:ef7eb2e8f9f7 1 /* mbed Microcontroller Library
<> 144:ef7eb2e8f9f7 2 *******************************************************************************
<> 144:ef7eb2e8f9f7 3 * Copyright (c) 2015 WIZnet Co.,Ltd. All rights reserved.
<> 144:ef7eb2e8f9f7 4 * All rights reserved.
<> 144:ef7eb2e8f9f7 5 *
<> 144:ef7eb2e8f9f7 6 * Redistribution and use in source and binary forms, with or without
<> 144:ef7eb2e8f9f7 7 * modification, are permitted provided that the following conditions are met:
<> 144:ef7eb2e8f9f7 8 *
<> 144:ef7eb2e8f9f7 9 * 1. Redistributions of source code must retain the above copyright notice,
<> 144:ef7eb2e8f9f7 10 * this list of conditions and the following disclaimer.
<> 144:ef7eb2e8f9f7 11 * 2. Redistributions in binary form must reproduce the above copyright notice,
<> 144:ef7eb2e8f9f7 12 * this list of conditions and the following disclaimer in the documentation
<> 144:ef7eb2e8f9f7 13 * and/or other materials provided with the distribution.
<> 144:ef7eb2e8f9f7 14 * 3. Neither the name of ARM Limited nor the names of its contributors
<> 144:ef7eb2e8f9f7 15 * may be used to endorse or promote products derived from this software
<> 144:ef7eb2e8f9f7 16 * without specific prior written permission.
<> 144:ef7eb2e8f9f7 17 *
<> 144:ef7eb2e8f9f7 18 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
<> 144:ef7eb2e8f9f7 19 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
<> 144:ef7eb2e8f9f7 20 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
<> 144:ef7eb2e8f9f7 21 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
<> 144:ef7eb2e8f9f7 22 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
<> 144:ef7eb2e8f9f7 23 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
<> 144:ef7eb2e8f9f7 24 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
<> 144:ef7eb2e8f9f7 25 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
<> 144:ef7eb2e8f9f7 26 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
<> 144:ef7eb2e8f9f7 27 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
<> 144:ef7eb2e8f9f7 28 *******************************************************************************
<> 144:ef7eb2e8f9f7 29 */
<> 144:ef7eb2e8f9f7 30
<> 144:ef7eb2e8f9f7 31 #ifndef MBED_PINNAMES_H
<> 144:ef7eb2e8f9f7 32 #define MBED_PINNAMES_H
<> 144:ef7eb2e8f9f7 33
<> 144:ef7eb2e8f9f7 34 #include "cmsis.h"
<> 144:ef7eb2e8f9f7 35
<> 144:ef7eb2e8f9f7 36 #ifdef __cplusplus
<> 144:ef7eb2e8f9f7 37 extern "C" {
<> 144:ef7eb2e8f9f7 38 #endif
<> 144:ef7eb2e8f9f7 39
<> 144:ef7eb2e8f9f7 40
<> 144:ef7eb2e8f9f7 41 // See W7500x_hal_gpio.h for values of MODE, PUPD and AFNUM
<> 144:ef7eb2e8f9f7 42 #define WIZ_PIN_DATA(MODE, PUPD, AFNUM) ((int)(((MODE) << 8) | ((PUPD) << 4) | ((AFNUM) << 0)))
<> 144:ef7eb2e8f9f7 43 #define WIZ_PIN_PUPD(X) (((X) >> 4) & 0x0F)
<> 144:ef7eb2e8f9f7 44 #define WIZ_PIN_AFNUM(X) (((X) >> 0) & 0x0F)
<> 144:ef7eb2e8f9f7 45 #define WIZ_PIN_MODE(X) (((X) >> 8) & 0x0F)
<> 144:ef7eb2e8f9f7 46 #define WIZ_MODE_INPUT (0)
<> 144:ef7eb2e8f9f7 47 #define WIZ_MODE_OUTPUT (1)
<> 144:ef7eb2e8f9f7 48 #define WIZ_MODE_AF (2)
<> 144:ef7eb2e8f9f7 49
<> 144:ef7eb2e8f9f7 50 #define WIZ_GPIO_NOPULL (0) /*!< No Pull-up or Pull-down activation */
<> 144:ef7eb2e8f9f7 51 #define WIZ_GPIO_PULLDOWN (1) /*!< Pull-down activation */
<> 144:ef7eb2e8f9f7 52 #define WIZ_GPIO_PULLUP (2) /*!< Pull-up activation */
<> 144:ef7eb2e8f9f7 53 #define WIZ_GPIO_OPEN_DRAIN (3) /*!< Open Drain activation */
<> 144:ef7eb2e8f9f7 54
<> 144:ef7eb2e8f9f7 55
<> 144:ef7eb2e8f9f7 56 #define WIZ_PORT(X) (((uint32_t)(X) >> 4) & 0xF) // port number (0=A, 1=B, 2=C, 3=D)
<> 144:ef7eb2e8f9f7 57 #define WIZ_PIN_NUM(X) ((uint32_t)(X) & 0xF) // pin number
<> 144:ef7eb2e8f9f7 58 #define WIZ_PIN_INDEX(X) (1 << ((uint32_t)(X) & 0xF)) // pin index : flag bit
<> 144:ef7eb2e8f9f7 59
<> 144:ef7eb2e8f9f7 60
<> 144:ef7eb2e8f9f7 61 typedef enum {
<> 144:ef7eb2e8f9f7 62 PIN_INPUT,
<> 144:ef7eb2e8f9f7 63 PIN_OUTPUT
<> 144:ef7eb2e8f9f7 64 } PinDirection;
<> 144:ef7eb2e8f9f7 65
<> 144:ef7eb2e8f9f7 66
<> 144:ef7eb2e8f9f7 67 typedef enum {
<> 144:ef7eb2e8f9f7 68 // W7500x PORT[5:4] + PIN[3:0])
<> 144:ef7eb2e8f9f7 69 PA_0 = 0x000,
<> 144:ef7eb2e8f9f7 70 PA_1 = 0x001,
<> 144:ef7eb2e8f9f7 71 PA_2 = 0x002,
<> 144:ef7eb2e8f9f7 72 PA_3 = 0x003,
<> 144:ef7eb2e8f9f7 73 PA_4 = 0x004,
<> 144:ef7eb2e8f9f7 74 PA_5 = 0x005,
<> 144:ef7eb2e8f9f7 75 PA_6 = 0x006,
<> 144:ef7eb2e8f9f7 76 PA_7 = 0x007,
<> 144:ef7eb2e8f9f7 77 PA_8 = 0x008,
<> 144:ef7eb2e8f9f7 78 PA_9 = 0x009,
<> 144:ef7eb2e8f9f7 79 PA_10 = 0x00A,
<> 144:ef7eb2e8f9f7 80 PA_11 = 0x00B,
<> 144:ef7eb2e8f9f7 81 PA_12 = 0x00C,
<> 144:ef7eb2e8f9f7 82 PA_13 = 0x00D,
<> 144:ef7eb2e8f9f7 83 PA_14 = 0x00E,
<> 144:ef7eb2e8f9f7 84 PA_15 = 0x00F,
<> 144:ef7eb2e8f9f7 85
<> 144:ef7eb2e8f9f7 86 PB_0 = 0x010,
<> 144:ef7eb2e8f9f7 87 PB_1 = 0x011,
<> 144:ef7eb2e8f9f7 88 PB_2 = 0x012,
<> 144:ef7eb2e8f9f7 89 PB_3 = 0x013,
<> 144:ef7eb2e8f9f7 90 PB_4 = 0x014,
<> 144:ef7eb2e8f9f7 91 PB_5 = 0x015,
<> 144:ef7eb2e8f9f7 92 PB_6 = 0x016,
<> 144:ef7eb2e8f9f7 93 PB_7 = 0x017,
<> 144:ef7eb2e8f9f7 94 PB_8 = 0x018,
<> 144:ef7eb2e8f9f7 95 PB_9 = 0x019,
<> 144:ef7eb2e8f9f7 96 PB_10 = 0x01A,
<> 144:ef7eb2e8f9f7 97 PB_11 = 0x01B,
<> 144:ef7eb2e8f9f7 98 PB_12 = 0x01C,
<> 144:ef7eb2e8f9f7 99 PB_13 = 0x01D,
<> 144:ef7eb2e8f9f7 100 PB_14 = 0x01E,
<> 144:ef7eb2e8f9f7 101 PB_15 = 0x01F,
<> 144:ef7eb2e8f9f7 102
<> 144:ef7eb2e8f9f7 103 PC_0 = 0x020,
<> 144:ef7eb2e8f9f7 104 PC_1 = 0x021,
<> 144:ef7eb2e8f9f7 105 PC_2 = 0x022,
<> 144:ef7eb2e8f9f7 106 PC_3 = 0x023,
<> 144:ef7eb2e8f9f7 107 PC_4 = 0x024,
<> 144:ef7eb2e8f9f7 108 PC_5 = 0x025,
<> 144:ef7eb2e8f9f7 109 PC_6 = 0x026,
<> 144:ef7eb2e8f9f7 110 PC_7 = 0x027,
<> 144:ef7eb2e8f9f7 111 PC_8 = 0x028,
<> 144:ef7eb2e8f9f7 112 PC_9 = 0x029,
<> 144:ef7eb2e8f9f7 113
<> 144:ef7eb2e8f9f7 114 PC_10 = 0x02A,
<> 144:ef7eb2e8f9f7 115 PC_11 = 0x02B,
<> 144:ef7eb2e8f9f7 116 PC_12 = 0x02C,
<> 144:ef7eb2e8f9f7 117 PC_13 = 0x02D,
<> 144:ef7eb2e8f9f7 118 PC_14 = 0x02E,
<> 144:ef7eb2e8f9f7 119 PC_15 = 0x02F,
<> 144:ef7eb2e8f9f7 120
<> 144:ef7eb2e8f9f7 121 PD_0 = 0x030,
<> 144:ef7eb2e8f9f7 122 PD_1 = 0x031,
<> 144:ef7eb2e8f9f7 123 PD_2 = 0x032,
<> 144:ef7eb2e8f9f7 124 PD_3 = 0x033,
<> 144:ef7eb2e8f9f7 125 PD_4 = 0x034,
<> 144:ef7eb2e8f9f7 126
<> 144:ef7eb2e8f9f7 127 PA_00 = PA_0,
<> 144:ef7eb2e8f9f7 128 PA_01 = PA_1,
<> 144:ef7eb2e8f9f7 129 PA_02 = PA_2,
<> 144:ef7eb2e8f9f7 130 PA_03 = PA_3,
<> 144:ef7eb2e8f9f7 131 PA_04 = PA_4,
<> 144:ef7eb2e8f9f7 132 PA_05 = PA_5,
<> 144:ef7eb2e8f9f7 133 PA_06 = PA_6,
<> 144:ef7eb2e8f9f7 134 PA_07 = PA_7,
<> 144:ef7eb2e8f9f7 135 PA_08 = PA_8,
<> 144:ef7eb2e8f9f7 136 PA_09 = PA_9,
<> 144:ef7eb2e8f9f7 137
<> 144:ef7eb2e8f9f7 138 PB_00 = PB_0,
<> 144:ef7eb2e8f9f7 139 PB_01 = PB_1,
<> 144:ef7eb2e8f9f7 140 PB_02 = PB_2,
<> 144:ef7eb2e8f9f7 141 PB_03 = PB_3,
<> 144:ef7eb2e8f9f7 142 PB_04 = PB_4,
<> 144:ef7eb2e8f9f7 143 PB_05 = PB_5,
<> 144:ef7eb2e8f9f7 144 PB_06 = PB_6,
<> 144:ef7eb2e8f9f7 145 PB_07 = PB_7,
<> 144:ef7eb2e8f9f7 146 PB_08 = PB_8,
<> 144:ef7eb2e8f9f7 147 PB_09 = PB_9,
<> 144:ef7eb2e8f9f7 148
<> 144:ef7eb2e8f9f7 149 PC_00 = PC_0,
<> 144:ef7eb2e8f9f7 150 PC_01 = PC_1,
<> 144:ef7eb2e8f9f7 151 PC_02 = PC_2,
<> 144:ef7eb2e8f9f7 152 PC_03 = PC_3,
<> 144:ef7eb2e8f9f7 153 PC_04 = PC_4,
<> 144:ef7eb2e8f9f7 154 PC_05 = PC_5,
<> 144:ef7eb2e8f9f7 155 PC_06 = PC_6,
<> 144:ef7eb2e8f9f7 156 PC_07 = PC_7,
<> 144:ef7eb2e8f9f7 157 PC_08 = PC_8,
<> 144:ef7eb2e8f9f7 158 PC_09 = PC_9,
<> 144:ef7eb2e8f9f7 159
<> 144:ef7eb2e8f9f7 160 PD_00 = PD_0,
<> 144:ef7eb2e8f9f7 161 PD_01 = PD_1,
<> 144:ef7eb2e8f9f7 162 PD_02 = PD_2,
<> 144:ef7eb2e8f9f7 163 PD_03 = PD_3,
<> 144:ef7eb2e8f9f7 164 PD_04 = PD_4,
<> 144:ef7eb2e8f9f7 165
<> 144:ef7eb2e8f9f7 166 // Arduino connector namings
<> 144:ef7eb2e8f9f7 167 A0 = PC_15, // AIN0
<> 144:ef7eb2e8f9f7 168 A1 = PC_14, // AIN1
<> 144:ef7eb2e8f9f7 169 A2 = PC_13, // AIN2
<> 144:ef7eb2e8f9f7 170 A3 = PC_12, // AIN3
<> 144:ef7eb2e8f9f7 171 A4 = PC_9, // AIN4
<> 144:ef7eb2e8f9f7 172 A5 = PC_8, // AIN5
<> 144:ef7eb2e8f9f7 173
<> 144:ef7eb2e8f9f7 174 D0 = PA_14,
<> 144:ef7eb2e8f9f7 175 D1 = PA_13,
<> 144:ef7eb2e8f9f7 176 D2 = PC_3,
<> 144:ef7eb2e8f9f7 177 D3 = PC_2,
<> 144:ef7eb2e8f9f7 178 D4 = PA_2,
<> 144:ef7eb2e8f9f7 179 D5 = PA_1,
<> 144:ef7eb2e8f9f7 180 D6 = PA_0,
<> 144:ef7eb2e8f9f7 181 D7 = PA_12,
<> 144:ef7eb2e8f9f7 182 D8 = PA_11,
<> 144:ef7eb2e8f9f7 183 D9 = PC_1,
<> 144:ef7eb2e8f9f7 184 D10 = PA_5,
<> 144:ef7eb2e8f9f7 185 D11 = PA_8,
<> 144:ef7eb2e8f9f7 186 D12 = PA_7,
<> 144:ef7eb2e8f9f7 187 D13 = PA_6,
<> 144:ef7eb2e8f9f7 188 D14 = PA_10,
<> 144:ef7eb2e8f9f7 189 D15 = PA_9,
<> 144:ef7eb2e8f9f7 190
<> 144:ef7eb2e8f9f7 191 // Generic signals namings
<> 144:ef7eb2e8f9f7 192 LED_RED = PC_0,
<> 144:ef7eb2e8f9f7 193 LED_GREEN = PC_4,
<> 144:ef7eb2e8f9f7 194 LED_BLUE = PC_5,
<> 144:ef7eb2e8f9f7 195
<> 144:ef7eb2e8f9f7 196 LED1 = LED_RED,
<> 144:ef7eb2e8f9f7 197 LED2 = LED_GREEN,
<> 144:ef7eb2e8f9f7 198 LED3 = LED_BLUE,
<> 144:ef7eb2e8f9f7 199 LED4 = LED_BLUE,
<> 144:ef7eb2e8f9f7 200
<> 144:ef7eb2e8f9f7 201 LEDR = LED_RED,
<> 144:ef7eb2e8f9f7 202 LEDG = LED_GREEN,
<> 144:ef7eb2e8f9f7 203 LEDB = LED_BLUE,
<> 144:ef7eb2e8f9f7 204
<> 144:ef7eb2e8f9f7 205 USBTX = PC_10,
<> 144:ef7eb2e8f9f7 206 USBRX = PC_11,
<> 144:ef7eb2e8f9f7 207
<> 144:ef7eb2e8f9f7 208 //Use SPI1
<> 144:ef7eb2e8f9f7 209 SD_SEL = PB_0, // SPI1_CS
<> 144:ef7eb2e8f9f7 210 SD_CLK = PB_1, // SPI1_CLK
<> 144:ef7eb2e8f9f7 211 SD_MISO = PB_2, // MOSI1
<> 144:ef7eb2e8f9f7 212 SD_MOSI = PB_3, // MISO1
<> 144:ef7eb2e8f9f7 213
<> 144:ef7eb2e8f9f7 214 // Not connected
<> 144:ef7eb2e8f9f7 215 NC = (int)0xFFFFFFFF
<> 144:ef7eb2e8f9f7 216 } PinName;
<> 144:ef7eb2e8f9f7 217
<> 144:ef7eb2e8f9f7 218 typedef enum {
<> 144:ef7eb2e8f9f7 219 PullNone = 0,
<> 144:ef7eb2e8f9f7 220 PullDown = 1,
<> 144:ef7eb2e8f9f7 221 PullUp = 2,
<> 144:ef7eb2e8f9f7 222 PullDefault = PullNone
<> 144:ef7eb2e8f9f7 223 } PinMode;
<> 144:ef7eb2e8f9f7 224
<> 144:ef7eb2e8f9f7 225
<> 144:ef7eb2e8f9f7 226 #ifdef __cplusplus
<> 144:ef7eb2e8f9f7 227 }
<> 144:ef7eb2e8f9f7 228 #endif
<> 144:ef7eb2e8f9f7 229
<> 144:ef7eb2e8f9f7 230 #endif