2020-06-01 20:32:43 +00:00
|
|
|
// Copyright 2018-2020, Collabora, Ltd.
|
2019-03-18 05:52:32 +00:00
|
|
|
// SPDX-License-Identifier: BSL-1.0
|
|
|
|
/*!
|
|
|
|
* @file
|
|
|
|
* @brief Holds system related entrypoints.
|
|
|
|
* @author Jakob Bornecrantz <jakob@collabora.com>
|
|
|
|
* @ingroup oxr_api
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <assert.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
|
|
|
|
|
|
|
#include "xrt/xrt_compiler.h"
|
|
|
|
#include "xrt/xrt_gfx_gl.h"
|
2019-10-29 10:08:11 +00:00
|
|
|
#include "xrt/xrt_gfx_gles.h"
|
2019-03-18 05:52:32 +00:00
|
|
|
#include "util/u_debug.h"
|
|
|
|
|
|
|
|
#include "oxr_objects.h"
|
|
|
|
#include "oxr_logger.h"
|
|
|
|
#include "oxr_two_call.h"
|
|
|
|
|
|
|
|
#include "oxr_api_funcs.h"
|
|
|
|
#include "oxr_api_verify.h"
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
2019-06-05 19:21:25 +00:00
|
|
|
* A helper define that verifies the systemId.
|
2019-03-18 05:52:32 +00:00
|
|
|
*/
|
|
|
|
#define OXR_VERIFY_SYSTEM_AND_GET(log, inst, sysId, system) \
|
2019-09-29 10:43:45 +00:00
|
|
|
struct oxr_system *system = NULL; \
|
2019-03-18 05:52:32 +00:00
|
|
|
do { \
|
2019-06-18 16:18:47 +00:00
|
|
|
XrResult ret = \
|
|
|
|
oxr_system_get_by_id(log, inst, sysId, &system); \
|
2019-03-18 05:52:32 +00:00
|
|
|
if (ret != XR_SUCCESS) { \
|
|
|
|
return ret; \
|
|
|
|
} \
|
|
|
|
assert(system != NULL); \
|
|
|
|
} while (false)
|
|
|
|
|
|
|
|
XrResult
|
|
|
|
oxr_xrGetSystem(XrInstance instance,
|
2019-09-29 10:43:45 +00:00
|
|
|
const XrSystemGetInfo *getInfo,
|
|
|
|
XrSystemId *systemId)
|
2019-03-18 05:52:32 +00:00
|
|
|
{
|
2019-09-29 10:43:45 +00:00
|
|
|
struct oxr_instance *inst;
|
2019-03-18 05:52:32 +00:00
|
|
|
struct oxr_logger log;
|
|
|
|
OXR_VERIFY_INSTANCE_AND_INIT_LOG(&log, instance, inst, "xrGetSystem");
|
2019-11-05 09:15:33 +00:00
|
|
|
OXR_VERIFY_ARG_TYPE_AND_NOT_NULL(&log, getInfo,
|
|
|
|
XR_TYPE_SYSTEM_GET_INFO);
|
2019-03-18 05:52:32 +00:00
|
|
|
OXR_VERIFY_ARG_NOT_NULL(&log, systemId);
|
|
|
|
|
2019-09-29 10:43:45 +00:00
|
|
|
struct oxr_system *selected = NULL;
|
|
|
|
struct oxr_system *systems[1] = {&inst->system};
|
2019-03-18 05:52:32 +00:00
|
|
|
uint32_t num_systems = 1;
|
|
|
|
|
|
|
|
XrResult ret = oxr_system_select(&log, systems, num_systems,
|
|
|
|
getInfo->formFactor, &selected);
|
|
|
|
if (ret != XR_SUCCESS) {
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
*systemId = selected->systemId;
|
|
|
|
|
|
|
|
return XR_SUCCESS;
|
|
|
|
}
|
|
|
|
|
|
|
|
XrResult
|
|
|
|
oxr_xrGetSystemProperties(XrInstance instance,
|
|
|
|
XrSystemId systemId,
|
2019-09-29 10:43:45 +00:00
|
|
|
XrSystemProperties *properties)
|
2019-03-18 05:52:32 +00:00
|
|
|
{
|
2019-09-29 10:43:45 +00:00
|
|
|
struct oxr_instance *inst;
|
2019-03-18 05:52:32 +00:00
|
|
|
struct oxr_logger log;
|
|
|
|
OXR_VERIFY_INSTANCE_AND_INIT_LOG(&log, instance, inst,
|
|
|
|
"xrGetSystemProperties");
|
2019-11-05 09:15:33 +00:00
|
|
|
OXR_VERIFY_ARG_TYPE_AND_NOT_NULL(&log, properties,
|
|
|
|
XR_TYPE_SYSTEM_PROPERTIES);
|
2019-03-18 05:52:32 +00:00
|
|
|
OXR_VERIFY_SYSTEM_AND_GET(&log, inst, systemId, sys);
|
|
|
|
|
|
|
|
return oxr_system_get_properties(&log, sys, properties);
|
|
|
|
}
|
|
|
|
|
|
|
|
XrResult
|
|
|
|
oxr_xrEnumerateViewConfigurations(
|
|
|
|
XrInstance instance,
|
|
|
|
XrSystemId systemId,
|
|
|
|
uint32_t viewConfigurationTypeCapacityInput,
|
2019-09-29 10:43:45 +00:00
|
|
|
uint32_t *viewConfigurationTypeCountOutput,
|
|
|
|
XrViewConfigurationType *viewConfigurationTypes)
|
2019-03-18 05:52:32 +00:00
|
|
|
{
|
2019-09-29 10:43:45 +00:00
|
|
|
struct oxr_instance *inst;
|
2019-03-18 05:52:32 +00:00
|
|
|
struct oxr_logger log;
|
|
|
|
OXR_VERIFY_INSTANCE_AND_INIT_LOG(&log, instance, inst,
|
|
|
|
"xrEnumerateViewConfigurations");
|
|
|
|
OXR_VERIFY_SYSTEM_AND_GET(&log, inst, systemId, sys);
|
|
|
|
|
|
|
|
return oxr_system_enumerate_view_confs(
|
|
|
|
&log, sys, viewConfigurationTypeCapacityInput,
|
|
|
|
viewConfigurationTypeCountOutput, viewConfigurationTypes);
|
|
|
|
}
|
|
|
|
|
|
|
|
XrResult
|
|
|
|
oxr_xrEnumerateEnvironmentBlendModes(
|
|
|
|
XrInstance instance,
|
|
|
|
XrSystemId systemId,
|
2019-07-13 16:17:57 +00:00
|
|
|
XrViewConfigurationType viewConfigurationType,
|
2019-03-18 05:52:32 +00:00
|
|
|
uint32_t environmentBlendModeCapacityInput,
|
2019-09-29 10:43:45 +00:00
|
|
|
uint32_t *environmentBlendModeCountOutput,
|
|
|
|
XrEnvironmentBlendMode *environmentBlendModes)
|
2019-03-18 05:52:32 +00:00
|
|
|
{
|
2019-09-29 10:43:45 +00:00
|
|
|
struct oxr_instance *inst;
|
2019-03-18 05:52:32 +00:00
|
|
|
struct oxr_logger log;
|
|
|
|
OXR_VERIFY_INSTANCE_AND_INIT_LOG(&log, instance, inst,
|
|
|
|
"xrEnumerateEnvironmentBlendModes");
|
|
|
|
OXR_VERIFY_SYSTEM_AND_GET(&log, inst, systemId, sys);
|
2020-06-04 14:01:57 +00:00
|
|
|
OXR_VERIFY_VIEW_CONFIG_TYPE(&log, inst, viewConfigurationType);
|
2020-05-30 10:58:06 +00:00
|
|
|
|
|
|
|
if (viewConfigurationType != sys->view_config_type) {
|
|
|
|
return oxr_error(&log,
|
|
|
|
XR_ERROR_VIEW_CONFIGURATION_TYPE_UNSUPPORTED,
|
|
|
|
"(viewConfigurationType == 0x%08x) "
|
|
|
|
"unsupported view configuration type",
|
|
|
|
viewConfigurationType);
|
|
|
|
}
|
|
|
|
|
2019-03-18 05:52:32 +00:00
|
|
|
return oxr_system_enumerate_blend_modes(
|
2019-07-13 16:17:57 +00:00
|
|
|
&log, sys, viewConfigurationType, environmentBlendModeCapacityInput,
|
2019-03-18 05:52:32 +00:00
|
|
|
environmentBlendModeCountOutput, environmentBlendModes);
|
|
|
|
}
|
|
|
|
|
|
|
|
XrResult
|
|
|
|
oxr_xrGetViewConfigurationProperties(
|
|
|
|
XrInstance instance,
|
|
|
|
XrSystemId systemId,
|
|
|
|
XrViewConfigurationType viewConfigurationType,
|
2019-09-29 10:43:45 +00:00
|
|
|
XrViewConfigurationProperties *configurationProperties)
|
2019-03-18 05:52:32 +00:00
|
|
|
{
|
2019-09-29 10:43:45 +00:00
|
|
|
struct oxr_instance *inst;
|
2019-03-18 05:52:32 +00:00
|
|
|
struct oxr_logger log;
|
|
|
|
OXR_VERIFY_INSTANCE_AND_INIT_LOG(&log, instance, inst,
|
|
|
|
"xrGetViewConfigurationProperties");
|
2019-11-05 09:15:33 +00:00
|
|
|
OXR_VERIFY_ARG_TYPE_AND_NOT_NULL(&log, configurationProperties,
|
|
|
|
XR_TYPE_VIEW_CONFIGURATION_PROPERTIES);
|
2019-03-18 05:52:32 +00:00
|
|
|
OXR_VERIFY_SYSTEM_AND_GET(&log, inst, systemId, sys);
|
|
|
|
|
|
|
|
return oxr_system_get_view_conf_properties(
|
|
|
|
&log, sys, viewConfigurationType, configurationProperties);
|
|
|
|
}
|
|
|
|
|
|
|
|
XrResult
|
|
|
|
oxr_xrEnumerateViewConfigurationViews(
|
|
|
|
XrInstance instance,
|
|
|
|
XrSystemId systemId,
|
|
|
|
XrViewConfigurationType viewConfigurationType,
|
|
|
|
uint32_t viewCapacityInput,
|
2019-09-29 10:43:45 +00:00
|
|
|
uint32_t *viewCountOutput,
|
|
|
|
XrViewConfigurationView *views)
|
2019-03-18 05:52:32 +00:00
|
|
|
{
|
2019-09-29 10:43:45 +00:00
|
|
|
struct oxr_instance *inst;
|
2019-03-18 05:52:32 +00:00
|
|
|
struct oxr_logger log;
|
|
|
|
OXR_VERIFY_INSTANCE_AND_INIT_LOG(&log, instance, inst,
|
|
|
|
"xrEnumerateViewConfigurationViews");
|
|
|
|
OXR_VERIFY_SYSTEM_AND_GET(&log, inst, systemId, sys);
|
|
|
|
|
|
|
|
return oxr_system_enumerate_view_conf_views(
|
|
|
|
&log, sys, viewConfigurationType, viewCapacityInput,
|
|
|
|
viewCountOutput, views);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-10-29 10:08:11 +00:00
|
|
|
/*
|
|
|
|
*
|
|
|
|
* OpenGL ES
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifdef XR_USE_GRAPHICS_API_OPENGL_ES
|
|
|
|
|
|
|
|
XrResult
|
|
|
|
oxr_xrGetOpenGLESGraphicsRequirementsKHR(
|
|
|
|
XrInstance instance,
|
|
|
|
XrSystemId systemId,
|
|
|
|
XrGraphicsRequirementsOpenGLESKHR *graphicsRequirements)
|
|
|
|
{
|
|
|
|
struct oxr_instance *inst;
|
|
|
|
struct oxr_logger log;
|
|
|
|
OXR_VERIFY_INSTANCE_AND_INIT_LOG(
|
|
|
|
&log, instance, inst, "xrGetOpenGLESGraphicsRequirementsKHR");
|
|
|
|
OXR_VERIFY_ARG_TYPE_AND_NOT_NULL(
|
|
|
|
&log, graphicsRequirements,
|
|
|
|
XR_TYPE_GRAPHICS_REQUIREMENTS_OPENGL_ES_KHR);
|
|
|
|
OXR_VERIFY_SYSTEM_AND_GET(&log, inst, systemId, sys);
|
|
|
|
|
|
|
|
struct xrt_api_requirements ver;
|
|
|
|
|
|
|
|
xrt_gfx_gles_get_versions(&ver);
|
|
|
|
|
|
|
|
graphicsRequirements->minApiVersionSupported =
|
|
|
|
XR_MAKE_VERSION(ver.min_major, ver.min_minor, ver.min_patch);
|
|
|
|
graphicsRequirements->maxApiVersionSupported =
|
|
|
|
XR_MAKE_VERSION(ver.max_major, ver.max_minor, ver.max_patch);
|
|
|
|
|
2020-05-30 11:42:41 +00:00
|
|
|
sys->gotten_requirements = true;
|
|
|
|
|
2019-10-29 10:08:11 +00:00
|
|
|
return XR_SUCCESS;
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
2019-03-18 05:52:32 +00:00
|
|
|
/*
|
|
|
|
*
|
|
|
|
* OpenGL
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifdef XR_USE_GRAPHICS_API_OPENGL
|
|
|
|
|
|
|
|
XrResult
|
|
|
|
oxr_xrGetOpenGLGraphicsRequirementsKHR(
|
|
|
|
XrInstance instance,
|
|
|
|
XrSystemId systemId,
|
2019-09-29 10:43:45 +00:00
|
|
|
XrGraphicsRequirementsOpenGLKHR *graphicsRequirements)
|
2019-03-18 05:52:32 +00:00
|
|
|
{
|
2019-09-29 10:43:45 +00:00
|
|
|
struct oxr_instance *inst;
|
2019-03-18 05:52:32 +00:00
|
|
|
struct oxr_logger log;
|
|
|
|
OXR_VERIFY_INSTANCE_AND_INIT_LOG(&log, instance, inst,
|
|
|
|
"xrGetOpenGLGraphicsRequirementsKHR");
|
2019-11-05 09:15:33 +00:00
|
|
|
OXR_VERIFY_ARG_TYPE_AND_NOT_NULL(
|
|
|
|
&log, graphicsRequirements,
|
|
|
|
XR_TYPE_GRAPHICS_REQUIREMENTS_OPENGL_KHR);
|
2019-03-18 05:52:32 +00:00
|
|
|
OXR_VERIFY_SYSTEM_AND_GET(&log, inst, systemId, sys);
|
|
|
|
|
|
|
|
struct xrt_api_requirements ver;
|
|
|
|
|
|
|
|
xrt_gfx_gl_get_versions(&ver);
|
|
|
|
|
|
|
|
graphicsRequirements->minApiVersionSupported =
|
|
|
|
XR_MAKE_VERSION(ver.min_major, ver.min_minor, ver.min_patch);
|
|
|
|
graphicsRequirements->maxApiVersionSupported =
|
|
|
|
XR_MAKE_VERSION(ver.max_major, ver.max_minor, ver.max_patch);
|
|
|
|
|
2020-05-30 11:42:41 +00:00
|
|
|
sys->gotten_requirements = true;
|
|
|
|
|
2019-03-18 05:52:32 +00:00
|
|
|
return XR_SUCCESS;
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
*
|
|
|
|
* Vulkan
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifdef XR_USE_GRAPHICS_API_VULKAN
|
|
|
|
|
|
|
|
XrResult
|
|
|
|
oxr_xrGetVulkanInstanceExtensionsKHR(XrInstance instance,
|
|
|
|
XrSystemId systemId,
|
|
|
|
uint32_t namesCapacityInput,
|
2019-09-29 10:43:45 +00:00
|
|
|
uint32_t *namesCountOutput,
|
|
|
|
char *namesString)
|
2019-03-18 05:52:32 +00:00
|
|
|
{
|
2019-09-29 10:43:45 +00:00
|
|
|
struct oxr_instance *inst;
|
2019-03-18 05:52:32 +00:00
|
|
|
struct oxr_logger log;
|
|
|
|
OXR_VERIFY_INSTANCE_AND_INIT_LOG(&log, instance, inst,
|
|
|
|
"xrGetVulkanInstanceExtensionsKHR");
|
|
|
|
OXR_VERIFY_SYSTEM_AND_GET(&log, inst, systemId, sys);
|
|
|
|
|
|
|
|
return oxr_vk_get_instance_exts(&log, sys, namesCapacityInput,
|
|
|
|
namesCountOutput, namesString);
|
|
|
|
}
|
|
|
|
|
|
|
|
XrResult
|
|
|
|
oxr_xrGetVulkanDeviceExtensionsKHR(XrInstance instance,
|
|
|
|
XrSystemId systemId,
|
|
|
|
uint32_t namesCapacityInput,
|
2019-09-29 10:43:45 +00:00
|
|
|
uint32_t *namesCountOutput,
|
|
|
|
char *namesString)
|
2019-03-18 05:52:32 +00:00
|
|
|
{
|
2019-09-29 10:43:45 +00:00
|
|
|
struct oxr_instance *inst;
|
2019-03-18 05:52:32 +00:00
|
|
|
struct oxr_logger log;
|
|
|
|
OXR_VERIFY_INSTANCE_AND_INIT_LOG(&log, instance, inst,
|
|
|
|
"xrGetVulkanDeviceExtensionsKHR");
|
|
|
|
OXR_VERIFY_SYSTEM_AND_GET(&log, inst, systemId, sys);
|
|
|
|
|
|
|
|
return oxr_vk_get_device_exts(&log, sys, namesCapacityInput,
|
|
|
|
namesCountOutput, namesString);
|
|
|
|
}
|
|
|
|
|
2020-08-06 14:29:37 +00:00
|
|
|
// NOLINTNEXTLINE // don't remove the forward decl.
|
2019-03-18 05:52:32 +00:00
|
|
|
VKAPI_ATTR PFN_vkVoidFunction VKAPI_CALL
|
2019-09-29 10:43:45 +00:00
|
|
|
vkGetInstanceProcAddr(VkInstance instance, const char *pName);
|
2019-03-18 05:52:32 +00:00
|
|
|
|
|
|
|
XrResult
|
|
|
|
oxr_xrGetVulkanGraphicsDeviceKHR(XrInstance instance,
|
|
|
|
XrSystemId systemId,
|
|
|
|
VkInstance vkInstance,
|
2019-09-29 10:43:45 +00:00
|
|
|
VkPhysicalDevice *vkPhysicalDevice)
|
2019-03-18 05:52:32 +00:00
|
|
|
{
|
2019-09-29 10:43:45 +00:00
|
|
|
struct oxr_instance *inst;
|
2019-03-18 05:52:32 +00:00
|
|
|
struct oxr_logger log;
|
|
|
|
OXR_VERIFY_INSTANCE_AND_INIT_LOG(&log, instance, inst,
|
|
|
|
"xrGetVulkanGraphicsDeviceKHR");
|
|
|
|
OXR_VERIFY_SYSTEM_AND_GET(&log, inst, systemId, sys);
|
|
|
|
OXR_VERIFY_ARG_NOT_NULL(&log, vkPhysicalDevice);
|
|
|
|
|
|
|
|
return oxr_vk_get_physical_device(&log, inst, sys, vkInstance,
|
|
|
|
vkGetInstanceProcAddr,
|
|
|
|
vkPhysicalDevice);
|
|
|
|
}
|
|
|
|
|
|
|
|
XrResult
|
|
|
|
oxr_xrGetVulkanGraphicsRequirementsKHR(
|
|
|
|
XrInstance instance,
|
|
|
|
XrSystemId systemId,
|
2019-09-29 10:43:45 +00:00
|
|
|
XrGraphicsRequirementsVulkanKHR *graphicsRequirements)
|
2019-03-18 05:52:32 +00:00
|
|
|
{
|
2019-09-29 10:43:45 +00:00
|
|
|
struct oxr_instance *inst;
|
2019-03-18 05:52:32 +00:00
|
|
|
struct oxr_logger log;
|
|
|
|
OXR_VERIFY_INSTANCE_AND_INIT_LOG(&log, instance, inst,
|
|
|
|
"xrGetVulkanGraphicsRequirementsKHR");
|
|
|
|
OXR_VERIFY_SYSTEM_AND_GET(&log, inst, systemId, sys);
|
2019-11-05 09:15:33 +00:00
|
|
|
OXR_VERIFY_ARG_TYPE_AND_NOT_NULL(
|
|
|
|
&log, graphicsRequirements,
|
|
|
|
XR_TYPE_GRAPHICS_REQUIREMENTS_VULKAN_KHR);
|
2019-03-18 05:52:32 +00:00
|
|
|
|
|
|
|
return oxr_vk_get_requirements(&log, sys, graphicsRequirements);
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|