Add a hack to make it work with XGL.

svn path=/trunk/KDE/kdebase/workspace/; revision=677300
This commit is contained in:
Luboš Luňák 2007-06-18 21:14:18 +00:00
parent 27f67f3428
commit 4040e9be58
2 changed files with 18 additions and 15 deletions

View file

@ -85,20 +85,19 @@ OpenGL TODO
/ Check/make it work with other gfx cards / Check/make it work with other gfx cards
? Xgl support % Xgl support
- Compiz itself doesn't work when compiled with the libGL from nvidia, - should work
it ships its own and links against it - in SceneGL::Texture::findTarget() there is a hack that makes KWin work with XGL
? - might be worth trying to use that libGL as well without requiring KWin to be built against the libGL version that Compiz is
- it may be just because of the special libGL, but when testing with Xgl built against
it even seemed non-conformant - none of the provided configs had % - that may not be necessary somewhen later
GLX_RENDER_TYPE with GLX_RGBA_BIT even though required by GLX - interesting observation: normally run glxgears performs somewhat poorly compared
and other funny things. Indeed, it may be just me being still pretty to normal nvidia mode, changing glxgears to be override-redirect (i.e. no reparenting)
clueless about these things. however makes glxgears to be even faster than without any compositing at all,
? - is there a good reason to support Xgl? With the 9625 nvidia drivers in this case however kwin's redrawing speed drops somewhat
it seems to work fine without them and there's AIGLX
+ AIGLX support % AIGLX support
- kind of works, needs more work - should work
+ - it needs indirect rendering, should be autodetected and disabled somehow + - it needs indirect rendering, should be autodetected and disabled somehow
% - may require LIBGL_ALWAYS_INDIRECT set with older X.org % - may require LIBGL_ALWAYS_INDIRECT set with older X.org
(http://lists.kde.org/?l=kwin&m=116439615124838&w=2) (http://lists.kde.org/?l=kwin&m=116439615124838&w=2)

View file

@ -766,7 +766,11 @@ void SceneOpenGL::Texture::findTarget()
unsigned int new_target = 0; unsigned int new_target = 0;
if( tfp_mode && glXQueryDrawable && bound_glxpixmap != None ) if( tfp_mode && glXQueryDrawable && bound_glxpixmap != None )
glXQueryDrawable( display(), bound_glxpixmap, GLX_TEXTURE_TARGET_EXT, &new_target ); glXQueryDrawable( display(), bound_glxpixmap, GLX_TEXTURE_TARGET_EXT, &new_target );
else // Hack for XGL - this should not be a fallback for glXQueryDrawable() but instead the case
// when glXQueryDrawable is not available. However this call fails with XGL, unless KWin
// is compiled statically with the libGL that Compiz is built against (without which neither
// Compiz works with XGL). Falling back to doing this manually makes this work.
if( new_target == 0 )
{ {
if( NPOTTextureSupported() || if( NPOTTextureSupported() ||
( isPowerOfTwo( mSize.width()) && isPowerOfTwo( mSize.height()))) ( isPowerOfTwo( mSize.width()) && isPowerOfTwo( mSize.height())))