Arm Community
Site
Search
User
Site
Search
User
Support forums
Mobile, Graphics, and Gaming forum
eglCopyBuffers() issue.
Jump...
Cancel
Locked
Locked
Replies
3 replies
Subscribers
137 subscribers
Views
6581 views
Users
0 members are here
Mali Drivers
OpenGL ES
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
eglCopyBuffers() issue.
Gaetano Montalti
over 12 years ago
Note: This was originally posted on 4th June 2012 at
http://forums.arm.com
[font=arial][size=2]Hi,[/size][/font][font=arial][size=2]In my project I am using egl library to plot a 3D object to the display and concurrently saving the image in a file or an area of memory.[/size][/font][font=arial][size=2]I'm trying to use eglCopyBuffers() to copy a surface to a pixmap in order to obtain the pixel value that are displayed. I'm using an ARM MALI architecture and I would not want to use X11 but writing directly to GNU/Linux framebuffer.[/size][/font][font=arial][size=2]I have few questions:[/size][/font][font=arial][size=2]
[/size][/font][font=arial][size=2]1)In my method, I pass to eglCopyBuffers function, as 'native_pixmap' parameter, an 'EGLNativePixmapType native_pixmap= NULL'. Is it correct? How should I declare the pixmap if I do not want to use X11 libraries?[/size][/font][font=arial][size=2]In addition, if I do as above, eglCopyBuffers returns an EGL_FALSE error, which means that the swapping of the surface buffers fails. [/size][/font][font=arial][size=2]
[/size][/font][font=arial][size=2]2) Is there another simpler method to obtain the image displayed in framebuffer? Should I directly read data from /dev/fb0? I read about the method glReadPixel but it is described as being slow and X11 dependent.[/size][/font][font=arial][size=2]
[/size][/font][font=arial][size=2]
[/size][/font][font=arial][size=2]Thank you in advance for your advice.[/size][/font][font=arial][size=2]
[/size][/font][font=arial][size=2]Kind Regards,[/size][/font][font=arial][size=2]Gaetano[/size][/font]
Parents
Pete
over 12 years ago
Note: This was originally posted on 6th June 2012 at
http://forums.arm.com
Hi,
yes it should be possible. Instead of the X window Pixmap, you need to pass in a Pixmap structure appropriate for a bare framebuffer. Actually, there is no defined Pixmap structure for bare framebuffer, so Mali uses a simple structure you can create yourself, which holds all the necessary information (start memory address, width, height, color format, etc.).
You should be able to find this structure defined in the EGL header files you received with your Mali drivers, in a file named:
EGL/fbdev_window.h
You can then allocate an fbdev_pixmap structure, fill it out to point at some memory you have allocated (possibly with the Unified Memory Provider, UMP) and pass this structure to eglCreatePixmapSurface().
In your situation, I would consider whether it may be too hard to synchronise with GLES when to read /dev/fb0. It may be easier to render to a Pixmap surface, then fwrite() that to disk (or whatever) and also BLock Image Transfer (BLIT) the Pixmap to /dev/fb0 yourself in order to show it on the screen.
In this way, you won't need to use eglCopyBuffers() or glReadPixels().
HTH, Pete
Cancel
Vote up
0
Vote down
Cancel
Reply
Pete
over 12 years ago
Note: This was originally posted on 6th June 2012 at
http://forums.arm.com
Hi,
yes it should be possible. Instead of the X window Pixmap, you need to pass in a Pixmap structure appropriate for a bare framebuffer. Actually, there is no defined Pixmap structure for bare framebuffer, so Mali uses a simple structure you can create yourself, which holds all the necessary information (start memory address, width, height, color format, etc.).
You should be able to find this structure defined in the EGL header files you received with your Mali drivers, in a file named:
EGL/fbdev_window.h
You can then allocate an fbdev_pixmap structure, fill it out to point at some memory you have allocated (possibly with the Unified Memory Provider, UMP) and pass this structure to eglCreatePixmapSurface().
In your situation, I would consider whether it may be too hard to synchronise with GLES when to read /dev/fb0. It may be easier to render to a Pixmap surface, then fwrite() that to disk (or whatever) and also BLock Image Transfer (BLIT) the Pixmap to /dev/fb0 yourself in order to show it on the screen.
In this way, you won't need to use eglCopyBuffers() or glReadPixels().
HTH, Pete
Cancel
Vote up
0
Vote down
Cancel
Children
No data