STM32 F103RB support for mbed-rpc, tested just once with the blinking example
Dependents: rpc_over_serial_irq
Fork of mbed-rpc by
parse_pins.cpp@7:279476428ecf, 2014-08-04 (annotated)
- 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?
User | Revision | Line number | New 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 | } |