OSDN Git Service

[VM][STATE] Use namespace {VMNAME} to separate per VMs.
[csp-qt/common_source_project-fm7.git] / source / src / vm / pasopia / pasopia.h
index 3ec95c3..4c6bda1 100644 (file)
 #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;
@@ -89,16 +99,19 @@ class Z80;
 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;
@@ -110,18 +123,18 @@ protected:
        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;
        
@@ -140,7 +153,7 @@ public:
        // drive virtual machine
        void reset();
        void run();
-       double frame_rate();
+       double get_frame_rate();
        
 #ifdef USE_DEBUGGER
        // debugger
@@ -149,28 +162,42 @@ public:
        
        // 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
@@ -178,9 +205,9 @@ public:
        
        // devices
        DEVICE* get_device(int id);
-       DEVICE* dummy;
-       DEVICE* first_device;
-       DEVICE* last_device;
+       //DEVICE* dummy;
+       //DEVICE* first_device;
+       //DEVICE* last_device;
 };
 
 #endif