diff options
author | Zhigang Gong <zhigang.gong@linux.intel.com> | 2012-02-17 19:50:51 +0800 |
---|---|---|
committer | Chris Wilson <chris@chris-wilson.co.uk> | 2012-02-21 08:42:12 +0000 |
commit | 1e0d702c3a77f6db3dfd55b8cafc5fca4d778751 (patch) | |
tree | 85c057ffeb6cc33cd14a6e5895d102016bf74ac6 /src/intel_glamor.c | |
parent | ce7a57994d662f340b9457a2750e4385e7d669cd (diff) |
uxa/glamor/dri: Enable the pageflip support on glamor.
To support easy buffer exchange at glamor layer, glamor
added a new API glamor_egl_exchange_buffers() to exchange
two pixmaps' EGL image and fbos and textures without
recreating any of them. But this simple method's requirement
is that there are two pixmaps. A exceptional case is:
If we are using triple buffer when do page flipping, we
will have an extra back_buffer which doesn't have a pixmap
attached to it. Then each time we set that buffer to a
pixmap, we will have to call the create_egl_textured_pixmap
to create the corresponding EGL image and fbo and texture
for it. This is not efficient.
To fix this issue, this commit introduces a new back_pixmap
to intel structure to hold the back buffer and corresponding
glamor resources. Then we will just need to do the light
weight buffer exchanging at both DDX and glamor layer.
As the new back pixmap is similar to the screen pixmap
and need to be handled carefully when close screen. As the
glamor data structure is a per screen data, and will be
released at its close screen method. The glamor's close
screen method must cleanup the screen pixmap and back
pixmap's glamor resources. screen pixmap is easy to get,
but there is no good way to store the back pixmap.
So the glamor add a new API glamor_egl_create_textured_screen_ext
function to pass the back pixmap's pointer to glamor layer.
This commit make us depend on glamor commit: 4e58c4f.
And we increased the required glamor version from 0.3.0 to 0.3.1
Signed-off-by: Zhigang Gong <zhigang.gong@linux.intel.com>
Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
Diffstat (limited to 'src/intel_glamor.c')
-rw-r--r-- | src/intel_glamor.c | 19 |
1 files changed, 15 insertions, 4 deletions
diff --git a/src/intel_glamor.c b/src/intel_glamor.c index c468d34f..a8681575 100644 --- a/src/intel_glamor.c +++ b/src/intel_glamor.c @@ -40,6 +40,16 @@ #include "intel_glamor.h" #include "uxa.h" +void +intel_glamor_exchange_buffers(struct intel_screen_private *intel, + PixmapPtr src, + PixmapPtr dst) +{ + if (!(intel->uxa_flags & UXA_USE_GLAMOR)) + return; + glamor_egl_exchange_buffers(src, dst); +} + Bool intel_glamor_create_screen_resources(ScreenPtr screen) { @@ -52,9 +62,10 @@ intel_glamor_create_screen_resources(ScreenPtr screen) if (!glamor_glyphs_init(screen)) return FALSE; - if (!glamor_egl_create_textured_screen(screen, - intel->front_buffer->handle, - intel->front_pitch)) + if (!glamor_egl_create_textured_screen_ext(screen, + intel->front_buffer->handle, + intel->front_pitch, + &intel->back_pixmap)) return FALSE; return TRUE; @@ -70,7 +81,7 @@ intel_glamor_pre_init(ScrnInfoPtr scrn) /* Load glamor module */ if ((glamor_module = xf86LoadSubModule(scrn, GLAMOR_EGL_MODULE_NAME))) { version = xf86GetModuleVersion(glamor_module); - if (version < MODULE_VERSION_NUMERIC(0,3,0)) { + if (version < MODULE_VERSION_NUMERIC(0,3,1)) { xf86DrvMsg(scrn->scrnIndex, X_ERROR, "Incompatible glamor version, required >= 0.3.0.\n"); } else { |