summaryrefslogtreecommitdiff
path: root/src/video_core/engines
diff options
context:
space:
mode:
authorGravatar FernandoS272018-09-08 21:54:11 -0400
committerGravatar FernandoS272018-09-17 17:42:43 -0400
commitaac77bbd18f2b943b7259d8099241c4ec697b8f4 (patch)
treebfe66b24714d358f9486c5f6115ff1d25bfe8dfc /src/video_core/engines
parentMerge pull request #1311 from FernandoS27/fast-swizzle (diff)
downloadyuzu-aac77bbd18f2b943b7259d8099241c4ec697b8f4.tar.gz
yuzu-aac77bbd18f2b943b7259d8099241c4ec697b8f4.tar.xz
yuzu-aac77bbd18f2b943b7259d8099241c4ec697b8f4.zip
Implemented Control Codes
Diffstat (limited to 'src/video_core/engines')
-rw-r--r--src/video_core/engines/shader_bytecode.h36
1 files changed, 36 insertions, 0 deletions
diff --git a/src/video_core/engines/shader_bytecode.h b/src/video_core/engines/shader_bytecode.h
index 6e555ea03..12229cf4c 100644
--- a/src/video_core/engines/shader_bytecode.h
+++ b/src/video_core/engines/shader_bytecode.h
@@ -240,6 +240,41 @@ enum class FlowCondition : u64 {
240 Fcsm_Tr = 0x1C, // TODO(bunnei): What is this used for? 240 Fcsm_Tr = 0x1C, // TODO(bunnei): What is this used for?
241}; 241};
242 242
243enum class ControlCode : u64 {
244 F = 0,
245 LT = 1,
246 EQ = 2,
247 LE = 3,
248 GT = 4,
249 NE = 5,
250 GE = 6,
251 Num = 7,
252 Nan = 8,
253 LTU = 9,
254 EQU = 10,
255 LEU = 11,
256 GTU = 12,
257 NEU = 13,
258 GEU = 14,
259 //
260 OFF = 16,
261 LO = 17,
262 SFF = 18,
263 LS = 19,
264 HI = 20,
265 SFT = 21,
266 HS = 22,
267 OFT = 23,
268 CSM_TA = 24,
269 CSM_TR = 25,
270 CSM_MX = 26,
271 FCSM_TA = 27,
272 FCSM_TR = 28,
273 FCSM_MX = 29,
274 RLE = 30,
275 RGT = 31,
276};
277
243enum class PredicateResultMode : u64 { 278enum class PredicateResultMode : u64 {
244 None = 0x0, 279 None = 0x0,
245 NotZero = 0x3, 280 NotZero = 0x3,
@@ -735,6 +770,7 @@ union Instruction {
735 BitField<36, 5, u64> index; 770 BitField<36, 5, u64> index;
736 } cbuf36; 771 } cbuf36;
737 772
773 BitField<47, 1, u64> generates_cc;
738 BitField<61, 1, u64> is_b_imm; 774 BitField<61, 1, u64> is_b_imm;
739 BitField<60, 1, u64> is_b_gpr; 775 BitField<60, 1, u64> is_b_gpr;
740 BitField<59, 1, u64> is_c_gpr; 776 BitField<59, 1, u64> is_c_gpr;