D3DStreamBuffer: Use size_t within the class interface
A few StreamBuffer instances take arguments that are actually size_t, and this will cause truncation warnings during argument forwarding with make_unique.
This commit is contained in:
parent
2c5fcad5f5
commit
626fcf4c15
|
@ -12,7 +12,7 @@
|
||||||
namespace DX12
|
namespace DX12
|
||||||
{
|
{
|
||||||
|
|
||||||
D3DStreamBuffer::D3DStreamBuffer(unsigned int initial_size, unsigned int max_size, bool* buffer_reallocation_notification) :
|
D3DStreamBuffer::D3DStreamBuffer(size_t initial_size, size_t max_size, bool* buffer_reallocation_notification) :
|
||||||
m_buffer_size(initial_size),
|
m_buffer_size(initial_size),
|
||||||
m_buffer_max_size(max_size),
|
m_buffer_max_size(max_size),
|
||||||
m_buffer_reallocation_notification(buffer_reallocation_notification)
|
m_buffer_reallocation_notification(buffer_reallocation_notification)
|
||||||
|
@ -39,13 +39,13 @@ D3DStreamBuffer::~D3DStreamBuffer()
|
||||||
|
|
||||||
// Obviously this is non-performant, so the buffer max_size should be large enough to
|
// Obviously this is non-performant, so the buffer max_size should be large enough to
|
||||||
// ensure this never happens.
|
// ensure this never happens.
|
||||||
bool D3DStreamBuffer::AllocateSpaceInBuffer(unsigned int allocation_size, unsigned int alignment)
|
bool D3DStreamBuffer::AllocateSpaceInBuffer(size_t allocation_size, size_t alignment)
|
||||||
{
|
{
|
||||||
CHECK(allocation_size <= m_buffer_max_size, "Error: Requested allocation size in D3DStreamBuffer is greater than max allowed size of backing buffer.");
|
CHECK(allocation_size <= m_buffer_max_size, "Error: Requested allocation size in D3DStreamBuffer is greater than max allowed size of backing buffer.");
|
||||||
|
|
||||||
if (alignment)
|
if (alignment)
|
||||||
{
|
{
|
||||||
unsigned int padding = m_buffer_offset % alignment;
|
size_t padding = m_buffer_offset % alignment;
|
||||||
|
|
||||||
// Check for case when adding alignment causes CPU offset to equal GPU offset,
|
// Check for case when adding alignment causes CPU offset to equal GPU offset,
|
||||||
// which would imply entire buffer is available (if not corrected).
|
// which would imply entire buffer is available (if not corrected).
|
||||||
|
@ -84,12 +84,12 @@ bool D3DStreamBuffer::AllocateSpaceInBuffer(unsigned int allocation_size, unsign
|
||||||
// we call AllocateSpaceInBuffer. We have to conservatively allocate 16MB (!).
|
// we call AllocateSpaceInBuffer. We have to conservatively allocate 16MB (!).
|
||||||
// After the vertex data is written, we can choose to specify the 'real' allocation
|
// After the vertex data is written, we can choose to specify the 'real' allocation
|
||||||
// size to avoid wasting space.
|
// size to avoid wasting space.
|
||||||
void D3DStreamBuffer::OverrideSizeOfPreviousAllocation(unsigned int override_allocation_size)
|
void D3DStreamBuffer::OverrideSizeOfPreviousAllocation(size_t override_allocation_size)
|
||||||
{
|
{
|
||||||
m_buffer_offset = m_buffer_current_allocation_offset + override_allocation_size;
|
m_buffer_offset = m_buffer_current_allocation_offset + override_allocation_size;
|
||||||
}
|
}
|
||||||
|
|
||||||
void D3DStreamBuffer::AllocateBuffer(unsigned int size)
|
void D3DStreamBuffer::AllocateBuffer(size_t size)
|
||||||
{
|
{
|
||||||
// First, put existing buffer (if it exists) in deferred destruction list.
|
// First, put existing buffer (if it exists) in deferred destruction list.
|
||||||
if (m_buffer)
|
if (m_buffer)
|
||||||
|
@ -120,7 +120,7 @@ void D3DStreamBuffer::AllocateBuffer(unsigned int size)
|
||||||
// Function returns true if current command list executed as a result of current command list
|
// Function returns true if current command list executed as a result of current command list
|
||||||
// referencing all of buffer's contents, AND we are already at max_size. No alternative but to
|
// referencing all of buffer's contents, AND we are already at max_size. No alternative but to
|
||||||
// flush. See comments above AllocateSpaceInBuffer for more details.
|
// flush. See comments above AllocateSpaceInBuffer for more details.
|
||||||
bool D3DStreamBuffer::AttemptBufferResizeOrElseStall(unsigned int allocation_size)
|
bool D3DStreamBuffer::AttemptBufferResizeOrElseStall(size_t allocation_size)
|
||||||
{
|
{
|
||||||
// This function will attempt to increase the size of the buffer, in response
|
// This function will attempt to increase the size of the buffer, in response
|
||||||
// to running out of room. If the buffer is already at its maximum size specified
|
// to running out of room. If the buffer is already at its maximum size specified
|
||||||
|
@ -148,7 +148,7 @@ bool D3DStreamBuffer::AttemptBufferResizeOrElseStall(unsigned int allocation_siz
|
||||||
}
|
}
|
||||||
|
|
||||||
// 2) Next, prefer increasing buffer size instead of stalling.
|
// 2) Next, prefer increasing buffer size instead of stalling.
|
||||||
unsigned int new_size = std::min(static_cast<unsigned int>(m_buffer_size * 1.5f), m_buffer_max_size);
|
size_t new_size = std::min(static_cast<size_t>(m_buffer_size * 1.5f), m_buffer_max_size);
|
||||||
new_size = std::max(new_size, allocation_size);
|
new_size = std::max(new_size, allocation_size);
|
||||||
|
|
||||||
// Can we grow buffer further?
|
// Can we grow buffer further?
|
||||||
|
@ -193,7 +193,7 @@ bool D3DStreamBuffer::AttemptBufferResizeOrElseStall(unsigned int allocation_siz
|
||||||
}
|
}
|
||||||
|
|
||||||
// Return true if space is found.
|
// Return true if space is found.
|
||||||
bool D3DStreamBuffer::AttemptToAllocateOutOfExistingUnusedSpaceInBuffer(unsigned int allocation_size)
|
bool D3DStreamBuffer::AttemptToAllocateOutOfExistingUnusedSpaceInBuffer(size_t allocation_size)
|
||||||
{
|
{
|
||||||
// First, check if there is room at end of buffer. Fast path.
|
// First, check if there is room at end of buffer. Fast path.
|
||||||
if (m_buffer_offset >= m_buffer_gpu_completion_offset)
|
if (m_buffer_offset >= m_buffer_gpu_completion_offset)
|
||||||
|
@ -225,12 +225,11 @@ bool D3DStreamBuffer::AttemptToAllocateOutOfExistingUnusedSpaceInBuffer(unsigned
|
||||||
}
|
}
|
||||||
|
|
||||||
// Returns true if fence was found and waited on.
|
// Returns true if fence was found and waited on.
|
||||||
bool D3DStreamBuffer::AttemptToFindExistingFenceToStallOn(unsigned int allocation_size)
|
bool D3DStreamBuffer::AttemptToFindExistingFenceToStallOn(size_t allocation_size)
|
||||||
{
|
{
|
||||||
// Let's find the first fence that will free up enough space in our buffer.
|
// Let's find the first fence that will free up enough space in our buffer.
|
||||||
|
|
||||||
UINT64 fence_value_required = 0;
|
UINT64 fence_value_required = 0;
|
||||||
unsigned int new_buffer_offset = 0;
|
|
||||||
|
|
||||||
while (m_queued_fences.size() > 0)
|
while (m_queued_fences.size() > 0)
|
||||||
{
|
{
|
||||||
|
@ -335,12 +334,12 @@ void* D3DStreamBuffer::GetCPUAddressOfCurrentAllocation() const
|
||||||
return static_cast<u8*>(m_buffer_cpu_address) + m_buffer_current_allocation_offset;
|
return static_cast<u8*>(m_buffer_cpu_address) + m_buffer_current_allocation_offset;
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned int D3DStreamBuffer::GetOffsetOfCurrentAllocation() const
|
size_t D3DStreamBuffer::GetOffsetOfCurrentAllocation() const
|
||||||
{
|
{
|
||||||
return m_buffer_current_allocation_offset;
|
return m_buffer_current_allocation_offset;
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned int D3DStreamBuffer::GetSize() const
|
size_t D3DStreamBuffer::GetSize() const
|
||||||
{
|
{
|
||||||
return m_buffer_size;
|
return m_buffer_size;
|
||||||
}
|
}
|
||||||
|
|
|
@ -14,29 +14,29 @@ namespace DX12
|
||||||
class D3DStreamBuffer
|
class D3DStreamBuffer
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
D3DStreamBuffer(unsigned int initial_size, unsigned int max_size, bool* buffer_reallocation_notification);
|
D3DStreamBuffer(size_t initial_size, size_t max_size, bool* buffer_reallocation_notification);
|
||||||
~D3DStreamBuffer();
|
~D3DStreamBuffer();
|
||||||
|
|
||||||
bool AllocateSpaceInBuffer(unsigned int allocation_size, unsigned int alignment);
|
bool AllocateSpaceInBuffer(size_t allocation_size, size_t alignment);
|
||||||
void OverrideSizeOfPreviousAllocation(unsigned int override_allocation_size);
|
void OverrideSizeOfPreviousAllocation(size_t override_allocation_size);
|
||||||
|
|
||||||
void* GetBaseCPUAddress() const;
|
void* GetBaseCPUAddress() const;
|
||||||
D3D12_GPU_VIRTUAL_ADDRESS GetBaseGPUAddress() const;
|
D3D12_GPU_VIRTUAL_ADDRESS GetBaseGPUAddress() const;
|
||||||
ID3D12Resource* GetBuffer() const;
|
ID3D12Resource* GetBuffer() const;
|
||||||
void* GetCPUAddressOfCurrentAllocation() const;
|
void* GetCPUAddressOfCurrentAllocation() const;
|
||||||
D3D12_GPU_VIRTUAL_ADDRESS GetGPUAddressOfCurrentAllocation() const;
|
D3D12_GPU_VIRTUAL_ADDRESS GetGPUAddressOfCurrentAllocation() const;
|
||||||
unsigned int GetOffsetOfCurrentAllocation() const;
|
size_t GetOffsetOfCurrentAllocation() const;
|
||||||
unsigned int GetSize() const;
|
size_t GetSize() const;
|
||||||
|
|
||||||
static void QueueFenceCallback(void* owning_object, UINT64 fence_value);
|
static void QueueFenceCallback(void* owning_object, UINT64 fence_value);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void AllocateBuffer(unsigned int size);
|
void AllocateBuffer(size_t size);
|
||||||
bool AttemptBufferResizeOrElseStall(unsigned int new_size);
|
bool AttemptBufferResizeOrElseStall(size_t new_size);
|
||||||
|
|
||||||
bool AttemptToAllocateOutOfExistingUnusedSpaceInBuffer(unsigned int allocation_size);
|
bool AttemptToAllocateOutOfExistingUnusedSpaceInBuffer(size_t allocation_size);
|
||||||
|
|
||||||
bool AttemptToFindExistingFenceToStallOn(unsigned int allocation_size);
|
bool AttemptToFindExistingFenceToStallOn(size_t allocation_size);
|
||||||
|
|
||||||
void UpdateGPUProgress();
|
void UpdateGPUProgress();
|
||||||
void QueueFence(UINT64 fence_value);
|
void QueueFence(UINT64 fence_value);
|
||||||
|
@ -44,7 +44,7 @@ private:
|
||||||
struct FenceTrackingInformation
|
struct FenceTrackingInformation
|
||||||
{
|
{
|
||||||
UINT64 fence_value;
|
UINT64 fence_value;
|
||||||
unsigned int buffer_offset;
|
size_t buffer_offset;
|
||||||
};
|
};
|
||||||
|
|
||||||
std::queue<FenceTrackingInformation> m_queued_fences;
|
std::queue<FenceTrackingInformation> m_queued_fences;
|
||||||
|
@ -56,13 +56,13 @@ private:
|
||||||
void* m_buffer_cpu_address = nullptr;
|
void* m_buffer_cpu_address = nullptr;
|
||||||
D3D12_GPU_VIRTUAL_ADDRESS m_buffer_gpu_address = {};
|
D3D12_GPU_VIRTUAL_ADDRESS m_buffer_gpu_address = {};
|
||||||
|
|
||||||
unsigned int m_buffer_current_allocation_offset = 0;
|
size_t m_buffer_current_allocation_offset = 0;
|
||||||
unsigned int m_buffer_offset = 0;
|
size_t m_buffer_offset = 0;
|
||||||
unsigned int m_buffer_size = 0;
|
size_t m_buffer_size = 0;
|
||||||
|
|
||||||
const unsigned int m_buffer_max_size = 0;
|
const size_t m_buffer_max_size = 0;
|
||||||
|
|
||||||
unsigned int m_buffer_gpu_completion_offset = 0;
|
size_t m_buffer_gpu_completion_offset = 0;
|
||||||
|
|
||||||
bool* m_buffer_reallocation_notification = nullptr;
|
bool* m_buffer_reallocation_notification = nullptr;
|
||||||
};
|
};
|
||||||
|
|
|
@ -56,7 +56,7 @@ void ResourceBarrier(ID3D12GraphicsCommandList* command_list, ID3D12Resource* re
|
||||||
class UtilVertexBuffer
|
class UtilVertexBuffer
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
explicit UtilVertexBuffer(int size)
|
explicit UtilVertexBuffer(size_t size)
|
||||||
{
|
{
|
||||||
m_stream_buffer = new D3DStreamBuffer(size, size * 4, nullptr);
|
m_stream_buffer = new D3DStreamBuffer(size, size * 4, nullptr);
|
||||||
}
|
}
|
||||||
|
@ -65,10 +65,10 @@ public:
|
||||||
SAFE_DELETE(m_stream_buffer);
|
SAFE_DELETE(m_stream_buffer);
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned int GetSize() const { return m_stream_buffer->GetSize(); }
|
size_t GetSize() const { return m_stream_buffer->GetSize(); }
|
||||||
|
|
||||||
// returns vertex offset to the new data
|
// returns vertex offset to the new data
|
||||||
int AppendData(void* data, int size, int vertex_size)
|
size_t AppendData(const void* data, size_t size, size_t vertex_size)
|
||||||
{
|
{
|
||||||
m_stream_buffer->AllocateSpaceInBuffer(size, vertex_size);
|
m_stream_buffer->AllocateSpaceInBuffer(size, vertex_size);
|
||||||
|
|
||||||
|
@ -77,7 +77,7 @@ public:
|
||||||
return m_stream_buffer->GetOffsetOfCurrentAllocation() / vertex_size;
|
return m_stream_buffer->GetOffsetOfCurrentAllocation() / vertex_size;
|
||||||
}
|
}
|
||||||
|
|
||||||
int BeginAppendData(void** write_ptr, int size, int vertex_size)
|
size_t BeginAppendData(void** write_ptr, size_t size, size_t vertex_size)
|
||||||
{
|
{
|
||||||
m_stream_buffer->AllocateSpaceInBuffer(size, vertex_size);
|
m_stream_buffer->AllocateSpaceInBuffer(size, vertex_size);
|
||||||
|
|
||||||
|
@ -535,9 +535,9 @@ struct
|
||||||
} clear_quad_data;
|
} clear_quad_data;
|
||||||
|
|
||||||
// ring buffer offsets
|
// ring buffer offsets
|
||||||
int stq_offset;
|
static size_t stq_offset;
|
||||||
int cq_offset;
|
static size_t cq_offset;
|
||||||
int clearq_offset;
|
static size_t clearq_offset;
|
||||||
|
|
||||||
void InitUtils()
|
void InitUtils()
|
||||||
{
|
{
|
||||||
|
@ -660,7 +660,7 @@ void DrawShadedTexQuad(D3DTexture2D* texture,
|
||||||
|
|
||||||
D3D12_VERTEX_BUFFER_VIEW vb_view = {
|
D3D12_VERTEX_BUFFER_VIEW vb_view = {
|
||||||
util_vbuf_stq->GetBuffer12()->GetGPUVirtualAddress(), // D3D12_GPU_VIRTUAL_ADDRESS BufferLocation;
|
util_vbuf_stq->GetBuffer12()->GetGPUVirtualAddress(), // D3D12_GPU_VIRTUAL_ADDRESS BufferLocation;
|
||||||
util_vbuf_stq->GetSize(), // UINT SizeInBytes; This is the size of the entire buffer, not just the size of the vertex data for one draw call, since the offsetting is done in the draw call itself.
|
static_cast<UINT>(util_vbuf_stq->GetSize()), // UINT SizeInBytes; This is the size of the entire buffer, not just the size of the vertex data for one draw call, since the offsetting is done in the draw call itself.
|
||||||
sizeof(STQVertex) // UINT StrideInBytes;
|
sizeof(STQVertex) // UINT StrideInBytes;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -714,7 +714,7 @@ void DrawShadedTexQuad(D3DTexture2D* texture,
|
||||||
// 2 ^ D3D12_MAX_TEXTURE_DIMENSION_2_TO_EXP = 131072
|
// 2 ^ D3D12_MAX_TEXTURE_DIMENSION_2_TO_EXP = 131072
|
||||||
D3D::current_command_list->RSSetScissorRects(1, &CD3DX12_RECT(0, 0, 131072, 131072));
|
D3D::current_command_list->RSSetScissorRects(1, &CD3DX12_RECT(0, 0, 131072, 131072));
|
||||||
|
|
||||||
D3D::current_command_list->DrawInstanced(4, 1, stq_offset, 0);
|
D3D::current_command_list->DrawInstanced(4, 1, static_cast<UINT>(stq_offset), 0);
|
||||||
|
|
||||||
g_renderer->RestoreAPIState();
|
g_renderer->RestoreAPIState();
|
||||||
}
|
}
|
||||||
|
@ -749,7 +749,7 @@ void DrawColorQuad(u32 Color, float z, float x1, float y1, float x2, float y2, D
|
||||||
|
|
||||||
D3D12_VERTEX_BUFFER_VIEW vb_view = {
|
D3D12_VERTEX_BUFFER_VIEW vb_view = {
|
||||||
util_vbuf_cq->GetBuffer12()->GetGPUVirtualAddress(), // D3D12_GPU_VIRTUAL_ADDRESS BufferLocation;
|
util_vbuf_cq->GetBuffer12()->GetGPUVirtualAddress(), // D3D12_GPU_VIRTUAL_ADDRESS BufferLocation;
|
||||||
util_vbuf_cq->GetSize(), // UINT SizeInBytes; This is the size of the entire buffer, not just the size of the vertex data for one draw call, since the offsetting is done in the draw call itself.
|
static_cast<UINT>(util_vbuf_cq->GetSize()), // UINT SizeInBytes; This is the size of the entire buffer, not just the size of the vertex data for one draw call, since the offsetting is done in the draw call itself.
|
||||||
sizeof(ColVertex) // UINT StrideInBytes;
|
sizeof(ColVertex) // UINT StrideInBytes;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -795,7 +795,7 @@ void DrawColorQuad(u32 Color, float z, float x1, float y1, float x2, float y2, D
|
||||||
// 2 ^ D3D12_MAX_TEXTURE_DIMENSION_2_TO_EXP = 131072
|
// 2 ^ D3D12_MAX_TEXTURE_DIMENSION_2_TO_EXP = 131072
|
||||||
D3D::current_command_list->RSSetScissorRects(1, &CD3DX12_RECT(0, 0, 131072, 131072));
|
D3D::current_command_list->RSSetScissorRects(1, &CD3DX12_RECT(0, 0, 131072, 131072));
|
||||||
|
|
||||||
D3D::current_command_list->DrawInstanced(4, 1, cq_offset, 0);
|
D3D::current_command_list->DrawInstanced(4, 1, static_cast<UINT>(cq_offset), 0);
|
||||||
|
|
||||||
g_renderer->RestoreAPIState();
|
g_renderer->RestoreAPIState();
|
||||||
}
|
}
|
||||||
|
@ -822,7 +822,7 @@ void DrawClearQuad(u32 Color, float z, D3D12_BLEND_DESC* blend_desc, D3D12_DEPTH
|
||||||
|
|
||||||
D3D12_VERTEX_BUFFER_VIEW vb_view = {
|
D3D12_VERTEX_BUFFER_VIEW vb_view = {
|
||||||
util_vbuf_clearq->GetBuffer12()->GetGPUVirtualAddress(), // D3D12_GPU_VIRTUAL_ADDRESS BufferLocation;
|
util_vbuf_clearq->GetBuffer12()->GetGPUVirtualAddress(), // D3D12_GPU_VIRTUAL_ADDRESS BufferLocation;
|
||||||
util_vbuf_clearq->GetSize(), // UINT SizeInBytes; This is the size of the entire buffer, not just the size of the vertex data for one draw call, since the offsetting is done in the draw call itself.
|
static_cast<UINT>(util_vbuf_clearq->GetSize()), // UINT SizeInBytes; This is the size of the entire buffer, not just the size of the vertex data for one draw call, since the offsetting is done in the draw call itself.
|
||||||
sizeof(ClearVertex) // UINT StrideInBytes;
|
sizeof(ClearVertex) // UINT StrideInBytes;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -870,7 +870,7 @@ void DrawClearQuad(u32 Color, float z, D3D12_BLEND_DESC* blend_desc, D3D12_DEPTH
|
||||||
// 2 ^ D3D12_MAX_TEXTURE_DIMENSION_2_TO_EXP = 131072
|
// 2 ^ D3D12_MAX_TEXTURE_DIMENSION_2_TO_EXP = 131072
|
||||||
D3D::current_command_list->RSSetScissorRects(1, &CD3DX12_RECT(0, 0, 131072, 131072));
|
D3D::current_command_list->RSSetScissorRects(1, &CD3DX12_RECT(0, 0, 131072, 131072));
|
||||||
|
|
||||||
D3D::current_command_list->DrawInstanced(4, 1, clearq_offset, 0);
|
D3D::current_command_list->DrawInstanced(4, 1, static_cast<UINT>(clearq_offset), 0);
|
||||||
|
|
||||||
g_renderer->RestoreAPIState();
|
g_renderer->RestoreAPIState();
|
||||||
}
|
}
|
||||||
|
@ -942,7 +942,7 @@ void DrawEFBPokeQuads(EFBAccessType type,
|
||||||
size_t required_bytes = COL_QUAD_SIZE * points_to_draw;
|
size_t required_bytes = COL_QUAD_SIZE * points_to_draw;
|
||||||
|
|
||||||
void* buffer_ptr = nullptr;
|
void* buffer_ptr = nullptr;
|
||||||
int base_vertex_index = util_vbuf_efbpokequads->BeginAppendData(&buffer_ptr, static_cast<int>(required_bytes), sizeof(ColVertex));
|
size_t base_vertex_index = util_vbuf_efbpokequads->BeginAppendData(&buffer_ptr, required_bytes, sizeof(ColVertex));
|
||||||
|
|
||||||
CHECK(base_vertex_index * 16 + required_bytes <= util_vbuf_efbpokequads->GetSize(), "Uh oh");
|
CHECK(base_vertex_index * 16 + required_bytes <= util_vbuf_efbpokequads->GetSize(), "Uh oh");
|
||||||
|
|
||||||
|
@ -953,7 +953,7 @@ void DrawEFBPokeQuads(EFBAccessType type,
|
||||||
|
|
||||||
D3D12_VERTEX_BUFFER_VIEW vb_view = {
|
D3D12_VERTEX_BUFFER_VIEW vb_view = {
|
||||||
util_vbuf_efbpokequads->GetBuffer12()->GetGPUVirtualAddress(), // D3D12_GPU_VIRTUAL_ADDRESS BufferLocation;
|
util_vbuf_efbpokequads->GetBuffer12()->GetGPUVirtualAddress(), // D3D12_GPU_VIRTUAL_ADDRESS BufferLocation;
|
||||||
util_vbuf_efbpokequads->GetSize(), // UINT SizeInBytes; This is the size of the entire buffer, not just the size of the vertex data for one draw call, since the offsetting is done in the draw call itself.
|
static_cast<UINT>(util_vbuf_efbpokequads->GetSize()), // UINT SizeInBytes; This is the size of the entire buffer, not just the size of the vertex data for one draw call, since the offsetting is done in the draw call itself.
|
||||||
sizeof(ColVertex) // UINT StrideInBytes;
|
sizeof(ColVertex) // UINT StrideInBytes;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -991,7 +991,7 @@ void DrawEFBPokeQuads(EFBAccessType type,
|
||||||
}
|
}
|
||||||
|
|
||||||
// Issue the draw
|
// Issue the draw
|
||||||
D3D::current_command_list->DrawInstanced(6 * static_cast<unsigned int>(points_to_draw), 1, base_vertex_index, 0);
|
D3D::current_command_list->DrawInstanced(6 * static_cast<UINT>(points_to_draw), 1, static_cast<UINT>(base_vertex_index), 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -32,7 +32,7 @@ void VertexManager::SetIndexBuffer()
|
||||||
{
|
{
|
||||||
D3D12_INDEX_BUFFER_VIEW ib_view = {
|
D3D12_INDEX_BUFFER_VIEW ib_view = {
|
||||||
m_index_stream_buffer->GetBaseGPUAddress(), // D3D12_GPU_VIRTUAL_ADDRESS BufferLocation;
|
m_index_stream_buffer->GetBaseGPUAddress(), // D3D12_GPU_VIRTUAL_ADDRESS BufferLocation;
|
||||||
m_index_stream_buffer->GetSize(), // UINT SizeInBytes;
|
static_cast<UINT>(m_index_stream_buffer->GetSize()), // UINT SizeInBytes;
|
||||||
DXGI_FORMAT_R16_UINT // DXGI_FORMAT Format;
|
DXGI_FORMAT_R16_UINT // DXGI_FORMAT Format;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -96,7 +96,7 @@ void VertexManager::Draw(u32 stride)
|
||||||
{
|
{
|
||||||
D3D12_VERTEX_BUFFER_VIEW vb_view = {
|
D3D12_VERTEX_BUFFER_VIEW vb_view = {
|
||||||
m_vertex_stream_buffer->GetBaseGPUAddress(), // D3D12_GPU_VIRTUAL_ADDRESS BufferLocation;
|
m_vertex_stream_buffer->GetBaseGPUAddress(), // D3D12_GPU_VIRTUAL_ADDRESS BufferLocation;
|
||||||
m_vertex_stream_buffer->GetSize(), // UINT SizeInBytes;
|
static_cast<UINT>(m_vertex_stream_buffer->GetSize()), // UINT SizeInBytes;
|
||||||
stride // UINT StrideInBytes;
|
stride // UINT StrideInBytes;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -196,7 +196,7 @@ void VertexManager::ResetBuffer(u32 stride)
|
||||||
s_pBaseBufferPointer = static_cast<u8*>(m_vertex_stream_buffer->GetBaseCPUAddress());
|
s_pBaseBufferPointer = static_cast<u8*>(m_vertex_stream_buffer->GetBaseCPUAddress());
|
||||||
s_pEndBufferPointer = s_pBaseBufferPointer + m_vertex_stream_buffer->GetSize();
|
s_pEndBufferPointer = s_pBaseBufferPointer + m_vertex_stream_buffer->GetSize();
|
||||||
s_pCurBufferPointer = static_cast<u8*>(m_vertex_stream_buffer->GetCPUAddressOfCurrentAllocation());
|
s_pCurBufferPointer = static_cast<u8*>(m_vertex_stream_buffer->GetCPUAddressOfCurrentAllocation());
|
||||||
m_vertex_draw_offset = m_vertex_stream_buffer->GetOffsetOfCurrentAllocation();
|
m_vertex_draw_offset = static_cast<u32>(m_vertex_stream_buffer->GetOffsetOfCurrentAllocation());
|
||||||
|
|
||||||
command_list_executed |= m_index_stream_buffer->AllocateSpaceInBuffer(MAXIBUFFERSIZE * sizeof(u16), sizeof(u16));
|
command_list_executed |= m_index_stream_buffer->AllocateSpaceInBuffer(MAXIBUFFERSIZE * sizeof(u16), sizeof(u16));
|
||||||
if (command_list_executed)
|
if (command_list_executed)
|
||||||
|
@ -211,8 +211,8 @@ void VertexManager::ResetBuffer(u32 stride)
|
||||||
m_index_stream_buffer_reallocated = false;
|
m_index_stream_buffer_reallocated = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
m_index_draw_offset = m_index_stream_buffer->GetOffsetOfCurrentAllocation();
|
m_index_draw_offset = static_cast<u32>(m_index_stream_buffer->GetOffsetOfCurrentAllocation());
|
||||||
IndexGenerator::Start(reinterpret_cast<u16*>(m_index_stream_buffer->GetCPUAddressOfCurrentAllocation()));
|
IndexGenerator::Start(static_cast<u16*>(m_index_stream_buffer->GetCPUAddressOfCurrentAllocation()));
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace
|
} // namespace
|
||||||
|
|
Loading…
Reference in New Issue