diff options
| -rw-r--r-- | src/gallium/state_trackers/xorg/xorg_exa.c | 30 | 
1 files changed, 28 insertions, 2 deletions
| diff --git a/src/gallium/state_trackers/xorg/xorg_exa.c b/src/gallium/state_trackers/xorg/xorg_exa.c index 94f4ea2c38..c3fff95466 100644 --- a/src/gallium/state_trackers/xorg/xorg_exa.c +++ b/src/gallium/state_trackers/xorg/xorg_exa.c @@ -438,17 +438,43 @@ ExaPrepareComposite(int op, PicturePtr pSrcPicture,     ScrnInfoPtr pScrn = xf86Screens[pDst->drawable.pScreen->myNum];     modesettingPtr ms = modesettingPTR(pScrn);     struct exa_context *exa = ms->exa; +   struct exa_pixmap_priv *priv;     debug_printf("ExaPrepareComposite\n"); +   priv = exaGetPixmapDriverPrivate(pDst); +   if (!priv || !priv->tex || +       !exa->scrn->is_format_supported(exa->scrn, priv->tex->format, +                                       priv->tex->target, +                                       PIPE_TEXTURE_USAGE_RENDER_TARGET, 0)) +      return FALSE; + +   if (pSrc) { +      priv = exaGetPixmapDriverPrivate(pSrc); +      if (!priv || !priv->tex || +          !exa->scrn->is_format_supported(exa->scrn, priv->tex->format, +                                          priv->tex->target, +                                          PIPE_TEXTURE_USAGE_SAMPLER, 0)) +         return FALSE; +   } + +   if (pMask) { +      priv = exaGetPixmapDriverPrivate(pMask); +      if (!priv || !priv->tex || +          !exa->scrn->is_format_supported(exa->scrn, priv->tex->format, +                                          priv->tex->target, +                                          PIPE_TEXTURE_USAGE_SAMPLER, 0)) +         return FALSE; +   } +  #if DISABLE_ACCEL     (void) exa;     return FALSE;  #else     return xorg_composite_bind_state(exa, op, pSrcPicture, pMaskPicture,                                      pDstPicture, -                                    exaGetPixmapDriverPrivate(pSrc), -                                    exaGetPixmapDriverPrivate(pMask), +                                    pSrc ? exaGetPixmapDriverPrivate(pSrc) : NULL, +                                    pMask ? exaGetPixmapDriverPrivate(pMask) : NULL,                                      exaGetPixmapDriverPrivate(pDst));  #endif  } | 
