working on d3d11 backend

This commit is contained in:
2025-09-06 16:52:02 +02:00
parent aceec58473
commit 231e8f2687
4 changed files with 32 additions and 3 deletions

View File

@@ -14,9 +14,24 @@
PulseCommandList Direct3D11RequestCommandList(PulseDevice device, PulseCommandListUsage usage)
{
PULSE_CHECK_HANDLE_RETVAL(device, PULSE_NULL_HANDLE);
Direct3D11Device* d3d11_device = D3D11_RETRIEVE_DRIVER_DATA_AS(device, Direct3D11Device*);
PulseCommandList cmd = (PulseCommandList)calloc(1, sizeof(PulseCommandListHandler));
PULSE_CHECK_ALLOCATION_RETVAL(cmd, PULSE_NULL_HANDLE);
Direct3D11CommandList* d3d11_cmd = (Direct3D11CommandList*)calloc(1, sizeof(Direct3D11CommandList));
PULSE_CHECK_ALLOCATION_RETVAL(d3d11_cmd, PULSE_NULL_HANDLE);
CHECK_D3D11_RETVAL(device->backend, ID3D11Device_CreateDeferredContext(d3d11_device->device, 0, &d3d11_cmd->context), PULSE_ERROR_INITIALIZATION_FAILED, PULSE_NULL_HANDLE);
cmd->usage = usage;
cmd->device = device;
cmd->driver_data = d3d11_cmd;
cmd->thread_id = PulseGetThreadID();
cmd->pass = PULSE_NULL_HANDLE;
cmd->state = PULSE_COMMAND_LIST_STATE_RECORDING;
cmd->is_available = false;
return cmd;
}
@@ -26,4 +41,9 @@ bool Direct3D11SubmitCommandList(PulseDevice device, PulseCommandList cmd, Pulse
void Direct3D11ReleaseCommandList(PulseDevice device, PulseCommandList cmd)
{
PULSE_UNUSED(device);
Direct3D11CommandList* d3d11_cmd = D3D11_RETRIEVE_DRIVER_DATA_AS(cmd, Direct3D11CommandList*);
ID3D11DeviceContext_Release(d3d11_cmd->context);
free(d3d11_cmd);
free(cmd);
}