137 lines
3.6 KiB
C++
137 lines
3.6 KiB
C++
#ifndef _rom__hpp__included__
|
|
#define _rom__hpp__included__
|
|
|
|
#define ROM_SLOT_COUNT 27
|
|
|
|
#include <string>
|
|
#include <map>
|
|
#include <vector>
|
|
#include <stdexcept>
|
|
#include "core/misc.hpp"
|
|
#include "interface/romtype.hpp"
|
|
#include "library/fileimage.hpp"
|
|
|
|
/**
|
|
* ROM loaded into memory.
|
|
*/
|
|
struct loaded_rom
|
|
{
|
|
/**
|
|
* Create blank ROM
|
|
*/
|
|
loaded_rom() throw();
|
|
/**
|
|
* Take in ROM filename (or a bundle) and load it to memory.
|
|
*
|
|
* parameter file: The file to load
|
|
* parameter tmpprefer: The core name to prefer.
|
|
* throws std::bad_alloc: Not enough memory.
|
|
* throws std::runtime_error: Loading ROM file failed.
|
|
*/
|
|
loaded_rom(const std::string& file, const std::string& tmpprefer = "") throw(std::bad_alloc,
|
|
std::runtime_error);
|
|
/**
|
|
* Take a ROM and load it.
|
|
*/
|
|
loaded_rom(const std::string& file, const std::string& core, const std::string& type,
|
|
const std::string& region);
|
|
/**
|
|
* Load a multi-file ROM.
|
|
*/
|
|
loaded_rom(const std::string file[ROM_SLOT_COUNT], const std::string& core, const std::string& type,
|
|
const std::string& region);
|
|
/**
|
|
* Take in ROM filename and load it to memory with specified type.
|
|
*
|
|
* parameter file: The file to load
|
|
* parameter ctype: The core type to use.
|
|
* throws std::bad_alloc: Not enough memory.
|
|
* throws std::runtime_error: Loading ROM file failed.
|
|
*/
|
|
loaded_rom(const std::string& file, core_type& ctype) throw(std::bad_alloc, std::runtime_error);
|
|
/**
|
|
* ROM type
|
|
*/
|
|
core_type* rtype;
|
|
/**
|
|
* ROM region (this is the currently active region).
|
|
*/
|
|
core_region* region;
|
|
/**
|
|
* ROM original region (this is the region ROM is loaded as).
|
|
*/
|
|
core_region* orig_region;
|
|
/**
|
|
* Loaded main ROM
|
|
*/
|
|
loaded_image romimg[ROM_SLOT_COUNT];
|
|
/**
|
|
* Loaded main ROM XML
|
|
*/
|
|
loaded_image romxml[ROM_SLOT_COUNT];
|
|
/**
|
|
* MSU-1 base.
|
|
*/
|
|
std::string msu1_base;
|
|
/**
|
|
* Load filename.
|
|
*/
|
|
std::string load_filename;
|
|
/**
|
|
* Switches the active cartridge to this cartridge. The compatiblity between selected region and original region
|
|
* is checked. Region is updated after cartridge has been loaded.
|
|
*
|
|
* throws std::bad_alloc: Not enough memory
|
|
* throws std::runtime_error: Switching cartridges failed.
|
|
*/
|
|
void load(std::map<std::string, std::string>& settings, uint64_t rtc_sec, uint64_t rtc_subsec)
|
|
throw(std::bad_alloc, std::runtime_error);
|
|
/**
|
|
* Saves core state into buffer. WARNING: This takes emulated time.
|
|
*
|
|
* returns: The saved state.
|
|
* throws std::bad_alloc: Not enough memory.
|
|
*/
|
|
std::vector<char> save_core_state(bool nochecksum = false) throw(std::bad_alloc);
|
|
|
|
/**
|
|
* Loads core state from buffer.
|
|
*
|
|
* parameter buf: The buffer containing the state.
|
|
* throws std::runtime_error: Loading state failed.
|
|
*/
|
|
void load_core_state(const std::vector<char>& buf, bool nochecksum = false) throw(std::runtime_error);
|
|
};
|
|
|
|
/**
|
|
* Get major type and region of loaded ROM.
|
|
*
|
|
* returns: Tuple (ROM type, ROM region) of currently loaded ROM.
|
|
*/
|
|
std::pair<core_type*, core_region*> get_current_rom_info() throw();
|
|
|
|
/**
|
|
* Read SRAMs from command-line and and load the files.
|
|
*
|
|
* parameter cmdline: Command line
|
|
* returns: The loaded SRAM contents.
|
|
* throws std::bad_alloc: Out of memory.
|
|
* throws std::runtime_error: Failed to load.
|
|
*/
|
|
std::map<std::string, std::vector<char>> load_sram_commandline(const std::vector<std::string>& cmdline)
|
|
throw(std::bad_alloc, std::runtime_error);
|
|
|
|
/**
|
|
* Set the hasher callback.
|
|
*/
|
|
void set_hasher_callback(std::function<void(uint64_t, uint64_t)> cb);
|
|
|
|
//Map of preferred cores for each extension and type.
|
|
extern std::map<std::string, core_type*> preferred_core;
|
|
//Preferred overall core.
|
|
extern std::string preferred_core_default;
|
|
//Main hasher
|
|
extern sha256_hasher lsnes_image_hasher;
|
|
|
|
|
|
#endif
|