diff options
| author | 2019-05-18 02:35:01 -0300 | |
|---|---|---|
| committer | 2019-05-20 22:38:59 -0300 | |
| commit | f78ef617b66e81b6095156fa0ff435cf8307aef7 (patch) | |
| tree | c822e8d45e7b33bd36f8778bff56f67a8e461fec /src/video_core/engines | |
| parent | Merge pull request #2455 from lioncash/config (diff) | |
| download | yuzu-f78ef617b66e81b6095156fa0ff435cf8307aef7.tar.gz yuzu-f78ef617b66e81b6095156fa0ff435cf8307aef7.tar.xz yuzu-f78ef617b66e81b6095156fa0ff435cf8307aef7.zip | |
shader/memory: Implement LD (generic memory)
Diffstat (limited to 'src/video_core/engines')
| -rw-r--r-- | src/video_core/engines/shader_bytecode.h | 19 |
1 files changed, 15 insertions, 4 deletions
diff --git a/src/video_core/engines/shader_bytecode.h b/src/video_core/engines/shader_bytecode.h index 7bbc556da..073b622ef 100644 --- a/src/video_core/engines/shader_bytecode.h +++ b/src/video_core/engines/shader_bytecode.h | |||
| @@ -530,6 +530,11 @@ union Instruction { | |||
| 530 | BitField<48, 16, u64> opcode; | 530 | BitField<48, 16, u64> opcode; |
| 531 | 531 | ||
| 532 | union { | 532 | union { |
| 533 | BitField<8, 8, Register> gpr; | ||
| 534 | BitField<20, 24, s64> offset; | ||
| 535 | } gmem; | ||
| 536 | |||
| 537 | union { | ||
| 533 | BitField<20, 16, u64> imm20_16; | 538 | BitField<20, 16, u64> imm20_16; |
| 534 | BitField<20, 19, u64> imm20_19; | 539 | BitField<20, 19, u64> imm20_19; |
| 535 | BitField<20, 32, s64> imm20_32; | 540 | BitField<20, 32, s64> imm20_32; |
| @@ -812,13 +817,11 @@ union Instruction { | |||
| 812 | union { | 817 | union { |
| 813 | BitField<48, 3, UniformType> type; | 818 | BitField<48, 3, UniformType> type; |
| 814 | BitField<46, 2, u64> cache_mode; | 819 | BitField<46, 2, u64> cache_mode; |
| 815 | BitField<20, 24, s64> immediate_offset; | ||
| 816 | } ldg; | 820 | } ldg; |
| 817 | 821 | ||
| 818 | union { | 822 | union { |
| 819 | BitField<48, 3, UniformType> type; | 823 | BitField<48, 3, UniformType> type; |
| 820 | BitField<46, 2, u64> cache_mode; | 824 | BitField<46, 2, u64> cache_mode; |
| 821 | BitField<20, 24, s64> immediate_offset; | ||
| 822 | } stg; | 825 | } stg; |
| 823 | 826 | ||
| 824 | union { | 827 | union { |
| @@ -828,6 +831,11 @@ union Instruction { | |||
| 828 | } al2p; | 831 | } al2p; |
| 829 | 832 | ||
| 830 | union { | 833 | union { |
| 834 | BitField<53, 3, UniformType> type; | ||
| 835 | BitField<52, 1, u64> extended; | ||
| 836 | } generic; | ||
| 837 | |||
| 838 | union { | ||
| 831 | BitField<0, 3, u64> pred0; | 839 | BitField<0, 3, u64> pred0; |
| 832 | BitField<3, 3, u64> pred3; | 840 | BitField<3, 3, u64> pred3; |
| 833 | BitField<7, 1, u64> abs_a; | 841 | BitField<7, 1, u64> abs_a; |
| @@ -1387,10 +1395,12 @@ public: | |||
| 1387 | LD_L, | 1395 | LD_L, |
| 1388 | LD_S, | 1396 | LD_S, |
| 1389 | LD_C, | 1397 | LD_C, |
| 1398 | LD, // Load from generic memory | ||
| 1399 | LDG, // Load from global memory | ||
| 1390 | ST_A, | 1400 | ST_A, |
| 1391 | ST_L, | 1401 | ST_L, |
| 1392 | ST_S, | 1402 | ST_S, |
| 1393 | LDG, // Load from global memory | 1403 | ST, // Store in generic memory |
| 1394 | STG, // Store in global memory | 1404 | STG, // Store in global memory |
| 1395 | AL2P, // Transforms attribute memory into physical memory | 1405 | AL2P, // Transforms attribute memory into physical memory |
| 1396 | TEX, | 1406 | TEX, |
| @@ -1658,10 +1668,11 @@ private: | |||
| 1658 | INST("1110111101001---", Id::LD_S, Type::Memory, "LD_S"), | 1668 | INST("1110111101001---", Id::LD_S, Type::Memory, "LD_S"), |
| 1659 | INST("1110111101000---", Id::LD_L, Type::Memory, "LD_L"), | 1669 | INST("1110111101000---", Id::LD_L, Type::Memory, "LD_L"), |
| 1660 | INST("1110111110010---", Id::LD_C, Type::Memory, "LD_C"), | 1670 | INST("1110111110010---", Id::LD_C, Type::Memory, "LD_C"), |
| 1671 | INST("100-------------", Id::LD, Type::Memory, "LD"), | ||
| 1672 | INST("1110111011010---", Id::LDG, Type::Memory, "LDG"), | ||
| 1661 | INST("1110111111110---", Id::ST_A, Type::Memory, "ST_A"), | 1673 | INST("1110111111110---", Id::ST_A, Type::Memory, "ST_A"), |
| 1662 | INST("1110111101011---", Id::ST_S, Type::Memory, "ST_S"), | 1674 | INST("1110111101011---", Id::ST_S, Type::Memory, "ST_S"), |
| 1663 | INST("1110111101010---", Id::ST_L, Type::Memory, "ST_L"), | 1675 | INST("1110111101010---", Id::ST_L, Type::Memory, "ST_L"), |
| 1664 | INST("1110111011010---", Id::LDG, Type::Memory, "LDG"), | ||
| 1665 | INST("1110111011011---", Id::STG, Type::Memory, "STG"), | 1676 | INST("1110111011011---", Id::STG, Type::Memory, "STG"), |
| 1666 | INST("1110111110100---", Id::AL2P, Type::Memory, "AL2P"), | 1677 | INST("1110111110100---", Id::AL2P, Type::Memory, "AL2P"), |
| 1667 | INST("110000----111---", Id::TEX, Type::Texture, "TEX"), | 1678 | INST("110000----111---", Id::TEX, Type::Texture, "TEX"), |