cancel
Showing results for 
Search instead for 
Did you mean: 

How to test STM32 MCU SPI communication using Host PC ?

ercjethava1992
Associate

I am using this dev board: NUCLEO-F411RE for developing SPI communication protocol considering it as a SLAVE device. My firmware will receive data over SPI sent by Host machine and acts on it.

I have following requirement:


How to transmit data packets via host PC to MCU using SPI to test whether my firmware working correctly or not ?

Option A: To use Raspberry Pi as a Host machine device and send data over SPI to MCU :
-> This one so far seems best option for me as I can easily write test python application using open source spidev package python-spidev and easily connect Raspberry Pi and NUCLEO board as both supports SPI interface.

Option B : I have also found this USB-SPI-bridge converter to directly connect Host PC (Windows, Linux) to Nucleo-Board based on SPI interface 
pdf: FTDI-MULTI-SLAVE

Also found this Adafruit-FT232H for same USB-to-SPI bridge converter

Is thee any other similar dongle available which are cost effective and easy to use ?

Can anyone suggest which one is the best options to achieve this communication setup for testing SPI communication between Host Machine and MCU ?

6 REPLIES 6
Karl Yamashita
Lead III

You can always connect a 2nd SPI bus on the same Nucleo board as a master to your slave SPI bus. Use the VCP to receive some data and pass that data over the master SPI. Then you can see if your slave SPI works correctly.

Tips and Tricks with TimerCallback https://www.youtube.com/@eebykarl
If you find my solution useful, please click the Accept as Solution so others see the solution.

Yes, you would need a SPI Master which you can control from PC host (e.g. Windows OS, Linux OS, ....).
Yes, Raspberry would be a good option: with the Python library it should be possible.

Yes, there are also boards (and chips) for SPI, e.g. FTDI, Silicon Labs, even Aardvark (TotalPhase).

It should work (we use TotalPhase very often, sometimes also FTDI).
Just to make sure to configure properly:

  • the nCS (nSS) polarity (default is active low)
  • and the SPI mode (0...3, often 0 or 3 used)
  • the SPI bitrate depends on your setup (e.g. cable length)\

Where is your problem?

Sure, you can also configure another SPI as Master on MCU and try a "loopback" test (to make sure your SPI Slave implementation works).
If you ask about how to implement a SPI Master on PC side (Windows or Linux OS) - yes, some solutions there as you have mentioned. FTDI and TotalPhase are good options (and coming with C/Python sample code).
You can also create a second MCU with FW running as "UART over USB" and acting as a SPI Master: connect both SPIs and let receive what you send. 

Techn
Senior III

Looks like you are trying to simulate spi master. Your selection depends on the maximum clock rate, voltage levels etc. Lowest possible expensive solution would be esp32 using arduino or Raspberri pico board. Both are easy to be set-up and you can make changes and update easily. 

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

@ercjethava1992 wrote:

Is there any other similar dongle available which are cost effective and easy to use ?


I don't think you're going to find anything more cost effective than a simple FTDI chip!

eg, Total Phase have a great range of products, but they are orders of magnitude more expensive:

https://www.totalphase.com/protocols/spi/

 

As @Karl Yamashita said, you could use another SPI port on the same microcontroller.

You could also use another, separate microcontroller - it needn't be an STM32; eg, an Arduino...

 


@ercjethava1992 wrote:

setup for testing SPI communication between Host Machine and MCU ?


The key thing you'll need is something to enable you to see what's happening on the wires - an oscilloscope and/or a logic analyser.

Without that, you're in the dark!

Low-cost (~$10) logic analysers are widely available on the likes of Amazon, ebay, et al ...

 

PS:

Don't make the classic mistake of trying to do both ends of the link at once!

Otherwise you're just testing your unproven slave against an unproven master:

https://community.st.com/t5/stm32-mcus-products/two-nucleo-boards-stm32f446re-and-stm32h723zg-communicate/m-p/737695/highlight/true#M264992

 

I suggest that you start by getting your Host/Master to work with some well-known standard slaves:

https://community.st.com/t5/automotive-mcus/seeking-guidance-establishing-spi-communication-between/m-p/661736/highlight/true#M6318

 

ercjethava1992
Associate

@Andrew Neil @tjaekel 
Have further question based on considering Raspberry Pi(As Master SPI) for testing MCU SPI SLAVE  firmware which I am developing

MCU board : (SLAVE)
https://www.st.com/en/evaluation-tools/nucleo-f411re.html

 Q.1. where I can find SPI pins voltage ratings for MCU used in this board which is :STM32F411RE 
to determine whether level shifter required or not to connect SPI pins between RaspberryPi and MCU 

Raspberry Pi:(MASTER) https://www.sparkfun.com/products/15446?src=raspberrypi
SPI: https://www.raspberrypi.com/documentation/computers/raspberry-pi.html#spi-overview
GPIO voltage ratings on Raspberry Pi: (3.3V)
https://www.raspberrypi.com/documentation/computers/raspberry-pi.html#outputs  

From MCU datasheet I found following Speed supported by SPI:
stm32f411re-datasheet 

Q2. Description mentioned into section 3.23 and Table-60,  I am confused about actual Speed Supported by SPI in slave mode :
What is difference between Slave Mode vs Slave Full duplex Mode ? as both defined with different Clock rate as 25Mhz vs 38 MHz
Then I cant use  Master supported Max SPI clock settings if slave doesn't support it and have to use same clock setting as supported by Slave Am I correct ?

SPI.png

SPI interface characteristics:
SPI-CLOCK.png



@ercjethava1992 wrote:

 Q.1. where I can find SPI pins voltage ratings for MCU 


That will be in the MCU's datasheet