2008-11-08 01:05:41 +03:00
/*
* Copyright © 2007 - 2008 Intel Corporation
* Jesse Barnes < jesse . barnes @ intel . com >
*
* Permission is hereby granted , free of charge , to any person obtaining a
* copy of this software and associated documentation files ( the " Software " ) ,
* to deal in the Software without restriction , including without limitation
* the rights to use , copy , modify , merge , publish , distribute , sublicense ,
* and / or sell copies of the Software , and to permit persons to whom the
* Software is furnished to do so , subject to the following conditions :
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software .
*
* THE SOFTWARE IS PROVIDED " AS IS " , WITHOUT WARRANTY OF ANY KIND , EXPRESS OR
* IMPLIED , INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY ,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT . IN NO EVENT SHALL
* THE COPYRIGHT HOLDER ( S ) OR AUTHOR ( S ) BE LIABLE FOR ANY CLAIM , DAMAGES OR
* OTHER LIABILITY , WHETHER IN AN ACTION OF CONTRACT , TORT OR OTHERWISE ,
* ARISING FROM , OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
* OTHER DEALINGS IN THE SOFTWARE .
*/
# ifndef __DRM_EDID_H__
# define __DRM_EDID_H__
# include <linux/types.h>
2017-01-11 15:57:21 +03:00
# include <linux/hdmi.h>
2008-11-08 01:05:41 +03:00
2016-08-31 19:09:06 +03:00
struct drm_device ;
struct i2c_adapter ;
2008-11-08 01:05:41 +03:00
# define EDID_LENGTH 128
# define DDC_ADDR 0x50
2014-10-20 10:13:19 +04:00
# define DDC_ADDR2 0x52 /* E-DDC 1.2 - where DisplayID can hide */
2008-11-08 01:05:41 +03:00
2010-08-03 22:38:17 +04:00
# define CEA_EXT 0x02
# define VTB_EXT 0x10
# define DI_EXT 0x40
# define LS_EXT 0x50
# define MI_EXT 0x60
2014-10-20 10:13:19 +04:00
# define DISPLAYID_EXT 0x70
2010-08-03 22:38:17 +04:00
2008-11-08 01:05:41 +03:00
struct est_timings {
u8 t1 ;
u8 t2 ;
u8 mfg_rsvd ;
} __attribute__ ( ( packed ) ) ;
2009-06-15 18:56:07 +04:00
/* 00=16:10, 01=4:3, 10=5:4, 11=16:9 */
2009-06-23 14:36:32 +04:00
# define EDID_TIMING_ASPECT_SHIFT 6
2009-06-15 18:56:07 +04:00
# define EDID_TIMING_ASPECT_MASK (0x3 << EDID_TIMING_ASPECT_SHIFT)
/* need to add 60 */
2009-06-23 14:36:32 +04:00
# define EDID_TIMING_VFREQ_SHIFT 0
2009-06-15 18:56:07 +04:00
# define EDID_TIMING_VFREQ_MASK (0x3f << EDID_TIMING_VFREQ_SHIFT)
2008-11-08 01:05:41 +03:00
struct std_timing {
u8 hsize ; /* need to multiply by 8 then add 248 */
2009-06-15 18:56:07 +04:00
u8 vfreq_aspect ;
2008-11-08 01:05:41 +03:00
} __attribute__ ( ( packed ) ) ;
2009-06-23 14:36:32 +04:00
# define DRM_EDID_PT_HSYNC_POSITIVE (1 << 1)
# define DRM_EDID_PT_VSYNC_POSITIVE (1 << 2)
2009-06-15 18:56:07 +04:00
# define DRM_EDID_PT_SEPARATE_SYNC (3 << 3)
2009-06-23 14:36:32 +04:00
# define DRM_EDID_PT_STEREO (1 << 5)
# define DRM_EDID_PT_INTERLACED (1 << 7)
2009-06-15 18:56:07 +04:00
2008-11-08 01:05:41 +03:00
/* If detailed data is pixel timing */
struct detailed_pixel_timing {
u8 hactive_lo ;
u8 hblank_lo ;
2009-06-15 18:56:07 +04:00
u8 hactive_hblank_hi ;
2008-11-08 01:05:41 +03:00
u8 vactive_lo ;
u8 vblank_lo ;
2009-06-15 18:56:07 +04:00
u8 vactive_vblank_hi ;
2008-11-08 01:05:41 +03:00
u8 hsync_offset_lo ;
u8 hsync_pulse_width_lo ;
2009-06-15 18:56:07 +04:00
u8 vsync_offset_pulse_width_lo ;
u8 hsync_vsync_offset_pulse_width_hi ;
2008-11-08 01:05:41 +03:00
u8 width_mm_lo ;
u8 height_mm_lo ;
2009-06-15 18:56:07 +04:00
u8 width_height_mm_hi ;
2008-11-08 01:05:41 +03:00
u8 hborder ;
u8 vborder ;
2009-06-15 18:56:07 +04:00
u8 misc ;
2008-11-08 01:05:41 +03:00
} __attribute__ ( ( packed ) ) ;
/* If it's not pixel timing, it'll be one of the below */
struct detailed_data_string {
u8 str [ 13 ] ;
} __attribute__ ( ( packed ) ) ;
struct detailed_data_monitor_range {
u8 min_vfreq ;
u8 max_vfreq ;
u8 min_hfreq_khz ;
u8 max_hfreq_khz ;
u8 pixel_clock_mhz ; /* need to multiply by 10 */
2012-04-14 00:33:37 +04:00
u8 flags ;
union {
struct {
u8 reserved ;
u8 hfreq_start_khz ; /* need to multiply by 2 */
u8 c ; /* need to divide by 2 */
__le16 m ;
u8 k ;
u8 j ; /* need to divide by 2 */
2012-04-23 20:40:49 +04:00
} __attribute__ ( ( packed ) ) gtf2 ;
2012-04-14 00:33:37 +04:00
struct {
u8 version ;
u8 data1 ; /* high 6 bits: extra clock resolution */
u8 data2 ; /* plus low 2 of above: max hactive */
u8 supported_aspects ;
u8 flags ; /* preferred aspect and blanking support */
u8 supported_scalings ;
u8 preferred_refresh ;
2012-04-23 20:40:49 +04:00
} __attribute__ ( ( packed ) ) cvt ;
2012-04-14 00:33:37 +04:00
} formula ;
2008-11-08 01:05:41 +03:00
} __attribute__ ( ( packed ) ) ;
struct detailed_data_wpindex {
2009-06-23 14:36:32 +04:00
u8 white_yx_lo ; /* Lower 2 bits each */
2008-11-08 01:05:41 +03:00
u8 white_x_hi ;
u8 white_y_hi ;
u8 gamma ; /* need to divide by 100 then add 1 */
} __attribute__ ( ( packed ) ) ;
struct detailed_data_color_point {
u8 windex1 ;
u8 wpindex1 [ 3 ] ;
u8 windex2 ;
u8 wpindex2 [ 3 ] ;
} __attribute__ ( ( packed ) ) ;
2009-12-04 01:44:40 +03:00
struct cvt_timing {
u8 code [ 3 ] ;
} __attribute__ ( ( packed ) ) ;
2008-11-08 01:05:41 +03:00
struct detailed_non_pixel {
u8 pad1 ;
u8 type ; /* ff=serial, fe=string, fd=monitor range, fc=monitor name
fb = color point data , fa = standard timing data ,
f9 = undefined , f8 = mfg . reserved */
u8 pad2 ;
union {
struct detailed_data_string str ;
struct detailed_data_monitor_range range ;
struct detailed_data_wpindex color ;
2010-05-14 15:06:19 +04:00
struct std_timing timings [ 6 ] ;
2009-12-04 01:44:40 +03:00
struct cvt_timing cvt [ 4 ] ;
2008-11-08 01:05:41 +03:00
} data ;
} __attribute__ ( ( packed ) ) ;
2009-12-04 01:44:39 +03:00
# define EDID_DETAIL_EST_TIMINGS 0xf7
# define EDID_DETAIL_CVT_3BYTE 0xf8
# define EDID_DETAIL_COLOR_MGMT_DATA 0xf9
2008-11-08 01:05:41 +03:00
# define EDID_DETAIL_STD_MODES 0xfa
# define EDID_DETAIL_MONITOR_CPDATA 0xfb
# define EDID_DETAIL_MONITOR_NAME 0xfc
# define EDID_DETAIL_MONITOR_RANGE 0xfd
# define EDID_DETAIL_MONITOR_STRING 0xfe
# define EDID_DETAIL_MONITOR_SERIAL 0xff
struct detailed_timing {
2009-06-15 18:56:07 +04:00
__le16 pixel_clock ; /* need to multiply by 10 KHz */
2008-11-08 01:05:41 +03:00
union {
struct detailed_pixel_timing pixel_data ;
struct detailed_non_pixel other_data ;
} data ;
} __attribute__ ( ( packed ) ) ;
2009-06-23 14:36:32 +04:00
# define DRM_EDID_INPUT_SERRATION_VSYNC (1 << 0)
# define DRM_EDID_INPUT_SYNC_ON_GREEN (1 << 1)
# define DRM_EDID_INPUT_COMPOSITE_SYNC (1 << 2)
2009-06-15 18:56:07 +04:00
# define DRM_EDID_INPUT_SEPARATE_SYNCS (1 << 3)
2009-06-23 14:36:32 +04:00
# define DRM_EDID_INPUT_BLANK_TO_BLACK (1 << 4)
# define DRM_EDID_INPUT_VIDEO_LEVEL (3 << 5)
2011-04-15 23:49:23 +04:00
# define DRM_EDID_INPUT_DIGITAL (1 << 7)
# define DRM_EDID_DIGITAL_DEPTH_MASK (7 << 4)
# define DRM_EDID_DIGITAL_DEPTH_UNDEF (0 << 4)
# define DRM_EDID_DIGITAL_DEPTH_6 (1 << 4)
# define DRM_EDID_DIGITAL_DEPTH_8 (2 << 4)
# define DRM_EDID_DIGITAL_DEPTH_10 (3 << 4)
# define DRM_EDID_DIGITAL_DEPTH_12 (4 << 4)
# define DRM_EDID_DIGITAL_DEPTH_14 (5 << 4)
# define DRM_EDID_DIGITAL_DEPTH_16 (6 << 4)
# define DRM_EDID_DIGITAL_DEPTH_RSVD (7 << 4)
# define DRM_EDID_DIGITAL_TYPE_UNDEF (0)
# define DRM_EDID_DIGITAL_TYPE_DVI (1)
# define DRM_EDID_DIGITAL_TYPE_HDMI_A (2)
# define DRM_EDID_DIGITAL_TYPE_HDMI_B (3)
# define DRM_EDID_DIGITAL_TYPE_MDDI (4)
# define DRM_EDID_DIGITAL_TYPE_DP (5)
2009-06-15 18:56:07 +04:00
2009-06-23 14:36:32 +04:00
# define DRM_EDID_FEATURE_DEFAULT_GTF (1 << 0)
# define DRM_EDID_FEATURE_PREFERRED_TIMING (1 << 1)
# define DRM_EDID_FEATURE_STANDARD_COLOR (1 << 2)
2011-04-16 00:48:57 +04:00
/* If analog */
2009-06-15 18:56:07 +04:00
# define DRM_EDID_FEATURE_DISPLAY_TYPE (3 << 3) /* 00=mono, 01=rgb, 10=non-rgb, 11=unknown */
2011-04-16 00:48:57 +04:00
/* If digital */
# define DRM_EDID_FEATURE_COLOR_MASK (3 << 3)
# define DRM_EDID_FEATURE_RGB (0 << 3)
# define DRM_EDID_FEATURE_RGB_YCRCB444 (1 << 3)
# define DRM_EDID_FEATURE_RGB_YCRCB422 (2 << 3)
# define DRM_EDID_FEATURE_RGB_YCRCB (3 << 3) /* both 4:4:4 and 4:2:2 */
2009-06-23 14:36:32 +04:00
# define DRM_EDID_FEATURE_PM_ACTIVE_OFF (1 << 5)
# define DRM_EDID_FEATURE_PM_SUSPEND (1 << 6)
# define DRM_EDID_FEATURE_PM_STANDBY (1 << 7)
2009-06-15 18:56:07 +04:00
2014-03-27 22:59:39 +04:00
# define DRM_EDID_HDMI_DC_48 (1 << 6)
# define DRM_EDID_HDMI_DC_36 (1 << 5)
# define DRM_EDID_HDMI_DC_30 (1 << 4)
# define DRM_EDID_HDMI_DC_Y444 (1 << 3)
2017-07-13 18:33:13 +03:00
/* YCBCR 420 deep color modes */
# define DRM_EDID_YCBCR420_DC_48 (1 << 6)
# define DRM_EDID_YCBCR420_DC_36 (1 << 5)
# define DRM_EDID_YCBCR420_DC_30 (1 << 4)
# define DRM_EDID_YCBCR420_DC_MASK (DRM_EDID_YCBCR420_DC_48 | \
DRM_EDID_YCBCR420_DC_36 | \
DRM_EDID_YCBCR420_DC_30 )
2014-10-28 17:20:47 +03:00
/* ELD Header Block */
# define DRM_ELD_HEADER_BLOCK_SIZE 4
# define DRM_ELD_VER 0
# define DRM_ELD_VER_SHIFT 3
# define DRM_ELD_VER_MASK (0x1f << 3)
2015-04-13 10:57:14 +03:00
# define DRM_ELD_VER_CEA861D (2 << 3) /* supports 861D or below */
# define DRM_ELD_VER_CANNED (0x1f << 3)
2014-10-28 17:20:47 +03:00
# define DRM_ELD_BASELINE_ELD_LEN 2 /* in dwords! */
/* ELD Baseline Block for ELD_Ver == 2 */
# define DRM_ELD_CEA_EDID_VER_MNL 4
# define DRM_ELD_CEA_EDID_VER_SHIFT 5
# define DRM_ELD_CEA_EDID_VER_MASK (7 << 5)
# define DRM_ELD_CEA_EDID_VER_NONE (0 << 5)
# define DRM_ELD_CEA_EDID_VER_CEA861 (1 << 5)
# define DRM_ELD_CEA_EDID_VER_CEA861A (2 << 5)
# define DRM_ELD_CEA_EDID_VER_CEA861BCD (3 << 5)
# define DRM_ELD_MNL_SHIFT 0
# define DRM_ELD_MNL_MASK (0x1f << 0)
# define DRM_ELD_SAD_COUNT_CONN_TYPE 5
# define DRM_ELD_SAD_COUNT_SHIFT 4
# define DRM_ELD_SAD_COUNT_MASK (0xf << 4)
# define DRM_ELD_CONN_TYPE_SHIFT 2
# define DRM_ELD_CONN_TYPE_MASK (3 << 2)
# define DRM_ELD_CONN_TYPE_HDMI (0 << 2)
# define DRM_ELD_CONN_TYPE_DP (1 << 2)
# define DRM_ELD_SUPPORTS_AI (1 << 1)
# define DRM_ELD_SUPPORTS_HDCP (1 << 0)
# define DRM_ELD_AUD_SYNCH_DELAY 6 /* in units of 2 ms */
# define DRM_ELD_AUD_SYNCH_DELAY_MAX 0xfa /* 500 ms */
# define DRM_ELD_SPEAKER 7
2017-01-03 18:52:50 +03:00
# define DRM_ELD_SPEAKER_MASK 0x7f
2014-10-28 17:20:47 +03:00
# define DRM_ELD_SPEAKER_RLRC (1 << 6)
# define DRM_ELD_SPEAKER_FLRC (1 << 5)
# define DRM_ELD_SPEAKER_RC (1 << 4)
# define DRM_ELD_SPEAKER_RLR (1 << 3)
# define DRM_ELD_SPEAKER_FC (1 << 2)
# define DRM_ELD_SPEAKER_LFE (1 << 1)
# define DRM_ELD_SPEAKER_FLR (1 << 0)
# define DRM_ELD_PORT_ID 8 /* offsets 8..15 inclusive */
# define DRM_ELD_PORT_ID_LEN 8
# define DRM_ELD_MANUFACTURER_NAME0 16
# define DRM_ELD_MANUFACTURER_NAME1 17
# define DRM_ELD_PRODUCT_CODE0 18
# define DRM_ELD_PRODUCT_CODE1 19
# define DRM_ELD_MONITOR_NAME_STRING 20 /* offsets 20..(20+mnl-1) inclusive */
# define DRM_ELD_CEA_SAD(mnl, sad) (20 + (mnl) + 3 * (sad))
2008-11-08 01:05:41 +03:00
struct edid {
u8 header [ 8 ] ;
/* Vendor & product info */
u8 mfg_id [ 2 ] ;
u8 prod_code [ 2 ] ;
u32 serial ; /* FIXME: byte order */
u8 mfg_week ;
u8 mfg_year ;
/* EDID version */
u8 version ;
u8 revision ;
/* Display info: */
2009-06-15 18:56:07 +04:00
u8 input ;
2008-11-08 01:05:41 +03:00
u8 width_cm ;
u8 height_cm ;
u8 gamma ;
2009-06-15 18:56:07 +04:00
u8 features ;
2008-11-08 01:05:41 +03:00
/* Color characteristics */
u8 red_green_lo ;
u8 black_white_lo ;
u8 red_x ;
u8 red_y ;
u8 green_x ;
u8 green_y ;
u8 blue_x ;
u8 blue_y ;
u8 white_x ;
u8 white_y ;
/* Est. timings and mfg rsvd timings*/
struct est_timings established_timings ;
/* Standard timings 1-8*/
struct std_timing standard_timings [ 8 ] ;
/* Detailing timings 1-4 */
struct detailed_timing detailed_timings [ 4 ] ;
/* Number of 128 byte ext. blocks */
u8 extensions ;
/* Checksum */
u8 checksum ;
} __attribute__ ( ( packed ) ) ;
# define EDID_PRODUCT_ID(e) ((e)->prod_code[0] | ((e)->prod_code[1] << 8))
2013-04-19 21:01:25 +04:00
/* Short Audio Descriptor */
struct cea_sad {
u8 format ;
u8 channels ; /* max number of channels - 1 */
u8 freq ;
u8 byte2 ; /* meaning depends on format */
} ;
2011-09-05 10:23:20 +04:00
struct drm_encoder ;
struct drm_connector ;
struct drm_display_mode ;
2012-11-21 18:31:35 +04:00
2011-09-05 10:23:20 +04:00
void drm_edid_to_eld ( struct drm_connector * connector , struct edid * edid ) ;
2013-04-19 21:01:25 +04:00
int drm_edid_to_sad ( struct edid * edid , struct cea_sad * * sads ) ;
2013-07-25 23:55:32 +04:00
int drm_edid_to_speaker_allocation ( struct edid * edid , u8 * * sadb ) ;
2011-09-05 10:23:20 +04:00
int drm_av_sync_delay ( struct drm_connector * connector ,
2015-09-07 18:22:58 +03:00
const struct drm_display_mode * mode ) ;
2016-04-19 20:40:37 +03:00
# ifdef CONFIG_DRM_LOAD_EDID_FIRMWARE
2017-02-17 18:20:51 +03:00
struct edid * drm_load_edid_firmware ( struct drm_connector * connector ) ;
2017-09-18 21:20:03 +03:00
int __drm_set_edid_firmware_path ( const char * path ) ;
int __drm_get_edid_firmware_path ( char * buf , size_t bufsize ) ;
2016-04-19 20:40:37 +03:00
# else
2017-02-17 18:20:51 +03:00
static inline struct edid *
drm_load_edid_firmware ( struct drm_connector * connector )
2016-04-19 20:40:37 +03:00
{
2017-02-17 18:20:51 +03:00
return ERR_PTR ( - ENOENT ) ;
2016-04-19 20:40:37 +03:00
}
# endif
2011-09-05 10:23:20 +04:00
2012-11-21 18:31:35 +04:00
int
drm_hdmi_avi_infoframe_from_display_mode ( struct hdmi_avi_infoframe * frame ,
drm: handle HDMI 2.0 VICs in AVI info-frames
HDMI 1.4b support the CEA video modes as per range of CEA-861-D (VIC 1-64).
For any other mode, the VIC filed in AVI infoframes should be 0.
HDMI 2.0 sinks, support video modes range as per CEA-861-F spec, which is
extended to (VIC 1-107).
This patch adds a bool input variable, which indicates if the connected
sink is a HDMI 2.0 sink or not. This will make sure that we don't pass a
HDMI 2.0 VIC to a HDMI 1.4 sink.
This patch touches all drm drivers, who are callers of this function
drm_hdmi_avi_infoframe_from_display_mode but to make sure there is
no change in current behavior, is_hdmi2 is kept as false.
In case of I915 driver, this patch:
- checks if the connected display is HDMI 2.0.
- HDMI infoframes carry one of this two type of information:
- VIC for 4K modes for HDMI 1.4 sinks
- S3D information for S3D modes
As CEA-861-F has already defined VICs for 4K videomodes, this
patch doesn't allow sending HDMI infoframes for HDMI 2.0 sinks,
until the mode is 3D.
Cc: Ville Syrjala <ville.syrjala@linux.intel.com>
Cc: Jose Abreu <jose.abreu@synopsys.com>
Cc: Andrzej Hajda <a.hajda@samsung.com>
Cc: Alex Deucher <alexander.deucher@amd.com>
Cc: Daniel Vetter <daniel.vetter@intel.com>
PS: This patch touches a few lines in few files, which were
already above 80 char, so checkpatch gives 80 char warning again.
- gpu/drm/omapdrm/omap_encoder.c
- gpu/drm/i915/intel_sdvo.c
V2: Rebase, Added r-b from Andrzej
V3: Addressed review comment from Ville:
- Do not send VICs in both AVI-IF and HDMI-IF
send only one of it.
V4: Rebase
V5: Added r-b from Neil.
Addressed review comments from Ville
- Do not block HDMI vendor IF, instead check for VIC while
handling AVI infoframes
V6: Rebase
V7: Rebase
Reviewed-by: Andrzej Hajda <a.hajda@samsung.com>
Reviewed-by: Neil Armstrong <narmstrong@baylibre.com>
Signed-off-by: Shashank Sharma <shashank.sharma@intel.com>
Link: http://patchwork.freedesktop.org/patch/msgid/1499960000-9232-2-git-send-email-shashank.sharma@intel.com
Signed-off-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
2017-07-13 18:33:07 +03:00
const struct drm_display_mode * mode ,
bool is_hdmi2_sink ) ;
2013-08-19 19:59:03 +04:00
int
drm_hdmi_vendor_infoframe_from_display_mode ( struct hdmi_vendor_infoframe * frame ,
const struct drm_display_mode * mode ) ;
2017-01-11 15:57:23 +03:00
void
drm_hdmi_avi_infoframe_quant_range ( struct hdmi_avi_infoframe * frame ,
2017-01-11 15:57:24 +03:00
const struct drm_display_mode * mode ,
2017-01-11 15:57:23 +03:00
enum hdmi_quantization_range rgb_quant_range ,
bool rgb_quant_range_selectable ) ;
2012-11-21 18:31:35 +04:00
2014-10-28 17:20:47 +03:00
/**
* drm_eld_mnl - Get ELD monitor name length in bytes .
* @ eld : pointer to an eld memory structure with mnl set
*/
static inline int drm_eld_mnl ( const uint8_t * eld )
{
return ( eld [ DRM_ELD_CEA_EDID_VER_MNL ] & DRM_ELD_MNL_MASK ) > > DRM_ELD_MNL_SHIFT ;
}
2015-03-28 21:13:52 +03:00
/**
* drm_eld_sad - Get ELD SAD structures .
* @ eld : pointer to an eld memory structure with sad_count set
*/
static inline const uint8_t * drm_eld_sad ( const uint8_t * eld )
{
unsigned int ver , mnl ;
ver = ( eld [ DRM_ELD_VER ] & DRM_ELD_VER_MASK ) > > DRM_ELD_VER_SHIFT ;
if ( ver ! = 2 & & ver ! = 31 )
return NULL ;
mnl = drm_eld_mnl ( eld ) ;
if ( mnl > 16 )
return NULL ;
return eld + DRM_ELD_CEA_SAD ( mnl , 0 ) ;
}
2014-10-28 17:20:47 +03:00
/**
* drm_eld_sad_count - Get ELD SAD count .
* @ eld : pointer to an eld memory structure with sad_count set
*/
static inline int drm_eld_sad_count ( const uint8_t * eld )
{
return ( eld [ DRM_ELD_SAD_COUNT_CONN_TYPE ] & DRM_ELD_SAD_COUNT_MASK ) > >
DRM_ELD_SAD_COUNT_SHIFT ;
}
/**
* drm_eld_calc_baseline_block_size - Calculate baseline block size in bytes
* @ eld : pointer to an eld memory structure with mnl and sad_count set
*
* This is a helper for determining the payload size of the baseline block , in
* bytes , for e . g . setting the Baseline_ELD_Len field in the ELD header block .
*/
static inline int drm_eld_calc_baseline_block_size ( const uint8_t * eld )
{
return DRM_ELD_MONITOR_NAME_STRING - DRM_ELD_HEADER_BLOCK_SIZE +
drm_eld_mnl ( eld ) + drm_eld_sad_count ( eld ) * 3 ;
}
/**
* drm_eld_size - Get ELD size in bytes
* @ eld : pointer to a complete eld memory structure
*
* The returned value does not include the vendor block . It ' s vendor specific ,
* and comprises of the remaining bytes in the ELD memory buffer after
* drm_eld_size ( ) bytes of header and baseline block .
*
* The returned value is guaranteed to be a multiple of 4.
*/
static inline int drm_eld_size ( const uint8_t * eld )
{
return DRM_ELD_HEADER_BLOCK_SIZE + eld [ DRM_ELD_BASELINE_ELD_LEN ] * 4 ;
}
2017-01-03 18:52:50 +03:00
/**
* drm_eld_get_spk_alloc - Get speaker allocation
* @ eld : pointer to an ELD memory structure
*
* The returned value is the speakers mask . User has to use % DRM_ELD_SPEAKER
* field definitions to identify speakers .
*/
static inline u8 drm_eld_get_spk_alloc ( const uint8_t * eld )
{
return eld [ DRM_ELD_SPEAKER ] & DRM_ELD_SPEAKER_MASK ;
}
2016-02-12 05:16:08 +03:00
/**
* drm_eld_get_conn_type - Get device type hdmi / dp connected
* @ eld : pointer to an ELD memory structure
*
* The caller need to use % DRM_ELD_CONN_TYPE_HDMI or % DRM_ELD_CONN_TYPE_DP to
* identify the display type connected .
*/
static inline u8 drm_eld_get_conn_type ( const uint8_t * eld )
{
return eld [ DRM_ELD_SAD_COUNT_CONN_TYPE ] & DRM_ELD_CONN_TYPE_MASK ;
}
2016-08-31 19:09:06 +03:00
bool drm_probe_ddc ( struct i2c_adapter * adapter ) ;
2012-04-27 13:11:58 +04:00
struct edid * drm_do_get_edid ( struct drm_connector * connector ,
int ( * get_edid_block ) ( void * data , u8 * buf , unsigned int block ,
size_t len ) ,
void * data ) ;
2016-08-31 19:09:06 +03:00
struct edid * drm_get_edid ( struct drm_connector * connector ,
struct i2c_adapter * adapter ) ;
struct edid * drm_get_edid_switcheroo ( struct drm_connector * connector ,
struct i2c_adapter * adapter ) ;
struct edid * drm_edid_duplicate ( const struct edid * edid ) ;
int drm_add_edid_modes ( struct drm_connector * connector , struct edid * edid ) ;
u8 drm_match_cea_mode ( const struct drm_display_mode * to_match ) ;
enum hdmi_picture_aspect drm_get_cea_aspect_ratio ( const u8 video_code ) ;
bool drm_detect_hdmi_monitor ( struct edid * edid ) ;
bool drm_detect_monitor_audio ( struct edid * edid ) ;
bool drm_rgb_quant_range_selectable ( struct edid * edid ) ;
2017-01-11 17:18:35 +03:00
enum hdmi_quantization_range
drm_default_rgb_quant_range ( const struct drm_display_mode * mode ) ;
2016-08-31 19:09:06 +03:00
int drm_add_modes_noedid ( struct drm_connector * connector ,
int hdisplay , int vdisplay ) ;
void drm_set_preferred_mode ( struct drm_connector * connector ,
int hpref , int vpref ) ;
int drm_edid_header_is_valid ( const u8 * raw_edid ) ;
bool drm_edid_block_valid ( u8 * raw_edid , int block , bool print_bad_edid ,
bool * edid_corrupt ) ;
bool drm_edid_is_valid ( struct edid * edid ) ;
void drm_edid_get_monitor_name ( struct edid * edid , char * name ,
int buflen ) ;
struct drm_display_mode * drm_mode_find_dmt ( struct drm_device * dev ,
int hsize , int vsize , int fresh ,
bool rb ) ;
2008-11-08 01:05:41 +03:00
# endif /* __DRM_EDID_H__ */