mirror of
https://github.com/AppleWin/AppleWin.git
synced 2024-12-23 16:30:23 +00:00
137 lines
2.8 KiB
C
137 lines
2.8 KiB
C
|
#pragma once
|
||
|
|
||
|
// Structs used by save-state file
|
||
|
|
||
|
// *** DON'T CHANGE ANY STRUCT WITHOUT CONSIDERING BACKWARDS COMPATIBILITY WITH .AWS FORMAT ***
|
||
|
|
||
|
/////////////////////////////////////////////////////////////////////////////////
|
||
|
|
||
|
#define MAKE_VERSION(a,b,c,d) ((a<<24) | (b<<16) | (c<<8) | (d))
|
||
|
|
||
|
#define AW_SS_TAG 'SSWA' // 'AWSS' = AppleWin SnapShot
|
||
|
|
||
|
struct SS_FILE_HDR
|
||
|
{
|
||
|
DWORD dwTag; // "AWSS"
|
||
|
DWORD dwVersion;
|
||
|
DWORD dwChecksum;
|
||
|
};
|
||
|
|
||
|
struct SS_UNIT_HDR
|
||
|
{
|
||
|
union
|
||
|
{
|
||
|
struct
|
||
|
{
|
||
|
DWORD dwLength; // Byte length of this unit struct
|
||
|
DWORD dwVersion;
|
||
|
} v1;
|
||
|
struct
|
||
|
{
|
||
|
DWORD Length; // Byte length of this unit struct
|
||
|
WORD Type; // SS_UNIT_TYPE
|
||
|
WORD Version; // Incrementing value from 1
|
||
|
} v2;
|
||
|
} hdr;
|
||
|
};
|
||
|
|
||
|
enum SS_UNIT_TYPE
|
||
|
{
|
||
|
UT_Reserved = 0,
|
||
|
UT_Apple2,
|
||
|
UT_Card,
|
||
|
UT_Config,
|
||
|
};
|
||
|
|
||
|
const UINT nMemMainSize = 64*1024;
|
||
|
const UINT nMemAuxSize = 64*1024;
|
||
|
|
||
|
const UINT kSLOT_LANG = 0;
|
||
|
const UINT kSLOT_AUX = 8;
|
||
|
|
||
|
struct SS_CARD_HDR
|
||
|
{
|
||
|
SS_UNIT_HDR UnitHdr;
|
||
|
DWORD Type; // SS_CARDTYPE
|
||
|
DWORD Slot; // [1..7], 0=Language card, 8=Aux
|
||
|
};
|
||
|
|
||
|
enum SS_CARDTYPE
|
||
|
{
|
||
|
CT_Empty = 0,
|
||
|
CT_Disk2, // Apple Disk][
|
||
|
CT_SSC, // Apple Super Serial Card
|
||
|
CT_MockingboardC, // Soundcard
|
||
|
CT_GenericPrinter,
|
||
|
CT_GenericHDD, // Hard disk
|
||
|
CT_GenericClock,
|
||
|
CT_MouseInterface,
|
||
|
CT_Z80,
|
||
|
CT_Phasor, // Soundcard
|
||
|
CT_Echo, // Soundcard
|
||
|
CT_SAM, // Soundcard: Software Automated Mouth
|
||
|
CT_80Col, // 80 column card (no memory)
|
||
|
CT_Extended80Col, // Extended 80-col card (64K)
|
||
|
CT_RamWorksIII, // RamWorksIII (up to 8MB)
|
||
|
CT_Uthernet,
|
||
|
};
|
||
|
|
||
|
/////////////////////////////////////////////////////////////////////////////////
|
||
|
|
||
|
struct SS_CARD_EMPTY
|
||
|
{
|
||
|
SS_CARD_HDR Hdr;
|
||
|
};
|
||
|
|
||
|
/////////////////////////////////////////////////////////////////////////////////
|
||
|
|
||
|
struct IWORD
|
||
|
{
|
||
|
union
|
||
|
{
|
||
|
struct
|
||
|
{
|
||
|
BYTE l;
|
||
|
BYTE h;
|
||
|
};
|
||
|
USHORT w;
|
||
|
};
|
||
|
};
|
||
|
|
||
|
struct SY6522
|
||
|
{
|
||
|
BYTE ORB; // $00 - Port B
|
||
|
BYTE ORA; // $01 - Port A (with handshaking)
|
||
|
BYTE DDRB; // $02 - Data Direction Register B
|
||
|
BYTE DDRA; // $03 - Data Direction Register A
|
||
|
//
|
||
|
// $04 - Read counter (L) / Write latch (L)
|
||
|
// $05 - Read / Write & initiate count (H)
|
||
|
// $06 - Read / Write & latch (L)
|
||
|
// $07 - Read / Write & latch (H)
|
||
|
// $08 - Read counter (L) / Write latch (L)
|
||
|
// $09 - Read counter (H) / Write latch (H)
|
||
|
IWORD TIMER1_COUNTER;
|
||
|
IWORD TIMER1_LATCH;
|
||
|
IWORD TIMER2_COUNTER;
|
||
|
IWORD TIMER2_LATCH;
|
||
|
//
|
||
|
BYTE SERIAL_SHIFT; // $0A
|
||
|
BYTE ACR; // $0B - Auxiliary Control Register
|
||
|
BYTE PCR; // $0C - Peripheral Control Register
|
||
|
BYTE IFR; // $0D - Interrupt Flag Register
|
||
|
BYTE IER; // $0E - Interrupt Enable Register
|
||
|
BYTE ORA_NO_HS; // $0F - Port A (without handshaking)
|
||
|
};
|
||
|
|
||
|
struct SSI263A
|
||
|
{
|
||
|
BYTE DurationPhoneme;
|
||
|
BYTE Inflection; // I10..I3
|
||
|
BYTE RateInflection;
|
||
|
BYTE CtrlArtAmp;
|
||
|
BYTE FilterFreq;
|
||
|
//
|
||
|
BYTE CurrentMode; // b7:6=Mode; b0=D7 pin (for IRQ)
|
||
|
};
|