Jump to content

optimizing gdisp_lld_ILI9341 for STM32 SPI DMA


Recommended Posts

Posted

I tried uGfx but its to slow. I started to optimize the ili9341 lld. i switched spi to 16bit, wrote functions for Hardware clear, fill & bitfills with DMA. Speed is fine now.

Had a hard time to initialize the lcd with 16bit spi. Now i init the lcd with 8bit spi and switch to 16bit after init is done.

Now i want to try to read back from display, how can i test? What else could be done to speed things up?

Thanks for your uGFX.

Posted

I can read from the display, AA is working fine. Reading requires 3x8bit transfer per pixel. This is weired because when you write you need to write 16bit per pixel.

Reading happends in the slowest possible way. Pixel by pixel using gdisp_lld_get_pixel_color.

gdisp_lld_read_start, gdisp_lld_read_color and gdisp_lld_read_stop is never been used.  Is this to be expected? I have GDISP_HARDWARE_STREAM_READ defined TRUE.

How to use streaming for reading ?

 

I will try to change the setting for the ILI (RIM).

Quote

RIM: Specify the RGB interface mode when the RGB interface is used.

Quote

1  101 (65K color)  6- bit RGB interface (3 transfer/pixel)

Quote

0  101 (65K color)  16- bit RGB interface (1 transfer/pixel)

 

  • 2 weeks later...
  • 6 years later...
Posted

Hello!

Sorry for using an old thread, but I'm running into the same performance issue as M3Michi.

I would like to use SPI DMA in my project with STM32F4 and 
ili9341. I can imagine the architecture of the solution, but having an example of implementation from M3Michi I would do it much faster.
Could you please update the link to M3Michi's project or publish his implementation of the "gdisp_lld_ILI9341" driver?
I sure this example would be very useful for everyone who want to use combination of DMA and ili9341 in STM32.

Thanks for your uGFX!

Posted

Hello & Welcome to the µGFX community!

 

On 12/12/2024 at 10:10, VsTimf said:

Could you please update the link to M3Michi's project or publish his implementation of the "gdisp_lld_ILI9341" driver?

Have you checked out the attached archive in @M3Michi 's last post?

  • 4 weeks later...
Posted

FYI: AA by using readback works, but will always suffer a performance penalty on SPI displays.

This is because:
1. Readback adds much overhead on the SPI bus.
2. The ILI9341 display only supports SPI at max 6MHz for reading, but 10MHz for writing.

You get the best font rendering performance on this display if you use gdispGFillString() or gdispGFillStringBox() to write both the background color and the text in one go, avoiding the need for readback.

Particularly if you also use this patch which speeds up FillString font rendering by an additional 25%:

 

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now
×
×
  • Create New...