summaryrefslogtreecommitdiff
path: root/or_copyplane_fullmask_clipmask.hlps
diff options
context:
space:
mode:
Diffstat (limited to 'or_copyplane_fullmask_clipmask.hlps')
-rw-r--r--or_copyplane_fullmask_clipmask.hlps59
1 files changed, 59 insertions, 0 deletions
diff --git a/or_copyplane_fullmask_clipmask.hlps b/or_copyplane_fullmask_clipmask.hlps
new file mode 100644
index 0000000..597d318
--- /dev/null
+++ b/or_copyplane_fullmask_clipmask.hlps
@@ -0,0 +1,59 @@
+/* Automatically generated file; do not edit */
+
+/* or shader for copyplane with fullmask 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 | out_color;
+
+ return color;
+}