Print this page
NEX-16819 loader UEFI support
Includes work by Toomas Soome <tsoome@me.com>
Upstream commits:
loader: pxe receive cleanup
9475 libefi: Do not return only if ReceiveFilter
installboot: should support efi system partition
8931 boot1.efi: scan all display modes rather than
loader: spinconsole updates
loader: gfx experiment to try GOP Blt() function.
sha1 build test
loader: add sha1 hash calculation
common/sha1: update for loader build
loader: biosdisk rework
uts: 32-bit kernel FB needs mapping in low memory
uts: add diag-device
uts: boot console mirror with diag-device
uts: enable very early console on ttya
kmdb: add diag-device as input/output device
uts: test VGA memory exclusion from mapping
uts: clear boot mapping and protect boot pages test
uts: add dboot map debug printf
uts: need to release FB pages in release_bootstrap()
uts: add screenmap ioctl
uts: update sys/queue.h
loader: add illumos uts/common to include path
loader: tem/gfx font cleanup
loader: vbe checks
uts: gfx_private set KD_TEXT when KD_RESETTEXT is
uts: gfx 8-bit update
loader: gfx 8-bit fix
loader: always set media size from partition.
uts: MB2 support for 32-bit kernel
loader: x86 should have tem 80x25
uts: x86 should have tem 80x25
uts: font update
loader: font update
uts: tem attributes
loader: tem.c comment added
uts: use font module
loader: add font module
loader: build rules for new font setup
uts: gfx_private update for new font structure
uts: early boot update for new font structure
uts: font update
uts: font build rules update for new fonts
uts: tem update to new font structure
loader: module.c needs to include tem_impl.h
uts: gfx_private 8x16 font rework
uts: make font_lookup public
loader: font rework
uts: font rework
9259 libefi: efi_alloc_and_read should check for PMBR
uts: tem utf-8 support
loader: implement tem utf-8 support
loader: tem should be able to display UTF-8
7784 uts: console input should support utf-8
7796 uts: ldterm default to utf-8
uts: do not reset serial console
uts: set up colors even if tem is not console
uts: add type for early boot properties
uts: gfx_private experiment with drm and vga
uts: gfx_private should use setmode drm callback.
uts: identify FB types and set up gfx_private based
loader: replace gop and vesa with framebuffer
uts: boot needs simple tem to support mdb
uts: boot_keyboard should emit esc sequences for
uts: gfx_private FB showuld be written by line
kmdb: set terminal window size
uts: gfx_private needs to keep track of early boot FB
pnglite: move pnglite to usr/src/common
loader: gfx_fb
ficl-sys: add gfx primitives
loader: add illumos.png logo
ficl: add fb-putimage
loader: add png support
loader: add alpha blending for gfx_fb
loader: use term-drawrect for menu frame
ficl: add simple gfx words
uts: provide fb_info via fbgattr dev_specific array.
uts: gfx_private add alpha blending
uts: update sys/ascii.h
uts: tem OSC support (incomplete)
uts: implement env module support and use data from
uts: tem get colors from early boot data
loader: use crc32 from libstand (libz)
loader: optimize for size
loader: pass tem info to the environment
loader: import tem for loader console
loader: UEFI loader needs to set ISADIR based on
loader: need UEFI32 support
8918 loader.efi: add vesa edid support
uts: tem_safe_pix_clear_prom_output() should only
uts: tem_safe_pix_clear_entire_screen() should use
uts: tem_safe_check_first_time() should query cursor
uts: tem implement cls callback & visual_io v4
uts: gfx_vgatext use block cursor for vgatext
uts: gfx_private implement cls callback & visual_io
uts: gfx_private bitmap framebuffer implementation
uts: early start frame buffer console support
uts: font functions should check the input char
uts: font rendering should support 16/24/32bit depths
uts: use smallest font as fallback default.
uts: update terminal dimensions based on selected
7834 uts: vgatext should use gfx_private
uts: add spacing property to 8859-1.bdf
terminfo: add underline for sun-color
terminfo: sun-color has 16 colors
uts: add font load callback type
loader: do not repeat int13 calls with error 0x20 and
8905 loader: add skein/edonr support
8904 common/crypto: make skein and edonr loader
Reviewed by: Yuri Pankov <yuri.pankov@nexenta.com>
Reviewed by: Sanjay Nadkarni <sanjay.nadkarni@nexenta.com>
Reviewed by: Evan Layton <evan.layton@nexenta.com>
Revert "NEX-16819 loader UEFI support"
This reverts commit ec06b9fc617b99234e538bf2e7e4d02a24993e0c.
Reverting due to failures in the zfs-tests and the sharefs-tests
NEX-16819 loader UEFI support
Includes work by Toomas Soome <tsoome@me.com>
Upstream commits:
loader: pxe receive cleanup
9475 libefi: Do not return only if ReceiveFilter
installboot: should support efi system partition
8931 boot1.efi: scan all display modes rather than
loader: spinconsole updates
loader: gfx experiment to try GOP Blt() function.
sha1 build test
loader: add sha1 hash calculation
common/sha1: update for loader build
loader: biosdisk rework
uts: 32-bit kernel FB needs mapping in low memory
uts: add diag-device
uts: boot console mirror with diag-device
uts: enable very early console on ttya
kmdb: add diag-device as input/output device
uts: test VGA memory exclusion from mapping
uts: clear boot mapping and protect boot pages test
uts: add dboot map debug printf
uts: need to release FB pages in release_bootstrap()
uts: add screenmap ioctl
uts: update sys/queue.h
loader: add illumos uts/common to include path
loader: tem/gfx font cleanup
loader: vbe checks
uts: gfx_private set KD_TEXT when KD_RESETTEXT is
uts: gfx 8-bit update
loader: gfx 8-bit fix
loader: always set media size from partition.
uts: MB2 support for 32-bit kernel
loader: x86 should have tem 80x25
uts: x86 should have tem 80x25
uts: font update
loader: font update
uts: tem attributes
loader: tem.c comment added
uts: use font module
loader: add font module
loader: build rules for new font setup
uts: gfx_private update for new font structure
uts: early boot update for new font structure
uts: font update
uts: font build rules update for new fonts
uts: tem update to new font structure
loader: module.c needs to include tem_impl.h
uts: gfx_private 8x16 font rework
uts: make font_lookup public
loader: font rework
uts: font rework
libefi: efi_alloc_and_read should check for PMBR
uts: tem utf-8 support
loader: implement tem utf-8 support
loader: tem should be able to display UTF-8
7784 uts: console input should support utf-8
7796 uts: ldterm default to utf-8
uts: do not reset serial console
uts: set up colors even if tem is not console
uts: add type for early boot properties
uts: gfx_private experiment with drm and vga
uts: gfx_private should use setmode drm callback.
uts: identify FB types and set up gfx_private based
loader: replace gop and vesa with framebuffer
uts: boot needs simple tem to support mdb
uts: boot_keyboard should emit esc sequences for
uts: gfx_private FB showuld be written by line
kmdb: set terminal window size
uts: gfx_private needs to keep track of early boot FB
pnglite: move pnglite to usr/src/common
loader: gfx_fb
ficl-sys: add gfx primitives
loader: add illumos.png logo
ficl: add fb-putimage
loader: add png support
loader: add alpha blending for gfx_fb
loader: use term-drawrect for menu frame
ficl: add simple gfx words
uts: provide fb_info via fbgattr dev_specific array.
uts: gfx_private add alpha blending
uts: update sys/ascii.h
uts: tem OSC support (incomplete)
uts: implement env module support and use data from
uts: tem get colors from early boot data
loader: use crc32 from libstand (libz)
loader: optimize for size
loader: pass tem info to the environment
loader: import tem for loader console
loader: UEFI loader needs to set ISADIR based on
loader: need UEFI32 support
8918 loader.efi: add vesa edid support
uts: tem_safe_pix_clear_prom_output() should only
uts: tem_safe_pix_clear_entire_screen() should use
uts: tem_safe_check_first_time() should query cursor
uts: tem implement cls callback & visual_io v4
uts: gfx_vgatext use block cursor for vgatext
uts: gfx_private implement cls callback & visual_io
uts: gfx_private bitmap framebuffer implementation
uts: early start frame buffer console support
uts: font functions should check the input char
uts: font rendering should support 16/24/32bit depths
uts: use smallest font as fallback default.
uts: update terminal dimensions based on selected
7834 uts: vgatext should use gfx_private
uts: add spacing property to 8859-1.bdf
terminfo: add underline for sun-color
terminfo: sun-color has 16 colors
uts: add font load callback type
loader: do not repeat int13 calls with error 0x20 and
8905 loader: add skein/edonr support
8904 common/crypto: make skein and edonr loader
Reviewed by: Yuri Pankov <yuri.pankov@nexenta.com>
Reviewed by: Sanjay Nadkarni <sanjay.nadkarni@nexenta.com>
Reviewed by: Evan Layton <evan.layton@nexenta.com>
| Split |
Close |
| Expand all |
| Collapse all |
--- old/usr/src/uts/common/sys/vgareg.h
+++ new/usr/src/uts/common/sys/vgareg.h
1 1 /*
2 2 * CDDL HEADER START
3 3 *
4 4 * The contents of this file are subject to the terms of the
5 5 * Common Development and Distribution License, Version 1.0 only
6 6 * (the "License"). You may not use this file except in compliance
7 7 * with the License.
8 8 *
9 9 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
10 10 * or http://www.opensolaris.org/os/licensing.
11 11 * See the License for the specific language governing permissions
12 12 * and limitations under the License.
13 13 *
14 14 * When distributing Covered Code, include this CDDL HEADER in each
15 15 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
16 16 * If applicable, add the following below this CDDL HEADER, with the
17 17 * fields enclosed by brackets "[]" replaced with your own identifying
18 18 * information: Portions Copyright [yyyy] [name of copyright owner]
19 19 *
|
↓ open down ↓ |
19 lines elided |
↑ open up ↑ |
20 20 * CDDL HEADER END
21 21 */
22 22 /*
23 23 * Copyright 2005 Sun Microsystems, Inc. All rights reserved.
24 24 * Use is subject to license terms.
25 25 */
26 26
27 27 #ifndef _SYS_VGAREG_H
28 28 #define _SYS_VGAREG_H
29 29
30 -#pragma ident "%Z%%M% %I% %E% SMI"
31 -
32 30 #ifdef __cplusplus
33 31 extern "C" {
34 32 #endif
35 33
36 34 /*
37 35 * VGA frame buffer hardware definitions.
38 36 */
39 37
40 38 #define VGA8_DEPTH 8
41 39 #define VGA8_CMAP_ENTRIES 256
42 40 #define VGA_TEXT_CMAP_ENTRIES 64
43 41
44 42 /*
45 43 * General VGA registers
46 44 * These are relative to their register set, which
47 45 * the 3c0-3df set.
48 46 */
49 47 #define VGA_ATR_AD 0x00
50 48 #define VGA_ATR_DATA 0x01
51 49 #define VGA_MISC_W 0x02
52 50 #define VGA_SEQ_ADR 0x04
53 51 #define VGA_SEQ_DATA 0x05
54 52 #define VGA_DAC_BASE 0x06
55 53 #define VGA_DAC_AD_MK 0x06
56 54 #define VGA_DAC_RD_AD 0x07
57 55 #define VGA_DAC_STS 0x07
58 56 #define VGA_DAC_WR_AD 0x08
59 57 #define VGA_DAC_DATA 0x09
60 58 #define VGA_MISC_R 0x0c
61 59 #define VGA_GRC_ADR 0x0e
62 60 #define VGA_GRC_DATA 0x0f
63 61 #define VGA_CRTC_ADR 0x14
64 62 #define VGA_CRTC_DATA 0x15
65 63 #define CGA_STAT 0x1a
66 64
67 65 /*
68 66 * Attribute controller index bits
69 67 */
70 68 #define VGA_ATR_ENB_PLT 0x20
71 69
72 70 /*
73 71 * Miscellaneous output bits
74 72 */
|
↓ open down ↓ |
33 lines elided |
↑ open up ↑ |
75 73 #define VGA_MISC_IOA_SEL 0x01
76 74 #define VGA_MISC_ENB_RAM 0x02
77 75 #define VGA_MISC_VCLK 0x0c
78 76 #define VGA_MISC_VCLK0 0x00
79 77 #define VGA_MISC_VCLK1 0x04
80 78 #define VGA_MISC_VCLK2 0x08
81 79 #define VGA_MISC_VCLK3 0x0c
82 80 #define VGA_MISC_PGSL 0x20
83 81 #define VGA_MISC_HSP 0x40
84 82 #define VGA_MISC_VSP 0x80
83 +#define VGA_MISC_IS1_VR 0x08 /* Vertical Retrace */
84 +#define VGA_MISC_IS1_DD 0x01 /* Display Disabled */
85 85
86 86 /*
87 87 * CRT Controller registers
88 88 */
89 89 #define VGA_CRTC_H_TOTAL 0x00
90 90 #define VGA_CRTC_H_D_END 0x01
91 91 #define VGA_CRTC_S_H_BLNK 0x02
92 92 #define VGA_CRTC_E_H_BLNK 0x03
93 93 #define VGA_CRTC_E_H_BLNK_PUT_EHB(n) \
94 94 ((n)&0x1f)
95 95 #define VGA_CRTC_S_H_SY_P 0x04
96 96 #define VGA_CRTC_E_H_SY_P 0x05
97 97 #define VGA_CRTC_E_H_SY_P_HOR_SKW_SHIFT 5
98 98 #define VGA_CRTC_E_H_SY_P_HOR_SKW 0x60
99 99 #define VGA_CRTC_E_H_SY_P_EHB5 7
100 100 #define VGA_CRTC_E_H_SY_P_PUT_HOR_SKW(skew) \
101 101 ((skew)<<VGA_CRTC_E_H_SY_P_HOR_SKW_SHIFT)
102 102 #define VGA_CRTC_E_H_SY_P_PUT_EHB(n) \
103 103 ((((n)>>5)&1)<<VGA_CRTC_E_H_SY_P_EHB5)
104 104 #define VGA_CRTC_E_H_SY_P_PUT_EHS(n) \
105 105 ((n)&0x1f)
106 106 #define VGA_CRTC_V_TOTAL 0x06
107 107 #define VGA_CRTC_OVFL_REG 0x07
108 108 #define VGA_CRTC_OVFL_REG_VT8 0
109 109 #define VGA_CRTC_OVFL_REG_VDE8 1
110 110 #define VGA_CRTC_OVFL_REG_VRS8 2
111 111 #define VGA_CRTC_OVFL_REG_SVB8 3
112 112 #define VGA_CRTC_OVFL_REG_LCM8 4
113 113 #define VGA_CRTC_OVFL_REG_VT9 5
114 114 #define VGA_CRTC_OVFL_REG_VDE9 6
115 115 #define VGA_CRTC_OVFL_REG_VRS9 7
116 116 #define VGA_CRTC_OVFL_REG_PUT_VT(n) \
117 117 ((((n)>>8)&1)<<VGA_CRTC_OVFL_REG_VT8) \
118 118 | ((((n)>>9)&1)<<VGA_CRTC_OVFL_REG_VT9)
119 119 #define VGA_CRTC_OVFL_REG_PUT_VDE(n) \
120 120 ((((n)>>8)&1)<<VGA_CRTC_OVFL_REG_VDE8) \
121 121 | ((((n)>>9)&1)<<VGA_CRTC_OVFL_REG_VDE9)
122 122 #define VGA_CRTC_OVFL_REG_PUT_VRS(n) \
123 123 ((((n)>>8)&1)<<VGA_CRTC_OVFL_REG_VRS8) \
124 124 | ((((n)>>9)&1)<<VGA_CRTC_OVFL_REG_VRS9)
125 125 #define VGA_CRTC_OVFL_REG_PUT_LCM(n) \
126 126 ((((n)>>8)&1)<<VGA_CRTC_OVFL_REG_LCM8)
127 127 #define VGA_CRTC_OVFL_REG_PUT_SVB(n) \
128 128 ((((n)>>8)&1)<<VGA_CRTC_OVFL_REG_SVB8)
129 129 #define VGA_CRTC_P_R_SCAN 0x08
130 130 #define VGA_CRTC_MAX_S_LN 0x09
131 131 #define VGA_CRTC_MAX_S_LN_SVB9 5
132 132 #define VGA_CRTC_MAX_S_LN_LCM9 6
133 133 #define VGA_CRTC_MAX_S_LN_PUT_SVB(n) \
134 134 ((((n)>>9)&1)<<VGA_CRTC_MAX_S_LN_SVB9)
135 135 #define VGA_CRTC_MAX_S_LN_PUT_LCM(n) \
136 136 ((((n)>>9)&1)<<VGA_CRTC_MAX_S_LN_LCM9)
137 137 #define VGA_CRTC_CSSL 0x0a
138 138 #define VGA_CRTC_CESL 0x0b
139 139 #define VGA_CRTC_STAH 0x0c
140 140 #define VGA_CRTC_STAL 0x0d
141 141 #define VGA_CRTC_CLAH 0x0e
142 142 #define VGA_CRTC_CLAL 0x0f
143 143 #define VGA_CRTC_VRS 0x10
144 144 #define VGA_CRTC_VRE 0x11
145 145 #define VGA_CRTC_VRE_LOCK 0x80
146 146 #define VGA_CRTC_VRE_DIS_VINT 0x20
147 147 #define VGA_CRTC_VRE_PUT_VRE(n) \
148 148 ((n)&0x0f)
149 149 #define VGA_CRTC_VDE 0x12
150 150 #define VGA_CRTC_SCREEN_OFFSET 0x13
151 151 #define VGA_CRTC_ULL 0x14
152 152 #define VGA_CRTC_SVB 0x15
153 153 #define VGA_CRTC_EVB 0x16
154 154 #define VGA_CRTC_CRT_MD 0x17
155 155 #define VGA_CRTC_CRT_MD_2BK_CGA 0x01
156 156 #define VGA_CRTC_CRT_MD_4BK_HGC 0x02
157 157 #define VGA_CRTC_CRT_MD_VT_X2 0x04
158 158 #define VGA_CRTC_CRT_MD_WRD_MODE 0x08
159 159 #define VGA_CRTC_CRT_MD_ADW_16K 0x20
160 160 #define VGA_CRTC_CRT_MD_BYTE_MODE 0x40
161 161 #define VGA_CRTC_CRT_MD_NO_RESET 0x80
162 162 #define VGA_CRTC_LCM 0x18
163 163
164 164 /*
165 165 * Sequencer registers
|
↓ open down ↓ |
71 lines elided |
↑ open up ↑ |
166 166 */
167 167 #define VGA_SEQ_RST_SYN 0x00
168 168 #define VGA_SEQ_RST_SYN_ASYNC_RESET 0x00
169 169 #define VGA_SEQ_RST_SYN_NO_ASYNC_RESET 0x01
170 170 #define VGA_SEQ_RST_SYN_SYNC_RESET 0x00
171 171 #define VGA_SEQ_RST_SYN_NO_SYNC_RESET 0x02
172 172 #define VGA_SEQ_CLK_MODE 0x01
173 173 #define VGA_SEQ_CLK_MODE_8DC 0x01
174 174 #define VGA_SEQ_EN_WT_PL 0x02
175 175 #define VGA_SEQ_EN_WT_PL_ALL 0x0f
176 +#define VGA_SEQ_CMS 0x03 /* Char Map Select */
177 +#define VGA_SEQ_CMS_SAH 0x20 /* Char. A (bit 2) */
178 +#define VGA_SEQ_CMS_SBH 0x10 /* Char. B (bit 2) */
179 +#define VGA_SEQ_CMS_SA 0x0C /* Char. A (bit 0+1) */
180 +#define VGA_SEQ_CMS_SB 0x03 /* Char. B (bit 0+1) */
176 181 #define VGA_SEQ_MEM_MODE 0x04
177 182 #define VGA_SEQ_MEM_MODE_EXT_MEM 0x02
178 183 #define VGA_SEQ_MEM_MODE_SEQ_MODE 0x04
179 184 #define VGA_SEQ_MEM_MODE_CHN_4M 0x08
180 185
181 186 /*
182 187 * Graphics Controller
183 188 */
184 189 #define VGA_GRC_SET_RST_DT 0x00
185 190 #define VGA_GRC_EN_S_R_DT 0x01
186 191 #define VGA_GRC_COLOR_CMP 0x02
187 192 #define VGA_GRC_WT_ROP_RTC 0x03
188 193 #define VGA_GRC_RD_PL_SL 0x04
189 194 #define VGA_GRC_GRP_MODE 0x05
190 195 #define VGA_GRC_GRP_MODE_SHF_MODE_256 0x40
|
↓ open down ↓ |
5 lines elided |
↑ open up ↑ |
191 196 #define VGA_GRC_MISC_GM 0x06
192 197 #define VGA_GRC_MISC_GM_GRAPH 0x01
193 198 #define VGA_GRC_MISC_GM_MEM_MAP_1 0x04
194 199 #define VGA_GRC_CMP_DNTC 0x07
195 200 #define VGA_GRC_CMP_DNTC_ALL 0x0f
196 201 #define VGA_GRC_BIT_MASK 0x08
197 202
198 203 /*
199 204 * Attribute controller registers
200 205 */
201 -#define VGA_ATR_PLT_REG 0x00
202 -#define VGA_ATR_NUM_PLT 0x10
203 -#define VGA_ATR_MODE 0x10
204 -#define VGA_ATR_MODE_GRAPH 0x01
205 -#define VGA_ATR_MODE_9WIDE 0x04
206 -#define VGA_ATR_MODE_BLINK 0x08
207 -#define VGA_ATR_MODE_256CLR 0x40
206 +#define VGA_ATR_PAS 0x20 /* Palette Address Source */
207 +#define VGA_ATR_PLT_REG 0x00 /* Palette Register */
208 +#define VGA_ATR_NUM_PLT 0x10 /* Palette Register count */
209 +#define VGA_ATR_MODE 0x10 /* Attribute mode control */
210 +#define VGA_ATR_MODE_GRAPH 0x01 /* Graphics enable */
211 +#define VGA_ATR_MODE_MONO 0x02 /* Monochrome emulation */
212 +#define VGA_ATR_MODE_9WIDE 0x04 /* Line Graphics enable */
213 +#define VGA_ATR_MODE_BLINK 0x08 /* Blink enable */
214 +#define VGA_ATR_MODE_PPM 0x20 /* Pixel panning mode */
215 +#define VGA_ATR_MODE_256CLR 0x40 /* 8-bit color enable */
216 +#define VGA_ATR_MODE_P54S 0x80 /* Palette bits 4-5 select */
208 217 #define VGA_ATR_BDR_CLR 0x11
209 218 #define VGA_ATR_DISP_PLN 0x12
210 219 #define VGA_ATR_DISP_PLN_ALL 0x0f
211 220 #define VGA_ATR_H_PX_PAN 0x13
212 221 #define VGA_ATR_PX_PADD 0x14
213 222
214 223 /*
215 224 * Low-memory frame buffer definitions. These are relative to the
216 225 * A0000 register set.
217 226 */
218 227 #define VGA_MONO_BASE 0x10000 /* Base of monochrome text */
219 228 #define VGA_COLOR_BASE 0x18000 /* Base of color text */
220 229 #define VGA_TEXT_SIZE 0x8000 /* Size of text frame buffer */
221 230
222 231 #ifdef __cplusplus
223 232 }
224 233 #endif
225 234
226 235 #endif /* _SYS_VGAREG_H */
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX