--- np2/pccore.h 2003/11/15 07:10:02 1.7 +++ np2/pccore.h 2004/02/21 04:48:35 1.24 @@ -1,5 +1,6 @@ #include "nevent.h" +#include "statsave.h" enum { PCBASECLOCK25 = 2457600, @@ -7,35 +8,48 @@ enum { }; enum { - PCMODEL_VM = 0, - PCMODEL_VX = 1 + CPUMODE_8MHZ = 0x20, + + PCMODEL_VF = 0, + PCMODEL_VM = 1, + PCMODEL_VX = 2, + PCMODELMASK = 0x3f, + PCMODEL_PC9821 = 0x40, + PCMODEL_EPSON = 0x80, + + PCHDD_SASI = 0x01, + PCHDD_SCSI = 0x02, + PCHDD_IDE = 0x04, + + PCSOUND_NONE = 0x00, + + PCCBUS_PC9861K = 0x0001, + PCCBUS_MPU98 = 0x0002 }; -#define CPUMODE_8MHz 0x20 typedef struct { // エミュレート中によく参照される奴 - BYTE uPD72020; - BYTE DISPSYNC; - BYTE RASTER; - BYTE realpal; - BYTE LCD_MODE; - BYTE skipline; + UINT8 uPD72020; + UINT8 DISPSYNC; + UINT8 RASTER; + UINT8 realpal; + UINT8 LCD_MODE; + UINT8 skipline; UINT16 skiplight; - BYTE KEY_MODE; - BYTE XSHIFT; - BYTE BTN_RAPID; - BYTE BTN_MODE; + UINT8 KEY_MODE; + UINT8 XSHIFT; + UINT8 BTN_RAPID; + UINT8 BTN_MODE; BYTE dipsw[3]; - BYTE MOUSERAPID; + UINT8 MOUSERAPID; - BYTE calendar; - BYTE usefd144; + UINT8 calendar; + UINT8 usefd144; BYTE wait[6]; - // リセット時とかあんまり参照されない奴 char model[8]; UINT baseclock; @@ -43,63 +57,71 @@ typedef struct { BYTE memsw[8]; - BYTE ITF_WORK; - BYTE EXTMEM; - BYTE grcg; - BYTE color16; + UINT8 ITF_WORK; + UINT8 EXTMEM; + UINT8 grcg; + UINT8 color16; UINT32 BG_COLOR; UINT32 FG_COLOR; UINT16 samplingrate; UINT16 delayms; - BYTE SOUND_SW; - BYTE snd_x; + UINT8 SOUND_SW; + UINT8 snd_x; BYTE snd14opt[3]; - BYTE snd26opt; - BYTE snd86opt; - BYTE spbopt; - BYTE spb_vrc; // ver0.30 - BYTE spb_vrl; // ver0.30 - BYTE spb_x; // ver0.30 + UINT8 snd26opt; + UINT8 snd86opt; + UINT8 spbopt; + UINT8 spb_vrc; // ver0.30 + UINT8 spb_vrl; // ver0.30 + UINT8 spb_x; // ver0.30 - BYTE BEEP_VOL; + UINT8 BEEP_VOL; BYTE vol14[6]; - BYTE vol_fm; - BYTE vol_ssg; - BYTE vol_adpcm; - BYTE vol_pcm; - BYTE vol_rhythm; + UINT8 vol_fm; + UINT8 vol_ssg; + UINT8 vol_adpcm; + UINT8 vol_pcm; + UINT8 vol_rhythm; - BYTE mpuenable; - BYTE mpuopt; + UINT8 mpuenable; + UINT8 mpuopt; - BYTE pc9861enable; + UINT8 pc9861enable; BYTE pc9861sw[3]; BYTE pc9861jmp[6]; - BYTE MOTOR; - BYTE MOTORVOL; - BYTE PROTECTMEM; - - char hddfile[2][MAX_PATH]; // ver0.30 + UINT8 fddequip; + UINT8 MOTOR; + UINT8 MOTORVOL; + UINT8 PROTECTMEM; + UINT8 hdrvacc; + + char sasihdd[2][MAX_PATH]; // ver0.74 +#if defined(SUPPORT_SCSI) + char scsihdd[4][MAX_PATH]; // ver0.74 +#endif char fontfile[MAX_PATH]; + char biospath[MAX_PATH]; + char hdrvroot[MAX_PATH]; } NP2CFG; typedef struct { UINT32 baseclock; UINT multiple; + + UINT8 cpumode; + UINT8 model; + UINT8 hddif; + UINT8 extmem; + BYTE dipsw[3]; // リセット時のDIPSW + UINT8 padding; + + UINT32 sound; + UINT32 device; + UINT32 realclock; - UINT32 dispclock; - UINT32 vsyncclock; - UINT32 mouseclock; - UINT32 keyboardclock; - UINT32 midiclock; - UINT32 frame1000; - UINT32 raster; - UINT32 hsync; - BYTE cpumode; - BYTE model; } PCCORE; @@ -110,13 +132,14 @@ extern "C" { extern const char np2version[]; extern NP2CFG np2cfg; -extern PCCORE pc; +extern PCCORE pccore; extern BYTE screenupdate; extern int soundrenewal; extern BOOL drawframe; extern UINT drawcount; +extern BOOL hardwarereset; - +void getbiospath(char *path, const char *fname, int maxlen); void screendisp(NEVENTITEM item); void screenvsync(NEVENTITEM item);