mirror of
https://github.com/ekeeke/Genesis-Plus-GX.git
synced 2025-01-03 23:21:51 +01:00
109 lines
4.2 KiB
C
109 lines
4.2 KiB
C
/***************************************************************************************
|
|
* Genesis Plus
|
|
* Video Display Processor (68k & Z80 CPU interface)
|
|
*
|
|
* Support for SG-1000 (TMS99xx & 315-5066), Master System (315-5124 & 315-5246), Game Gear & Mega Drive VDP
|
|
*
|
|
* Copyright (C) 1998-2003 Charles Mac Donald (original code)
|
|
* Copyright (C) 2007-2024 Eke-Eke (Genesis Plus GX)
|
|
*
|
|
* Redistribution and use of this code or any derivative works are permitted
|
|
* provided that the following conditions are met:
|
|
*
|
|
* - Redistributions may not be sold, nor may they be used in a commercial
|
|
* product or activity.
|
|
*
|
|
* - Redistributions that are modified from the original source must include the
|
|
* complete source code, including the source code for all components used by a
|
|
* binary built from the modified sources. However, as a special exception, the
|
|
* source code distributed need not include anything that is normally distributed
|
|
* (in either source or binary form) with the major components (compiler, kernel,
|
|
* and so on) of the operating system on which the executable runs, unless that
|
|
* component itself accompanies the executable.
|
|
*
|
|
* - Redistributions must reproduce the above copyright notice, this list of
|
|
* conditions and the following disclaimer in the documentation and/or other
|
|
* materials provided with the distribution.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
|
|
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
* POSSIBILITY OF SUCH DAMAGE.
|
|
*
|
|
****************************************************************************************/
|
|
|
|
#ifndef _VDP_H_
|
|
#define _VDP_H_
|
|
|
|
/* VDP context */
|
|
extern uint8 reg[0x20];
|
|
extern uint8 sat[0x400];
|
|
extern uint8 vram[0x10000];
|
|
extern uint8 cram[0x80];
|
|
extern uint8 vsram[0x80];
|
|
extern uint8 hint_pending;
|
|
extern uint8 vint_pending;
|
|
extern uint16 status;
|
|
extern uint32 dma_length;
|
|
extern uint32 dma_endCycles;
|
|
extern uint8 dma_type;
|
|
|
|
/* Global variables */
|
|
extern uint16 ntab;
|
|
extern uint16 ntbb;
|
|
extern uint16 ntwb;
|
|
extern uint16 satb;
|
|
extern uint16 hscb;
|
|
extern uint8 bg_name_dirty[0x800];
|
|
extern uint16 bg_name_list[0x800];
|
|
extern uint16 bg_list_index;
|
|
extern uint8 hscroll_mask;
|
|
extern uint8 playfield_shift;
|
|
extern uint8 playfield_col_mask;
|
|
extern uint16 playfield_row_mask;
|
|
extern uint8 odd_frame;
|
|
extern uint8 im2_flag;
|
|
extern uint8 interlaced;
|
|
extern uint8 vdp_pal;
|
|
extern uint8 h_counter;
|
|
extern uint16 v_counter;
|
|
extern uint16 vc_max;
|
|
extern uint16 vscroll;
|
|
extern uint16 lines_per_frame;
|
|
extern uint16 max_sprite_pixels;
|
|
extern uint32 fifo_cycles[4];
|
|
extern uint32 hvc_latch;
|
|
extern uint32 vint_cycle;
|
|
extern const uint8 *hctab;
|
|
|
|
/* Function pointers */
|
|
extern void (*vdp_68k_data_w)(unsigned int data);
|
|
extern void (*vdp_z80_data_w)(unsigned int data);
|
|
extern unsigned int (*vdp_68k_data_r)(void);
|
|
extern unsigned int (*vdp_z80_data_r)(void);
|
|
|
|
/* Function prototypes */
|
|
extern void vdp_init(void);
|
|
extern void vdp_reset(void);
|
|
extern int vdp_context_save(uint8 *state);
|
|
extern int vdp_context_load(uint8 *state);
|
|
extern void vdp_dma_update(unsigned int cycles);
|
|
extern void vdp_68k_ctrl_w(unsigned int data);
|
|
extern void vdp_z80_ctrl_w(unsigned int data);
|
|
extern void vdp_sms_ctrl_w(unsigned int data);
|
|
extern void vdp_tms_ctrl_w(unsigned int data);
|
|
extern unsigned int vdp_68k_ctrl_r(unsigned int cycles);
|
|
extern unsigned int vdp_z80_ctrl_r(unsigned int cycles);
|
|
extern unsigned int vdp_hvc_r(unsigned int cycles);
|
|
extern void vdp_test_w(unsigned int data);
|
|
extern int vdp_68k_irq_ack(int int_level);
|
|
|
|
#endif /* _VDP_H_ */
|