RetroArch/gfx/video_context_driver.h

350 lines
11 KiB
C
Raw Normal View History

/* RetroArch - A frontend for libretro.
2014-01-01 00:50:59 +00:00
* Copyright (C) 2010-2014 - Hans-Kristian Arntzen
2016-01-10 03:41:52 +00:00
* Copyright (C) 2011-2016 - Daniel De Matteis
2016-10-27 15:47:10 +00:00
* Copyright (C) 2016 - Brad Parker
*
* RetroArch is free software: you can redistribute it and/or modify it under the terms
* of the GNU General Public License as published by the Free Software Found-
* ation, either version 3 of the License, or (at your option) any later version.
*
* RetroArch is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
* PURPOSE. See the GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License along with RetroArch.
* If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef __VIDEO_CONTEXT_DRIVER_H
#define __VIDEO_CONTEXT_DRIVER_H
#include <boolean.h>
2016-06-03 03:43:49 +00:00
#include <retro_common_api.h>
2015-12-05 06:45:36 +00:00
#include "video_driver.h"
2016-06-03 03:43:49 +00:00
RETRO_BEGIN_DECLS
2014-01-22 15:38:42 +00:00
2015-01-12 03:19:57 +00:00
#ifndef MAX_EGLIMAGE_TEXTURES
#define MAX_EGLIMAGE_TEXTURES 32
2015-01-12 03:19:57 +00:00
#endif
2012-09-24 23:26:22 +00:00
enum gfx_ctx_api
{
2015-11-20 12:27:31 +00:00
GFX_CTX_NONE = 0,
2012-09-24 23:26:22 +00:00
GFX_CTX_OPENGL_API,
GFX_CTX_OPENGL_ES_API,
GFX_CTX_DIRECT3D8_API,
GFX_CTX_DIRECT3D9_API,
2016-02-16 19:24:00 +00:00
GFX_CTX_OPENVG_API,
2017-01-04 19:03:01 +00:00
GFX_CTX_VULKAN_API,
GFX_CTX_GDI_API
2012-09-24 23:26:22 +00:00
};
enum display_metric_types
{
DISPLAY_METRIC_NONE = 0,
DISPLAY_METRIC_MM_WIDTH,
DISPLAY_METRIC_MM_HEIGHT,
2015-06-26 15:46:13 +00:00
DISPLAY_METRIC_DPI
};
2012-09-24 23:26:22 +00:00
enum display_flags
{
GFX_CTX_FLAGS_NONE = 0,
GFX_CTX_FLAGS_GL_CORE_CONTEXT,
2016-10-08 12:00:06 +00:00
GFX_CTX_FLAGS_MULTISAMPLING,
GFX_CTX_FLAGS_CUSTOMIZABLE_SWAPCHAIN_IMAGES
};
2012-09-24 23:26:22 +00:00
typedef void (*gfx_ctx_proc_t)(void);
typedef struct gfx_ctx_driver
{
/* The opaque pointer is the underlying video driver data (e.g. gl_t for
* OpenGL contexts). Although not advised, the context driver is allowed
* to hold a pointer to it as the context never outlives the video driver.
*
* The context driver is responsible for it's own data.*/
void* (*init)(video_frame_info_t video_info, void *video_driver);
void (*destroy)(void *data);
2012-09-24 23:26:22 +00:00
2014-09-08 15:57:18 +00:00
/* Which API to bind to. */
bool (*bind_api)(void *video_driver, enum gfx_ctx_api,
2014-09-08 15:57:18 +00:00
unsigned major, unsigned minor);
2012-09-24 23:26:22 +00:00
2014-09-08 15:57:18 +00:00
/* Sets the swap interval. */
void (*swap_interval)(void *data, unsigned);
2012-09-24 23:26:22 +00:00
2014-09-08 15:57:18 +00:00
/* Sets video mode. Creates a window, etc. */
2017-01-18 16:41:27 +00:00
bool (*set_video_mode)(void*, video_frame_info_t *video_info, unsigned, unsigned, bool);
2012-09-24 23:26:22 +00:00
2014-09-08 15:57:18 +00:00
/* Gets current window size.
* If not initialized yet, it returns current screen size. */
void (*get_video_size)(void*, unsigned*, unsigned*);
2012-09-24 23:26:22 +00:00
void (*get_video_output_size)(void*, unsigned*, unsigned*);
void (*get_video_output_prev)(void*);
void (*get_video_output_next)(void*);
bool (*get_metrics)(void *data, enum display_metric_types type,
float *value);
2014-09-08 15:57:18 +00:00
/* Translates a window size to an aspect ratio.
* In most cases this will be just width / height, but
* some contexts will better know which actual aspect ratio is used.
* This can be NULL to assume the default behavior.
*/
float (*translate_aspect)(void*, unsigned, unsigned);
2012-09-25 11:51:44 +00:00
2014-09-08 15:57:18 +00:00
/* Asks driver to update window title (FPS, etc). */
2017-01-18 16:41:27 +00:00
void (*update_window_title)(void*, video_frame_info_t *video_info);
2012-09-24 23:26:22 +00:00
2014-09-08 15:57:18 +00:00
/* Queries for resize and quit events.
* Also processes events. */
void (*check_window)(void*, bool*, bool*,
unsigned*, unsigned*);
2012-09-24 23:26:22 +00:00
/* Acknowledge a resize event. This is needed for some APIs.
2014-09-08 15:57:18 +00:00
* Most backends will ignore this. */
bool (*set_resize)(void*, unsigned, unsigned);
2012-09-24 23:26:22 +00:00
2014-09-08 15:57:18 +00:00
/* Checks if window has input focus. */
bool (*has_focus)(void*);
2012-09-24 23:26:22 +00:00
2015-01-18 21:32:14 +00:00
/* Should the screensaver be suppressed? */
2015-04-10 06:05:31 +00:00
bool (*suppress_screensaver)(void *data, bool enable);
2015-04-10 06:05:31 +00:00
/* Checks if context driver has windowed support. */
bool (*has_windowed)(void*);
/* Swaps buffers. VBlank sync depends on
2014-09-08 15:57:18 +00:00
* earlier calls to swap_interval. */
2017-01-18 16:41:27 +00:00
void (*swap_buffers)(void*, video_frame_info_t *video_info);
2012-09-24 23:26:22 +00:00
2014-09-08 15:57:18 +00:00
/* Most video backends will want to use a certain input driver.
* Checks for it here. */
void (*input_driver)(void*, const char *, const input_driver_t**, void**);
2012-09-24 23:26:22 +00:00
2014-09-08 15:57:18 +00:00
/* Wraps whatever gl_proc_address() there is.
* Does not take opaque, to avoid lots of ugly wrapper code. */
2012-09-24 23:26:22 +00:00
gfx_ctx_proc_t (*get_proc_address)(const char*);
/* Returns true if this context supports EGLImage buffers for
2014-09-08 15:57:18 +00:00
* screen drawing and was initalized correctly. */
2015-04-10 07:02:24 +00:00
bool (*image_buffer_init)(void*, const video_info_t*);
2014-09-08 15:57:18 +00:00
/* Writes the frame to the EGLImage and sets image_handle to it.
2014-09-08 15:57:18 +00:00
* Returns true if a new image handle is created.
* Always returns true the first time it's called for a new index.
2014-09-08 15:57:18 +00:00
* The graphics core must handle a change in the handle correctly. */
2015-04-10 07:02:24 +00:00
bool (*image_buffer_write)(void*, const void *frame, unsigned width,
2014-09-08 15:57:18 +00:00
unsigned height, unsigned pitch, bool rgb32,
unsigned index, void **image_handle);
/* Shows or hides mouse. Can be NULL if context doesn't
2014-09-08 15:57:18 +00:00
* have a concept of mouse pointer. */
2015-01-18 21:32:14 +00:00
void (*show_mouse)(void *data, bool state);
2013-03-29 12:46:11 +00:00
2014-09-08 15:57:18 +00:00
/* Human readable string. */
2012-09-24 23:26:22 +00:00
const char *ident;
uint32_t (*get_flags)(void *data);
2016-05-05 15:35:28 +00:00
void (*set_flags)(void *data, uint32_t flags);
2014-09-08 15:57:18 +00:00
/* Optional. Binds HW-render offscreen context. */
void (*bind_hw_render)(void *data, bool enable);
2016-02-16 19:24:00 +00:00
/* Optional. Gets base data for the context which is used by the driver.
* This is mostly relevant for graphics APIs such as Vulkan
* which do not have global context state. */
void *(*get_context_data)(void *data);
/* Optional. Makes driver context (only GLX right now)
* active for this thread. */
void (*make_current)(bool release);
2012-09-24 23:26:22 +00:00
} gfx_ctx_driver_t;
2016-05-05 03:49:48 +00:00
typedef struct gfx_ctx_flags
{
uint32_t flags;
} gfx_ctx_flags_t;
2016-02-13 18:36:02 +00:00
typedef struct gfx_ctx_size
{
2016-02-13 18:53:14 +00:00
bool *quit;
bool *resize;
2016-02-13 18:36:02 +00:00
unsigned *width;
unsigned *height;
} gfx_ctx_size_t;
2016-02-14 01:12:18 +00:00
typedef struct gfx_ctx_mode
{
unsigned width;
unsigned height;
bool fullscreen;
} gfx_ctx_mode_t;
2016-02-13 20:58:35 +00:00
typedef struct gfx_ctx_metrics
{
enum display_metric_types type;
float *value;
} gfx_ctx_metrics_t;
typedef struct gfx_ctx_aspect
{
float *aspect;
2016-02-13 21:07:56 +00:00
unsigned width;
unsigned height;
2016-02-13 20:58:35 +00:00
} gfx_ctx_aspect_t;
typedef struct gfx_ctx_image
{
const void *frame;
unsigned width;
unsigned height;
unsigned pitch;
unsigned index;
bool rgb32;
void **handle;
} gfx_ctx_image_t;
typedef struct gfx_ctx_input
{
const input_driver_t **input;
void **input_data;
} gfx_ctx_input_t;
typedef struct gfx_ctx_proc_address
{
const char *sym;
retro_proc_address_t addr;
} gfx_ctx_proc_address_t;
2016-02-14 01:05:20 +00:00
typedef struct gfx_ctx_ident
{
const char *ident;
} gfx_ctx_ident_t;
2016-07-30 14:37:22 +00:00
extern const gfx_ctx_driver_t gfx_ctx_osmesa;
2012-09-24 23:26:22 +00:00
extern const gfx_ctx_driver_t gfx_ctx_sdl_gl;
extern const gfx_ctx_driver_t gfx_ctx_x_egl;
extern const gfx_ctx_driver_t gfx_ctx_wayland;
2016-02-20 04:48:45 +00:00
extern const gfx_ctx_driver_t gfx_ctx_x;
2014-09-14 04:45:47 +00:00
extern const gfx_ctx_driver_t gfx_ctx_d3d;
2016-02-22 11:59:13 +00:00
extern const gfx_ctx_driver_t gfx_ctx_drm;
2014-06-05 10:28:17 +00:00
extern const gfx_ctx_driver_t gfx_ctx_mali_fbdev;
2014-07-27 20:19:11 +00:00
extern const gfx_ctx_driver_t gfx_ctx_vivante_fbdev;
2012-10-08 22:11:11 +00:00
extern const gfx_ctx_driver_t gfx_ctx_android;
2012-09-24 23:26:22 +00:00
extern const gfx_ctx_driver_t gfx_ctx_ps3;
2012-09-30 09:26:26 +00:00
extern const gfx_ctx_driver_t gfx_ctx_wgl;
2012-09-24 23:26:22 +00:00
extern const gfx_ctx_driver_t gfx_ctx_videocore;
extern const gfx_ctx_driver_t gfx_ctx_qnx;
extern const gfx_ctx_driver_t gfx_ctx_cgl;
extern const gfx_ctx_driver_t gfx_ctx_cocoagl;
extern const gfx_ctx_driver_t gfx_ctx_emscripten;
extern const gfx_ctx_driver_t gfx_ctx_opendingux_fbdev;
extern const gfx_ctx_driver_t gfx_ctx_khr_display;
2017-01-04 07:07:19 +00:00
extern const gfx_ctx_driver_t gfx_ctx_gdi;
extern const gfx_ctx_driver_t gfx_ctx_null;
2012-09-24 23:26:22 +00:00
2015-01-09 22:32:32 +00:00
/**
2016-05-08 18:32:46 +00:00
* video_context_driver_init_first:
2015-01-09 22:32:32 +00:00
* @data : Input data.
* @ident : Identifier of graphics context driver to find.
* @api : API of higher-level graphics API.
* @major : Major version number of higher-level graphics API.
* @minor : Minor version number of higher-level graphics API.
* @hw_render_ctx : Request a graphics context driver capable of
* hardware rendering?
*
* Finds first suitable graphics context driver and initializes.
*
* Returns: graphics context driver if found, otherwise NULL.
**/
2016-05-08 18:32:46 +00:00
const gfx_ctx_driver_t *video_context_driver_init_first(void *data, const char *ident,
2014-10-23 21:09:37 +00:00
enum gfx_ctx_api api, unsigned major, unsigned minor, bool hw_render_ctx);
2012-09-24 23:26:22 +00:00
2016-05-08 18:32:46 +00:00
bool video_context_driver_check_window(gfx_ctx_size_t *size_data);
bool video_context_driver_find_prev_driver(void);
bool video_context_driver_find_next_driver(void);
bool video_context_driver_init_image_buffer(const video_info_t *data);
bool video_context_driver_write_to_image_buffer(gfx_ctx_image_t *img);
bool video_context_driver_get_video_output_prev(void);
bool video_context_driver_get_video_output_next(void);
bool video_context_driver_bind_hw_render(bool *enable);
void video_context_driver_make_current(bool restore);
2016-05-08 18:32:46 +00:00
bool video_context_driver_set(const gfx_ctx_driver_t *data);
void video_context_driver_destroy(void);
#define video_context_driver_update_window_title(video_info) \
if (current_video_context && current_video_context->update_window_title) \
current_video_context->update_window_title(video_context_data, video_info)
2016-05-08 18:32:46 +00:00
2017-01-09 13:59:15 +00:00
#define video_context_driver_swap_buffers(video_info) \
if (current_video_context && current_video_context->swap_buffers) \
2017-01-09 13:59:15 +00:00
current_video_context->swap_buffers(video_context_data, video_info)
2016-05-08 18:32:46 +00:00
#define video_context_driver_focus() ((video_context_data && current_video_context->has_focus && current_video_context->has_focus(video_context_data)) ? true : false)
2016-05-08 18:32:46 +00:00
#define video_context_driver_set_resize(mode_info) \
if (current_video_context && current_video_context->set_resize) \
current_video_context->set_resize(video_context_data, mode_info.width, mode_info.height)
2016-05-08 18:32:46 +00:00
bool video_context_driver_get_video_output_size(gfx_ctx_size_t *size_data);
bool video_context_driver_swap_interval(unsigned *interval);
bool video_context_driver_get_proc_address(gfx_ctx_proc_address_t *proc);
bool video_context_driver_suppress_screensaver(bool *bool_data);
bool video_context_driver_get_ident(gfx_ctx_ident_t *ident);
bool video_context_driver_set_video_mode(gfx_ctx_mode_t *mode_info);
bool video_context_driver_get_video_size(gfx_ctx_mode_t *mode_info);
bool video_context_driver_get_context_data(void *data);
bool video_context_driver_show_mouse(bool *bool_data);
void video_context_driver_set_data(void *data);
bool video_context_driver_get_flags(gfx_ctx_flags_t *flags);
bool video_context_driver_set_flags(gfx_ctx_flags_t *flags);
bool video_context_driver_get_metrics(gfx_ctx_metrics_t *metrics);
bool video_context_driver_translate_aspect(gfx_ctx_aspect_t *aspect);
bool video_context_driver_input_driver(gfx_ctx_input_t *inp);
2017-01-19 01:50:56 +00:00
#define video_context_driver_has_windowed() ((video_context_data && current_video_context->has_windowed && current_video_context->has_windowed(video_context_data)) ? true : false)
2016-05-08 18:32:46 +00:00
void video_context_driver_free(void);
2016-02-13 07:21:35 +00:00
extern const gfx_ctx_driver_t *current_video_context;
extern void *video_context_data;
2016-06-03 03:43:49 +00:00
RETRO_END_DECLS
2014-01-22 15:38:42 +00:00
#endif