c7f63fca93
(TODO: support for standard VGA 4 bit mode - saving as 8 bpp BMP)
270 lines
9.5 KiB
C++
270 lines
9.5 KiB
C++
/////////////////////////////////////////////////////////////////////////
|
|
// $Id$
|
|
/////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// Copyright (c) 2004 Makoto Suzuki (suzu)
|
|
// Volker Ruppert (vruppert)
|
|
// Robin Kay (komadori)
|
|
//
|
|
// This library is free software; you can redistribute it and/or
|
|
// modify it under the terms of the GNU Lesser General Public
|
|
// License as published by the Free Software Foundation; either
|
|
// version 2 of the License, or (at your option) any later version.
|
|
//
|
|
// This library is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
// Lesser General Public License for more details.
|
|
//
|
|
// You should have received a copy of the GNU Lesser General Public
|
|
// License along with this library; if not, write to the Free Software
|
|
// Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
//
|
|
/////////////////////////////////////////////////////////////////////////
|
|
|
|
#if BX_SUPPORT_CLGD54XX
|
|
|
|
#if BX_USE_CIRRUS_SMF
|
|
# define BX_CIRRUS_SMF static
|
|
# define BX_CIRRUS_THIS theSvga->
|
|
# define BX_CIRRUS_THIS_PTR theSvga
|
|
#else
|
|
# define BX_CIRRUS_SMF
|
|
# define BX_CIRRUS_THIS this->
|
|
# define BX_CIRRUS_THIS_PTR this
|
|
#endif // BX_USE_CIRRUS_SMF
|
|
|
|
// 0x3b4,0x3d4
|
|
#define VGA_CRTC_MAX 0x18
|
|
#define CIRRUS_CRTC_MAX 0x27
|
|
// 0x3c4
|
|
#define VGA_SEQENCER_MAX 0x04
|
|
#define CIRRUS_SEQENCER_MAX 0x1f
|
|
// 0x3ce
|
|
#define VGA_CONTROL_MAX 0x08
|
|
#define CIRRUS_CONTROL_MAX 0x39
|
|
|
|
// Size of internal cache memory for bitblt. (must be >= 256 and 4-byte aligned)
|
|
#define CIRRUS_BLT_CACHESIZE (2048 * 4)
|
|
|
|
#if BX_SUPPORT_PCI
|
|
#define CIRRUS_VIDEO_MEMORY_MB 4
|
|
#else
|
|
#define CIRRUS_VIDEO_MEMORY_MB 2
|
|
#endif
|
|
|
|
#define CIRRUS_VIDEO_MEMORY_KB (CIRRUS_VIDEO_MEMORY_MB * 1024)
|
|
#define CIRRUS_VIDEO_MEMORY_BYTES (CIRRUS_VIDEO_MEMORY_KB * 1024)
|
|
|
|
typedef void (*bx_cirrus_bitblt_rop_t)(
|
|
Bit8u *dst,const Bit8u *src,
|
|
int dstpitch,int srcpitch,
|
|
int bltwidth,int bltheight);
|
|
|
|
class bx_svga_cirrus_c : public bx_vga_c
|
|
#if BX_SUPPORT_PCI
|
|
, public bx_pci_device_stub_c
|
|
#endif
|
|
{
|
|
public:
|
|
bx_svga_cirrus_c();
|
|
virtual ~bx_svga_cirrus_c();
|
|
|
|
virtual void init_vga_extension(void);
|
|
virtual void reset(unsigned type);
|
|
virtual void redraw_area(unsigned x0, unsigned y0,
|
|
unsigned width, unsigned height);
|
|
virtual Bit8u mem_read(bx_phy_address addr);
|
|
virtual void mem_write(bx_phy_address addr, Bit8u value);
|
|
virtual int get_snapshot_mode(void);
|
|
virtual void get_text_snapshot(Bit8u **text_snapshot,
|
|
unsigned *txHeight, unsigned *txWidth);
|
|
virtual Bit32u get_gfx_snapshot(Bit8u **snapshot_ptr, Bit8u **palette_ptr,
|
|
unsigned *iHeight, unsigned *iWidth, unsigned *iDepth);
|
|
virtual void trigger_timer(void *this_ptr);
|
|
virtual Bit8u get_actl_palette_idx(Bit8u index);
|
|
virtual void register_state(void);
|
|
virtual void after_restore_state(void);
|
|
|
|
#if BX_SUPPORT_PCI
|
|
virtual Bit32u pci_read_handler(Bit8u address, unsigned io_len);
|
|
virtual void pci_write_handler(Bit8u address, Bit32u value, unsigned io_len);
|
|
#endif
|
|
|
|
private:
|
|
static Bit32u svga_read_handler(void *this_ptr, Bit32u address, unsigned io_len);
|
|
static void svga_write_handler(void *this_ptr, Bit32u address, Bit32u value, unsigned io_len);
|
|
#if !BX_USE_CIRRUS_SMF
|
|
Bit32u svga_read(Bit32u address, unsigned io_len);
|
|
void svga_write(Bit32u address, Bit32u value, unsigned io_len);
|
|
#endif
|
|
BX_CIRRUS_SMF void mem_write_mode4and5_8bpp(Bit8u mode, Bit32u offset, Bit8u value);
|
|
BX_CIRRUS_SMF void mem_write_mode4and5_16bpp(Bit8u mode, Bit32u offset, Bit8u value);
|
|
|
|
static void svga_timer_handler(void *);
|
|
static Bit64s svga_param_handler(bx_param_c *param, int set, Bit64s val);
|
|
BX_CIRRUS_SMF void svga_timer(void);
|
|
BX_CIRRUS_SMF void svga_modeupdate(void);
|
|
BX_CIRRUS_SMF void svga_update(void);
|
|
|
|
BX_CIRRUS_SMF void svga_init_members();
|
|
|
|
BX_CIRRUS_SMF void draw_hardware_cursor(unsigned, unsigned, bx_svga_tileinfo_t *);
|
|
|
|
// bank memory
|
|
BX_CIRRUS_SMF void update_bank_ptr(Bit8u bank_index);
|
|
// 0x3b4-0x3b5,0x3d4-0x3d5
|
|
BX_CIRRUS_SMF Bit8u svga_read_crtc(Bit32u address, unsigned index);
|
|
BX_CIRRUS_SMF void svga_write_crtc(Bit32u address, unsigned index, Bit8u value);
|
|
// 0x3c4-0x3c5
|
|
BX_CIRRUS_SMF Bit8u svga_read_sequencer(Bit32u address, unsigned index);
|
|
BX_CIRRUS_SMF void svga_write_sequencer(Bit32u address, unsigned index, Bit8u value);
|
|
// 0x3ce-0x3cf
|
|
BX_CIRRUS_SMF Bit8u svga_read_control(Bit32u address, unsigned index);
|
|
BX_CIRRUS_SMF void svga_write_control(Bit32u address, unsigned index, Bit8u value);
|
|
// memory-mapped I/O
|
|
BX_CIRRUS_SMF Bit8u svga_mmio_vga_read(Bit32u address);
|
|
BX_CIRRUS_SMF void svga_mmio_vga_write(Bit32u address,Bit8u value);
|
|
BX_CIRRUS_SMF Bit8u svga_mmio_blt_read(Bit32u address);
|
|
BX_CIRRUS_SMF void svga_mmio_blt_write(Bit32u address,Bit8u value);
|
|
|
|
BX_CIRRUS_SMF void svga_reset_bitblt(void);
|
|
BX_CIRRUS_SMF void svga_bitblt();
|
|
|
|
BX_CIRRUS_SMF void svga_colorexpand(Bit8u *dst,const Bit8u *src,int count,int pixelwidth);
|
|
|
|
#if BX_USE_CIRRUS_SMF
|
|
#define svga_colorexpand_8_static svga_colorexpand_8
|
|
#define svga_colorexpand_16_static svga_colorexpand_16
|
|
#define svga_colorexpand_24_static svga_colorexpand_24
|
|
#define svga_colorexpand_32_static svga_colorexpand_32
|
|
#else
|
|
static void svga_colorexpand_8_static(void *this_ptr,Bit8u *dst,const Bit8u *src,int count);
|
|
static void svga_colorexpand_16_static(void *this_ptr,Bit8u *dst,const Bit8u *src,int count);
|
|
static void svga_colorexpand_24_static(void *this_ptr,Bit8u *dst,const Bit8u *src,int count);
|
|
static void svga_colorexpand_32_static(void *this_ptr,Bit8u *dst,const Bit8u *src,int count);
|
|
#endif
|
|
|
|
BX_CIRRUS_SMF void svga_colorexpand_8(Bit8u *dst,const Bit8u *src,int count);
|
|
BX_CIRRUS_SMF void svga_colorexpand_16(Bit8u *dst,const Bit8u *src,int count);
|
|
BX_CIRRUS_SMF void svga_colorexpand_24(Bit8u *dst,const Bit8u *src,int count);
|
|
BX_CIRRUS_SMF void svga_colorexpand_32(Bit8u *dst,const Bit8u *src,int count);
|
|
|
|
BX_CIRRUS_SMF void svga_setup_bitblt_cputovideo(Bit32u dstaddr,Bit32u srcaddr);
|
|
BX_CIRRUS_SMF void svga_setup_bitblt_videotocpu(Bit32u dstaddr,Bit32u srcaddr);
|
|
BX_CIRRUS_SMF void svga_setup_bitblt_videotovideo(Bit32u dstaddr,Bit32u srcaddr);
|
|
|
|
#if BX_USE_CIRRUS_SMF == 0
|
|
static void svga_patterncopy_static(void *this_ptr);
|
|
static void svga_simplebitblt_static(void *this_ptr);
|
|
static void svga_solidfill_static(void *this_ptr);
|
|
static void svga_patterncopy_memsrc_static(void *this_ptr);
|
|
static void svga_simplebitblt_memsrc_static(void *this_ptr);
|
|
static void svga_colorexpand_transp_memsrc_static(void *this_ptr);
|
|
#else
|
|
#define svga_patterncopy_static svga_patterncopy
|
|
#define svga_simplebitblt_static svga_simplebitblt
|
|
#define svga_solidfill_static svga_solidfill
|
|
#define svga_patterncopy_memsrc_static svga_patterncopy_memsrc
|
|
#define svga_simplebitblt_memsrc_static svga_simplebitblt_memsrc
|
|
#define svga_colorexpand_transp_memsrc_static svga_colorexpand_transp_memsrc
|
|
#endif
|
|
|
|
BX_CIRRUS_SMF void svga_patterncopy();
|
|
BX_CIRRUS_SMF void svga_simplebitblt();
|
|
BX_CIRRUS_SMF void svga_solidfill();
|
|
BX_CIRRUS_SMF void svga_patterncopy_memsrc();
|
|
BX_CIRRUS_SMF void svga_simplebitblt_memsrc();
|
|
BX_CIRRUS_SMF void svga_colorexpand_transp_memsrc();
|
|
|
|
BX_CIRRUS_SMF bx_bool svga_asyncbitblt_next();
|
|
BX_CIRRUS_SMF bx_cirrus_bitblt_rop_t svga_get_fwd_rop_handler(Bit8u rop);
|
|
BX_CIRRUS_SMF bx_cirrus_bitblt_rop_t svga_get_bkwd_rop_handler(Bit8u rop);
|
|
|
|
struct {
|
|
Bit8u index;
|
|
Bit8u reg[CIRRUS_CRTC_MAX+1];
|
|
} crtc; // 0x3b4-5/0x3d4-5
|
|
struct {
|
|
Bit8u index;
|
|
Bit8u reg[CIRRUS_SEQENCER_MAX+1];
|
|
} sequencer; // 0x3c4-5
|
|
struct {
|
|
Bit8u index;
|
|
Bit8u reg[CIRRUS_CONTROL_MAX+1];
|
|
Bit8u shadow_reg0;
|
|
Bit8u shadow_reg1;
|
|
} control; // 0x3ce-f
|
|
struct {
|
|
unsigned lockindex;
|
|
Bit8u data;
|
|
Bit8u palette[48];
|
|
} hidden_dac; // 0x3c6
|
|
|
|
bx_bool svga_unlock_special;
|
|
bx_bool svga_needs_update_tile;
|
|
bx_bool svga_needs_update_dispentire;
|
|
bx_bool svga_needs_update_mode;
|
|
|
|
unsigned svga_xres;
|
|
unsigned svga_yres;
|
|
unsigned svga_pitch;
|
|
unsigned svga_bpp;
|
|
unsigned svga_dispbpp;
|
|
|
|
Bit32u bank_base[2];
|
|
Bit32u bank_limit[2];
|
|
Bit8u *disp_ptr;
|
|
|
|
struct {
|
|
bx_cirrus_bitblt_rop_t rop_handler;
|
|
int pixelwidth;
|
|
int bltwidth;
|
|
int bltheight;
|
|
int dstpitch;
|
|
int srcpitch;
|
|
Bit8u bltmode;
|
|
Bit8u bltmodeext;
|
|
Bit8u bltrop;
|
|
Bit8u *dst;
|
|
const Bit8u *src;
|
|
Bit32u srcaddr;
|
|
#if BX_USE_CIRRUS_SMF
|
|
void (*bitblt_ptr)();
|
|
#else
|
|
void (*bitblt_ptr)(void *this_ptr);
|
|
#endif
|
|
Bit8u *memsrc_ptr; // CPU -> video
|
|
Bit8u *memsrc_endptr;
|
|
int memsrc_needed;
|
|
Bit8u *memdst_ptr; // video -> CPU
|
|
Bit8u *memdst_endptr;
|
|
int memdst_bytesperline;
|
|
int memdst_needed;
|
|
Bit8u memsrc[CIRRUS_BLT_CACHESIZE];
|
|
Bit8u memdst[CIRRUS_BLT_CACHESIZE];
|
|
} bitblt;
|
|
|
|
struct {
|
|
Bit16u x, y, size;
|
|
} hw_cursor;
|
|
|
|
struct {
|
|
Bit16u x, y, w, h;
|
|
} redraw;
|
|
|
|
bx_bool is_unlocked() { return svga_unlock_special; }
|
|
|
|
bx_bool banking_granularity_is_16k() { return !!(control.reg[0x0B] & 0x20); }
|
|
bx_bool banking_is_dual() { return !!(control.reg[0x0B] & 0x01); }
|
|
|
|
#if BX_SUPPORT_PCI
|
|
BX_CIRRUS_SMF void svga_init_pcihandlers(void);
|
|
|
|
BX_CIRRUS_SMF bx_bool cirrus_mem_read_handler(bx_phy_address addr, unsigned len, void *data, void *param);
|
|
BX_CIRRUS_SMF bx_bool cirrus_mem_write_handler(bx_phy_address addr, unsigned len, void *data, void *param);
|
|
#endif
|
|
};
|
|
|
|
#endif // BX_SUPPORT_CLGD54XX
|