cancel
Showing results for 
Search instead for 
Did you mean: 

STM32H745 SPI Cores communicating

__silardg
Associate III

Hi!
I'm using STM32H745 dual core. The reason behind it is as I have to do very fast measurement on one core (M7) and the rest of the slower things on the M4. The M4 is mostly used for communicating with the external world. 

I have setup SPI3 and SPI4. SPI3 is on the M7 and the SPI4 is on the M4. 

SPI3 is the slave. SPI4 is the master. 

I have used this example to get the cores to communicate, which works!

What I'm trying to achieve is for the M4 (master) to use the transmitreceive function (it can be in any mode - polling, it or dma) to send config data and receive measurement data from the M7. For now I can use the given example. 

What I'm trying to do is to move the SPI receiving, packing the data and sending it back to the master in an interrupt routine on the M7. Is that possible to do? Or is it done by setting a flag and computing it in the main while loop? 

Thanks!

1 ACCEPTED SOLUTION

Accepted Solutions
13 REPLIES 13
SofLit
ST Employee

Hello,

Note: it's not recommended to handle a huge calculation in an interrupt routine. Better to handle that in the main loop.

To give better visibility on the answered topics, please click on "Accept as Solution" on the reply which solved your issue or answered your question.
PS: This is a collaborative space. So please be polite in your reply. Otherwise, it will be reported as inappropriate and you will be permanently blacklisted from my help/support.

To clarify. I'm doing sampling and calculations in the main loop. 

In the interrupt routine I would just pack the already calculated data into a buffer that I would send out to the SPI master. Masking bits and simple operations like that. Basically I just want to send data out when I get a message from the master. 

You need to stay at the interrupt handler less time as possible. This is the recommendation.

Pack/Unpack data could be influenced by the length of the data. More you have data to tranceive more you're blocking the interrupt.

To give better visibility on the answered topics, please click on "Accept as Solution" on the reply which solved your issue or answered your question.
PS: This is a collaborative space. So please be polite in your reply. Otherwise, it will be reported as inappropriate and you will be permanently blacklisted from my help/support.

Okay, then what is the recommended setup for this? 
If I do DMA and in the RX callback I set a flag, which will be read by the while loop, process the data and send back spi data? Is that the way this is done or? 

SofLit
ST Employee

In my opinion yes .. and manage this in a ring in order to keep a correct synchronization and coherent tranceived data ..

To give better visibility on the answered topics, please click on "Accept as Solution" on the reply which solved your issue or answered your question.
PS: This is a collaborative space. So please be polite in your reply. Otherwise, it will be reported as inappropriate and you will be permanently blacklisted from my help/support.

Is this example as a good follow up? 
I guess the changes I have to make is to the slave, where it will do the above with the rx callback and flag setting.

__silardg
Associate III
HAL_SPI_Receive_DMA(&hspi3, aRxBuffer, BUFFERSIZE);

	/* USER CODE END 2 */

	/* Infinite loop */
	/* USER CODE BEGIN WHILE */
	while (1) {

		HAL_GPIO_TogglePin(GPIOC, GPIO_PIN_13);
		if(flagz == 1) {
			HAL_Delay(10); // simulating some processing
			flagz = 0;
			HAL_SPI_Transmit_DMA(&hspi3, aTxBuffer, BUFFERSIZE);

		}

	}

The flag is being set by the Receive DMA

void HAL_SPI_RxCpltCallback(SPI_HandleTypeDef * hspi)
{
    // RX Done .. Do Something ...
	if(hspi->Instance == SPI3) {
		flagz = 1;
	}
}

But the DMA transmit is not sending anything... 

__silardg_0-1707757571055.png

 

__silardg
Associate III

I figured out that if I put a 

while(hspi3.State != HAL_SPI_STATE_READY) {}

before the DMA transmission, it stays there and it blocks it. Why can this happen? 

const uint8_t aTxBuffer[] = "****SPI - Two Boards communication based on IT **** SPI Message ********* SPI Message *********";
#define BUFFER_ALIGNED_SIZE (((BUFFERSIZE+31)/32)*32)
//ALIGN_32BYTES(uint8_t aRxBuffer[BUFFER_ALIGNED_SIZE]);
uint8_t aRxBuffer[BUFFERSIZE];

I'm doing receive like this

HAL_SPI_Receive_DMA(&hspi3, aRxBuffer, BUFFERSIZE);

 

TDK
Guru

Let's change the approach:

If you want to share data between two cores, dedicate a section of AXI SRAM as shared memory and have one core write it and the other read. This will be hundreds of times faster than sending/receiving over SPI and will be easier to code.

If you feel a post has answered your question, please click "Accept as Solution".