OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [rtos/] [ecos-2.0/] [packages/] [services/] [gfx/] [mw/] [v2_0/] [src/] [drivers/] [vgaplan4.h] - Rev 27

Go to most recent revision | Compare with Previous | Blame | View Log

/*
 * Copyright (c) 1999, 2002 Greg Haerr <greg@censoft.com>
 *
 * Header file for EGA/VGA 16 color 4 planes screen driver
 * Added functions for Hercules access
 *
 */
#define SLOWVGA		0	/* =1 for outb rather than outw instructions*/
 
#ifdef __PACIFIC__
#define HAVEBLIT	0
#else
#define HAVEBLIT	1	/* =0 to exclude blitting in vgaplan4 drivers*/
#endif
 
#if UNIX & !ELKS
#define HAVEFARPTR	1
#define FAR
#endif
 
#if LINUX
#ifdef __GLIBC__
#include <sys/io.h>		/* for outb def's, requires -O */
#else
#include <asm/io.h>		/* for outb def's on 2.3.x*/
#endif
#include <unistd.h>
#define HAVEFARPTR	1
#define FAR
#define HAVEIOPERM	1	/* has ioperm() system call*/
#endif
 
#if MSDOS
#define HAVEFARPTR	1	/* compiler has _far extension*/
#ifdef __PACIFIC__
#include <dos.h>
#define FAR		far
#else
#define FAR		_far
#endif
#endif
 
#if __rtems__
#define HAVEFARPTR	1
#define FAR
#include <i386_io.h>
#endif
 
#if MSDOS | ELKS
/* make far ptr*/
#define MK_FP(seg,ofs)	((FARADDR)(((unsigned long)(seg) << 16) | (unsigned)(ofs)))
#define EGA_BASE 	MK_FP(0xa000, 0)
#else
#define EGA_BASE 	((unsigned char *)0xa0000)
#endif
 
#ifdef __ECOS
# define HAVEFARPTR 1
# define FAR
# include <pkgconf/system.h>
# ifdef CYGPKG_HAL_I386
#  include <cyg/hal/hal_io.h>
#  define outb(_a_, _b_) HAL_WRITE_UINT8(_b_, _a_)
#  define outp(_a_, _b_) HAL_WRITE_UINT8(_a_, _b_)
#  define outw(_a_, _b_) HAL_WRITE_UINT16(_b_, _a_)
# else
#  define outb(_a_, _b_)
#  define outp(_a_, _b_)
#  define outw(_a_, _b_)
# endif
#endif
 
#if HAVEFARPTR
/* far ptr access to screen*/
typedef volatile unsigned char FAR * FARADDR;
 
#if _MINIX
/* get byte at address*/
extern unsigned char GETBYTE_FP(FARADDR);
 
/* put byte at address*/
extern void PUTBYTE_FP(FARADDR,unsigned char);
 
/* read-modify-write at address*/
extern void RMW_FP(FARADDR);
#else
/* get byte at address*/
#define GETBYTE_FP(addr)	(*(FARADDR)(addr))
 
/* put byte at address*/
#define PUTBYTE_FP(addr,val)	((*(FARADDR)(addr)) = (val))
 
/* read-modify-write at address*/
#define RMW_FP(addr)		((*(FARADDR)(addr)) |= 1)
 
/* or byte at address*/
#define ORBYTE_FP(addr,val)	((*(FARADDR)(addr)) |= (val))
 
/* and byte at address*/
#define ANDBYTE_FP(addr,val)	((*(FARADDR)(addr)) &= (val))
#endif
#else
 
/* for bcc with no _far extension*/
typedef unsigned long	FARADDR;
 
/* get byte at address*/
extern unsigned char GETBYTE_FP(FARADDR);
 
/* put byte at address*/
extern void PUTBYTE_FP(FARADDR,unsigned char);
 
/* read-modify-write at address*/
extern void RMW_FP(FARADDR);
 
/* or byte at address*/
extern void ORBYTE_FP(FARADDR,unsigned char);
 
/* and byte at address*/
extern void ANDBYTE_FP(FARADDR,unsigned char);
#endif
 
 
#if MSDOS
#define outb(val,port)	outp(port,val)
#endif
 
#if ELKS
#define outb(val,port)	outportb(port,val)
#define outw(val,port)	outport(port,val)
 
extern int  inportb(int port);
extern void outportb(int port,unsigned char data);
extern void outport(int port,int data);
#endif
 
/* external routines*/
FARADDR		int10(int ax,int bx);
 
/* external routines implementing planar ega/vga access*/
 
/* vgaplan4.c portable C, asmplan4.s asm, or ELKS asm elkplan4.c driver*/
int		ega_init(PSD psd);
void 		ega_drawpixel(PSD psd,unsigned int x,unsigned int y,
			MWPIXELVAL c);
MWPIXELVAL 	ega_readpixel(PSD psd,unsigned int x,unsigned int y);
void		ega_drawhorzline(PSD psd,unsigned int x1,unsigned int x2,
			unsigned int y,MWPIXELVAL c);
void		ega_drawvertline(PSD psd,unsigned int x,unsigned int y1,
			unsigned int y2, MWPIXELVAL c);
#if HAVEBLIT
/* memplan4.c*/
void	 	ega_blit(PSD dstpsd, MWCOORD dstx, MWCOORD dsty, MWCOORD w,
			MWCOORD h,PSD srcpsd,MWCOORD srcx,MWCOORD srcy,long op);
#endif
 
/* vgainit.c - direct hw init*/
void		ega_hwinit(void);
void		ega_hwterm(void);
 
#if _MINIX
#define	outb(v, p)	outb(p, v)
#define	outw(v, p)	outw(p, v)
#endif
 
#if SLOWVGA
/* use outb rather than outw instructions for older, slower VGA's*/
 
/* Program the Set/Reset Register for drawing in color COLOR for write
   mode 0. */
#define set_color(c)		{ outb (0, 0x3ce); outb (c, 0x3cf); }
 
/* Set the Enable Set/Reset Register. */
#define set_enable_sr(mask) { outb (1, 0x3ce); outb (mask, 0x3cf); }
 
/* Select the Bit Mask Register on the Graphics Controller. */
#define select_mask() 		{ outb (8, 0x3ce); }
 
/* Program the Bit Mask Register to affect only the pixels selected in
   MASK.  The Bit Mask Register must already have been selected with
   select_mask (). */
#define set_mask(mask)		{ outb (mask, 0x3cf); }
 
#define select_and_set_mask(mask) { outb (8, 0x3ce); outb (mask, 0x3cf); }
 
/* Set the Data Rotate Register.  Bits 0-2 are rotate count, bits 3-4
   are logical operation (0=NOP, 1=AND, 2=OR, 3=XOR). */
#define set_op(op) 		{ outb (3, 0x3ce); outb (op, 0x3cf); }
 
/* Set the Memory Plane Write Enable register. */
#define set_write_planes(mask) { outb (2, 0x3c4); outb (mask, 0x3c5); }
 
/* Set the Read Map Select register. */
#define set_read_plane(plane)	{ outb (4, 0x3ce); outb (plane, 0x3cf); }
 
/* Set the Graphics Mode Register.  The write mode is in bits 0-1, the
   read mode is in bit 3. */
#define set_mode(mode) 		{ outb (5, 0x3ce); outb (mode, 0x3cf); }
 
#else /* !SLOWVGA*/
/* use outw rather than outb instructions for new VGAs*/
 
/* Program the Set/Reset Register for drawing in color COLOR for write
   mode 0. */
#define set_color(c)		{ outw ((c)<<8, 0x3ce); }
 
/* Set the Enable Set/Reset Register. */
#define set_enable_sr(mask) 	{ outw (1|((mask)<<8), 0x3ce); }
 
/* Select the Bit Mask Register on the Graphics Controller. */
#define select_mask() 		{ outb (8, 0x3ce); }
 
/* Program the Bit Mask Register to affect only the pixels selected in
   MASK.  The Bit Mask Register must already have been selected with
   select_mask (). */
#define set_mask(mask)		{ outb (mask, 0x3cf); }
 
#define select_and_set_mask(mask) { outw (8|((mask)<<8), 0x3ce); }
 
/* Set the Data Rotate Register.  Bits 0-2 are rotate count, bits 3-4
   are logical operation (0=NOP, 1=AND, 2=OR, 3=XOR). */
#define set_op(op) 		{ outw (3|((op)<<8), 0x3ce); }
 
/* Set the Memory Plane Write Enable register. */
#define set_write_planes(mask) { outw (2|((mask)<<8), 0x3c4); }
 
/* Set the Read Map Select register. */
#define set_read_plane(plane)	{ outw (4|((plane)<<8), 0x3ce); }
 
/* Set the Graphics Mode Register.  The write mode is in bits 0-1, the
   read mode is in bit 3. */
#define set_mode(mode) 		{ outw (5|((mode)<<8), 0x3ce); }
 
#endif /* SLOWVGA*/
 

Go to most recent revision | Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.