]>
Commit | Line | Data |
---|---|---|
83d290c5 | 1 | /* SPDX-License-Identifier: BSD-2-Clause */ |
647f56e7 SG |
2 | /****************************************************************************** |
3 | * Copyright (c) 2004, 2008 IBM Corporation | |
4 | * Copyright (c) 2009 Pattrick Hueper <[email protected]> | |
5 | * All rights reserved. | |
6 | * | |
647f56e7 SG |
7 | * Contributors: |
8 | * IBM Corporation - initial implementation | |
9 | *****************************************************************************/ | |
10 | #ifndef _VBE_H | |
11 | #define _VBE_H | |
12 | ||
13 | /* these structs are for input from and output to OF */ | |
a4520022 | 14 | struct __packed vbe_screen_info { |
647f56e7 SG |
15 | u8 display_type; /* 0=NONE, 1= analog, 2=digital */ |
16 | u16 screen_width; | |
17 | u16 screen_height; | |
18 | /* bytes per line in framebuffer, may be more than screen_width */ | |
19 | u16 screen_linebytes; | |
20 | u8 color_depth; /* color depth in bits per pixel */ | |
21 | u32 framebuffer_address; | |
22 | u8 edid_block_zero[128]; | |
23 | }; | |
24 | ||
a4520022 | 25 | struct __packed vbe_screen_info_input { |
647f56e7 SG |
26 | u8 signature[4]; |
27 | u16 size_reserved; | |
28 | u8 monitor_number; | |
29 | u16 max_screen_width; | |
30 | u8 color_depth; | |
31 | }; | |
32 | ||
33 | /* these structs only store the required a subset of the VBE-defined fields */ | |
34 | struct __packed vbe_info { | |
35 | char signature[4]; | |
36 | u16 version; | |
222f25f8 | 37 | u32 oem_string_ptr; |
647f56e7 | 38 | u32 capabilities; |
222f25f8 | 39 | u32 modes_ptr; |
647f56e7 | 40 | u16 total_memory; |
222f25f8 SG |
41 | u16 oem_version; |
42 | u32 vendor_name_ptr; | |
43 | u32 product_name_ptr; | |
44 | u32 product_rev_ptr; | |
647f56e7 SG |
45 | }; |
46 | ||
47 | struct __packed vesa_mode_info { | |
48 | u16 mode_attributes; /* 00 */ | |
49 | u8 win_a_attributes; /* 02 */ | |
50 | u8 win_b_attributes; /* 03 */ | |
51 | u16 win_granularity; /* 04 */ | |
52 | u16 win_size; /* 06 */ | |
53 | u16 win_a_segment; /* 08 */ | |
54 | u16 win_b_segment; /* 0a */ | |
55 | u32 win_func_ptr; /* 0c */ | |
56 | u16 bytes_per_scanline; /* 10 */ | |
57 | u16 x_resolution; /* 12 */ | |
58 | u16 y_resolution; /* 14 */ | |
59 | u8 x_charsize; /* 16 */ | |
60 | u8 y_charsize; /* 17 */ | |
61 | u8 number_of_planes; /* 18 */ | |
62 | u8 bits_per_pixel; /* 19 */ | |
63 | u8 number_of_banks; /* 20 */ | |
64 | u8 memory_model; /* 21 */ | |
65 | u8 bank_size; /* 22 */ | |
66 | u8 number_of_image_pages; /* 23 */ | |
67 | u8 reserved_page; | |
68 | u8 red_mask_size; | |
69 | u8 red_mask_pos; | |
70 | u8 green_mask_size; | |
71 | u8 green_mask_pos; | |
72 | u8 blue_mask_size; | |
73 | u8 blue_mask_pos; | |
74 | u8 reserved_mask_size; | |
75 | u8 reserved_mask_pos; | |
76 | u8 direct_color_mode_info; | |
77 | u32 phys_base_ptr; | |
78 | u32 offscreen_mem_offset; | |
79 | u16 offscreen_mem_size; | |
80 | u8 reserved[206]; | |
81 | }; | |
82 | ||
83 | struct vbe_mode_info { | |
84 | u16 video_mode; | |
85 | bool valid; | |
86 | union { | |
87 | struct vesa_mode_info vesa; | |
88 | u8 mode_info_block[256]; | |
89 | }; | |
90 | }; | |
91 | ||
92 | struct vbe_ddc_info { | |
93 | u8 port_number; /* i.e. monitor number */ | |
94 | u8 edid_transfer_time; | |
95 | u8 ddc_level; | |
96 | u8 edid_block_zero[128]; | |
97 | }; | |
98 | ||
99 | #define VESA_GET_INFO 0x4f00 | |
100 | #define VESA_GET_MODE_INFO 0x4f01 | |
101 | #define VESA_SET_MODE 0x4f02 | |
222f25f8 | 102 | #define VESA_GET_CUR_MODE 0x4f03 |
647f56e7 | 103 | |
153e1dda BM |
104 | extern struct vbe_mode_info mode_info; |
105 | ||
ee87ee82 | 106 | struct video_priv; |
5f6ad029 BM |
107 | struct video_uc_platdata; |
108 | int vbe_setup_video_priv(struct vesa_mode_info *vesa, | |
109 | struct video_priv *uc_priv, | |
110 | struct video_uc_platdata *plat); | |
ee87ee82 | 111 | int vbe_setup_video(struct udevice *dev, int (*int15_handler)(void)); |
647f56e7 SG |
112 | |
113 | #endif |