mbed library sources. Supersedes mbed-src.

Fork of mbed by teralytic

Committer:
bogdanm
Date:
Thu Oct 01 15:25:22 2015 +0300
Revision:
0:9b334a45a8ff
Child:
144:ef7eb2e8f9f7
Initial commit on mbed-dev

Replaces mbed-src (now inactive)

Who changed what in which revision?

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