STM32 F103RB support for mbed-rpc, tested just once with the blinking example
Dependents: rpc_over_serial_irq
Fork of mbed-rpc by
Revision 7:279476428ecf, committed 2014-08-04
- Comitter:
- mosi
- Date:
- Mon Aug 04 16:50:46 2014 +0000
- Parent:
- 6:78303e9c7590
- Commit message:
- Added STM32 F103RB TARGET_NUCLEO_F103RB support for mbed RPC
Changed in this revision
parse_pins.cpp | Show annotated file Show diff for this revision Revisions of this file |
parse_pins.old.txt | Show annotated file Show diff for this revision Revisions of this file |
diff -r 78303e9c7590 -r 279476428ecf parse_pins.cpp --- a/parse_pins.cpp Fri Aug 01 22:04:52 2014 +0000 +++ b/parse_pins.cpp Mon Aug 04 16:50:46 2014 +0000 @@ -1,18 +1,7 @@ /* mbed Microcontroller Library * Copyright (c) 2006-2013 ARM Limited - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. */ +#include "stmbed.h" #include "port_api.h" namespace mbed { @@ -31,6 +20,12 @@ , p15, p16, p17, p18, p19, p20, NC, NC, p23 , p24, p25, p26, p27, p28, p29, p30, p31, p32 , p33, p34, NC, NC, p37, p38, p39}; + +#elif defined(TARGET_STM32F4XX) || defined(TARGET_STM32F1XX) || defined(TARGET_NUCLEO_F103RB) + static const PinName pin_names[] = { p5, p6, p7, p8, p9, p10, p11, p12, p13, p14 + , p15, p16, p17, p18, p19, p20, p21, p22, p23 + , p24, p25, p26, p27, p28, p29, p30, p31, p32 + , p33, p34, NC, NC, NC, NC, NC}; #endif #if defined(TARGET_LPC1768) || defined(TARGET_LPC11U24) || defined(TARGET_LPC2368) || defined(TARGET_LPC812) || defined(TARGET_LPC4088)|| defined(TARGET_LPC1114) @@ -53,9 +48,34 @@ pin = pin * 10 + pin2; } return port_pin((PortName)port, pin); + +#elif defined(TARGET_NUCLEO_F103RB) + if (str[0] == 'P') { // Pn_n + uint32_t port = str[1] - '0'; + uint32_t pin = str[3] - '0'; // Pn_n + uint32_t pin2 = str[4] - '0'; // Pn_nn + if (pin2 <= 9) { + pin = pin * 10 + pin2; + } + return port_pin((PortName)port, pin); #endif -#if defined(TARGET_LPC1768) || defined(TARGET_LPC11U24) || defined(TARGET_LPC2368) +#if defined(TARGET_NUCLEO_F103RB) || defined(TARGET_LPC1768) || defined(TARGET_LPC11U24) || defined(TARGET_LPC2368) \ + || defined(TARGET_STM32F3XX) || defined(TARGET_STM32F4XX) +/* defined(TARGET_NUCLEO_F103RB) || defined(TARGET_NUCLEO_L152RE) || \ +defined(TARGET_NUCLEO_F302R8) || \ +defined(TARGET_NUCLEO_F030R8) || \ +defined(TARGET_NUCLEO_F401RE) || \ +defined(TARGET_NUCLEO_F411RE) || \ +defined(TARGET_NUCLEO_F072RB) || \ +defined(TARGET_NUCLEO_F334R8) || \ +defined(TARGET_NUCLEO_L053R8) +//#define TXPIN STDIO_UART_TX +//#endif +//TARGET_NUCLEO_L152RE +//TARGET_STM32F4XX) || defined(TARGET_STM32F1XX +//TARGET_STM32F4XX) || defined(TARGET_STM32F103) +*/ } else if (str[0] == 'p') { // pn uint32_t pin = str[1] - '0'; // pn uint32_t pin2 = str[2] - '0'; // pnn @@ -77,7 +97,7 @@ return NC; } return pin_names[pin - 5]; -#elif defined(TARGET_STM32F4XX) || defined(TARGET_STM32F1XX) +//#elif defined(TARGET_STM32F4XX) || defined(TARGET_STM32F1XX) // TODO: implement pin names specific to STM32 platform here #endif
diff -r 78303e9c7590 -r 279476428ecf parse_pins.old.txt --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/parse_pins.old.txt Mon Aug 04 16:50:46 2014 +0000 @@ -0,0 +1,124 @@ +/* mbed Microcontroller Library + * Copyright (c) 2006-2013 ARM Limited + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +#include "stmbed.h" +#include "port_api.h" + +namespace mbed { + +PinName parse_pins(const char *str) { +#if defined(TARGET_LPC1768) || defined(TARGET_LPC11U24) || defined(TARGET_LPC2368) + static const PinName pin_names[] = {p5, p6, p7, p8, p9, p10, p11, p12, p13, p14 + , p15, p16, p17, p18, p19, p20, p21, p22, p23 + , p24, p25, p26, p27, p28, p29, p30}; +#elif defined(TARGET_LPC1114) + static const PinName pin_names[] = {dp1, dp2, dp4, dp5, dp6, dp9, dp10, dp11 + , dp13, dp14, dp15, dp16, dp17, dp18, dp23 + , dp24, dp25, dp26, dp27, dp28}; +#elif defined(TARGET_LPC4088) + static const PinName pin_names[] = {p5, p6, p7, p8, p9, p10, p11, p12, p13, p14 + , p15, p16, p17, p18, p19, p20, NC, NC, p23 + , p24, p25, p26, p27, p28, p29, p30, p31, p32 + , p33, p34, NC, NC, p37, p38, p39}; + +#elif defined(TARGET_STM32F4XX) || defined(TARGET_STM32F1XX) + static const PinName pin_names[] = { p5, p6, p7, p8, p9, p10, p11, p12, p13, p14 + , p15, p16, p17, p18, p19, p20, p21, p22, p23 + , p24, p25, p26, p27, p28, p29, p30, p31, p32 + , p33, p34, NC, NC, NC, NC, NC}; +#endif + +#if defined(TARGET_LPC1768) || defined(TARGET_LPC11U24) || defined(TARGET_LPC2368) || defined(TARGET_LPC812) || defined(TARGET_LPC4088)|| defined(TARGET_LPC1114) + if (str[0] == 'P') { // Pn_n + uint32_t port = str[1] - '0'; + uint32_t pin = str[3] - '0'; // Pn_n + uint32_t pin2 = str[4] - '0'; // Pn_nn + if (pin2 <= 9) { + pin = pin * 10 + pin2; + } + return port_pin((PortName)port, pin); + +#elif defined(TARGET_KL25Z) + if (str[0] == 'P' && str[1] == 'T') { // PTx_n + uint32_t port = str[2] - 'A'; + uint32_t pin = str[3] - '0'; // PTxn + uint32_t pin2 = str[4] - '0'; // PTxnn + + if (pin2 <= 9) { + pin = pin * 10 + pin2; + } + return port_pin((PortName)port, pin); +#endif + +#if defined(TARGET_LPC1768) || defined(TARGET_LPC11U24) || defined(TARGET_LPC2368) || defined(TARGET_STM32F3XX) || defined(TARGET_STM32F4XX) || defined(TARGET_NUCLEO_F103RB) + +#if defined(TARGET_NUCLEO_F103RB) || defined(TARGET_NUCLEO_L152RE) || \ +defined(TARGET_NUCLEO_F302R8) || \ +defined(TARGET_NUCLEO_F030R8) || \ +defined(TARGET_NUCLEO_F401RE) || \ +defined(TARGET_NUCLEO_F411RE) || \ +defined(TARGET_NUCLEO_F072RB) || \ +defined(TARGET_NUCLEO_F334R8) || \ +defined(TARGET_NUCLEO_L053R8) +//#define TXPIN STDIO_UART_TX +//#endif +//TARGET_NUCLEO_L152RE +//TARGET_STM32F4XX) || defined(TARGET_STM32F1XX +//TARGET_STM32F4XX) || defined(TARGET_STM32F103) + + } else if (str[0] == 'p') { // pn + uint32_t pin = str[1] - '0'; // pn + uint32_t pin2 = str[2] - '0'; // pnn + if (pin2 <= 9) { + pin = pin * 10 + pin2; + } + if (pin < 5 || pin > 30) { + return NC; + } + return pin_names[pin - 5]; +#elif defined(TARGET_LPC4088) + } else if (str[0] == 'p') { // pn + uint32_t pin = str[1] - '0'; // pn + uint32_t pin2 = str[2] - '0'; // pnn + if (pin2 <= 9) { + pin = pin * 10 + pin2; + } + if (pin < 5 || pin > 39) { + return NC; + } + return pin_names[pin - 5]; +//#elif defined(TARGET_STM32F4XX) || defined(TARGET_STM32F1XX) + // TODO: implement pin names specific to STM32 platform here +#endif + + } else if (str[0] == 'L') { // LEDn + switch (str[3]) { + case '1' : return LED1; + case '2' : return LED2; + case '3' : return LED3; + case '4' : return LED4; + } + + } else if (str[0] == 'U') { // USB?X + switch (str[3]) { + case 'T' : return USBTX; + case 'R' : return USBRX; + } + } + + return NC; +} + +}