1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
|
#ifndef vbe_h_included
#define vbe_h_included
#include "vgabios.h"
// DISPI helper function
void dispi_set_enable(enable);
/** VBE int10 API
*
* See the function descriptions in vbe.c for more information
*/
Boolean vbe_has_vbe_display();
void vbe_biosfn_return_controller_information(AX, ES, DI);
void vbe_biosfn_return_mode_information(AX, CX, ES, DI);
void vbe_biosfn_set_mode(AX, BX, ES, DI);
void vbe_biosfn_save_restore_state(AX, CX, DX, ES, BX);
void vbe_biosfn_set_get_palette_data(AX);
void vbe_biosfn_return_protected_mode_interface(AX);
// The official VBE Information Block
typedef struct VbeInfoBlock
{
Bit8u VbeSignature[4];
Bit16u VbeVersion;
Bit16u OemStringPtr_Off;
Bit16u OemStringPtr_Seg;
Bit8u Capabilities[4];
Bit16u VideoModePtr_Off;
Bit16u VideoModePtr_Seg;
Bit16u TotalMemory;
Bit16u OemSoftwareRev;
Bit16u OemVendorNamePtr_Off;
Bit16u OemVendorNamePtr_Seg;
Bit16u OemProductNamePtr_Off;
Bit16u OemProductNamePtr_Seg;
Bit16u OemProductRevPtr_Off;
Bit16u OemProductRevPtr_Seg;
Bit16u Reserved[111]; // used for dynamicly generated mode list
Bit8u OemData[256];
} VbeInfoBlock;
// This one is for compactly storing a static list of mode info blocks
// this saves us 189 bytes per block
typedef struct ModeInfoBlockCompact
{
// Mandatory information for all VBE revisions
Bit16u ModeAttributes;
Bit8u WinAAttributes;
Bit8u WinBAttributes;
Bit16u WinGranularity;
Bit16u WinSize;
Bit16u WinASegment;
Bit16u WinBSegment;
Bit32u WinFuncPtr;
Bit16u BytesPerScanLine;
// Mandatory information for VBE 1.2 and above
Bit16u XResolution;
Bit16u YResolution;
Bit8u XCharSize;
Bit8u YCharSize;
Bit8u NumberOfPlanes;
Bit8u BitsPerPixel;
Bit8u NumberOfBanks;
Bit8u MemoryModel;
Bit8u BankSize;
Bit8u NumberOfImagePages;
Bit8u Reserved_page;
// Direct Color fields (required for direct/6 and YUV/7 memory models)
Bit8u RedMaskSize;
Bit8u RedFieldPosition;
Bit8u GreenMaskSize;
Bit8u GreenFieldPosition;
Bit8u BlueMaskSize;
Bit8u BlueFieldPosition;
Bit8u RsvdMaskSize;
Bit8u RsvdFieldPosition;
Bit8u DirectColorModeInfo;
// Mandatory information for VBE 2.0 and above
Bit32u PhysBasePtr;
Bit32u OffScreenMemOffset;
Bit16u OffScreenMemSize;
// Mandatory information for VBE 3.0 and above
Bit16u LinBytesPerScanLine;
Bit8u BnkNumberOfPages;
Bit8u LinNumberOfPages;
Bit8u LinRedMaskSize;
Bit8u LinRedFieldPosition;
Bit8u LinGreenMaskSize;
Bit8u LinGreenFieldPosition;
Bit8u LinBlueMaskSize;
Bit8u LinBlueFieldPosition;
Bit8u LinRsvdMaskSize;
Bit8u LinRsvdFieldPosition;
Bit32u MaxPixelClock;
// Bit8u Reserved[189]; // DO NOT PUT THIS IN HERE because of Compact Mode Info storage in bios
} ModeInfoBlockCompact;
typedef struct ModeInfoBlock
{
// Mandatory information for all VBE revisions
Bit16u ModeAttributes;
Bit8u WinAAttributes;
Bit8u WinBAttributes;
Bit16u WinGranularity;
Bit16u WinSize;
Bit16u WinASegment;
Bit16u WinBSegment;
Bit32u WinFuncPtr;
Bit16u BytesPerScanLine;
// Mandatory information for VBE 1.2 and above
Bit16u XResolution;
Bit16u YResolution;
Bit8u XCharSize;
Bit8u YCharSize;
Bit8u NumberOfPlanes;
Bit8u BitsPerPixel;
Bit8u NumberOfBanks;
Bit8u MemoryModel;
Bit8u BankSize;
Bit8u NumberOfImagePages;
Bit8u Reserved_page;
// Direct Color fields (required for direct/6 and YUV/7 memory models)
Bit8u RedMaskSize;
Bit8u RedFieldPosition;
Bit8u GreenMaskSize;
Bit8u GreenFieldPosition;
Bit8u BlueMaskSize;
Bit8u BlueFieldPosition;
Bit8u RsvdMaskSize;
Bit8u RsvdFieldPosition;
Bit8u DirectColorModeInfo;
// Mandatory information for VBE 2.0 and above
Bit32u PhysBasePtr;
Bit32u OffScreenMemOffset;
Bit16u OffScreenMemSize;
// Mandatory information for VBE 3.0 and above
Bit16u LinBytesPerScanLine;
Bit8u BnkNumberOfPages;
Bit8u LinNumberOfPages;
Bit8u LinRedMaskSize;
Bit8u LinRedFieldPosition;
Bit8u LinGreenMaskSize;
Bit8u LinGreenFieldPosition;
Bit8u LinBlueMaskSize;
Bit8u LinBlueFieldPosition;
Bit8u LinRsvdMaskSize;
Bit8u LinRsvdFieldPosition;
Bit32u MaxPixelClock;
Bit8u Reserved[189];
} ModeInfoBlock;
typedef struct ModeInfoListItem
{
Bit16u mode;
ModeInfoBlockCompact info;
} ModeInfoListItem;
// VBE Return Status Info
// AL
#define VBE_RETURN_STATUS_SUPPORTED 0x4F
#define VBE_RETURN_STATUS_UNSUPPORTED 0x00
// AH
#define VBE_RETURN_STATUS_SUCCESSFULL 0x00
#define VBE_RETURN_STATUS_FAILED 0x01
#define VBE_RETURN_STATUS_NOT_SUPPORTED 0x02
#define VBE_RETURN_STATUS_INVALID 0x03
// VBE Mode Numbers
#define VBE_MODE_VESA_DEFINED 0x0100
#define VBE_MODE_REFRESH_RATE_USE_CRTC 0x0800
#define VBE_MODE_LINEAR_FRAME_BUFFER 0x4000
#define VBE_MODE_PRESERVE_DISPLAY_MEMORY 0x8000
// VBE GFX Mode Number
#define VBE_VESA_MODE_640X400X8 0x100
#define VBE_VESA_MODE_640X480X8 0x101
#define VBE_VESA_MODE_800X600X4 0x102
#define VBE_VESA_MODE_800X600X8 0x103
#define VBE_VESA_MODE_1024X768X4 0x104
#define VBE_VESA_MODE_1024X768X8 0x105
#define VBE_VESA_MODE_1280X1024X4 0x106
#define VBE_VESA_MODE_1280X1024X8 0x107
#define VBE_VESA_MODE_320X200X1555 0x10D
#define VBE_VESA_MODE_320X200X565 0x10E
#define VBE_VESA_MODE_320X200X888 0x10F
#define VBE_VESA_MODE_640X480X1555 0x110
#define VBE_VESA_MODE_640X480X565 0x111
#define VBE_VESA_MODE_640X480X888 0x112
#define VBE_VESA_MODE_800X600X1555 0x113
#define VBE_VESA_MODE_800X600X565 0x114
#define VBE_VESA_MODE_800X600X888 0x115
#define VBE_VESA_MODE_1024X768X1555 0x116
#define VBE_VESA_MODE_1024X768X565 0x117
#define VBE_VESA_MODE_1024X768X888 0x118
#define VBE_VESA_MODE_1280X1024X1555 0x119
#define VBE_VESA_MODE_1280X1024X565 0x11A
#define VBE_VESA_MODE_1280X1024X888 0x11B
#define VBE_VESA_MODE_1600X1200X8 0x11C
#define VBE_VESA_MODE_1600X1200X1555 0x11D
#define VBE_VESA_MODE_1600X1200X565 0x11E
#define VBE_VESA_MODE_1600X1200X888 0x11F
// BOCHS/PLEX86 'own' mode numbers
#define VBE_OWN_MODE_320X200X8888 0x140
#define VBE_OWN_MODE_640X400X8888 0x141
#define VBE_OWN_MODE_640X480X8888 0x142
#define VBE_OWN_MODE_800X600X8888 0x143
#define VBE_OWN_MODE_1024X768X8888 0x144
#define VBE_OWN_MODE_1280X1024X8888 0x145
#define VBE_OWN_MODE_320X200X8 0x146
#define VBE_OWN_MODE_1600X1200X8888 0x147
#define VBE_OWN_MODE_1152X864X8 0x148
#define VBE_OWN_MODE_1152X864X1555 0x149
#define VBE_OWN_MODE_1152X864X565 0x14a
#define VBE_OWN_MODE_1152X864X888 0x14b
#define VBE_OWN_MODE_1152X864X8888 0x14c
#define VBE_VESA_MODE_END_OF_LIST 0xFFFF
// Capabilities
#define VBE_CAPABILITY_8BIT_DAC 0x0001
#define VBE_CAPABILITY_NOT_VGA_COMPATIBLE 0x0002
#define VBE_CAPABILITY_RAMDAC_USE_BLANK_BIT 0x0004
#define VBE_CAPABILITY_STEREOSCOPIC_SUPPORT 0x0008
#define VBE_CAPABILITY_STEREO_VIA_VESA_EVC 0x0010
// Mode Attributes
#define VBE_MODE_ATTRIBUTE_SUPPORTED 0x0001
#define VBE_MODE_ATTRIBUTE_EXTENDED_INFORMATION_AVAILABLE 0x0002
#define VBE_MODE_ATTRIBUTE_TTY_BIOS_SUPPORT 0x0004
#define VBE_MODE_ATTRIBUTE_COLOR_MODE 0x0008
#define VBE_MODE_ATTRIBUTE_GRAPHICS_MODE 0x0010
#define VBE_MODE_ATTRIBUTE_NOT_VGA_COMPATIBLE 0x0020
#define VBE_MODE_ATTRIBUTE_NO_VGA_COMPATIBLE_WINDOW 0x0040
#define VBE_MODE_ATTRIBUTE_LINEAR_FRAME_BUFFER_MODE 0x0080
#define VBE_MODE_ATTRIBUTE_DOUBLE_SCAN_MODE 0x0100
#define VBE_MODE_ATTRIBUTE_INTERLACE_MODE 0x0200
#define VBE_MODE_ATTRIBUTE_HARDWARE_TRIPLE_BUFFER 0x0400
#define VBE_MODE_ATTRIBUTE_HARDWARE_STEREOSCOPIC_DISPLAY 0x0800
#define VBE_MODE_ATTRIBUTE_DUAL_DISPLAY_START_ADDRESS 0x1000
#define VBE_MODE_ATTTRIBUTE_LFB_ONLY ( VBE_MODE_ATTRIBUTE_NO_VGA_COMPATIBLE_WINDOW | VBE_MODE_ATTRIBUTE_LINEAR_FRAME_BUFFER_MODE )
// Window attributes
#define VBE_WINDOW_ATTRIBUTE_RELOCATABLE 0x01
#define VBE_WINDOW_ATTRIBUTE_READABLE 0x02
#define VBE_WINDOW_ATTRIBUTE_WRITEABLE 0x04
// Memory model
#define VBE_MEMORYMODEL_TEXT_MODE 0x00
#define VBE_MEMORYMODEL_CGA_GRAPHICS 0x01
#define VBE_MEMORYMODEL_HERCULES_GRAPHICS 0x02
#define VBE_MEMORYMODEL_PLANAR 0x03
#define VBE_MEMORYMODEL_PACKED_PIXEL 0x04
#define VBE_MEMORYMODEL_NON_CHAIN_4_256 0x05
#define VBE_MEMORYMODEL_DIRECT_COLOR 0x06
#define VBE_MEMORYMODEL_YUV 0x07
// DirectColorModeInfo
#define VBE_DIRECTCOLOR_COLOR_RAMP_PROGRAMMABLE 0x01
#define VBE_DIRECTCOLOR_RESERVED_BITS_AVAILABLE 0x02
// GUEST <-> HOST Communication API
// FIXME: either dynamicly ask host for this or put somewhere high in physical memory
// like 0xE0000000
#define VBE_DISPI_BANK_ADDRESS 0xA0000
#define VBE_DISPI_BANK_SIZE_KB 64
#define VBE_DISPI_MAX_XRES 2560
#define VBE_DISPI_MAX_YRES 1600
#define VBE_DISPI_IOPORT_INDEX 0x01CE
#define VBE_DISPI_IOPORT_DATA 0x01CF
#define VBE_DISPI_INDEX_ID 0x0
#define VBE_DISPI_INDEX_XRES 0x1
#define VBE_DISPI_INDEX_YRES 0x2
#define VBE_DISPI_INDEX_BPP 0x3
#define VBE_DISPI_INDEX_ENABLE 0x4
#define VBE_DISPI_INDEX_BANK 0x5
#define VBE_DISPI_INDEX_VIRT_WIDTH 0x6
#define VBE_DISPI_INDEX_VIRT_HEIGHT 0x7
#define VBE_DISPI_INDEX_X_OFFSET 0x8
#define VBE_DISPI_INDEX_Y_OFFSET 0x9
#define VBE_DISPI_INDEX_VIDEO_MEMORY_64K 0xa
#define VBE_DISPI_ID0 0xB0C0
#define VBE_DISPI_ID1 0xB0C1
#define VBE_DISPI_ID2 0xB0C2
#define VBE_DISPI_ID3 0xB0C3
#define VBE_DISPI_ID4 0xB0C4
#define VBE_DISPI_ID5 0xB0C5
#define VBE_DISPI_DISABLED 0x00
#define VBE_DISPI_ENABLED 0x01
#define VBE_DISPI_GETCAPS 0x02
#define VBE_DISPI_8BIT_DAC 0x20
#define VBE_DISPI_LFB_ENABLED 0x40
#define VBE_DISPI_NOCLEARMEM 0x80
#define VBE_DISPI_LFB_PHYSICAL_ADDRESS 0xE0000000
#endif
|