b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync * copyed from from linux kernel 2.2.4
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync * removed internal stuff (#ifdef __KERNEL__)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync/* $XFree86: xc/programs/Xserver/hw/xfree86/fbdevhw/fbpriv.h,v 1.2 2000/01/21 02:30:02 dawes Exp $ */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync/* Definitions of frame buffers */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_MODES_SHIFT 5 /* 32 modes per framebuffer */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_MAX (FB_NUM_MINORS / (1 << FB_MODES_SHIFT))
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define GET_FB_IDX(node) (MINOR(node) >> FB_MODES_SHIFT)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync 0x46 is 'F' */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync/* 0x4607-0x460B are defined below */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync/* #define FBIOGET_MONITORSPEC 0x460C */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync/* #define FBIOPUT_MONITORSPEC 0x460D */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync/* #define FBIOSWITCH_MONIBIT 0x460E */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_TYPE_PLANES 1 /* Non interleaved planes */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_TYPE_INTERLEAVED_PLANES 2 /* Interleaved planes */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_AUX_TEXT_CGA 1 /* CGA/EGA/VGA Color text */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_AUX_TEXT_S3_MMIO 2 /* S3 MMIO fasttext */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_AUX_TEXT_MGA_STEP16 3 /* MGA Millenium I: text, attr, 14 reserved bytes */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_AUX_TEXT_MGA_STEP8 4 /* other MGAs: text, attr, 6 reserved bytes */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_VISUAL_MONO01 0 /* Monochr. 1=Black 0=White */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_VISUAL_MONO10 1 /* Monochr. 1=White 0=Black */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_VISUAL_PSEUDOCOLOR 3 /* Pseudo color (like atari) */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_VISUAL_STATIC_PSEUDOCOLOR 5 /* Pseudo color readonly */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_ACCEL_NONE 0 /* no hardware accelerator */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_ACCEL_S3_TRIO64 3 /* Cybervision64 (S3 Trio64) */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_ACCEL_NCR_77C32BLT 4 /* RetinaZ3 (NCR 77C32BLT) */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_ACCEL_S3_VIRGE 5 /* Cybervision64/3D (S3 ViRGE) */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_ACCEL_ATI_MACH64GX 6 /* ATI Mach 64GX family */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_ACCEL_ATI_MACH64CT 8 /* ATI Mach 64CT family */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_ACCEL_ATI_MACH64VT 9 /* ATI Mach 64CT family VT class */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_ACCEL_ATI_MACH64GT 10 /* ATI Mach 64CT family GT class */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_ACCEL_SUN_CREATOR 11 /* Sun Creator/Creator3D */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_ACCEL_IMS_TWINTURBO 14 /* IMS Twin Turbo */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_ACCEL_3DLABS_PERMEDIA2 15 /* 3Dlabs Permedia 2 */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_ACCEL_MATROX_MGA2064W 16 /* Matrox MGA2064W (Millenium) */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_ACCEL_MATROX_MGA1064SG 17 /* Matrox MGA1064SG (Mystique) */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_ACCEL_MATROX_MGA2164W 18 /* Matrox MGA2164W (Millenium II) */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_ACCEL_MATROX_MGA2164W_AGP 19 /* Matrox MGA2164W (Millenium II) */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_ACCEL_MATROX_MGAG100 20 /* Matrox G100 (Productiva G100) */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_ACCEL_MATROX_MGAG200 21 /* Matrox G200 (Myst, Mill, ...) */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_ACCEL_MATROX_MGAG400 26 /* Matrox G400 */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_ACCEL_ATI_RAGE128 32 /* ATI Rage128 family */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync char id[16]; /* identification string eg "TT Builtin" */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync /* (physical address) */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync __u32 type_aux; /* Interleave for interleaved Planes */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync /* (physical address) */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync __u16 reserved[3]; /* Reserved for future compatibility */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync/* Interpretation of offset for color fields: All offsets are from the right,
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync * inside a "pixel" value, which is exactly 'bits_per_pixel' wide (means: you
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync * can use the offset as right argument to <<). A pixel afterwards is a bit
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync * stream and is written to video memory as that unmodified. This implies
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync * big-endian byte order if bits_per_pixel is greater than 8.
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync __u32 msb_right; /* != 0 : Most significant bit is */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync /* right */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_ACTIVATE_NOW 0 /* set values immediately (or vbl)*/
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_ACTIVATE_NXTOPEN 1 /* activate on next open */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_ACTIVATE_TEST 2 /* don't set, round up impossible */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync /* values */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_ACTIVATE_VBL 16 /* activate values on next vbl */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_CHANGE_CMAP_VBL 32 /* change colormap on vbl */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_ACTIVATE_ALL 64 /* change all VCs on this fb */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_ACCELF_TEXT 1 /* text mode acceleration */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_SYNC_HOR_HIGH_ACT 1 /* horizontal sync high active */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_SYNC_VERT_HIGH_ACT 2 /* vertical sync high active */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_SYNC_COMP_HIGH_ACT 8 /* composite sync high active */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_SYNC_BROADCAST 16 /* broadcast video timings */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync /* vtotal = 144d/288n/576i => PAL */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync /* vtotal = 121d/242n/484i => NTSC */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_VMODE_NONINTERLACED 0 /* non interlaced */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_VMODE_YWRAP 256 /* ywrap instead of panning */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_VMODE_SMOOTH_XPAN 512 /* smooth xpan possible (internally used) */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define FB_VMODE_CONUPDATE 512 /* don't update x/yoffset */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync __u32 xoffset; /* offset from virtual to visible */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync __u32 grayscale; /* != 0 Graylevels instead of colors */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync struct fb_bitfield red; /* bitfield in fb mem if true color, */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync struct fb_bitfield green; /* else only length is significant */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync __u32 accel_flags; /* acceleration flags (hints) */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync /* Timing: All values in pixclocks, except pixclock (of course) */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync __u32 pixclock; /* pixel clock in ps (pico seconds) */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync __u32 right_margin; /* time from picture to sync */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync __u32 upper_margin; /* time from sync to picture */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync __u32 reserved[6]; /* Reserved for future compatibility */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync * Hardware Cursor
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync __u16 crsr_width; /* width and height of the cursor in */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync __u16 crsr_height; /* pixels (zero if no cursor) */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync __u16 crsr_xsize; /* cursor size in display pixels */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync __u16 crsr_color1; /* colormap entry for cursor color1 */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync __u16 crsr_color2; /* colormap entry for cursor color2 */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#endif /* Preliminary */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#endif /* _LINUX_FB_H */