mirror of
https://github.com/gnif/LookingGlass.git
synced 2025-01-18 10:43:58 +00:00
[host] dxgi: rename cpu
to tex
This commit is contained in:
parent
772e0e3b4a
commit
f991f994f0
1 changed files with 13 additions and 15 deletions
|
@ -36,15 +36,13 @@ struct D3D11Backend
|
||||||
struct
|
struct
|
||||||
{
|
{
|
||||||
uint64_t copyTime;
|
uint64_t copyTime;
|
||||||
ID3D11Texture2D ** cpu;
|
ID3D11Texture2D ** tex;
|
||||||
}
|
}
|
||||||
texture[0];
|
texture[0];
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct D3D11Backend * this = NULL;
|
static struct D3D11Backend * this = NULL;
|
||||||
|
|
||||||
static void d3d11_free(void);
|
|
||||||
|
|
||||||
static bool d3d11_create(unsigned textures)
|
static bool d3d11_create(unsigned textures)
|
||||||
{
|
{
|
||||||
DEBUG_ASSERT(!this);
|
DEBUG_ASSERT(!this);
|
||||||
|
@ -72,7 +70,7 @@ static bool d3d11_configure(
|
||||||
{
|
{
|
||||||
HRESULT status;
|
HRESULT status;
|
||||||
|
|
||||||
D3D11_TEXTURE2D_DESC cpuTexDesc =
|
D3D11_TEXTURE2D_DESC texTexDesc =
|
||||||
{
|
{
|
||||||
.Width = width,
|
.Width = width,
|
||||||
.Height = height,
|
.Height = height,
|
||||||
|
@ -87,22 +85,22 @@ static bool d3d11_configure(
|
||||||
.MiscFlags = 0
|
.MiscFlags = 0
|
||||||
};
|
};
|
||||||
|
|
||||||
comRef_defineLocal(ID3D11Texture2D, cpu);
|
comRef_defineLocal(ID3D11Texture2D, tex);
|
||||||
for(int i = 0; i < this->textures; ++i)
|
for(int i = 0; i < this->textures; ++i)
|
||||||
{
|
{
|
||||||
status = ID3D11Device_CreateTexture2D(dxgi_getDevice(), &cpuTexDesc, NULL, cpu);
|
status = ID3D11Device_CreateTexture2D(dxgi_getDevice(), &texTexDesc, NULL, tex);
|
||||||
if (FAILED(status))
|
if (FAILED(status))
|
||||||
{
|
{
|
||||||
DEBUG_WINERROR("Failed to create CPU texture", status);
|
DEBUG_WINERROR("Failed to create CPU texture", status);
|
||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
comRef_toGlobal(this->texture[i].cpu, cpu);
|
comRef_toGlobal(this->texture[i].tex, tex);
|
||||||
}
|
}
|
||||||
|
|
||||||
// map the texture simply to get the pitch and stride
|
// map the texture simply to get the pitch and stride
|
||||||
D3D11_MAPPED_SUBRESOURCE mapping;
|
D3D11_MAPPED_SUBRESOURCE mapping;
|
||||||
status = ID3D11DeviceContext_Map(dxgi_getContext(),
|
status = ID3D11DeviceContext_Map(dxgi_getContext(),
|
||||||
*(ID3D11Resource **)this->texture[0].cpu, 0, D3D11_MAP_READ, 0, &mapping);
|
*(ID3D11Resource **)this->texture[0].tex, 0, D3D11_MAP_READ, 0, &mapping);
|
||||||
|
|
||||||
if (FAILED(status))
|
if (FAILED(status))
|
||||||
{
|
{
|
||||||
|
@ -111,7 +109,7 @@ static bool d3d11_configure(
|
||||||
}
|
}
|
||||||
|
|
||||||
ID3D11DeviceContext_Unmap(dxgi_getContext(),
|
ID3D11DeviceContext_Unmap(dxgi_getContext(),
|
||||||
*(ID3D11Resource **)this->texture[0].cpu, 0);
|
*(ID3D11Resource **)this->texture[0].tex, 0);
|
||||||
|
|
||||||
*pitch = mapping.RowPitch;
|
*pitch = mapping.RowPitch;
|
||||||
return true;
|
return true;
|
||||||
|
@ -139,7 +137,7 @@ static bool d3d11_preCopy(ID3D11Texture2D * src, unsigned textureIndex)
|
||||||
|
|
||||||
static bool d3d11_copyFull(ID3D11Texture2D * src, unsigned textureIndex)
|
static bool d3d11_copyFull(ID3D11Texture2D * src, unsigned textureIndex)
|
||||||
{
|
{
|
||||||
ID3D11Texture2D * dst = *this->texture[textureIndex].cpu;
|
ID3D11Texture2D * dst = *this->texture[textureIndex].tex;
|
||||||
|
|
||||||
ID3D11DeviceContext_CopyResource(dxgi_getContext(),
|
ID3D11DeviceContext_CopyResource(dxgi_getContext(),
|
||||||
(ID3D11Resource *)dst, (ID3D11Resource *)src);
|
(ID3D11Resource *)dst, (ID3D11Resource *)src);
|
||||||
|
@ -151,7 +149,7 @@ static bool d3d11_copyFull(ID3D11Texture2D * src, unsigned textureIndex)
|
||||||
static bool d3d11_copyRect(ID3D11Texture2D * src, unsigned textureIndex,
|
static bool d3d11_copyRect(ID3D11Texture2D * src, unsigned textureIndex,
|
||||||
FrameDamageRect * rect)
|
FrameDamageRect * rect)
|
||||||
{
|
{
|
||||||
ID3D11Texture2D * dst = *this->texture[textureIndex].cpu;
|
ID3D11Texture2D * dst = *this->texture[textureIndex].tex;
|
||||||
|
|
||||||
D3D11_BOX box =
|
D3D11_BOX box =
|
||||||
{
|
{
|
||||||
|
@ -180,7 +178,7 @@ static bool d3d11_postCopy(ID3D11Texture2D * src, unsigned textureIndex)
|
||||||
|
|
||||||
static CaptureResult d3d11_mapTexture(unsigned textureIndex, void ** map)
|
static CaptureResult d3d11_mapTexture(unsigned textureIndex, void ** map)
|
||||||
{
|
{
|
||||||
ID3D11Resource * cpu = *(ID3D11Resource **)this->texture[textureIndex].cpu;
|
ID3D11Resource * tex = *(ID3D11Resource **)this->texture[textureIndex].tex;
|
||||||
|
|
||||||
// sleep until it's close to time to map
|
// sleep until it's close to time to map
|
||||||
const uint64_t delta = microtime() - this->texture[textureIndex].copyTime;
|
const uint64_t delta = microtime() - this->texture[textureIndex].copyTime;
|
||||||
|
@ -195,7 +193,7 @@ static CaptureResult d3d11_mapTexture(unsigned textureIndex, void ** map)
|
||||||
HRESULT status;
|
HRESULT status;
|
||||||
|
|
||||||
dxgi_contextLock();
|
dxgi_contextLock();
|
||||||
status = ID3D11DeviceContext_Map(dxgi_getContext(), cpu, 0, D3D11_MAP_READ,
|
status = ID3D11DeviceContext_Map(dxgi_getContext(), tex, 0, D3D11_MAP_READ,
|
||||||
0x100000L, &mappedRes);
|
0x100000L, &mappedRes);
|
||||||
dxgi_contextUnlock();
|
dxgi_contextUnlock();
|
||||||
if (status == DXGI_ERROR_WAS_STILL_DRAWING)
|
if (status == DXGI_ERROR_WAS_STILL_DRAWING)
|
||||||
|
@ -228,10 +226,10 @@ static CaptureResult d3d11_mapTexture(unsigned textureIndex, void ** map)
|
||||||
|
|
||||||
static void d3d11_unmapTexture(unsigned textureIndex)
|
static void d3d11_unmapTexture(unsigned textureIndex)
|
||||||
{
|
{
|
||||||
ID3D11Resource * cpu = *(ID3D11Resource **)this->texture[textureIndex].cpu;
|
ID3D11Resource * tex = *(ID3D11Resource **)this->texture[textureIndex].tex;
|
||||||
|
|
||||||
dxgi_contextLock();
|
dxgi_contextLock();
|
||||||
ID3D11DeviceContext_Unmap(dxgi_getContext(), cpu, 0);
|
ID3D11DeviceContext_Unmap(dxgi_getContext(), tex, 0);
|
||||||
dxgi_contextUnlock();
|
dxgi_contextUnlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue