Arm Community
Site
Search
User
Site
Search
User
Groups
Education Hub
Arm Ambassadors
Open Source Software and Platforms
Research Collaboration and Enablement
Forums
AI and ML forum
Architectures and Processors forum
Arm Development Platforms forum
Arm Development Studio forum
Arm Virtual Hardware forum
Automotive forum
Compilers and Libraries forum
Graphics, Gaming, and VR forum
High Performance Computing (HPC) forum
Infrastructure Solutions forum
Internet of Things (IoT) forum
Keil forum
Morello forum
Operating Systems forum
SoC Design and Simulation forum
SystemReady Forum
Blogs
AI and ML blog
Announcements
Architectures and Processors blog
Automotive blog
Graphics, Gaming, and VR blog
High Performance Computing (HPC) blog
Infrastructure Solutions blog
Internet of Things (IoT) blog
Operating Systems blog
SoC Design and Simulation blog
Tools, Software and IDEs blog
Support
Arm Support Services
Documentation
Downloads
Training
Arm Approved program
Arm Design Reviews
Community Help
More
Cancel
Support forums
Graphics, Gaming, and VR forum
DirectFB Support
Jump...
Cancel
Locked
Locked
Replies
3 replies
Subscribers
136 subscribers
Views
6115 views
Users
0 members are here
Mali-VE6
NEON
Mali-GPU
Mali-400
Options
Share
More actions
Cancel
Related
How was your experience today?
This discussion has been locked.
You can no longer post new replies to this discussion. If you have a question you can start a new discussion
DirectFB Support
Gonzalo Brusco
over 11 years ago
Note: This was originally posted on 1st December 2011 at
http://forums.arm.com
Hello.
I am not an expert on this field but I'm doing my best to learn about it. I have several questions regarding the ARM Mali 400 GPU, the Mali-VE6 and the NEON coprocessor.
I need to develop a SoC using an ARM processor (could be the A8 or the A9) and I need to comply with some software requirements. The most important one is DirectFB support.
I was wondering if the Mali 400 offers DirectFB HW acceleration. If not, do you know if the DirectFB library works without HW acceleration?
Also, I have a very basic question regaring how the Mali 400 and the Mali-VE6 work together. Suppose I am decoding a H264 video using the Mali-VE6 and at the same time I'm rendering some openGL stuff using the Mali 400 GPU. If I want to see the combined result of this processes on the same screen, how I am supposed to combine this inside the SoC. What kind of HW do I need for that?
Thank you in advance.
Gonzalo.
P.S: If you have any reference to keep reading about this subjet (graphics architecture on SoCs - specially ARM) I would really appreciate it.
Parents
Pete
over 11 years ago
Note: This was originally posted on 2nd December 2011 at
http://forums.arm.com
Hi,
for the question about how to combine video and 3D graphics, one solution I have seen is to have 2 framebuffers (e.g. /dev/fb0 and /dev/fb1 on Linux).
The Mali-VE6 video decode hardware can decode video into one framebuffer (e.g. fb0). The Mali-400 can request a drawing surface which includes an alpha channel (e.g. RGBA8888) and draw this output into the 2nd framebuffer (e.g. fb1).
Then, a hardware overlay mixer can read the color channel of the video (fb0), the color channel of the 3D (fb1) and determine how transparent or opaque to make the 3D by checking the 3D alpha channel, then blend the two color channels together as appropriate.
In this way you can overlay a 3D user interface over the video, letting the 3D application choose how translucent to be over the video.
If you search for terms such as the ones below I think you should find more reading material on the subject:
hardware overlay mixer raster operation alpha blending
Hope this helps, Pete
Cancel
Up
0
Down
Cancel
Reply
Pete
over 11 years ago
Note: This was originally posted on 2nd December 2011 at
http://forums.arm.com
Hi,
for the question about how to combine video and 3D graphics, one solution I have seen is to have 2 framebuffers (e.g. /dev/fb0 and /dev/fb1 on Linux).
The Mali-VE6 video decode hardware can decode video into one framebuffer (e.g. fb0). The Mali-400 can request a drawing surface which includes an alpha channel (e.g. RGBA8888) and draw this output into the 2nd framebuffer (e.g. fb1).
Then, a hardware overlay mixer can read the color channel of the video (fb0), the color channel of the 3D (fb1) and determine how transparent or opaque to make the 3D by checking the 3D alpha channel, then blend the two color channels together as appropriate.
In this way you can overlay a 3D user interface over the video, letting the 3D application choose how translucent to be over the video.
If you search for terms such as the ones below I think you should find more reading material on the subject:
hardware overlay mixer raster operation alpha blending
Hope this helps, Pete
Cancel
Up
0
Down
Cancel
Children
No data