summaryrefslogtreecommitdiff
path: root/copyinverted_copyplane_planemask_clipmask.hlps
diff options
context:
space:
mode:
authorPeter Harris <pharris@opentext.com>2014-03-10 13:03:51 -0400
committerPeter Harris <pharris@opentext.com>2014-03-10 13:03:51 -0400
commita8d6bbf19a3e6c57c8b902cbd994bafe63591078 (patch)
tree6547c2fa2e10ca840e6df30348e4a8077cfc336f /copyinverted_copyplane_planemask_clipmask.hlps
parentc404049a52f7999d716bc0e2cf6c7af30c62f50f (diff)
Add generated shadersHEADmaster
So they can be studied without needing to run the generator.
Diffstat (limited to 'copyinverted_copyplane_planemask_clipmask.hlps')
-rw-r--r--copyinverted_copyplane_planemask_clipmask.hlps62
1 files changed, 62 insertions, 0 deletions
diff --git a/copyinverted_copyplane_planemask_clipmask.hlps b/copyinverted_copyplane_planemask_clipmask.hlps
new file mode 100644
index 0000000..3a0ad20
--- /dev/null
+++ b/copyinverted_copyplane_planemask_clipmask.hlps
@@ -0,0 +1,62 @@
+/* Automatically generated file; do not edit */
+
+/* copyinverted shader for copyplane with planemask and clipmask */
+
+SamplerState point_sample;
+
+Texture2D<uint4> tile : register(t0);
+Texture2D clipmask : register(t1);
+Texture2D<uint4> output : register(t2);
+
+cbuffer colors :register(b0) {
+ uint4 foreground;
+ uint4 background;
+ uint4 planemask;
+}
+
+cbuffer tile_stats :register(b1) {
+ uint4 plane;
+ uint2 tile_wh;
+}
+
+struct PS_INPUT {
+ float2 tile_pos : TEXCOORD0;
+ float2 clip_pos : TEXCOORD1;
+ float2 out_pos : TEXCOORD2;
+};
+
+uint4 main(PS_INPUT input) : SV_TARGET
+{
+ // Test clip mask
+ float4 cm = clipmask.Sample(point_sample, input.clip_pos);
+ if (cm.r < 0.5) {
+ discard;
+ return 0;
+ }
+
+ uint4 color;
+
+ // Load input color
+ int3 tp;
+ tp.xy = input.tile_pos.xy % tile_wh.xy;
+ tp.z = 0;
+ color = tile.Load(tp);
+ if (any(color & plane))
+ color = foreground;
+ else
+ color = background;
+
+ // Load output color
+ int3 pos;
+ pos.xy = input.out_pos.xy;
+ pos.z = 0;
+ uint4 out_color = output.Load(pos);
+
+ // rop
+ color = ~color;
+
+ // planemask
+ color = (color & planemask) | (out_color & ~planemask);
+
+ return color;
+}