diff options
author | Zack Rusin <zackr@vmware.com> | 2009-08-27 18:17:54 -0400 |
---|---|---|
committer | Zack Rusin <zackr@vmware.com> | 2009-08-27 18:17:54 -0400 |
commit | 8bdce0c3a7b3e3798de736ef4ce72431d777901c (patch) | |
tree | 66812a7334e3765c863e231870ebfd571858a279 /src/gallium/state_trackers | |
parent | c7e103d2388ea53348c9537adf40c643f80e76dc (diff) |
st/xorg: set vertex and fragment shader for the current op
Diffstat (limited to 'src/gallium/state_trackers')
-rw-r--r-- | src/gallium/state_trackers/xorg/xorg_composite.c | 23 |
1 files changed, 21 insertions, 2 deletions
diff --git a/src/gallium/state_trackers/xorg/xorg_composite.c b/src/gallium/state_trackers/xorg/xorg_composite.c index 7e9dabf885..950c6828b0 100644 --- a/src/gallium/state_trackers/xorg/xorg_composite.c +++ b/src/gallium/state_trackers/xorg/xorg_composite.c @@ -1,5 +1,7 @@ #include "xorg_composite.h" +#include "xorg_exa_tgsi.h" + #include <cso_cache/cso_context.h> #include <pipe/p_inlines.h> @@ -227,8 +229,25 @@ bind_rasterizer_state(struct exa_context *exa) } static void -bind_shaders() +bind_shaders(struct exa_context *exa, int op, + PicturePtr pSrcPicture, PicturePtr pMaskPicture) { + unsigned vs_traits = 0, fs_traits = 0; + struct xorg_shader shader; + + if (pSrcPicture) { + vs_traits |= VS_COMPOSITE; + fs_traits |= FS_COMPOSITE; + } + + if (pMaskPicture) { + vs_traits |= VS_MASK; + fs_traits |= FS_MASK; + } + + shader = xorg_shaders_get(exa->shaders, vs_traits, fs_traits); + cso_set_vertex_shader_handle(exa->cso, shader.vs); + cso_set_fragment_shader_handle(exa->cso, shader.fs); } @@ -245,7 +264,7 @@ boolean xorg_composite_bind_state(struct exa_context *exa, bind_viewport_state(exa, pDstPicture); bind_blend_state(exa, op, pSrcPicture, pMaskPicture); bind_rasterizer_state(exa); - bind_shaders(); + bind_shaders(exa, op, pSrcPicture, pMaskPicture); return FALSE; } |