summaryrefslogtreecommitdiff
path: root/src/shader_recompiler/backend/glsl/emit_glsl_convert.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/shader_recompiler/backend/glsl/emit_glsl_convert.cpp')
-rw-r--r--src/shader_recompiler/backend/glsl/emit_glsl_convert.cpp42
1 files changed, 21 insertions, 21 deletions
diff --git a/src/shader_recompiler/backend/glsl/emit_glsl_convert.cpp b/src/shader_recompiler/backend/glsl/emit_glsl_convert.cpp
index c27965ef0..fa1b02af1 100644
--- a/src/shader_recompiler/backend/glsl/emit_glsl_convert.cpp
+++ b/src/shader_recompiler/backend/glsl/emit_glsl_convert.cpp
@@ -30,12 +30,12 @@ void EmitConvertS32F16([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::I
30 30
31void EmitConvertS32F32([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst, 31void EmitConvertS32F32([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
32 [[maybe_unused]] std::string_view value) { 32 [[maybe_unused]] std::string_view value) {
33 ctx.AddS32("{}=int({});", inst, value); 33 ctx.AddS32("{}=int(float({}));", inst, value);
34} 34}
35 35
36void EmitConvertS32F64([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst, 36void EmitConvertS32F64([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
37 [[maybe_unused]] std::string_view value) { 37 [[maybe_unused]] std::string_view value) {
38 ctx.AddS32("{}=int({});", inst, value); 38 ctx.AddS32("{}=int(double({}));", inst, value);
39} 39}
40 40
41void EmitConvertS64F16([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst, 41void EmitConvertS64F16([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
@@ -45,12 +45,12 @@ void EmitConvertS64F16([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::I
45 45
46void EmitConvertS64F32([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst, 46void EmitConvertS64F32([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
47 [[maybe_unused]] std::string_view value) { 47 [[maybe_unused]] std::string_view value) {
48 ctx.AddS64("{}=int64_t(double({}));", inst, value); 48 ctx.AddS64("{}=int64_t(double(float({})));", inst, value);
49} 49}
50 50
51void EmitConvertS64F64([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst, 51void EmitConvertS64F64([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
52 [[maybe_unused]] std::string_view value) { 52 [[maybe_unused]] std::string_view value) {
53 ctx.AddS64("{}=int64_t({});", inst, value); 53 ctx.AddS64("{}=int64_t(double({}));", inst, value);
54} 54}
55 55
56void EmitConvertU16F16([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst, 56void EmitConvertU16F16([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
@@ -75,12 +75,12 @@ void EmitConvertU32F16([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::I
75 75
76void EmitConvertU32F32([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst, 76void EmitConvertU32F32([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
77 [[maybe_unused]] std::string_view value) { 77 [[maybe_unused]] std::string_view value) {
78 ctx.AddU32("{}=uint({});", inst, value); 78 ctx.AddU32("{}=uint(float({}));", inst, value);
79} 79}
80 80
81void EmitConvertU32F64([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst, 81void EmitConvertU32F64([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
82 [[maybe_unused]] std::string_view value) { 82 [[maybe_unused]] std::string_view value) {
83 ctx.AddU32("{}=uint({});", inst, value); 83 ctx.AddU32("{}=uint(double({}));", inst, value);
84} 84}
85 85
86void EmitConvertU64F16([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst, 86void EmitConvertU64F16([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
@@ -90,22 +90,22 @@ void EmitConvertU64F16([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::I
90 90
91void EmitConvertU64F32([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst, 91void EmitConvertU64F32([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
92 [[maybe_unused]] std::string_view value) { 92 [[maybe_unused]] std::string_view value) {
93 ctx.AddU64("{}=uint64_t(double({}));", inst, value); 93 ctx.AddU64("{}=uint64_t(float({}));", inst, value);
94} 94}
95 95
96void EmitConvertU64F64([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst, 96void EmitConvertU64F64([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
97 [[maybe_unused]] std::string_view value) { 97 [[maybe_unused]] std::string_view value) {
98 ctx.AddU64("{}=uint64_t({});", inst, value); 98 ctx.AddU64("{}=uint64_t(double({}));", inst, value);
99} 99}
100 100
101void EmitConvertU64U32([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst, 101void EmitConvertU64U32([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
102 [[maybe_unused]] std::string_view value) { 102 [[maybe_unused]] std::string_view value) {
103 ctx.AddU64("{}=uint64_t({});", inst, value); 103 ctx.AddU64("{}=uint64_t(uint({}));", inst, value);
104} 104}
105 105
106void EmitConvertU32U64([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst, 106void EmitConvertU32U64([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
107 [[maybe_unused]] std::string_view value) { 107 [[maybe_unused]] std::string_view value) {
108 ctx.AddU32("{}=uint({});", inst, value); 108 ctx.AddU32("{}=uint(uint64_t({}));", inst, value);
109} 109}
110 110
111void EmitConvertF16F32([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst, 111void EmitConvertF16F32([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
@@ -120,12 +120,12 @@ void EmitConvertF32F16([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::I
120 120
121void EmitConvertF32F64([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst, 121void EmitConvertF32F64([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
122 [[maybe_unused]] std::string_view value) { 122 [[maybe_unused]] std::string_view value) {
123 ctx.AddF32("{}=float({});", inst, value); 123 ctx.AddF32("{}=float(double({}));", inst, value);
124} 124}
125 125
126void EmitConvertF64F32([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst, 126void EmitConvertF64F32([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
127 [[maybe_unused]] std::string_view value) { 127 [[maybe_unused]] std::string_view value) {
128 ctx.AddF64("{}=double({});", inst, value); 128 ctx.AddF64("{}=double(float({}));", inst, value);
129} 129}
130 130
131void EmitConvertF16S8([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst, 131void EmitConvertF16S8([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
@@ -180,12 +180,12 @@ void EmitConvertF32S16([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::I
180 180
181void EmitConvertF32S32([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst, 181void EmitConvertF32S32([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
182 [[maybe_unused]] std::string_view value) { 182 [[maybe_unused]] std::string_view value) {
183 ctx.AddF32("{}=float({});", inst, value); 183 ctx.AddF32("{}=float(int({}));", inst, value);
184} 184}
185 185
186void EmitConvertF32S64([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst, 186void EmitConvertF32S64([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
187 [[maybe_unused]] std::string_view value) { 187 [[maybe_unused]] std::string_view value) {
188 ctx.AddF32("{}=float({});", inst, value); 188 ctx.AddF32("{}=float(double(int64_t({})));", inst, value);
189} 189}
190 190
191void EmitConvertF32U8([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst, 191void EmitConvertF32U8([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
@@ -195,17 +195,17 @@ void EmitConvertF32U8([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::In
195 195
196void EmitConvertF32U16([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst, 196void EmitConvertF32U16([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
197 [[maybe_unused]] std::string_view value) { 197 [[maybe_unused]] std::string_view value) {
198 ctx.AddF32("{}=float({});", inst, value); 198 ctx.AddF32("{}=float(uint({}));", inst, value);
199} 199}
200 200
201void EmitConvertF32U32([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst, 201void EmitConvertF32U32([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
202 [[maybe_unused]] std::string_view value) { 202 [[maybe_unused]] std::string_view value) {
203 ctx.AddF32("{}=float({});", inst, value); 203 ctx.AddF32("{}=float(uint({}));", inst, value);
204} 204}
205 205
206void EmitConvertF32U64([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst, 206void EmitConvertF32U64([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
207 [[maybe_unused]] std::string_view value) { 207 [[maybe_unused]] std::string_view value) {
208 ctx.AddF32("{}=float({});", inst, value); 208 ctx.AddF32("{}=float(double(uint64_t({})));", inst, value);
209} 209}
210 210
211void EmitConvertF64S8([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst, 211void EmitConvertF64S8([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
@@ -220,12 +220,12 @@ void EmitConvertF64S16([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::I
220 220
221void EmitConvertF64S32([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst, 221void EmitConvertF64S32([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
222 [[maybe_unused]] std::string_view value) { 222 [[maybe_unused]] std::string_view value) {
223 ctx.AddF64("{}=double({});", inst, value); 223 ctx.AddF64("{}=double(int({}));", inst, value);
224} 224}
225 225
226void EmitConvertF64S64([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst, 226void EmitConvertF64S64([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
227 [[maybe_unused]] std::string_view value) { 227 [[maybe_unused]] std::string_view value) {
228 ctx.AddF64("{}=double({});", inst, value); 228 ctx.AddF64("{}=double(int64_t({}));", inst, value);
229} 229}
230 230
231void EmitConvertF64U8([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst, 231void EmitConvertF64U8([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
@@ -240,12 +240,12 @@ void EmitConvertF64U16([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::I
240 240
241void EmitConvertF64U32([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst, 241void EmitConvertF64U32([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
242 [[maybe_unused]] std::string_view value) { 242 [[maybe_unused]] std::string_view value) {
243 ctx.AddF64("{}=double({});", inst, value); 243 ctx.AddF64("{}=double(uint({}));", inst, value);
244} 244}
245 245
246void EmitConvertF64U64([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst, 246void EmitConvertF64U64([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
247 [[maybe_unused]] std::string_view value) { 247 [[maybe_unused]] std::string_view value) {
248 ctx.AddF64("{}=double({});", inst, value); 248 ctx.AddF64("{}=double(uint64_t({}));", inst, value);
249} 249}
250 250
251} // namespace Shader::Backend::GLSL 251} // namespace Shader::Backend::GLSL