t
Fork of mbed-dev by
targets/hal/TARGET_STM/TARGET_STM32F4/TARGET_UBLOX_C029/PinNames.h@147:30b64687e01f, 2016-09-16 (annotated)
- Committer:
- <>
- Date:
- Fri Sep 16 16:24:25 2016 +0100
- Revision:
- 147:30b64687e01f
- Parent:
- 144:ef7eb2e8f9f7
- Child:
- 148:21d94c44109e
This updates the lib to the mbed lib v126
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
<> | 144:ef7eb2e8f9f7 | 1 | /* mbed Microcontroller Library |
<> | 144:ef7eb2e8f9f7 | 2 | ******************************************************************************* |
<> | 144:ef7eb2e8f9f7 | 3 | * Copyright (c) 2014, STMicroelectronics |
<> | 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 STMicroelectronics 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 | #ifndef MBED_PINNAMES_H |
<> | 144:ef7eb2e8f9f7 | 31 | #define MBED_PINNAMES_H |
<> | 144:ef7eb2e8f9f7 | 32 | |
<> | 144:ef7eb2e8f9f7 | 33 | #include "cmsis.h" |
<> | 144:ef7eb2e8f9f7 | 34 | |
<> | 144:ef7eb2e8f9f7 | 35 | #ifdef __cplusplus |
<> | 144:ef7eb2e8f9f7 | 36 | extern "C" { |
<> | 144:ef7eb2e8f9f7 | 37 | #endif |
<> | 144:ef7eb2e8f9f7 | 38 | |
<> | 144:ef7eb2e8f9f7 | 39 | // See stm32f4xx_hal_gpio.h and stm32f4xx_hal_gpio_ex.h for values of MODE, PUPD and AFNUM |
<> | 147:30b64687e01f | 40 | #define STM_PIN_DATA(MODE, PUPD, AFNUM) ((int)(((AFNUM & 0x0F) << 7) | ((PUPD & 0x07) << 4) | ((MODE & 0x0F) << 0))) |
<> | 147:30b64687e01f | 41 | #define STM_PIN_DATA_EXT(MODE, PUPD, AFNUM, CHANNEL, INVERTED) ((int)(((INVERTED & 0x01) << 16) | ((CHANNEL & 0x1F) << 11) | ((AFNUM & 0x0F) << 7) | ((PUPD & 0x07) << 4) | ((MODE & 0x0F) << 0))) |
<> | 144:ef7eb2e8f9f7 | 42 | #define STM_PIN_MODE(X) (((X) >> 0) & 0x0F) |
<> | 144:ef7eb2e8f9f7 | 43 | #define STM_PIN_PUPD(X) (((X) >> 4) & 0x07) |
<> | 144:ef7eb2e8f9f7 | 44 | #define STM_PIN_AFNUM(X) (((X) >> 7) & 0x0F) |
<> | 147:30b64687e01f | 45 | #define STM_PIN_CHANNEL(X) (((X) >> 11) & 0x1F) |
<> | 147:30b64687e01f | 46 | #define STM_PIN_INVERTED(X) (((X) >> 16) & 0x01) |
<> | 144:ef7eb2e8f9f7 | 47 | #define STM_MODE_INPUT (0) |
<> | 144:ef7eb2e8f9f7 | 48 | #define STM_MODE_OUTPUT_PP (1) |
<> | 144:ef7eb2e8f9f7 | 49 | #define STM_MODE_OUTPUT_OD (2) |
<> | 144:ef7eb2e8f9f7 | 50 | #define STM_MODE_AF_PP (3) |
<> | 144:ef7eb2e8f9f7 | 51 | #define STM_MODE_AF_OD (4) |
<> | 144:ef7eb2e8f9f7 | 52 | #define STM_MODE_ANALOG (5) |
<> | 144:ef7eb2e8f9f7 | 53 | #define STM_MODE_IT_RISING (6) |
<> | 144:ef7eb2e8f9f7 | 54 | #define STM_MODE_IT_FALLING (7) |
<> | 144:ef7eb2e8f9f7 | 55 | #define STM_MODE_IT_RISING_FALLING (8) |
<> | 144:ef7eb2e8f9f7 | 56 | #define STM_MODE_EVT_RISING (9) |
<> | 144:ef7eb2e8f9f7 | 57 | #define STM_MODE_EVT_FALLING (10) |
<> | 144:ef7eb2e8f9f7 | 58 | #define STM_MODE_EVT_RISING_FALLING (11) |
<> | 144:ef7eb2e8f9f7 | 59 | #define STM_MODE_IT_EVT_RESET (12) |
<> | 144:ef7eb2e8f9f7 | 60 | |
<> | 144:ef7eb2e8f9f7 | 61 | // High nibble = port number (0=A, 1=B, 2=C, 3=D, 4=E, 5=F, 6=G, 7=H) |
<> | 144:ef7eb2e8f9f7 | 62 | // Low nibble = pin number |
<> | 144:ef7eb2e8f9f7 | 63 | #define STM_PORT(X) (((uint32_t)(X) >> 4) & 0xF) |
<> | 144:ef7eb2e8f9f7 | 64 | #define STM_PIN(X) ((uint32_t)(X) & 0xF) |
<> | 144:ef7eb2e8f9f7 | 65 | |
<> | 144:ef7eb2e8f9f7 | 66 | typedef enum { |
<> | 144:ef7eb2e8f9f7 | 67 | PIN_INPUT, |
<> | 144:ef7eb2e8f9f7 | 68 | PIN_OUTPUT |
<> | 144:ef7eb2e8f9f7 | 69 | } PinDirection; |
<> | 144:ef7eb2e8f9f7 | 70 | |
<> | 144:ef7eb2e8f9f7 | 71 | typedef enum { |
<> | 144:ef7eb2e8f9f7 | 72 | PA_0 = 0x00, PA_1 = 0x01, PA_2 = 0x02, PA_3 = 0x03, |
<> | 144:ef7eb2e8f9f7 | 73 | PA_4 = 0x04, PA_5 = 0x05, PA_6 = 0x06, PA_7 = 0x07, |
<> | 144:ef7eb2e8f9f7 | 74 | PA_8 = 0x08, PA_9 = 0x09, PA_10 = 0x0A, PA_11 = 0x0B, |
<> | 144:ef7eb2e8f9f7 | 75 | PA_12 = 0x0C, PA_13 = 0x0D, PA_14 = 0x0E, PA_15 = 0x0F, |
<> | 144:ef7eb2e8f9f7 | 76 | |
<> | 144:ef7eb2e8f9f7 | 77 | PB_0 = 0x10, PB_1 = 0x11, PB_2 = 0x12, PB_3 = 0x13, |
<> | 144:ef7eb2e8f9f7 | 78 | PB_4 = 0x14, PB_5 = 0x15, PB_6 = 0x16, PB_7 = 0x17, |
<> | 144:ef7eb2e8f9f7 | 79 | PB_8 = 0x18, PB_9 = 0x19, PB_10 = 0x1A, PB_11 = 0x1B, |
<> | 144:ef7eb2e8f9f7 | 80 | PB_12 = 0x1C, PB_13 = 0x1D, PB_14 = 0x1E, PB_15 = 0x1F, |
<> | 144:ef7eb2e8f9f7 | 81 | |
<> | 144:ef7eb2e8f9f7 | 82 | PC_0 = 0x20, PC_1 = 0x21, PC_2 = 0x22, PC_3 = 0x23, |
<> | 144:ef7eb2e8f9f7 | 83 | PC_4 = 0x24, PC_5 = 0x25, PC_6 = 0x26, PC_7 = 0x27, |
<> | 144:ef7eb2e8f9f7 | 84 | PC_8 = 0x28, PC_9 = 0x29, PC_10 = 0x2A, PC_11 = 0x2B, |
<> | 144:ef7eb2e8f9f7 | 85 | PC_12 = 0x2C, PC_13 = 0x2D, PC_14 = 0x2E, PC_15 = 0x2F, |
<> | 144:ef7eb2e8f9f7 | 86 | |
<> | 144:ef7eb2e8f9f7 | 87 | PD_0 = 0x30, PD_1 = 0x31, PD_2 = 0x32, PD_3 = 0x33, |
<> | 144:ef7eb2e8f9f7 | 88 | PD_4 = 0x34, PD_5 = 0x35, PD_6 = 0x36, PD_7 = 0x37, |
<> | 144:ef7eb2e8f9f7 | 89 | PD_8 = 0x38, PD_9 = 0x39, PD_10 = 0x3A, PD_11 = 0x3B, |
<> | 144:ef7eb2e8f9f7 | 90 | PD_12 = 0x3C, PD_13 = 0x3D, PD_14 = 0x3E, PD_15 = 0x3F, |
<> | 144:ef7eb2e8f9f7 | 91 | |
<> | 144:ef7eb2e8f9f7 | 92 | PE_0 = 0x40, PE_1 = 0x41, PE_2 = 0x42, PE_3 = 0x43, |
<> | 144:ef7eb2e8f9f7 | 93 | PE_4 = 0x44, PE_5 = 0x45, PE_6 = 0x46, PE_7 = 0x47, |
<> | 144:ef7eb2e8f9f7 | 94 | PE_8 = 0x48, PE_9 = 0x49, PE_10 = 0x4A, PE_11 = 0x4B, |
<> | 144:ef7eb2e8f9f7 | 95 | PE_12 = 0x4C, PE_13 = 0x4D, PE_14 = 0x4E, PE_15 = 0x4F, |
<> | 144:ef7eb2e8f9f7 | 96 | |
<> | 144:ef7eb2e8f9f7 | 97 | PF_0 = 0x50, PF_1 = 0x51, PF_2 = 0x52, PF_3 = 0x53, |
<> | 144:ef7eb2e8f9f7 | 98 | PF_4 = 0x54, PF_5 = 0x55, PF_6 = 0x56, PF_7 = 0x57, |
<> | 144:ef7eb2e8f9f7 | 99 | PF_8 = 0x58, PF_9 = 0x59, PF_10 = 0x5A, PF_11 = 0x5B, |
<> | 144:ef7eb2e8f9f7 | 100 | PF_12 = 0x5C, PF_13 = 0x5D, PF_14 = 0x5E, PF_15 = 0x5F, |
<> | 144:ef7eb2e8f9f7 | 101 | |
<> | 144:ef7eb2e8f9f7 | 102 | PG_0 = 0x60, PG_1 = 0x61, PG_2 = 0x62, PG_3 = 0x63, |
<> | 144:ef7eb2e8f9f7 | 103 | PG_4 = 0x64, PG_5 = 0x65, PG_6 = 0x66, PG_7 = 0x67, |
<> | 144:ef7eb2e8f9f7 | 104 | PG_8 = 0x68, PG_9 = 0x69, PG_10 = 0x6A, PG_11 = 0x6B, |
<> | 144:ef7eb2e8f9f7 | 105 | PG_12 = 0x6C, PG_13 = 0x6D, PG_14 = 0x6E, PG_15 = 0x6F, |
<> | 144:ef7eb2e8f9f7 | 106 | |
<> | 144:ef7eb2e8f9f7 | 107 | PH_0 = 0x70, PH_1 = 0x71, PH_2 = 0x72, PH_3 = 0x73, |
<> | 144:ef7eb2e8f9f7 | 108 | PH_4 = 0x74, PH_5 = 0x75, PH_6 = 0x76, PH_7 = 0x77, |
<> | 144:ef7eb2e8f9f7 | 109 | PH_8 = 0x78, PH_9 = 0x79, PH_10 = 0x7A, PH_11 = 0x7B, |
<> | 144:ef7eb2e8f9f7 | 110 | PH_12 = 0x7C, PH_13 = 0x7D, PH_14 = 0x7E, PH_15 = 0x7F, |
<> | 144:ef7eb2e8f9f7 | 111 | |
<> | 147:30b64687e01f | 112 | // ADC internal channels |
<> | 147:30b64687e01f | 113 | ADC_TEMP = 0xF0, |
<> | 147:30b64687e01f | 114 | ADC_VREF = 0xF1, |
<> | 147:30b64687e01f | 115 | ADC_VBAT = 0xF2, |
<> | 147:30b64687e01f | 116 | |
<> | 144:ef7eb2e8f9f7 | 117 | // Module Pins |
<> | 144:ef7eb2e8f9f7 | 118 | // A |
<> | 144:ef7eb2e8f9f7 | 119 | P_A5 = PC_2, // UART-DTR |
<> | 144:ef7eb2e8f9f7 | 120 | P_A6 = PF_2, // Switch-0 |
<> | 144:ef7eb2e8f9f7 | 121 | P_A7 = PE_0, // Red, Mode |
<> | 144:ef7eb2e8f9f7 | 122 | P_A8 = PB_6, // Green, Switch-1 |
<> | 144:ef7eb2e8f9f7 | 123 | P_A9 = PB_8, // Blue |
<> | 144:ef7eb2e8f9f7 | 124 | P_A10 = PA_11, // UART-CTS |
<> | 144:ef7eb2e8f9f7 | 125 | P_A11 = PA_9, // UART-TXD |
<> | 144:ef7eb2e8f9f7 | 126 | P_A12 = PA_12, // UART-RTS |
<> | 144:ef7eb2e8f9f7 | 127 | P_A13 = PA_10, // UART-RXD |
<> | 144:ef7eb2e8f9f7 | 128 | P_A14 = PD_9, // GPIO-0 |
<> | 144:ef7eb2e8f9f7 | 129 | P_A15 = PD_8, // GPIO-1 |
<> | 144:ef7eb2e8f9f7 | 130 | P_A16 = PD_11, // GPIO-2 |
<> | 144:ef7eb2e8f9f7 | 131 | P_A17 = PD_12, // GPIO-3 |
<> | 144:ef7eb2e8f9f7 | 132 | P_A18 = PA_3, // UART-DSR |
<> | 144:ef7eb2e8f9f7 | 133 | // B |
<> | 144:ef7eb2e8f9f7 | 134 | // C |
<> | 144:ef7eb2e8f9f7 | 135 | P_C5 = PG_4, // SPI-IRQ |
<> | 144:ef7eb2e8f9f7 | 136 | P_C6 = PE_13, // SPI-MISO |
<> | 144:ef7eb2e8f9f7 | 137 | P_C8 = PE_12, // Res |
<> | 144:ef7eb2e8f9f7 | 138 | P_C10 = PE_14, // SPI-MOSI |
<> | 144:ef7eb2e8f9f7 | 139 | P_C11 = PE_11, // SPI-CS0 |
<> | 144:ef7eb2e8f9f7 | 140 | P_C12 = PE_9, // Res |
<> | 144:ef7eb2e8f9f7 | 141 | P_C13 = PF_6, // GPIO-4 |
<> | 144:ef7eb2e8f9f7 | 142 | P_C14 = PC_1, // RMII-MDC |
<> | 144:ef7eb2e8f9f7 | 143 | P_C15 = PA_2, // RMII-MDIO |
<> | 144:ef7eb2e8f9f7 | 144 | P_C16 = PF_7, // GPIO-7 |
<> | 144:ef7eb2e8f9f7 | 145 | P_C17 = PF_1, // I2C-SCL |
<> | 144:ef7eb2e8f9f7 | 146 | P_C18 = PF_0, // I2C-SDA |
<> | 144:ef7eb2e8f9f7 | 147 | // D |
<> | 144:ef7eb2e8f9f7 | 148 | P_D1 = PB_12, // RMII-TXD0 |
<> | 144:ef7eb2e8f9f7 | 149 | P_D2 = PB_13, // RMII-TXD1 |
<> | 144:ef7eb2e8f9f7 | 150 | P_D3 = PB_11, // RMII-TXEN |
<> | 144:ef7eb2e8f9f7 | 151 | P_D4 = PA_7, // RMII-CRSDV |
<> | 144:ef7eb2e8f9f7 | 152 | P_D5 = PC_4, // RMII-RXD0 |
<> | 144:ef7eb2e8f9f7 | 153 | P_D6 = PC_5, // RMII-RXD1 |
<> | 144:ef7eb2e8f9f7 | 154 | P_D8 = PA_1, // RMII-REFCLK |
<> | 144:ef7eb2e8f9f7 | 155 | // TP |
<> | 144:ef7eb2e8f9f7 | 156 | P_TP5 = PB_4, // NTRST |
<> | 144:ef7eb2e8f9f7 | 157 | P_TP7 = PA_13, // TMS SWDIO |
<> | 144:ef7eb2e8f9f7 | 158 | P_TP8 = PA_15, // TDI |
<> | 144:ef7eb2e8f9f7 | 159 | P_TP9 = PA_14, // TCK SWCLK |
<> | 144:ef7eb2e8f9f7 | 160 | P_TP10 = PB_3, // TDO |
<> | 144:ef7eb2e8f9f7 | 161 | //P_TP11, // BOOT0 |
<> | 144:ef7eb2e8f9f7 | 162 | |
<> | 144:ef7eb2e8f9f7 | 163 | // Board Pins |
<> | 144:ef7eb2e8f9f7 | 164 | // A0-A5 |
<> | 144:ef7eb2e8f9f7 | 165 | A0 = PF_6, // AI4 |
<> | 144:ef7eb2e8f9f7 | 166 | A1 = PA_3, // AI3 |
<> | 144:ef7eb2e8f9f7 | 167 | A2 = PC_2, // AI12 |
<> | 144:ef7eb2e8f9f7 | 168 | A3 = PF_7, // LPOCLK, not AI |
<> | 144:ef7eb2e8f9f7 | 169 | A4 = PG_4, // not AI |
<> | 144:ef7eb2e8f9f7 | 170 | A5 = PB_3, // not AI |
<> | 144:ef7eb2e8f9f7 | 171 | // D0-D15 |
<> | 144:ef7eb2e8f9f7 | 172 | D0 = PD_9, // UART3-RX |
<> | 144:ef7eb2e8f9f7 | 173 | D1 = PD_8, // UART3-TX |
<> | 144:ef7eb2e8f9f7 | 174 | D2 = PA_10, // UART1-RX |
<> | 144:ef7eb2e8f9f7 | 175 | D3 = PA_11, // CAN1-RX |
<> | 144:ef7eb2e8f9f7 | 176 | D4 = PA_12, // CAN1-TX |
<> | 144:ef7eb2e8f9f7 | 177 | D5 = PA_15, |
<> | 144:ef7eb2e8f9f7 | 178 | D6 = PD_11, // UART3-CTS |
<> | 144:ef7eb2e8f9f7 | 179 | D7 = PD_12, // UART3-RTS |
<> | 144:ef7eb2e8f9f7 | 180 | D8 = PA_9, // UART1-TX |
<> | 144:ef7eb2e8f9f7 | 181 | D9 = PE_9, // SDCard-CS |
<> | 144:ef7eb2e8f9f7 | 182 | D10 = PE_11, // SSEL |
<> | 144:ef7eb2e8f9f7 | 183 | D11 = PE_14, // MOSI |
<> | 144:ef7eb2e8f9f7 | 184 | D12 = PE_13, // MISO |
<> | 144:ef7eb2e8f9f7 | 185 | D13 = PE_12, // SCK |
<> | 144:ef7eb2e8f9f7 | 186 | D14 = PF_0, // SDA |
<> | 144:ef7eb2e8f9f7 | 187 | D15 = PF_1, // SCL |
<> | 144:ef7eb2e8f9f7 | 188 | // Internal |
<> | 144:ef7eb2e8f9f7 | 189 | LED_RED = PE_0, // Red / Mode |
<> | 144:ef7eb2e8f9f7 | 190 | LED_GRE = PB_6, // Green / Switch-1 |
<> | 144:ef7eb2e8f9f7 | 191 | LED_BLU = PB_8, // Blue |
<> | 144:ef7eb2e8f9f7 | 192 | SW0 = PF_2, // Switch-0 |
<> | 144:ef7eb2e8f9f7 | 193 | SW1 = PB_6, // Green / Switch-1 |
<> | 144:ef7eb2e8f9f7 | 194 | // ST-Link |
<> | 144:ef7eb2e8f9f7 | 195 | USBRXD = PD_9, |
<> | 144:ef7eb2e8f9f7 | 196 | USBTXD = PD_8, |
<> | 144:ef7eb2e8f9f7 | 197 | SWDIO = PA_15, |
<> | 144:ef7eb2e8f9f7 | 198 | SWCLK = PA_14, |
<> | 144:ef7eb2e8f9f7 | 199 | NTRST = PB_4, |
<> | 144:ef7eb2e8f9f7 | 200 | |
<> | 144:ef7eb2e8f9f7 | 201 | // Not connected |
<> | 144:ef7eb2e8f9f7 | 202 | NC = (int)0xFFFFFFFF |
<> | 144:ef7eb2e8f9f7 | 203 | } PinName; |
<> | 144:ef7eb2e8f9f7 | 204 | |
<> | 144:ef7eb2e8f9f7 | 205 | typedef enum { |
<> | 144:ef7eb2e8f9f7 | 206 | PullNone = 0, |
<> | 144:ef7eb2e8f9f7 | 207 | PullUp = 1, |
<> | 144:ef7eb2e8f9f7 | 208 | PullDown = 2, |
<> | 144:ef7eb2e8f9f7 | 209 | OpenDrain = 3, |
<> | 144:ef7eb2e8f9f7 | 210 | PullDefault = PullNone |
<> | 144:ef7eb2e8f9f7 | 211 | } PinMode; |
<> | 144:ef7eb2e8f9f7 | 212 | |
<> | 144:ef7eb2e8f9f7 | 213 | #ifdef __cplusplus |
<> | 144:ef7eb2e8f9f7 | 214 | } |
<> | 144:ef7eb2e8f9f7 | 215 | #endif |
<> | 144:ef7eb2e8f9f7 | 216 | |
<> | 144:ef7eb2e8f9f7 | 217 | #endif |