2011-09-12 05:43:37 +00:00
|
|
|
/**
|
|
|
|
** Supermodel
|
|
|
|
** A Sega Model 3 Arcade Emulator.
|
2011-09-14 19:08:43 +00:00
|
|
|
** Copyright 2011 Bart Trzynadlowski, Nik Henson
|
2011-09-12 05:43:37 +00:00
|
|
|
**
|
|
|
|
** This file is part of Supermodel.
|
|
|
|
**
|
|
|
|
** Supermodel 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 Foundation, either version 3 of the License, or (at your option)
|
|
|
|
** any later version.
|
|
|
|
**
|
|
|
|
** Supermodel 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 Supermodel. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
**/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Model3.h
|
|
|
|
*
|
Some updates to Supermodel made at beginning of the year but only now got around to checking in (better late than never...):
- hooked up the remaining controls in Supermodel (except for Magical Truck Adventure which does not work at all yet). The new controls are:
* InputAnalogJoyTrigger2 and InputAnalogJoyEvent2 for the additional second trigger and event buttons that were missing from Star Wars Trilogy,
* InputRearBrake and InputMusicSelect for the rear brake and music selection buttons that were missing from Harley Davidson,
* InputAnalogGunXXX, InputAnalogTriggerXXX, InputAnalogGunXXX2 and InputAnalogTriggerXXX2 for the analogue guns of Ocean Hunter and LA Machineguns (NOTE: these controls must be calibrated in the games' service menus otherwise they will not work properly. Also, the alignment of the gun cursor does not line up very well with the mouse position at the moment, but at least the games are a bit more playable now, although still with numerous graphical glitches...)
* InputSkiXXX for the controls of Ski Champ, making the game playable now.
- hooked up existing InputViewChange control to Harley Davidson's view change button
- improved the handling of InputGearShiftUp/Down inputs so that they work better with the driving games. With Dirt Devils, ECA, Harley and LeMans this means they map directly to the game's own shift up/down controls, while with the 4-speed games such as Daytona 2, Scud Racer and Sega Rally 2, they simulate the user shifting up and down through the gears
- added defaults for the new controls to Supermodel.ini
- other small code tweaks:
* fix small bug with handling of pos/neg inputs mapping to a control with inverted range (0XFF to 0x00) - this was needed to get Ski Champ's X-axis to work properly
* removed Wait method from InputSystem and added to CThread as CThread::Sleep instead
* added FrameTimings struct to hold all frame timings in a single place
No networking code yet as just haven't had a chance to work on it since initial progress at the beginning of the year - am *hoping* might have some time to pick it up again over Christmas...
2013-11-30 19:39:59 +00:00
|
|
|
* Header file defining the CModel3 and CModel3Config classes.
|
2011-09-12 05:43:37 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef INCLUDED_MODEL3_H
|
|
|
|
#define INCLUDED_MODEL3_H
|
|
|
|
|
2016-04-02 21:50:40 +00:00
|
|
|
#include "Model3/Crypto.h"
|
2012-01-16 23:21:14 +00:00
|
|
|
|
Some updates to Supermodel made at beginning of the year but only now got around to checking in (better late than never...):
- hooked up the remaining controls in Supermodel (except for Magical Truck Adventure which does not work at all yet). The new controls are:
* InputAnalogJoyTrigger2 and InputAnalogJoyEvent2 for the additional second trigger and event buttons that were missing from Star Wars Trilogy,
* InputRearBrake and InputMusicSelect for the rear brake and music selection buttons that were missing from Harley Davidson,
* InputAnalogGunXXX, InputAnalogTriggerXXX, InputAnalogGunXXX2 and InputAnalogTriggerXXX2 for the analogue guns of Ocean Hunter and LA Machineguns (NOTE: these controls must be calibrated in the games' service menus otherwise they will not work properly. Also, the alignment of the gun cursor does not line up very well with the mouse position at the moment, but at least the games are a bit more playable now, although still with numerous graphical glitches...)
* InputSkiXXX for the controls of Ski Champ, making the game playable now.
- hooked up existing InputViewChange control to Harley Davidson's view change button
- improved the handling of InputGearShiftUp/Down inputs so that they work better with the driving games. With Dirt Devils, ECA, Harley and LeMans this means they map directly to the game's own shift up/down controls, while with the 4-speed games such as Daytona 2, Scud Racer and Sega Rally 2, they simulate the user shifting up and down through the gears
- added defaults for the new controls to Supermodel.ini
- other small code tweaks:
* fix small bug with handling of pos/neg inputs mapping to a control with inverted range (0XFF to 0x00) - this was needed to get Ski Champ's X-axis to work properly
* removed Wait method from InputSystem and added to CThread as CThread::Sleep instead
* added FrameTimings struct to hold all frame timings in a single place
No networking code yet as just haven't had a chance to work on it since initial progress at the beginning of the year - am *hoping* might have some time to pick it up again over Christmas...
2013-11-30 19:39:59 +00:00
|
|
|
/*
|
|
|
|
* FrameTimings
|
|
|
|
*
|
|
|
|
* Timings within a frame, for debugging purposes
|
|
|
|
*/
|
|
|
|
struct FrameTimings
|
|
|
|
{
|
2016-04-02 21:50:40 +00:00
|
|
|
UINT32 ppcTicks;
|
|
|
|
UINT32 syncSize;
|
|
|
|
UINT32 syncTicks;
|
|
|
|
UINT32 renderTicks;
|
|
|
|
UINT32 sndTicks;
|
|
|
|
UINT32 drvTicks;
|
|
|
|
UINT32 frameTicks;
|
Some updates to Supermodel made at beginning of the year but only now got around to checking in (better late than never...):
- hooked up the remaining controls in Supermodel (except for Magical Truck Adventure which does not work at all yet). The new controls are:
* InputAnalogJoyTrigger2 and InputAnalogJoyEvent2 for the additional second trigger and event buttons that were missing from Star Wars Trilogy,
* InputRearBrake and InputMusicSelect for the rear brake and music selection buttons that were missing from Harley Davidson,
* InputAnalogGunXXX, InputAnalogTriggerXXX, InputAnalogGunXXX2 and InputAnalogTriggerXXX2 for the analogue guns of Ocean Hunter and LA Machineguns (NOTE: these controls must be calibrated in the games' service menus otherwise they will not work properly. Also, the alignment of the gun cursor does not line up very well with the mouse position at the moment, but at least the games are a bit more playable now, although still with numerous graphical glitches...)
* InputSkiXXX for the controls of Ski Champ, making the game playable now.
- hooked up existing InputViewChange control to Harley Davidson's view change button
- improved the handling of InputGearShiftUp/Down inputs so that they work better with the driving games. With Dirt Devils, ECA, Harley and LeMans this means they map directly to the game's own shift up/down controls, while with the 4-speed games such as Daytona 2, Scud Racer and Sega Rally 2, they simulate the user shifting up and down through the gears
- added defaults for the new controls to Supermodel.ini
- other small code tweaks:
* fix small bug with handling of pos/neg inputs mapping to a control with inverted range (0XFF to 0x00) - this was needed to get Ski Champ's X-axis to work properly
* removed Wait method from InputSystem and added to CThread as CThread::Sleep instead
* added FrameTimings struct to hold all frame timings in a single place
No networking code yet as just haven't had a chance to work on it since initial progress at the beginning of the year - am *hoping* might have some time to pick it up again over Christmas...
2013-11-30 19:39:59 +00:00
|
|
|
};
|
|
|
|
|
2011-09-12 05:43:37 +00:00
|
|
|
/*
|
|
|
|
* CModel3Config:
|
|
|
|
*
|
|
|
|
* Settings used by CModel3.
|
|
|
|
*/
|
|
|
|
class CModel3Config
|
|
|
|
{
|
|
|
|
public:
|
2016-04-02 21:50:40 +00:00
|
|
|
bool multiThreaded; // Multi-threaded (enabled if true)
|
|
|
|
bool gpuMultiThreaded; // Multi-threaded rendering (enabled if true)
|
|
|
|
|
|
|
|
// PowerPC clock frequency in MHz (minimum: 1 MHz)
|
|
|
|
inline void SetPowerPCFrequency(unsigned f)
|
|
|
|
{
|
|
|
|
if ((f<1) || (f>1000))
|
|
|
|
{
|
|
|
|
ErrorLog("PowerPC frequency must be between 1 and 1000 MHz; setting to 50 MHz.");
|
|
|
|
f = 50;
|
|
|
|
}
|
|
|
|
ppcFrequency = f*1000000;
|
|
|
|
}
|
|
|
|
inline unsigned GetPowerPCFrequency(void)
|
|
|
|
{
|
|
|
|
return ppcFrequency/1000000;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Defaults
|
|
|
|
CModel3Config(void)
|
|
|
|
{
|
|
|
|
multiThreaded = true; // enable by default
|
|
|
|
gpuMultiThreaded = true; // enable by default
|
|
|
|
ppcFrequency = 50*1000000; // 50 MHz
|
|
|
|
}
|
|
|
|
|
2011-09-12 05:43:37 +00:00
|
|
|
private:
|
2016-04-02 21:50:40 +00:00
|
|
|
unsigned ppcFrequency; // in Hz
|
2011-09-12 05:43:37 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
* CModel3:
|
|
|
|
*
|
|
|
|
* A complete Model 3 system.
|
|
|
|
*
|
|
|
|
* Inherits CBus in order to pass the address space handlers to devices that
|
|
|
|
* may need them (CPU, DMA, etc.)
|
|
|
|
*
|
|
|
|
* NOTE: Currently NOT re-entrant due to a non-OOP PowerPC core. Do NOT create
|
|
|
|
* create more than one CModel3 object!
|
|
|
|
*/
|
|
|
|
class CModel3: public CBus, public CPCIDevice
|
|
|
|
{
|
|
|
|
public:
|
2016-04-02 21:50:40 +00:00
|
|
|
/*
|
|
|
|
* ReadPCIConfigSpace(device, reg, bits, offset):
|
|
|
|
*
|
|
|
|
* Handles unknown PCI devices. See CPCIDevice definition for more details.
|
|
|
|
*
|
|
|
|
* Parameters:
|
|
|
|
* device Device number.
|
|
|
|
* reg Register number.
|
|
|
|
* bits Bit width of access (8, 16, or 32 only).;
|
|
|
|
* offset Byte offset within register, aligned to the specified bit
|
|
|
|
* width, and offset from the 32-bit aligned base of the
|
|
|
|
* register number.
|
|
|
|
*
|
|
|
|
* Returns:
|
|
|
|
* Register data.
|
|
|
|
*/
|
|
|
|
UINT32 ReadPCIConfigSpace(unsigned device, unsigned reg, unsigned bits, unsigned width);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* WritePCIConfigSpace(device, reg, bits, offset, data):
|
|
|
|
*
|
|
|
|
* Handles unknown PCI devices. See CPCIDevice definition for more details.
|
|
|
|
*
|
|
|
|
* Parameters:
|
|
|
|
* device Device number.
|
|
|
|
* reg Register number.
|
|
|
|
* bits Bit width of access (8, 16, or 32 only).
|
|
|
|
* offset Byte offset within register, aligned to the specified bit
|
|
|
|
* width, and offset from the 32-bit aligned base of the
|
|
|
|
* register number.
|
|
|
|
* data Data.
|
|
|
|
*/
|
|
|
|
void WritePCIConfigSpace(unsigned device, unsigned reg, unsigned bits, unsigned width, UINT32 data);
|
2011-09-12 05:43:37 +00:00
|
|
|
|
2016-04-02 21:50:40 +00:00
|
|
|
/*
|
|
|
|
* Read8(addr):
|
|
|
|
* Read16(addr):
|
|
|
|
* Read32(addr):
|
|
|
|
* Read64(addr):
|
|
|
|
*
|
|
|
|
* Read a byte, 16-bit half word, 32-bit word, or 64-bit double word from
|
|
|
|
* the PowerPC address space. This implements the PowerPC address bus. Note
|
|
|
|
* that it is big endian, so when accessing from a little endian device,
|
|
|
|
* the byte order must be manually reversed.
|
|
|
|
*
|
|
|
|
* Parameters:
|
|
|
|
* addr Address to read.
|
|
|
|
*
|
|
|
|
* Returns:
|
|
|
|
* Data at the address.
|
|
|
|
*/
|
|
|
|
UINT8 Read8(UINT32 addr);
|
|
|
|
UINT16 Read16(UINT32 addr);
|
|
|
|
UINT32 Read32(UINT32 addr);
|
|
|
|
UINT64 Read64(UINT32 addr);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Write8(addr, data):
|
|
|
|
* Write16(addr, data):
|
|
|
|
* Write32(addr, data):
|
|
|
|
* Write64(addr, data):
|
|
|
|
*
|
|
|
|
* Write a byte, half word, word, or double word to the PowerPC address
|
|
|
|
* space. Note that everything is stored in big endian form, so when
|
|
|
|
* accessing with a little endian device, the byte order must be manually
|
|
|
|
* reversed.
|
|
|
|
*
|
|
|
|
* Parameters:
|
|
|
|
* addr Address to write.
|
|
|
|
* data Data to write.
|
|
|
|
*/
|
|
|
|
void Write8(UINT32 addr, UINT8 data);
|
|
|
|
void Write16(UINT32 addr, UINT16 data);
|
|
|
|
void Write32(UINT32 addr, UINT32 data);
|
|
|
|
void Write64(UINT32 addr, UINT64 data);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* SaveState(SaveState):
|
|
|
|
*
|
|
|
|
* Saves an image of the current state. Must never be called while emulator
|
|
|
|
* is running (inside RunFrame()).
|
|
|
|
*
|
|
|
|
* Parameters:
|
|
|
|
* SaveState Block file to save state information to.
|
|
|
|
*/
|
|
|
|
void SaveState(CBlockFile *SaveState);
|
2011-09-12 05:43:37 +00:00
|
|
|
|
2016-04-02 21:50:40 +00:00
|
|
|
/*
|
|
|
|
* LoadState(SaveState):
|
|
|
|
*
|
|
|
|
* Loads and resumes execution from a state image. Modifies data that may
|
|
|
|
* be used by multiple threads -- use with caution and ensure threads are
|
|
|
|
* not accessing data that will be touched, this can be done by calling
|
|
|
|
* PauseThreads beforehand. Must never be called while emulator is running
|
|
|
|
* (inside RunFrame()).
|
|
|
|
*
|
|
|
|
* Parameters:
|
|
|
|
* SaveState Block file to load state information from.
|
|
|
|
*/
|
|
|
|
void LoadState(CBlockFile *SaveState);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* SaveNVRAM(NVRAM):
|
|
|
|
*
|
|
|
|
* Saves an image of the current NVRAM state.
|
|
|
|
*
|
|
|
|
* Parameters:
|
|
|
|
* NVRAM Block file to save NVRAM to.
|
|
|
|
*/
|
|
|
|
void SaveNVRAM(CBlockFile *NVRAM);
|
2011-09-12 05:43:37 +00:00
|
|
|
|
2016-04-02 21:50:40 +00:00
|
|
|
/*
|
|
|
|
* LoadNVRAM(NVRAM):
|
|
|
|
*
|
|
|
|
* Loads an NVRAM image.
|
|
|
|
*
|
|
|
|
* Parameters:
|
|
|
|
* NVRAM Block file to load NVRAM state from.
|
|
|
|
*/
|
|
|
|
void LoadNVRAM(CBlockFile *NVRAM);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* ClearNVRAM(void):
|
|
|
|
*
|
|
|
|
* Clears all NVRAM (backup RAM and EEPROM).
|
|
|
|
*/
|
|
|
|
void ClearNVRAM(void);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* RunFrame(void):
|
|
|
|
*
|
|
|
|
* Runs one frame (assuming 60 Hz video refresh rate).
|
|
|
|
*/
|
|
|
|
void RunFrame(void);
|
2011-09-12 05:43:37 +00:00
|
|
|
|
2016-04-02 21:50:40 +00:00
|
|
|
/*
|
|
|
|
* Reset(void):
|
|
|
|
*
|
|
|
|
* Resets the system. Does not modify non-volatile memory.
|
|
|
|
*/
|
|
|
|
void Reset(void);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* GetGameInfo(void):
|
|
|
|
*
|
|
|
|
* Returns:
|
|
|
|
* A pointer to the presently loaded game's information structure (or
|
|
|
|
* NULL if no ROM set has yet been loaded).
|
|
|
|
*/
|
|
|
|
const struct GameInfo * GetGameInfo(void);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* LoadROMSet(GameList, zipFile):
|
|
|
|
*
|
|
|
|
* Loads a complete ROM set from the specified ZIP archive.
|
|
|
|
*
|
|
|
|
* NOTE: Command line settings will not have been applied here yet.
|
|
|
|
*
|
|
|
|
* Parameters:
|
|
|
|
* GameList List of all supported games and their ROMs.
|
|
|
|
* zipFile ZIP file to load from.
|
|
|
|
*
|
|
|
|
* Returns:
|
|
|
|
* OKAY if successful, FAIL otherwise. Prints errors.
|
|
|
|
*/
|
|
|
|
bool LoadROMSet(const struct GameInfo *GameList, const char *zipFile);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* AttachRenderers(Render2DPtr, Render3DPtr):
|
|
|
|
*
|
|
|
|
* Attaches the renderers to the appropriate device objects.
|
|
|
|
*
|
|
|
|
* Parameters:
|
|
|
|
* Render2DPtr Pointer to a tile renderer object.
|
|
|
|
* Render3DPtr Same as above but for a 3D renderer.
|
|
|
|
*/
|
|
|
|
void AttachRenderers(CRender2D *Render2DPtr, IRender3D *Render3DPtr);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* AttachInputs(InputsPtr):
|
|
|
|
*
|
|
|
|
* Attaches OSD-managed inputs.
|
|
|
|
*
|
|
|
|
* Parameters:
|
|
|
|
* InputsPtr Pointer to the object containing input states.
|
|
|
|
*/
|
|
|
|
void AttachInputs(CInputs *InputsPtr);
|
|
|
|
|
|
|
|
void AttachOutputs(COutputs *OutputsPtr);
|
2012-07-15 21:04:46 +00:00
|
|
|
|
2016-04-02 21:50:40 +00:00
|
|
|
/*
|
|
|
|
* Init(void):
|
|
|
|
*
|
|
|
|
* One-time initialization of the context. Must be called prior to all
|
|
|
|
* other members. Allocates memory and initializes device states.
|
|
|
|
*
|
|
|
|
* NOTE: Command line settings will not have been applied here yet.
|
|
|
|
*
|
|
|
|
* Returns:
|
|
|
|
* OKAY is successful, otherwise FAILED if a non-recoverable error
|
|
|
|
* occurred. Prints own error messages.
|
|
|
|
*/
|
|
|
|
bool Init(void);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* GetSoundBoard(void):
|
|
|
|
*
|
|
|
|
* Returns a reference to the sound board.
|
|
|
|
*
|
|
|
|
* Returns:
|
|
|
|
* Pointer to CSoundBoard object.
|
|
|
|
*/
|
|
|
|
CSoundBoard *GetSoundBoard(void);
|
2011-09-15 21:10:38 +00:00
|
|
|
|
2016-04-02 21:50:40 +00:00
|
|
|
/*
|
|
|
|
* GetDriveBoard(void):
|
|
|
|
*
|
|
|
|
* Returns a reference to the drive board.
|
2011-09-15 21:10:38 +00:00
|
|
|
|
2016-04-02 21:50:40 +00:00
|
|
|
* Returns:
|
|
|
|
* Pointer to CDriveBoard object.
|
|
|
|
*/
|
|
|
|
CDriveBoard *GetDriveBoard(void);
|
2011-09-15 21:10:38 +00:00
|
|
|
|
2016-04-02 21:50:40 +00:00
|
|
|
/*
|
|
|
|
* PauseThreads(void):
|
|
|
|
*
|
|
|
|
* Flags that any running threads should pause and waits for them to do so.
|
|
|
|
* Should be used before invoking any method that accesses the internal state, eg LoadState or SaveState.
|
|
|
|
*/
|
|
|
|
bool PauseThreads(void);
|
2011-09-15 21:10:38 +00:00
|
|
|
|
2016-04-02 21:50:40 +00:00
|
|
|
/*
|
|
|
|
* ResumeThreads(void):
|
|
|
|
*
|
|
|
|
* Flags that any paused threads should resume running.
|
|
|
|
*/
|
|
|
|
bool ResumeThreads(void);
|
2012-01-16 23:21:14 +00:00
|
|
|
|
2016-04-02 21:50:40 +00:00
|
|
|
/*
|
|
|
|
* DumpTimings(void):
|
|
|
|
*
|
|
|
|
* Prints all timings for the most recent frame to the console, for debugging purposes.
|
|
|
|
*/
|
|
|
|
void DumpTimings(void);
|
2011-09-15 21:10:38 +00:00
|
|
|
|
2016-04-02 21:50:40 +00:00
|
|
|
/*
|
|
|
|
* GetTimings(void):
|
|
|
|
*
|
|
|
|
* Returns timings for the most recent frame, for debugging purposes.
|
|
|
|
*/
|
|
|
|
FrameTimings GetTimings(void);
|
Some updates to Supermodel made at beginning of the year but only now got around to checking in (better late than never...):
- hooked up the remaining controls in Supermodel (except for Magical Truck Adventure which does not work at all yet). The new controls are:
* InputAnalogJoyTrigger2 and InputAnalogJoyEvent2 for the additional second trigger and event buttons that were missing from Star Wars Trilogy,
* InputRearBrake and InputMusicSelect for the rear brake and music selection buttons that were missing from Harley Davidson,
* InputAnalogGunXXX, InputAnalogTriggerXXX, InputAnalogGunXXX2 and InputAnalogTriggerXXX2 for the analogue guns of Ocean Hunter and LA Machineguns (NOTE: these controls must be calibrated in the games' service menus otherwise they will not work properly. Also, the alignment of the gun cursor does not line up very well with the mouse position at the moment, but at least the games are a bit more playable now, although still with numerous graphical glitches...)
* InputSkiXXX for the controls of Ski Champ, making the game playable now.
- hooked up existing InputViewChange control to Harley Davidson's view change button
- improved the handling of InputGearShiftUp/Down inputs so that they work better with the driving games. With Dirt Devils, ECA, Harley and LeMans this means they map directly to the game's own shift up/down controls, while with the 4-speed games such as Daytona 2, Scud Racer and Sega Rally 2, they simulate the user shifting up and down through the gears
- added defaults for the new controls to Supermodel.ini
- other small code tweaks:
* fix small bug with handling of pos/neg inputs mapping to a control with inverted range (0XFF to 0x00) - this was needed to get Ski Champ's X-axis to work properly
* removed Wait method from InputSystem and added to CThread as CThread::Sleep instead
* added FrameTimings struct to hold all frame timings in a single place
No networking code yet as just haven't had a chance to work on it since initial progress at the beginning of the year - am *hoping* might have some time to pick it up again over Christmas...
2013-11-30 19:39:59 +00:00
|
|
|
|
2016-04-02 21:50:40 +00:00
|
|
|
/*
|
|
|
|
* CModel3(void):
|
|
|
|
* ~CModel3(void):
|
|
|
|
*
|
|
|
|
* Constructor and destructor for Model 3 class. Constructor performs a
|
|
|
|
* bare-bones initialization of object; does not perform any memory
|
|
|
|
* allocation or any actions that can fail. The destructor will deallocate
|
|
|
|
* memory and free resources used by the object (and its child objects).
|
|
|
|
*/
|
|
|
|
CModel3(void);
|
|
|
|
~CModel3(void);
|
2011-09-12 05:43:37 +00:00
|
|
|
|
2016-04-02 21:50:40 +00:00
|
|
|
/*
|
|
|
|
* Private Property.
|
|
|
|
* Tresspassers will be shot! ;)
|
|
|
|
*/
|
2011-09-12 05:43:37 +00:00
|
|
|
private:
|
2016-04-02 21:50:40 +00:00
|
|
|
// Private member functions
|
|
|
|
UINT8 ReadInputs(unsigned reg);
|
|
|
|
void WriteInputs(unsigned reg, UINT8 data);
|
|
|
|
uint16_t ReadSecurityRAM(uint32_t addr);
|
|
|
|
UINT32 ReadSecurity(unsigned reg);
|
|
|
|
void WriteSecurity(unsigned reg, UINT32 data);
|
|
|
|
void SetCROMBank(unsigned idx);
|
|
|
|
UINT8 ReadSystemRegister(unsigned reg);
|
|
|
|
void WriteSystemRegister(unsigned reg, UINT8 data);
|
|
|
|
void Patch(void);
|
2011-09-12 05:43:37 +00:00
|
|
|
|
2016-04-02 21:50:40 +00:00
|
|
|
void RunMainBoardFrame(void); // Runs PPC main board for a frame
|
|
|
|
void SyncGPUs(void); // Sync's up GPUs in preparation for rendering - must be called when PPC is not running
|
|
|
|
void RenderFrame(void); // Renders current frame
|
|
|
|
bool RunSoundBoardFrame(void); // Runs sound board for a frame
|
|
|
|
void RunDriveBoardFrame(void); // Runs drive board for a frame
|
2012-01-16 23:21:14 +00:00
|
|
|
|
2016-04-02 21:50:40 +00:00
|
|
|
bool StartThreads(void); // Starts all threads
|
|
|
|
bool StopThreads(void); // Stops all threads
|
|
|
|
void DeleteThreadObjects(void); // Deletes all threads and synchronization objects
|
2011-09-12 05:43:37 +00:00
|
|
|
|
2016-04-02 21:50:40 +00:00
|
|
|
static int StartMainBoardThread(void *data); // Callback to start PPC main board thread
|
|
|
|
static int StartSoundBoardThread(void *data); // Callback to start sound board thread (unsync'd)
|
|
|
|
static int StartSoundBoardThreadSyncd(void *data); // Callback to start sound board thread (sync'd)
|
|
|
|
static int StartDriveBoardThread(void *data); // Callback to start drive board thread
|
2011-09-12 05:43:37 +00:00
|
|
|
|
2016-04-02 21:50:40 +00:00
|
|
|
static void AudioCallback(void *data); // Audio buffer callback
|
|
|
|
|
|
|
|
bool WakeSoundBoardThread(void); // Used by audio callback to wake sound board thread (when not sync'd with render thread)
|
|
|
|
int RunMainBoardThread(void); // Runs PPC main board thread (sync'd in step with render thread)
|
|
|
|
int RunSoundBoardThread(void); // Runs sound board thread (not sync'd in step with render thread, ie running at full speed)
|
|
|
|
int RunSoundBoardThreadSyncd(void); // Runs sound board thread (sync'd in step with render thread)
|
|
|
|
int RunDriveBoardThread(void); // Runs drive board thread (sync'd in step with render thread)
|
|
|
|
|
|
|
|
// Game and hardware information
|
|
|
|
const struct GameInfo *Game;
|
|
|
|
|
|
|
|
// Game inputs and outputs
|
|
|
|
CInputs *Inputs;
|
|
|
|
COutputs *Outputs;
|
|
|
|
|
|
|
|
// Input registers (game controls)
|
|
|
|
UINT8 inputBank;
|
|
|
|
UINT8 serialFIFO1, serialFIFO2;
|
|
|
|
UINT8 gunReg;
|
|
|
|
int adcChannel;
|
|
|
|
|
|
|
|
// MIDI port
|
|
|
|
UINT8 midiCtrlPort; // controls MIDI (SCSP) IRQ behavior
|
|
|
|
|
|
|
|
// Emulated core Model 3 memory regions
|
|
|
|
UINT8 *memoryPool; // single allocated region for all ROM and system RAM
|
|
|
|
UINT8 *ram; // 8 MB PowerPC RAM
|
|
|
|
UINT8 *crom; // 8+128 MB CROM (fixed CROM first, then 64MB of banked CROMs -- Daytona2 might need extra?)
|
|
|
|
UINT8 *vrom; // 64 MB VROM (video ROM, visible only to Real3D)
|
|
|
|
UINT8 *soundROM; // 512 KB sound ROM (68K program)
|
|
|
|
UINT8 *sampleROM; // 8 MB samples (68K)
|
|
|
|
UINT8 *dsbROM; // 128 KB DSB ROM (Z80 program)
|
|
|
|
UINT8 *mpegROM; // 8 MB DSB MPEG ROM
|
|
|
|
UINT8 *backupRAM; // 128 KB Backup RAM (battery backed)
|
|
|
|
UINT8 *securityRAM; // 128 KB Security Board RAM
|
|
|
|
UINT8 *driveROM; // 32 KB drive board ROM (Z80 program) (optional)
|
|
|
|
|
|
|
|
// Banked CROM
|
|
|
|
UINT8 *cromBank; // currently mapped in CROM bank
|
|
|
|
unsigned cromBankReg; // the CROM bank register
|
|
|
|
|
|
|
|
// Security device
|
|
|
|
bool m_securityFirstRead = true;
|
|
|
|
unsigned securityPtr; // pointer to current offset in security data
|
|
|
|
|
|
|
|
// PowerPC
|
|
|
|
PPC_FETCH_REGION PPCFetchRegions[3];
|
2012-07-15 21:04:46 +00:00
|
|
|
|
2016-04-02 21:50:40 +00:00
|
|
|
// Multiple threading
|
|
|
|
bool gpusReady; // True if GPUs are ready to render
|
|
|
|
bool startedThreads; // True if threads have been created and started
|
|
|
|
bool pauseThreads; // True if threads should pause
|
|
|
|
bool stopThreads; // True if threads should stop
|
|
|
|
bool syncSndBrdThread; // True if sound board thread should be sync'd in step with render thread
|
|
|
|
CThread *ppcBrdThread; // PPC main board thread
|
|
|
|
CThread *sndBrdThread; // Sound board thread
|
|
|
|
CThread *drvBrdThread; // Drive board thread
|
|
|
|
bool ppcBrdThreadRunning; // Flag to indicate PPC main board thread is currently processing
|
|
|
|
bool ppcBrdThreadDone; // Flag to indicate PPC main board thread has finished processing
|
|
|
|
bool sndBrdThreadRunning; // Flag to indicate sound board thread is currently processing
|
|
|
|
bool sndBrdThreadDone; // Flag to indicate sound board thread has finished processing
|
|
|
|
bool sndBrdWakeNotify; // Flag to indicate that sound board thread has been woken by audio callback (when not sync'd with render thread)
|
|
|
|
bool drvBrdThreadRunning; // Flag to indicate drive board thread is currently processing
|
|
|
|
bool drvBrdThreadDone; // Flag to indicate drive board thread has finished processing
|
2011-09-12 05:43:37 +00:00
|
|
|
|
2016-04-02 21:50:40 +00:00
|
|
|
// Thread synchronization objects
|
|
|
|
CSemaphore *ppcBrdThreadSync;
|
|
|
|
CSemaphore *sndBrdThreadSync;
|
|
|
|
CMutex *sndBrdNotifyLock;
|
|
|
|
CCondVar *sndBrdNotifySync;
|
|
|
|
CSemaphore *drvBrdThreadSync;
|
|
|
|
CMutex *notifyLock;
|
|
|
|
CCondVar *notifySync;
|
|
|
|
|
|
|
|
// Frame timings
|
|
|
|
FrameTimings timings;
|
|
|
|
|
|
|
|
// Other devices
|
|
|
|
CIRQ IRQ; // Model 3 IRQ controller
|
|
|
|
CMPC10x PCIBridge; // MPC10x PCI/bridge/memory controller
|
|
|
|
CPCIBus PCIBus; // Model 3's PCI bus
|
|
|
|
C53C810 SCSI; // NCR 53C810 SCSI controller
|
|
|
|
CRTC72421 RTC; // Epson RTC-72421 real-time clock
|
|
|
|
C93C46 EEPROM; // 93C46 EEPROM
|
|
|
|
CTileGen TileGen; // Sega 2D tile generator
|
|
|
|
CReal3D GPU; // Real3D graphics hardware
|
|
|
|
CSoundBoard SoundBoard; // Sound board
|
|
|
|
CDSB *DSB; // Digital Sound Board (type determined dynamically at load time)
|
|
|
|
CDriveBoard DriveBoard; // Drive board
|
|
|
|
CCrypto m_cryptoDevice; // Encryption device
|
2011-09-12 05:43:37 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2016-04-02 21:50:40 +00:00
|
|
|
#endif // INCLUDED_MODEL3_H
|