xref: /freebsd/stand/efi/include/Protocol/EdidDiscovered.h (revision 43a5ec4eb41567cc92586503212743d89686d78f)
1 /* $FreeBSD$ */
2 /** @file
3   EDID Discovered Protocol from the UEFI 2.0 specification.
4 
5   This protocol is placed on the video output device child handle. It represents
6   the EDID information being used for the output device represented by the child handle.
7 
8   Copyright (c) 2006 - 2012, Intel Corporation. All rights reserved.<BR>
9   This program and the accompanying materials
10   are licensed and made available under the terms and conditions of the BSD License
11   which accompanies this distribution.  The full text of the license may be found at
12   http://opensource.org/licenses/bsd-license.php
13 
14   THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
15   WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
16 
17 **/
18 
19 #ifndef __EDID_DISCOVERED_H__
20 #define __EDID_DISCOVERED_H__
21 
22 #define EFI_EDID_DISCOVERED_PROTOCOL_GUID \
23   { \
24     0x1c0c34f6, 0xd380, 0x41fa, {0xa0, 0x49, 0x8a, 0xd0, 0x6c, 0x1a, 0x66, 0xaa } \
25   }
26 
27 ///
28 /// This protocol contains the EDID information retrieved from a video output device.
29 ///
30 typedef struct {
31   ///
32   /// The size, in bytes, of the Edid buffer. 0 if no EDID information
33   /// is available from the video output device. Otherwise, it must be a
34   /// minimum of 128 bytes.
35   ///
36   UINT32   SizeOfEdid;
37 
38   ///
39   /// A pointer to a read-only array of bytes that contains the EDID
40   /// information for an active video output device. This pointer is
41   /// NULL if no EDID information is available for the video output
42   /// device. The minimum size of a valid Edid buffer is 128 bytes.
43   /// EDID information is defined in the E-EDID EEPROM
44   /// specification published by VESA (www.vesa.org).
45   ///
46   UINT8    *Edid;
47 } EFI_EDID_DISCOVERED_PROTOCOL;
48 
49 extern EFI_GUID gEfiEdidDiscoveredProtocolGuid;
50 
51 #endif
52