STM32 F103RB support for mbed-rpc, tested just once with the blinking example

Dependents:   rpc_over_serial_irq

Fork of mbed-rpc by mbed official

Committer:
mosi
Date:
Mon Aug 04 16:50:46 2014 +0000
Revision:
7:279476428ecf
Parent:
6:78303e9c7590
Added STM32 F103RB TARGET_NUCLEO_F103RB support for mbed RPC

Who changed what in which revision?

UserRevisionLine numberNew contents of line
emilmont 1:6919289a5946 1 /* mbed Microcontroller Library
emilmont 1:6919289a5946 2 * Copyright (c) 2006-2013 ARM Limited
emilmont 1:6919289a5946 3 */
mosi 7:279476428ecf 4 #include "stmbed.h"
emilmont 1:6919289a5946 5 #include "port_api.h"
emilmont 1:6919289a5946 6
emilmont 1:6919289a5946 7 namespace mbed {
emilmont 1:6919289a5946 8
emilmont 1:6919289a5946 9 PinName parse_pins(const char *str) {
emilmont 4:9f88f495e549 10 #if defined(TARGET_LPC1768) || defined(TARGET_LPC11U24) || defined(TARGET_LPC2368)
emilmont 1:6919289a5946 11 static const PinName pin_names[] = {p5, p6, p7, p8, p9, p10, p11, p12, p13, p14
emilmont 1:6919289a5946 12 , p15, p16, p17, p18, p19, p20, p21, p22, p23
emilmont 1:6919289a5946 13 , p24, p25, p26, p27, p28, p29, p30};
bogdanm 5:4490a0d9cb2a 14 #elif defined(TARGET_LPC1114)
bogdanm 5:4490a0d9cb2a 15 static const PinName pin_names[] = {dp1, dp2, dp4, dp5, dp6, dp9, dp10, dp11
bogdanm 5:4490a0d9cb2a 16 , dp13, dp14, dp15, dp16, dp17, dp18, dp23
bogdanm 5:4490a0d9cb2a 17 , dp24, dp25, dp26, dp27, dp28};
emilmont 4:9f88f495e549 18 #elif defined(TARGET_LPC4088)
emilmont 4:9f88f495e549 19 static const PinName pin_names[] = {p5, p6, p7, p8, p9, p10, p11, p12, p13, p14
emilmont 4:9f88f495e549 20 , p15, p16, p17, p18, p19, p20, NC, NC, p23
emilmont 4:9f88f495e549 21 , p24, p25, p26, p27, p28, p29, p30, p31, p32
emilmont 4:9f88f495e549 22 , p33, p34, NC, NC, p37, p38, p39};
mosi 7:279476428ecf 23
mosi 7:279476428ecf 24 #elif defined(TARGET_STM32F4XX) || defined(TARGET_STM32F1XX) || defined(TARGET_NUCLEO_F103RB)
mosi 7:279476428ecf 25 static const PinName pin_names[] = { p5, p6, p7, p8, p9, p10, p11, p12, p13, p14
mosi 7:279476428ecf 26 , p15, p16, p17, p18, p19, p20, p21, p22, p23
mosi 7:279476428ecf 27 , p24, p25, p26, p27, p28, p29, p30, p31, p32
mosi 7:279476428ecf 28 , p33, p34, NC, NC, NC, NC, NC};
emilmont 1:6919289a5946 29 #endif
emilmont 1:6919289a5946 30
bogdanm 5:4490a0d9cb2a 31 #if defined(TARGET_LPC1768) || defined(TARGET_LPC11U24) || defined(TARGET_LPC2368) || defined(TARGET_LPC812) || defined(TARGET_LPC4088)|| defined(TARGET_LPC1114)
emilmont 1:6919289a5946 32 if (str[0] == 'P') { // Pn_n
emilmont 1:6919289a5946 33 uint32_t port = str[1] - '0';
emilmont 1:6919289a5946 34 uint32_t pin = str[3] - '0'; // Pn_n
emilmont 1:6919289a5946 35 uint32_t pin2 = str[4] - '0'; // Pn_nn
emilmont 1:6919289a5946 36 if (pin2 <= 9) {
emilmont 1:6919289a5946 37 pin = pin * 10 + pin2;
emilmont 1:6919289a5946 38 }
emilmont 1:6919289a5946 39 return port_pin((PortName)port, pin);
emilmont 1:6919289a5946 40
emilmont 2:65228c367483 41 #elif defined(TARGET_KL25Z)
emilmont 1:6919289a5946 42 if (str[0] == 'P' && str[1] == 'T') { // PTx_n
emilmont 1:6919289a5946 43 uint32_t port = str[2] - 'A';
emilmont 1:6919289a5946 44 uint32_t pin = str[3] - '0'; // PTxn
emilmont 1:6919289a5946 45 uint32_t pin2 = str[4] - '0'; // PTxnn
emilmont 1:6919289a5946 46
emilmont 1:6919289a5946 47 if (pin2 <= 9) {
emilmont 1:6919289a5946 48 pin = pin * 10 + pin2;
emilmont 1:6919289a5946 49 }
emilmont 1:6919289a5946 50 return port_pin((PortName)port, pin);
mosi 7:279476428ecf 51
mosi 7:279476428ecf 52 #elif defined(TARGET_NUCLEO_F103RB)
mosi 7:279476428ecf 53 if (str[0] == 'P') { // Pn_n
mosi 7:279476428ecf 54 uint32_t port = str[1] - '0';
mosi 7:279476428ecf 55 uint32_t pin = str[3] - '0'; // Pn_n
mosi 7:279476428ecf 56 uint32_t pin2 = str[4] - '0'; // Pn_nn
mosi 7:279476428ecf 57 if (pin2 <= 9) {
mosi 7:279476428ecf 58 pin = pin * 10 + pin2;
mosi 7:279476428ecf 59 }
mosi 7:279476428ecf 60 return port_pin((PortName)port, pin);
emilmont 1:6919289a5946 61 #endif
emilmont 1:6919289a5946 62
mosi 7:279476428ecf 63 #if defined(TARGET_NUCLEO_F103RB) || defined(TARGET_LPC1768) || defined(TARGET_LPC11U24) || defined(TARGET_LPC2368) \
mosi 7:279476428ecf 64 || defined(TARGET_STM32F3XX) || defined(TARGET_STM32F4XX)
mosi 7:279476428ecf 65 /* defined(TARGET_NUCLEO_F103RB) || defined(TARGET_NUCLEO_L152RE) || \
mosi 7:279476428ecf 66 defined(TARGET_NUCLEO_F302R8) || \
mosi 7:279476428ecf 67 defined(TARGET_NUCLEO_F030R8) || \
mosi 7:279476428ecf 68 defined(TARGET_NUCLEO_F401RE) || \
mosi 7:279476428ecf 69 defined(TARGET_NUCLEO_F411RE) || \
mosi 7:279476428ecf 70 defined(TARGET_NUCLEO_F072RB) || \
mosi 7:279476428ecf 71 defined(TARGET_NUCLEO_F334R8) || \
mosi 7:279476428ecf 72 defined(TARGET_NUCLEO_L053R8)
mosi 7:279476428ecf 73 //#define TXPIN STDIO_UART_TX
mosi 7:279476428ecf 74 //#endif
mosi 7:279476428ecf 75 //TARGET_NUCLEO_L152RE
mosi 7:279476428ecf 76 //TARGET_STM32F4XX) || defined(TARGET_STM32F1XX
mosi 7:279476428ecf 77 //TARGET_STM32F4XX) || defined(TARGET_STM32F103)
mosi 7:279476428ecf 78 */
emilmont 1:6919289a5946 79 } else if (str[0] == 'p') { // pn
emilmont 1:6919289a5946 80 uint32_t pin = str[1] - '0'; // pn
emilmont 1:6919289a5946 81 uint32_t pin2 = str[2] - '0'; // pnn
emilmont 1:6919289a5946 82 if (pin2 <= 9) {
emilmont 1:6919289a5946 83 pin = pin * 10 + pin2;
emilmont 1:6919289a5946 84 }
emilmont 1:6919289a5946 85 if (pin < 5 || pin > 30) {
emilmont 1:6919289a5946 86 return NC;
emilmont 1:6919289a5946 87 }
emilmont 1:6919289a5946 88 return pin_names[pin - 5];
emilmont 4:9f88f495e549 89 #elif defined(TARGET_LPC4088)
emilmont 4:9f88f495e549 90 } else if (str[0] == 'p') { // pn
emilmont 4:9f88f495e549 91 uint32_t pin = str[1] - '0'; // pn
emilmont 4:9f88f495e549 92 uint32_t pin2 = str[2] - '0'; // pnn
emilmont 4:9f88f495e549 93 if (pin2 <= 9) {
emilmont 4:9f88f495e549 94 pin = pin * 10 + pin2;
emilmont 4:9f88f495e549 95 }
emilmont 4:9f88f495e549 96 if (pin < 5 || pin > 39) {
emilmont 4:9f88f495e549 97 return NC;
emilmont 4:9f88f495e549 98 }
emilmont 4:9f88f495e549 99 return pin_names[pin - 5];
mosi 7:279476428ecf 100 //#elif defined(TARGET_STM32F4XX) || defined(TARGET_STM32F1XX)
mosi 6:78303e9c7590 101 // TODO: implement pin names specific to STM32 platform here
emilmont 1:6919289a5946 102 #endif
emilmont 1:6919289a5946 103
emilmont 1:6919289a5946 104 } else if (str[0] == 'L') { // LEDn
emilmont 1:6919289a5946 105 switch (str[3]) {
emilmont 1:6919289a5946 106 case '1' : return LED1;
emilmont 1:6919289a5946 107 case '2' : return LED2;
emilmont 1:6919289a5946 108 case '3' : return LED3;
emilmont 1:6919289a5946 109 case '4' : return LED4;
emilmont 1:6919289a5946 110 }
emilmont 1:6919289a5946 111
emilmont 1:6919289a5946 112 } else if (str[0] == 'U') { // USB?X
emilmont 1:6919289a5946 113 switch (str[3]) {
emilmont 1:6919289a5946 114 case 'T' : return USBTX;
emilmont 1:6919289a5946 115 case 'R' : return USBRX;
emilmont 1:6919289a5946 116 }
emilmont 1:6919289a5946 117 }
emilmont 1:6919289a5946 118
emilmont 1:6919289a5946 119 return NC;
emilmont 1:6919289a5946 120 }
emilmont 1:6919289a5946 121
emilmont 1:6919289a5946 122 }