diff options
| author | 2020-02-01 02:57:01 -0300 | |
|---|---|---|
| committer | 2020-02-01 21:19:44 -0300 | |
| commit | 017474c3f89e5afcb3ffdb9fac3e412c40986092 (patch) | |
| tree | 4164fe82d9d5ee8abb9ac3ae7d7875d163195c9b /src/video_core/engines | |
| parent | Merge pull request #3350 from ReinUsesLisp/atom (diff) | |
| download | yuzu-017474c3f89e5afcb3ffdb9fac3e412c40986092.tar.gz yuzu-017474c3f89e5afcb3ffdb9fac3e412c40986092.tar.xz yuzu-017474c3f89e5afcb3ffdb9fac3e412c40986092.zip | |
shader/shift: Implement SHF_LEFT_{IMM,R}
Shifts a pair of registers to the left and returns the high register.
Diffstat (limited to 'src/video_core/engines')
| -rw-r--r-- | src/video_core/engines/shader_bytecode.h | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/src/video_core/engines/shader_bytecode.h b/src/video_core/engines/shader_bytecode.h index f443ec0fe..901adb97b 100644 --- a/src/video_core/engines/shader_bytecode.h +++ b/src/video_core/engines/shader_bytecode.h | |||
| @@ -624,6 +624,19 @@ enum class ShuffleOperation : u64 { | |||
| 624 | Bfly = 3, // shuffleXorNV | 624 | Bfly = 3, // shuffleXorNV |
| 625 | }; | 625 | }; |
| 626 | 626 | ||
| 627 | enum class ShfType : u64 { | ||
| 628 | Bits32 = 0, | ||
| 629 | U64 = 2, | ||
| 630 | S64 = 3, | ||
| 631 | }; | ||
| 632 | |||
| 633 | enum class ShfXmode : u64 { | ||
| 634 | None = 0, | ||
| 635 | HI = 1, | ||
| 636 | X = 2, | ||
| 637 | XHI = 3, | ||
| 638 | }; | ||
| 639 | |||
| 627 | union Instruction { | 640 | union Instruction { |
| 628 | constexpr Instruction& operator=(const Instruction& instr) { | 641 | constexpr Instruction& operator=(const Instruction& instr) { |
| 629 | value = instr.value; | 642 | value = instr.value; |
| @@ -776,6 +789,13 @@ union Instruction { | |||
| 776 | } shr; | 789 | } shr; |
| 777 | 790 | ||
| 778 | union { | 791 | union { |
| 792 | BitField<37, 2, ShfType> type; | ||
| 793 | BitField<48, 2, ShfXmode> xmode; | ||
| 794 | BitField<50, 1, u64> wrap; | ||
| 795 | BitField<20, 6, u64> immediate; | ||
| 796 | } shf; | ||
| 797 | |||
| 798 | union { | ||
| 779 | BitField<39, 5, u64> shift_amount; | 799 | BitField<39, 5, u64> shift_amount; |
| 780 | BitField<48, 1, u64> negate_b; | 800 | BitField<48, 1, u64> negate_b; |
| 781 | BitField<49, 1, u64> negate_a; | 801 | BitField<49, 1, u64> negate_a; |