xref: /freebsd/stand/i386/libi386/vbe.h (revision 82397d791966b09d344251bc709cd9db2b3a1902)
1 /*-
2  * Copyright (c) 2009 Jared D. McNeill <jmcneill@invisible.ca>
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions
7  * are met:
8  * 1. Redistributions of source code must retain the above copyright
9  *    notice, this list of conditions and the following disclaimer.
10  * 2. Redistributions in binary form must reproduce the above copyright
11  *    notice, this list of conditions and the following disclaimer in the
12  *    documentation and/or other materials provided with the distribution.
13  *
14  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
15  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
16  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
17  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
18  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
19  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
20  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
21  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
22  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
23  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
24  * POSSIBILITY OF SUCH DAMAGE.
25  */
26 
27 /*
28  * Default mode for VESA frame buffer.
29  * This mode is selected when there is no EDID inormation and
30  * mode is not provided by user.
31  * To provide consistent look with UEFI GOP, we use 800x600 here,
32  * and if this mode is not available, we fall back to text mode and
33  * VESA disabled.
34  */
35 
36 #define VBE_DEFAULT_MODE	"800x600"
37 
38 struct vbeinfoblock {
39 	char VbeSignature[4];
40 	uint16_t VbeVersion;
41 	uint32_t OemStringPtr;
42 	uint32_t Capabilities;
43 #define	VBE_CAP_DAC8	(1 << 0)	/* Can switch DAC */
44 #define	VBE_CAP_NONVGA	(1 << 1)	/* Controller is not VGA comp. */
45 #define	VBE_CAP_SNOW	(1 << 2)	/* Set data during Vertical Reterace */
46 	uint32_t VideoModePtr;
47 	uint16_t TotalMemory;
48 	uint16_t OemSoftwareRev;
49 	uint32_t OemVendorNamePtr, OemProductNamePtr, OemProductRevPtr;
50 	/* data area, in total max 512 bytes for VBE 2.0 */
51 	uint8_t Reserved[222];
52 	uint8_t OemData[256];
53 } __packed;
54 
55 struct modeinfoblock {
56 	/* Mandatory information for all VBE revisions */
57 	uint16_t ModeAttributes;
58 	uint8_t WinAAttributes, WinBAttributes;
59 	uint16_t WinGranularity, WinSize, WinASegment, WinBSegment;
60 	uint32_t WinFuncPtr;
61 	uint16_t BytesPerScanLine;
62 	/* Mandatory information for VBE 1.2 and above */
63 	uint16_t XResolution, YResolution;
64 	uint8_t XCharSize, YCharSize, NumberOfPlanes, BitsPerPixel;
65 	uint8_t NumberOfBanks, MemoryModel, BankSize, NumberOfImagePages;
66 	uint8_t Reserved1;
67 	/* Direct Color fields
68 	   (required for direct/6 and YUV/7 memory models) */
69 	uint8_t RedMaskSize, RedFieldPosition;
70 	uint8_t GreenMaskSize, GreenFieldPosition;
71 	uint8_t BlueMaskSize, BlueFieldPosition;
72 	uint8_t RsvdMaskSize, RsvdFieldPosition;
73 	uint8_t DirectColorModeInfo;
74 	/* Mandatory information for VBE 2.0 and above */
75 	uint32_t PhysBasePtr;
76 	uint32_t OffScreenMemOffset;	/* reserved in VBE 3.0 and above */
77 	uint16_t OffScreenMemSize;	/* reserved in VBE 3.0 and above */
78 
79 	/* Mandatory information for VBE 3.0 and above */
80 	uint16_t LinBytesPerScanLine;
81 	uint8_t BnkNumberOfImagePages;
82 	uint8_t LinNumberOfImagePages;
83 	uint8_t LinRedMaskSize, LinRedFieldPosition;
84 	uint8_t LinGreenMaskSize, LinGreenFieldPosition;
85 	uint8_t LinBlueMaskSize, LinBlueFieldPosition;
86 	uint8_t LinRsvdMaskSize, LinRsvdFieldPosition;
87 	uint32_t MaxPixelClock;
88 	/* + 1 will fix the size to 256 bytes */
89 	uint8_t Reserved4[189 + 1];
90 } __packed;
91 
92 struct crtciinfoblock {
93 	uint16_t HorizontalTotal;
94 	uint16_t HorizontalSyncStart;
95 	uint16_t HorizontalSyncEnd;
96 	uint16_t VerticalTotal;
97 	uint16_t VerticalSyncStart;
98 	uint16_t VerticalSyncEnd;
99 	uint8_t Flags;
100 	uint32_t PixelClock;
101 	uint16_t RefreshRate;
102 	uint8_t Reserved[40];
103 } __packed;
104 
105 struct paletteentry {
106 	uint8_t Blue;
107 	uint8_t Green;
108 	uint8_t Red;
109 	uint8_t Reserved;
110 } __packed;
111 
112 struct flatpanelinfo
113 {
114 	uint16_t HorizontalSize;
115 	uint16_t VerticalSize;
116 	uint16_t PanelType;
117 	uint8_t RedBPP;
118 	uint8_t GreenBPP;
119 	uint8_t BlueBPP;
120 	uint8_t ReservedBPP;
121 	uint32_t ReservedOffScreenMemSize;
122 	uint32_t ReservedOffScreenMemPtr;
123 
124 	uint8_t Reserved[14];
125 } __packed;
126 
127 #define	VBE_BASE_MODE		(0x100)		/* VBE 3.0 page 18 */
128 #define	VBE_VALID_MODE(a)	((a) >= VBE_BASE_MODE)
129 #define	VBE_ERROR(a)		(((a) & 0xFF) != 0x4F || ((a) & 0xFF00) != 0)
130 #define	VBE_SUCCESS		(0x004F)
131 #define	VBE_FAILED		(0x014F)
132 #define	VBE_NOTSUP		(0x024F)
133 #define	VBE_INVALID		(0x034F)
134 
135 #define	VGA_TEXT_MODE		(3)		/* 80x25 text mode */
136 #define	TEXT_ROWS		(25)		/* VGATEXT rows */
137 #define	TEXT_COLS		(80)		/* VGATEXT columns */
138 
139 extern struct paletteentry *pe8;
140 extern int palette_format;
141 
142 int vga_get_reg(int, int);
143 int vga_get_atr(int, int);
144 void vga_set_atr(int, int, int);
145 void vga_set_indexed(int, int, int, uint8_t, uint8_t);
146 int vga_get_indexed(int, int, int, uint8_t);
147 int vga_get_crtc(int, int);
148 void vga_set_crtc(int, int, int);
149 int vga_get_seq(int, int);
150 void vga_set_seq(int, int, int);
151 int vga_get_grc(int, int);
152 void vga_set_grc(int, int, int);
153 
154 /* high-level VBE helpers, from vbe.c */
155 void bios_set_text_mode(int);
156 int biosvbe_palette_format(int *);
157 void vbe_init(void);
158 bool vbe_available(void);
159 int vbe_default_mode(void);
160 int vbe_set_mode(int);
161 int vbe_get_mode(void);
162 int vbe_set_palette(const struct paletteentry *, size_t);
163 void vbe_modelist(int);
164