2016-08-17 12:31:22 +00:00
|
|
|
namespace MasterSystem {
|
|
|
|
|
|
|
|
struct ID {
|
|
|
|
enum : uint {
|
|
|
|
System,
|
|
|
|
MasterSystem,
|
|
|
|
GameGear,
|
|
|
|
};
|
|
|
|
|
|
|
|
struct Port { enum : uint {
|
|
|
|
Controller1,
|
|
|
|
Controller2,
|
|
|
|
};};
|
|
|
|
|
|
|
|
struct Device { enum : uint {
|
Update to v101r28 release.
byuu says:
Changelog:
- SMS: emulated the remaining 240 instructions in the (0xfd, 0xdd)
0xcb (displacement) (opcode) set
- 1/8th of these were "legal" instructions, and apparently games
use them a lot
- SMS: emulated the standard gamepad controllers
- reset button not emulated yet
The reset button is tricky. In every other case, reset is a hardware
thing that instantly reboots the entire machine.
But on the SMS, it's more like a gamepad button that's attached to the
front of the device. When you press it, it fires off a reset vector
interrupt and the gamepad polling routine lets you query the status of
the button.
Just having a reset option in the "Master System" hardware menu is not
sufficient to fully emulate the behavior. Even more annoying is that the
Game Gear doesn't have such a button, yet the core information structs
aren't flexible enough for the Master System to have it, and the Game
Gear to not have it, in the main menu. But that doesn't matter anyway,
since it won't work having it in the menu for the Master System.
So as a result, I'm going to have to have a new "input device" called
"Hardware" that has the "Reset" button listed under there. And for the
sake of consistency, I'm not sure if we should treat the other systems
the same way or not :/
2017-01-08 20:55:02 +00:00
|
|
|
None,
|
2016-08-17 12:31:22 +00:00
|
|
|
Gamepad,
|
|
|
|
};};
|
|
|
|
};
|
|
|
|
|
|
|
|
struct Interface : Emulator::Interface {
|
|
|
|
using Emulator::Interface::load;
|
|
|
|
|
|
|
|
Interface();
|
|
|
|
|
|
|
|
auto manifest() -> string override;
|
|
|
|
auto title() -> string override;
|
|
|
|
|
|
|
|
auto videoSize() -> VideoSize override;
|
|
|
|
auto videoSize(uint width, uint height, bool arc) -> VideoSize override;
|
|
|
|
auto videoFrequency() -> double override;
|
|
|
|
auto videoColors() -> uint32 override;
|
|
|
|
auto videoColor(uint32 color) -> uint64 override;
|
|
|
|
|
|
|
|
auto audioFrequency() -> double override;
|
|
|
|
|
|
|
|
auto loaded() -> bool override;
|
|
|
|
auto load(uint id) -> bool override;
|
|
|
|
auto save() -> void override;
|
|
|
|
auto unload() -> void override;
|
|
|
|
|
Update to v101r28 release.
byuu says:
Changelog:
- SMS: emulated the remaining 240 instructions in the (0xfd, 0xdd)
0xcb (displacement) (opcode) set
- 1/8th of these were "legal" instructions, and apparently games
use them a lot
- SMS: emulated the standard gamepad controllers
- reset button not emulated yet
The reset button is tricky. In every other case, reset is a hardware
thing that instantly reboots the entire machine.
But on the SMS, it's more like a gamepad button that's attached to the
front of the device. When you press it, it fires off a reset vector
interrupt and the gamepad polling routine lets you query the status of
the button.
Just having a reset option in the "Master System" hardware menu is not
sufficient to fully emulate the behavior. Even more annoying is that the
Game Gear doesn't have such a button, yet the core information structs
aren't flexible enough for the Master System to have it, and the Game
Gear to not have it, in the main menu. But that doesn't matter anyway,
since it won't work having it in the menu for the Master System.
So as a result, I'm going to have to have a new "input device" called
"Hardware" that has the "Reset" button listed under there. And for the
sake of consistency, I'm not sure if we should treat the other systems
the same way or not :/
2017-01-08 20:55:02 +00:00
|
|
|
auto connect(uint port, uint device) -> void override;
|
2016-08-17 12:31:22 +00:00
|
|
|
auto power() -> void override;
|
|
|
|
auto reset() -> void override;
|
|
|
|
auto run() -> void override;
|
|
|
|
|
|
|
|
auto serialize() -> serializer override;
|
|
|
|
auto unserialize(serializer&) -> bool override;
|
|
|
|
|
|
|
|
auto cap(const string& name) -> bool override;
|
|
|
|
auto get(const string& name) -> any override;
|
|
|
|
auto set(const string& name, const any& value) -> bool override;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct Settings {
|
Update to v101r28 release.
byuu says:
Changelog:
- SMS: emulated the remaining 240 instructions in the (0xfd, 0xdd)
0xcb (displacement) (opcode) set
- 1/8th of these were "legal" instructions, and apparently games
use them a lot
- SMS: emulated the standard gamepad controllers
- reset button not emulated yet
The reset button is tricky. In every other case, reset is a hardware
thing that instantly reboots the entire machine.
But on the SMS, it's more like a gamepad button that's attached to the
front of the device. When you press it, it fires off a reset vector
interrupt and the gamepad polling routine lets you query the status of
the button.
Just having a reset option in the "Master System" hardware menu is not
sufficient to fully emulate the behavior. Even more annoying is that the
Game Gear doesn't have such a button, yet the core information structs
aren't flexible enough for the Master System to have it, and the Game
Gear to not have it, in the main menu. But that doesn't matter anyway,
since it won't work having it in the menu for the Master System.
So as a result, I'm going to have to have a new "input device" called
"Hardware" that has the "Reset" button listed under there. And for the
sake of consistency, I'm not sure if we should treat the other systems
the same way or not :/
2017-01-08 20:55:02 +00:00
|
|
|
uint controllerPort1 = 0;
|
|
|
|
uint controllerPort2 = 0;
|
2016-08-17 12:31:22 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
extern Interface* interface;
|
|
|
|
extern Settings settings;
|
|
|
|
|
|
|
|
}
|