2010-05-19 10:44:14 +02:00
|
|
|
#ifndef _LINUX_XGIFB
|
|
|
|
#define _LINUX_XGIFB
|
2011-04-24 07:55:49 +02:00
|
|
|
#include <linux/ioctl.h>
|
|
|
|
#include <linux/types.h>
|
2010-05-19 10:44:14 +02:00
|
|
|
|
|
|
|
#define DISPTYPE_CRT1 0x00000008L
|
|
|
|
#define DISPTYPE_CRT2 0x00000004L
|
|
|
|
#define DISPTYPE_LCD 0x00000002L
|
|
|
|
#define DISPTYPE_TV 0x00000001L
|
|
|
|
#define DISPTYPE_DISP2 (DISPTYPE_CRT2 | DISPTYPE_LCD | DISPTYPE_TV)
|
|
|
|
#define DISPMODE_SINGLE 0x00000020L
|
|
|
|
#define DISPMODE_MIRROR 0x00000010L
|
|
|
|
|
2011-04-24 07:55:49 +02:00
|
|
|
#define HASVB_NONE 0x00
|
|
|
|
#define HASVB_301 0x01
|
|
|
|
#define HASVB_LVDS 0x02
|
|
|
|
#define HASVB_TRUMPION 0x04
|
|
|
|
#define HASVB_LVDS_CHRONTEL 0x10
|
|
|
|
#define HASVB_302 0x20
|
|
|
|
#define HASVB_CHRONTEL 0x80
|
2010-05-19 10:44:14 +02:00
|
|
|
|
2010-06-17 19:10:52 +02:00
|
|
|
enum XGI_CHIP_TYPE {
|
2011-04-24 07:55:49 +02:00
|
|
|
XG40 = 32,
|
|
|
|
XG41,
|
|
|
|
XG42,
|
|
|
|
XG45,
|
|
|
|
XG20 = 48,
|
|
|
|
XG21,
|
|
|
|
XG27,
|
2010-06-17 19:10:52 +02:00
|
|
|
};
|
2010-05-19 10:44:14 +02:00
|
|
|
|
2010-06-17 19:10:52 +02:00
|
|
|
enum xgi_tvtype {
|
2010-05-19 10:44:14 +02:00
|
|
|
TVMODE_NTSC = 0,
|
|
|
|
TVMODE_PAL,
|
|
|
|
TVMODE_HIVISION,
|
2011-04-24 07:55:49 +02:00
|
|
|
TVTYPE_PALM, /* vicki@030226 */
|
|
|
|
TVTYPE_PALN, /* vicki@030226 */
|
|
|
|
TVTYPE_NTSCJ, /* vicki@030226 */
|
2010-05-19 10:44:14 +02:00
|
|
|
TVMODE_TOTAL
|
2010-06-17 19:10:52 +02:00
|
|
|
};
|
2010-05-19 10:44:14 +02:00
|
|
|
|
2011-04-24 07:55:49 +02:00
|
|
|
enum xgi_tv_plug { /* vicki@030226 */
|
|
|
|
TVPLUG_UNKNOWN = 0,
|
|
|
|
TVPLUG_COMPOSITE = 1,
|
|
|
|
TVPLUG_SVIDEO = 2,
|
|
|
|
TVPLUG_COMPOSITE_AND_SVIDEO = 3,
|
|
|
|
TVPLUG_SCART = 4,
|
|
|
|
TVPLUG_YPBPR_525i = 5,
|
|
|
|
TVPLUG_YPBPR_525P = 6,
|
|
|
|
TVPLUG_YPBPR_750P = 7,
|
|
|
|
TVPLUG_YPBPR_1080i = 8,
|
2010-05-19 10:44:14 +02:00
|
|
|
TVPLUG_TOTAL
|
2010-06-17 19:10:53 +02:00
|
|
|
};
|
2010-05-19 10:44:14 +02:00
|
|
|
|
2011-04-24 07:55:49 +02:00
|
|
|
struct video_info {
|
|
|
|
int chip_id;
|
|
|
|
unsigned int video_size;
|
|
|
|
unsigned long video_base;
|
|
|
|
char *video_vbase;
|
|
|
|
unsigned long mmio_base;
|
2011-02-17 22:29:17 +01:00
|
|
|
unsigned long mmio_size;
|
2011-04-24 07:55:49 +02:00
|
|
|
char *mmio_vbase;
|
|
|
|
unsigned long vga_base;
|
|
|
|
unsigned long mtrr;
|
|
|
|
|
|
|
|
int video_bpp;
|
|
|
|
int video_cmap_len;
|
|
|
|
int video_width;
|
|
|
|
int video_height;
|
|
|
|
int video_vwidth;
|
|
|
|
int video_vheight;
|
|
|
|
int org_x;
|
|
|
|
int org_y;
|
|
|
|
int video_linelength;
|
|
|
|
unsigned int refresh_rate;
|
|
|
|
|
|
|
|
unsigned long disp_state;
|
|
|
|
unsigned char hasVB;
|
|
|
|
unsigned char TV_type;
|
|
|
|
unsigned char TV_plug;
|
2010-05-19 10:44:14 +02:00
|
|
|
|
2010-06-17 19:10:52 +02:00
|
|
|
enum XGI_CHIP_TYPE chip;
|
2011-04-24 07:55:49 +02:00
|
|
|
unsigned char revision_id;
|
2010-05-19 10:44:14 +02:00
|
|
|
|
2011-04-24 07:55:49 +02:00
|
|
|
unsigned short DstColor;
|
|
|
|
unsigned long XGI310_AccelDepth;
|
|
|
|
unsigned long CommandReg;
|
2010-05-19 10:44:14 +02:00
|
|
|
|
2011-04-24 07:55:49 +02:00
|
|
|
unsigned int pcibus;
|
|
|
|
unsigned int pcislot;
|
|
|
|
unsigned int pcifunc;
|
2010-05-19 10:44:14 +02:00
|
|
|
|
2011-04-24 07:55:49 +02:00
|
|
|
unsigned short subsysvendor;
|
|
|
|
unsigned short subsysdevice;
|
2010-05-19 10:44:14 +02:00
|
|
|
|
2011-04-24 07:55:49 +02:00
|
|
|
char reserved[236];
|
2010-05-19 10:44:14 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
extern struct video_info xgi_video_info;
|
|
|
|
|
|
|
|
#endif
|