mirror of
https://github.com/ValveSoftware/Proton.git
synced 2025-01-28 06:28:20 +03:00
vrclient: Fix IVRCompositor_WaitGetPoses calls after struct wrapping.
And call the right versions of the interfaces. CW-Bug-Id: #22729
This commit is contained in:
parent
ec675e1fe3
commit
6d9762bfef
@ -269,21 +269,6 @@ static void post_present_handoff_init( void *linux_side, unsigned int version )
|
|||||||
{
|
{
|
||||||
if (!compositor_data.dxvk_device) return;
|
if (!compositor_data.dxvk_device) return;
|
||||||
compositor_data.dxvk_device->lpVtbl->LockSubmissionQueue( compositor_data.dxvk_device );
|
compositor_data.dxvk_device->lpVtbl->LockSubmissionQueue( compositor_data.dxvk_device );
|
||||||
|
|
||||||
if (!compositor_data.d3d11_explicit_handoff && version >= 21)
|
|
||||||
{
|
|
||||||
struct cppIVRCompositor_IVRCompositor_021_SetExplicitTimingMode_params params =
|
|
||||||
{
|
|
||||||
.linux_side = linux_side,
|
|
||||||
.bExplicitTimingMode = VRCompositorTimingMode_Explicit_ApplicationPerformsPostPresentHandoff,
|
|
||||||
};
|
|
||||||
|
|
||||||
/* PostPresentHandoff can be used with d3d11 without SetExplicitTimingMode
|
|
||||||
* (which is Vulkan / d3d12 only), but doing the same with Vulkan results
|
|
||||||
* in lockups and crashes. */
|
|
||||||
cppIVRCompositor_IVRCompositor_021_SetExplicitTimingMode( ¶ms );
|
|
||||||
compositor_data.d3d11_explicit_handoff = TRUE;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void post_present_handoff_done(void)
|
static void post_present_handoff_done(void)
|
||||||
@ -297,22 +282,11 @@ static void wait_get_poses_init( void *linux_side )
|
|||||||
{
|
{
|
||||||
if (!compositor_data.dxvk_device) return;
|
if (!compositor_data.dxvk_device) return;
|
||||||
compositor_data.dxvk_device->lpVtbl->LockSubmissionQueue( compositor_data.dxvk_device );
|
compositor_data.dxvk_device->lpVtbl->LockSubmissionQueue( compositor_data.dxvk_device );
|
||||||
|
|
||||||
if (compositor_data.d3d11_explicit_handoff && !compositor_data.handoff_called)
|
|
||||||
{
|
|
||||||
/* Calling handoff after submit is optional for d3d11 but mandatory for Vulkan
|
|
||||||
* if explicit timing mode is set. */
|
|
||||||
cppIVRCompositor_IVRCompositor_022_PostPresentHandoff( linux_side );
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void wait_get_poses_done( void *linux_side )
|
static void wait_get_poses_done( void *linux_side )
|
||||||
{
|
{
|
||||||
if (!compositor_data.dxvk_device) return;
|
if (!compositor_data.dxvk_device) return;
|
||||||
|
|
||||||
if (compositor_data.d3d11_explicit_handoff)
|
|
||||||
cppIVRCompositor_IVRCompositor_022_SubmitExplicitTimingData( linux_side );
|
|
||||||
|
|
||||||
compositor_data.dxvk_device->lpVtbl->ReleaseSubmissionQueue( compositor_data.dxvk_device );
|
compositor_data.dxvk_device->lpVtbl->ReleaseSubmissionQueue( compositor_data.dxvk_device );
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1031,7 +1005,23 @@ EVRCompositorError __thiscall winIVRCompositor_IVRCompositor_021_WaitGetPoses( s
|
|||||||
};
|
};
|
||||||
TRACE( "%p\n", _this );
|
TRACE( "%p\n", _this );
|
||||||
wait_get_poses_init( _this->u_iface );
|
wait_get_poses_init( _this->u_iface );
|
||||||
|
|
||||||
|
if (compositor_data.dxvk_device && compositor_data.d3d11_explicit_handoff && !compositor_data.handoff_called)
|
||||||
|
{
|
||||||
|
struct cppIVRCompositor_IVRCompositor_021_PostPresentHandoff_params params = {.linux_side = _this->u_iface};
|
||||||
|
/* Calling handoff after submit is optional for d3d11 but mandatory for Vulkan
|
||||||
|
* if explicit timing mode is set. */
|
||||||
|
cppIVRCompositor_IVRCompositor_021_PostPresentHandoff( ¶ms );
|
||||||
|
}
|
||||||
|
|
||||||
cppIVRCompositor_IVRCompositor_021_WaitGetPoses( ¶ms );
|
cppIVRCompositor_IVRCompositor_021_WaitGetPoses( ¶ms );
|
||||||
|
|
||||||
|
if (compositor_data.dxvk_device && compositor_data.d3d11_explicit_handoff)
|
||||||
|
{
|
||||||
|
struct cppIVRCompositor_IVRCompositor_021_SubmitExplicitTimingData_params params = {.linux_side = _this->u_iface};
|
||||||
|
cppIVRCompositor_IVRCompositor_021_SubmitExplicitTimingData( ¶ms );
|
||||||
|
}
|
||||||
|
|
||||||
wait_get_poses_done( _this->u_iface );
|
wait_get_poses_done( _this->u_iface );
|
||||||
return params._ret;
|
return params._ret;
|
||||||
}
|
}
|
||||||
@ -1064,6 +1054,22 @@ void __thiscall winIVRCompositor_IVRCompositor_021_PostPresentHandoff( struct w_
|
|||||||
struct cppIVRCompositor_IVRCompositor_021_PostPresentHandoff_params params = {.linux_side = _this->u_iface};
|
struct cppIVRCompositor_IVRCompositor_021_PostPresentHandoff_params params = {.linux_side = _this->u_iface};
|
||||||
TRACE( "%p\n", _this );
|
TRACE( "%p\n", _this );
|
||||||
post_present_handoff_init( _this->u_iface, 21 );
|
post_present_handoff_init( _this->u_iface, 21 );
|
||||||
|
|
||||||
|
if (compositor_data.dxvk_device && !compositor_data.d3d11_explicit_handoff)
|
||||||
|
{
|
||||||
|
struct cppIVRCompositor_IVRCompositor_021_SetExplicitTimingMode_params params =
|
||||||
|
{
|
||||||
|
.linux_side = _this->u_iface,
|
||||||
|
.bExplicitTimingMode = TRUE,
|
||||||
|
};
|
||||||
|
|
||||||
|
/* PostPresentHandoff can be used with d3d11 without SetExplicitTimingMode
|
||||||
|
* (which is Vulkan / d3d12 only), but doing the same with Vulkan results
|
||||||
|
* in lockups and crashes. */
|
||||||
|
cppIVRCompositor_IVRCompositor_021_SetExplicitTimingMode( ¶ms );
|
||||||
|
compositor_data.d3d11_explicit_handoff = TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
cppIVRCompositor_IVRCompositor_021_PostPresentHandoff( ¶ms );
|
cppIVRCompositor_IVRCompositor_021_PostPresentHandoff( ¶ms );
|
||||||
post_present_handoff_done();
|
post_present_handoff_done();
|
||||||
}
|
}
|
||||||
@ -1113,7 +1119,23 @@ EVRCompositorError __thiscall winIVRCompositor_IVRCompositor_022_WaitGetPoses( s
|
|||||||
};
|
};
|
||||||
TRACE( "%p\n", _this );
|
TRACE( "%p\n", _this );
|
||||||
wait_get_poses_init( _this->u_iface );
|
wait_get_poses_init( _this->u_iface );
|
||||||
|
|
||||||
|
if (compositor_data.dxvk_device && compositor_data.d3d11_explicit_handoff && !compositor_data.handoff_called)
|
||||||
|
{
|
||||||
|
struct cppIVRCompositor_IVRCompositor_022_PostPresentHandoff_params params = {.linux_side = _this->u_iface};
|
||||||
|
/* Calling handoff after submit is optional for d3d11 but mandatory for Vulkan
|
||||||
|
* if explicit timing mode is set. */
|
||||||
|
cppIVRCompositor_IVRCompositor_022_PostPresentHandoff( ¶ms );
|
||||||
|
}
|
||||||
|
|
||||||
cppIVRCompositor_IVRCompositor_022_WaitGetPoses( ¶ms );
|
cppIVRCompositor_IVRCompositor_022_WaitGetPoses( ¶ms );
|
||||||
|
|
||||||
|
if (compositor_data.dxvk_device && compositor_data.d3d11_explicit_handoff)
|
||||||
|
{
|
||||||
|
struct cppIVRCompositor_IVRCompositor_022_SubmitExplicitTimingData_params params = {.linux_side = _this->u_iface};
|
||||||
|
cppIVRCompositor_IVRCompositor_022_SubmitExplicitTimingData( ¶ms );
|
||||||
|
}
|
||||||
|
|
||||||
wait_get_poses_done( _this->u_iface );
|
wait_get_poses_done( _this->u_iface );
|
||||||
return params._ret;
|
return params._ret;
|
||||||
}
|
}
|
||||||
@ -1146,6 +1168,22 @@ void __thiscall winIVRCompositor_IVRCompositor_022_PostPresentHandoff( struct w_
|
|||||||
struct cppIVRCompositor_IVRCompositor_022_PostPresentHandoff_params params = {.linux_side = _this->u_iface};
|
struct cppIVRCompositor_IVRCompositor_022_PostPresentHandoff_params params = {.linux_side = _this->u_iface};
|
||||||
TRACE( "%p\n", _this );
|
TRACE( "%p\n", _this );
|
||||||
post_present_handoff_init( _this->u_iface, 22 );
|
post_present_handoff_init( _this->u_iface, 22 );
|
||||||
|
|
||||||
|
if (compositor_data.dxvk_device && !compositor_data.d3d11_explicit_handoff)
|
||||||
|
{
|
||||||
|
struct cppIVRCompositor_IVRCompositor_022_SetExplicitTimingMode_params params =
|
||||||
|
{
|
||||||
|
.linux_side = _this->u_iface,
|
||||||
|
.eTimingMode = VRCompositorTimingMode_Explicit_ApplicationPerformsPostPresentHandoff,
|
||||||
|
};
|
||||||
|
|
||||||
|
/* PostPresentHandoff can be used with d3d11 without SetExplicitTimingMode
|
||||||
|
* (which is Vulkan / d3d12 only), but doing the same with Vulkan results
|
||||||
|
* in lockups and crashes. */
|
||||||
|
cppIVRCompositor_IVRCompositor_022_SetExplicitTimingMode( ¶ms );
|
||||||
|
compositor_data.d3d11_explicit_handoff = TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
cppIVRCompositor_IVRCompositor_022_PostPresentHandoff( ¶ms );
|
cppIVRCompositor_IVRCompositor_022_PostPresentHandoff( ¶ms );
|
||||||
post_present_handoff_done();
|
post_present_handoff_done();
|
||||||
}
|
}
|
||||||
@ -1195,7 +1233,23 @@ EVRCompositorError __thiscall winIVRCompositor_IVRCompositor_024_WaitGetPoses( s
|
|||||||
};
|
};
|
||||||
TRACE( "%p\n", _this );
|
TRACE( "%p\n", _this );
|
||||||
wait_get_poses_init( _this->u_iface );
|
wait_get_poses_init( _this->u_iface );
|
||||||
|
|
||||||
|
if (compositor_data.dxvk_device && compositor_data.d3d11_explicit_handoff && !compositor_data.handoff_called)
|
||||||
|
{
|
||||||
|
struct cppIVRCompositor_IVRCompositor_024_PostPresentHandoff_params params = {.linux_side = _this->u_iface};
|
||||||
|
/* Calling handoff after submit is optional for d3d11 but mandatory for Vulkan
|
||||||
|
* if explicit timing mode is set. */
|
||||||
|
cppIVRCompositor_IVRCompositor_024_PostPresentHandoff( ¶ms );
|
||||||
|
}
|
||||||
|
|
||||||
cppIVRCompositor_IVRCompositor_024_WaitGetPoses( ¶ms );
|
cppIVRCompositor_IVRCompositor_024_WaitGetPoses( ¶ms );
|
||||||
|
|
||||||
|
if (compositor_data.dxvk_device && compositor_data.d3d11_explicit_handoff)
|
||||||
|
{
|
||||||
|
struct cppIVRCompositor_IVRCompositor_024_SubmitExplicitTimingData_params params = {.linux_side = _this->u_iface};
|
||||||
|
cppIVRCompositor_IVRCompositor_024_SubmitExplicitTimingData( ¶ms );
|
||||||
|
}
|
||||||
|
|
||||||
wait_get_poses_done( _this->u_iface );
|
wait_get_poses_done( _this->u_iface );
|
||||||
return params._ret;
|
return params._ret;
|
||||||
}
|
}
|
||||||
@ -1228,6 +1282,22 @@ void __thiscall winIVRCompositor_IVRCompositor_024_PostPresentHandoff( struct w_
|
|||||||
struct cppIVRCompositor_IVRCompositor_024_PostPresentHandoff_params params = {.linux_side = _this->u_iface};
|
struct cppIVRCompositor_IVRCompositor_024_PostPresentHandoff_params params = {.linux_side = _this->u_iface};
|
||||||
TRACE( "%p\n", _this );
|
TRACE( "%p\n", _this );
|
||||||
post_present_handoff_init( _this->u_iface, 24 );
|
post_present_handoff_init( _this->u_iface, 24 );
|
||||||
|
|
||||||
|
if (compositor_data.dxvk_device && !compositor_data.d3d11_explicit_handoff)
|
||||||
|
{
|
||||||
|
struct cppIVRCompositor_IVRCompositor_024_SetExplicitTimingMode_params params =
|
||||||
|
{
|
||||||
|
.linux_side = _this->u_iface,
|
||||||
|
.eTimingMode = VRCompositorTimingMode_Explicit_ApplicationPerformsPostPresentHandoff,
|
||||||
|
};
|
||||||
|
|
||||||
|
/* PostPresentHandoff can be used with d3d11 without SetExplicitTimingMode
|
||||||
|
* (which is Vulkan / d3d12 only), but doing the same with Vulkan results
|
||||||
|
* in lockups and crashes. */
|
||||||
|
cppIVRCompositor_IVRCompositor_024_SetExplicitTimingMode( ¶ms );
|
||||||
|
compositor_data.d3d11_explicit_handoff = TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
cppIVRCompositor_IVRCompositor_024_PostPresentHandoff( ¶ms );
|
cppIVRCompositor_IVRCompositor_024_PostPresentHandoff( ¶ms );
|
||||||
post_present_handoff_done();
|
post_present_handoff_done();
|
||||||
}
|
}
|
||||||
@ -1277,7 +1347,23 @@ EVRCompositorError __thiscall winIVRCompositor_IVRCompositor_026_WaitGetPoses( s
|
|||||||
};
|
};
|
||||||
TRACE( "%p\n", _this );
|
TRACE( "%p\n", _this );
|
||||||
wait_get_poses_init( _this->u_iface );
|
wait_get_poses_init( _this->u_iface );
|
||||||
|
|
||||||
|
if (compositor_data.dxvk_device && compositor_data.d3d11_explicit_handoff && !compositor_data.handoff_called)
|
||||||
|
{
|
||||||
|
struct cppIVRCompositor_IVRCompositor_026_PostPresentHandoff_params params = {.linux_side = _this->u_iface};
|
||||||
|
/* Calling handoff after submit is optional for d3d11 but mandatory for Vulkan
|
||||||
|
* if explicit timing mode is set. */
|
||||||
|
cppIVRCompositor_IVRCompositor_026_PostPresentHandoff( ¶ms );
|
||||||
|
}
|
||||||
|
|
||||||
cppIVRCompositor_IVRCompositor_026_WaitGetPoses( ¶ms );
|
cppIVRCompositor_IVRCompositor_026_WaitGetPoses( ¶ms );
|
||||||
|
|
||||||
|
if (compositor_data.dxvk_device && compositor_data.d3d11_explicit_handoff)
|
||||||
|
{
|
||||||
|
struct cppIVRCompositor_IVRCompositor_026_SubmitExplicitTimingData_params params = {.linux_side = _this->u_iface};
|
||||||
|
cppIVRCompositor_IVRCompositor_026_SubmitExplicitTimingData( ¶ms );
|
||||||
|
}
|
||||||
|
|
||||||
wait_get_poses_done( _this->u_iface );
|
wait_get_poses_done( _this->u_iface );
|
||||||
return params._ret;
|
return params._ret;
|
||||||
}
|
}
|
||||||
@ -1310,6 +1396,22 @@ void __thiscall winIVRCompositor_IVRCompositor_026_PostPresentHandoff( struct w_
|
|||||||
struct cppIVRCompositor_IVRCompositor_026_PostPresentHandoff_params params = {.linux_side = _this->u_iface};
|
struct cppIVRCompositor_IVRCompositor_026_PostPresentHandoff_params params = {.linux_side = _this->u_iface};
|
||||||
TRACE( "%p\n", _this );
|
TRACE( "%p\n", _this );
|
||||||
post_present_handoff_init( _this->u_iface, 26 );
|
post_present_handoff_init( _this->u_iface, 26 );
|
||||||
|
|
||||||
|
if (compositor_data.dxvk_device && !compositor_data.d3d11_explicit_handoff)
|
||||||
|
{
|
||||||
|
struct cppIVRCompositor_IVRCompositor_026_SetExplicitTimingMode_params params =
|
||||||
|
{
|
||||||
|
.linux_side = _this->u_iface,
|
||||||
|
.eTimingMode = VRCompositorTimingMode_Explicit_ApplicationPerformsPostPresentHandoff,
|
||||||
|
};
|
||||||
|
|
||||||
|
/* PostPresentHandoff can be used with d3d11 without SetExplicitTimingMode
|
||||||
|
* (which is Vulkan / d3d12 only), but doing the same with Vulkan results
|
||||||
|
* in lockups and crashes. */
|
||||||
|
cppIVRCompositor_IVRCompositor_026_SetExplicitTimingMode( ¶ms );
|
||||||
|
compositor_data.d3d11_explicit_handoff = TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
cppIVRCompositor_IVRCompositor_026_PostPresentHandoff( ¶ms );
|
cppIVRCompositor_IVRCompositor_026_PostPresentHandoff( ¶ms );
|
||||||
post_present_handoff_done();
|
post_present_handoff_done();
|
||||||
}
|
}
|
||||||
@ -1373,6 +1475,22 @@ void __thiscall winIVRCompositor_IVRCompositor_027_PostPresentHandoff( struct w_
|
|||||||
struct cppIVRCompositor_IVRCompositor_027_PostPresentHandoff_params params = {.linux_side = _this->u_iface};
|
struct cppIVRCompositor_IVRCompositor_027_PostPresentHandoff_params params = {.linux_side = _this->u_iface};
|
||||||
TRACE( "%p\n", _this );
|
TRACE( "%p\n", _this );
|
||||||
post_present_handoff_init( _this->u_iface, 27 );
|
post_present_handoff_init( _this->u_iface, 27 );
|
||||||
|
|
||||||
|
if (compositor_data.dxvk_device && !compositor_data.d3d11_explicit_handoff)
|
||||||
|
{
|
||||||
|
struct cppIVRCompositor_IVRCompositor_027_SetExplicitTimingMode_params params =
|
||||||
|
{
|
||||||
|
.linux_side = _this->u_iface,
|
||||||
|
.eTimingMode = VRCompositorTimingMode_Explicit_ApplicationPerformsPostPresentHandoff,
|
||||||
|
};
|
||||||
|
|
||||||
|
/* PostPresentHandoff can be used with d3d11 without SetExplicitTimingMode
|
||||||
|
* (which is Vulkan / d3d12 only), but doing the same with Vulkan results
|
||||||
|
* in lockups and crashes. */
|
||||||
|
cppIVRCompositor_IVRCompositor_027_SetExplicitTimingMode( ¶ms );
|
||||||
|
compositor_data.d3d11_explicit_handoff = TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
cppIVRCompositor_IVRCompositor_027_PostPresentHandoff( ¶ms );
|
cppIVRCompositor_IVRCompositor_027_PostPresentHandoff( ¶ms );
|
||||||
post_present_handoff_done();
|
post_present_handoff_done();
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user