IMX8ULP : Hardware acceleration with EPDC display

取消
显示结果 
显示  仅  | 搜索替代 
您的意思是: 

IMX8ULP : Hardware acceleration with EPDC display

1,547 次查看
Bhavin-Sharma
Contributor III

Hello,

I am working with an EPDC display interfaced to IMX8ULP. The driver for EPDC display is based on FBDEV. As FBDEV supports software rendering only, it loads up CPU beyond 100% at the moment. I have below queries regarding support of EPDC display:

1. Does EPDC only has support for FBDEV? Is there any driver or patch leveraging DRM for EPDC? As with DRM we can use GLES for hardware acceleration.
2. With FBDEV, can I, somehow, still use any kind of hardware rendering?
3. What would be the best way to not let CPU load up while rendering with FBDEV for EPDC display?

Regards,
Bhavin

#IMX8ULP

0 项奖励
回复
18 回复数

1,022 次查看
Chong
NXP Employee
NXP Employee

Hi @Bhavin-Sharma ,

 

Could you please contact your local NXP FAE so that we can provide more assistance?

Best regards,
Chong

0 项奖励
回复

1,517 次查看
Chong
NXP Employee
NXP Employee

Hi @Bhavin-Sharma ,

1. Does EPDC only has support for FBDEV?

We only provide EPDC driver based on FBdev. But you can also refer to some third-party DRM porting. Keep FBdev because it has better performance on EPD for DRM. You just need to mark the rendered memory as Framebuffer and submit it for upload. Which display framework(QT/LVGL/wayland) is your UI using? You can contact your FAE for more support. 

2. With FBDEV, can I, somehow, still use any kind of hardware rendering?

You can use GPU and PXP to accelerate the program. Just point the rendered memory to the framebuffer and submit the EPDC update.

3. What would be the best way to not let CPU load up while rendering with FBDEV for EPDC display?
There are many hardware modules for EPD rendering in imx8ulp. You can describe the specific functions you have implemented, or provide us with a test program, and we can help you achieve better performance in imx8ulp.

Best regards,
Chong

0 项奖励
回复

1,511 次查看
Bhavin-Sharma
Contributor III

Hi @Chong,

 

The framework that I am using is LVGL for UI implementation. So far I have developed for HDMI display to observe performance over FBDEV. I am yet to migrate the application for EPDC display and it may take a couple of days. I will post it here once I test something with the display.

 

I believe LVGL does support rendering using PXP but for specific platforms only. Is it true? 

 

Regards,

Bhavin

0 项奖励
回复

1,504 次查看
Chong
NXP Employee
NXP Employee

Hi @Bhavin-Sharma ,

Indeed, we have not published examples of GPU/PXP accelerated rendering for LVGL on imx8ulp. However, 2D GPU and PXP can be accelerated in LVGL programs. We can implement this function through patching. Which LVGL version are you using? If you can provide a simple test program, we can help you improve the performance of imx8ulp.

Best regards,
Chong 


0 项奖励
回复

1,492 次查看
Bhavin-Sharma
Contributor III

Thanks for the prompt response, @Chong 

For my UI development I am using the GUI-guider tool supported by NXP itself, and the LVGL version is 9.2. 

At the moment I can't share any code as the application is proprietary and the simple test application won't have that much of CPU load. 

Can you provide an example application, using PXP and GPU for rendering and offloading CPU?

Regards,

Bhavin

0 项奖励
回复

1,331 次查看
Bhavin-Sharma
Contributor III

Hi,

@Chong, I’m still working on the same issue and haven’t found a workaround yet. Could you please help me out?

0 项奖励
回复

1,325 次查看
Chong
NXP Employee
NXP Employee

Hi @Bhavin-Sharma ,

Sorry I missed the message. I can continue to help.

I can try to provide a simple demo based on LVGL and using G2D acceleration. What transformations (rotation/scaling/resize) are used in your application, or are there any special animation effects?

Best regards,
Chong

0 项奖励
回复

1,322 次查看
Bhavin-Sharma
Contributor III

I am not working with animations at the moment, just trying to render multiple images on the display, zoom-in and out. But it would be helpful if animations like rendering a 3D object as done in glmark2-es2 utilities could be tested.

 

Regards,

Bhavin

0 项奖励
回复

1,316 次查看
Chong
NXP Employee
NXP Employee

Hi @Bhavin-Sharma ,

The attached demo enables g2d and can reduce CPU loading.  You can get more information by visiting imx-LVGL-G2D-enablement , but please note that this patch only works on LVGL version 8.x. G2D is enabled by default in LVGL 9.3(Check here). It applies for imx8ulp. It requires some porting knowledge to FBdev for EPD panel.
We haven‘t tested the complex animations(like rendering a 3D object).  If you need, we hope you can provide a specific test and we can help you optimize it.

Best regards,
Chong

0 项奖励
回复

1,279 次查看
Bhavin-Sharma
Contributor III

Thanks for the patch @Chong.

 

I am on leave for this week so I won't be able to test it at the moment. Will surely post an update once I have.

 

Regards,

Bhavin

0 项奖励
回复

1,534 次查看
Bio_TICFSL
NXP TechSupport
NXP TechSupport

Hello,

A1) No it support DRM and yes it is accelerated with the GPU.

A2) Sorry no, it should be pure software

A3) Just disable the GPU and all render will be via software.

 

Here are how to connect the EPDC in case of iMX8ULP:

https://docs.nxp.com/bundle/MCIMX8ULP-EVK-UM/page/topics/electrophoretic_display_interface.html

 

Regards

0 项奖励
回复

1,523 次查看
Bhavin-Sharma
Contributor III

Thanks for the reply, @Bio_TICFSL.

 

A1) No it support DRM and yes it is accelerated with the GPU.

I am working with YOCTO (Walnascar) setup for IMX8ULP. It has kernel 6.12. I have had a look through it, and I have not been able to find any driver for EPDC supporting DRM.

 

Is it supported in some other kernel version? Can you help with the steps to enable the DRM support for EPDC?

 

Regards,
Bhavin

0 项奖励
回复

1,307 次查看
Bio_TICFSL
NXP TechSupport
NXP TechSupport

Hello,

The yocto from NXP support DRM on EPDC but you are using community BSP since we support yocto Styhead in 6.12v please update your yocto.

Regards

0 项奖励
回复

1,222 次查看
Bhavin-Sharma
Contributor III

Hi @Bio_TICFSL,

 

I switched to the yocto-styhead branch and I checked in the kernel (6.12.3) source, it also has the support for the EPDC display over FBDEV only.

Can you please validate this once and provide the link of the yocto branch that has this support?

 

Regards,

Bhavin

0 项奖励
回复

1,199 次查看
Bio_TICFSL
NXP TechSupport
NXP TechSupport

Hello,

In NXP bsp 6.12.20 yes it works.

Regards

0 项奖励
回复

1,176 次查看
Bhavin-Sharma
Contributor III

I validated the source that I am cloning for my BSP setup, and it is the official NXP GitHub repo. Also, the styhead branch only has support for the 6.12.3 kernel, while 6.12.20 is provided within walnascar.

 

I have tried with both these branches, and none of them has the support of DRM for EPDC display. Can you provide any link or source that supports it?

 

Regards,

Bhavin

0 项奖励
回复

1,169 次查看
Bio_TICFSL
NXP TechSupport
NXP TechSupport

Hello,

Yes both supported, please check the release note of iMX linux

https://www.nxp.com/docs/en/release-note/RN00210.pdf

Regards

 

0 项奖励
回复

1,059 次查看
Bhavin-Sharma
Contributor III

I referred to the attached link, but I could not find any statement related to the use of DRM with the EPDC display.

Could you please share the exact section or statement from the PDF link that you have shared which confirms the support of it?

 

Thanks for your support.

0 项奖励
回复