2012-04-21 23:13:50 +02:00
|
|
|
/* RetroArch - A frontend for libretro.
|
2014-01-01 01:50:59 +01:00
|
|
|
* Copyright (C) 2010-2014 - Hans-Kristian Arntzen
|
2017-03-22 03:09:18 +01:00
|
|
|
* Copyright (C) 2011-2017 - Daniel De Matteis
|
2010-12-30 13:54:49 +01:00
|
|
|
*
|
2012-04-21 23:13:50 +02:00
|
|
|
* RetroArch is free software: you can redistribute it and/or modify it under the terms
|
2010-12-30 13:54:49 +01:00
|
|
|
* 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.
|
|
|
|
*
|
2012-04-21 23:13:50 +02:00
|
|
|
* RetroArch is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
|
2010-12-30 13:54:49 +01:00
|
|
|
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
|
|
|
|
* PURPOSE. See the GNU General Public License for more details.
|
|
|
|
*
|
2012-04-21 23:31:57 +02:00
|
|
|
* You should have received a copy of the GNU General Public License along with RetroArch.
|
2010-12-30 13:54:49 +01:00
|
|
|
* If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __DYNAMIC_H
|
|
|
|
#define __DYNAMIC_H
|
|
|
|
|
2014-10-21 05:05:52 +02:00
|
|
|
#include <boolean.h>
|
2016-06-03 02:39:35 +02:00
|
|
|
#include <retro_common_api.h>
|
2016-05-10 19:03:53 +02:00
|
|
|
#include <libretro.h>
|
2016-02-04 20:56:22 +01:00
|
|
|
|
2016-03-22 02:56:06 +01:00
|
|
|
#include "core_type.h"
|
2010-12-30 13:54:49 +01:00
|
|
|
|
2016-06-03 02:39:35 +02:00
|
|
|
RETRO_BEGIN_DECLS
|
2013-02-09 10:36:39 +01:00
|
|
|
|
2015-01-09 21:30:07 +01:00
|
|
|
/**
|
|
|
|
* libretro_get_system_info:
|
|
|
|
* @path : Path to libretro library.
|
|
|
|
* @info : System info information.
|
|
|
|
* @load_no_content : If true, core should be able to auto-start
|
|
|
|
* without any content loaded.
|
|
|
|
*
|
|
|
|
* Gets system info from an arbitrary lib.
|
|
|
|
* The struct returned must be freed as strings are allocated dynamically.
|
|
|
|
*
|
|
|
|
* Returns: true (1) if successful, otherwise false (0).
|
|
|
|
**/
|
2014-09-07 05:47:18 +02:00
|
|
|
bool libretro_get_system_info(const char *path,
|
2017-05-30 01:44:49 +02:00
|
|
|
struct retro_system_info *info, bool *load_no_content);
|
2014-09-02 05:57:53 +02:00
|
|
|
|
2015-01-09 21:30:07 +01:00
|
|
|
/**
|
|
|
|
* libretro_free_system_info:
|
|
|
|
* @info : Pointer to system info information.
|
|
|
|
*
|
|
|
|
* Frees system information.
|
|
|
|
**/
|
2017-05-30 01:44:49 +02:00
|
|
|
void libretro_free_system_info(struct retro_system_info *info);
|
2013-03-17 20:08:24 +01:00
|
|
|
|
2014-09-02 05:57:53 +02:00
|
|
|
const struct retro_subsystem_info *libretro_find_subsystem_info(
|
|
|
|
const struct retro_subsystem_info *info,
|
|
|
|
unsigned num_info, const char *ident);
|
|
|
|
|
2015-01-15 02:48:40 +01:00
|
|
|
/**
|
|
|
|
* libretro_find_controller_description:
|
|
|
|
* @info : Pointer to controller info handle.
|
|
|
|
* @id : Identifier of controller to search
|
|
|
|
* for.
|
|
|
|
*
|
|
|
|
* Search for a controller of type @id in @info.
|
|
|
|
*
|
|
|
|
* Returns: controller description of found controller on success,
|
|
|
|
* otherwise NULL.
|
|
|
|
**/
|
2014-09-02 05:57:53 +02:00
|
|
|
const struct retro_controller_description *
|
|
|
|
libretro_find_controller_description(
|
|
|
|
const struct retro_controller_info *info, unsigned id);
|
2014-04-04 14:58:42 +02:00
|
|
|
|
2015-01-15 02:48:40 +01:00
|
|
|
/**
|
|
|
|
* rarch_environment_cb:
|
|
|
|
* @cmd : Identifier of command.
|
|
|
|
* @data : Pointer to data.
|
|
|
|
*
|
|
|
|
* Environment callback function implementation.
|
|
|
|
*
|
|
|
|
* Returns: true (1) if environment callback command could
|
|
|
|
* be performed, otherwise false (0).
|
|
|
|
**/
|
|
|
|
bool rarch_environment_cb(unsigned cmd, void *data);
|
|
|
|
|
2015-11-20 17:22:19 +01:00
|
|
|
struct retro_core_t
|
|
|
|
{
|
2015-10-06 14:34:09 -03:00
|
|
|
void (*retro_init)(void);
|
|
|
|
void (*retro_deinit)(void);
|
|
|
|
unsigned (*retro_api_version)(void);
|
|
|
|
void (*retro_get_system_info)(struct retro_system_info*);
|
|
|
|
void (*retro_get_system_av_info)(struct retro_system_av_info*);
|
|
|
|
void (*retro_set_environment)(retro_environment_t);
|
|
|
|
void (*retro_set_video_refresh)(retro_video_refresh_t);
|
|
|
|
void (*retro_set_audio_sample)(retro_audio_sample_t);
|
|
|
|
void (*retro_set_audio_sample_batch)(retro_audio_sample_batch_t);
|
|
|
|
void (*retro_set_input_poll)(retro_input_poll_t);
|
|
|
|
void (*retro_set_input_state)(retro_input_state_t);
|
|
|
|
void (*retro_set_controller_port_device)(unsigned, unsigned);
|
|
|
|
void (*retro_reset)(void);
|
|
|
|
void (*retro_run)(void);
|
|
|
|
size_t (*retro_serialize_size)(void);
|
|
|
|
bool (*retro_serialize)(void*, size_t);
|
|
|
|
bool (*retro_unserialize)(const void*, size_t);
|
|
|
|
void (*retro_cheat_reset)(void);
|
|
|
|
void (*retro_cheat_set)(unsigned, bool, const char*);
|
|
|
|
bool (*retro_load_game)(const struct retro_game_info*);
|
2016-02-04 20:58:53 +01:00
|
|
|
bool (*retro_load_game_special)(unsigned,
|
|
|
|
const struct retro_game_info*, size_t);
|
2015-10-06 14:34:09 -03:00
|
|
|
void (*retro_unload_game)(void);
|
|
|
|
unsigned (*retro_get_region)(void);
|
|
|
|
void *(*retro_get_memory_data)(unsigned);
|
|
|
|
size_t (*retro_get_memory_size)(unsigned);
|
2017-05-21 09:07:19 +02:00
|
|
|
|
|
|
|
unsigned poll_type;
|
|
|
|
bool inited;
|
|
|
|
bool symbols_inited;
|
|
|
|
bool game_loaded;
|
|
|
|
bool input_polled;
|
|
|
|
bool has_set_input_descriptors;
|
|
|
|
uint64_t serialization_quirks_v;
|
2015-10-06 14:34:09 -03:00
|
|
|
};
|
2014-09-02 05:57:53 +02:00
|
|
|
|
2015-05-08 09:44:41 +02:00
|
|
|
/**
|
|
|
|
* init_libretro_sym:
|
2015-06-20 23:42:30 +02:00
|
|
|
* @type : Type of core to be loaded.
|
|
|
|
* If CORE_TYPE_DUMMY, will
|
|
|
|
* load dummy symbols.
|
2015-05-08 09:44:41 +02:00
|
|
|
*
|
|
|
|
* Initializes libretro symbols and
|
2016-10-11 20:28:36 -04:00
|
|
|
* setups environment callback functions. Returns true on success,
|
|
|
|
* or false if symbols could not be loaded.
|
2015-05-08 09:44:41 +02:00
|
|
|
**/
|
2016-10-11 20:28:36 -04:00
|
|
|
bool init_libretro_sym(enum rarch_core_type type,
|
2016-02-04 20:58:53 +01:00
|
|
|
struct retro_core_t *core);
|
2015-05-08 09:44:41 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* uninit_libretro_sym:
|
|
|
|
*
|
|
|
|
* Frees libretro core.
|
|
|
|
*
|
|
|
|
* Frees all core options,
|
|
|
|
* associated state, and
|
|
|
|
* unbind all libretro callback symbols.
|
|
|
|
**/
|
2016-01-28 03:36:14 +01:00
|
|
|
void uninit_libretro_sym(struct retro_core_t *core);
|
2015-05-08 09:44:41 +02:00
|
|
|
|
2016-06-03 02:39:35 +02:00
|
|
|
RETRO_END_DECLS
|
2013-02-09 10:36:39 +01:00
|
|
|
|
2010-12-30 13:54:49 +01:00
|
|
|
#endif
|
|
|
|
|