2024-03-20 07:41:14 +01:00
|
|
|
/*
|
|
|
|
* types.h
|
|
|
|
*
|
|
|
|
* This file is part of Emu48
|
|
|
|
*
|
|
|
|
* Copyright (C) 1995 Sebastien Carlier
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
// HST bits
|
|
|
|
#define XM 1
|
|
|
|
#define SB 2
|
|
|
|
#define SR 4
|
|
|
|
#define MP 8
|
|
|
|
|
|
|
|
#define SWORD SHORT // signed 16 Bit variable
|
|
|
|
#define QWORD ULONGLONG // unsigned 64 Bit variable
|
|
|
|
|
|
|
|
typedef struct
|
|
|
|
{
|
|
|
|
SWORD nPosX; // position of window
|
|
|
|
SWORD nPosY;
|
|
|
|
BYTE type; // calculator type
|
|
|
|
|
|
|
|
DWORD Port0Size; // real size of module in KB
|
|
|
|
DWORD Port1Size; // real size of module in KB
|
|
|
|
DWORD Port2Size; // real size of module in KB (HP49G only)
|
2024-03-20 07:46:28 +01:00
|
|
|
DWORD dwUnused0; // not used, was memory pointer Port0
|
|
|
|
DWORD dwUnused1; // not used, was memory pointer Port1
|
|
|
|
DWORD dwUnused2; // not used, was memory pointer Port2
|
2024-03-20 07:41:14 +01:00
|
|
|
|
|
|
|
DWORD pc;
|
|
|
|
DWORD d0;
|
|
|
|
DWORD d1;
|
|
|
|
DWORD rstkp;
|
|
|
|
DWORD rstk[8];
|
|
|
|
BYTE A[16];
|
|
|
|
BYTE B[16];
|
|
|
|
BYTE C[16];
|
|
|
|
BYTE D[16];
|
|
|
|
BYTE R0[16];
|
|
|
|
BYTE R1[16];
|
|
|
|
BYTE R2[16];
|
|
|
|
BYTE R3[16];
|
|
|
|
BYTE R4[16];
|
|
|
|
BYTE ST[4];
|
|
|
|
BYTE HST;
|
|
|
|
BYTE P;
|
|
|
|
WORD out;
|
|
|
|
WORD in;
|
|
|
|
BOOL SoftInt;
|
|
|
|
BOOL Shutdn;
|
|
|
|
BOOL mode_dec;
|
|
|
|
BOOL inte; // interrupt status flag (FALSE = int in service)
|
|
|
|
BOOL intk; // 1 ms keyboard scan flag (TRUE = enable)
|
|
|
|
BOOL intd; // keyboard interrupt pending (TRUE = int pending)
|
|
|
|
BOOL carry;
|
|
|
|
|
|
|
|
WORD crc;
|
|
|
|
WORD wPort2Crc; // fingerprint of port2
|
|
|
|
WORD wRomCrc; // fingerprint of ROM
|
|
|
|
#if defined _USRDLL // DLL version
|
|
|
|
QWORD cycles; // oscillator cycles
|
|
|
|
#else // EXE version
|
|
|
|
DWORD cycles; // oscillator cycles
|
|
|
|
DWORD cycles_reserved; // reserved for MSB of oscillator cycles
|
|
|
|
#endif
|
|
|
|
DWORD dwKdnCycles; // cpu cycles at start of 1ms key handler
|
|
|
|
|
|
|
|
UINT Bank_FF; // save state of HP48GX port2 or state of HP49G ROM FF
|
|
|
|
UINT FlashRomState; // WSM state of flash memory (unused)
|
|
|
|
BYTE cards_status;
|
|
|
|
BYTE IORam[64]; // I/O hardware register
|
|
|
|
UINT IOBase; // address of I/O modules page
|
|
|
|
BOOL IOCfig; // I/O module configuration flag
|
|
|
|
BYTE P0Base, BSBase, P1Base, P2Base; // address of modules first 2KB page
|
|
|
|
BYTE P0Size, BSSize, P1Size, P2Size; // mapped size of module in 2KB
|
|
|
|
BYTE P0End, BSEnd, P1End, P2End; // address of modules last 2KB page
|
|
|
|
BOOL P0Cfig, BSCfig, P1Cfig, P2Cfig; // module address configuration flag
|
|
|
|
BOOL P0Cfg2, BSCfg2, P1Cfg2, P2Cfg2; // module size configuration flag
|
|
|
|
|
|
|
|
BYTE t1;
|
|
|
|
DWORD t2;
|
|
|
|
|
|
|
|
BOOL bShutdnWake; // flag for wake up from SHUTDN mode
|
|
|
|
|
|
|
|
BYTE Keyboard_Row[9];
|
|
|
|
WORD IR15X;
|
|
|
|
UINT Keyboard_State; // not used
|
|
|
|
|
|
|
|
signed short loffset;
|
|
|
|
signed int width;
|
|
|
|
UINT boffset;
|
|
|
|
UINT lcounter;
|
|
|
|
UINT sync; // not used
|
|
|
|
BYTE contrast;
|
|
|
|
BOOL dispon; // not used
|
|
|
|
DWORD start1;
|
|
|
|
DWORD start12;
|
|
|
|
DWORD end1;
|
|
|
|
DWORD start2, end2;
|
|
|
|
|
|
|
|
// CdB for HP: add apples header
|
|
|
|
DWORD d0size; // no. of header display lines
|
|
|
|
BYTE d0memory[4096*2]; // memory for header display area
|
|
|
|
DWORD d0offset; // offset inside the header display for the content
|
|
|
|
DWORD d0address; // address in saturn addr area for d0memory (2 pages)
|
|
|
|
// BOOL d0Cfig; // modul configured
|
2024-03-20 07:46:27 +01:00
|
|
|
} CHIPSET;
|
|
|
|
|
|
|
|
// additional Saturnator registers and Apple hardware
|
|
|
|
typedef struct
|
|
|
|
{
|
|
|
|
BYTE byType[4]; // "SPL" Saturn PLus
|
|
|
|
|
|
|
|
QWORD fld[7]; // user defined field masks F1-F7
|
|
|
|
|
|
|
|
BOOL d0Cfig; // display memory modul configured
|
|
|
|
DWORD d0address; // address in saturn addr area for d0memory (2 pages)
|
|
|
|
DWORD d0size; // no. of header display lines
|
|
|
|
DWORD d0offset; // offset inside the display memory for the content
|
|
|
|
BYTE d0memory[4096*2]; // 4KB memory for header display area
|
|
|
|
} APPLE_CHIPSET;
|