mirror of
https://github.com/ValveSoftware/Proton.git
synced 2025-01-28 06:28:20 +03:00
vrclient: Split IVRSystem helpers to vrsystem_manual.c.
CW-Bug-Id: #22729
This commit is contained in:
parent
d2ef33eb25
commit
6b50dd5920
@ -8,6 +8,7 @@ EXTRADEFS = -DWINE_NO_LONG_TYPES -DGNUC
|
|||||||
C_SRCS = \
|
C_SRCS = \
|
||||||
vrclient_x64/flatapi.c \
|
vrclient_x64/flatapi.c \
|
||||||
vrclient_x64/vrclient_main.c \
|
vrclient_x64/vrclient_main.c \
|
||||||
|
vrclient_x64/vrsystem_manual.c \
|
||||||
vrclient_x64/winIVRApplications.c \
|
vrclient_x64/winIVRApplications.c \
|
||||||
vrclient_x64/winIVRChaperone.c \
|
vrclient_x64/winIVRChaperone.c \
|
||||||
vrclient_x64/winIVRChaperoneSetup.c \
|
vrclient_x64/winIVRChaperoneSetup.c \
|
||||||
|
@ -369,11 +369,11 @@ void *CDECL VRClientCoreFactory(const char *name, int *return_code)
|
|||||||
return create_win_interface(name, vrclient_VRClientCoreFactory(name, return_code));
|
return create_win_interface(name, vrclient_VRClientCoreFactory(name, return_code));
|
||||||
}
|
}
|
||||||
|
|
||||||
static VkDevice_T *(WINAPI *get_native_VkDevice)(VkDevice_T *);
|
static VkDevice_T *(WINAPI *p_get_native_VkDevice)( VkDevice_T * );
|
||||||
static VkInstance_T *(WINAPI *get_native_VkInstance)(VkInstance_T *);
|
static VkInstance_T *(WINAPI *p_get_native_VkInstance)( VkInstance_T * );
|
||||||
static VkPhysicalDevice_T *(WINAPI *get_native_VkPhysicalDevice)(VkPhysicalDevice_T *);
|
static VkPhysicalDevice_T *(WINAPI *p_get_native_VkPhysicalDevice)( VkPhysicalDevice_T * );
|
||||||
static VkPhysicalDevice_T *(WINAPI *get_wrapped_VkPhysicalDevice)(VkInstance_T *, VkPhysicalDevice_T *);
|
static VkPhysicalDevice_T *(WINAPI *p_get_wrapped_VkPhysicalDevice)( VkInstance_T *, VkPhysicalDevice_T * );
|
||||||
static VkQueue_T *(WINAPI *get_native_VkQueue)(VkQueue_T *);
|
static VkQueue_T *(WINAPI *p_get_native_VkQueue)( VkQueue_T * );
|
||||||
|
|
||||||
static void *get_winevulkan_unix_lib_handle(HMODULE hvulkan)
|
static void *get_winevulkan_unix_lib_handle(HMODULE hvulkan)
|
||||||
{
|
{
|
||||||
@ -418,12 +418,12 @@ static void load_vk_unwrappers(void)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
#define L(name) \
|
#define L( name ) \
|
||||||
if (!(name = dlsym(unix_handle, "__wine_"#name))) \
|
if (!(p_##name = dlsym( unix_handle, "__wine_" #name ))) \
|
||||||
{\
|
{ \
|
||||||
ERR("%s not found.\n", #name);\
|
ERR( "%s not found.\n", #name ); \
|
||||||
dlclose(unix_handle);\
|
dlclose( unix_handle ); \
|
||||||
return;\
|
return; \
|
||||||
}
|
}
|
||||||
|
|
||||||
L(get_native_VkDevice);
|
L(get_native_VkDevice);
|
||||||
@ -436,6 +436,36 @@ static void load_vk_unwrappers(void)
|
|||||||
dlclose(unix_handle);
|
dlclose(unix_handle);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
VkDevice_T *get_native_VkDevice( VkDevice_T *device )
|
||||||
|
{
|
||||||
|
load_vk_unwrappers();
|
||||||
|
return p_get_native_VkDevice( device );
|
||||||
|
}
|
||||||
|
|
||||||
|
VkInstance_T *get_native_VkInstance( VkInstance_T *instance )
|
||||||
|
{
|
||||||
|
load_vk_unwrappers();
|
||||||
|
return p_get_native_VkInstance( instance );
|
||||||
|
}
|
||||||
|
|
||||||
|
VkPhysicalDevice_T *get_native_VkPhysicalDevice( VkPhysicalDevice_T *device )
|
||||||
|
{
|
||||||
|
load_vk_unwrappers();
|
||||||
|
return p_get_native_VkPhysicalDevice( device );
|
||||||
|
}
|
||||||
|
|
||||||
|
VkPhysicalDevice_T *get_wrapped_VkPhysicalDevice( VkInstance_T *instance, VkPhysicalDevice_T *device )
|
||||||
|
{
|
||||||
|
load_vk_unwrappers();
|
||||||
|
return p_get_wrapped_VkPhysicalDevice( instance, device );
|
||||||
|
}
|
||||||
|
|
||||||
|
VkQueue_T *get_native_VkQueue( VkQueue_T *queue )
|
||||||
|
{
|
||||||
|
load_vk_unwrappers();
|
||||||
|
return p_get_native_VkQueue( queue );
|
||||||
|
}
|
||||||
|
|
||||||
static bool is_hmd_present_reg(void)
|
static bool is_hmd_present_reg(void)
|
||||||
{
|
{
|
||||||
DWORD type, value, wait_status, size;
|
DWORD type, value, wait_status, size;
|
||||||
@ -672,33 +702,6 @@ void ivrsystem_016_get_output_device(
|
|||||||
cpp_func(linux_side, out_device, type);
|
cpp_func(linux_side, out_device, type);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ivrsystem_get_output_device(
|
|
||||||
void (*cpp_func)(void *, uint64_t *, ETextureType, VkInstance_T *),
|
|
||||||
void *linux_side, uint64_t *out_device, ETextureType type,
|
|
||||||
VkInstance_T *wrapped_instance, unsigned int version)
|
|
||||||
{
|
|
||||||
switch(type){
|
|
||||||
case TextureType_Vulkan:
|
|
||||||
{
|
|
||||||
VkInstance_T *native_instance;
|
|
||||||
|
|
||||||
load_vk_unwrappers();
|
|
||||||
|
|
||||||
native_instance = get_native_VkInstance(wrapped_instance);
|
|
||||||
|
|
||||||
cpp_func(linux_side, out_device, type, native_instance);
|
|
||||||
|
|
||||||
*out_device = (uint64_t)(intptr_t)get_wrapped_VkPhysicalDevice(wrapped_instance,
|
|
||||||
(VkPhysicalDevice_T *)(intptr_t)*out_device);
|
|
||||||
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
default:
|
|
||||||
cpp_func(linux_side, out_device, type, wrapped_instance);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
struct submit_data
|
struct submit_data
|
||||||
{
|
{
|
||||||
void *linux_side;
|
void *linux_side;
|
||||||
@ -781,8 +784,6 @@ static Texture_t vrclient_translate_texture_dxvk(const Texture_t *texture, struc
|
|||||||
|
|
||||||
dxvk_surface->lpVtbl->GetVulkanImageInfo(dxvk_surface, &image_handle, image_layout, image_info);
|
dxvk_surface->lpVtbl->GetVulkanImageInfo(dxvk_surface, &image_handle, image_layout, image_info);
|
||||||
|
|
||||||
load_vk_unwrappers();
|
|
||||||
|
|
||||||
vkdata->m_nImage = (uint64_t)image_handle;
|
vkdata->m_nImage = (uint64_t)image_handle;
|
||||||
vkdata->m_pDevice = get_native_VkDevice(vkdata->m_pDevice);
|
vkdata->m_pDevice = get_native_VkDevice(vkdata->m_pDevice);
|
||||||
vkdata->m_pPhysicalDevice = get_native_VkPhysicalDevice(vkdata->m_pPhysicalDevice);
|
vkdata->m_pPhysicalDevice = get_native_VkPhysicalDevice(vkdata->m_pPhysicalDevice);
|
||||||
@ -899,8 +900,6 @@ static EVROverlayError ivroverlay_set_overlay_texture_vulkan(
|
|||||||
struct VRVulkanTextureData_t our_vkdata, *their_vkdata;
|
struct VRVulkanTextureData_t our_vkdata, *their_vkdata;
|
||||||
Texture_t our_texture;
|
Texture_t our_texture;
|
||||||
|
|
||||||
load_vk_unwrappers();
|
|
||||||
|
|
||||||
their_vkdata = texture->handle;
|
their_vkdata = texture->handle;
|
||||||
|
|
||||||
our_vkdata = *their_vkdata;
|
our_vkdata = *their_vkdata;
|
||||||
@ -926,9 +925,7 @@ static EVRCompositorError ivrcompositor_submit_vulkan(
|
|||||||
VRTextureWithDepth_t our_depth;
|
VRTextureWithDepth_t our_depth;
|
||||||
VRTextureWithPose_t our_pose;
|
VRTextureWithPose_t our_pose;
|
||||||
Texture_t our_texture;
|
Texture_t our_texture;
|
||||||
void *tex = texture;
|
const void *tex = texture;
|
||||||
|
|
||||||
load_vk_unwrappers();
|
|
||||||
|
|
||||||
their_vkdata = texture->handle;
|
their_vkdata = texture->handle;
|
||||||
|
|
||||||
@ -1281,8 +1278,6 @@ uint32_t ivrcompositor_get_vulkan_device_extensions_required(
|
|||||||
{
|
{
|
||||||
uint32_t ret;
|
uint32_t ret;
|
||||||
|
|
||||||
load_vk_unwrappers();
|
|
||||||
|
|
||||||
phys_dev = get_native_VkPhysicalDevice(phys_dev);
|
phys_dev = get_native_VkPhysicalDevice(phys_dev);
|
||||||
|
|
||||||
ret = cpp_func(linux_side, phys_dev, value, bufsize);
|
ret = cpp_func(linux_side, phys_dev, value, bufsize);
|
||||||
|
@ -188,4 +188,10 @@ EVRInputError ivrinput_get_digital_action_data(
|
|||||||
void *linux_side, VRActionHandle_t action_handle, void *action_data, uint32_t action_data_size,
|
void *linux_side, VRActionHandle_t action_handle, void *action_data, uint32_t action_data_size,
|
||||||
VRInputValueHandle_t restrict_to_device, unsigned int version);
|
VRInputValueHandle_t restrict_to_device, unsigned int version);
|
||||||
|
|
||||||
|
extern VkDevice_T *get_native_VkDevice( VkDevice_T *device );
|
||||||
|
extern VkInstance_T *get_native_VkInstance( VkInstance_T *instance );
|
||||||
|
extern VkPhysicalDevice_T *get_native_VkPhysicalDevice( VkPhysicalDevice_T *device );
|
||||||
|
extern VkPhysicalDevice_T *get_wrapped_VkPhysicalDevice( VkInstance_T *instance, VkPhysicalDevice_T *device );
|
||||||
|
extern VkQueue_T *get_native_VkQueue( VkQueue_T *queue );
|
||||||
|
|
||||||
#endif /* __cplusplus */
|
#endif /* __cplusplus */
|
||||||
|
37
vrclient_x64/vrclient_x64/vrsystem_manual.c
Normal file
37
vrclient_x64/vrclient_x64/vrsystem_manual.c
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
#include <stdarg.h>
|
||||||
|
#include <stddef.h>
|
||||||
|
#include <stdint.h>
|
||||||
|
|
||||||
|
#include "windef.h"
|
||||||
|
#include "winbase.h"
|
||||||
|
|
||||||
|
#include "wine/debug.h"
|
||||||
|
#include "vrclient_defs.h"
|
||||||
|
#include "vrclient_private.h"
|
||||||
|
|
||||||
|
#include "flatapi.h"
|
||||||
|
|
||||||
|
#include "struct_converters.h"
|
||||||
|
|
||||||
|
void ivrsystem_get_output_device( void (*cpp_func)( void *, uint64_t *, ETextureType, VkInstance_T * ),
|
||||||
|
void *linux_side, uint64_t *out_device, ETextureType type,
|
||||||
|
VkInstance_T *wrapped_instance, unsigned int version )
|
||||||
|
{
|
||||||
|
switch (type)
|
||||||
|
{
|
||||||
|
case TextureType_Vulkan:
|
||||||
|
{
|
||||||
|
VkInstance_T *native_instance;
|
||||||
|
|
||||||
|
native_instance = get_native_VkInstance( wrapped_instance );
|
||||||
|
|
||||||
|
cpp_func( linux_side, out_device, type, native_instance );
|
||||||
|
|
||||||
|
*out_device = (uint64_t)(intptr_t)
|
||||||
|
get_wrapped_VkPhysicalDevice( wrapped_instance, (VkPhysicalDevice_T *)(intptr_t)*out_device );
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
default: cpp_func( linux_side, out_device, type, wrapped_instance ); return;
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user