#define FRAMES_PER_SEC 74.38
#define LINES_PER_FRAME 32
#define CHARS_PER_LINE 94
-#define HD46505_HORIZ_FREQ 2380
+#define HD46505_HORIZ_FREQ (1789780.0 / 752.0)
#else
#define FRAMES_PER_SEC 59.92
#define LINES_PER_FRAME 262
#define CHARS_PER_LINE 57
-#define HD46505_HORIZ_FREQ 15700
+#define HD46505_HORIZ_FREQ (14318180.0 / 912.0)
#endif
#define CPU_CLOCKS 3993600
#ifdef _LCD
#define SCREEN_WIDTH 320
#define SCREEN_HEIGHT 128
#else
+#define SUPPORT_TV_RENDER
#define SCREEN_WIDTH 640
#define SCREEN_HEIGHT 400
+#define WINDOW_HEIGHT_ASPECT 480
#endif
#define MAX_DRIVE 4
#define SUPPORT_VARIABLE_TIMING
// device informations for win32
#define USE_BOOT_MODE 5
#define USE_DEVICE_TYPE 3
-#define USE_TAPE
-#define USE_FD1
-#define USE_FD2
-//#define USE_FD3
-//#define USE_FD4
-#define USE_BINARY_FILE1
+#define USE_TAPE 1
+#define USE_TAPE_BUTTON
+#define USE_FLOPPY_DISK 2
+#define USE_BINARY_FILE 1
#define USE_SHIFT_NUMPAD_KEY
#define USE_ALT_F10_KEY
#define USE_AUTO_KEY 5
#define USE_AUTO_KEY_RELEASE 6
-#define USE_CRT_FILTER
+#define USE_AUTO_KEY_NUMPAD
+#define USE_SCREEN_FILTER
#define USE_SCANLINE
-#define USE_ACCESS_LAMP
+#define USE_SOUND_VOLUME 4
+#define USE_JOYSTICK
#define USE_DEBUGGER
#define USE_STATE
+#define USE_CPU_Z80
#include "../../common.h"
#include "../../fileio.h"
+#include "../vm_template.h"
+
+#ifdef USE_SOUND_VOLUME
+static const _TCHAR *sound_device_caption[] = {
+ _T("Beep"), _T("CMT (Signal)"), _T("Noise (FDD)"), _T("Noise (CMT)"),
+};
+#endif
class EMU;
class DEVICE;
class Z80CTC;
class Z80PIO;
-class FLOPPY;
-class DISPLAY;
-class KEYBOARD;
-class MEMORY;
-class PAC2;
+namespace PASOPIA {
+ class FLOPPY;
+ class DISPLAY;
+ class KEYBOARD;
+ class MEMORY;
+ class PAC2;
+}
-class VM
+class VM : public VM_TEMPLATE
{
protected:
- EMU* emu;
+ //EMU* emu;
+ //csp_state_utils *state_entry;
// devices
EVENT* event;
I8255* pio2;
IO* io;
LS393* flipflop;
- NOT* not;
+ NOT* not_remote;
PCM1BIT* pcm;
UPD765A* fdc;
Z80* cpu;
Z80CTC* ctc;
Z80PIO* pio;
- FLOPPY* floppy;
- DISPLAY* display;
- KEYBOARD* key;
- MEMORY* memory;
- PAC2* pac2;
+ PASOPIA::FLOPPY* floppy;
+ PASOPIA::DISPLAY* display;
+ PASOPIA::KEYBOARD* key;
+ PASOPIA::MEMORY* memory;
+ PASOPIA::PAC2* pac2;
int boot_mode;
// drive virtual machine
void reset();
void run();
- double frame_rate();
+ double get_frame_rate();
#ifdef USE_DEBUGGER
// debugger
// draw screen
void draw_screen();
- int access_lamp();
// sound generation
void initialize_sound(int rate, int samples);
- uint16* create_sound(int* extra_frames);
- int sound_buffer_ptr();
+ uint16_t* create_sound(int* extra_frames);
+ int get_sound_buffer_ptr();
+#ifdef USE_SOUND_VOLUME
+ void set_sound_device_volume(int ch, int decibel_l, int decibel_r);
+#endif
// user interface
- void open_disk(int drv, _TCHAR* file_path, int bank);
- void close_disk(int drv);
- bool disk_inserted(int drv);
- void play_tape(_TCHAR* file_path);
- void rec_tape(_TCHAR* file_path);
- void close_tape();
- bool tape_inserted();
- void load_binary(int drv, _TCHAR* file_path);
- void save_binary(int drv, _TCHAR* file_path) {}
- bool now_skip();
+ void open_floppy_disk(int drv, const _TCHAR* file_path, int bank);
+ void close_floppy_disk(int drv);
+ bool is_floppy_disk_inserted(int drv);
+ void is_floppy_disk_protected(int drv, bool value);
+ bool is_floppy_disk_protected(int drv);
+ uint32_t is_floppy_disk_accessed();
+ void play_tape(int drv, const _TCHAR* file_path);
+ void rec_tape(int drv, const _TCHAR* file_path);
+ void close_tape(int drv);
+ bool is_tape_inserted(int drv);
+ bool is_tape_playing(int drv);
+ bool is_tape_recording(int drv);
+ int get_tape_position(int drv);
+ const _TCHAR* get_tape_message(int drv);
+ void push_play(int drv);
+ void push_stop(int drv);
+ void push_fast_forward(int drv);
+ void push_fast_rewind(int drv);
+ void push_apss_forward(int drv) {}
+ void push_apss_rewind(int drv) {}
+ void load_binary(int drv, const _TCHAR* file_path);
+ void save_binary(int drv, const _TCHAR* file_path) {}
+ bool is_frame_skippable();
void update_config();
- void save_state(FILEIO* state_fio);
- bool load_state(FILEIO* state_fio);
+ bool process_state(FILEIO* state_fio, bool loading);
// ----------------------------------------
// for each device
// devices
DEVICE* get_device(int id);
- DEVICE* dummy;
- DEVICE* first_device;
- DEVICE* last_device;
+ //DEVICE* dummy;
+ //DEVICE* first_device;
+ //DEVICE* last_device;
};
#endif