#ifndef CG6_H
#define CG6_H
#include "xf86.h"
#include "xf86_OSproc.h"
#include "xf86_ansic.h"
#include "xf86RamDac.h"
#include "Xmd.h"
#include "gcstruct.h"
#include "cg6_regs.h"
#include "xf86sbusBus.h"
#define CG6_FBC_VOFF 0x70000000
#define CG6_TEC_VOFF 0x70001000
#define CG6_BTREGS_VOFF 0x70002000
#define CG6_FHC_VOFF 0x70004000
#define CG6_THC_VOFF 0x70005000
#define CG6_ROM_VOFF 0x70006000
#define CG6_RAM_VOFF 0x70016000
#define CG6_DHC_VOFF 0x80000000
typedef struct {
unsigned int fg, bg;
unsigned int patalign;
unsigned int alu;
unsigned int bits[32];
} Cg6StippleRec, *Cg6StipplePtr;
typedef struct {
int type;
Cg6StipplePtr stipple;
} Cg6PrivGCRec, *Cg6PrivGCPtr;
typedef struct {
unsigned char *fb;
Cg6FbcPtr fbc;
Cg6ThcPtr thc;
int vclipmax;
int width;
int height;
sbusDevicePtr psdp;
Bool HWCursor;
Bool NoAccel;
CloseScreenProcPtr CloseScreen;
xf86CursorInfoPtr CursorInfoRec;
unsigned int CursorXY;
int CursorBg, CursorFg;
Bool CursorEnabled;
OptionInfoPtr Options;
} Cg6Rec, *Cg6Ptr;
extern int Cg6ScreenPrivateIndex;
extern int Cg6GCPrivateIndex;
extern int Cg6WindowPrivateIndex;
#define GET_CG6_FROM_SCRN(p) ((Cg6Ptr)((p)->driverPrivate))
#define Cg6GetScreenPrivate(s) \
((Cg6Ptr) (s)->devPrivates[Cg6ScreenPrivateIndex].ptr)
#define Cg6GetGCPrivate(g) \
((Cg6PrivGCPtr) (g)->devPrivates [Cg6GCPrivateIndex].ptr)
#define Cg6GetWindowPrivate(w) \
((Cg6StipplePtr) (w)->devPrivates[Cg6WindowPrivateIndex].ptr)
#define Cg6SetWindowPrivate(w,p) \
((w)->devPrivates[Cg6WindowPrivateIndex].ptr = (pointer) p)
extern int cg6RopTable[];
#endif