Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

SPI0 & SPI1 vs SPI0 only #12

Open
jroever opened this issue Sep 23, 2019 · 2 comments
Open

SPI0 & SPI1 vs SPI0 only #12

jroever opened this issue Sep 23, 2019 · 2 comments

Comments

@jroever
Copy link

jroever commented Sep 23, 2019

I was having problems with my RBPi 3 B+ / running Linux Kernel 4.19.57-v7+ while trying to get both eyes to work reliable with the arduino IPS TFT 240x240 panel. Left eye (SPI0.0) was fine, but right eye (SPI1.2) would only work with frequency dropped to 10MHz vs suggested 96MHz.
After doing some research I found that at least for bcm2835 only SPI0 has DMA support and a larger FIFO, while SPI1 and 2 can only support lower speeds due to lack of DMA and smaller FIFO size. I couldn't find any supporting info that SPI1 would have a larger FIFO or DMA on bcm2837 (PI3 and beyond) so I changed my setup to use SPI0 for both left and right eye using two channel selects - the problem with the right eye went away and I am able to run at 30+ fps with 96MHz spi frequency... only change needed to the fbx2.c was to change spi1.2 to spi0.1 and wire my eyes accordingly.
My questions now:

  1. with other linux kernels, could SPI1 actually reach 96MHz? If yes, would this be at the expense of higher processor utilization in case SPI1 fifo has to be serviced more often or does RBPi3 and above have large FIFOs and DMA on SPI1 & 2 as well?
  2. regardless of the above - would it make sense to switch to single SPI in order to share resources and reduce wiring - or did anybody reach significantly more than 30fps on RBPi3 using the dual SPI approach?
@gurahamu
Copy link

gurahamu commented Sep 27, 2019

I also have the same setup by the sounds of it, and the 'right' eye screen (same IPS 240x240) is blank but backlit and obviously getting a signal. I spent an hour with a multimeter thinking it was my soldering, but they checked out fine.

I was going to try https://learn.adafruit.com/animated-snake-eyes-bonnet-for-raspberry-pi/software-installation ... from "If the eyes are experiencing glitches (video snow, tearing, dropped frames or weird inverted colors), here’s what to do…" , then would try yours above, but what wiring change did you make?

@gurahamu
Copy link

As follow-up; in my situation, the bitrate drop to even 4,000,000 didnt result in an image on the right screen (left was still fine) - or at 8M or 10M. (Also, as new person to this kind of work, not sure why a bitrate is measures in MHz here?)

I think my next option is to try to hook them up to the single SPI and use channel select as suggested. Bit mystified as to why this wouldnt work on my set up.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants