]>
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 | *****************************************************************************/ | |
cafe8712 SG |
10 | #ifndef _VESA_H |
11 | #define _VESA_H | |
647f56e7 SG |
12 | |
13 | /* these structs are for input from and output to OF */ | |
da62e1e8 | 14 | struct __packed vesa_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 | ||
da62e1e8 | 25 | struct __packed vesa_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 | ||
da62e1e8 SG |
33 | /* |
34 | * These structs only store the required subset of fields in Vesa BIOS | |
35 | * Extensions | |
36 | */ | |
37 | struct __packed vesa_bios_ext_info { | |
647f56e7 SG |
38 | char signature[4]; |
39 | u16 version; | |
222f25f8 | 40 | u32 oem_string_ptr; |
647f56e7 | 41 | u32 capabilities; |
222f25f8 | 42 | u32 modes_ptr; |
647f56e7 | 43 | u16 total_memory; |
222f25f8 SG |
44 | u16 oem_version; |
45 | u32 vendor_name_ptr; | |
46 | u32 product_name_ptr; | |
47 | u32 product_rev_ptr; | |
647f56e7 SG |
48 | }; |
49 | ||
50 | struct __packed vesa_mode_info { | |
51 | u16 mode_attributes; /* 00 */ | |
52 | u8 win_a_attributes; /* 02 */ | |
53 | u8 win_b_attributes; /* 03 */ | |
54 | u16 win_granularity; /* 04 */ | |
55 | u16 win_size; /* 06 */ | |
56 | u16 win_a_segment; /* 08 */ | |
57 | u16 win_b_segment; /* 0a */ | |
58 | u32 win_func_ptr; /* 0c */ | |
59 | u16 bytes_per_scanline; /* 10 */ | |
60 | u16 x_resolution; /* 12 */ | |
61 | u16 y_resolution; /* 14 */ | |
62 | u8 x_charsize; /* 16 */ | |
63 | u8 y_charsize; /* 17 */ | |
64 | u8 number_of_planes; /* 18 */ | |
65 | u8 bits_per_pixel; /* 19 */ | |
66 | u8 number_of_banks; /* 20 */ | |
67 | u8 memory_model; /* 21 */ | |
68 | u8 bank_size; /* 22 */ | |
69 | u8 number_of_image_pages; /* 23 */ | |
70 | u8 reserved_page; | |
71 | u8 red_mask_size; | |
72 | u8 red_mask_pos; | |
73 | u8 green_mask_size; | |
74 | u8 green_mask_pos; | |
75 | u8 blue_mask_size; | |
76 | u8 blue_mask_pos; | |
77 | u8 reserved_mask_size; | |
78 | u8 reserved_mask_pos; | |
79 | u8 direct_color_mode_info; | |
80 | u32 phys_base_ptr; | |
81 | u32 offscreen_mem_offset; | |
82 | u16 offscreen_mem_size; | |
83 | u8 reserved[206]; | |
84 | }; | |
85 | ||
da62e1e8 | 86 | struct vesa_state { |
647f56e7 SG |
87 | u16 video_mode; |
88 | bool valid; | |
89 | union { | |
90 | struct vesa_mode_info vesa; | |
91 | u8 mode_info_block[256]; | |
92 | }; | |
93 | }; | |
94 | ||
da62e1e8 | 95 | struct vesa_ddc_info { |
647f56e7 SG |
96 | u8 port_number; /* i.e. monitor number */ |
97 | u8 edid_transfer_time; | |
98 | u8 ddc_level; | |
99 | u8 edid_block_zero[128]; | |
100 | }; | |
101 | ||
102 | #define VESA_GET_INFO 0x4f00 | |
103 | #define VESA_GET_MODE_INFO 0x4f01 | |
104 | #define VESA_SET_MODE 0x4f02 | |
222f25f8 | 105 | #define VESA_GET_CUR_MODE 0x4f03 |
647f56e7 | 106 | |
da62e1e8 | 107 | extern struct vesa_state mode_info; |
153e1dda | 108 | |
ee87ee82 | 109 | struct video_priv; |
8a8d24bd | 110 | struct video_uc_plat; |
644e6144 SG |
111 | |
112 | /** | |
113 | * vesa_setup_video_priv() - Set up a video device using VESA information | |
114 | * | |
115 | * The vesa struct is used by various x86 drivers, so this is a common function | |
116 | * to use it to set up the video. | |
117 | * | |
118 | * @vesa: Vesa information to use (vesa->phys_base_ptr is ignored) | |
119 | * @fb: Frame buffer address (since vesa->phys_base_ptr is only 32 bits) | |
120 | * @uc_priv: Video device's uclass-private information | |
121 | * @plat: Video devices's uclass-private platform data | |
122 | * Returns: 0 if OK, -ENXIO if the x resolution is 0, -EEPROTONOSUPPORT if the | |
123 | * pixel format is not supported | |
124 | */ | |
125 | int vesa_setup_video_priv(struct vesa_mode_info *vesa, u64 fb, | |
da62e1e8 SG |
126 | struct video_priv *uc_priv, |
127 | struct video_uc_plat *plat); | |
128 | int vesa_setup_video(struct udevice *dev, int (*int15_handler)(void)); | |
647f56e7 SG |
129 | |
130 | #endif |