Forum : ARM
Original Post
    | Post Information | Post | 
|---|---|
| November 25, 2010 - 10:58am | Hi all! I'm tryng to establish a RS232 communication between my RevA (with a STM32F107 daughterboard) and the Hyperterminal. I want to display simply "Helloworld" on my monitor. Does it exist an RS232 working example program for STM32F107 which can help me? Thank you! | 
 
            
Hi,
You can find an "Hello World" example in the C:\Program Files\Raisonance\Ride\Examples\ARM\. You just have to change the processor from STR7 to STM32F107 and it will work.
Regards,
Hi,
I'm sorry, but I already try to change the target device, and download this example but it still doesn't work.
However, I check my hyperterminal connexion and configuration and all seem to be right.
Are you sure there is any adds or modifications to bring for adapt the code for a STM32F107VCT6 use?
Thx for your help, Bruno!
Hi,
Using REva and the STM32F107, the hello World example should work right away.
Few things to check:
- Does the "Toggle" application work on your board?
- Is the Hello World project configured as RLink (not Simulator) mode?
- Did you properly place the Tx and Rx jumpers on the board?
Once this is done, you may have various problems with the use of Hyperterminal. The best thing to do is to check the UART output using an oscilloscope. We usually write something such as
while(1) putchar('U');'U' has the property of being 01010101 in binary, so it generates nice patterns on the scope.
The bit width on your scope should be 104us (9600bps).
Check whether the signal is present, and whether it is 104us wide. If it is, then your problem revolves around Hyperterminal and your COM ports.
Best Regards,
Wooops sorry,
I gave an invalid information: The putchar/getchar functions provided with the RKit-ARM use USART1 for communication, although USART2 is connected to the Tx/Rx pins through USART2!
This means that you cannot directly call the integrated putchar, you need to write your own init/putchar/getchar routines that use USART2 instead of USART1.
More on that later, I will post some source code that fixes the problem so that you do not have to worry about writing the functions by yourself.
Best Regards,
Bruno
Hi,
There is an additional oddity on our STM32F107 REva Daughterboard: The USART is the USART2, but REMAPPED.
Here is a piece of code that performs proper initialization on both STM32F103 and STM32F107 daughterboards.
You can use the code without limitation. It does not use the ST Library, hence is quite portable.
However, you will need to adapt the baud rate, which is currently hardcoded to 9600 bps (no parity, 8 data bits, 1 stop bit).
/** * STM32F10X_IO_putchar.c * * This file implements the io_putchar and io_getchar functions * for the STM32F10x devices. * * It does not use the ST firmware Libraries. * * You can duplicate it and include the copy in your project, * then you'll be able to modify it for using different parameters: * baudrate, stop bits, other UART, etc. * * The default settings permit a 9600/N/8/1 settings for an 8MHz clock. */ typedef unsigned long u32; typedef volatile unsigned long vu32; typedef volatile unsigned short vu16; // RCC registers #define RCC_CR (*(vu32*)0x40021000) #define RCC_CFGR (*(vu32*)0x40021004) #define RCC_CIR (*(vu32*)0x40021008) #define RCC_APB2RSTR (*(vu32*)0x4002100C) #define RCC_APB1RSTR (*(vu32*)0x40021010) #define RCC_AHBENR (*(vu32*)0x40021014) #define RCC_APB2ENR (*(vu32*)0x40021018) #define RCC_APB1ENR (*(vu32*)0x4002101C) #define RCC_BDCR (*(vu32*)0x40021020) #define RCC_CSR (*(vu32*)0x40021024) #ifdef STM32F10X_CL #define RCC_AHBRSTR (*(vu32*)0x40021028) #define RCC_CFGR2 (*(vu32*)0x4002102C) #endif /* STM32F10X_CL */ #define RCC_APB2Periph_AFIO 0x00000001 #define RCC_APB2Periph_GPIOA 0x00000004 #define RCC_APB2Periph_GPIOB 0x00000008 #define RCC_APB2Periph_GPIOC 0x00000010 #define RCC_APB2Periph_GPIOD 0x00000020 #define RCC_APB2Periph_GPIOE 0x00000040 #define RCC_APB2Periph_GPIOF 0x00000080 #define RCC_APB2Periph_GPIOG 0x00000100 #define RCC_APB2Periph_ADC1 0x00000200 #define RCC_APB2Periph_ADC2 0x00000400 #define RCC_APB2Periph_TIM1 0x00000800 #define RCC_APB2Periph_SPI1 0x00001000 #define RCC_APB2Periph_TIM8 0x00002000 #define RCC_APB2Periph_USART1 0x00004000 #define RCC_APB2Periph_ADC3 0x00008000 #define RCC_APB1Periph_USART2 0x00020000 //Alternate function IO remapping #define AFIO_MAPR (*(vu32*)0x40010004) #define AFIO_MAPR_USART2_REMAP 0x00000008 // GPIOA registers #define GPIOA_CRL (*(vu32*)0x40010800) #define GPIOA_CRH (*(vu32*)0x40010804) #define GPIOA_IDR (*(vu32*)0x40010808) #define GPIOA_ODR (*(vu32*)0x4001080C) #define GPIOA_BSRR (*(vu32*)0x40010810) #define GPIOA_BRR (*(vu32*)0x40010814) #define GPIOA_LCKR (*(vu32*)0x40010818) // GPIOD registers #define GPIOD_CRL (*(vu32*)0x40011400) #define GPIOD_CRH (*(vu32*)0x40011404) #define GPIOD_IDR (*(vu32*)0x40011408) #define GPIOD_ODR (*(vu32*)0x4001140C) #define GPIOD_BSRR (*(vu32*)0x40011410) #define GPIOD_BRR (*(vu32*)0x40011414) #define GPIOD_LCKR (*(vu32*)0x40011418) #define GPIOPin_0 0 #define GPIOPin_1 1 #define GPIOPin_2 2 #define GPIOPin_3 3 #define GPIOPin_4 4 #define GPIOPin_5 5 #define GPIOPin_6 6 #define GPIOPin_7 7 #define GPIOPin_8 8 #define GPIOPin_9 9 #define GPIOPin_10 10 #define GPIOPin_11 11 #define GPIOPin_12 12 #define GPIOPin_13 13 #define GPIOPin_14 14 #define GPIOPin_15 15 /* Warning: These are NOT identical to the ST library macros! */ #define GPIO_Mode_IN_FLOAT 0x04 #define GPIO_Mode_AF_PP_50MHz 0x0B // USART1 registers (these are 16-bit, not 32-bit registers) #define USART1_SR (*(vu16*)0x40013800) #define USART1_DR (*(vu16*)0x40013804) #define USART1_BRR (*(vu16*)0x40013808) #define USART1_CR1 (*(vu16*)0x4001380C) #define USART1_CR2 (*(vu16*)0x40013810) #define USART1_CR3 (*(vu16*)0x40013814) #define USART1_GTPR (*(vu16*)0x40013818) // USART2 registers (these are 16-bit, not 32-bit registers) #define USART2_SR (*(vu16*)0x40004400) #define USART2_DR (*(vu16*)0x40004404) #define USART2_BRR (*(vu16*)0x40004408) #define USART2_CR1 (*(vu16*)0x4000440C) #define USART2_CR2 (*(vu16*)0x40004410) #define USART2_CR3 (*(vu16*)0x40004414) #define USART2_GTPR (*(vu16*)0x40004418) #define USART_FLAG_CTS 0x0200 #define USART_FLAG_LBD 0x0100 #define USART_FLAG_TXE 0x0080 #define USART_FLAG_TC 0x0040 #define USART_FLAG_RXNE 0x0020 #define USART_FLAG_IDLE 0x0010 #define USART_FLAG_ORE 0x0008 #define USART_FLAG_NE 0x0004 #define USART_FLAG_FE 0x0002 #define USART_FLAG_PE 0x0001 #define USART_CR1_Enable 0x2000 #define USART_CR1_Transmit_Enable 0x0008 #define USART_CR1_Receive_Enable 0x0004 /** * For the REva STM32F103 daughterboard, the UART is mapped onto USART1, * with Tx on PA9 and Rx on PA10. * For the REva STM32F107 daughterboard, the UART is mapped onto USART2, * with Tx on PD5 and Rx on PD6. */ #ifdef _STM32F107VCT6_ #define USARTx_SR USART2_SR #define USARTx_DR USART2_DR #define USARTx_CR1 USART2_CR1 void __io_init( void ) { /* Enable GPIOx and AFIO clocks */ RCC_APB2ENR |= RCC_APB2Periph_GPIOD; RCC_APB2ENR |= RCC_APB2Periph_AFIO; RCC_APB1ENR |= RCC_APB1Periph_USART2; /* Remap USART2 for STM32F107 REva daughterboard */ AFIO_MAPR |= AFIO_MAPR_USART2_REMAP; /* Configure the GPIO ports */ /* Configure USARTx_Tx (PD5) as alternate function push-pull */ u32 pinmask = 0x0F << ((GPIOPin_5) << 2); GPIOD_CRL &= ~pinmask; GPIOD_CRL |= GPIO_Mode_AF_PP_50MHz << ((GPIOPin_5) << 2); /* Configure USARTx_Rx (PD6) as input floating */ pinmask = 0x0F << ((GPIOPin_6) << 2); GPIOD_CRL &= ~pinmask; GPIOD_CRL |= GPIO_Mode_IN_FLOAT << ((GPIOPin_6) << 2); /* USARTx configured as 9600 baud, 8 Bits length, One Stop Bit, No parity */ USART2_CR2 = 0x0000; USART2_CR1 = USART_CR1_Transmit_Enable | USART_CR1_Receive_Enable; USART2_CR3 = 0x0000; USART2_BRR = 0x0341; // Baud rate should be adapted if you clock is not 8MHz. USART2_CR1 |= USART_CR1_Enable; // Enable USART } #else // _STM32F107VCT6_ #define USARTx_SR USART1_SR #define USARTx_DR USART1_DR #define USARTx_CR1 USART1_CR1 void __io_init( void ) { /* Enable GPIOx and AFIO clocks */ RCC_APB2ENR |= RCC_APB2Periph_GPIOA; RCC_APB2ENR |= RCC_APB2Periph_AFIO; RCC_APB2ENR |= RCC_APB2Periph_USART1; /* Configure the GPIO ports */ /* Configure USARTx_Tx (PA9) as alternate function push-pull */ u32 pinmask = 0x0F << ((GPIOPin_9 - 8) << 2); GPIOA_CRH &= ~pinmask; GPIOA_CRH |= GPIO_Mode_AF_PP_50MHz << ((GPIOPin_9 - 8) << 2); /* Configure USARTx_Rx (PA10) as input floating */ pinmask = 0x0F << ((GPIOPin_10 - 8) << 2); GPIOA_CRH &= ~pinmask; GPIOA_CRH |= GPIO_Mode_IN_FLOAT << ((GPIOPin_10 - 8) << 2); /* USARTx configured as 9600 baud, 8 Bits length, One Stop Bit, No parity */ USART1_CR2 = 0x0000; USART1_CR1 = USART_CR1_Transmit_Enable | USART_CR1_Receive_Enable; USART1_CR3 = 0x0000; USART1_BRR = 0x0341; // Baud rate should be adapted if you clock is not 8MHz. USART1_CR1 |= USART_CR1_Enable; // Enable USART } #endif // _STM32F107VCT6_ // Send the character on UART void __io_putchar( char c ) { //init UART if needed if(!(USARTx_CR1 & USART_CR1_Enable)) { __io_init(); } // \n is not enough. Need \r too! if( c == 0x0A ) { __io_putchar( 0x0D ); } while((USARTx_SR & USART_FLAG_TXE) == 0); USARTx_DR = c; } int putchar( int c ) { __io_putchar( (char) c ); return c; } int __io_getchar( void ) { unsigned short value; unsigned short wStatus; //init UART if needed if(!(USARTx_CR1 & USART_CR1_Enable)) { __io_init(); } while((USARTx_SR & USART_FLAG_RXNE) == 0); value = USARTx_DR; return value; } int getchar( void ) { return __io_getchar(); }This code will be available in the next release USART_putchar library offered in the RKit-ARM, which should be next week.
Best Regards,
Hi!
Thank you Bruno for your help!
I succeed to write "HelloWorld" on my hyperterminal, your code helped me to understand many things and to check my RS232 connexion (about hardware and configurations).
It is possible that I need your knows soon ;)