blob: d567115744aa203172501138b0d3258131ee1410 [file] [log] [blame]
Ronald G. Minnichb3b72f32013-03-13 14:35:01 -07001/*
2 * This file is part of the coreboot project.
3 *
4 * Copyright 2013 Google Inc.
5 *
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; version 2 of the License.
9 *
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
Ronald G. Minnichb3b72f32013-03-13 14:35:01 -070014 */
15
16#ifndef EDID_H
17#define EDID_H
18
Nico Huber3db76532017-05-18 18:07:34 +020019#include <stdint.h>
20
David Hendricks7dbf9c62015-07-30 18:49:48 -070021enum edid_modes {
David Hendricks7dbf9c62015-07-30 18:49:48 -070022 EDID_MODE_640x480_60Hz,
David Hendrickse2054102015-08-07 18:41:37 -070023 EDID_MODE_720x480_60Hz,
24 EDID_MODE_1280x720_60Hz,
25 EDID_MODE_1920x1080_60Hz,
26 NUM_KNOWN_MODES,
27
28 EDID_MODE_AUTO
David Hendricks7dbf9c62015-07-30 18:49:48 -070029};
30
31struct edid_mode {
32 const char *name;
33 unsigned int pixel_clock;
Vladimir Serbinenko551cff02015-10-10 23:58:08 +020034 int lvds_dual_channel;
David Hendricks7dbf9c62015-07-30 18:49:48 -070035 unsigned int refresh;
36 unsigned int ha;
37 unsigned int hbl;
38 unsigned int hso;
39 unsigned int hspw;
40 unsigned int hborder;
41 unsigned int va;
42 unsigned int vbl;
43 unsigned int vso;
44 unsigned int vspw;
45 unsigned int vborder;
46 unsigned char phsync;
47 unsigned char pvsync;
48 unsigned int x_mm;
49 unsigned int y_mm;
50};
51
Ronald G. Minnichb3b72f32013-03-13 14:35:01 -070052/* structure for communicating EDID information from a raw EDID block to
53 * higher level functions.
54 * The size of the data types is not critical, so we leave them as
55 * unsigned int. We can move more into into this struct as needed.
56 */
57
Arthur Heymansdbe81612017-04-29 14:00:47 +020058#define EDID_ASCII_STRING_LENGTH 13
59
Ronald G. Minnichb3b72f32013-03-13 14:35:01 -070060struct edid {
Ronald G. Minnich9518b562013-09-19 16:45:22 -070061 /* These next three things used to all be called bpp.
62 * Merriment ensued. The identifier
63 * 'bpp' is herewith banished from our
64 * Kingdom.
65 */
66 /* How many bits in the framebuffer per pixel.
67 * Under all reasonable circumstances, it's 32.
68 */
69 unsigned int framebuffer_bits_per_pixel;
70 /* On the panel, how many bits per color?
71 * In almost all cases, it's 6 or 8.
72 * The standard allows for much more!
73 */
74 unsigned int panel_bits_per_color;
75 /* On the panel, how many bits per pixel.
76 * On Planet Earth, there are three colors
77 * per pixel, but this is convenient to have here
78 * instead of having 3*panel_bits_per_color
79 * all over the place.
80 */
81 unsigned int panel_bits_per_pixel;
Ronald G. Minnichb3b72f32013-03-13 14:35:01 -070082 /* used to compute timing for graphics chips. */
David Hendricks7dbf9c62015-07-30 18:49:48 -070083 struct edid_mode mode;
David Hendrickse2054102015-08-07 18:41:37 -070084 u8 mode_is_supported[NUM_KNOWN_MODES];
Furquan Shaikh6b190712013-07-22 16:18:31 -070085 unsigned int link_clock;
Ronald G. Minnich4c5b1612013-06-28 14:33:30 -070086 /* 3 variables needed for coreboot framebuffer.
87 * In most cases, they are the same as the ha
88 * and va variables, but not always, as in the
89 * case of a 1366 wide display.
90 */
91 u32 x_resolution;
92 u32 y_resolution;
93 u32 bytes_per_line;
Yakir Yang85810cc2015-10-27 16:17:13 +080094
95 int hdmi_monitor_detected;
Arthur Heymansdbe81612017-04-29 14:00:47 +020096 char ascii_string[EDID_ASCII_STRING_LENGTH + 1];
Ronald G. Minnichb3b72f32013-03-13 14:35:01 -070097};
98
Arthur Heymans8c5884e2017-04-30 08:28:05 +020099enum edid_status {
100 EDID_CONFORMANT,
101 EDID_NOT_CONFORMANT,
102 EDID_ABSENT,
103};
104
Ronald G. Minnichb2893a012013-04-23 10:59:11 -0700105/* Defined in src/lib/edid.c */
Ronald G. Minnichb3b72f32013-03-13 14:35:01 -0700106int decode_edid(unsigned char *edid, int size, struct edid *out);
Julius Werner2b6db972016-04-06 12:50:40 -0700107void edid_set_framebuffer_bits_per_pixel(struct edid *edid, int fb_bpp,
108 int row_byte_alignment);
Nico Huber994a4a12016-06-16 05:57:49 +0200109void set_vbe_mode_info_valid(const struct edid *edid, uintptr_t fb_addr);
David Hendrickse2054102015-08-07 18:41:37 -0700110int set_display_mode(struct edid *edid, enum edid_modes mode);
Ronald G. Minnichb2893a012013-04-23 10:59:11 -0700111
Ronald G. Minnichb3b72f32013-03-13 14:35:01 -0700112#endif /* EDID_H */