2015-02-13 22:40:53 +00:00
|
|
|
#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;
|
|
|
|
|
|
|
|
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
|
2018-10-26 18:23:30 +00:00
|
|
|
CT_80Col, // 80 column card (1K)
|
2015-04-11 21:24:54 +00:00
|
|
|
CT_Extended80Col, // Extended 80-col card (64K)
|
|
|
|
CT_RamWorksIII, // RamWorksIII (up to 8MB)
|
2015-08-21 20:45:21 +00:00
|
|
|
CT_Uthernet,
|
2018-10-26 18:23:30 +00:00
|
|
|
CT_LanguageCard, // Apple][ or ][+ in slot-0
|
|
|
|
CT_LanguageCardIIe, // Apple//e LC instance (not a card)
|
|
|
|
CT_Saturn128K, // Saturn 128K (but may be populated with less RAM, in multiples of 16K)
|
2015-02-13 22:40:53 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/////////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
struct SS_CARD_EMPTY
|
|
|
|
{
|
|
|
|
SS_CARD_HDR Hdr;
|
|
|
|
};
|
2015-04-11 21:24:54 +00:00
|
|
|
|
|
|
|
/////////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
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;
|
2019-06-15 16:41:53 +00:00
|
|
|
int timer1IrqDelay;
|
|
|
|
int timer2IrqDelay;
|
2015-04-11 21:24:54 +00:00
|
|
|
//
|
|
|
|
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
|
|
|
|
{
|
2015-12-05 16:50:27 +00:00
|
|
|
BYTE DurationPhoneme;
|
2015-04-11 21:24:54 +00:00
|
|
|
BYTE Inflection; // I10..I3
|
|
|
|
BYTE RateInflection;
|
|
|
|
BYTE CtrlArtAmp;
|
|
|
|
BYTE FilterFreq;
|
|
|
|
//
|
|
|
|
BYTE CurrentMode; // b7:6=Mode; b0=D7 pin (for IRQ)
|
|
|
|
};
|