diff options
| author | 2021-03-09 17:14:57 -0300 | |
|---|---|---|
| committer | 2021-07-22 21:51:23 -0400 | |
| commit | 3a63fa0477ea8297c80133d35494e1dfdc012f95 (patch) | |
| tree | 3cd8b9be6f91cb1628b0d47513b7adb88df5f7b2 /src/shader_recompiler/frontend/ir/ir_emitter.cpp | |
| parent | shader: Initial support for textures and TEX (diff) | |
| download | yuzu-3a63fa0477ea8297c80133d35494e1dfdc012f95.tar.gz yuzu-3a63fa0477ea8297c80133d35494e1dfdc012f95.tar.xz yuzu-3a63fa0477ea8297c80133d35494e1dfdc012f95.zip | |
shader: Partial implementation of LDC
Diffstat (limited to 'src/shader_recompiler/frontend/ir/ir_emitter.cpp')
| -rw-r--r-- | src/shader_recompiler/frontend/ir/ir_emitter.cpp | 22 |
1 files changed, 21 insertions, 1 deletions
diff --git a/src/shader_recompiler/frontend/ir/ir_emitter.cpp b/src/shader_recompiler/frontend/ir/ir_emitter.cpp index ae3354c66..33819dd36 100644 --- a/src/shader_recompiler/frontend/ir/ir_emitter.cpp +++ b/src/shader_recompiler/frontend/ir/ir_emitter.cpp | |||
| @@ -112,7 +112,27 @@ void IREmitter::SetPred(IR::Pred pred, const U1& value) { | |||
| 112 | } | 112 | } |
| 113 | 113 | ||
| 114 | U32 IREmitter::GetCbuf(const U32& binding, const U32& byte_offset) { | 114 | U32 IREmitter::GetCbuf(const U32& binding, const U32& byte_offset) { |
| 115 | return Inst<U32>(Opcode::GetCbuf, binding, byte_offset); | 115 | return Inst<U32>(Opcode::GetCbufU32, binding, byte_offset); |
| 116 | } | ||
| 117 | |||
| 118 | UAny IREmitter::GetCbuf(const U32& binding, const U32& byte_offset, size_t bitsize, | ||
| 119 | bool is_signed) { | ||
| 120 | switch (bitsize) { | ||
| 121 | case 8: | ||
| 122 | return Inst<U32>(is_signed ? Opcode::GetCbufS8 : Opcode::GetCbufU8, binding, byte_offset); | ||
| 123 | case 16: | ||
| 124 | return Inst<U32>(is_signed ? Opcode::GetCbufS16 : Opcode::GetCbufU16, binding, byte_offset); | ||
| 125 | case 32: | ||
| 126 | return Inst<U32>(Opcode::GetCbufU32, binding, byte_offset); | ||
| 127 | case 64: | ||
| 128 | return Inst<U64>(Opcode::GetCbufU64, binding, byte_offset); | ||
| 129 | default: | ||
| 130 | throw InvalidArgument("Invalid bit size {}", bitsize); | ||
| 131 | } | ||
| 132 | } | ||
| 133 | |||
| 134 | F32 IREmitter::GetFloatCbuf(const U32& binding, const U32& byte_offset) { | ||
| 135 | return Inst<F32>(Opcode::GetCbufF32, binding, byte_offset); | ||
| 116 | } | 136 | } |
| 117 | 137 | ||
| 118 | U1 IREmitter::GetZFlag() { | 138 | U1 IREmitter::GetZFlag() { |