[Base] RingBuffer: Add ReadAndSwap instead of piggybacking off of Read
This commit is contained in:
parent
705fd7594a
commit
ffef59aaa5
|
@ -12,6 +12,7 @@
|
||||||
|
|
||||||
#include <cstdint>
|
#include <cstdint>
|
||||||
#include <string>
|
#include <string>
|
||||||
|
#include <type_traits>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
#include "xenia/base/assert.h"
|
#include "xenia/base/assert.h"
|
||||||
|
@ -72,16 +73,25 @@ class RingBuffer {
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
T Read(bool swap = false) {
|
T Read() {
|
||||||
static_assert(sizeof(T) <= 8, "Immediate read only supports basic types!");
|
static_assert(std::is_fundamental<T>::value,
|
||||||
|
"Immediate read only supports basic types!");
|
||||||
|
|
||||||
T imm;
|
T imm;
|
||||||
size_t read = Read(reinterpret_cast<uint8_t*>(&imm), sizeof(T));
|
size_t read = Read(reinterpret_cast<uint8_t*>(&imm), sizeof(T));
|
||||||
assert_true(read == sizeof(T));
|
assert_true(read == sizeof(T));
|
||||||
if (swap) {
|
return imm;
|
||||||
imm = xe::byte_swap(imm);
|
}
|
||||||
}
|
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
T ReadAndSwap() {
|
||||||
|
static_assert(std::is_fundamental<T>::value,
|
||||||
|
"Immediate read only supports basic types!");
|
||||||
|
|
||||||
|
T imm;
|
||||||
|
size_t read = Read(reinterpret_cast<uint8_t*>(&imm), sizeof(T));
|
||||||
|
assert_true(read == sizeof(T));
|
||||||
|
imm = xe::byte_swap(imm);
|
||||||
return imm;
|
return imm;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -443,7 +443,7 @@ void CommandProcessor::ExecutePacket(uint32_t ptr, uint32_t count) {
|
||||||
}
|
}
|
||||||
|
|
||||||
bool CommandProcessor::ExecutePacket(RingBuffer* reader) {
|
bool CommandProcessor::ExecutePacket(RingBuffer* reader) {
|
||||||
const uint32_t packet = reader->Read<uint32_t>(true);
|
const uint32_t packet = reader->ReadAndSwap<uint32_t>();
|
||||||
const uint32_t packet_type = packet >> 30;
|
const uint32_t packet_type = packet >> 30;
|
||||||
if (packet == 0) {
|
if (packet == 0) {
|
||||||
trace_writer_.WritePacketStart(uint32_t(reader->read_ptr() - 4), 1);
|
trace_writer_.WritePacketStart(uint32_t(reader->read_ptr() - 4), 1);
|
||||||
|
@ -483,7 +483,7 @@ bool CommandProcessor::ExecutePacketType0(RingBuffer* reader, uint32_t packet) {
|
||||||
uint32_t base_index = (packet & 0x7FFF);
|
uint32_t base_index = (packet & 0x7FFF);
|
||||||
uint32_t write_one_reg = (packet >> 15) & 0x1;
|
uint32_t write_one_reg = (packet >> 15) & 0x1;
|
||||||
for (uint32_t m = 0; m < count; m++) {
|
for (uint32_t m = 0; m < count; m++) {
|
||||||
uint32_t reg_data = reader->Read<uint32_t>(true);
|
uint32_t reg_data = reader->ReadAndSwap<uint32_t>();
|
||||||
uint32_t target_index = write_one_reg ? base_index : base_index + m;
|
uint32_t target_index = write_one_reg ? base_index : base_index + m;
|
||||||
WriteRegister(target_index, reg_data);
|
WriteRegister(target_index, reg_data);
|
||||||
}
|
}
|
||||||
|
@ -498,8 +498,8 @@ bool CommandProcessor::ExecutePacketType1(RingBuffer* reader, uint32_t packet) {
|
||||||
trace_writer_.WritePacketStart(uint32_t(reader->read_ptr() - 4), 3);
|
trace_writer_.WritePacketStart(uint32_t(reader->read_ptr() - 4), 3);
|
||||||
uint32_t reg_index_1 = packet & 0x7FF;
|
uint32_t reg_index_1 = packet & 0x7FF;
|
||||||
uint32_t reg_index_2 = (packet >> 11) & 0x7FF;
|
uint32_t reg_index_2 = (packet >> 11) & 0x7FF;
|
||||||
uint32_t reg_data_1 = reader->Read<uint32_t>(true);
|
uint32_t reg_data_1 = reader->ReadAndSwap<uint32_t>();
|
||||||
uint32_t reg_data_2 = reader->Read<uint32_t>(true);
|
uint32_t reg_data_2 = reader->ReadAndSwap<uint32_t>();
|
||||||
WriteRegister(reg_index_1, reg_data_1);
|
WriteRegister(reg_index_1, reg_data_1);
|
||||||
WriteRegister(reg_index_2, reg_data_2);
|
WriteRegister(reg_index_2, reg_data_2);
|
||||||
trace_writer_.WritePacketEnd();
|
trace_writer_.WritePacketEnd();
|
||||||
|
@ -622,38 +622,38 @@ bool CommandProcessor::ExecutePacketType3(RingBuffer* reader, uint32_t packet) {
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case PM4_SET_BIN_MASK_LO: {
|
case PM4_SET_BIN_MASK_LO: {
|
||||||
uint32_t value = reader->Read<uint32_t>(true);
|
uint32_t value = reader->ReadAndSwap<uint32_t>();
|
||||||
bin_mask_ = (bin_mask_ & 0xFFFFFFFF00000000ull) | value;
|
bin_mask_ = (bin_mask_ & 0xFFFFFFFF00000000ull) | value;
|
||||||
result = true;
|
result = true;
|
||||||
} break;
|
} break;
|
||||||
case PM4_SET_BIN_MASK_HI: {
|
case PM4_SET_BIN_MASK_HI: {
|
||||||
uint32_t value = reader->Read<uint32_t>(true);
|
uint32_t value = reader->ReadAndSwap<uint32_t>();
|
||||||
bin_mask_ =
|
bin_mask_ =
|
||||||
(bin_mask_ & 0xFFFFFFFFull) | (static_cast<uint64_t>(value) << 32);
|
(bin_mask_ & 0xFFFFFFFFull) | (static_cast<uint64_t>(value) << 32);
|
||||||
result = true;
|
result = true;
|
||||||
} break;
|
} break;
|
||||||
case PM4_SET_BIN_SELECT_LO: {
|
case PM4_SET_BIN_SELECT_LO: {
|
||||||
uint32_t value = reader->Read<uint32_t>(true);
|
uint32_t value = reader->ReadAndSwap<uint32_t>();
|
||||||
bin_select_ = (bin_select_ & 0xFFFFFFFF00000000ull) | value;
|
bin_select_ = (bin_select_ & 0xFFFFFFFF00000000ull) | value;
|
||||||
result = true;
|
result = true;
|
||||||
} break;
|
} break;
|
||||||
case PM4_SET_BIN_SELECT_HI: {
|
case PM4_SET_BIN_SELECT_HI: {
|
||||||
uint32_t value = reader->Read<uint32_t>(true);
|
uint32_t value = reader->ReadAndSwap<uint32_t>();
|
||||||
bin_select_ =
|
bin_select_ =
|
||||||
(bin_select_ & 0xFFFFFFFFull) | (static_cast<uint64_t>(value) << 32);
|
(bin_select_ & 0xFFFFFFFFull) | (static_cast<uint64_t>(value) << 32);
|
||||||
result = true;
|
result = true;
|
||||||
} break;
|
} break;
|
||||||
case PM4_SET_BIN_MASK: {
|
case PM4_SET_BIN_MASK: {
|
||||||
assert_true(count == 2);
|
assert_true(count == 2);
|
||||||
uint64_t val_hi = reader->Read<uint32_t>(true);
|
uint64_t val_hi = reader->ReadAndSwap<uint32_t>();
|
||||||
uint64_t val_lo = reader->Read<uint32_t>(true);
|
uint64_t val_lo = reader->ReadAndSwap<uint32_t>();
|
||||||
bin_mask_ = (val_hi << 32) | val_lo;
|
bin_mask_ = (val_hi << 32) | val_lo;
|
||||||
result = true;
|
result = true;
|
||||||
} break;
|
} break;
|
||||||
case PM4_SET_BIN_SELECT: {
|
case PM4_SET_BIN_SELECT: {
|
||||||
assert_true(count == 2);
|
assert_true(count == 2);
|
||||||
uint64_t val_hi = reader->Read<uint32_t>(true);
|
uint64_t val_hi = reader->ReadAndSwap<uint32_t>();
|
||||||
uint64_t val_lo = reader->Read<uint32_t>(true);
|
uint64_t val_lo = reader->ReadAndSwap<uint32_t>();
|
||||||
bin_select_ = (val_hi << 32) | val_lo;
|
bin_select_ = (val_hi << 32) | val_lo;
|
||||||
result = true;
|
result = true;
|
||||||
} break;
|
} break;
|
||||||
|
@ -713,7 +713,7 @@ bool CommandProcessor::ExecutePacketType3_INTERRUPT(RingBuffer* reader,
|
||||||
SCOPE_profile_cpu_f("gpu");
|
SCOPE_profile_cpu_f("gpu");
|
||||||
|
|
||||||
// generate interrupt from the command stream
|
// generate interrupt from the command stream
|
||||||
uint32_t cpu_mask = reader->Read<uint32_t>(true);
|
uint32_t cpu_mask = reader->ReadAndSwap<uint32_t>();
|
||||||
for (int n = 0; n < 6; n++) {
|
for (int n = 0; n < 6; n++) {
|
||||||
if (cpu_mask & (1 << n)) {
|
if (cpu_mask & (1 << n)) {
|
||||||
graphics_system_->DispatchInterruptCallback(1, n);
|
graphics_system_->DispatchInterruptCallback(1, n);
|
||||||
|
@ -735,13 +735,13 @@ bool CommandProcessor::ExecutePacketType3_XE_SWAP(RingBuffer* reader,
|
||||||
// VdSwap will post this to tell us we need to swap the screen/fire an
|
// VdSwap will post this to tell us we need to swap the screen/fire an
|
||||||
// interrupt.
|
// interrupt.
|
||||||
// 63 words here, but only the first has any data.
|
// 63 words here, but only the first has any data.
|
||||||
uint32_t magic = reader->Read<uint32_t>(true);
|
uint32_t magic = reader->ReadAndSwap<uint32_t>();
|
||||||
assert_true(magic == 'SWAP');
|
assert_true(magic == 'SWAP');
|
||||||
|
|
||||||
// TODO(benvanik): only swap frontbuffer ptr.
|
// TODO(benvanik): only swap frontbuffer ptr.
|
||||||
uint32_t frontbuffer_ptr = reader->Read<uint32_t>(true);
|
uint32_t frontbuffer_ptr = reader->ReadAndSwap<uint32_t>();
|
||||||
uint32_t frontbuffer_width = reader->Read<uint32_t>(true);
|
uint32_t frontbuffer_width = reader->ReadAndSwap<uint32_t>();
|
||||||
uint32_t frontbuffer_height = reader->Read<uint32_t>(true);
|
uint32_t frontbuffer_height = reader->ReadAndSwap<uint32_t>();
|
||||||
reader->AdvanceRead((count - 4) * sizeof(uint32_t));
|
reader->AdvanceRead((count - 4) * sizeof(uint32_t));
|
||||||
|
|
||||||
if (swap_mode_ == SwapMode::kNormal) {
|
if (swap_mode_ == SwapMode::kNormal) {
|
||||||
|
@ -756,8 +756,8 @@ bool CommandProcessor::ExecutePacketType3_INDIRECT_BUFFER(RingBuffer* reader,
|
||||||
uint32_t packet,
|
uint32_t packet,
|
||||||
uint32_t count) {
|
uint32_t count) {
|
||||||
// indirect buffer dispatch
|
// indirect buffer dispatch
|
||||||
uint32_t list_ptr = CpuToGpu(reader->Read<uint32_t>(true));
|
uint32_t list_ptr = CpuToGpu(reader->ReadAndSwap<uint32_t>());
|
||||||
uint32_t list_length = reader->Read<uint32_t>(true);
|
uint32_t list_length = reader->ReadAndSwap<uint32_t>();
|
||||||
assert_zero(list_length & ~0xFFFFF);
|
assert_zero(list_length & ~0xFFFFF);
|
||||||
list_length &= 0xFFFFF;
|
list_length &= 0xFFFFF;
|
||||||
ExecuteIndirectBuffer(GpuToCpu(list_ptr), list_length);
|
ExecuteIndirectBuffer(GpuToCpu(list_ptr), list_length);
|
||||||
|
@ -770,11 +770,11 @@ bool CommandProcessor::ExecutePacketType3_WAIT_REG_MEM(RingBuffer* reader,
|
||||||
SCOPE_profile_cpu_f("gpu");
|
SCOPE_profile_cpu_f("gpu");
|
||||||
|
|
||||||
// wait until a register or memory location is a specific value
|
// wait until a register or memory location is a specific value
|
||||||
uint32_t wait_info = reader->Read<uint32_t>(true);
|
uint32_t wait_info = reader->ReadAndSwap<uint32_t>();
|
||||||
uint32_t poll_reg_addr = reader->Read<uint32_t>(true);
|
uint32_t poll_reg_addr = reader->ReadAndSwap<uint32_t>();
|
||||||
uint32_t ref = reader->Read<uint32_t>(true);
|
uint32_t ref = reader->ReadAndSwap<uint32_t>();
|
||||||
uint32_t mask = reader->Read<uint32_t>(true);
|
uint32_t mask = reader->ReadAndSwap<uint32_t>();
|
||||||
uint32_t wait = reader->Read<uint32_t>(true);
|
uint32_t wait = reader->ReadAndSwap<uint32_t>();
|
||||||
bool matched = false;
|
bool matched = false;
|
||||||
do {
|
do {
|
||||||
uint32_t value;
|
uint32_t value;
|
||||||
|
@ -851,9 +851,9 @@ bool CommandProcessor::ExecutePacketType3_REG_RMW(RingBuffer* reader,
|
||||||
uint32_t count) {
|
uint32_t count) {
|
||||||
// register read/modify/write
|
// register read/modify/write
|
||||||
// ? (used during shader upload and edram setup)
|
// ? (used during shader upload and edram setup)
|
||||||
uint32_t rmw_info = reader->Read<uint32_t>(true);
|
uint32_t rmw_info = reader->ReadAndSwap<uint32_t>();
|
||||||
uint32_t and_mask = reader->Read<uint32_t>(true);
|
uint32_t and_mask = reader->ReadAndSwap<uint32_t>();
|
||||||
uint32_t or_mask = reader->Read<uint32_t>(true);
|
uint32_t or_mask = reader->ReadAndSwap<uint32_t>();
|
||||||
uint32_t value = register_file_->values[rmw_info & 0x1FFF].u32;
|
uint32_t value = register_file_->values[rmw_info & 0x1FFF].u32;
|
||||||
if ((rmw_info >> 31) & 0x1) {
|
if ((rmw_info >> 31) & 0x1) {
|
||||||
// & reg
|
// & reg
|
||||||
|
@ -879,8 +879,8 @@ bool CommandProcessor::ExecutePacketType3_REG_TO_MEM(RingBuffer* reader,
|
||||||
// Copy Register to Memory (?)
|
// Copy Register to Memory (?)
|
||||||
// Count is 2, assuming a Register Addr and a Memory Addr.
|
// Count is 2, assuming a Register Addr and a Memory Addr.
|
||||||
|
|
||||||
uint32_t reg_addr = reader->Read<uint32_t>(true);
|
uint32_t reg_addr = reader->ReadAndSwap<uint32_t>();
|
||||||
uint32_t mem_addr = reader->Read<uint32_t>(true);
|
uint32_t mem_addr = reader->ReadAndSwap<uint32_t>();
|
||||||
|
|
||||||
uint32_t reg_val;
|
uint32_t reg_val;
|
||||||
|
|
||||||
|
@ -899,9 +899,9 @@ bool CommandProcessor::ExecutePacketType3_REG_TO_MEM(RingBuffer* reader,
|
||||||
bool CommandProcessor::ExecutePacketType3_MEM_WRITE(RingBuffer* reader,
|
bool CommandProcessor::ExecutePacketType3_MEM_WRITE(RingBuffer* reader,
|
||||||
uint32_t packet,
|
uint32_t packet,
|
||||||
uint32_t count) {
|
uint32_t count) {
|
||||||
uint32_t write_addr = reader->Read<uint32_t>(true);
|
uint32_t write_addr = reader->ReadAndSwap<uint32_t>();
|
||||||
for (uint32_t i = 0; i < count - 1; i++) {
|
for (uint32_t i = 0; i < count - 1; i++) {
|
||||||
uint32_t write_data = reader->Read<uint32_t>(true);
|
uint32_t write_data = reader->ReadAndSwap<uint32_t>();
|
||||||
|
|
||||||
auto endianness = static_cast<Endian>(write_addr & 0x3);
|
auto endianness = static_cast<Endian>(write_addr & 0x3);
|
||||||
auto addr = write_addr & ~0x3;
|
auto addr = write_addr & ~0x3;
|
||||||
|
@ -918,12 +918,12 @@ bool CommandProcessor::ExecutePacketType3_COND_WRITE(RingBuffer* reader,
|
||||||
uint32_t packet,
|
uint32_t packet,
|
||||||
uint32_t count) {
|
uint32_t count) {
|
||||||
// conditional write to memory or register
|
// conditional write to memory or register
|
||||||
uint32_t wait_info = reader->Read<uint32_t>(true);
|
uint32_t wait_info = reader->ReadAndSwap<uint32_t>();
|
||||||
uint32_t poll_reg_addr = reader->Read<uint32_t>(true);
|
uint32_t poll_reg_addr = reader->ReadAndSwap<uint32_t>();
|
||||||
uint32_t ref = reader->Read<uint32_t>(true);
|
uint32_t ref = reader->ReadAndSwap<uint32_t>();
|
||||||
uint32_t mask = reader->Read<uint32_t>(true);
|
uint32_t mask = reader->ReadAndSwap<uint32_t>();
|
||||||
uint32_t write_reg_addr = reader->Read<uint32_t>(true);
|
uint32_t write_reg_addr = reader->ReadAndSwap<uint32_t>();
|
||||||
uint32_t write_data = reader->Read<uint32_t>(true);
|
uint32_t write_data = reader->ReadAndSwap<uint32_t>();
|
||||||
uint32_t value;
|
uint32_t value;
|
||||||
if (wait_info & 0x10) {
|
if (wait_info & 0x10) {
|
||||||
// Memory.
|
// Memory.
|
||||||
|
@ -985,7 +985,7 @@ bool CommandProcessor::ExecutePacketType3_EVENT_WRITE(RingBuffer* reader,
|
||||||
uint32_t packet,
|
uint32_t packet,
|
||||||
uint32_t count) {
|
uint32_t count) {
|
||||||
// generate an event that creates a write to memory when completed
|
// generate an event that creates a write to memory when completed
|
||||||
uint32_t initiator = reader->Read<uint32_t>(true);
|
uint32_t initiator = reader->ReadAndSwap<uint32_t>();
|
||||||
// Writeback initiator.
|
// Writeback initiator.
|
||||||
WriteRegister(XE_GPU_REG_VGT_EVENT_INITIATOR, initiator & 0x3F);
|
WriteRegister(XE_GPU_REG_VGT_EVENT_INITIATOR, initiator & 0x3F);
|
||||||
if (count == 1) {
|
if (count == 1) {
|
||||||
|
@ -1002,9 +1002,9 @@ bool CommandProcessor::ExecutePacketType3_EVENT_WRITE_SHD(RingBuffer* reader,
|
||||||
uint32_t packet,
|
uint32_t packet,
|
||||||
uint32_t count) {
|
uint32_t count) {
|
||||||
// generate a VS|PS_done event
|
// generate a VS|PS_done event
|
||||||
uint32_t initiator = reader->Read<uint32_t>(true);
|
uint32_t initiator = reader->ReadAndSwap<uint32_t>();
|
||||||
uint32_t address = reader->Read<uint32_t>(true);
|
uint32_t address = reader->ReadAndSwap<uint32_t>();
|
||||||
uint32_t value = reader->Read<uint32_t>(true);
|
uint32_t value = reader->ReadAndSwap<uint32_t>();
|
||||||
// Writeback initiator.
|
// Writeback initiator.
|
||||||
WriteRegister(XE_GPU_REG_VGT_EVENT_INITIATOR, initiator & 0x3F);
|
WriteRegister(XE_GPU_REG_VGT_EVENT_INITIATOR, initiator & 0x3F);
|
||||||
uint32_t data_value;
|
uint32_t data_value;
|
||||||
|
@ -1027,8 +1027,8 @@ bool CommandProcessor::ExecutePacketType3_EVENT_WRITE_EXT(RingBuffer* reader,
|
||||||
uint32_t packet,
|
uint32_t packet,
|
||||||
uint32_t count) {
|
uint32_t count) {
|
||||||
// generate a screen extent event
|
// generate a screen extent event
|
||||||
uint32_t initiator = reader->Read<uint32_t>(true);
|
uint32_t initiator = reader->ReadAndSwap<uint32_t>();
|
||||||
uint32_t address = reader->Read<uint32_t>(true);
|
uint32_t address = reader->ReadAndSwap<uint32_t>();
|
||||||
// Writeback initiator.
|
// Writeback initiator.
|
||||||
WriteRegister(XE_GPU_REG_VGT_EVENT_INITIATOR, initiator & 0x3F);
|
WriteRegister(XE_GPU_REG_VGT_EVENT_INITIATOR, initiator & 0x3F);
|
||||||
auto endianness = static_cast<Endian>(address & 0x3);
|
auto endianness = static_cast<Endian>(address & 0x3);
|
||||||
|
@ -1057,7 +1057,7 @@ bool CommandProcessor::ExecutePacketType3_EVENT_WRITE_ZPD(RingBuffer* reader,
|
||||||
uint32_t packet,
|
uint32_t packet,
|
||||||
uint32_t count) {
|
uint32_t count) {
|
||||||
assert_true(count == 1);
|
assert_true(count == 1);
|
||||||
uint32_t initiator = reader->Read<uint32_t>(true);
|
uint32_t initiator = reader->ReadAndSwap<uint32_t>();
|
||||||
// Writeback initiator.
|
// Writeback initiator.
|
||||||
WriteRegister(XE_GPU_REG_VGT_EVENT_INITIATOR, initiator & 0x3F);
|
WriteRegister(XE_GPU_REG_VGT_EVENT_INITIATOR, initiator & 0x3F);
|
||||||
|
|
||||||
|
@ -1076,8 +1076,8 @@ bool CommandProcessor::ExecutePacketType3_DRAW_INDX(RingBuffer* reader,
|
||||||
// This ID matches the one issued in PM4_VIZ_QUERY
|
// This ID matches the one issued in PM4_VIZ_QUERY
|
||||||
// ID = dword0 & 0x3F;
|
// ID = dword0 & 0x3F;
|
||||||
// use = dword0 & 0x40;
|
// use = dword0 & 0x40;
|
||||||
uint32_t dword0 = reader->Read<uint32_t>(true); // viz query info
|
uint32_t dword0 = reader->ReadAndSwap<uint32_t>(); // viz query info
|
||||||
uint32_t dword1 = reader->Read<uint32_t>(true);
|
uint32_t dword1 = reader->ReadAndSwap<uint32_t>();
|
||||||
uint32_t index_count = dword1 >> 16;
|
uint32_t index_count = dword1 >> 16;
|
||||||
auto prim_type = static_cast<PrimitiveType>(dword1 & 0x3F);
|
auto prim_type = static_cast<PrimitiveType>(dword1 & 0x3F);
|
||||||
bool is_indexed = false;
|
bool is_indexed = false;
|
||||||
|
@ -1087,8 +1087,8 @@ bool CommandProcessor::ExecutePacketType3_DRAW_INDX(RingBuffer* reader,
|
||||||
// DI_SRC_SEL_DMA
|
// DI_SRC_SEL_DMA
|
||||||
// Indexed draw.
|
// Indexed draw.
|
||||||
is_indexed = true;
|
is_indexed = true;
|
||||||
index_buffer_info.guest_base = reader->Read<uint32_t>(true);
|
index_buffer_info.guest_base = reader->ReadAndSwap<uint32_t>();
|
||||||
uint32_t index_size = reader->Read<uint32_t>(true);
|
uint32_t index_size = reader->ReadAndSwap<uint32_t>();
|
||||||
index_buffer_info.endianness = static_cast<Endian>(index_size >> 30);
|
index_buffer_info.endianness = static_cast<Endian>(index_size >> 30);
|
||||||
index_size &= 0x00FFFFFF;
|
index_size &= 0x00FFFFFF;
|
||||||
bool index_32bit = (dword1 >> 11) & 0x1;
|
bool index_32bit = (dword1 >> 11) & 0x1;
|
||||||
|
@ -1124,7 +1124,7 @@ bool CommandProcessor::ExecutePacketType3_DRAW_INDX_2(RingBuffer* reader,
|
||||||
uint32_t packet,
|
uint32_t packet,
|
||||||
uint32_t count) {
|
uint32_t count) {
|
||||||
// draw using supplied indices in packet
|
// draw using supplied indices in packet
|
||||||
uint32_t dword0 = reader->Read<uint32_t>(true);
|
uint32_t dword0 = reader->ReadAndSwap<uint32_t>();
|
||||||
uint32_t index_count = dword0 >> 16;
|
uint32_t index_count = dword0 >> 16;
|
||||||
auto prim_type = static_cast<PrimitiveType>(dword0 & 0x3F);
|
auto prim_type = static_cast<PrimitiveType>(dword0 & 0x3F);
|
||||||
uint32_t src_sel = (dword0 >> 6) & 0x3;
|
uint32_t src_sel = (dword0 >> 6) & 0x3;
|
||||||
|
@ -1150,7 +1150,7 @@ bool CommandProcessor::ExecutePacketType3_SET_CONSTANT(RingBuffer* reader,
|
||||||
// load constant into chip and to memory
|
// load constant into chip and to memory
|
||||||
// PM4_REG(reg) ((0x4 << 16) | (GSL_HAL_SUBBLOCK_OFFSET(reg)))
|
// PM4_REG(reg) ((0x4 << 16) | (GSL_HAL_SUBBLOCK_OFFSET(reg)))
|
||||||
// reg - 0x2000
|
// reg - 0x2000
|
||||||
uint32_t offset_type = reader->Read<uint32_t>(true);
|
uint32_t offset_type = reader->ReadAndSwap<uint32_t>();
|
||||||
uint32_t index = offset_type & 0x7FF;
|
uint32_t index = offset_type & 0x7FF;
|
||||||
uint32_t type = (offset_type >> 16) & 0xFF;
|
uint32_t type = (offset_type >> 16) & 0xFF;
|
||||||
switch (type) {
|
switch (type) {
|
||||||
|
@ -1175,7 +1175,7 @@ bool CommandProcessor::ExecutePacketType3_SET_CONSTANT(RingBuffer* reader,
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
for (uint32_t n = 0; n < count - 1; n++, index++) {
|
for (uint32_t n = 0; n < count - 1; n++, index++) {
|
||||||
uint32_t data = reader->Read<uint32_t>(true);
|
uint32_t data = reader->ReadAndSwap<uint32_t>();
|
||||||
WriteRegister(index, data);
|
WriteRegister(index, data);
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
|
@ -1184,10 +1184,10 @@ bool CommandProcessor::ExecutePacketType3_SET_CONSTANT(RingBuffer* reader,
|
||||||
bool CommandProcessor::ExecutePacketType3_SET_CONSTANT2(RingBuffer* reader,
|
bool CommandProcessor::ExecutePacketType3_SET_CONSTANT2(RingBuffer* reader,
|
||||||
uint32_t packet,
|
uint32_t packet,
|
||||||
uint32_t count) {
|
uint32_t count) {
|
||||||
uint32_t offset_type = reader->Read<uint32_t>(true);
|
uint32_t offset_type = reader->ReadAndSwap<uint32_t>();
|
||||||
uint32_t index = offset_type & 0xFFFF;
|
uint32_t index = offset_type & 0xFFFF;
|
||||||
for (uint32_t n = 0; n < count - 1; n++, index++) {
|
for (uint32_t n = 0; n < count - 1; n++, index++) {
|
||||||
uint32_t data = reader->Read<uint32_t>(true);
|
uint32_t data = reader->ReadAndSwap<uint32_t>();
|
||||||
WriteRegister(index, data);
|
WriteRegister(index, data);
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
|
@ -1197,11 +1197,11 @@ bool CommandProcessor::ExecutePacketType3_LOAD_ALU_CONSTANT(RingBuffer* reader,
|
||||||
uint32_t packet,
|
uint32_t packet,
|
||||||
uint32_t count) {
|
uint32_t count) {
|
||||||
// load constants from memory
|
// load constants from memory
|
||||||
uint32_t address = reader->Read<uint32_t>(true);
|
uint32_t address = reader->ReadAndSwap<uint32_t>();
|
||||||
address &= 0x3FFFFFFF;
|
address &= 0x3FFFFFFF;
|
||||||
uint32_t offset_type = reader->Read<uint32_t>(true);
|
uint32_t offset_type = reader->ReadAndSwap<uint32_t>();
|
||||||
uint32_t index = offset_type & 0x7FF;
|
uint32_t index = offset_type & 0x7FF;
|
||||||
uint32_t size_dwords = reader->Read<uint32_t>(true);
|
uint32_t size_dwords = reader->ReadAndSwap<uint32_t>();
|
||||||
size_dwords &= 0xFFF;
|
size_dwords &= 0xFFF;
|
||||||
uint32_t type = (offset_type >> 16) & 0xFF;
|
uint32_t type = (offset_type >> 16) & 0xFF;
|
||||||
switch (type) {
|
switch (type) {
|
||||||
|
@ -1235,10 +1235,10 @@ bool CommandProcessor::ExecutePacketType3_LOAD_ALU_CONSTANT(RingBuffer* reader,
|
||||||
|
|
||||||
bool CommandProcessor::ExecutePacketType3_SET_SHADER_CONSTANTS(
|
bool CommandProcessor::ExecutePacketType3_SET_SHADER_CONSTANTS(
|
||||||
RingBuffer* reader, uint32_t packet, uint32_t count) {
|
RingBuffer* reader, uint32_t packet, uint32_t count) {
|
||||||
uint32_t offset_type = reader->Read<uint32_t>(true);
|
uint32_t offset_type = reader->ReadAndSwap<uint32_t>();
|
||||||
uint32_t index = offset_type & 0xFFFF;
|
uint32_t index = offset_type & 0xFFFF;
|
||||||
for (uint32_t n = 0; n < count - 1; n++, index++) {
|
for (uint32_t n = 0; n < count - 1; n++, index++) {
|
||||||
uint32_t data = reader->Read<uint32_t>(true);
|
uint32_t data = reader->ReadAndSwap<uint32_t>();
|
||||||
WriteRegister(index, data);
|
WriteRegister(index, data);
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
|
@ -1250,10 +1250,10 @@ bool CommandProcessor::ExecutePacketType3_IM_LOAD(RingBuffer* reader,
|
||||||
SCOPE_profile_cpu_f("gpu");
|
SCOPE_profile_cpu_f("gpu");
|
||||||
|
|
||||||
// load sequencer instruction memory (pointer-based)
|
// load sequencer instruction memory (pointer-based)
|
||||||
uint32_t addr_type = reader->Read<uint32_t>(true);
|
uint32_t addr_type = reader->ReadAndSwap<uint32_t>();
|
||||||
auto shader_type = static_cast<ShaderType>(addr_type & 0x3);
|
auto shader_type = static_cast<ShaderType>(addr_type & 0x3);
|
||||||
uint32_t addr = addr_type & ~0x3;
|
uint32_t addr = addr_type & ~0x3;
|
||||||
uint32_t start_size = reader->Read<uint32_t>(true);
|
uint32_t start_size = reader->ReadAndSwap<uint32_t>();
|
||||||
uint32_t start = start_size >> 16;
|
uint32_t start = start_size >> 16;
|
||||||
uint32_t size_dwords = start_size & 0xFFFF; // dwords
|
uint32_t size_dwords = start_size & 0xFFFF; // dwords
|
||||||
assert_true(start == 0);
|
assert_true(start == 0);
|
||||||
|
@ -1281,8 +1281,8 @@ bool CommandProcessor::ExecutePacketType3_IM_LOAD_IMMEDIATE(RingBuffer* reader,
|
||||||
SCOPE_profile_cpu_f("gpu");
|
SCOPE_profile_cpu_f("gpu");
|
||||||
|
|
||||||
// load sequencer instruction memory (code embedded in packet)
|
// load sequencer instruction memory (code embedded in packet)
|
||||||
uint32_t dword0 = reader->Read<uint32_t>(true);
|
uint32_t dword0 = reader->ReadAndSwap<uint32_t>();
|
||||||
uint32_t dword1 = reader->Read<uint32_t>(true);
|
uint32_t dword1 = reader->ReadAndSwap<uint32_t>();
|
||||||
auto shader_type = static_cast<ShaderType>(dword0);
|
auto shader_type = static_cast<ShaderType>(dword0);
|
||||||
uint32_t start_size = dword1;
|
uint32_t start_size = dword1;
|
||||||
uint32_t start = start_size >> 16;
|
uint32_t start = start_size >> 16;
|
||||||
|
@ -1312,7 +1312,7 @@ bool CommandProcessor::ExecutePacketType3_INVALIDATE_STATE(RingBuffer* reader,
|
||||||
uint32_t packet,
|
uint32_t packet,
|
||||||
uint32_t count) {
|
uint32_t count) {
|
||||||
// selective invalidation of state pointers
|
// selective invalidation of state pointers
|
||||||
/*uint32_t mask =*/reader->Read<uint32_t>(true);
|
/*uint32_t mask =*/reader->ReadAndSwap<uint32_t>();
|
||||||
// driver_->InvalidateState(mask);
|
// driver_->InvalidateState(mask);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -1324,7 +1324,7 @@ bool CommandProcessor::ExecutePacketType3_VIZ_QUERY(RingBuffer* reader,
|
||||||
// http://www.google.com/patents/US20050195186
|
// http://www.google.com/patents/US20050195186
|
||||||
assert_true(count == 1);
|
assert_true(count == 1);
|
||||||
|
|
||||||
uint32_t dword0 = reader->Read<uint32_t>(true);
|
uint32_t dword0 = reader->ReadAndSwap<uint32_t>();
|
||||||
|
|
||||||
uint32_t id = dword0 & 0x3F;
|
uint32_t id = dword0 & 0x3F;
|
||||||
uint32_t end = dword0 & 0x80;
|
uint32_t end = dword0 & 0x80;
|
||||||
|
|
Loading…
Reference in New Issue