1 /* SPDX-License-Identifier: GPL-2.0-only */ 2 /* 3 * Copyright (c) 2012-2020, The Linux Foundation. All rights reserved. 4 */ 5 6 #ifndef _DP_PANEL_H_ 7 #define _DP_PANEL_H_ 8 9 #include <drm/drm_modes.h> 10 #include <drm/msm_drm.h> 11 12 #include "dp_aux.h" 13 #include "dp_link.h" 14 15 struct edid; 16 17 struct msm_dp_display_mode { 18 struct drm_display_mode drm_mode; 19 u32 bpp; 20 u32 h_active_low; 21 u32 v_active_low; 22 bool out_fmt_is_yuv_420; 23 }; 24 25 struct msm_dp_panel_psr { 26 u8 version; 27 u8 capabilities; 28 }; 29 30 struct msm_dp_panel { 31 /* dpcd raw data */ 32 u8 dpcd[DP_RECEIVER_CAP_SIZE]; 33 u8 downstream_ports[DP_MAX_DOWNSTREAM_PORTS]; 34 35 struct msm_dp_link_info link_info; 36 const struct drm_edid *drm_edid; 37 struct drm_connector *connector; 38 struct msm_dp_display_mode msm_dp_mode; 39 struct msm_dp_panel_psr psr_cap; 40 bool video_test; 41 bool vsc_sdp_supported; 42 u32 hw_revision; 43 44 u32 max_bw_code; 45 }; 46 47 int msm_dp_panel_init_panel_info(struct msm_dp_panel *msm_dp_panel); 48 int msm_dp_panel_deinit(struct msm_dp_panel *msm_dp_panel); 49 int msm_dp_panel_timing_cfg(struct msm_dp_panel *msm_dp_panel, bool wide_bus_en); 50 int msm_dp_panel_read_sink_caps(struct msm_dp_panel *msm_dp_panel, 51 struct drm_connector *connector); 52 void msm_dp_panel_unplugged(struct msm_dp_panel *msm_dp_panel, 53 struct drm_connector *connector); 54 u32 msm_dp_panel_get_mode_bpp(struct msm_dp_panel *msm_dp_panel, u32 mode_max_bpp, 55 u32 mode_pclk_khz); 56 int msm_dp_panel_get_modes(struct msm_dp_panel *msm_dp_panel, 57 struct drm_connector *connector); 58 void msm_dp_panel_handle_sink_request(struct msm_dp_panel *msm_dp_panel); 59 void msm_dp_panel_tpg_config(struct msm_dp_panel *msm_dp_panel, bool enable); 60 61 void msm_dp_panel_clear_dsc_dto(struct msm_dp_panel *msm_dp_panel); 62 63 void msm_dp_panel_enable_vsc_sdp(struct msm_dp_panel *msm_dp_panel, struct dp_sdp *vsc_sdp); 64 void msm_dp_panel_disable_vsc_sdp(struct msm_dp_panel *msm_dp_panel); 65 66 /** 67 * is_link_rate_valid() - validates the link rate 68 * @bw_code: link rate requested by the sink 69 * 70 * Returns: true if the requested link rate is supported. 71 */ 72 static inline bool is_link_rate_valid(u32 bw_code) 73 { 74 return (bw_code == DP_LINK_BW_1_62 || 75 bw_code == DP_LINK_BW_2_7 || 76 bw_code == DP_LINK_BW_5_4 || 77 bw_code == DP_LINK_BW_8_1); 78 } 79 80 /** 81 * is_lane_count_valid() - validates the lane count 82 * @lane_count: lane count requested by the sink 83 * 84 * Returns: true if the requested lane count is supported. 85 */ 86 static inline bool is_lane_count_valid(u32 lane_count) 87 { 88 return (lane_count == 1 || 89 lane_count == 2 || 90 lane_count == 4); 91 } 92 93 struct msm_dp_panel *msm_dp_panel_get(struct device *dev, struct drm_dp_aux *aux, 94 struct msm_dp_link *link, 95 void __iomem *link_base, 96 void __iomem *p0_base); 97 void msm_dp_panel_put(struct msm_dp_panel *msm_dp_panel); 98 #endif /* _DP_PANEL_H_ */ 99