Bluepill_Plantilla Es la plantilla base (mejorada) para soporte y compatibilidad en Mbed para la tarjeta "BluePill" basada en el procesador ARM M3 STM32F103C8T6

Dependencies:   mbed

Committer:
Antulius
Date:
Wed Jun 26 18:54:11 2019 +0000
Revision:
0:9f7581d1af6f
Child:
2:ed30bbd12e22
Plantilla para la Tarjeta STM32-F103C8T6 mejor conocida como "Blue Pill"

Who changed what in which revision?

UserRevisionLine numberNew contents of line
Antulius 0:9f7581d1af6f 1 /* mbed Microcontroller Library
Antulius 0:9f7581d1af6f 2 *******************************************************************************
Antulius 0:9f7581d1af6f 3 * Copyright (c) 2014, STMicroelectronics
Antulius 0:9f7581d1af6f 4 * All rights reserved.
Antulius 0:9f7581d1af6f 5 *
Antulius 0:9f7581d1af6f 6 * Redistribution and use in source and binary forms, with or without
Antulius 0:9f7581d1af6f 7 * modification, are permitted provided that the following conditions are met:
Antulius 0:9f7581d1af6f 8 *
Antulius 0:9f7581d1af6f 9 * 1. Redistributions of source code must retain the above copyright notice,
Antulius 0:9f7581d1af6f 10 * this list of conditions and the following disclaimer.
Antulius 0:9f7581d1af6f 11 * 2. Redistributions in binary form must reproduce the above copyright notice,
Antulius 0:9f7581d1af6f 12 * this list of conditions and the following disclaimer in the documentation
Antulius 0:9f7581d1af6f 13 * and/or other materials provided with the distribution.
Antulius 0:9f7581d1af6f 14 * 3. Neither the name of STMicroelectronics nor the names of its contributors
Antulius 0:9f7581d1af6f 15 * may be used to endorse or promote products derived from this software
Antulius 0:9f7581d1af6f 16 * without specific prior written permission.
Antulius 0:9f7581d1af6f 17 *
Antulius 0:9f7581d1af6f 18 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
Antulius 0:9f7581d1af6f 19 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
Antulius 0:9f7581d1af6f 20 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
Antulius 0:9f7581d1af6f 21 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
Antulius 0:9f7581d1af6f 22 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
Antulius 0:9f7581d1af6f 23 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
Antulius 0:9f7581d1af6f 24 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
Antulius 0:9f7581d1af6f 25 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
Antulius 0:9f7581d1af6f 26 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
Antulius 0:9f7581d1af6f 27 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
Antulius 0:9f7581d1af6f 28 *******************************************************************************
Antulius 0:9f7581d1af6f 29
Antulius 0:9f7581d1af6f 30 */
Antulius 0:9f7581d1af6f 31 #ifndef MBED_PINNAMES_H
Antulius 0:9f7581d1af6f 32 #define MBED_PINNAMES_H
Antulius 0:9f7581d1af6f 33
Antulius 0:9f7581d1af6f 34 #include "cmsis.h"
Antulius 0:9f7581d1af6f 35 #include "PinNamesTypes.h"
Antulius 0:9f7581d1af6f 36
Antulius 0:9f7581d1af6f 37 #ifdef __cplusplus
Antulius 0:9f7581d1af6f 38 extern "C" {
Antulius 0:9f7581d1af6f 39 #endif
Antulius 0:9f7581d1af6f 40
Antulius 0:9f7581d1af6f 41 typedef enum {
Antulius 0:9f7581d1af6f 42 // Not connected
Antulius 0:9f7581d1af6f 43 NC = (int)0xFFFFFFFF,
Antulius 0:9f7581d1af6f 44
Antulius 0:9f7581d1af6f 45 // Ports
Antulius 0:9f7581d1af6f 46 PA_0 = 0x00,
Antulius 0:9f7581d1af6f 47 PA_1 = 0x01,
Antulius 0:9f7581d1af6f 48 PA_2 = 0x02,
Antulius 0:9f7581d1af6f 49 PA_3 = 0x03,
Antulius 0:9f7581d1af6f 50 PA_4 = 0x04,
Antulius 0:9f7581d1af6f 51 PA_5 = 0x05,
Antulius 0:9f7581d1af6f 52 PA_6 = 0x06,
Antulius 0:9f7581d1af6f 53 PA_7 = 0x07,
Antulius 0:9f7581d1af6f 54 PA_8 = 0x08,
Antulius 0:9f7581d1af6f 55 PA_9 = 0x09,
Antulius 0:9f7581d1af6f 56 PA_10 = 0x0A,
Antulius 0:9f7581d1af6f 57 PA_11 = 0x0B,
Antulius 0:9f7581d1af6f 58 PA_12 = 0x0C,
Antulius 0:9f7581d1af6f 59 PA_13 = NC,
Antulius 0:9f7581d1af6f 60 PA_14 = NC,
Antulius 0:9f7581d1af6f 61 PA_15 = 0x0F,
Antulius 0:9f7581d1af6f 62
Antulius 0:9f7581d1af6f 63 PB_0 = 0x10,
Antulius 0:9f7581d1af6f 64 PB_1 = 0x11,
Antulius 0:9f7581d1af6f 65 PB_2 = NC,
Antulius 0:9f7581d1af6f 66 PB_3 = 0x13,
Antulius 0:9f7581d1af6f 67 PB_4 = 0x14,
Antulius 0:9f7581d1af6f 68 PB_5 = 0x15,
Antulius 0:9f7581d1af6f 69 PB_6 = 0x16,
Antulius 0:9f7581d1af6f 70 PB_7 = 0x17,
Antulius 0:9f7581d1af6f 71 PB_8 = 0x18,
Antulius 0:9f7581d1af6f 72 PB_9 = 0x19,
Antulius 0:9f7581d1af6f 73 PB_10 = 0x1A,
Antulius 0:9f7581d1af6f 74 PB_11 = 0x1B,
Antulius 0:9f7581d1af6f 75 PB_12 = 0x1C,
Antulius 0:9f7581d1af6f 76 PB_13 = 0x1D,
Antulius 0:9f7581d1af6f 77 PB_14 = 0x1E,
Antulius 0:9f7581d1af6f 78 PB_15 = 0x1F,
Antulius 0:9f7581d1af6f 79
Antulius 0:9f7581d1af6f 80 PC_0 = NC,
Antulius 0:9f7581d1af6f 81 PC_1 = NC,
Antulius 0:9f7581d1af6f 82 PC_2 = NC,
Antulius 0:9f7581d1af6f 83 PC_3 = NC,
Antulius 0:9f7581d1af6f 84 PC_4 = NC,
Antulius 0:9f7581d1af6f 85 PC_5 = NC,
Antulius 0:9f7581d1af6f 86 PC_6 = NC,
Antulius 0:9f7581d1af6f 87 PC_7 = NC,
Antulius 0:9f7581d1af6f 88 PC_8 = NC,
Antulius 0:9f7581d1af6f 89 PC_9 = NC,
Antulius 0:9f7581d1af6f 90 PC_10 = NC,
Antulius 0:9f7581d1af6f 91 PC_11 = NC,
Antulius 0:9f7581d1af6f 92 PC_12 = NC,
Antulius 0:9f7581d1af6f 93 PC_13 = 0x2D,
Antulius 0:9f7581d1af6f 94 PC_14 = 0x2E,
Antulius 0:9f7581d1af6f 95 PC_15 = 0x2F,
Antulius 0:9f7581d1af6f 96
Antulius 0:9f7581d1af6f 97 PD_2 = NC,
Antulius 0:9f7581d1af6f 98
Antulius 0:9f7581d1af6f 99 // ADC internal channels
Antulius 0:9f7581d1af6f 100 ADC_TEMP = 0xF0,
Antulius 0:9f7581d1af6f 101 ADC_VREF = 0xF1,
Antulius 0:9f7581d1af6f 102
Antulius 0:9f7581d1af6f 103 // Arduino connector namings
Antulius 0:9f7581d1af6f 104 A0 = PA_0,
Antulius 0:9f7581d1af6f 105 A1 = PA_1,
Antulius 0:9f7581d1af6f 106 A2 = PA_4,
Antulius 0:9f7581d1af6f 107 A3 = PB_0,
Antulius 0:9f7581d1af6f 108 A4 = NC,
Antulius 0:9f7581d1af6f 109 A5 = NC,
Antulius 0:9f7581d1af6f 110 D0 = PA_3,
Antulius 0:9f7581d1af6f 111 D1 = PA_2,
Antulius 0:9f7581d1af6f 112 D2 = PA_10,
Antulius 0:9f7581d1af6f 113 D3 = PB_3,
Antulius 0:9f7581d1af6f 114 D4 = PB_5,
Antulius 0:9f7581d1af6f 115 D5 = PB_4,
Antulius 0:9f7581d1af6f 116 D6 = PB_10,
Antulius 0:9f7581d1af6f 117 D7 = PA_8,
Antulius 0:9f7581d1af6f 118 D8 = PA_9,
Antulius 0:9f7581d1af6f 119 D9 = NC,
Antulius 0:9f7581d1af6f 120 D10 = PB_6,
Antulius 0:9f7581d1af6f 121 D11 = PA_7,
Antulius 0:9f7581d1af6f 122 D12 = PA_6,
Antulius 0:9f7581d1af6f 123 D13 = PA_5,
Antulius 0:9f7581d1af6f 124 D14 = PB_9,
Antulius 0:9f7581d1af6f 125 D15 = PB_8,
Antulius 0:9f7581d1af6f 126
Antulius 0:9f7581d1af6f 127 // Generic signals namings
Antulius 0:9f7581d1af6f 128 Red_Led = NC,
Antulius 0:9f7581d1af6f 129 Green_Led = PC_13,
Antulius 0:9f7581d1af6f 130 Blue_Led = NC,
Antulius 0:9f7581d1af6f 131 LED1 = PC_13,
Antulius 0:9f7581d1af6f 132 LED2 = NC,
Antulius 0:9f7581d1af6f 133 LED3 = NC,
Antulius 0:9f7581d1af6f 134 LED4 = NC,
Antulius 0:9f7581d1af6f 135 USER_BUTTON = NC,
Antulius 0:9f7581d1af6f 136 SERIAL_TX = PA_2,
Antulius 0:9f7581d1af6f 137 SERIAL_RX = PA_3,
Antulius 0:9f7581d1af6f 138 USBTX = PA_12,
Antulius 0:9f7581d1af6f 139 USBRX = PA_11,
Antulius 0:9f7581d1af6f 140 CANRX = PB_8,
Antulius 0:9f7581d1af6f 141 CANTX = PB_9,
Antulius 0:9f7581d1af6f 142 I2C_SCL = PB_8,
Antulius 0:9f7581d1af6f 143 I2C_SDA = PB_9,
Antulius 0:9f7581d1af6f 144 SPI_MOSI = PA_7,
Antulius 0:9f7581d1af6f 145 SPI_MISO = PA_6,
Antulius 0:9f7581d1af6f 146 SPI_SCK = PA_5,
Antulius 0:9f7581d1af6f 147 SPI_CS = PB_6,
Antulius 0:9f7581d1af6f 148 PWM_OUT = PB_3
Antulius 0:9f7581d1af6f 149 } PinName;
Antulius 0:9f7581d1af6f 150
Antulius 0:9f7581d1af6f 151 #ifdef __cplusplus
Antulius 0:9f7581d1af6f 152 }
Antulius 0:9f7581d1af6f 153 #endif
Antulius 0:9f7581d1af6f 154
Antulius 0:9f7581d1af6f 155 #endif