2006-11-26 11:13:41 -07:00
|
|
|
|
|
|
|
#ifndef _XF86RAMDAC_H
|
|
|
|
#define _XF86RAMDAC_H 1
|
|
|
|
|
|
|
|
#include "colormapst.h"
|
|
|
|
#include "xf86Cursor.h"
|
|
|
|
|
|
|
|
/* Define unique vendor codes for RAMDAC's */
|
|
|
|
#define VENDOR_IBM 0x0000
|
|
|
|
#define VENDOR_BT 0x0001
|
|
|
|
#define VENDOR_TI 0x0002
|
|
|
|
|
|
|
|
typedef struct _RamDacRegRec {
|
|
|
|
/* This is probably the nastiest assumption, we allocate 1024 slots for
|
2015-09-16 13:10:19 -06:00
|
|
|
* ramdac registers, should be enough. I've checked IBM and TVP series
|
|
|
|
* and they seem o.k
|
2006-11-26 11:13:41 -07:00
|
|
|
* Then we allocate 768 entries for the DAC too. IBM640 needs 1024 -FIXME
|
|
|
|
*/
|
2012-06-10 07:21:05 -06:00
|
|
|
unsigned short DacRegs[0x400]; /* register set */
|
|
|
|
unsigned char DAC[0x300]; /* colour map */
|
2006-11-26 11:13:41 -07:00
|
|
|
Bool Overlay;
|
|
|
|
} RamDacRegRec, *RamDacRegRecPtr;
|
|
|
|
|
|
|
|
typedef struct _RamDacHWRegRec {
|
2012-06-10 07:21:05 -06:00
|
|
|
RamDacRegRec SavedReg;
|
|
|
|
RamDacRegRec ModeReg;
|
2006-11-26 11:13:41 -07:00
|
|
|
} RamDacHWRec, *RamDacHWRecPtr;
|
|
|
|
|
|
|
|
typedef struct _RamDacRec {
|
|
|
|
CARD32 RamDacType;
|
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
void (*LoadPalette) (ScrnInfoPtr pScrn,
|
|
|
|
int numColors,
|
|
|
|
int *indices, LOCO * colors, VisualPtr pVisual);
|
|
|
|
|
|
|
|
unsigned char (*ReadDAC) (ScrnInfoPtr pScrn, CARD32);
|
|
|
|
|
|
|
|
void (*WriteDAC) (ScrnInfoPtr pScrn, CARD32, unsigned char, unsigned char);
|
|
|
|
|
|
|
|
void (*WriteAddress) (ScrnInfoPtr pScrn, CARD32);
|
|
|
|
|
|
|
|
void (*WriteData) (ScrnInfoPtr pScrn, unsigned char);
|
|
|
|
|
|
|
|
void (*ReadAddress) (ScrnInfoPtr pScrn, CARD32);
|
|
|
|
|
|
|
|
unsigned char (*ReadData) (ScrnInfoPtr pScrn);
|
2006-11-26 11:13:41 -07:00
|
|
|
} RamDacRec, *RamDacRecPtr;
|
|
|
|
|
|
|
|
typedef struct _RamDacHelperRec {
|
|
|
|
CARD32 RamDacType;
|
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
void (*Restore) (ScrnInfoPtr pScrn,
|
|
|
|
RamDacRecPtr ramdacPtr, RamDacRegRecPtr ramdacReg);
|
|
|
|
|
|
|
|
void (*Save) (ScrnInfoPtr pScrn,
|
|
|
|
RamDacRecPtr ramdacPtr, RamDacRegRecPtr ramdacReg);
|
|
|
|
|
|
|
|
void (*SetBpp) (ScrnInfoPtr pScrn, RamDacRegRecPtr ramdacReg);
|
|
|
|
|
|
|
|
void (*HWCursorInit) (xf86CursorInfoPtr infoPtr);
|
2006-11-26 11:13:41 -07:00
|
|
|
} RamDacHelperRec, *RamDacHelperRecPtr;
|
|
|
|
|
|
|
|
#define RAMDACHWPTR(p) ((RamDacHWRecPtr)((p)->privates[RamDacGetHWIndex()].ptr))
|
|
|
|
|
|
|
|
typedef struct _RamdacScreenRec {
|
2012-06-10 07:21:05 -06:00
|
|
|
RamDacRecPtr RamDacRec;
|
2006-11-26 11:13:41 -07:00
|
|
|
} RamDacScreenRec, *RamDacScreenRecPtr;
|
2012-06-10 07:21:05 -06:00
|
|
|
|
2006-11-26 11:13:41 -07:00
|
|
|
#define RAMDACSCRPTR(p) ((RamDacScreenRecPtr)((p)->privates[RamDacGetScreenIndex()].ptr))->RamDacRec
|
|
|
|
|
2010-07-27 13:02:24 -06:00
|
|
|
extern _X_EXPORT int RamDacHWPrivateIndex;
|
|
|
|
extern _X_EXPORT int RamDacScreenPrivateIndex;
|
2006-11-26 11:13:41 -07:00
|
|
|
|
|
|
|
typedef struct {
|
2012-06-10 07:21:05 -06:00
|
|
|
int token;
|
2006-11-26 11:13:41 -07:00
|
|
|
} RamDacSupportedInfoRec, *RamDacSupportedInfoRecPtr;
|
|
|
|
|
2010-07-27 13:02:24 -06:00
|
|
|
extern _X_EXPORT RamDacRecPtr RamDacCreateInfoRec(void);
|
|
|
|
extern _X_EXPORT RamDacHelperRecPtr RamDacHelperCreateInfoRec(void);
|
|
|
|
extern _X_EXPORT void RamDacDestroyInfoRec(RamDacRecPtr RamDacRec);
|
|
|
|
extern _X_EXPORT void RamDacHelperDestroyInfoRec(RamDacHelperRecPtr RamDacRec);
|
|
|
|
extern _X_EXPORT Bool RamDacInit(ScrnInfoPtr pScrn, RamDacRecPtr RamDacRec);
|
2012-06-10 07:21:05 -06:00
|
|
|
extern _X_EXPORT Bool RamDacHandleColormaps(ScreenPtr pScreen, int maxColors,
|
|
|
|
int sigRGBbits, unsigned int flags);
|
2010-07-27 13:02:24 -06:00
|
|
|
extern _X_EXPORT void RamDacFreeRec(ScrnInfoPtr pScrn);
|
2012-06-10 07:21:05 -06:00
|
|
|
extern _X_EXPORT int RamDacGetHWIndex(void);
|
2006-11-26 11:13:41 -07:00
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
#endif /* _XF86RAMDAC_H */
|