aboutsummaryrefslogtreecommitdiff
path: root/disassembly/dwmcore_2202_10.asm
blob: abfe3513d9f616f956f16ffe9981cd13bb9f3df4 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
//
// Generated by Microsoft (R) HLSL Shader Compiler 9.25.950.2675
//
//   using 3Dmigoto v1.3.16 on Wed Feb 09 18:55:48 2022
//
//
// Resource Bindings:
//
// Name                                 Type  Format         Dim Slot Elements
// ------------------------------ ---------- ------- ----------- ---- --------
// SuperSampleTextureFromInterpolatorUV1_Sampler    sampler      NA          NA    0        1
// SampleTextureFromInterpolatorUV2_Sampler    sampler      NA          NA    1        1
// SuperSampleTextureFromInterpolatorUV1_Sampler    texture  float4          2d    0        1
// SampleTextureFromInterpolatorUV2_Sampler    texture  float4          2d    1        1
//
//
//
// Input signature:
//
// Name                 Index   Mask Register SysValue  Format   Used
// -------------------- ----- ------ -------- -------- ------- ------
// SV_POSITION              0   xyzw        0      POS   float
// TEXCOORD                 0   xyzw        1     NONE   float
// TEXCOORD                 1   xyzw        2     NONE   float   xyzw
// TEXCOORD                 2   xyzw        3     NONE   float   xyzw
// TEXCOORD                 3   xy          4     NONE   float   xy
// TEXCOORD                 4   xyzw        5     NONE   float      w
//
//
// Output signature:
//
// Name                 Index   Mask Register SysValue  Format   Used
// -------------------- ----- ------ -------- -------- ------- ------
// SV_Target                0   xyzw        0   TARGET   float   xyzw
//
//
// Sampler/Resource to DX9 shader sampler mappings:
//
// Target Sampler Source Sampler  Source Resource
// -------------- --------------- ----------------
// s0             s0              t0
// s1             s1              t1
//
//
// Level9 shader bytecode:
//
    ps_2_0
    def c0, 0.25, 0.0404499993, 0.0773993805, 0.0549999997
    def c1, 0.947867274, 2.4000001, 0, 0
    dcl t1
    dcl t2
    dcl t3.xy
    dcl t4
    dcl_2d s0
    dcl_2d s1
    mov r0.x, t1.z
    mov r0.y, t1.w
    mov r1.x, t2.z
    mov r1.y, t2.w
    texld r0, r0, s0
    texld r2, t1, s0
    texld r3, t2, s0
    texld r1, r1, s0
    texld r4, t3, s1
    add r0, r0, r2
    add r0, r3, r0
    add r0, r1, r0
    mul r0, r0, c0.x
    rcp r1.x, r0.w
    mad r1.y, r0.x, r1.x, c0.w
    mul r1.y, r1.y, c1.x
    pow r2.x, r1.y, c1.y
    mad r1.y, r0.x, -r1.x, c0.y
    mul r2.yzw, r0.wzyx, r1.x
    mul r2.w, r2.w, c0.z
    cmp r3.x, r1.y, r2.w, r2.x
    mad r3.w, r0.y, r1.x, c0.w
    mul r3.w, r3.w, c1.x
    pow r1.y, r3.w, c1.y
    mad r3.w, r0.y, -r1.x, c0.y
    mul r1.z, r2.z, c0.z
    mul r1.w, r2.y, c0.z
    cmp r3.y, r3.w, r1.z, r1.y
    mad r3.w, r0.z, r1.x, c0.w
    mad r1.x, r0.z, -r1.x, c0.y
    mul r3.w, r3.w, c1.x
    pow r1.y, r3.w, c1.y
    cmp r3.z, r1.x, r1.w, r1.y
    mul r1.xyz, r0.w, r3
    cmp r0.xyz, -r0.w, r0, r1
    mul r0, r4.w, r0
    mul r0.w, r0.w, t4.w
    mov oC0, r0

// approximately 44 instruction slots used (5 texture, 39 arithmetic)
ps_4_0
dcl_sampler s0, mode_default
dcl_sampler s1, mode_default
dcl_resource_texture2d (float,float,float,float) t0
dcl_resource_texture2d (float,float,float,float) t1
dcl_input_ps linear v2.xyzw
dcl_input_ps linear v3.xyzw
dcl_input_ps linear v4.xy
dcl_input_ps linear v5.w
dcl_output o0.xyzw
dcl_temps 4
sample r0.xyzw, v2.xyxx, t0.xyzw, s0
sample r1.xyzw, v2.zwzz, t0.xyzw, s0
sample r2.xyzw, v3.xyxx, t0.xyzw, s0
sample r3.xyzw, v3.zwzz, t0.xyzw, s0
add r0.xyzw, r0.xyzw, r1.xyzw
add r0.xyzw, r2.xyzw, r0.xyzw
add r0.xyzw, r3.xyzw, r0.xyzw
mul r0.xyzw, r0.xyzw, l(0.250000, 0.250000, 0.250000, 0.250000)
lt r1.x, l(0.000000), r0.w
if_nz r1.x
  div r1.xyz, r0.xyzx, r0.wwww
  ge r2.xyz, l(0.040450, 0.040450, 0.040450, 0.000000), r1.xyzx
  mul r3.xyz, r1.xyzx, l(0.0773993805, 0.0773993805, 0.0773993805, 0.000000)
  add r1.xyz, r1.xyzx, l(0.055000, 0.055000, 0.055000, 0.000000)
  mul r1.xyz, r1.xyzx, l(0.947867274, 0.947867274, 0.947867274, 0.000000)
  log r1.xyz, r1.xyzx
  mul r1.xyz, r1.xyzx, l(2.400000, 2.400000, 2.400000, 0.000000)
  exp r1.xyz, r1.xyzx
  movc r1.xyz, r2.xyzx, r3.xyzx, r1.xyzx
  mul r0.xyz, r0.wwww, r1.xyzx
endif
sample r1.xyzw, v4.xyxx, t1.xyzw, s1
mul r0.xyzw, r0.xyzw, r1.wwww
mul o0.w, r0.w, v5.w
mov o0.xyz, r0.xyzx
ret
// Approximately 26 instruction slots used