mirror of
https://github.com/doitsujin/dxvk.git
synced 2024-12-11 19:24:11 +01:00
[d3d9] Handle map failure in texture initializer
This commit is contained in:
parent
e38693cdbc
commit
5c987ea3d1
@ -194,6 +194,8 @@ namespace dxvk {
|
|||||||
|
|
||||||
m_data.Map();
|
m_data.Map();
|
||||||
uint8_t* ptr = reinterpret_cast<uint8_t*>(m_data.Ptr());
|
uint8_t* ptr = reinterpret_cast<uint8_t*>(m_data.Ptr());
|
||||||
|
if (ptr == nullptr)
|
||||||
|
return nullptr;
|
||||||
ptr += m_memoryOffset[Subresource];
|
ptr += m_memoryOffset[Subresource];
|
||||||
return ptr;
|
return ptr;
|
||||||
}
|
}
|
||||||
|
@ -44,11 +44,21 @@ namespace dxvk {
|
|||||||
if (pTexture->GetMapMode() == D3D9_COMMON_TEXTURE_MAP_MODE_NONE)
|
if (pTexture->GetMapMode() == D3D9_COMMON_TEXTURE_MAP_MODE_NONE)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
void* mapPtr = nullptr;
|
||||||
|
|
||||||
|
if (pTexture->Desc()->Pool != D3DPOOL_DEFAULT) {
|
||||||
|
mapPtr = pTexture->GetData(0);
|
||||||
|
if (mapPtr == nullptr)
|
||||||
|
throw DxvkError("D3D9: InitTexture: map failed");
|
||||||
|
}
|
||||||
|
|
||||||
if (pTexture->GetImage() != nullptr)
|
if (pTexture->GetImage() != nullptr)
|
||||||
InitDeviceLocalTexture(pTexture);
|
InitDeviceLocalTexture(pTexture);
|
||||||
|
|
||||||
if (pTexture->Desc()->Pool != D3DPOOL_DEFAULT)
|
if (mapPtr != nullptr) {
|
||||||
InitHostVisibleTexture(pTexture, pInitialData);
|
InitHostVisibleTexture(pTexture, pInitialData, mapPtr);
|
||||||
|
pTexture->UnmapData();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -109,11 +119,11 @@ namespace dxvk {
|
|||||||
|
|
||||||
void D3D9Initializer::InitHostVisibleTexture(
|
void D3D9Initializer::InitHostVisibleTexture(
|
||||||
D3D9CommonTexture* pTexture,
|
D3D9CommonTexture* pTexture,
|
||||||
void* pInitialData) {
|
void* pInitialData,
|
||||||
|
void* mapPtr) {
|
||||||
// If the buffer is mapped, we can write data directly
|
// If the buffer is mapped, we can write data directly
|
||||||
// to the mapped memory region instead of doing it on
|
// to the mapped memory region instead of doing it on
|
||||||
// the GPU. Same goes for zero-initialization.
|
// the GPU. Same goes for zero-initialization.
|
||||||
void* mapPtr = pTexture->GetData(0);
|
|
||||||
if (pInitialData) {
|
if (pInitialData) {
|
||||||
// Initial data is only supported for textures with 1 subresource
|
// Initial data is only supported for textures with 1 subresource
|
||||||
VkExtent3D mipExtent = pTexture->GetExtentMip(0);
|
VkExtent3D mipExtent = pTexture->GetExtentMip(0);
|
||||||
@ -141,7 +151,6 @@ namespace dxvk {
|
|||||||
mapPtr, 0,
|
mapPtr, 0,
|
||||||
pTexture->GetTotalSize());
|
pTexture->GetTotalSize());
|
||||||
}
|
}
|
||||||
pTexture->UnmapData();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -52,7 +52,8 @@ namespace dxvk {
|
|||||||
|
|
||||||
void InitHostVisibleTexture(
|
void InitHostVisibleTexture(
|
||||||
D3D9CommonTexture* pTexture,
|
D3D9CommonTexture* pTexture,
|
||||||
void* pInitialData);
|
void* pInitialData,
|
||||||
|
void* mapPtr);
|
||||||
|
|
||||||
void FlushImplicit();
|
void FlushImplicit();
|
||||||
void FlushInternal();
|
void FlushInternal();
|
||||||
|
Loading…
Reference in New Issue
Block a user