| 
									
										
										
										
											2021-05-09 17:57:57 -04: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-05-18 21:30:09 -03:00
										 |  |  | void EmitSelectU1(EmitContext& ctx, IR::Inst& inst, ScalarS32 cond, ScalarS32 true_value, | 
					
						
							|  |  |  |                   ScalarS32 false_value) { | 
					
						
							|  |  |  |     ctx.Add("CMP.S {},{},{},{};", inst, cond, true_value, false_value); | 
					
						
							| 
									
										
										
										
											2021-05-09 17:57:57 -04:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void EmitSelectU8([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] ScalarS32 cond, | 
					
						
							|  |  |  |                   [[maybe_unused]] ScalarS32 true_value, [[maybe_unused]] ScalarS32 false_value) { | 
					
						
							|  |  |  |     throw NotImplementedException("GLASM instruction"); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void EmitSelectU16([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] ScalarS32 cond, | 
					
						
							|  |  |  |                    [[maybe_unused]] ScalarS32 true_value, [[maybe_unused]] ScalarS32 false_value) { | 
					
						
							|  |  |  |     throw NotImplementedException("GLASM instruction"); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void EmitSelectU32(EmitContext& ctx, IR::Inst& inst, ScalarS32 cond, ScalarS32 true_value, | 
					
						
							|  |  |  |                    ScalarS32 false_value) { | 
					
						
							|  |  |  |     ctx.Add("CMP.S {},{},{},{};", inst, cond, true_value, false_value); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-10 01:41:07 -03:00
										 |  |  | void EmitSelectU64(EmitContext& ctx, IR::Inst& inst, ScalarS32 cond, Register true_value, | 
					
						
							|  |  |  |                    Register false_value) { | 
					
						
							|  |  |  |     ctx.reg_alloc.InvalidateConditionCodes(); | 
					
						
							|  |  |  |     const Register ret{ctx.reg_alloc.LongDefine(inst)}; | 
					
						
							|  |  |  |     if (ret == true_value) { | 
					
						
							|  |  |  |         ctx.Add("MOV.S.CC RC.x,{};" | 
					
						
							|  |  |  |                 "MOV.U64 {}.x(EQ.x),{};", | 
					
						
							|  |  |  |                 cond, ret, false_value); | 
					
						
							|  |  |  |     } else if (ret == false_value) { | 
					
						
							|  |  |  |         ctx.Add("MOV.S.CC RC.x,{};" | 
					
						
							|  |  |  |                 "MOV.U64 {}.x(NE.x),{};", | 
					
						
							|  |  |  |                 cond, ret, true_value); | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |         ctx.Add("MOV.S.CC RC.x,{};" | 
					
						
							| 
									
										
										
										
											2021-05-10 19:20:15 -03:00
										 |  |  |                 "MOV.U64 {}.x,{};" | 
					
						
							| 
									
										
										
										
											2021-05-10 01:41:07 -03:00
										 |  |  |                 "MOV.U64 {}.x(NE.x),{};", | 
					
						
							|  |  |  |                 cond, ret, false_value, ret, true_value); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-05-09 17:57:57 -04:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void EmitSelectF16([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] ScalarS32 cond, | 
					
						
							|  |  |  |                    [[maybe_unused]] Register true_value, [[maybe_unused]] Register false_value) { | 
					
						
							|  |  |  |     throw NotImplementedException("GLASM instruction"); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void EmitSelectF32(EmitContext& ctx, IR::Inst& inst, ScalarS32 cond, ScalarS32 true_value, | 
					
						
							|  |  |  |                    ScalarS32 false_value) { | 
					
						
							|  |  |  |     ctx.Add("CMP.S {},{},{},{};", inst, cond, true_value, false_value); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void EmitSelectF64([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] ScalarS32 cond, | 
					
						
							|  |  |  |                    [[maybe_unused]] Register true_value, [[maybe_unused]] Register false_value) { | 
					
						
							|  |  |  |     throw NotImplementedException("GLASM instruction"); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } // namespace Shader::Backend::GLASM
 |