iPXE
vga.h
Go to the documentation of this file.
1 /*
2  *
3  * modified
4  * by Steve M. Gehlbach <steve@kesa.com>
5  *
6  * Originally from linux/drivers/video/vga16.c by
7  * Ben Pfaff <pfaffben@debian.org> and Petr Vandrovec <VANDROVE@vc.cvut.cz>
8  * Copyright 1999 Ben Pfaff <pfaffben@debian.org> and Petr Vandrovec <VANDROVE@vc.cvut.cz>
9  * Based on VGA info at http://www.goodnet.com/~tinara/FreeVGA/home.htm
10  * Based on VESA framebuffer (c) 1998 Gerd Knorr <kraxel@goldbach.in-berlin.de>
11  *
12  */
13 
14 #ifndef VGA_H_INCL
15 #define VGA_H_INCL 1
16 
17 //#include <cpu/p5/io.h>
18 
19 #define u8 unsigned char
20 #define u16 unsigned short
21 #define u32 unsigned int
22 #define __u32 u32
23 
24 #define VERROR -1
25 #define CHAR_HEIGHT 16
26 #define LINES 25
27 #define COLS 80
28 
29 // macros for writing to vga regs
30 #define write_crtc(data,addr) outb(addr,CRT_IC); outb(data,CRT_DC)
31 #define write_att(data,addr) inb(IS1_RC); inb(0x80); outb(addr,ATT_IW); inb(0x80); outb(data,ATT_IW); inb(0x80)
32 #define write_seq(data,addr) outb(addr,SEQ_I); outb(data,SEQ_D)
33 #define write_gra(data,addr) outb(addr,GRA_I); outb(data,GRA_D)
38 
39 
40 #ifdef VGA_HARDWARE_FIXUP
41 void vga_hardware_fixup(void);
42 #else
43 #define vga_hardware_fixup() do{} while(0)
44 #endif
45 
46 #define SYNC_HOR_HIGH_ACT 1 /* horizontal sync high active */
47 #define SYNC_VERT_HIGH_ACT 2 /* vertical sync high active */
48 #define SYNC_EXT 4 /* external sync */
49 #define SYNC_COMP_HIGH_ACT 8 /* composite sync high active */
50 #define SYNC_BROADCAST 16 /* broadcast video timings */
51  /* vtotal = 144d/288n/576i => PAL */
52  /* vtotal = 121d/242n/484i => NTSC */
53 
54 #define SYNC_ON_GREEN 32 /* sync on green */
55 
56 #define VMODE_NONINTERLACED 0 /* non interlaced */
57 #define VMODE_INTERLACED 1 /* interlaced */
58 #define VMODE_DOUBLE 2 /* double scan */
59 #define VMODE_MASK 255
60 
61 #define VMODE_YWRAP 256 /* ywrap instead of panning */
62 #define VMODE_SMOOTH_XPAN 512 /* smooth xpan possible (internally used) */
63 #define VMODE_CONUPDATE 512 /* don't update x/yoffset */
64 
65 /* VGA data register ports */
66 #define CRT_DC 0x3D5 /* CRT Controller Data Register - color emulation */
67 #define CRT_DM 0x3B5 /* CRT Controller Data Register - mono emulation */
68 #define ATT_R 0x3C1 /* Attribute Controller Data Read Register */
69 #define GRA_D 0x3CF /* Graphics Controller Data Register */
70 #define SEQ_D 0x3C5 /* Sequencer Data Register */
71 
72 #define MIS_R 0x3CC // Misc Output Read Register
73 #define MIS_W 0x3C2 // Misc Output Write Register
74 
75 #define IS1_RC 0x3DA /* Input Status Register 1 - color emulation */
76 #define IS1_RM 0x3BA /* Input Status Register 1 - mono emulation */
77 #define PEL_D 0x3C9 /* PEL Data Register */
78 #define PEL_MSK 0x3C6 /* PEL mask register */
79 
80 /* EGA-specific registers */
81 #define GRA_E0 0x3CC /* Graphics enable processor 0 */
82 #define GRA_E1 0x3CA /* Graphics enable processor 1 */
83 
84 
85 /* VGA index register ports */
86 #define CRT_IC 0x3D4 /* CRT Controller Index - color emulation */
87 #define CRT_IM 0x3B4 /* CRT Controller Index - mono emulation */
88 #define ATT_IW 0x3C0 /* Attribute Controller Index & Data Write Register */
89 #define GRA_I 0x3CE /* Graphics Controller Index */
90 #define SEQ_I 0x3C4 /* Sequencer Index */
91 #define PEL_IW 0x3C8 /* PEL Write Index */
92 #define PEL_IR 0x3C7 /* PEL Read Index */
93 
94 /* standard VGA indexes max counts */
95 #define CRTC_C 25 /* 25 CRT Controller Registers sequentially set*/
96  // the remainder are not in the par array
97 #define ATT_C 21 /* 21 Attribute Controller Registers */
98 #define GRA_C 9 /* 9 Graphics Controller Registers */
99 #define SEQ_C 5 /* 5 Sequencer Registers */
100 #define MIS_C 1 /* 1 Misc Output Register */
101 
102 #define CRTC_H_TOTAL 0
103 #define CRTC_H_DISP 1
104 #define CRTC_H_BLANK_START 2
105 #define CRTC_H_BLANK_END 3
106 #define CRTC_H_SYNC_START 4
107 #define CRTC_H_SYNC_END 5
108 #define CRTC_V_TOTAL 6
109 #define CRTC_OVERFLOW 7
110 #define CRTC_PRESET_ROW 8
111 #define CRTC_MAX_SCAN 9
112 #define CRTC_CURSOR_START 0x0A
113 #define CRTC_CURSOR_END 0x0B
114 #define CRTC_START_HI 0x0C
115 #define CRTC_START_LO 0x0D
116 #define CRTC_CURSOR_HI 0x0E
117 #define CRTC_CURSOR_LO 0x0F
118 #define CRTC_V_SYNC_START 0x10
119 #define CRTC_V_SYNC_END 0x11
120 #define CRTC_V_DISP_END 0x12
121 #define CRTC_OFFSET 0x13
122 #define CRTC_UNDERLINE 0x14
123 #define CRTC_V_BLANK_START 0x15
124 #define CRTC_V_BLANK_END 0x16
125 #define CRTC_MODE 0x17
126 #define CRTC_LINE_COMPARE 0x18
127 
128 #define ATC_MODE 0x10
129 #define ATC_OVERSCAN 0x11
130 #define ATC_PLANE_ENABLE 0x12
131 #define ATC_PEL 0x13
132 #define ATC_COLOR_PAGE 0x14
133 
134 #define SEQ_CLOCK_MODE 0x01
135 #define SEQ_PLANE_WRITE 0x02
136 #define SEQ_CHARACTER_MAP 0x03
137 #define SEQ_MEMORY_MODE 0x04
138 
139 #define GDC_SR_VALUE 0x00
140 #define GDC_SR_ENABLE 0x01
141 #define GDC_COMPARE_VALUE 0x02
142 #define GDC_DATA_ROTATE 0x03
143 #define GDC_PLANE_READ 0x04
144 #define GDC_MODE 0x05
145 #define GDC_MISC 0x06
146 #define GDC_COMPARE_MASK 0x07
147 #define GDC_BIT_MASK 0x08
148 
149 // text attributes
150 #define VGA_ATTR_CLR_RED 0x4
151 #define VGA_ATTR_CLR_GRN 0x2
152 #define VGA_ATTR_CLR_BLU 0x1
153 #define VGA_ATTR_CLR_YEL (VGA_ATTR_CLR_RED | VGA_ATTR_CLR_GRN)
154 #define VGA_ATTR_CLR_CYN (VGA_ATTR_CLR_GRN | VGA_ATTR_CLR_BLU)
155 #define VGA_ATTR_CLR_MAG (VGA_ATTR_CLR_BLU | VGA_ATTR_CLR_RED)
156 #define VGA_ATTR_CLR_BLK 0
157 #define VGA_ATTR_CLR_WHT (VGA_ATTR_CLR_RED | VGA_ATTR_CLR_GRN | VGA_ATTR_CLR_BLU)
158 #define VGA_ATTR_BNK 0x80
159 #define VGA_ATTR_ITN 0x08
160 
161 /*
162  * vga register parameters
163  * these are copied to the
164  * registers.
165  *
166  */
167 struct vga_par {
172  u8 misc; // the misc register, MIS_W
174 };
175 
176 
177 /* Interpretation of offset for color fields: All offsets are from the right,
178  * inside a "pixel" value, which is exactly 'bits_per_pixel' wide (means: you
179  * can use the offset as right argument to <<). A pixel afterwards is a bit
180  * stream and is written to video memory as that unmodified. This implies
181  * big-endian byte order if bits_per_pixel is greater than 8.
182  */
183 struct fb_bitfield {
184  __u32 offset; /* beginning of bitfield */
185  __u32 length; /* length of bitfield */
186  __u32 msb_right; /* != 0 : Most significant bit is */
187  /* right */
188 };
189 
190 struct screeninfo {
191  __u32 xres; /* visible resolution */
193  __u32 xres_virtual; /* virtual resolution */
195  __u32 xoffset; /* offset from virtual to visible */
196  __u32 yoffset; /* resolution */
197 
198  __u32 bits_per_pixel; /* guess what */
199  __u32 grayscale; /* != 0 Graylevels instead of colors */
200 
201  struct fb_bitfield red; /* bitfield in fb mem if true color, */
202  struct fb_bitfield green; /* else only length is significant */
204  struct fb_bitfield transp; /* transparency */
205 
206  __u32 nonstd; /* != 0 Non standard pixel format */
207 
208  __u32 activate; /* see FB_ACTIVATE_* */
209 
210  __u32 height; /* height of picture in mm */
211  __u32 width; /* width of picture in mm */
212 
213  __u32 accel_flags; /* acceleration flags (hints) */
214 
215  /* Timing: All values in pixclocks, except pixclock (of course) */
216  __u32 pixclock; /* pixel clock in ps (pico seconds) */
217  __u32 left_margin; /* time from sync to picture */
218  __u32 right_margin; /* time from picture to sync */
219  __u32 upper_margin; /* time from sync to picture */
221  __u32 hsync_len; /* length of horizontal sync */
222  __u32 vsync_len; /* length of vertical sync */
223  __u32 sync; /* sync polarity */
224  __u32 vmode; /* interlaced etc */
225  __u32 reserved[6]; /* Reserved for future compatibility */
226 };
227 
228 #endif
uint16_t u16
Definition: stdint.h:21
__u32 right_margin
Definition: vga.h:218
__u32 upper_margin
Definition: vga.h:219
u8 atc[ATT_C]
Definition: vga.h:169
__u32 msb_right
Definition: vga.h:186
u8 read_att_b(u16 addr)
__u32 left_margin
Definition: vga.h:217
u8 gdc[GRA_C]
Definition: vga.h:170
__u32 yres_virtual
Definition: vga.h:194
__u32 yoffset
Definition: vga.h:196
#define GRA_C
Definition: vga.h:98
__u32 length
Definition: vga.h:185
__u32 xres_virtual
Definition: vga.h:193
#define vga_hardware_fixup()
Definition: vga.h:43
struct fb_bitfield transp
Definition: vga.h:204
struct fb_bitfield green
Definition: vga.h:202
__u32 vmode
Definition: vga.h:224
u8 read_gra_b(u16 addr)
#define __u32
Definition: vga.h:22
u8 read_seq_b(u16 addr)
__u32 bits_per_pixel
Definition: vga.h:198
u8 vss
Definition: vga.h:173
__u32 lower_margin
Definition: vga.h:220
struct fb_bitfield red
Definition: vga.h:201
__u32 vsync_len
Definition: vga.h:222
u8 crtc[CRTC_C]
Definition: vga.h:168
__u32 sync
Definition: vga.h:223
__u32 xoffset
Definition: vga.h:195
#define CRTC_C
Definition: vga.h:95
struct fb_bitfield blue
Definition: vga.h:203
__u32 height
Definition: vga.h:210
__u32 yres
Definition: vga.h:192
__u32 nonstd
Definition: vga.h:206
__u32 offset
Definition: vga.h:184
__u32 xres
Definition: vga.h:191
__u32 grayscale
Definition: vga.h:199
u32 addr
Definition: sky2.h:8
__u32 accel_flags
Definition: vga.h:213
u8 read_crtc_b(u16 addr)
__u32 activate
Definition: vga.h:208
#define SEQ_C
Definition: vga.h:99
__u32 hsync_len
Definition: vga.h:221
__u32 width
Definition: vga.h:211
__u32 pixclock
Definition: vga.h:216
uint8_t u8
Definition: stdint.h:19
u8 misc
Definition: vga.h:172
#define ATT_C
Definition: vga.h:97
Definition: vga.h:167
u8 seq[SEQ_C]
Definition: vga.h:171
__u32 reserved[6]
Definition: vga.h:225