2018-09-06 01:50 AM
Hello!
I'm experiencing difficulties using STM32-MAT-TARGET to generate code for STM32 controllers from Simulink models using the provided blocks for USART communication.
I'm using this setup:
The following pictures show my Simulink model:
Unfortunately, the program only does half the job. I observe that only one USART is actually receiving anything. The other just doesn't respond when I send it a byte. Either USART works if I have just one of them in my model. But with both USARTS in my model, one will work, the other won't. It seems to be whichever USART happens to get put into receptin mode first, will be the one that's working.
Can anyone help me with a solution to this problem? Is my setup correct? Does STM32-MAT-TARGET support this kind of operation?
Best regards
Roman
2018-09-06 02:40 AM
there must be a selection for using DMA circular buffer .
that is the most robust method for Uarts Rx.
did you use the cube ?
2018-09-06 02:56 AM
I enable the circular Rx
void initUart1RxDMABuffer(void) {
if (HAL_UART_Receive_DMA(&huart2, (uint8_t *)Usart1RxDMABuffer, U1RxBufSize) != HAL_OK)
{
// Transfer error in reception process
//_Error_Handler(__FILE__, __LINE__);
//char string[32];
sprintf(string, "initUart1RxDMABuffer Failed\n");
puts1(string);
}
else
{
//char string[32];
sprintf(string, "initUart1RxDMABuffer OK!\n");
puts1(string);
}
}
DMA and the Rx interrupts, in the cube
2018-09-06 03:05 AM
I have to use Cube configuration and then use the code generation from within Simulink. The process is automatic and I cannot edit the code manually.
2018-09-06 03:12 AM
in the cube, add the 'circular' DMA function to Rx and enable the Uart Rx Interrupt
I use a 'normal' DMA buffer for Tx.
2018-09-06 03:21 AM
Thank you for the suggestion. I tried it with DMA mode.
This time I get no response at all.
2018-09-06 03:42 AM
not sure if it will help but you don't need high priority interrupts for serial ports.
you did make sure the Uart interrupt was left enabled ?
then I run this code to make it work:
void initUart1RxDMABuffer(void) {
if (HAL_UART_Receive_DMA(&huart7, (uint8_t *)Usart1RxDMABuffer, U1RxBufSize) != HAL_OK)
{
// Transfer error in reception process
//_Error_Handler(__FILE__, __LINE__);
sprintf(string, "initUart1RxDMABuffer Failed\n");
puts1(string);
}
else
{
//char string[32];
sprintf(string, "initUart1RxDMABuffer OK!\n");
puts1(string);
}
}
did you look in the DMA buffer ?
int U1RxBufferPtrOUT =0;
char readableU1(void) {
U1RxBufferPtrIN = U1RxBufSize - __HAL_DMA_GET_COUNTER(huart7.hdmarx);
return U1RxBufferPtrIN - U1RxBufferPtrOUT;
}
2018-09-06 03:53 AM
I tried it again with low priority for the DMA channels. That didn't make a difference.
I checked and verified that the UART interrupt is enabled.
I'm generating code with Simulink (slbuild) and compile it with gmake. It's an automated process. I don't know how to use the code you show with that. I cannot debug that code.
Should I post the code that Simulink generated?
2018-09-06 04:26 AM
If you couldn't run the init code, the DMAs are not running.
So turn off the DMAs, are you getting the interrupts ?
save the U1 byte in a U1 buffer under interrupt.
save the U6 byte in a U6 buffer under interrupt.
I'm not sure if anyone here can support Simulink, do they have a forum ?
can you let us know the fix ?
2018-09-06 04:51 AM
I discovered something new:
I use this minimal example for testing purposes:
This generally works. Though it doesn't work anymore when I enable the USART1 (the other USART I enabled in Cube but do not use here) interrupt.
So the issue is having two USART interrupts enabled at the same time.