capi: fix height/width order
This commit is contained in:
parent
c20104703b
commit
7f01c9aad3
5 changed files with 282 additions and 313 deletions
|
@ -36,9 +36,7 @@ CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
#if defined(_WIN32) && defined(LIBRA_RUNTIME_D3D11)
|
#if defined(_WIN32) && defined(LIBRA_RUNTIME_D3D11)
|
||||||
#include <d3d11.h>
|
#include <d3d11.h>
|
||||||
#else
|
#else
|
||||||
typedef void ID3D11Device;
|
typedef void ID3D11Device;typedef void ID3D11RenderTargetView;typedef void ID3D11ShaderResourceView;
|
||||||
typedef void ID3D11RenderTargetView;
|
|
||||||
typedef void ID3D11ShaderResourceView;
|
|
||||||
#endif
|
#endif
|
||||||
#if defined(LIBRA_RUNTIME_VULKAN)
|
#if defined(LIBRA_RUNTIME_VULKAN)
|
||||||
#include <vulkan\vulkan.h>
|
#include <vulkan\vulkan.h>
|
||||||
|
@ -75,11 +73,10 @@ typedef struct _filter_chain_vk _filter_chain_vk;
|
||||||
/// The error type for librashader.
|
/// The error type for librashader.
|
||||||
typedef struct _libra_error _libra_error;
|
typedef struct _libra_error _libra_error;
|
||||||
|
|
||||||
/// A shader preset including all specified parameters, textures, and paths to
|
/// A shader preset including all specified parameters, textures, and paths to specified shaders.
|
||||||
/// specified shaders.
|
|
||||||
///
|
///
|
||||||
/// A shader preset can be used to create a filter chain runtime instance, or
|
/// A shader preset can be used to create a filter chain runtime instance, or reflected to get
|
||||||
/// reflected to get parameter metadata.
|
/// parameter metadata.
|
||||||
typedef struct _shader_preset _shader_preset;
|
typedef struct _shader_preset _shader_preset;
|
||||||
|
|
||||||
/// A handle to a librashader error object.
|
/// A handle to a librashader error object.
|
||||||
|
@ -111,8 +108,7 @@ typedef struct libra_preset_param_list_t {
|
||||||
/// The number of parameters in the list.
|
/// The number of parameters in the list.
|
||||||
uint64_t length;
|
uint64_t length;
|
||||||
/// For internal use only.
|
/// For internal use only.
|
||||||
/// Changing this causes immediate undefined behaviour on freeing this
|
/// Changing this causes immediate undefined behaviour on freeing this parameter list.
|
||||||
/// parameter list.
|
|
||||||
uint64_t _internal_alloc;
|
uint64_t _internal_alloc;
|
||||||
} libra_preset_param_list_t;
|
} libra_preset_param_list_t;
|
||||||
|
|
||||||
|
@ -125,11 +121,9 @@ typedef const void *(*libra_gl_loader_t)(const char *);
|
||||||
typedef struct filter_chain_gl_opt_t {
|
typedef struct filter_chain_gl_opt_t {
|
||||||
/// The GLSL version. Should be at least `330`.
|
/// The GLSL version. Should be at least `330`.
|
||||||
uint16_t gl_version;
|
uint16_t gl_version;
|
||||||
/// Whether or not to use the Direct State Access APIs. Only available on
|
/// Whether or not to use the Direct State Access APIs. Only available on OpenGL 4.5+.
|
||||||
/// OpenGL 4.5+.
|
|
||||||
bool use_dsa;
|
bool use_dsa;
|
||||||
/// Whether or not to explicitly disable mipmap generation regardless of
|
/// Whether or not to explicitly disable mipmap generation regardless of shader preset settings.
|
||||||
/// shader preset settings.
|
|
||||||
bool force_no_mipmaps;
|
bool force_no_mipmaps;
|
||||||
} filter_chain_gl_opt_t;
|
} filter_chain_gl_opt_t;
|
||||||
|
|
||||||
|
@ -145,10 +139,10 @@ typedef struct libra_source_image_gl_t {
|
||||||
uint32_t handle;
|
uint32_t handle;
|
||||||
/// The format of the source image.
|
/// The format of the source image.
|
||||||
uint32_t format;
|
uint32_t format;
|
||||||
/// The width of the source image.
|
|
||||||
uint32_t width;
|
|
||||||
/// The height of the source image.
|
/// The height of the source image.
|
||||||
uint32_t height;
|
uint32_t height;
|
||||||
|
/// The width of the source image.
|
||||||
|
uint32_t width;
|
||||||
} libra_source_image_gl_t;
|
} libra_source_image_gl_t;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -158,10 +152,10 @@ typedef struct libra_viewport_t {
|
||||||
float x;
|
float x;
|
||||||
/// The y offset in the viewport framebuffer to begin rendering from.
|
/// The y offset in the viewport framebuffer to begin rendering from.
|
||||||
float y;
|
float y;
|
||||||
/// The width of the viewport framebuffer.
|
|
||||||
uint32_t width;
|
|
||||||
/// The height of the viewport framebuffer.
|
/// The height of the viewport framebuffer.
|
||||||
uint32_t height;
|
uint32_t height;
|
||||||
|
/// The width of the viewport framebuffer.
|
||||||
|
uint32_t width;
|
||||||
} libra_viewport_t;
|
} libra_viewport_t;
|
||||||
|
|
||||||
#if defined(LIBRA_RUNTIME_OPENGL)
|
#if defined(LIBRA_RUNTIME_OPENGL)
|
||||||
|
@ -206,10 +200,10 @@ typedef struct _filter_chain_d3d11 *libra_d3d11_filter_chain_t;
|
||||||
typedef struct libra_source_image_d3d11_t {
|
typedef struct libra_source_image_d3d11_t {
|
||||||
/// A shader resource view into the source image
|
/// A shader resource view into the source image
|
||||||
const ID3D11ShaderResourceView *handle;
|
const ID3D11ShaderResourceView *handle;
|
||||||
/// The width of the source image.
|
|
||||||
uint32_t width;
|
|
||||||
/// The height of the source image.
|
/// The height of the source image.
|
||||||
uint32_t height;
|
uint32_t height;
|
||||||
|
/// The width of the source image.
|
||||||
|
uint32_t width;
|
||||||
} libra_source_image_d3d11_t;
|
} libra_source_image_d3d11_t;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -242,8 +236,7 @@ typedef struct libra_device_vk_t {
|
||||||
typedef struct filter_chain_vk_opt_t {
|
typedef struct filter_chain_vk_opt_t {
|
||||||
/// The number of frames in flight to keep. If zero, defaults to three.
|
/// The number of frames in flight to keep. If zero, defaults to three.
|
||||||
uint32_t frames_in_flight;
|
uint32_t frames_in_flight;
|
||||||
/// Whether or not to explicitly disable mipmap generation regardless of
|
/// Whether or not to explicitly disable mipmap generation regardless of shader preset settings.
|
||||||
/// shader preset settings.
|
|
||||||
bool force_no_mipmaps;
|
bool force_no_mipmaps;
|
||||||
} filter_chain_vk_opt_t;
|
} filter_chain_vk_opt_t;
|
||||||
|
|
||||||
|
@ -259,10 +252,10 @@ typedef struct libra_image_vk_t {
|
||||||
VkImage handle;
|
VkImage handle;
|
||||||
/// The `VkFormat` of the source image.
|
/// The `VkFormat` of the source image.
|
||||||
VkFormat format;
|
VkFormat format;
|
||||||
/// The width of the source image.
|
|
||||||
uint32_t width;
|
|
||||||
/// The height of the source image.
|
/// The height of the source image.
|
||||||
uint32_t height;
|
uint32_t height;
|
||||||
|
/// The width of the source image.
|
||||||
|
uint32_t width;
|
||||||
} libra_image_vk_t;
|
} libra_image_vk_t;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -276,8 +269,7 @@ typedef struct frame_vk_opt_t {
|
||||||
|
|
||||||
/// Function pointer definition for
|
/// Function pointer definition for
|
||||||
///libra_preset_create
|
///libra_preset_create
|
||||||
typedef libra_error_t (*PFN_libra_preset_create)(const char *filename,
|
typedef libra_error_t (*PFN_libra_preset_create)(const char *filename, libra_shader_preset_t *out);
|
||||||
libra_shader_preset_t *out);
|
|
||||||
|
|
||||||
/// Function pointer definition for
|
/// Function pointer definition for
|
||||||
///libra_preset_free
|
///libra_preset_free
|
||||||
|
@ -285,13 +277,15 @@ typedef libra_error_t (*PFN_libra_preset_free)(libra_shader_preset_t *preset);
|
||||||
|
|
||||||
/// Function pointer definition for
|
/// Function pointer definition for
|
||||||
///libra_preset_set_param
|
///libra_preset_set_param
|
||||||
typedef libra_error_t (*PFN_libra_preset_set_param)(
|
typedef libra_error_t (*PFN_libra_preset_set_param)(libra_shader_preset_t *preset,
|
||||||
libra_shader_preset_t *preset, const char *name, float value);
|
const char *name,
|
||||||
|
float value);
|
||||||
|
|
||||||
/// Function pointer definition for
|
/// Function pointer definition for
|
||||||
///libra_preset_get_param
|
///libra_preset_get_param
|
||||||
typedef libra_error_t (*PFN_libra_preset_get_param)(
|
typedef libra_error_t (*PFN_libra_preset_get_param)(libra_shader_preset_t *preset,
|
||||||
libra_shader_preset_t *preset, const char *name, float *value);
|
const char *name,
|
||||||
|
float *value);
|
||||||
|
|
||||||
/// Function pointer definition for
|
/// Function pointer definition for
|
||||||
///libra_preset_print
|
///libra_preset_print
|
||||||
|
@ -299,13 +293,12 @@ typedef libra_error_t (*PFN_libra_preset_print)(libra_shader_preset_t *preset);
|
||||||
|
|
||||||
/// Function pointer definition for
|
/// Function pointer definition for
|
||||||
///libra_preset_get_runtime_params
|
///libra_preset_get_runtime_params
|
||||||
typedef libra_error_t (*PFN_libra_preset_get_runtime_params)(
|
typedef libra_error_t (*PFN_libra_preset_get_runtime_params)(libra_shader_preset_t *preset,
|
||||||
libra_shader_preset_t *preset, struct libra_preset_param_list_t *out);
|
struct libra_preset_param_list_t *out);
|
||||||
|
|
||||||
/// Function pointer definition for
|
/// Function pointer definition for
|
||||||
///libra_preset_free_runtime_params
|
///libra_preset_free_runtime_params
|
||||||
typedef libra_error_t (*PFN_libra_preset_free_runtime_params)(
|
typedef libra_error_t (*PFN_libra_preset_free_runtime_params)(struct libra_preset_param_list_t preset);
|
||||||
struct libra_preset_param_list_t preset);
|
|
||||||
|
|
||||||
/// Function pointer definition for libra_error_errno
|
/// Function pointer definition for libra_error_errno
|
||||||
typedef LIBRA_ERRNO (*PFN_libra_error_errno)(libra_error_t error);
|
typedef LIBRA_ERRNO (*PFN_libra_error_errno)(libra_error_t error);
|
||||||
|
@ -331,161 +324,172 @@ typedef libra_error_t (*PFN_libra_gl_init_context)(libra_gl_loader_t loader);
|
||||||
#if defined(LIBRA_RUNTIME_OPENGL)
|
#if defined(LIBRA_RUNTIME_OPENGL)
|
||||||
/// Function pointer definition for
|
/// Function pointer definition for
|
||||||
///libra_gl_filter_chain_create
|
///libra_gl_filter_chain_create
|
||||||
typedef libra_error_t (*PFN_libra_gl_filter_chain_create)(
|
typedef libra_error_t (*PFN_libra_gl_filter_chain_create)(libra_shader_preset_t *preset,
|
||||||
libra_shader_preset_t *preset, const struct filter_chain_gl_opt_t *options,
|
const struct filter_chain_gl_opt_t *options,
|
||||||
libra_gl_filter_chain_t *out);
|
libra_gl_filter_chain_t *out);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(LIBRA_RUNTIME_OPENGL)
|
#if defined(LIBRA_RUNTIME_OPENGL)
|
||||||
/// Function pointer definition for
|
/// Function pointer definition for
|
||||||
///libra_gl_filter_chain_frame
|
///libra_gl_filter_chain_frame
|
||||||
typedef libra_error_t (*PFN_libra_gl_filter_chain_frame)(
|
typedef libra_error_t (*PFN_libra_gl_filter_chain_frame)(libra_gl_filter_chain_t *chain,
|
||||||
libra_gl_filter_chain_t *chain, size_t frame_count,
|
size_t frame_count,
|
||||||
struct libra_source_image_gl_t image, struct libra_viewport_t viewport,
|
struct libra_source_image_gl_t image,
|
||||||
struct libra_draw_framebuffer_gl_t out, const float *mvp,
|
struct libra_viewport_t viewport,
|
||||||
|
struct libra_draw_framebuffer_gl_t out,
|
||||||
|
const float *mvp,
|
||||||
const struct frame_gl_opt_t *opt);
|
const struct frame_gl_opt_t *opt);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(LIBRA_RUNTIME_OPENGL)
|
#if defined(LIBRA_RUNTIME_OPENGL)
|
||||||
/// Function pointer definition for
|
/// Function pointer definition for
|
||||||
///libra_gl_filter_chain_set_param
|
///libra_gl_filter_chain_set_param
|
||||||
typedef libra_error_t (*PFN_libra_gl_filter_chain_set_param)(
|
typedef libra_error_t (*PFN_libra_gl_filter_chain_set_param)(libra_gl_filter_chain_t *chain,
|
||||||
libra_gl_filter_chain_t *chain, const char *param_name, float value);
|
const char *param_name,
|
||||||
|
float value);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(LIBRA_RUNTIME_OPENGL)
|
#if defined(LIBRA_RUNTIME_OPENGL)
|
||||||
/// Function pointer definition for
|
/// Function pointer definition for
|
||||||
///libra_gl_filter_chain_get_param
|
///libra_gl_filter_chain_get_param
|
||||||
typedef libra_error_t (*PFN_libra_gl_filter_chain_get_param)(
|
typedef libra_error_t (*PFN_libra_gl_filter_chain_get_param)(libra_gl_filter_chain_t *chain,
|
||||||
libra_gl_filter_chain_t *chain, const char *param_name, float *out);
|
const char *param_name,
|
||||||
|
float *out);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(LIBRA_RUNTIME_OPENGL)
|
#if defined(LIBRA_RUNTIME_OPENGL)
|
||||||
/// Function pointer definition for
|
/// Function pointer definition for
|
||||||
///libra_gl_filter_chain_set_active_pass_count
|
///libra_gl_filter_chain_set_active_pass_count
|
||||||
typedef libra_error_t (*PFN_libra_gl_filter_chain_set_active_pass_count)(
|
typedef libra_error_t (*PFN_libra_gl_filter_chain_set_active_pass_count)(libra_gl_filter_chain_t *chain,
|
||||||
libra_gl_filter_chain_t *chain, uint32_t value);
|
uint32_t value);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(LIBRA_RUNTIME_OPENGL)
|
#if defined(LIBRA_RUNTIME_OPENGL)
|
||||||
/// Function pointer definition for
|
/// Function pointer definition for
|
||||||
///libra_gl_filter_chain_get_active_pass_count
|
///libra_gl_filter_chain_get_active_pass_count
|
||||||
typedef libra_error_t (*PFN_libra_gl_filter_chain_get_active_pass_count)(
|
typedef libra_error_t (*PFN_libra_gl_filter_chain_get_active_pass_count)(libra_gl_filter_chain_t *chain,
|
||||||
libra_gl_filter_chain_t *chain, uint32_t *out);
|
uint32_t *out);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(LIBRA_RUNTIME_OPENGL)
|
#if defined(LIBRA_RUNTIME_OPENGL)
|
||||||
/// Function pointer definition for
|
/// Function pointer definition for
|
||||||
///libra_gl_filter_chain_free
|
///libra_gl_filter_chain_free
|
||||||
typedef libra_error_t (*PFN_libra_gl_filter_chain_free)(
|
typedef libra_error_t (*PFN_libra_gl_filter_chain_free)(libra_gl_filter_chain_t *chain);
|
||||||
libra_gl_filter_chain_t *chain);
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(LIBRA_RUNTIME_D3D11)
|
#if defined(LIBRA_RUNTIME_D3D11)
|
||||||
/// Function pointer definition for
|
/// Function pointer definition for
|
||||||
///libra_d3d11_filter_chain_create
|
///libra_d3d11_filter_chain_create
|
||||||
typedef libra_error_t (*PFN_libra_d3d11_filter_chain_create)(
|
typedef libra_error_t (*PFN_libra_d3d11_filter_chain_create)(libra_shader_preset_t *preset,
|
||||||
libra_shader_preset_t *preset,
|
const struct filter_chain_d3d11_opt_t *options,
|
||||||
const struct filter_chain_d3d11_opt_t *options, const ID3D11Device *device,
|
const ID3D11Device *device,
|
||||||
libra_d3d11_filter_chain_t *out);
|
libra_d3d11_filter_chain_t *out);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(LIBRA_RUNTIME_D3D11)
|
#if defined(LIBRA_RUNTIME_D3D11)
|
||||||
/// Function pointer definition for
|
/// Function pointer definition for
|
||||||
///libra_d3d11_filter_chain_frame
|
///libra_d3d11_filter_chain_frame
|
||||||
typedef libra_error_t (*PFN_libra_d3d11_filter_chain_frame)(
|
typedef libra_error_t (*PFN_libra_d3d11_filter_chain_frame)(libra_d3d11_filter_chain_t *chain,
|
||||||
libra_d3d11_filter_chain_t *chain, size_t frame_count,
|
size_t frame_count,
|
||||||
struct libra_source_image_d3d11_t image, struct libra_viewport_t viewport,
|
struct libra_source_image_d3d11_t image,
|
||||||
const ID3D11RenderTargetView *out, const float *mvp,
|
struct libra_viewport_t viewport,
|
||||||
|
const ID3D11RenderTargetView *out,
|
||||||
|
const float *mvp,
|
||||||
const struct frame_d3d11_opt_t *opt);
|
const struct frame_d3d11_opt_t *opt);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(LIBRA_RUNTIME_D3D11)
|
#if defined(LIBRA_RUNTIME_D3D11)
|
||||||
/// Function pointer definition for
|
/// Function pointer definition for
|
||||||
///libra_d3d11_filter_chain_set_param
|
///libra_d3d11_filter_chain_set_param
|
||||||
typedef libra_error_t (*PFN_libra_d3d11_filter_chain_set_param)(
|
typedef libra_error_t (*PFN_libra_d3d11_filter_chain_set_param)(libra_d3d11_filter_chain_t *chain,
|
||||||
libra_d3d11_filter_chain_t *chain, const char *param_name, float value);
|
const char *param_name,
|
||||||
|
float value);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(LIBRA_RUNTIME_D3D11)
|
#if defined(LIBRA_RUNTIME_D3D11)
|
||||||
/// Function pointer definition for
|
/// Function pointer definition for
|
||||||
///libra_d3d11_filter_chain_get_param
|
///libra_d3d11_filter_chain_get_param
|
||||||
typedef libra_error_t (*PFN_libra_d3d11_filter_chain_get_param)(
|
typedef libra_error_t (*PFN_libra_d3d11_filter_chain_get_param)(libra_d3d11_filter_chain_t *chain,
|
||||||
libra_d3d11_filter_chain_t *chain, const char *param_name, float *out);
|
const char *param_name,
|
||||||
|
float *out);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(LIBRA_RUNTIME_D3D11)
|
#if defined(LIBRA_RUNTIME_D3D11)
|
||||||
/// Function pointer definition for
|
/// Function pointer definition for
|
||||||
///libra_d3d11_filter_chain_set_active_pass_count
|
///libra_d3d11_filter_chain_set_active_pass_count
|
||||||
typedef libra_error_t (*PFN_libra_d3d11_filter_chain_set_active_pass_count)(
|
typedef libra_error_t (*PFN_libra_d3d11_filter_chain_set_active_pass_count)(libra_d3d11_filter_chain_t *chain,
|
||||||
libra_d3d11_filter_chain_t *chain, uint32_t value);
|
uint32_t value);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(LIBRA_RUNTIME_D3D11)
|
#if defined(LIBRA_RUNTIME_D3D11)
|
||||||
/// Function pointer definition for
|
/// Function pointer definition for
|
||||||
///libra_d3d11_filter_chain_get_active_pass_count
|
///libra_d3d11_filter_chain_get_active_pass_count
|
||||||
typedef libra_error_t (*PFN_libra_d3d11_filter_chain_get_active_pass_count)(
|
typedef libra_error_t (*PFN_libra_d3d11_filter_chain_get_active_pass_count)(libra_d3d11_filter_chain_t *chain,
|
||||||
libra_d3d11_filter_chain_t *chain, uint32_t *out);
|
uint32_t *out);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(LIBRA_RUNTIME_D3D11)
|
#if defined(LIBRA_RUNTIME_D3D11)
|
||||||
/// Function pointer definition for
|
/// Function pointer definition for
|
||||||
///libra_d3d11_filter_chain_free
|
///libra_d3d11_filter_chain_free
|
||||||
typedef libra_error_t (*PFN_libra_d3d11_filter_chain_free)(
|
typedef libra_error_t (*PFN_libra_d3d11_filter_chain_free)(libra_d3d11_filter_chain_t *chain);
|
||||||
libra_d3d11_filter_chain_t *chain);
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(LIBRA_RUNTIME_VULKAN)
|
#if defined(LIBRA_RUNTIME_VULKAN)
|
||||||
/// Function pointer definition for
|
/// Function pointer definition for
|
||||||
///libra_vk_filter_chain_create
|
///libra_vk_filter_chain_create
|
||||||
typedef libra_error_t (*PFN_libra_vk_filter_chain_create)(
|
typedef libra_error_t (*PFN_libra_vk_filter_chain_create)(struct libra_device_vk_t vulkan,
|
||||||
struct libra_device_vk_t vulkan, libra_shader_preset_t *preset,
|
libra_shader_preset_t *preset,
|
||||||
const struct filter_chain_vk_opt_t *options, libra_vk_filter_chain_t *out);
|
const struct filter_chain_vk_opt_t *options,
|
||||||
|
libra_vk_filter_chain_t *out);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(LIBRA_RUNTIME_VULKAN)
|
#if defined(LIBRA_RUNTIME_VULKAN)
|
||||||
/// Function pointer definition for
|
/// Function pointer definition for
|
||||||
///libra_vk_filter_chain_frame
|
///libra_vk_filter_chain_frame
|
||||||
typedef libra_error_t (*PFN_libra_vk_filter_chain_frame)(
|
typedef libra_error_t (*PFN_libra_vk_filter_chain_frame)(libra_vk_filter_chain_t *chain,
|
||||||
libra_vk_filter_chain_t *chain, VkCommandBuffer command_buffer,
|
VkCommandBuffer command_buffer,
|
||||||
size_t frame_count, struct libra_image_vk_t image,
|
size_t frame_count,
|
||||||
struct libra_viewport_t viewport, struct libra_image_vk_t out,
|
struct libra_image_vk_t image,
|
||||||
const float *mvp, const struct frame_vk_opt_t *opt);
|
struct libra_viewport_t viewport,
|
||||||
|
struct libra_image_vk_t out,
|
||||||
|
const float *mvp,
|
||||||
|
const struct frame_vk_opt_t *opt);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(LIBRA_RUNTIME_VULKAN)
|
#if defined(LIBRA_RUNTIME_VULKAN)
|
||||||
/// Function pointer definition for
|
/// Function pointer definition for
|
||||||
///libra_vk_filter_chain_set_param
|
///libra_vk_filter_chain_set_param
|
||||||
typedef libra_error_t (*PFN_libra_vk_filter_chain_set_param)(
|
typedef libra_error_t (*PFN_libra_vk_filter_chain_set_param)(libra_vk_filter_chain_t *chain,
|
||||||
libra_vk_filter_chain_t *chain, const char *param_name, float value);
|
const char *param_name,
|
||||||
|
float value);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(LIBRA_RUNTIME_VULKAN)
|
#if defined(LIBRA_RUNTIME_VULKAN)
|
||||||
/// Function pointer definition for
|
/// Function pointer definition for
|
||||||
///libra_vk_filter_chain_get_param
|
///libra_vk_filter_chain_get_param
|
||||||
typedef libra_error_t (*PFN_libra_vk_filter_chain_get_param)(
|
typedef libra_error_t (*PFN_libra_vk_filter_chain_get_param)(libra_vk_filter_chain_t *chain,
|
||||||
libra_vk_filter_chain_t *chain, const char *param_name, float *out);
|
const char *param_name,
|
||||||
|
float *out);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(LIBRA_RUNTIME_VULKAN)
|
#if defined(LIBRA_RUNTIME_VULKAN)
|
||||||
/// Function pointer definition for
|
/// Function pointer definition for
|
||||||
///libra_vk_filter_chain_set_active_pass_count
|
///libra_vk_filter_chain_set_active_pass_count
|
||||||
typedef libra_error_t (*PFN_libra_vk_filter_chain_set_active_pass_count)(
|
typedef libra_error_t (*PFN_libra_vk_filter_chain_set_active_pass_count)(libra_vk_filter_chain_t *chain,
|
||||||
libra_vk_filter_chain_t *chain, uint32_t value);
|
uint32_t value);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(LIBRA_RUNTIME_VULKAN)
|
#if defined(LIBRA_RUNTIME_VULKAN)
|
||||||
/// Function pointer definition for
|
/// Function pointer definition for
|
||||||
///libra_vk_filter_chain_get_active_pass_count
|
///libra_vk_filter_chain_get_active_pass_count
|
||||||
typedef libra_error_t (*PFN_libra_vk_filter_chain_get_active_pass_count)(
|
typedef libra_error_t (*PFN_libra_vk_filter_chain_get_active_pass_count)(libra_vk_filter_chain_t *chain,
|
||||||
libra_vk_filter_chain_t *chain, uint32_t *out);
|
uint32_t *out);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(LIBRA_RUNTIME_VULKAN)
|
#if defined(LIBRA_RUNTIME_VULKAN)
|
||||||
/// Function pointer definition for
|
/// Function pointer definition for
|
||||||
///libra_vk_filter_chain_free
|
///libra_vk_filter_chain_free
|
||||||
typedef libra_error_t (*PFN_libra_vk_filter_chain_free)(
|
typedef libra_error_t (*PFN_libra_vk_filter_chain_free)(libra_vk_filter_chain_t *chain);
|
||||||
libra_vk_filter_chain_t *chain);
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
|
@ -500,58 +504,51 @@ LIBRA_ERRNO libra_error_errno(libra_error_t error);
|
||||||
|
|
||||||
/// Print the error message.
|
/// Print the error message.
|
||||||
///
|
///
|
||||||
/// If `error` is null, this function does nothing and returns 1. Otherwise,
|
/// If `error` is null, this function does nothing and returns 1. Otherwise, this function returns 0.
|
||||||
/// this function returns 0.
|
|
||||||
/// ## Safety
|
/// ## Safety
|
||||||
/// - `error` must be a valid and initialized instance of `libra_error_t`.
|
/// - `error` must be a valid and initialized instance of `libra_error_t`.
|
||||||
int32_t libra_error_print(libra_error_t error);
|
int32_t libra_error_print(libra_error_t error);
|
||||||
|
|
||||||
/// Frees any internal state kept by the error.
|
/// Frees any internal state kept by the error.
|
||||||
///
|
///
|
||||||
/// If `error` is null, this function does nothing and returns 1. Otherwise,
|
/// If `error` is null, this function does nothing and returns 1. Otherwise, this function returns 0.
|
||||||
/// this function returns 0. The resulting error object becomes null.
|
/// The resulting error object becomes null.
|
||||||
/// ## Safety
|
/// ## Safety
|
||||||
/// - `error` must be null or a pointer to a valid and initialized instance of
|
/// - `error` must be null or a pointer to a valid and initialized instance of `libra_error_t`.
|
||||||
/// `libra_error_t`.
|
|
||||||
int32_t libra_error_free(libra_error_t *error);
|
int32_t libra_error_free(libra_error_t *error);
|
||||||
|
|
||||||
/// Writes the error message into `out`
|
/// Writes the error message into `out`
|
||||||
///
|
///
|
||||||
/// If `error` is null, this function does nothing and returns 1. Otherwise,
|
/// If `error` is null, this function does nothing and returns 1. Otherwise, this function returns 0.
|
||||||
/// this function returns 0.
|
|
||||||
/// ## Safety
|
/// ## Safety
|
||||||
/// - `error` must be a valid and initialized instance of `libra_error_t`.
|
/// - `error` must be a valid and initialized instance of `libra_error_t`.
|
||||||
/// - `out` must be a non-null pointer. The resulting string must not be
|
/// - `out` must be a non-null pointer. The resulting string must not be modified.
|
||||||
/// modified.
|
int32_t libra_error_write(libra_error_t error,
|
||||||
int32_t libra_error_write(libra_error_t error, char **out);
|
char **out);
|
||||||
|
|
||||||
/// Frees an error string previously allocated by `libra_error_write`.
|
/// Frees an error string previously allocated by `libra_error_write`.
|
||||||
///
|
///
|
||||||
/// After freeing, the pointer will be set to null.
|
/// After freeing, the pointer will be set to null.
|
||||||
/// ## Safety
|
/// ## Safety
|
||||||
/// - If `libra_error_write` is not null, it must point to a string previously
|
/// - If `libra_error_write` is not null, it must point to a string previously returned by `libra_error_write`.
|
||||||
/// returned by `libra_error_write`.
|
/// Attempting to free anything else, including strings or objects from other librashader functions, is immediate
|
||||||
/// Attempting to free anything else, including strings or objects from
|
/// Undefined Behaviour.
|
||||||
/// other librashader functions, is immediate Undefined Behaviour.
|
|
||||||
int32_t libra_error_free_string(char **out);
|
int32_t libra_error_free_string(char **out);
|
||||||
|
|
||||||
/// Load a preset.
|
/// Load a preset.
|
||||||
///
|
///
|
||||||
/// ## Safety
|
/// ## Safety
|
||||||
/// - `filename` must be either null or a valid, aligned pointer to a string
|
/// - `filename` must be either null or a valid, aligned pointer to a string path to the shader preset.
|
||||||
/// path to the shader preset.
|
/// - `out` must be either null, or an aligned pointer to an uninitialized or invalid `libra_shader_preset_t`.
|
||||||
/// - `out` must be either null, or an aligned pointer to an uninitialized or
|
|
||||||
/// invalid `libra_shader_preset_t`.
|
|
||||||
/// ## Returns
|
/// ## Returns
|
||||||
/// - If any parameters are null, `out` is unchanged, and this function returns
|
/// - If any parameters are null, `out` is unchanged, and this function returns `LIBRA_ERR_INVALID_PARAMETER`.
|
||||||
/// `LIBRA_ERR_INVALID_PARAMETER`.
|
|
||||||
libra_error_t libra_preset_create(const char *filename,
|
libra_error_t libra_preset_create(const char *filename,
|
||||||
libra_shader_preset_t *out);
|
libra_shader_preset_t *out);
|
||||||
|
|
||||||
/// Free the preset.
|
/// Free the preset.
|
||||||
///
|
///
|
||||||
/// If `preset` is null, this function does nothing. The resulting value in
|
/// If `preset` is null, this function does nothing. The resulting value in `preset` then becomes
|
||||||
/// `preset` then becomes null.
|
/// null.
|
||||||
///
|
///
|
||||||
/// ## Safety
|
/// ## Safety
|
||||||
/// - `preset` must be a valid and aligned pointer to a shader preset.
|
/// - `preset` must be a valid and aligned pointer to a shader preset.
|
||||||
|
@ -562,8 +559,7 @@ libra_error_t libra_preset_free(libra_shader_preset_t *preset);
|
||||||
/// ## Safety
|
/// ## Safety
|
||||||
/// - `preset` must be null or a valid and aligned pointer to a shader preset.
|
/// - `preset` must be null or a valid and aligned pointer to a shader preset.
|
||||||
/// - `name` must be null or a valid and aligned pointer to a string.
|
/// - `name` must be null or a valid and aligned pointer to a string.
|
||||||
libra_error_t libra_preset_set_param(libra_shader_preset_t *preset,
|
libra_error_t libra_preset_set_param(libra_shader_preset_t *preset, const char *name, float value);
|
||||||
const char *name, float value);
|
|
||||||
|
|
||||||
/// Get the value of the parameter as set in the preset.
|
/// Get the value of the parameter as set in the preset.
|
||||||
///
|
///
|
||||||
|
@ -571,8 +567,7 @@ libra_error_t libra_preset_set_param(libra_shader_preset_t *preset,
|
||||||
/// - `preset` must be null or a valid and aligned pointer to a shader preset.
|
/// - `preset` must be null or a valid and aligned pointer to a shader preset.
|
||||||
/// - `name` must be null or a valid and aligned pointer to a string.
|
/// - `name` must be null or a valid and aligned pointer to a string.
|
||||||
/// - `value` may be a pointer to a uninitialized `float`.
|
/// - `value` may be a pointer to a uninitialized `float`.
|
||||||
libra_error_t libra_preset_get_param(libra_shader_preset_t *preset,
|
libra_error_t libra_preset_get_param(libra_shader_preset_t *preset, const char *name, float *value);
|
||||||
const char *name, float *value);
|
|
||||||
|
|
||||||
/// Pretty print the shader preset.
|
/// Pretty print the shader preset.
|
||||||
///
|
///
|
||||||
|
@ -585,15 +580,13 @@ libra_error_t libra_preset_print(libra_shader_preset_t *preset);
|
||||||
/// ## Safety
|
/// ## Safety
|
||||||
/// - `preset` must be null or a valid and aligned pointer to a shader preset.
|
/// - `preset` must be null or a valid and aligned pointer to a shader preset.
|
||||||
/// - `out` must be an aligned pointer to a `libra_preset_parameter_list_t`.
|
/// - `out` must be an aligned pointer to a `libra_preset_parameter_list_t`.
|
||||||
/// - The output struct should be treated as immutable. Mutating any struct
|
/// - The output struct should be treated as immutable. Mutating any struct fields
|
||||||
/// fields
|
|
||||||
/// in the returned struct may at best cause memory leaks, and at worse
|
/// in the returned struct may at best cause memory leaks, and at worse
|
||||||
/// cause undefined behaviour when later freed.
|
/// cause undefined behaviour when later freed.
|
||||||
/// - It is safe to call `libra_preset_get_runtime_params` multiple times,
|
/// - It is safe to call `libra_preset_get_runtime_params` multiple times, however
|
||||||
/// however
|
|
||||||
/// the output struct must only be freed once per call.
|
/// the output struct must only be freed once per call.
|
||||||
libra_error_t libra_preset_get_runtime_params(
|
libra_error_t libra_preset_get_runtime_params(libra_shader_preset_t *preset,
|
||||||
libra_shader_preset_t *preset, struct libra_preset_param_list_t *out);
|
struct libra_preset_param_list_t *out);
|
||||||
|
|
||||||
/// Free the runtime parameters.
|
/// Free the runtime parameters.
|
||||||
///
|
///
|
||||||
|
@ -603,23 +596,18 @@ libra_error_t libra_preset_get_runtime_params(
|
||||||
/// contained within the input `libra_preset_param_list_t`.
|
/// contained within the input `libra_preset_param_list_t`.
|
||||||
///
|
///
|
||||||
/// ## Safety
|
/// ## Safety
|
||||||
/// - Any pointers rooted at `parameters` becomes invalid after this function
|
/// - Any pointers rooted at `parameters` becomes invalid after this function returns,
|
||||||
/// returns,
|
/// including any strings accessible via the input `libra_preset_param_list_t`.
|
||||||
/// including any strings accessible via the input
|
/// The caller must ensure that there are no live pointers, aliased or unaliased,
|
||||||
/// `libra_preset_param_list_t`. The caller must ensure that there are no live
|
/// to data accessible via the input `libra_preset_param_list_t`.
|
||||||
/// pointers, aliased or unaliased, to data accessible via the input
|
|
||||||
/// `libra_preset_param_list_t`.
|
|
||||||
///
|
///
|
||||||
/// - Accessing any data pointed to via the input `libra_preset_param_list_t`
|
/// - Accessing any data pointed to via the input `libra_preset_param_list_t` after it
|
||||||
/// after it
|
|
||||||
/// has been freed is a use-after-free and is immediate undefined behaviour.
|
/// has been freed is a use-after-free and is immediate undefined behaviour.
|
||||||
///
|
///
|
||||||
/// - If any struct fields of the input `libra_preset_param_list_t` was modified
|
/// - If any struct fields of the input `libra_preset_param_list_t` was modified from
|
||||||
/// from
|
/// their values given after `libra_preset_get_runtime_params`, this may result
|
||||||
/// their values given after `libra_preset_get_runtime_params`, this may
|
/// in undefined behaviour.
|
||||||
/// result in undefined behaviour.
|
libra_error_t libra_preset_free_runtime_params(struct libra_preset_param_list_t preset);
|
||||||
libra_error_t libra_preset_free_runtime_params(
|
|
||||||
struct libra_preset_param_list_t preset);
|
|
||||||
|
|
||||||
#if defined(LIBRA_RUNTIME_OPENGL)
|
#if defined(LIBRA_RUNTIME_OPENGL)
|
||||||
/// Initialize the OpenGL Context for librashader.
|
/// Initialize the OpenGL Context for librashader.
|
||||||
|
@ -628,12 +616,10 @@ libra_error_t libra_preset_free_runtime_params(
|
||||||
/// unless for whatever reason you switch OpenGL loaders mid-flight.
|
/// unless for whatever reason you switch OpenGL loaders mid-flight.
|
||||||
///
|
///
|
||||||
/// ## Safety
|
/// ## Safety
|
||||||
/// Attempting to create a filter chain will fail if the GL context is not
|
/// Attempting to create a filter chain will fail if the GL context is not initialized.
|
||||||
/// initialized.
|
|
||||||
///
|
///
|
||||||
/// Reinitializing the OpenGL context with a different loader immediately
|
/// Reinitializing the OpenGL context with a different loader immediately invalidates previous filter
|
||||||
/// invalidates previous filter chain objects, and drawing with them causes
|
/// chain objects, and drawing with them causes immediate undefined behaviour.
|
||||||
/// immediate undefined behaviour.
|
|
||||||
libra_error_t libra_gl_init_context(libra_gl_loader_t loader);
|
libra_error_t libra_gl_init_context(libra_gl_loader_t loader);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -647,8 +633,8 @@ libra_error_t libra_gl_init_context(libra_gl_loader_t loader);
|
||||||
/// - `preset` must be either null, or valid and aligned.
|
/// - `preset` must be either null, or valid and aligned.
|
||||||
/// - `options` must be either null, or valid and aligned.
|
/// - `options` must be either null, or valid and aligned.
|
||||||
/// - `out` must be aligned, but may be null, invalid, or uninitialized.
|
/// - `out` must be aligned, but may be null, invalid, or uninitialized.
|
||||||
libra_error_t libra_gl_filter_chain_create(
|
libra_error_t libra_gl_filter_chain_create(libra_shader_preset_t *preset,
|
||||||
libra_shader_preset_t *preset, const struct filter_chain_gl_opt_t *options,
|
const struct filter_chain_gl_opt_t *options,
|
||||||
libra_gl_filter_chain_t *out);
|
libra_gl_filter_chain_t *out);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -656,19 +642,18 @@ libra_error_t libra_gl_filter_chain_create(
|
||||||
/// Draw a frame with the given parameters for the given filter chain.
|
/// Draw a frame with the given parameters for the given filter chain.
|
||||||
///
|
///
|
||||||
/// ## Safety
|
/// ## Safety
|
||||||
/// - `chain` may be null, invalid, but not uninitialized. If `chain` is null or
|
/// - `chain` may be null, invalid, but not uninitialized. If `chain` is null or invalid, this
|
||||||
/// invalid, this
|
|
||||||
/// function will return an error.
|
/// function will return an error.
|
||||||
/// - `mvp` may be null, or if it is not null, must be an aligned pointer to 16
|
/// - `mvp` may be null, or if it is not null, must be an aligned pointer to 16 consecutive `float`
|
||||||
/// consecutive `float`
|
|
||||||
/// values for the model view projection matrix.
|
/// values for the model view projection matrix.
|
||||||
/// - `opt` may be null, or if it is not null, must be an aligned pointer to a
|
/// - `opt` may be null, or if it is not null, must be an aligned pointer to a valid `frame_gl_opt_t`
|
||||||
/// valid `frame_gl_opt_t`
|
|
||||||
/// struct.
|
/// struct.
|
||||||
libra_error_t libra_gl_filter_chain_frame(
|
libra_error_t libra_gl_filter_chain_frame(libra_gl_filter_chain_t *chain,
|
||||||
libra_gl_filter_chain_t *chain, size_t frame_count,
|
size_t frame_count,
|
||||||
struct libra_source_image_gl_t image, struct libra_viewport_t viewport,
|
struct libra_source_image_gl_t image,
|
||||||
struct libra_draw_framebuffer_gl_t out, const float *mvp,
|
struct libra_viewport_t viewport,
|
||||||
|
struct libra_draw_framebuffer_gl_t out,
|
||||||
|
const float *mvp,
|
||||||
const struct frame_gl_opt_t *opt);
|
const struct frame_gl_opt_t *opt);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -677,8 +662,7 @@ libra_error_t libra_gl_filter_chain_frame(
|
||||||
///
|
///
|
||||||
/// If the parameter does not exist, returns an error.
|
/// If the parameter does not exist, returns an error.
|
||||||
/// ## Safety
|
/// ## Safety
|
||||||
/// - `chain` must be either null or a valid and aligned pointer to an
|
/// - `chain` must be either null or a valid and aligned pointer to an initialized `libra_gl_filter_chain_t`.
|
||||||
/// initialized `libra_gl_filter_chain_t`.
|
|
||||||
/// - `param_name` must be either null or a null terminated string.
|
/// - `param_name` must be either null or a null terminated string.
|
||||||
libra_error_t libra_gl_filter_chain_set_param(libra_gl_filter_chain_t *chain,
|
libra_error_t libra_gl_filter_chain_set_param(libra_gl_filter_chain_t *chain,
|
||||||
const char *param_name,
|
const char *param_name,
|
||||||
|
@ -690,8 +674,7 @@ libra_error_t libra_gl_filter_chain_set_param(libra_gl_filter_chain_t *chain,
|
||||||
///
|
///
|
||||||
/// If the parameter does not exist, returns an error.
|
/// If the parameter does not exist, returns an error.
|
||||||
/// ## Safety
|
/// ## Safety
|
||||||
/// - `chain` must be either null or a valid and aligned pointer to an
|
/// - `chain` must be either null or a valid and aligned pointer to an initialized `libra_gl_filter_chain_t`.
|
||||||
/// initialized `libra_gl_filter_chain_t`.
|
|
||||||
/// - `param_name` must be either null or a null terminated string.
|
/// - `param_name` must be either null or a null terminated string.
|
||||||
libra_error_t libra_gl_filter_chain_get_param(libra_gl_filter_chain_t *chain,
|
libra_error_t libra_gl_filter_chain_get_param(libra_gl_filter_chain_t *chain,
|
||||||
const char *param_name,
|
const char *param_name,
|
||||||
|
@ -702,20 +685,18 @@ libra_error_t libra_gl_filter_chain_get_param(libra_gl_filter_chain_t *chain,
|
||||||
/// Sets the number of active passes for this chain.
|
/// Sets the number of active passes for this chain.
|
||||||
///
|
///
|
||||||
/// ## Safety
|
/// ## Safety
|
||||||
/// - `chain` must be either null or a valid and aligned pointer to an
|
/// - `chain` must be either null or a valid and aligned pointer to an initialized `libra_gl_filter_chain_t`.
|
||||||
/// initialized `libra_gl_filter_chain_t`.
|
libra_error_t libra_gl_filter_chain_set_active_pass_count(libra_gl_filter_chain_t *chain,
|
||||||
libra_error_t libra_gl_filter_chain_set_active_pass_count(
|
uint32_t value);
|
||||||
libra_gl_filter_chain_t *chain, uint32_t value);
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(LIBRA_RUNTIME_OPENGL)
|
#if defined(LIBRA_RUNTIME_OPENGL)
|
||||||
/// Gets the number of active passes for this chain.
|
/// Gets the number of active passes for this chain.
|
||||||
///
|
///
|
||||||
/// ## Safety
|
/// ## Safety
|
||||||
/// - `chain` must be either null or a valid and aligned pointer to an
|
/// - `chain` must be either null or a valid and aligned pointer to an initialized `libra_gl_filter_chain_t`.
|
||||||
/// initialized `libra_gl_filter_chain_t`.
|
libra_error_t libra_gl_filter_chain_get_active_pass_count(libra_gl_filter_chain_t *chain,
|
||||||
libra_error_t libra_gl_filter_chain_get_active_pass_count(
|
uint32_t *out);
|
||||||
libra_gl_filter_chain_t *chain, uint32_t *out);
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(LIBRA_RUNTIME_OPENGL)
|
#if defined(LIBRA_RUNTIME_OPENGL)
|
||||||
|
@ -723,8 +704,7 @@ libra_error_t libra_gl_filter_chain_get_active_pass_count(
|
||||||
///
|
///
|
||||||
/// The resulting value in `chain` then becomes null.
|
/// The resulting value in `chain` then becomes null.
|
||||||
/// ## Safety
|
/// ## Safety
|
||||||
/// - `chain` must be either null or a valid and aligned pointer to an
|
/// - `chain` must be either null or a valid and aligned pointer to an initialized `libra_gl_filter_chain_t`.
|
||||||
/// initialized `libra_gl_filter_chain_t`.
|
|
||||||
libra_error_t libra_gl_filter_chain_free(libra_gl_filter_chain_t *chain);
|
libra_error_t libra_gl_filter_chain_free(libra_gl_filter_chain_t *chain);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -738,9 +718,9 @@ libra_error_t libra_gl_filter_chain_free(libra_gl_filter_chain_t *chain);
|
||||||
/// - `preset` must be either null, or valid and aligned.
|
/// - `preset` must be either null, or valid and aligned.
|
||||||
/// - `options` must be either null, or valid and aligned.
|
/// - `options` must be either null, or valid and aligned.
|
||||||
/// - `out` must be aligned, but may be null, invalid, or uninitialized.
|
/// - `out` must be aligned, but may be null, invalid, or uninitialized.
|
||||||
libra_error_t libra_d3d11_filter_chain_create(
|
libra_error_t libra_d3d11_filter_chain_create(libra_shader_preset_t *preset,
|
||||||
libra_shader_preset_t *preset,
|
const struct filter_chain_d3d11_opt_t *options,
|
||||||
const struct filter_chain_d3d11_opt_t *options, const ID3D11Device *device,
|
const ID3D11Device *device,
|
||||||
libra_d3d11_filter_chain_t *out);
|
libra_d3d11_filter_chain_t *out);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -748,19 +728,18 @@ libra_error_t libra_d3d11_filter_chain_create(
|
||||||
/// Draw a frame with the given parameters for the given filter chain.
|
/// Draw a frame with the given parameters for the given filter chain.
|
||||||
///
|
///
|
||||||
/// ## Safety
|
/// ## Safety
|
||||||
/// - `chain` may be null, invalid, but not uninitialized. If `chain` is null or
|
/// - `chain` may be null, invalid, but not uninitialized. If `chain` is null or invalid, this
|
||||||
/// invalid, this
|
|
||||||
/// function will return an error.
|
/// function will return an error.
|
||||||
/// - `mvp` may be null, or if it is not null, must be an aligned pointer to 16
|
/// - `mvp` may be null, or if it is not null, must be an aligned pointer to 16 consecutive `float`
|
||||||
/// consecutive `float`
|
|
||||||
/// values for the model view projection matrix.
|
/// values for the model view projection matrix.
|
||||||
/// - `opt` may be null, or if it is not null, must be an aligned pointer to a
|
/// - `opt` may be null, or if it is not null, must be an aligned pointer to a valid `frame_gl_opt_t`
|
||||||
/// valid `frame_gl_opt_t`
|
|
||||||
/// struct.
|
/// struct.
|
||||||
libra_error_t libra_d3d11_filter_chain_frame(
|
libra_error_t libra_d3d11_filter_chain_frame(libra_d3d11_filter_chain_t *chain,
|
||||||
libra_d3d11_filter_chain_t *chain, size_t frame_count,
|
size_t frame_count,
|
||||||
struct libra_source_image_d3d11_t image, struct libra_viewport_t viewport,
|
struct libra_source_image_d3d11_t image,
|
||||||
const ID3D11RenderTargetView *out, const float *mvp,
|
struct libra_viewport_t viewport,
|
||||||
|
const ID3D11RenderTargetView *out,
|
||||||
|
const float *mvp,
|
||||||
const struct frame_d3d11_opt_t *opt);
|
const struct frame_d3d11_opt_t *opt);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -769,11 +748,11 @@ libra_error_t libra_d3d11_filter_chain_frame(
|
||||||
///
|
///
|
||||||
/// If the parameter does not exist, returns an error.
|
/// If the parameter does not exist, returns an error.
|
||||||
/// ## Safety
|
/// ## Safety
|
||||||
/// - `chain` must be either null or a valid and aligned pointer to an
|
/// - `chain` must be either null or a valid and aligned pointer to an initialized `libra_d3d11_filter_chain_t`.
|
||||||
/// initialized `libra_d3d11_filter_chain_t`.
|
|
||||||
/// - `param_name` must be either null or a null terminated string.
|
/// - `param_name` must be either null or a null terminated string.
|
||||||
libra_error_t libra_d3d11_filter_chain_set_param(
|
libra_error_t libra_d3d11_filter_chain_set_param(libra_d3d11_filter_chain_t *chain,
|
||||||
libra_d3d11_filter_chain_t *chain, const char *param_name, float value);
|
const char *param_name,
|
||||||
|
float value);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(LIBRA_RUNTIME_D3D11)
|
#if defined(LIBRA_RUNTIME_D3D11)
|
||||||
|
@ -781,31 +760,29 @@ libra_error_t libra_d3d11_filter_chain_set_param(
|
||||||
///
|
///
|
||||||
/// If the parameter does not exist, returns an error.
|
/// If the parameter does not exist, returns an error.
|
||||||
/// ## Safety
|
/// ## Safety
|
||||||
/// - `chain` must be either null or a valid and aligned pointer to an
|
/// - `chain` must be either null or a valid and aligned pointer to an initialized `libra_d3d11_filter_chain_t`.
|
||||||
/// initialized `libra_d3d11_filter_chain_t`.
|
|
||||||
/// - `param_name` must be either null or a null terminated string.
|
/// - `param_name` must be either null or a null terminated string.
|
||||||
libra_error_t libra_d3d11_filter_chain_get_param(
|
libra_error_t libra_d3d11_filter_chain_get_param(libra_d3d11_filter_chain_t *chain,
|
||||||
libra_d3d11_filter_chain_t *chain, const char *param_name, float *out);
|
const char *param_name,
|
||||||
|
float *out);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(LIBRA_RUNTIME_D3D11)
|
#if defined(LIBRA_RUNTIME_D3D11)
|
||||||
/// Sets the number of active passes for this chain.
|
/// Sets the number of active passes for this chain.
|
||||||
///
|
///
|
||||||
/// ## Safety
|
/// ## Safety
|
||||||
/// - `chain` must be either null or a valid and aligned pointer to an
|
/// - `chain` must be either null or a valid and aligned pointer to an initialized `libra_d3d11_filter_chain_t`.
|
||||||
/// initialized `libra_d3d11_filter_chain_t`.
|
libra_error_t libra_d3d11_filter_chain_set_active_pass_count(libra_d3d11_filter_chain_t *chain,
|
||||||
libra_error_t libra_d3d11_filter_chain_set_active_pass_count(
|
uint32_t value);
|
||||||
libra_d3d11_filter_chain_t *chain, uint32_t value);
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(LIBRA_RUNTIME_D3D11)
|
#if defined(LIBRA_RUNTIME_D3D11)
|
||||||
/// Gets the number of active passes for this chain.
|
/// Gets the number of active passes for this chain.
|
||||||
///
|
///
|
||||||
/// ## Safety
|
/// ## Safety
|
||||||
/// - `chain` must be either null or a valid and aligned pointer to an
|
/// - `chain` must be either null or a valid and aligned pointer to an initialized `libra_d3d11_filter_chain_t`.
|
||||||
/// initialized `libra_d3d11_filter_chain_t`.
|
libra_error_t libra_d3d11_filter_chain_get_active_pass_count(libra_d3d11_filter_chain_t *chain,
|
||||||
libra_error_t libra_d3d11_filter_chain_get_active_pass_count(
|
uint32_t *out);
|
||||||
libra_d3d11_filter_chain_t *chain, uint32_t *out);
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(LIBRA_RUNTIME_D3D11)
|
#if defined(LIBRA_RUNTIME_D3D11)
|
||||||
|
@ -813,8 +790,7 @@ libra_error_t libra_d3d11_filter_chain_get_active_pass_count(
|
||||||
///
|
///
|
||||||
/// The resulting value in `chain` then becomes null.
|
/// The resulting value in `chain` then becomes null.
|
||||||
/// ## Safety
|
/// ## Safety
|
||||||
/// - `chain` must be either null or a valid and aligned pointer to an
|
/// - `chain` must be either null or a valid and aligned pointer to an initialized `libra_d3d11_filter_chain_t`.
|
||||||
/// initialized `libra_d3d11_filter_chain_t`.
|
|
||||||
libra_error_t libra_d3d11_filter_chain_free(libra_d3d11_filter_chain_t *chain);
|
libra_error_t libra_d3d11_filter_chain_free(libra_d3d11_filter_chain_t *chain);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -825,43 +801,41 @@ libra_error_t libra_d3d11_filter_chain_free(libra_d3d11_filter_chain_t *chain);
|
||||||
/// the filter chain is created.
|
/// the filter chain is created.
|
||||||
///
|
///
|
||||||
/// ## Safety:
|
/// ## Safety:
|
||||||
/// - The handles provided in `vulkan` must be valid for the command buffers
|
/// - The handles provided in `vulkan` must be valid for the command buffers that
|
||||||
/// that
|
/// `libra_vk_filter_chain_frame` will write to. Namely, the VkDevice must have been
|
||||||
/// `libra_vk_filter_chain_frame` will write to. Namely, the VkDevice must
|
|
||||||
/// have been
|
|
||||||
/// created with the `VK_KHR_dynamic_rendering` extension.
|
/// created with the `VK_KHR_dynamic_rendering` extension.
|
||||||
/// - `preset` must be either null, or valid and aligned.
|
/// - `preset` must be either null, or valid and aligned.
|
||||||
/// - `options` must be either null, or valid and aligned.
|
/// - `options` must be either null, or valid and aligned.
|
||||||
/// - `out` must be aligned, but may be null, invalid, or uninitialized.
|
/// - `out` must be aligned, but may be null, invalid, or uninitialized.
|
||||||
libra_error_t libra_vk_filter_chain_create(
|
libra_error_t libra_vk_filter_chain_create(struct libra_device_vk_t vulkan,
|
||||||
struct libra_device_vk_t vulkan, libra_shader_preset_t *preset,
|
libra_shader_preset_t *preset,
|
||||||
const struct filter_chain_vk_opt_t *options, libra_vk_filter_chain_t *out);
|
const struct filter_chain_vk_opt_t *options,
|
||||||
|
libra_vk_filter_chain_t *out);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(LIBRA_RUNTIME_VULKAN)
|
#if defined(LIBRA_RUNTIME_VULKAN)
|
||||||
/// Records rendering commands for a frame with the given parameters for the
|
/// Records rendering commands for a frame with the given parameters for the given filter chain
|
||||||
/// given filter chain to the input command buffer.
|
/// to the input command buffer.
|
||||||
///
|
///
|
||||||
/// librashader will not do any queue submissions.
|
/// librashader will not do any queue submissions.
|
||||||
///
|
///
|
||||||
/// ## Safety
|
/// ## Safety
|
||||||
/// - `libra_vk_filter_chain_frame` **must not be called within a RenderPass**.
|
/// - `libra_vk_filter_chain_frame` **must not be called within a RenderPass**.
|
||||||
/// - `command_buffer` must be a valid handle to a `VkCommandBuffer` that is
|
/// - `command_buffer` must be a valid handle to a `VkCommandBuffer` that is ready for recording.
|
||||||
/// ready for recording.
|
/// - `chain` may be null, invalid, but not uninitialized. If `chain` is null or invalid, this
|
||||||
/// - `chain` may be null, invalid, but not uninitialized. If `chain` is null or
|
|
||||||
/// invalid, this
|
|
||||||
/// function will return an error.
|
/// function will return an error.
|
||||||
/// - `mvp` may be null, or if it is not null, must be an aligned pointer to 16
|
/// - `mvp` may be null, or if it is not null, must be an aligned pointer to 16 consecutive `float`
|
||||||
/// consecutive `float`
|
|
||||||
/// values for the model view projection matrix.
|
/// values for the model view projection matrix.
|
||||||
/// - `opt` may be null, or if it is not null, must be an aligned pointer to a
|
/// - `opt` may be null, or if it is not null, must be an aligned pointer to a valid `frame_vk_opt_t`
|
||||||
/// valid `frame_vk_opt_t`
|
|
||||||
/// struct.
|
/// struct.
|
||||||
libra_error_t libra_vk_filter_chain_frame(
|
libra_error_t libra_vk_filter_chain_frame(libra_vk_filter_chain_t *chain,
|
||||||
libra_vk_filter_chain_t *chain, VkCommandBuffer command_buffer,
|
VkCommandBuffer command_buffer,
|
||||||
size_t frame_count, struct libra_image_vk_t image,
|
size_t frame_count,
|
||||||
struct libra_viewport_t viewport, struct libra_image_vk_t out,
|
struct libra_image_vk_t image,
|
||||||
const float *mvp, const struct frame_vk_opt_t *opt);
|
struct libra_viewport_t viewport,
|
||||||
|
struct libra_image_vk_t out,
|
||||||
|
const float *mvp,
|
||||||
|
const struct frame_vk_opt_t *opt);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(LIBRA_RUNTIME_VULKAN)
|
#if defined(LIBRA_RUNTIME_VULKAN)
|
||||||
|
@ -869,8 +843,7 @@ libra_error_t libra_vk_filter_chain_frame(
|
||||||
///
|
///
|
||||||
/// If the parameter does not exist, returns an error.
|
/// If the parameter does not exist, returns an error.
|
||||||
/// ## Safety
|
/// ## Safety
|
||||||
/// - `chain` must be either null or a valid and aligned pointer to an
|
/// - `chain` must be either null or a valid and aligned pointer to an initialized `libra_vk_filter_chain_t`.
|
||||||
/// initialized `libra_vk_filter_chain_t`.
|
|
||||||
/// - `param_name` must be either null or a null terminated string.
|
/// - `param_name` must be either null or a null terminated string.
|
||||||
libra_error_t libra_vk_filter_chain_set_param(libra_vk_filter_chain_t *chain,
|
libra_error_t libra_vk_filter_chain_set_param(libra_vk_filter_chain_t *chain,
|
||||||
const char *param_name,
|
const char *param_name,
|
||||||
|
@ -882,8 +855,7 @@ libra_error_t libra_vk_filter_chain_set_param(libra_vk_filter_chain_t *chain,
|
||||||
///
|
///
|
||||||
/// If the parameter does not exist, returns an error.
|
/// If the parameter does not exist, returns an error.
|
||||||
/// ## Safety
|
/// ## Safety
|
||||||
/// - `chain` must be either null or a valid and aligned pointer to an
|
/// - `chain` must be either null or a valid and aligned pointer to an initialized `libra_vk_filter_chain_t`.
|
||||||
/// initialized `libra_vk_filter_chain_t`.
|
|
||||||
/// - `param_name` must be either null or a null terminated string.
|
/// - `param_name` must be either null or a null terminated string.
|
||||||
libra_error_t libra_vk_filter_chain_get_param(libra_vk_filter_chain_t *chain,
|
libra_error_t libra_vk_filter_chain_get_param(libra_vk_filter_chain_t *chain,
|
||||||
const char *param_name,
|
const char *param_name,
|
||||||
|
@ -894,20 +866,18 @@ libra_error_t libra_vk_filter_chain_get_param(libra_vk_filter_chain_t *chain,
|
||||||
/// Sets the number of active passes for this chain.
|
/// Sets the number of active passes for this chain.
|
||||||
///
|
///
|
||||||
/// ## Safety
|
/// ## Safety
|
||||||
/// - `chain` must be either null or a valid and aligned pointer to an
|
/// - `chain` must be either null or a valid and aligned pointer to an initialized `libra_vk_filter_chain_t`.
|
||||||
/// initialized `libra_vk_filter_chain_t`.
|
libra_error_t libra_vk_filter_chain_set_active_pass_count(libra_vk_filter_chain_t *chain,
|
||||||
libra_error_t libra_vk_filter_chain_set_active_pass_count(
|
uint32_t value);
|
||||||
libra_vk_filter_chain_t *chain, uint32_t value);
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(LIBRA_RUNTIME_VULKAN)
|
#if defined(LIBRA_RUNTIME_VULKAN)
|
||||||
/// Gets the number of active passes for this chain.
|
/// Gets the number of active passes for this chain.
|
||||||
///
|
///
|
||||||
/// ## Safety
|
/// ## Safety
|
||||||
/// - `chain` must be either null or a valid and aligned pointer to an
|
/// - `chain` must be either null or a valid and aligned pointer to an initialized `libra_vk_filter_chain_t`.
|
||||||
/// initialized `libra_vk_filter_chain_t`.
|
libra_error_t libra_vk_filter_chain_get_active_pass_count(libra_vk_filter_chain_t *chain,
|
||||||
libra_error_t libra_vk_filter_chain_get_active_pass_count(
|
uint32_t *out);
|
||||||
libra_vk_filter_chain_t *chain, uint32_t *out);
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(LIBRA_RUNTIME_VULKAN)
|
#if defined(LIBRA_RUNTIME_VULKAN)
|
||||||
|
@ -915,8 +885,7 @@ libra_error_t libra_vk_filter_chain_get_active_pass_count(
|
||||||
///
|
///
|
||||||
/// The resulting value in `chain` then becomes null.
|
/// The resulting value in `chain` then becomes null.
|
||||||
/// ## Safety
|
/// ## Safety
|
||||||
/// - `chain` must be either null or a valid and aligned pointer to an
|
/// - `chain` must be either null or a valid and aligned pointer to an initialized `libra_vk_filter_chain_t`.
|
||||||
/// initialized `libra_vk_filter_chain_t`.
|
|
||||||
libra_error_t libra_vk_filter_chain_free(libra_vk_filter_chain_t *chain);
|
libra_error_t libra_vk_filter_chain_free(libra_vk_filter_chain_t *chain);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
|
@ -30,8 +30,8 @@ pub struct libra_viewport_t {
|
||||||
pub x: f32,
|
pub x: f32,
|
||||||
/// The y offset in the viewport framebuffer to begin rendering from.
|
/// The y offset in the viewport framebuffer to begin rendering from.
|
||||||
pub y: f32,
|
pub y: f32,
|
||||||
/// The width of the viewport framebuffer.
|
|
||||||
pub width: u32,
|
|
||||||
/// The height of the viewport framebuffer.
|
/// The height of the viewport framebuffer.
|
||||||
pub height: u32,
|
pub height: u32,
|
||||||
|
/// The width of the viewport framebuffer.
|
||||||
|
pub width: u32,
|
||||||
}
|
}
|
||||||
|
|
|
@ -21,10 +21,10 @@ use librashader::runtime::{FilterChainParameters, Size, Viewport};
|
||||||
pub struct libra_source_image_d3d11_t {
|
pub struct libra_source_image_d3d11_t {
|
||||||
/// A shader resource view into the source image
|
/// A shader resource view into the source image
|
||||||
pub handle: *const ID3D11ShaderResourceView,
|
pub handle: *const ID3D11ShaderResourceView,
|
||||||
/// The width of the source image.
|
|
||||||
pub width: u32,
|
|
||||||
/// The height of the source image.
|
/// The height of the source image.
|
||||||
pub height: u32,
|
pub height: u32,
|
||||||
|
/// The width of the source image.
|
||||||
|
pub width: u32,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl TryFrom<libra_source_image_d3d11_t> for D3D11InputView {
|
impl TryFrom<libra_source_image_d3d11_t> for D3D11InputView {
|
||||||
|
|
|
@ -23,10 +23,10 @@ pub struct libra_source_image_gl_t {
|
||||||
pub handle: u32,
|
pub handle: u32,
|
||||||
/// The format of the source image.
|
/// The format of the source image.
|
||||||
pub format: u32,
|
pub format: u32,
|
||||||
/// The width of the source image.
|
|
||||||
pub width: u32,
|
|
||||||
/// The height of the source image.
|
/// The height of the source image.
|
||||||
pub height: u32,
|
pub height: u32,
|
||||||
|
/// The width of the source image.
|
||||||
|
pub width: u32,
|
||||||
}
|
}
|
||||||
|
|
||||||
/// OpenGL parameters for the output framebuffer.
|
/// OpenGL parameters for the output framebuffer.
|
||||||
|
|
|
@ -28,10 +28,10 @@ pub struct libra_image_vk_t {
|
||||||
pub handle: vk::Image,
|
pub handle: vk::Image,
|
||||||
/// The `VkFormat` of the source image.
|
/// The `VkFormat` of the source image.
|
||||||
pub format: vk::Format,
|
pub format: vk::Format,
|
||||||
/// The width of the source image.
|
|
||||||
pub width: u32,
|
|
||||||
/// The height of the source image.
|
/// The height of the source image.
|
||||||
pub height: u32,
|
pub height: u32,
|
||||||
|
/// The width of the source image.
|
||||||
|
pub width: u32,
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Handles required to instantiate vulkan
|
/// Handles required to instantiate vulkan
|
||||||
|
|
Loading…
Add table
Reference in a new issue