| 
									
										
										
										
											2021-05-08 16:28:52 -03:00
										 |  |  | // Copyright 2021 yuzu Emulator Project
 | 
					
						
							|  |  |  | // Licensed under GPLv2 or any later version
 | 
					
						
							|  |  |  | // Refer to the license.txt file included.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "shader_recompiler/backend/glasm/emit_context.h"
 | 
					
						
							|  |  |  | #include "shader_recompiler/backend/glasm/emit_glasm_instructions.h"
 | 
					
						
							|  |  |  | #include "shader_recompiler/frontend/ir/value.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace Shader::Backend::GLASM { | 
					
						
							| 
									
										
										
										
											2021-06-25 13:09:45 -04:00
										 |  |  | namespace { | 
					
						
							|  |  |  | void BitwiseLogicalOp(EmitContext& ctx, IR::Inst& inst, ScalarS32 a, ScalarS32 b, | 
					
						
							|  |  |  |                       std::string_view lop) { | 
					
						
							|  |  |  |     const auto zero = inst.GetAssociatedPseudoOperation(IR::Opcode::GetZeroFromOp); | 
					
						
							|  |  |  |     const auto sign = inst.GetAssociatedPseudoOperation(IR::Opcode::GetSignFromOp); | 
					
						
							|  |  |  |     if (zero) { | 
					
						
							|  |  |  |         zero->Invalidate(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (sign) { | 
					
						
							|  |  |  |         sign->Invalidate(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (zero || sign) { | 
					
						
							|  |  |  |         ctx.reg_alloc.InvalidateConditionCodes(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     const auto ret{ctx.reg_alloc.Define(inst)}; | 
					
						
							|  |  |  |     ctx.Add("{}.S {}.x,{},{};", lop, ret, a, b); | 
					
						
							|  |  |  |     if (zero) { | 
					
						
							|  |  |  |         ctx.Add("SEQ.S {},{},0;", *zero, ret); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (sign) { | 
					
						
							|  |  |  |         ctx.Add("SLT.S {},{},0;", *sign, ret); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | } // Anonymous namespace
 | 
					
						
							| 
									
										
										
										
											2021-05-08 16:28:52 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-09 03:11:34 -03:00
										 |  |  | void EmitIAdd32(EmitContext& ctx, IR::Inst& inst, ScalarS32 a, ScalarS32 b) { | 
					
						
							| 
									
										
										
										
											2021-05-25 02:22:21 -03:00
										 |  |  |     const std::array flags{ | 
					
						
							|  |  |  |         inst.GetAssociatedPseudoOperation(IR::Opcode::GetZeroFromOp), | 
					
						
							|  |  |  |         inst.GetAssociatedPseudoOperation(IR::Opcode::GetSignFromOp), | 
					
						
							|  |  |  |         inst.GetAssociatedPseudoOperation(IR::Opcode::GetCarryFromOp), | 
					
						
							|  |  |  |         inst.GetAssociatedPseudoOperation(IR::Opcode::GetOverflowFromOp), | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |     for (IR::Inst* const flag_inst : flags) { | 
					
						
							|  |  |  |         if (flag_inst) { | 
					
						
							|  |  |  |             flag_inst->Invalidate(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-05-19 00:29:07 -04:00
										 |  |  |     const bool cc{inst.HasAssociatedPseudoOperation()}; | 
					
						
							|  |  |  |     const std::string_view cc_mod{cc ? ".CC" : ""}; | 
					
						
							|  |  |  |     if (cc) { | 
					
						
							|  |  |  |         ctx.reg_alloc.InvalidateConditionCodes(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     const auto ret{ctx.reg_alloc.Define(inst)}; | 
					
						
							|  |  |  |     ctx.Add("ADD.S{} {}.x,{},{};", cc_mod, ret, a, b); | 
					
						
							|  |  |  |     if (!cc) { | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-05-25 02:22:21 -03:00
										 |  |  |     static constexpr std::array<std::string_view, 4> masks{"", "SF", "CF", "OF"}; | 
					
						
							|  |  |  |     for (size_t flag_index = 0; flag_index < flags.size(); ++flag_index) { | 
					
						
							|  |  |  |         if (!flags[flag_index]) { | 
					
						
							|  |  |  |             continue; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         const auto flag_ret{ctx.reg_alloc.Define(*flags[flag_index])}; | 
					
						
							|  |  |  |         if (flag_index == 0) { | 
					
						
							|  |  |  |             ctx.Add("SEQ.S {}.x,{}.x,0;", flag_ret, ret); | 
					
						
							|  |  |  |         } else { | 
					
						
							|  |  |  |             // We could use conditional execution here, but it's broken on Nvidia's compiler
 | 
					
						
							|  |  |  |             ctx.Add("IF {}.x;" | 
					
						
							|  |  |  |                     "MOV.S {}.x,-1;" | 
					
						
							|  |  |  |                     "ELSE;" | 
					
						
							|  |  |  |                     "MOV.S {}.x,0;" | 
					
						
							|  |  |  |                     "ENDIF;", | 
					
						
							|  |  |  |                     masks[flag_index], flag_ret, flag_ret); | 
					
						
							| 
									
										
										
										
											2021-05-19 00:29:07 -04:00
										 |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-05-08 16:28:52 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-23 20:16:09 -03:00
										 |  |  | void EmitIAdd64(EmitContext& ctx, IR::Inst& inst, Register a, Register b) { | 
					
						
							|  |  |  |     ctx.LongAdd("ADD.S64 {}.x,{}.x,{}.x;", inst, a, b); | 
					
						
							| 
									
										
										
										
											2021-05-08 16:28:52 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-09 03:11:34 -03:00
										 |  |  | void EmitISub32(EmitContext& ctx, IR::Inst& inst, ScalarS32 a, ScalarS32 b) { | 
					
						
							|  |  |  |     ctx.Add("SUB.S {}.x,{},{};", inst, a, b); | 
					
						
							| 
									
										
										
										
											2021-05-08 16:28:52 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-23 20:16:09 -03:00
										 |  |  | void EmitISub64(EmitContext& ctx, IR::Inst& inst, Register a, Register b) { | 
					
						
							|  |  |  |     ctx.LongAdd("SUB.S64 {}.x,{}.x,{}.x;", inst, a, b); | 
					
						
							| 
									
										
										
										
											2021-05-08 16:28:52 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-09 03:11:34 -03:00
										 |  |  | void EmitIMul32(EmitContext& ctx, IR::Inst& inst, ScalarS32 a, ScalarS32 b) { | 
					
						
							|  |  |  |     ctx.Add("MUL.S {}.x,{},{};", inst, a, b); | 
					
						
							| 
									
										
										
										
											2021-05-08 16:28:52 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-09 18:49:27 -04:00
										 |  |  | void EmitINeg32(EmitContext& ctx, IR::Inst& inst, ScalarS32 value) { | 
					
						
							| 
									
										
										
										
											2021-05-25 02:48:03 -03:00
										 |  |  |     if (value.type != Type::Register && static_cast<s32>(value.imm_u32) < 0) { | 
					
						
							|  |  |  |         ctx.Add("MOV.S {},{};", inst, -static_cast<s32>(value.imm_u32)); | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |         ctx.Add("MOV.S {},-{};", inst, value); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-05-08 16:28:52 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-10 03:55:33 -03:00
										 |  |  | void EmitINeg64(EmitContext& ctx, IR::Inst& inst, Register value) { | 
					
						
							|  |  |  |     ctx.LongAdd("MOV.S64 {},-{};", inst, value); | 
					
						
							| 
									
										
										
										
											2021-05-08 16:28:52 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-09 18:49:27 -04:00
										 |  |  | void EmitIAbs32(EmitContext& ctx, IR::Inst& inst, ScalarS32 value) { | 
					
						
							|  |  |  |     ctx.Add("ABS.S {},{};", inst, value); | 
					
						
							| 
									
										
										
										
											2021-05-08 16:28:52 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-09 03:11:34 -03:00
										 |  |  | void EmitShiftLeftLogical32(EmitContext& ctx, IR::Inst& inst, ScalarU32 base, ScalarU32 shift) { | 
					
						
							|  |  |  |     ctx.Add("SHL.U {}.x,{},{};", inst, base, shift); | 
					
						
							| 
									
										
										
										
											2021-05-08 16:28:52 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-19 17:09:29 -03:00
										 |  |  | void EmitShiftLeftLogical64(EmitContext& ctx, IR::Inst& inst, ScalarRegister base, | 
					
						
							|  |  |  |                             ScalarU32 shift) { | 
					
						
							|  |  |  |     ctx.LongAdd("SHL.U64 {}.x,{},{};", inst, base, shift); | 
					
						
							| 
									
										
										
										
											2021-05-08 16:28:52 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-09 18:49:27 -04:00
										 |  |  | void EmitShiftRightLogical32(EmitContext& ctx, IR::Inst& inst, ScalarU32 base, ScalarU32 shift) { | 
					
						
							|  |  |  |     ctx.Add("SHR.U {}.x,{},{};", inst, base, shift); | 
					
						
							| 
									
										
										
										
											2021-05-08 16:28:52 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-19 17:09:29 -03:00
										 |  |  | void EmitShiftRightLogical64(EmitContext& ctx, IR::Inst& inst, ScalarRegister base, | 
					
						
							|  |  |  |                              ScalarU32 shift) { | 
					
						
							|  |  |  |     ctx.LongAdd("SHR.U64 {}.x,{},{};", inst, base, shift); | 
					
						
							| 
									
										
										
										
											2021-05-08 16:28:52 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-09 18:49:27 -04:00
										 |  |  | void EmitShiftRightArithmetic32(EmitContext& ctx, IR::Inst& inst, ScalarS32 base, ScalarS32 shift) { | 
					
						
							|  |  |  |     ctx.Add("SHR.S {}.x,{},{};", inst, base, shift); | 
					
						
							| 
									
										
										
										
											2021-05-08 16:28:52 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-19 17:09:29 -03:00
										 |  |  | void EmitShiftRightArithmetic64(EmitContext& ctx, IR::Inst& inst, ScalarRegister base, | 
					
						
							|  |  |  |                                 ScalarS32 shift) { | 
					
						
							|  |  |  |     ctx.LongAdd("SHR.S64 {}.x,{},{};", inst, base, shift); | 
					
						
							| 
									
										
										
										
											2021-05-08 16:28:52 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-09 03:11:34 -03:00
										 |  |  | void EmitBitwiseAnd32(EmitContext& ctx, IR::Inst& inst, ScalarS32 a, ScalarS32 b) { | 
					
						
							| 
									
										
										
										
											2021-06-25 13:09:45 -04:00
										 |  |  |     BitwiseLogicalOp(ctx, inst, a, b, "AND"); | 
					
						
							| 
									
										
										
										
											2021-05-08 16:28:52 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-09 03:11:34 -03:00
										 |  |  | void EmitBitwiseOr32(EmitContext& ctx, IR::Inst& inst, ScalarS32 a, ScalarS32 b) { | 
					
						
							| 
									
										
										
										
											2021-06-25 13:09:45 -04:00
										 |  |  |     BitwiseLogicalOp(ctx, inst, a, b, "OR"); | 
					
						
							| 
									
										
										
										
											2021-05-08 16:28:52 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-09 03:11:34 -03:00
										 |  |  | void EmitBitwiseXor32(EmitContext& ctx, IR::Inst& inst, ScalarS32 a, ScalarS32 b) { | 
					
						
							| 
									
										
										
										
											2021-06-25 13:09:45 -04:00
										 |  |  |     BitwiseLogicalOp(ctx, inst, a, b, "XOR"); | 
					
						
							| 
									
										
										
										
											2021-05-08 16:28:52 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-09 17:57:57 -04:00
										 |  |  | void EmitBitFieldInsert(EmitContext& ctx, IR::Inst& inst, ScalarS32 base, ScalarS32 insert, | 
					
						
							|  |  |  |                         ScalarS32 offset, ScalarS32 count) { | 
					
						
							| 
									
										
										
										
											2021-05-10 19:20:15 -03:00
										 |  |  |     const Register ret{ctx.reg_alloc.Define(inst)}; | 
					
						
							|  |  |  |     if (count.type != Type::Register && offset.type != Type::Register) { | 
					
						
							|  |  |  |         ctx.Add("BFI.S {},{{{},{},0,0}},{},{};", ret, count, offset, insert, base); | 
					
						
							|  |  |  |     } else { | 
					
						
							| 
									
										
										
										
											2021-05-14 00:40:54 -03:00
										 |  |  |         ctx.Add("MOV.S RC.x,{};" | 
					
						
							|  |  |  |                 "MOV.S RC.y,{};" | 
					
						
							| 
									
										
										
										
											2021-05-10 19:20:15 -03:00
										 |  |  |                 "BFI.S {},RC,{},{};", | 
					
						
							|  |  |  |                 count, offset, ret, insert, base); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-05-08 16:28:52 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-09 17:57:57 -04:00
										 |  |  | void EmitBitFieldSExtract(EmitContext& ctx, IR::Inst& inst, ScalarS32 base, ScalarS32 offset, | 
					
						
							|  |  |  |                           ScalarS32 count) { | 
					
						
							| 
									
										
										
										
											2021-05-10 19:20:15 -03:00
										 |  |  |     const Register ret{ctx.reg_alloc.Define(inst)}; | 
					
						
							|  |  |  |     if (count.type != Type::Register && offset.type != Type::Register) { | 
					
						
							|  |  |  |         ctx.Add("BFE.S {},{{{},{},0,0}},{};", ret, count, offset, base); | 
					
						
							|  |  |  |     } else { | 
					
						
							| 
									
										
										
										
											2021-05-14 00:40:54 -03:00
										 |  |  |         ctx.Add("MOV.S RC.x,{};" | 
					
						
							|  |  |  |                 "MOV.S RC.y,{};" | 
					
						
							| 
									
										
										
										
											2021-05-10 19:20:15 -03:00
										 |  |  |                 "BFE.S {},RC,{};", | 
					
						
							|  |  |  |                 count, offset, ret, base); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-05-08 16:28:52 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-09 17:57:57 -04:00
										 |  |  | void EmitBitFieldUExtract(EmitContext& ctx, IR::Inst& inst, ScalarU32 base, ScalarU32 offset, | 
					
						
							|  |  |  |                           ScalarU32 count) { | 
					
						
							| 
									
										
										
										
											2021-05-25 02:22:21 -03:00
										 |  |  |     const auto zero = inst.GetAssociatedPseudoOperation(IR::Opcode::GetZeroFromOp); | 
					
						
							|  |  |  |     const auto sign = inst.GetAssociatedPseudoOperation(IR::Opcode::GetSignFromOp); | 
					
						
							|  |  |  |     if (zero) { | 
					
						
							|  |  |  |         zero->Invalidate(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (sign) { | 
					
						
							|  |  |  |         sign->Invalidate(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (zero || sign) { | 
					
						
							|  |  |  |         ctx.reg_alloc.InvalidateConditionCodes(); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-05-10 19:20:15 -03:00
										 |  |  |     const Register ret{ctx.reg_alloc.Define(inst)}; | 
					
						
							|  |  |  |     if (count.type != Type::Register && offset.type != Type::Register) { | 
					
						
							|  |  |  |         ctx.Add("BFE.U {},{{{},{},0,0}},{};", ret, count, offset, base); | 
					
						
							|  |  |  |     } else { | 
					
						
							| 
									
										
										
										
											2021-05-14 00:40:54 -03:00
										 |  |  |         ctx.Add("MOV.U RC.x,{};" | 
					
						
							|  |  |  |                 "MOV.U RC.y,{};" | 
					
						
							| 
									
										
										
										
											2021-05-10 19:20:15 -03:00
										 |  |  |                 "BFE.U {},RC,{};", | 
					
						
							|  |  |  |                 count, offset, ret, base); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-05-25 02:22:21 -03:00
										 |  |  |     if (zero) { | 
					
						
							| 
									
										
										
										
											2021-05-18 21:30:24 -03:00
										 |  |  |         ctx.Add("SEQ.S {},{},0;", *zero, ret); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-05-25 02:22:21 -03:00
										 |  |  |     if (sign) { | 
					
						
							| 
									
										
										
										
											2021-05-18 21:30:24 -03:00
										 |  |  |         ctx.Add("SLT.S {},{},0;", *sign, ret); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-05-08 16:28:52 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-09 17:57:57 -04:00
										 |  |  | void EmitBitReverse32(EmitContext& ctx, IR::Inst& inst, ScalarS32 value) { | 
					
						
							|  |  |  |     ctx.Add("BFR {},{};", inst, value); | 
					
						
							| 
									
										
										
										
											2021-05-08 16:28:52 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-09 18:49:27 -04:00
										 |  |  | void EmitBitCount32(EmitContext& ctx, IR::Inst& inst, ScalarS32 value) { | 
					
						
							|  |  |  |     ctx.Add("BTC {},{};", inst, value); | 
					
						
							| 
									
										
										
										
											2021-05-08 16:28:52 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-09 17:57:57 -04:00
										 |  |  | void EmitBitwiseNot32(EmitContext& ctx, IR::Inst& inst, ScalarS32 value) { | 
					
						
							|  |  |  |     ctx.Add("NOT.S {},{};", inst, value); | 
					
						
							| 
									
										
										
										
											2021-05-08 16:28:52 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-09 18:49:27 -04:00
										 |  |  | void EmitFindSMsb32(EmitContext& ctx, IR::Inst& inst, ScalarS32 value) { | 
					
						
							|  |  |  |     ctx.Add("BTFM.S {},{};", inst, value); | 
					
						
							| 
									
										
										
										
											2021-05-08 16:28:52 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-09 18:49:27 -04:00
										 |  |  | void EmitFindUMsb32(EmitContext& ctx, IR::Inst& inst, ScalarU32 value) { | 
					
						
							|  |  |  |     ctx.Add("BTFM.U {},{};", inst, value); | 
					
						
							| 
									
										
										
										
											2021-05-08 16:28:52 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-09 18:49:27 -04:00
										 |  |  | void EmitSMin32(EmitContext& ctx, IR::Inst& inst, ScalarS32 a, ScalarS32 b) { | 
					
						
							|  |  |  |     ctx.Add("MIN.S {},{},{};", inst, a, b); | 
					
						
							| 
									
										
										
										
											2021-05-08 16:28:52 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-09 18:49:27 -04:00
										 |  |  | void EmitUMin32(EmitContext& ctx, IR::Inst& inst, ScalarU32 a, ScalarU32 b) { | 
					
						
							|  |  |  |     ctx.Add("MIN.U {},{},{};", inst, a, b); | 
					
						
							| 
									
										
										
										
											2021-05-08 16:28:52 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-09 18:49:27 -04:00
										 |  |  | void EmitSMax32(EmitContext& ctx, IR::Inst& inst, ScalarS32 a, ScalarS32 b) { | 
					
						
							|  |  |  |     ctx.Add("MAX.S {},{},{};", inst, a, b); | 
					
						
							| 
									
										
										
										
											2021-05-08 16:28:52 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-09 18:49:27 -04:00
										 |  |  | void EmitUMax32(EmitContext& ctx, IR::Inst& inst, ScalarU32 a, ScalarU32 b) { | 
					
						
							|  |  |  |     ctx.Add("MAX.U {},{},{};", inst, a, b); | 
					
						
							| 
									
										
										
										
											2021-05-08 16:28:52 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-09 18:49:27 -04:00
										 |  |  | void EmitSClamp32(EmitContext& ctx, IR::Inst& inst, ScalarS32 value, ScalarS32 min, ScalarS32 max) { | 
					
						
							|  |  |  |     const Register ret{ctx.reg_alloc.Define(inst)}; | 
					
						
							| 
									
										
										
										
											2021-05-10 19:20:15 -03:00
										 |  |  |     ctx.Add("MIN.S RC.x,{},{};" | 
					
						
							|  |  |  |             "MAX.S {}.x,RC.x,{};", | 
					
						
							|  |  |  |             max, value, ret, min); | 
					
						
							| 
									
										
										
										
											2021-05-08 16:28:52 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-09 18:49:27 -04:00
										 |  |  | void EmitUClamp32(EmitContext& ctx, IR::Inst& inst, ScalarU32 value, ScalarU32 min, ScalarU32 max) { | 
					
						
							|  |  |  |     const Register ret{ctx.reg_alloc.Define(inst)}; | 
					
						
							| 
									
										
										
										
											2021-05-10 19:20:15 -03:00
										 |  |  |     ctx.Add("MIN.U RC.x,{},{};" | 
					
						
							|  |  |  |             "MAX.U {}.x,RC.x,{};", | 
					
						
							|  |  |  |             max, value, ret, min); | 
					
						
							| 
									
										
										
										
											2021-05-08 16:28:52 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-09 17:57:57 -04:00
										 |  |  | void EmitSLessThan(EmitContext& ctx, IR::Inst& inst, ScalarS32 lhs, ScalarS32 rhs) { | 
					
						
							| 
									
										
										
										
											2021-05-14 02:10:03 -03:00
										 |  |  |     ctx.Add("SLT.S {}.x,{},{};", inst, lhs, rhs); | 
					
						
							| 
									
										
										
										
											2021-05-08 16:28:52 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-09 17:57:57 -04:00
										 |  |  | void EmitULessThan(EmitContext& ctx, IR::Inst& inst, ScalarU32 lhs, ScalarU32 rhs) { | 
					
						
							| 
									
										
										
										
											2021-05-14 02:10:03 -03:00
										 |  |  |     ctx.Add("SLT.U {}.x,{},{};", inst, lhs, rhs); | 
					
						
							| 
									
										
										
										
											2021-05-08 16:28:52 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-09 17:57:57 -04:00
										 |  |  | void EmitIEqual(EmitContext& ctx, IR::Inst& inst, ScalarS32 lhs, ScalarS32 rhs) { | 
					
						
							| 
									
										
										
										
											2021-05-14 02:10:03 -03:00
										 |  |  |     ctx.Add("SEQ.S {}.x,{},{};", inst, lhs, rhs); | 
					
						
							| 
									
										
										
										
											2021-05-08 16:28:52 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-09 17:57:57 -04:00
										 |  |  | void EmitSLessThanEqual(EmitContext& ctx, IR::Inst& inst, ScalarS32 lhs, ScalarS32 rhs) { | 
					
						
							| 
									
										
										
										
											2021-05-14 02:10:03 -03:00
										 |  |  |     ctx.Add("SLE.S {}.x,{},{};", inst, lhs, rhs); | 
					
						
							| 
									
										
										
										
											2021-05-08 16:28:52 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-09 17:57:57 -04:00
										 |  |  | void EmitULessThanEqual(EmitContext& ctx, IR::Inst& inst, ScalarU32 lhs, ScalarU32 rhs) { | 
					
						
							| 
									
										
										
										
											2021-05-14 02:10:03 -03:00
										 |  |  |     ctx.Add("SLE.U {}.x,{},{};", inst, lhs, rhs); | 
					
						
							| 
									
										
										
										
											2021-05-08 16:28:52 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-09 17:57:57 -04:00
										 |  |  | void EmitSGreaterThan(EmitContext& ctx, IR::Inst& inst, ScalarS32 lhs, ScalarS32 rhs) { | 
					
						
							| 
									
										
										
										
											2021-05-14 02:10:03 -03:00
										 |  |  |     ctx.Add("SGT.S {}.x,{},{};", inst, lhs, rhs); | 
					
						
							| 
									
										
										
										
											2021-05-08 16:28:52 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-09 17:57:57 -04:00
										 |  |  | void EmitUGreaterThan(EmitContext& ctx, IR::Inst& inst, ScalarU32 lhs, ScalarU32 rhs) { | 
					
						
							| 
									
										
										
										
											2021-05-14 02:10:03 -03:00
										 |  |  |     ctx.Add("SGT.U {}.x,{},{};", inst, lhs, rhs); | 
					
						
							| 
									
										
										
										
											2021-05-08 16:28:52 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-09 17:57:57 -04:00
										 |  |  | void EmitINotEqual(EmitContext& ctx, IR::Inst& inst, ScalarS32 lhs, ScalarS32 rhs) { | 
					
						
							| 
									
										
										
										
											2021-05-14 02:10:03 -03:00
										 |  |  |     ctx.Add("SNE.U {}.x,{},{};", inst, lhs, rhs); | 
					
						
							| 
									
										
										
										
											2021-05-08 16:28:52 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-09 17:57:57 -04:00
										 |  |  | void EmitSGreaterThanEqual(EmitContext& ctx, IR::Inst& inst, ScalarS32 lhs, ScalarS32 rhs) { | 
					
						
							| 
									
										
										
										
											2021-05-14 02:10:03 -03:00
										 |  |  |     ctx.Add("SGE.S {}.x,{},{};", inst, lhs, rhs); | 
					
						
							| 
									
										
										
										
											2021-05-08 16:28:52 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-09 17:57:57 -04:00
										 |  |  | void EmitUGreaterThanEqual(EmitContext& ctx, IR::Inst& inst, ScalarU32 lhs, ScalarU32 rhs) { | 
					
						
							| 
									
										
										
										
											2021-05-14 02:10:03 -03:00
										 |  |  |     ctx.Add("SGE.U {}.x,{},{};", inst, lhs, rhs); | 
					
						
							| 
									
										
										
										
											2021-05-08 16:28:52 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } // namespace Shader::Backend::GLASM
 |