drm/i915: rename intel_drv.h to display/intel_display_types.h
authorJani Nikula <jani.nikula@intel.com>
Tue, 6 Aug 2019 11:39:33 +0000 (14:39 +0300)
committerJani Nikula <jani.nikula@intel.com>
Wed, 7 Aug 2019 09:43:50 +0000 (12:43 +0300)
Everything about the file is about display, and mostly about types
related to display. Move under display/ as intel_display_types.h to
reflect the facts.

There's still plenty to clean up, but start off with moving the file
where it logically belongs and naming according to contents.

v2: fix the include guard name in the renamed file

Reviewed-by: Chris Wilson <chris@chris-wilson.co.uk>
Signed-off-by: Jani Nikula <jani.nikula@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20190806113933.11799-1-jani.nikula@intel.com
73 files changed:
drivers/gpu/drm/i915/display/dvo_ch7017.c
drivers/gpu/drm/i915/display/dvo_ch7xxx.c
drivers/gpu/drm/i915/display/dvo_ivch.c
drivers/gpu/drm/i915/display/dvo_ns2501.c
drivers/gpu/drm/i915/display/dvo_sil164.c
drivers/gpu/drm/i915/display/dvo_tfp410.c
drivers/gpu/drm/i915/display/intel_atomic.c
drivers/gpu/drm/i915/display/intel_atomic_plane.c
drivers/gpu/drm/i915/display/intel_audio.c
drivers/gpu/drm/i915/display/intel_bw.c
drivers/gpu/drm/i915/display/intel_cdclk.c
drivers/gpu/drm/i915/display/intel_color.c
drivers/gpu/drm/i915/display/intel_combo_phy.c
drivers/gpu/drm/i915/display/intel_connector.c
drivers/gpu/drm/i915/display/intel_crt.c
drivers/gpu/drm/i915/display/intel_ddi.c
drivers/gpu/drm/i915/display/intel_display.c
drivers/gpu/drm/i915/display/intel_display_power.c
drivers/gpu/drm/i915/display/intel_display_types.h [new file with mode: 0644]
drivers/gpu/drm/i915/display/intel_dp.c
drivers/gpu/drm/i915/display/intel_dp_aux_backlight.c
drivers/gpu/drm/i915/display/intel_dp_link_training.c
drivers/gpu/drm/i915/display/intel_dp_mst.c
drivers/gpu/drm/i915/display/intel_dpio_phy.c
drivers/gpu/drm/i915/display/intel_dpll_mgr.c
drivers/gpu/drm/i915/display/intel_dsi.h
drivers/gpu/drm/i915/display/intel_dsi_dcs_backlight.c
drivers/gpu/drm/i915/display/intel_dsi_vbt.c
drivers/gpu/drm/i915/display/intel_dvo.c
drivers/gpu/drm/i915/display/intel_fbc.c
drivers/gpu/drm/i915/display/intel_fbdev.c
drivers/gpu/drm/i915/display/intel_fifo_underrun.c
drivers/gpu/drm/i915/display/intel_frontbuffer.c
drivers/gpu/drm/i915/display/intel_gmbus.c
drivers/gpu/drm/i915/display/intel_hdcp.c
drivers/gpu/drm/i915/display/intel_hdmi.c
drivers/gpu/drm/i915/display/intel_hotplug.c
drivers/gpu/drm/i915/display/intel_lspcon.c
drivers/gpu/drm/i915/display/intel_lvds.c
drivers/gpu/drm/i915/display/intel_opregion.c
drivers/gpu/drm/i915/display/intel_overlay.c
drivers/gpu/drm/i915/display/intel_panel.c
drivers/gpu/drm/i915/display/intel_pipe_crc.c
drivers/gpu/drm/i915/display/intel_psr.c
drivers/gpu/drm/i915/display/intel_quirks.c
drivers/gpu/drm/i915/display/intel_sdvo.c
drivers/gpu/drm/i915/display/intel_sprite.c
drivers/gpu/drm/i915/display/intel_tc.c
drivers/gpu/drm/i915/display/intel_tv.c
drivers/gpu/drm/i915/display/intel_vdsc.c
drivers/gpu/drm/i915/display/vlv_dsi.c
drivers/gpu/drm/i915/display/vlv_dsi_pll.c
drivers/gpu/drm/i915/gem/i915_gem_client_blt.c
drivers/gpu/drm/i915/gem/i915_gem_execbuffer.c
drivers/gpu/drm/i915/gem/i915_gem_mman.c
drivers/gpu/drm/i915/gem/i915_gem_object_blt.c
drivers/gpu/drm/i915/gem/i915_gem_userptr.c
drivers/gpu/drm/i915/gt/intel_reset.c
drivers/gpu/drm/i915/i915_debugfs.c
drivers/gpu/drm/i915/i915_drv.c
drivers/gpu/drm/i915/i915_gem.c
drivers/gpu/drm/i915/i915_gem_evict.c
drivers/gpu/drm/i915/i915_gem_fence_reg.c
drivers/gpu/drm/i915/i915_gem_gtt.c
drivers/gpu/drm/i915/i915_irq.c
drivers/gpu/drm/i915/i915_suspend.c
drivers/gpu/drm/i915/i915_sysfs.c
drivers/gpu/drm/i915/i915_trace.h
drivers/gpu/drm/i915/i915_vgpu.c
drivers/gpu/drm/i915/intel_drv.h [deleted file]
drivers/gpu/drm/i915/intel_pm.c
drivers/gpu/drm/i915/intel_sideband.c
drivers/gpu/drm/i915/intel_uncore.c

index 602380fe74f3e9277d854f98f926ac158a06e998..0589994dde113f562eb0da290cbb71bedbff6065 100644 (file)
@@ -25,7 +25,7 @@
  *
  */
 
-#include "intel_drv.h"
+#include "intel_display_types.h"
 #include "intel_dvo_dev.h"
 
 #define CH7017_TV_DISPLAY_MODE         0x00
index e070bebee7b5eb5f74b69b2e9c92031dc891709b..54f58ba44b9f0d21e40acf9b8f131e6d9bf1f429 100644 (file)
@@ -26,7 +26,7 @@ SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
 
 **************************************************************************/
 
-#include "intel_drv.h"
+#include "intel_display_types.h"
 #include "intel_dvo_dev.h"
 
 #define CH7xxx_REG_VID         0x4a
index 09dba35f3ffae963c4a785b821195a629e5cdad7..f43d8c610d3f9635e42a6536252a7dede97bbac1 100644 (file)
@@ -29,7 +29,7 @@
  *
  */
 
-#include "intel_drv.h"
+#include "intel_display_types.h"
 #include "intel_dvo_dev.h"
 
 /*
index c83a5d88d62bd8aabb2816ff5c090f205918c317..a724a8755673c318b110d1dfa33ee87d75a92d1a 100644 (file)
@@ -28,7 +28,7 @@
 
 #include "i915_drv.h"
 #include "i915_reg.h"
-#include "intel_drv.h"
+#include "intel_display_types.h"
 #include "intel_dvo_dev.h"
 
 #define NS2501_VID 0x1305
index 04698eaeb632e610283827340e912b9d3f9ae827..0dfa0a0209ff879fc2156df4bbbcc88a0952c628 100644 (file)
@@ -26,7 +26,7 @@ SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
 
 **************************************************************************/
 
-#include "intel_drv.h"
+#include "intel_display_types.h"
 #include "intel_dvo_dev.h"
 
 #define SIL164_VID 0x0001
index 623114ee73cdefd25ddaef44eb21dfa457b94958..009d65b0f3e9649c0ca103348454a93ccd18acdc 100644 (file)
@@ -25,7 +25,7 @@
  *
  */
 
-#include "intel_drv.h"
+#include "intel_display_types.h"
 #include "intel_dvo_dev.h"
 
 /* register definitions according to the TFP410 data sheet */
index 90ca11a4ae887188a0ef2137a72ceb7c23bff6f6..d3fb75bb9eb1d1b4c87a58bb8ca108cef42a7aa9 100644 (file)
@@ -35,7 +35,7 @@
 #include <drm/drm_plane_helper.h>
 
 #include "intel_atomic.h"
-#include "intel_drv.h"
+#include "intel_display_types.h"
 #include "intel_hdcp.h"
 #include "intel_sprite.h"
 
index c14c8dade9a45fce036eb10d8afba6b993bafdc0..d1fcdf206da41446f3069cfd8491c29f1c4685c1 100644 (file)
@@ -37,7 +37,7 @@
 
 #include "i915_trace.h"
 #include "intel_atomic_plane.h"
-#include "intel_drv.h"
+#include "intel_display_types.h"
 #include "intel_pm.h"
 #include "intel_sprite.h"
 
index c8fd35a7ca4255715c7bbc2faf8c82957e809bb5..ddcccf4408c37db690c73b6b25aec95fcd30501e 100644 (file)
@@ -29,7 +29,7 @@
 
 #include "i915_drv.h"
 #include "intel_audio.h"
-#include "intel_drv.h"
+#include "intel_display_types.h"
 #include "intel_lpe_audio.h"
 
 /**
index e59f8be7c99844d8c486fd360a960c171a46cdaa..688858ebe4d0a67ec1ee2a16a52947110e0c5e9c 100644 (file)
@@ -6,7 +6,7 @@
 #include <drm/drm_atomic_state_helper.h>
 
 #include "intel_bw.h"
-#include "intel_drv.h"
+#include "intel_display_types.h"
 #include "intel_sideband.h"
 
 /* Parameters for Qclk Geyserville (QGV) */
index 93b0d190c184d61822b00e0c099ea9b6c311c439..59c0ceb21aac50e30ecacd0734c2a3b5329d6b76 100644 (file)
@@ -22,7 +22,7 @@
  */
 
 #include "intel_cdclk.h"
-#include "intel_drv.h"
+#include "intel_display_types.h"
 #include "intel_sideband.h"
 
 /**
index 23a84dd7989fb1986219dcf70202db16b2322ac2..71a0201437a9ab42e9268facb1a3a58549723e7a 100644 (file)
@@ -23,7 +23,7 @@
  */
 
 #include "intel_color.h"
-#include "intel_drv.h"
+#include "intel_display_types.h"
 
 #define CTM_COEFF_SIGN (1ULL << 63)
 
index ac8218a040ab0a0127ec81d769fc0c06d91af329..44bbc7e74fc371adb501c6c6c5e22657293882cc 100644 (file)
@@ -4,7 +4,7 @@
  */
 
 #include "intel_combo_phy.h"
-#include "intel_drv.h"
+#include "intel_display_types.h"
 
 #define for_each_combo_phy(__dev_priv, __phy) \
        for ((__phy) = PHY_A; (__phy) < I915_MAX_PHYS; (__phy)++)       \
index cf8823ce960669fb030dbad9446116aaa94cc7f9..308ec63207ee272cf894e8a7ac15517f2396bf3a 100644 (file)
@@ -33,7 +33,7 @@
 
 #include "i915_drv.h"
 #include "intel_connector.h"
-#include "intel_drv.h"
+#include "intel_display_types.h"
 #include "intel_hdcp.h"
 
 int intel_connector_init(struct intel_connector *connector)
index 3fcf2f84bcce2723bc1b5e6ab9a2cc2b2333324b..067eb14dbf8062b8b06135186499831422d62742 100644 (file)
@@ -38,7 +38,7 @@
 #include "intel_connector.h"
 #include "intel_crt.h"
 #include "intel_ddi.h"
-#include "intel_drv.h"
+#include "intel_display_types.h"
 #include "intel_fifo_underrun.h"
 #include "intel_gmbus.h"
 #include "intel_hotplug.h"
index fb58845020dc888f6f2fe6ee8992e050a580ae2c..bde9e0f61cef8bca1f46a7e48398ee4e00c8e590 100644 (file)
 #include "intel_combo_phy.h"
 #include "intel_connector.h"
 #include "intel_ddi.h"
+#include "intel_display_types.h"
 #include "intel_dp.h"
 #include "intel_dp_link_training.h"
 #include "intel_dpio_phy.h"
-#include "intel_drv.h"
 #include "intel_dsi.h"
 #include "intel_fifo_underrun.h"
 #include "intel_gmbus.h"
index 51e4f6798a6bb73864f117844cbe3f674d9b0721..503e39e9adfdbb878a6244072be5769fecefa48f 100644 (file)
@@ -62,9 +62,9 @@
 #include "intel_atomic.h"
 #include "intel_atomic_plane.h"
 #include "intel_bw.h"
-#include "intel_color.h"
 #include "intel_cdclk.h"
-#include "intel_drv.h"
+#include "intel_color.h"
+#include "intel_display_types.h"
 #include "intel_fbc.h"
 #include "intel_fbdev.h"
 #include "intel_fifo_underrun.h"
index dd2a50b8ba0a47cffd965fc90060247ccfa1cf2d..e201dc6f977a1ccad7d4d904067b696943c5bd15 100644 (file)
@@ -13,8 +13,8 @@
 #include "intel_cdclk.h"
 #include "intel_combo_phy.h"
 #include "intel_csr.h"
+#include "intel_display_types.h"
 #include "intel_dpio_phy.h"
-#include "intel_drv.h"
 #include "intel_hotplug.h"
 #include "intel_sideband.h"
 #include "intel_tc.h"
diff --git a/drivers/gpu/drm/i915/display/intel_display_types.h b/drivers/gpu/drm/i915/display/intel_display_types.h
new file mode 100644 (file)
index 0000000..3283f8d
--- /dev/null
@@ -0,0 +1,1510 @@
+/*
+ * Copyright (c) 2006 Dave Airlie <airlied@linux.ie>
+ * Copyright (c) 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 (including the next
+ * paragraph) 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 AUTHORS OR COPYRIGHT HOLDERS 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 __INTEL_DISPLAY_TYPES_H__
+#define __INTEL_DISPLAY_TYPES_H__
+
+#include <linux/async.h>
+#include <linux/i2c.h>
+#include <linux/sched/clock.h>
+
+#include <drm/drm_atomic.h>
+#include <drm/drm_crtc.h>
+#include <drm/drm_dp_dual_mode_helper.h>
+#include <drm/drm_dp_mst_helper.h>
+#include <drm/drm_encoder.h>
+#include <drm/drm_fb_helper.h>
+#include <drm/drm_probe_helper.h>
+#include <drm/drm_rect.h>
+#include <drm/drm_vblank.h>
+#include <drm/i915_drm.h>
+#include <drm/i915_mei_hdcp_interface.h>
+#include <media/cec-notifier.h>
+
+#include "i915_drv.h"
+
+struct drm_printer;
+
+/*
+ * Display related stuff
+ */
+
+/* these are outputs from the chip - integrated only
+   external chips are via DVO or SDVO output */
+enum intel_output_type {
+       INTEL_OUTPUT_UNUSED = 0,
+       INTEL_OUTPUT_ANALOG = 1,
+       INTEL_OUTPUT_DVO = 2,
+       INTEL_OUTPUT_SDVO = 3,
+       INTEL_OUTPUT_LVDS = 4,
+       INTEL_OUTPUT_TVOUT = 5,
+       INTEL_OUTPUT_HDMI = 6,
+       INTEL_OUTPUT_DP = 7,
+       INTEL_OUTPUT_EDP = 8,
+       INTEL_OUTPUT_DSI = 9,
+       INTEL_OUTPUT_DDI = 10,
+       INTEL_OUTPUT_DP_MST = 11,
+};
+
+struct intel_framebuffer {
+       struct drm_framebuffer base;
+       struct intel_rotation_info rot_info;
+
+       /* for each plane in the normal GTT view */
+       struct {
+               unsigned int x, y;
+       } normal[2];
+       /* for each plane in the rotated GTT view */
+       struct {
+               unsigned int x, y;
+               unsigned int pitch; /* pixels */
+       } rotated[2];
+};
+
+struct intel_fbdev {
+       struct drm_fb_helper helper;
+       struct intel_framebuffer *fb;
+       struct i915_vma *vma;
+       unsigned long vma_flags;
+       async_cookie_t cookie;
+       int preferred_bpp;
+
+       /* Whether or not fbdev hpd processing is temporarily suspended */
+       bool hpd_suspended : 1;
+       /* Set when a hotplug was received while HPD processing was
+        * suspended
+        */
+       bool hpd_waiting : 1;
+
+       /* Protects hpd_suspended */
+       struct mutex hpd_lock;
+};
+
+enum intel_hotplug_state {
+       INTEL_HOTPLUG_UNCHANGED,
+       INTEL_HOTPLUG_CHANGED,
+       INTEL_HOTPLUG_RETRY,
+};
+
+struct intel_encoder {
+       struct drm_encoder base;
+
+       enum intel_output_type type;
+       enum port port;
+       unsigned int cloneable;
+       enum intel_hotplug_state (*hotplug)(struct intel_encoder *encoder,
+                                           struct intel_connector *connector,
+                                           bool irq_received);
+       enum intel_output_type (*compute_output_type)(struct intel_encoder *,
+                                                     struct intel_crtc_state *,
+                                                     struct drm_connector_state *);
+       int (*compute_config)(struct intel_encoder *,
+                             struct intel_crtc_state *,
+                             struct drm_connector_state *);
+       void (*update_prepare)(struct intel_atomic_state *,
+                              struct intel_encoder *,
+                              struct intel_crtc *);
+       void (*pre_pll_enable)(struct intel_encoder *,
+                              const struct intel_crtc_state *,
+                              const struct drm_connector_state *);
+       void (*pre_enable)(struct intel_encoder *,
+                          const struct intel_crtc_state *,
+                          const struct drm_connector_state *);
+       void (*enable)(struct intel_encoder *,
+                      const struct intel_crtc_state *,
+                      const struct drm_connector_state *);
+       void (*update_complete)(struct intel_atomic_state *,
+                               struct intel_encoder *,
+                               struct intel_crtc *);
+       void (*disable)(struct intel_encoder *,
+                       const struct intel_crtc_state *,
+                       const struct drm_connector_state *);
+       void (*post_disable)(struct intel_encoder *,
+                            const struct intel_crtc_state *,
+                            const struct drm_connector_state *);
+       void (*post_pll_disable)(struct intel_encoder *,
+                                const struct intel_crtc_state *,
+                                const struct drm_connector_state *);
+       void (*update_pipe)(struct intel_encoder *,
+                           const struct intel_crtc_state *,
+                           const struct drm_connector_state *);
+       /* Read out the current hw state of this connector, returning true if
+        * the encoder is active. If the encoder is enabled it also set the pipe
+        * it is connected to in the pipe parameter. */
+       bool (*get_hw_state)(struct intel_encoder *, enum pipe *pipe);
+       /* Reconstructs the equivalent mode flags for the current hardware
+        * state. This must be called _after_ display->get_pipe_config has
+        * pre-filled the pipe config. Note that intel_encoder->base.crtc must
+        * be set correctly before calling this function. */
+       void (*get_config)(struct intel_encoder *,
+                          struct intel_crtc_state *pipe_config);
+       /*
+        * Acquires the power domains needed for an active encoder during
+        * hardware state readout.
+        */
+       void (*get_power_domains)(struct intel_encoder *encoder,
+                                 struct intel_crtc_state *crtc_state);
+       /*
+        * Called during system suspend after all pending requests for the
+        * encoder are flushed (for example for DP AUX transactions) and
+        * device interrupts are disabled.
+        */
+       void (*suspend)(struct intel_encoder *);
+       int crtc_mask;
+       enum hpd_pin hpd_pin;
+       enum intel_display_power_domain power_domain;
+       /* for communication with audio component; protected by av_mutex */
+       const struct drm_connector *audio_connector;
+};
+
+struct intel_panel {
+       struct drm_display_mode *fixed_mode;
+       struct drm_display_mode *downclock_mode;
+
+       /* backlight */
+       struct {
+               bool present;
+               u32 level;
+               u32 min;
+               u32 max;
+               bool enabled;
+               bool combination_mode;  /* gen 2/4 only */
+               bool active_low_pwm;
+               bool alternate_pwm_increment;   /* lpt+ */
+
+               /* PWM chip */
+               bool util_pin_active_low;       /* bxt+ */
+               u8 controller;          /* bxt+ only */
+               struct pwm_device *pwm;
+
+               struct backlight_device *device;
+
+               /* Connector and platform specific backlight functions */
+               int (*setup)(struct intel_connector *connector, enum pipe pipe);
+               u32 (*get)(struct intel_connector *connector);
+               void (*set)(const struct drm_connector_state *conn_state, u32 level);
+               void (*disable)(const struct drm_connector_state *conn_state);
+               void (*enable)(const struct intel_crtc_state *crtc_state,
+                              const struct drm_connector_state *conn_state);
+               u32 (*hz_to_pwm)(struct intel_connector *connector, u32 hz);
+               void (*power)(struct intel_connector *, bool enable);
+       } backlight;
+};
+
+struct intel_digital_port;
+
+enum check_link_response {
+       HDCP_LINK_PROTECTED     = 0,
+       HDCP_TOPOLOGY_CHANGE,
+       HDCP_LINK_INTEGRITY_FAILURE,
+       HDCP_REAUTH_REQUEST
+};
+
+/*
+ * This structure serves as a translation layer between the generic HDCP code
+ * and the bus-specific code. What that means is that HDCP over HDMI differs
+ * from HDCP over DP, so to account for these differences, we need to
+ * communicate with the receiver through this shim.
+ *
+ * For completeness, the 2 buses differ in the following ways:
+ *     - DP AUX vs. DDC
+ *             HDCP registers on the receiver are set via DP AUX for DP, and
+ *             they are set via DDC for HDMI.
+ *     - Receiver register offsets
+ *             The offsets of the registers are different for DP vs. HDMI
+ *     - Receiver register masks/offsets
+ *             For instance, the ready bit for the KSV fifo is in a different
+ *             place on DP vs HDMI
+ *     - Receiver register names
+ *             Seriously. In the DP spec, the 16-bit register containing
+ *             downstream information is called BINFO, on HDMI it's called
+ *             BSTATUS. To confuse matters further, DP has a BSTATUS register
+ *             with a completely different definition.
+ *     - KSV FIFO
+ *             On HDMI, the ksv fifo is read all at once, whereas on DP it must
+ *             be read 3 keys at a time
+ *     - Aksv output
+ *             Since Aksv is hidden in hardware, there's different procedures
+ *             to send it over DP AUX vs DDC
+ */
+struct intel_hdcp_shim {
+       /* Outputs the transmitter's An and Aksv values to the receiver. */
+       int (*write_an_aksv)(struct intel_digital_port *intel_dig_port, u8 *an);
+
+       /* Reads the receiver's key selection vector */
+       int (*read_bksv)(struct intel_digital_port *intel_dig_port, u8 *bksv);
+
+       /*
+        * Reads BINFO from DP receivers and BSTATUS from HDMI receivers. The
+        * definitions are the same in the respective specs, but the names are
+        * different. Call it BSTATUS since that's the name the HDMI spec
+        * uses and it was there first.
+        */
+       int (*read_bstatus)(struct intel_digital_port *intel_dig_port,
+                           u8 *bstatus);
+
+       /* Determines whether a repeater is present downstream */
+       int (*repeater_present)(struct intel_digital_port *intel_dig_port,
+                               bool *repeater_present);
+
+       /* Reads the receiver's Ri' value */
+       int (*read_ri_prime)(struct intel_digital_port *intel_dig_port, u8 *ri);
+
+       /* Determines if the receiver's KSV FIFO is ready for consumption */
+       int (*read_ksv_ready)(struct intel_digital_port *intel_dig_port,
+                             bool *ksv_ready);
+
+       /* Reads the ksv fifo for num_downstream devices */
+       int (*read_ksv_fifo)(struct intel_digital_port *intel_dig_port,
+                            int num_downstream, u8 *ksv_fifo);
+
+       /* Reads a 32-bit part of V' from the receiver */
+       int (*read_v_prime_part)(struct intel_digital_port *intel_dig_port,
+                                int i, u32 *part);
+
+       /* Enables HDCP signalling on the port */
+       int (*toggle_signalling)(struct intel_digital_port *intel_dig_port,
+                                bool enable);
+
+       /* Ensures the link is still protected */
+       bool (*check_link)(struct intel_digital_port *intel_dig_port);
+
+       /* Detects panel's hdcp capability. This is optional for HDMI. */
+       int (*hdcp_capable)(struct intel_digital_port *intel_dig_port,
+                           bool *hdcp_capable);
+
+       /* HDCP adaptation(DP/HDMI) required on the port */
+       enum hdcp_wired_protocol protocol;
+
+       /* Detects whether sink is HDCP2.2 capable */
+       int (*hdcp_2_2_capable)(struct intel_digital_port *intel_dig_port,
+                               bool *capable);
+
+       /* Write HDCP2.2 messages */
+       int (*write_2_2_msg)(struct intel_digital_port *intel_dig_port,
+                            void *buf, size_t size);
+
+       /* Read HDCP2.2 messages */
+       int (*read_2_2_msg)(struct intel_digital_port *intel_dig_port,
+                           u8 msg_id, void *buf, size_t size);
+
+       /*
+        * Implementation of DP HDCP2.2 Errata for the communication of stream
+        * type to Receivers. In DP HDCP2.2 Stream type is one of the input to
+        * the HDCP2.2 Cipher for En/De-Cryption. Not applicable for HDMI.
+        */
+       int (*config_stream_type)(struct intel_digital_port *intel_dig_port,
+                                 bool is_repeater, u8 type);
+
+       /* HDCP2.2 Link Integrity Check */
+       int (*check_2_2_link)(struct intel_digital_port *intel_dig_port);
+};
+
+struct intel_hdcp {
+       const struct intel_hdcp_shim *shim;
+       /* Mutex for hdcp state of the connector */
+       struct mutex mutex;
+       u64 value;
+       struct delayed_work check_work;
+       struct work_struct prop_work;
+
+       /* HDCP1.4 Encryption status */
+       bool hdcp_encrypted;
+
+       /* HDCP2.2 related definitions */
+       /* Flag indicates whether this connector supports HDCP2.2 or not. */
+       bool hdcp2_supported;
+
+       /* HDCP2.2 Encryption status */
+       bool hdcp2_encrypted;
+
+       /*
+        * Content Stream Type defined by content owner. TYPE0(0x0) content can
+        * flow in the link protected by HDCP2.2 or HDCP1.4, where as TYPE1(0x1)
+        * content can flow only through a link protected by HDCP2.2.
+        */
+       u8 content_type;
+       struct hdcp_port_data port_data;
+
+       bool is_paired;
+       bool is_repeater;
+
+       /*
+        * Count of ReceiverID_List received. Initialized to 0 at AKE_INIT.
+        * Incremented after processing the RepeaterAuth_Send_ReceiverID_List.
+        * When it rolls over re-auth has to be triggered.
+        */
+       u32 seq_num_v;
+
+       /*
+        * Count of RepeaterAuth_Stream_Manage msg propagated.
+        * Initialized to 0 on AKE_INIT. Incremented after every successful
+        * transmission of RepeaterAuth_Stream_Manage message. When it rolls
+        * over re-Auth has to be triggered.
+        */
+       u32 seq_num_m;
+
+       /*
+        * Work queue to signal the CP_IRQ. Used for the waiters to read the
+        * available information from HDCP DP sink.
+        */
+       wait_queue_head_t cp_irq_queue;
+       atomic_t cp_irq_count;
+       int cp_irq_count_cached;
+};
+
+struct intel_connector {
+       struct drm_connector base;
+       /*
+        * The fixed encoder this connector is connected to.
+        */
+       struct intel_encoder *encoder;
+
+       /* ACPI device id for ACPI and driver cooperation */
+       u32 acpi_device_id;
+
+       /* Reads out the current hw, returning true if the connector is enabled
+        * and active (i.e. dpms ON state). */
+       bool (*get_hw_state)(struct intel_connector *);
+
+       /* Panel info for eDP and LVDS */
+       struct intel_panel panel;
+
+       /* Cached EDID for eDP and LVDS. May hold ERR_PTR for invalid EDID. */
+       struct edid *edid;
+       struct edid *detect_edid;
+
+       /* since POLL and HPD connectors may use the same HPD line keep the native
+          state of connector->polled in case hotplug storm detection changes it */
+       u8 polled;
+
+       void *port; /* store this opaque as its illegal to dereference it */
+
+       struct intel_dp *mst_port;
+
+       /* Work struct to schedule a uevent on link train failure */
+       struct work_struct modeset_retry_work;
+
+       struct intel_hdcp hdcp;
+};
+
+struct intel_digital_connector_state {
+       struct drm_connector_state base;
+
+       enum hdmi_force_audio force_audio;
+       int broadcast_rgb;
+};
+
+#define to_intel_digital_connector_state(x) container_of(x, struct intel_digital_connector_state, base)
+
+struct dpll {
+       /* given values */
+       int n;
+       int m1, m2;
+       int p1, p2;
+       /* derived values */
+       int     dot;
+       int     vco;
+       int     m;
+       int     p;
+};
+
+struct intel_atomic_state {
+       struct drm_atomic_state base;
+
+       intel_wakeref_t wakeref;
+
+       struct {
+               /*
+                * Logical state of cdclk (used for all scaling, watermark,
+                * etc. calculations and checks). This is computed as if all
+                * enabled crtcs were active.
+                */
+               struct intel_cdclk_state logical;
+
+               /*
+                * Actual state of cdclk, can be different from the logical
+                * state only when all crtc's are DPMS off.
+                */
+               struct intel_cdclk_state actual;
+
+               int force_min_cdclk;
+               bool force_min_cdclk_changed;
+               /* pipe to which cd2x update is synchronized */
+               enum pipe pipe;
+       } cdclk;
+
+       bool dpll_set, modeset;
+
+       /*
+        * Does this transaction change the pipes that are active?  This mask
+        * tracks which CRTC's have changed their active state at the end of
+        * the transaction (not counting the temporary disable during modesets).
+        * This mask should only be non-zero when intel_state->modeset is true,
+        * but the converse is not necessarily true; simply changing a mode may
+        * not flip the final active status of any CRTC's
+        */
+       unsigned int active_pipe_changes;
+
+       unsigned int active_crtcs;
+       /* minimum acceptable cdclk for each pipe */
+       int min_cdclk[I915_MAX_PIPES];
+       /* minimum acceptable voltage level for each pipe */
+       u8 min_voltage_level[I915_MAX_PIPES];
+
+       struct intel_shared_dpll_state shared_dpll[I915_NUM_PLLS];
+
+       /*
+        * Current watermarks can't be trusted during hardware readout, so
+        * don't bother calculating intermediate watermarks.
+        */
+       bool skip_intermediate_wm;
+
+       bool rps_interactive;
+
+       /* Gen9+ only */
+       struct skl_ddb_values wm_results;
+
+       struct i915_sw_fence commit_ready;
+
+       struct llist_node freed;
+};
+
+struct intel_plane_state {
+       struct drm_plane_state base;
+       struct i915_ggtt_view view;
+       struct i915_vma *vma;
+       unsigned long flags;
+#define PLANE_HAS_FENCE BIT(0)
+
+       struct {
+               u32 offset;
+               /*
+                * Plane stride in:
+                * bytes for 0/180 degree rotation
+                * pixels for 90/270 degree rotation
+                */
+               u32 stride;
+               int x, y;
+       } color_plane[2];
+
+       /* plane control register */
+       u32 ctl;
+
+       /* plane color control register */
+       u32 color_ctl;
+
+       /*
+        * scaler_id
+        *    = -1 : not using a scaler
+        *    >=  0 : using a scalers
+        *
+        * plane requiring a scaler:
+        *   - During check_plane, its bit is set in
+        *     crtc_state->scaler_state.scaler_users by calling helper function
+        *     update_scaler_plane.
+        *   - scaler_id indicates the scaler it got assigned.
+        *
+        * plane doesn't require a scaler:
+        *   - this can happen when scaling is no more required or plane simply
+        *     got disabled.
+        *   - During check_plane, corresponding bit is reset in
+        *     crtc_state->scaler_state.scaler_users by calling helper function
+        *     update_scaler_plane.
+        */
+       int scaler_id;
+
+       /*
+        * linked_plane:
+        *
+        * ICL planar formats require 2 planes that are updated as pairs.
+        * This member is used to make sure the other plane is also updated
+        * when required, and for update_slave() to find the correct
+        * plane_state to pass as argument.
+        */
+       struct intel_plane *linked_plane;
+
+       /*
+        * slave:
+        * If set don't update use the linked plane's state for updating
+        * this plane during atomic commit with the update_slave() callback.
+        *
+        * It's also used by the watermark code to ignore wm calculations on
+        * this plane. They're calculated by the linked plane's wm code.
+        */
+       u32 slave;
+
+       struct drm_intel_sprite_colorkey ckey;
+};
+
+struct intel_initial_plane_config {
+       struct intel_framebuffer *fb;
+       unsigned int tiling;
+       int size;
+       u32 base;
+       u8 rotation;
+};
+
+struct intel_scaler {
+       int in_use;
+       u32 mode;
+};
+
+struct intel_crtc_scaler_state {
+#define SKL_NUM_SCALERS 2
+       struct intel_scaler scalers[SKL_NUM_SCALERS];
+
+       /*
+        * scaler_users: keeps track of users requesting scalers on this crtc.
+        *
+        *     If a bit is set, a user is using a scaler.
+        *     Here user can be a plane or crtc as defined below:
+        *       bits 0-30 - plane (bit position is index from drm_plane_index)
+        *       bit 31    - crtc
+        *
+        * Instead of creating a new index to cover planes and crtc, using
+        * existing drm_plane_index for planes which is well less than 31
+        * planes and bit 31 for crtc. This should be fine to cover all
+        * our platforms.
+        *
+        * intel_atomic_setup_scalers will setup available scalers to users
+        * requesting scalers. It will gracefully fail if request exceeds
+        * avilability.
+        */
+#define SKL_CRTC_INDEX 31
+       unsigned scaler_users;
+
+       /* scaler used by crtc for panel fitting purpose */
+       int scaler_id;
+};
+
+/* drm_mode->private_flags */
+#define I915_MODE_FLAG_INHERITED (1<<0)
+/* Flag to get scanline using frame time stamps */
+#define I915_MODE_FLAG_GET_SCANLINE_FROM_TIMESTAMP (1<<1)
+/* Flag to use the scanline counter instead of the pixel counter */
+#define I915_MODE_FLAG_USE_SCANLINE_COUNTER (1<<2)
+
+struct intel_pipe_wm {
+       struct intel_wm_level wm[5];
+       u32 linetime;
+       bool fbc_wm_enabled;
+       bool pipe_enabled;
+       bool sprites_enabled;
+       bool sprites_scaled;
+};
+
+struct skl_plane_wm {
+       struct skl_wm_level wm[8];
+       struct skl_wm_level uv_wm[8];
+       struct skl_wm_level trans_wm;
+       bool is_planar;
+};
+
+struct skl_pipe_wm {
+       struct skl_plane_wm planes[I915_MAX_PLANES];
+       u32 linetime;
+};
+
+enum vlv_wm_level {
+       VLV_WM_LEVEL_PM2,
+       VLV_WM_LEVEL_PM5,
+       VLV_WM_LEVEL_DDR_DVFS,
+       NUM_VLV_WM_LEVELS,
+};
+
+struct vlv_wm_state {
+       struct g4x_pipe_wm wm[NUM_VLV_WM_LEVELS];
+       struct g4x_sr_wm sr[NUM_VLV_WM_LEVELS];
+       u8 num_levels;
+       bool cxsr;
+};
+
+struct vlv_fifo_state {
+       u16 plane[I915_MAX_PLANES];
+};
+
+enum g4x_wm_level {
+       G4X_WM_LEVEL_NORMAL,
+       G4X_WM_LEVEL_SR,
+       G4X_WM_LEVEL_HPLL,
+       NUM_G4X_WM_LEVELS,
+};
+
+struct g4x_wm_state {
+       struct g4x_pipe_wm wm;
+       struct g4x_sr_wm sr;
+       struct g4x_sr_wm hpll;
+       bool cxsr;
+       bool hpll_en;
+       bool fbc_en;
+};
+
+struct intel_crtc_wm_state {
+       union {
+               struct {
+                       /*
+                        * Intermediate watermarks; these can be
+                        * programmed immediately since they satisfy
+                        * both the current configuration we're
+                        * switching away from and the new
+                        * configuration we're switching to.
+                        */
+                       struct intel_pipe_wm intermediate;
+
+                       /*
+                        * Optimal watermarks, programmed post-vblank
+                        * when this state is committed.
+                        */
+                       struct intel_pipe_wm optimal;
+               } ilk;
+
+               struct {
+                       /* gen9+ only needs 1-step wm programming */
+                       struct skl_pipe_wm optimal;
+                       struct skl_ddb_entry ddb;
+                       struct skl_ddb_entry plane_ddb_y[I915_MAX_PLANES];
+                       struct skl_ddb_entry plane_ddb_uv[I915_MAX_PLANES];
+               } skl;
+
+               struct {
+                       /* "raw" watermarks (not inverted) */
+                       struct g4x_pipe_wm raw[NUM_VLV_WM_LEVELS];
+                       /* intermediate watermarks (inverted) */
+                       struct vlv_wm_state intermediate;
+                       /* optimal watermarks (inverted) */
+                       struct vlv_wm_state optimal;
+                       /* display FIFO split */
+                       struct vlv_fifo_state fifo_state;
+               } vlv;
+
+               struct {
+                       /* "raw" watermarks */
+                       struct g4x_pipe_wm raw[NUM_G4X_WM_LEVELS];
+                       /* intermediate watermarks */
+                       struct g4x_wm_state intermediate;
+                       /* optimal watermarks */
+                       struct g4x_wm_state optimal;
+               } g4x;
+       };
+
+       /*
+        * Platforms with two-step watermark programming will need to
+        * update watermark programming post-vblank to switch from the
+        * safe intermediate watermarks to the optimal final
+        * watermarks.
+        */
+       bool need_postvbl_update;
+};
+
+enum intel_output_format {
+       INTEL_OUTPUT_FORMAT_INVALID,
+       INTEL_OUTPUT_FORMAT_RGB,
+       INTEL_OUTPUT_FORMAT_YCBCR420,
+       INTEL_OUTPUT_FORMAT_YCBCR444,
+};
+
+struct intel_crtc_state {
+       struct drm_crtc_state base;
+
+       /**
+        * quirks - bitfield with hw state readout quirks
+        *
+        * For various reasons the hw state readout code might not be able to
+        * completely faithfully read out the current state. These cases are
+        * tracked with quirk flags so that fastboot and state checker can act
+        * accordingly.
+        */
+#define PIPE_CONFIG_QUIRK_MODE_SYNC_FLAGS      (1<<0) /* unreliable sync mode.flags */
+       unsigned long quirks;
+
+       unsigned fb_bits; /* framebuffers to flip */
+       bool update_pipe; /* can a fast modeset be performed? */
+       bool disable_cxsr;
+       bool update_wm_pre, update_wm_post; /* watermarks are updated */
+       bool fb_changed; /* fb on any of the planes is changed */
+       bool fifo_changed; /* FIFO split is changed */
+
+       /* Pipe source size (ie. panel fitter input size)
+        * All planes will be positioned inside this space,
+        * and get clipped at the edges. */
+       int pipe_src_w, pipe_src_h;
+
+       /*
+        * Pipe pixel rate, adjusted for
+        * panel fitter/pipe scaler downscaling.
+        */
+       unsigned int pixel_rate;
+
+       /* Whether to set up the PCH/FDI. Note that we never allow sharing
+        * between pch encoders and cpu encoders. */
+       bool has_pch_encoder;
+
+       /* Are we sending infoframes on the attached port */
+       bool has_infoframe;
+
+       /* CPU Transcoder for the pipe. Currently this can only differ from the
+        * pipe on Haswell and later (where we have a special eDP transcoder)
+        * and Broxton (where we have special DSI transcoders). */
+       enum transcoder cpu_transcoder;
+
+       /*
+        * Use reduced/limited/broadcast rbg range, compressing from the full
+        * range fed into the crtcs.
+        */
+       bool limited_color_range;
+
+       /* Bitmask of encoder types (enum intel_output_type)
+        * driven by the pipe.
+        */
+       unsigned int output_types;
+
+       /* Whether we should send NULL infoframes. Required for audio. */
+       bool has_hdmi_sink;
+
+       /* Audio enabled on this pipe. Only valid if either has_hdmi_sink or
+        * has_dp_encoder is set. */
+       bool has_audio;
+
+       /*
+        * Enable dithering, used when the selected pipe bpp doesn't match the
+        * plane bpp.
+        */
+       bool dither;
+
+       /*
+        * Dither gets enabled for 18bpp which causes CRC mismatch errors for
+        * compliance video pattern tests.
+        * Disable dither only if it is a compliance test request for
+        * 18bpp.
+        */
+       bool dither_force_disable;
+
+       /* Controls for the clock computation, to override various stages. */
+       bool clock_set;
+
+       /* SDVO TV has a bunch of special case. To make multifunction encoders
+        * work correctly, we need to track this at runtime.*/
+       bool sdvo_tv_clock;
+
+       /*
+        * crtc bandwidth limit, don't increase pipe bpp or clock if not really
+        * required. This is set in the 2nd loop of calling encoder's
+        * ->compute_config if the first pick doesn't work out.
+        */
+       bool bw_constrained;
+
+       /* Settings for the intel dpll used on pretty much everything but
+        * haswell. */
+       struct dpll dpll;
+
+       /* Selected dpll when shared or NULL. */
+       struct intel_shared_dpll *shared_dpll;
+
+       /* Actual register state of the dpll, for shared dpll cross-checking. */
+       struct intel_dpll_hw_state dpll_hw_state;
+
+       /*
+        * ICL reserved DPLLs for the CRTC/port. The active PLL is selected by
+        * setting shared_dpll and dpll_hw_state to one of these reserved ones.
+        */
+       struct icl_port_dpll {
+               struct intel_shared_dpll *pll;
+               struct intel_dpll_hw_state hw_state;
+       } icl_port_dplls[ICL_PORT_DPLL_COUNT];
+
+       /* DSI PLL registers */
+       struct {
+               u32 ctrl, div;
+       } dsi_pll;
+
+       int pipe_bpp;
+       struct intel_link_m_n dp_m_n;
+
+       /* m2_n2 for eDP downclock */
+       struct intel_link_m_n dp_m2_n2;
+       bool has_drrs;
+
+       bool has_psr;
+       bool has_psr2;
+
+       /*
+        * Frequence the dpll for the port should run at. Differs from the
+        * adjusted dotclock e.g. for DP or 12bpc hdmi mode. This is also
+        * already multiplied by pixel_multiplier.
+        */
+       int port_clock;
+
+       /* Used by SDVO (and if we ever fix it, HDMI). */
+       unsigned pixel_multiplier;
+
+       u8 lane_count;
+
+       /*
+        * Used by platforms having DP/HDMI PHY with programmable lane
+        * latency optimization.
+        */
+       u8 lane_lat_optim_mask;
+
+       /* minimum acceptable voltage level */
+       u8 min_voltage_level;
+
+       /* Panel fitter controls for gen2-gen4 + VLV */
+       struct {
+               u32 control;
+               u32 pgm_ratios;
+               u32 lvds_border_bits;
+       } gmch_pfit;
+
+       /* Panel fitter placement and size for Ironlake+ */
+       struct {
+               u32 pos;
+               u32 size;
+               bool enabled;
+               bool force_thru;
+       } pch_pfit;
+
+       /* FDI configuration, only valid if has_pch_encoder is set. */
+       int fdi_lanes;
+       struct intel_link_m_n fdi_m_n;
+
+       bool ips_enabled;
+
+       bool crc_enabled;
+
+       bool enable_fbc;
+
+       bool double_wide;
+
+       int pbn;
+
+       struct intel_crtc_scaler_state scaler_state;
+
+       /* w/a for waiting 2 vblanks during crtc enable */
+       enum pipe hsw_workaround_pipe;
+
+       /* IVB sprite scaling w/a (WaCxSRDisabledForSpriteScaling:ivb) */
+       bool disable_lp_wm;
+
+       struct intel_crtc_wm_state wm;
+
+       u32 data_rate[I915_MAX_PLANES];
+
+       /* Gamma mode programmed on the pipe */
+       u32 gamma_mode;
+
+       union {
+               /* CSC mode programmed on the pipe */
+               u32 csc_mode;
+
+               /* CHV CGM mode */
+               u32 cgm_mode;
+       };
+
+       /* bitmask of visible planes (enum plane_id) */
+       u8 active_planes;
+       u8 nv12_planes;
+       u8 c8_planes;
+
+       /* bitmask of planes that will be updated during the commit */
+       u8 update_planes;
+
+       struct {
+               u32 enable;
+               u32 gcp;
+               union hdmi_infoframe avi;
+               union hdmi_infoframe spd;
+               union hdmi_infoframe hdmi;
+               union hdmi_infoframe drm;
+       } infoframes;
+
+       /* HDMI scrambling status */
+       bool hdmi_scrambling;
+
+       /* HDMI High TMDS char rate ratio */
+       bool hdmi_high_tmds_clock_ratio;
+
+       /* Output format RGB/YCBCR etc */
+       enum intel_output_format output_format;
+
+       /* Output down scaling is done in LSPCON device */
+       bool lspcon_downsampling;
+
+       /* enable pipe gamma? */
+       bool gamma_enable;
+
+       /* enable pipe csc? */
+       bool csc_enable;
+
+       /* Display Stream compression state */
+       struct {
+               bool compression_enable;
+               bool dsc_split;
+               u16 compressed_bpp;
+               u8 slice_count;
+       } dsc_params;
+       struct drm_dsc_config dp_dsc_cfg;
+
+       /* Forward Error correction State */
+       bool fec_enable;
+};
+
+struct intel_crtc {
+       struct drm_crtc base;
+       enum pipe pipe;
+       /*
+        * Whether the crtc and the connected output pipeline is active. Implies
+        * that crtc->enabled is set, i.e. the current mode configuration has
+        * some outputs connected to this crtc.
+        */
+       bool active;
+       u8 plane_ids_mask;
+       unsigned long long enabled_power_domains;
+       struct intel_overlay *overlay;
+
+       struct intel_crtc_state *config;
+
+       /* Access to these should be protected by dev_priv->irq_lock. */
+       bool cpu_fifo_underrun_disabled;
+       bool pch_fifo_underrun_disabled;
+
+       /* per-pipe watermark state */
+       struct {
+               /* watermarks currently being used  */
+               union {
+                       struct intel_pipe_wm ilk;
+                       struct vlv_wm_state vlv;
+                       struct g4x_wm_state g4x;
+               } active;
+       } wm;
+
+       int scanline_offset;
+
+       struct {
+               unsigned start_vbl_count;
+               ktime_t start_vbl_time;
+               int min_vbl, max_vbl;
+               int scanline_start;
+       } debug;
+
+       /* scalers available on this crtc */
+       int num_scalers;
+};
+
+struct intel_plane {
+       struct drm_plane base;
+       enum i9xx_plane_id i9xx_plane;
+       enum plane_id id;
+       enum pipe pipe;
+       bool has_fbc;
+       bool has_ccs;
+       u32 frontbuffer_bit;
+
+       struct {
+               u32 base, cntl, size;
+       } cursor;
+
+       /*
+        * NOTE: Do not place new plane state fields here (e.g., when adding
+        * new plane properties).  New runtime state should now be placed in
+        * the intel_plane_state structure and accessed via plane_state.
+        */
+
+       unsigned int (*max_stride)(struct intel_plane *plane,
+                                  u32 pixel_format, u64 modifier,
+                                  unsigned int rotation);
+       void (*update_plane)(struct intel_plane *plane,
+                            const struct intel_crtc_state *crtc_state,
+                            const struct intel_plane_state *plane_state);
+       void (*update_slave)(struct intel_plane *plane,
+                            const struct intel_crtc_state *crtc_state,
+                            const struct intel_plane_state *plane_state);
+       void (*disable_plane)(struct intel_plane *plane,
+                             const struct intel_crtc_state *crtc_state);
+       bool (*get_hw_state)(struct intel_plane *plane, enum pipe *pipe);
+       int (*check_plane)(struct intel_crtc_state *crtc_state,
+                          struct intel_plane_state *plane_state);
+};
+
+struct intel_watermark_params {
+       u16 fifo_size;
+       u16 max_wm;
+       u8 default_wm;
+       u8 guard_size;
+       u8 cacheline_size;
+};
+
+struct cxsr_latency {
+       bool is_desktop : 1;
+       bool is_ddr3 : 1;
+       u16 fsb_freq;
+       u16 mem_freq;
+       u16 display_sr;
+       u16 display_hpll_disable;
+       u16 cursor_sr;
+       u16 cursor_hpll_disable;
+};
+
+#define to_intel_atomic_state(x) container_of(x, struct intel_atomic_state, base)
+#define to_intel_crtc(x) container_of(x, struct intel_crtc, base)
+#define to_intel_crtc_state(x) container_of(x, struct intel_crtc_state, base)
+#define to_intel_connector(x) container_of(x, struct intel_connector, base)
+#define to_intel_encoder(x) container_of(x, struct intel_encoder, base)
+#define to_intel_framebuffer(x) container_of(x, struct intel_framebuffer, base)
+#define to_intel_plane(x) container_of(x, struct intel_plane, base)
+#define to_intel_plane_state(x) container_of(x, struct intel_plane_state, base)
+#define intel_fb_obj(x) ((x) ? to_intel_bo((x)->obj[0]) : NULL)
+
+struct intel_hdmi {
+       i915_reg_t hdmi_reg;
+       int ddc_bus;
+       struct {
+               enum drm_dp_dual_mode_type type;
+               int max_tmds_clock;
+       } dp_dual_mode;
+       bool has_hdmi_sink;
+       bool has_audio;
+       struct intel_connector *attached_connector;
+       struct cec_notifier *cec_notifier;
+};
+
+struct intel_dp_mst_encoder;
+#define DP_MAX_DOWNSTREAM_PORTS                0x10
+
+/*
+ * enum link_m_n_set:
+ *     When platform provides two set of M_N registers for dp, we can
+ *     program them and switch between them incase of DRRS.
+ *     But When only one such register is provided, we have to program the
+ *     required divider value on that registers itself based on the DRRS state.
+ *
+ * M1_N1       : Program dp_m_n on M1_N1 registers
+ *                       dp_m2_n2 on M2_N2 registers (If supported)
+ *
+ * M2_N2       : Program dp_m2_n2 on M1_N1 registers
+ *                       M2_N2 registers are not supported
+ */
+
+enum link_m_n_set {
+       /* Sets the m1_n1 and m2_n2 */
+       M1_N1 = 0,
+       M2_N2
+};
+
+struct intel_dp_compliance_data {
+       unsigned long edid;
+       u8 video_pattern;
+       u16 hdisplay, vdisplay;
+       u8 bpc;
+};
+
+struct intel_dp_compliance {
+       unsigned long test_type;
+       struct intel_dp_compliance_data test_data;
+       bool test_active;
+       int test_link_rate;
+       u8 test_lane_count;
+};
+
+struct intel_dp {
+       i915_reg_t output_reg;
+       u32 DP;
+       int link_rate;
+       u8 lane_count;
+       u8 sink_count;
+       bool link_mst;
+       bool link_trained;
+       bool has_audio;
+       bool reset_link_params;
+       u8 dpcd[DP_RECEIVER_CAP_SIZE];
+       u8 psr_dpcd[EDP_PSR_RECEIVER_CAP_SIZE];
+       u8 downstream_ports[DP_MAX_DOWNSTREAM_PORTS];
+       u8 edp_dpcd[EDP_DISPLAY_CTL_CAP_SIZE];
+       u8 dsc_dpcd[DP_DSC_RECEIVER_CAP_SIZE];
+       u8 fec_capable;
+       /* source rates */
+       int num_source_rates;
+       const int *source_rates;
+       /* sink rates as reported by DP_MAX_LINK_RATE/DP_SUPPORTED_LINK_RATES */
+       int num_sink_rates;
+       int sink_rates[DP_MAX_SUPPORTED_RATES];
+       bool use_rate_select;
+       /* intersection of source and sink rates */
+       int num_common_rates;
+       int common_rates[DP_MAX_SUPPORTED_RATES];
+       /* Max lane count for the current link */
+       int max_link_lane_count;
+       /* Max rate for the current link */
+       int max_link_rate;
+       /* sink or branch descriptor */
+       struct drm_dp_desc desc;
+       struct drm_dp_aux aux;
+       u8 train_set[4];
+       int panel_power_up_delay;
+       int panel_power_down_delay;
+       int panel_power_cycle_delay;
+       int backlight_on_delay;
+       int backlight_off_delay;
+       struct delayed_work panel_vdd_work;
+       bool want_panel_vdd;
+       unsigned long last_power_on;
+       unsigned long last_backlight_off;
+       ktime_t panel_power_off_time;
+
+       struct notifier_block edp_notifier;
+
+       /*
+        * Pipe whose power sequencer is currently locked into
+        * this port. Only relevant on VLV/CHV.
+        */
+       enum pipe pps_pipe;
+       /*
+        * Pipe currently driving the port. Used for preventing
+        * the use of the PPS for any pipe currentrly driving
+        * external DP as that will mess things up on VLV.
+        */
+       enum pipe active_pipe;
+       /*
+        * Set if the sequencer may be reset due to a power transition,
+        * requiring a reinitialization. Only relevant on BXT.
+        */
+       bool pps_reset;
+       struct edp_power_seq pps_delays;
+
+       bool can_mst; /* this port supports mst */
+       bool is_mst;
+       int active_mst_links;
+       /* connector directly attached - won't be use for modeset in mst world */
+       struct intel_connector *attached_connector;
+
+       /* mst connector list */
+       struct intel_dp_mst_encoder *mst_encoders[I915_MAX_PIPES];
+       struct drm_dp_mst_topology_mgr mst_mgr;
+
+       u32 (*get_aux_clock_divider)(struct intel_dp *dp, int index);
+       /*
+        * This function returns the value we have to program the AUX_CTL
+        * register with to kick off an AUX transaction.
+        */
+       u32 (*get_aux_send_ctl)(struct intel_dp *dp, int send_bytes,
+                               u32 aux_clock_divider);
+
+       i915_reg_t (*aux_ch_ctl_reg)(struct intel_dp *dp);
+       i915_reg_t (*aux_ch_data_reg)(struct intel_dp *dp, int index);
+
+       /* This is called before a link training is starterd */
+       void (*prepare_link_retrain)(struct intel_dp *intel_dp);
+
+       /* Displayport compliance testing */
+       struct intel_dp_compliance compliance;
+
+       /* Display stream compression testing */
+       bool force_dsc_en;
+};
+
+enum lspcon_vendor {
+       LSPCON_VENDOR_MCA,
+       LSPCON_VENDOR_PARADE
+};
+
+struct intel_lspcon {
+       bool active;
+       enum drm_lspcon_mode mode;
+       enum lspcon_vendor vendor;
+};
+
+struct intel_digital_port {
+       struct intel_encoder base;
+       u32 saved_port_bits;
+       struct intel_dp dp;
+       struct intel_hdmi hdmi;
+       struct intel_lspcon lspcon;
+       enum irqreturn (*hpd_pulse)(struct intel_digital_port *, bool);
+       bool release_cl2_override;
+       u8 max_lanes;
+       /* Used for DP and ICL+ TypeC/DP and TypeC/HDMI ports. */
+       enum aux_ch aux_ch;
+       enum intel_display_power_domain ddi_io_power_domain;
+       struct mutex tc_lock;   /* protects the TypeC port mode */
+       intel_wakeref_t tc_lock_wakeref;
+       int tc_link_refcount;
+       bool tc_legacy_port:1;
+       char tc_port_name[8];
+       enum tc_port_mode tc_mode;
+       enum phy_fia tc_phy_fia;
+
+       void (*write_infoframe)(struct intel_encoder *encoder,
+                               const struct intel_crtc_state *crtc_state,
+                               unsigned int type,
+                               const void *frame, ssize_t len);
+       void (*read_infoframe)(struct intel_encoder *encoder,
+                              const struct intel_crtc_state *crtc_state,
+                              unsigned int type,
+                              void *frame, ssize_t len);
+       void (*set_infoframes)(struct intel_encoder *encoder,
+                              bool enable,
+                              const struct intel_crtc_state *crtc_state,
+                              const struct drm_connector_state *conn_state);
+       u32 (*infoframes_enabled)(struct intel_encoder *encoder,
+                                 const struct intel_crtc_state *pipe_config);
+};
+
+struct intel_dp_mst_encoder {
+       struct intel_encoder base;
+       enum pipe pipe;
+       struct intel_digital_port *primary;
+       struct intel_connector *connector;
+};
+
+static inline enum dpio_channel
+vlv_dport_to_channel(struct intel_digital_port *dport)
+{
+       switch (dport->base.port) {
+       case PORT_B:
+       case PORT_D:
+               return DPIO_CH0;
+       case PORT_C:
+               return DPIO_CH1;
+       default:
+               BUG();
+       }
+}
+
+static inline enum dpio_phy
+vlv_dport_to_phy(struct intel_digital_port *dport)
+{
+       switch (dport->base.port) {
+       case PORT_B:
+       case PORT_C:
+               return DPIO_PHY0;
+       case PORT_D:
+               return DPIO_PHY1;
+       default:
+               BUG();
+       }
+}
+
+static inline enum dpio_channel
+vlv_pipe_to_channel(enum pipe pipe)
+{
+       switch (pipe) {
+       case PIPE_A:
+       case PIPE_C:
+               return DPIO_CH0;
+       case PIPE_B:
+               return DPIO_CH1;
+       default:
+               BUG();
+       }
+}
+
+static inline struct intel_crtc *
+intel_get_crtc_for_pipe(struct drm_i915_private *dev_priv, enum pipe pipe)
+{
+       return dev_priv->pipe_to_crtc_mapping[pipe];
+}
+
+static inline struct intel_crtc *
+intel_get_crtc_for_plane(struct drm_i915_private *dev_priv, enum i9xx_plane_id plane)
+{
+       return dev_priv->plane_to_crtc_mapping[plane];
+}
+
+struct intel_load_detect_pipe {
+       struct drm_atomic_state *restore_state;
+};
+
+static inline struct intel_encoder *
+intel_attached_encoder(struct drm_connector *connector)
+{
+       return to_intel_connector(connector)->encoder;
+}
+
+static inline bool intel_encoder_is_dig_port(struct intel_encoder *encoder)
+{
+       switch (encoder->type) {
+       case INTEL_OUTPUT_DDI:
+       case INTEL_OUTPUT_DP:
+       case INTEL_OUTPUT_EDP:
+       case INTEL_OUTPUT_HDMI:
+               return true;
+       default:
+               return false;
+       }
+}
+
+static inline struct intel_digital_port *
+enc_to_dig_port(struct drm_encoder *encoder)
+{
+       struct intel_encoder *intel_encoder = to_intel_encoder(encoder);
+
+       if (intel_encoder_is_dig_port(intel_encoder))
+               return container_of(encoder, struct intel_digital_port,
+                                   base.base);
+       else
+               return NULL;
+}
+
+static inline struct intel_digital_port *
+conn_to_dig_port(struct intel_connector *connector)
+{
+       return enc_to_dig_port(&intel_attached_encoder(&connector->base)->base);
+}
+
+static inline struct intel_dp_mst_encoder *
+enc_to_mst(struct drm_encoder *encoder)
+{
+       return container_of(encoder, struct intel_dp_mst_encoder, base.base);
+}
+
+static inline struct intel_dp *enc_to_intel_dp(struct drm_encoder *encoder)
+{
+       return &enc_to_dig_port(encoder)->dp;
+}
+
+static inline bool intel_encoder_is_dp(struct intel_encoder *encoder)
+{
+       switch (encoder->type) {
+       case INTEL_OUTPUT_DP:
+       case INTEL_OUTPUT_EDP:
+               return true;
+       case INTEL_OUTPUT_DDI:
+               /* Skip pure HDMI/DVI DDI encoders */
+               return i915_mmio_reg_valid(enc_to_intel_dp(&encoder->base)->output_reg);
+       default:
+               return false;
+       }
+}
+
+static inline struct intel_lspcon *
+enc_to_intel_lspcon(struct drm_encoder *encoder)
+{
+       return &enc_to_dig_port(encoder)->lspcon;
+}
+
+static inline struct intel_digital_port *
+dp_to_dig_port(struct intel_dp *intel_dp)
+{
+       return container_of(intel_dp, struct intel_digital_port, dp);
+}
+
+static inline struct intel_lspcon *
+dp_to_lspcon(struct intel_dp *intel_dp)
+{
+       return &dp_to_dig_port(intel_dp)->lspcon;
+}
+
+static inline struct drm_i915_private *
+dp_to_i915(struct intel_dp *intel_dp)
+{
+       return to_i915(dp_to_dig_port(intel_dp)->base.base.dev);
+}
+
+static inline struct intel_digital_port *
+hdmi_to_dig_port(struct intel_hdmi *intel_hdmi)
+{
+       return container_of(intel_hdmi, struct intel_digital_port, hdmi);
+}
+
+static inline struct intel_plane_state *
+intel_atomic_get_plane_state(struct intel_atomic_state *state,
+                                struct intel_plane *plane)
+{
+       struct drm_plane_state *ret =
+               drm_atomic_get_plane_state(&state->base, &plane->base);
+
+       if (IS_ERR(ret))
+               return ERR_CAST(ret);
+
+       return to_intel_plane_state(ret);
+}
+
+static inline struct intel_plane_state *
+intel_atomic_get_old_plane_state(struct intel_atomic_state *state,
+                                struct intel_plane *plane)
+{
+       return to_intel_plane_state(drm_atomic_get_old_plane_state(&state->base,
+                                                                  &plane->base));
+}
+
+static inline struct intel_plane_state *
+intel_atomic_get_new_plane_state(struct intel_atomic_state *state,
+                                struct intel_plane *plane)
+{
+       return to_intel_plane_state(drm_atomic_get_new_plane_state(&state->base,
+                                                                  &plane->base));
+}
+
+static inline struct intel_crtc_state *
+intel_atomic_get_old_crtc_state(struct intel_atomic_state *state,
+                               struct intel_crtc *crtc)
+{
+       return to_intel_crtc_state(drm_atomic_get_old_crtc_state(&state->base,
+                                                                &crtc->base));
+}
+
+static inline struct intel_crtc_state *
+intel_atomic_get_new_crtc_state(struct intel_atomic_state *state,
+                               struct intel_crtc *crtc)
+{
+       return to_intel_crtc_state(drm_atomic_get_new_crtc_state(&state->base,
+                                                                &crtc->base));
+}
+
+/* intel_display.c */
+static inline bool
+intel_crtc_has_type(const struct intel_crtc_state *crtc_state,
+                   enum intel_output_type type)
+{
+       return crtc_state->output_types & (1 << type);
+}
+static inline bool
+intel_crtc_has_dp_encoder(const struct intel_crtc_state *crtc_state)
+{
+       return crtc_state->output_types &
+               ((1 << INTEL_OUTPUT_DP) |
+                (1 << INTEL_OUTPUT_DP_MST) |
+                (1 << INTEL_OUTPUT_EDP));
+}
+static inline void
+intel_wait_for_vblank(struct drm_i915_private *dev_priv, enum pipe pipe)
+{
+       drm_wait_one_vblank(&dev_priv->drm, pipe);
+}
+static inline void
+intel_wait_for_vblank_if_active(struct drm_i915_private *dev_priv, int pipe)
+{
+       const struct intel_crtc *crtc = intel_get_crtc_for_pipe(dev_priv, pipe);
+
+       if (crtc->active)
+               intel_wait_for_vblank(dev_priv, pipe);
+}
+
+static inline u32 intel_plane_ggtt_offset(const struct intel_plane_state *state)
+{
+       return i915_ggtt_offset(state->vma);
+}
+
+#endif /*  __INTEL_DISPLAY_TYPES_H__ */
index 956e886f9f1e44388e43688291ed42005a47ac00..1092499115760f2f19fbc3dfeda019dbeffb7972 100644 (file)
 #include "intel_audio.h"
 #include "intel_connector.h"
 #include "intel_ddi.h"
+#include "intel_display_types.h"
 #include "intel_dp.h"
 #include "intel_dp_link_training.h"
 #include "intel_dp_mst.h"
 #include "intel_dpio_phy.h"
-#include "intel_drv.h"
 #include "intel_fifo_underrun.h"
 #include "intel_hdcp.h"
 #include "intel_hdmi.h"
index 6b0b73479fb8e652a0c555da289334ce3da674c7..020422da2ae28de9c33ddce41fd3ca8eef3ed31f 100644 (file)
@@ -22,8 +22,8 @@
  *
  */
 
+#include "intel_display_types.h"
 #include "intel_dp_aux_backlight.h"
-#include "intel_drv.h"
 
 static void set_aux_backlight_enable(struct intel_dp *intel_dp, bool enable)
 {
index 9b1fccea966b512db0753427125a391665d359a5..2a1130dd1ad0a01f0f8df8e2bfec89cf1bc47115 100644 (file)
@@ -21,9 +21,9 @@
  * IN THE SOFTWARE.
  */
 
+#include "intel_display_types.h"
 #include "intel_dp.h"
 #include "intel_dp_link_training.h"
-#include "intel_drv.h"
 
 static void
 intel_dp_dump_link_status(const u8 link_status[DP_LINK_STATUS_SIZE])
index 4071c9da1065a14feb7bf2691ea0822e2d2e92b3..b1a3df185f4ca802ff8aa8b544c5dd61b9549eb5 100644 (file)
 #include "intel_audio.h"
 #include "intel_connector.h"
 #include "intel_ddi.h"
+#include "intel_display_types.h"
 #include "intel_dp.h"
 #include "intel_dp_mst.h"
 #include "intel_dpio_phy.h"
-#include "intel_drv.h"
 
 static int intel_dp_mst_compute_link_config(struct intel_encoder *encoder,
                                            struct intel_crtc_state *crtc_state,
index 7ccf7f3974dbbbd2e647bed48964b1e0641dfe2d..749e5a74825f127dd51a816cd79e5db993674fa7 100644 (file)
@@ -23,8 +23,8 @@
 
 #include "display/intel_dp.h"
 
+#include "intel_display_types.h"
 #include "intel_dpio_phy.h"
-#include "intel_drv.h"
 #include "intel_sideband.h"
 
 /**
index f9bdf8514a538d984b2c951e6be15fd6809d5295..84a09d96d52f68032e8d64b8cb4474873abe831f 100644 (file)
@@ -21,9 +21,9 @@
  * DEALINGS IN THE SOFTWARE.
  */
 
+#include "intel_display_types.h"
 #include "intel_dpio_phy.h"
 #include "intel_dpll_mgr.h"
-#include "intel_drv.h"
 
 /**
  * DOC: Display PLLs
index 1cd24bd46518b4fdfb5d80564951e7de278d6126..b15be5814599a8aad5274e3ac2ce2443a10ff9ae 100644 (file)
@@ -26,7 +26,8 @@
 
 #include <drm/drm_crtc.h>
 #include <drm/drm_mipi_dsi.h>
-#include "intel_drv.h"
+
+#include "intel_display_types.h"
 
 #define INTEL_DSI_VIDEO_MODE   0
 #define INTEL_DSI_COMMAND_MODE 1
index 8c33262cb0b2987d68fce09ef38d7261f3150a0f..bb3fd8b786a20a25222a324a279f8912c22fb456 100644 (file)
@@ -27,7 +27,7 @@
 #include <video/mipi_display.h>
 
 #include "i915_drv.h"
-#include "intel_drv.h"
+#include "intel_display_types.h"
 #include "intel_dsi.h"
 #include "intel_dsi_dcs_backlight.h"
 
index e5b17866040808e19e4e8db0311a79b95d3d9dcf..f90946c912eefb126907f8cd899a9e31e69483bc 100644 (file)
@@ -38,7 +38,7 @@
 #include <video/mipi_display.h>
 
 #include "i915_drv.h"
-#include "intel_drv.h"
+#include "intel_display_types.h"
 #include "intel_dsi.h"
 #include "intel_sideband.h"
 
index 22666d28f4aa5e973e93954d0ac1640a31ca708c..93baf366692ea3584af3f97a2b317bc75414cf4d 100644 (file)
@@ -34,7 +34,7 @@
 
 #include "i915_drv.h"
 #include "intel_connector.h"
-#include "intel_drv.h"
+#include "intel_display_types.h"
 #include "intel_dvo.h"
 #include "intel_dvo_dev.h"
 #include "intel_gmbus.h"
index d36cada2cc7da80b9c62bda7e988954ed5019581..f007f667315e90eacf877dbcc3f7ccc2fca377b4 100644 (file)
@@ -41,7 +41,7 @@
 #include <drm/drm_fourcc.h>
 
 #include "i915_drv.h"
-#include "intel_drv.h"
+#include "intel_display_types.h"
 #include "intel_fbc.h"
 #include "intel_frontbuffer.h"
 
index 1edd44ee32b204b5d7fd53c0666aab766aa83c4d..eccfc30f8e325670e813163c0ad9ad7466908e74 100644 (file)
@@ -43,7 +43,7 @@
 #include <drm/i915_drm.h>
 
 #include "i915_drv.h"
-#include "intel_drv.h"
+#include "intel_display_types.h"
 #include "intel_fbdev.h"
 #include "intel_frontbuffer.h"
 
index b48c15d8f79f772613f725b10d181188ae30b771..ab61f88d1d33d321b4626696e8e498f37b1c2052 100644 (file)
@@ -27,7 +27,7 @@
 
 #include "i915_drv.h"
 #include "i915_trace.h"
-#include "intel_drv.h"
+#include "intel_display_types.h"
 #include "intel_fbc.h"
 #include "intel_fifo_underrun.h"
 
index 44273c10cea5417377a89085ced804272344b6d3..9cda88e41d29a031239e1562e95487672a013a22 100644 (file)
@@ -58,7 +58,7 @@
 #include "display/intel_dp.h"
 
 #include "i915_drv.h"
-#include "intel_drv.h"
+#include "intel_display_types.h"
 #include "intel_fbc.h"
 #include "intel_frontbuffer.h"
 #include "intel_psr.h"
index b42c79aea61acdf1cc9ede4ff79c68aa8793bc13..1e27b18aa3fcaae117915229548b294e6d098f42 100644 (file)
@@ -35,7 +35,7 @@
 #include <drm/i915_drm.h>
 
 #include "i915_drv.h"
-#include "intel_drv.h"
+#include "intel_display_types.h"
 #include "intel_gmbus.h"
 
 struct gmbus_pin {
index 1ffc1e61c2bece610ef843915c60b72f28bccaf7..b83a0b71766ce168491729a855f35f613fdfcb26 100644 (file)
@@ -14,7 +14,7 @@
 #include <drm/i915_component.h>
 
 #include "i915_reg.h"
-#include "intel_drv.h"
+#include "intel_display_types.h"
 #include "intel_hdcp.h"
 #include "intel_sideband.h"
 
index 9bf28de10401ad902e67557ec0c5576fac3dd13f..b1ca8e5bdb56dc2a5b9e2b69f9e8d8f6e18a739c 100644 (file)
 #include "intel_audio.h"
 #include "intel_connector.h"
 #include "intel_ddi.h"
+#include "intel_display_types.h"
 #include "intel_dp.h"
 #include "intel_dpio_phy.h"
-#include "intel_drv.h"
 #include "intel_fifo_underrun.h"
 #include "intel_gmbus.h"
 #include "intel_hdcp.h"
 #include "intel_hdmi.h"
 #include "intel_hotplug.h"
 #include "intel_lspcon.h"
-#include "intel_sdvo.h"
 #include "intel_panel.h"
+#include "intel_sdvo.h"
 #include "intel_sideband.h"
 
 static struct drm_device *intel_hdmi_to_dev(struct intel_hdmi *intel_hdmi)
index c844ae4480af8cd94be53124ffdc1d95cda0a048..56be20f6f47e3fe32a30d4d2ba43a0da1be37e30 100644 (file)
@@ -26,7 +26,7 @@
 #include <drm/i915_drm.h>
 
 #include "i915_drv.h"
-#include "intel_drv.h"
+#include "intel_display_types.h"
 #include "intel_hotplug.h"
 
 /**
index 7028d0cf3bb154355b8112ee4aee3dc6c9208fe1..f8f1308643a97d8e1c16c1c18513568b9530ed09 100644 (file)
@@ -27,8 +27,8 @@
 #include <drm/drm_dp_dual_mode_helper.h>
 #include <drm/drm_edid.h>
 
+#include "intel_display_types.h"
 #include "intel_dp.h"
-#include "intel_drv.h"
 #include "intel_lspcon.h"
 
 /* LSPCON OUI Vendor ID(signatures) */
index efefed62a7f86aed0da29e1d189007a49f455399..78c9ee5230ea6e4355060e07c7ef28104a3af755 100644 (file)
@@ -42,7 +42,7 @@
 #include "i915_drv.h"
 #include "intel_atomic.h"
 #include "intel_connector.h"
-#include "intel_drv.h"
+#include "intel_display_types.h"
 #include "intel_gmbus.h"
 #include "intel_lvds.h"
 #include "intel_panel.h"
index 82488127135108cf1f5feecb67805dd364c7873a..969ade6236919872827b06e69c487242a81d1661 100644 (file)
@@ -35,7 +35,7 @@
 #include "display/intel_panel.h"
 
 #include "i915_drv.h"
-#include "intel_drv.h"
+#include "intel_display_types.h"
 #include "intel_opregion.h"
 
 #define OPREGION_HEADER_OFFSET 0
index 07929726b780c98a53e79858dbc188dfb919cf1e..4d3b2086570e6c77c17caf5cec340aaff96bbf28 100644 (file)
@@ -33,7 +33,7 @@
 
 #include "i915_drv.h"
 #include "i915_reg.h"
-#include "intel_drv.h"
+#include "intel_display_types.h"
 #include "intel_frontbuffer.h"
 #include "intel_overlay.h"
 
index 39d7420940658426a7cd2808d995670c6728e63d..bc14e9c0285a0234d35e7f6f08347d78fd9ae453 100644 (file)
@@ -35,8 +35,8 @@
 #include <linux/pwm.h>
 
 #include "intel_connector.h"
+#include "intel_display_types.h"
 #include "intel_dp_aux_backlight.h"
-#include "intel_drv.h"
 #include "intel_dsi_dcs_backlight.h"
 #include "intel_panel.h"
 
index 9a48f7a01e7ee0126816f154280abd4d3015171d..6260a208271952ef38b5f77e182268cf1c857507 100644 (file)
@@ -30,7 +30,7 @@
 #include <linux/seq_file.h>
 
 #include "intel_atomic.h"
-#include "intel_drv.h"
+#include "intel_display_types.h"
 #include "intel_pipe_crc.h"
 
 static const char * const pipe_crc_sources[] = {
index 69d908e6a0509c04bf9f43e66341beccab75541d..ad7044ea1efe5ac9ab28aa3136a3a301d87f6d49 100644 (file)
@@ -26,7 +26,7 @@
 #include "display/intel_dp.h"
 
 #include "i915_drv.h"
-#include "intel_drv.h"
+#include "intel_display_types.h"
 #include "intel_psr.h"
 #include "intel_sprite.h"
 
index 0b749c28541fcc60920b8b232541f2bb08a9d673..399b1542509f76a0a57b33c69abf427a271d6e6a 100644 (file)
@@ -5,7 +5,7 @@
 
 #include <linux/dmi.h>
 
-#include "intel_drv.h"
+#include "intel_display_types.h"
 #include "intel_quirks.h"
 
 /*
index c5e2dfd7ef80caef61b1b0ea260dcad903349ef9..adeb1c840976845739c259de4789e7c0a5edf9ec 100644 (file)
@@ -39,7 +39,7 @@
 #include "i915_drv.h"
 #include "intel_atomic.h"
 #include "intel_connector.h"
-#include "intel_drv.h"
+#include "intel_display_types.h"
 #include "intel_fifo_underrun.h"
 #include "intel_gmbus.h"
 #include "intel_hdmi.h"
index a8493c8d5e1d168678660a17d23ba9041a310e4f..dea63be1964f2fe6df25ab60da07f2504dc8fe68 100644 (file)
@@ -42,7 +42,7 @@
 #include "i915_drv.h"
 #include "i915_trace.h"
 #include "intel_atomic_plane.h"
-#include "intel_drv.h"
+#include "intel_display_types.h"
 #include "intel_frontbuffer.h"
 #include "intel_pm.h"
 #include "intel_psr.h"
index a4d3d2d541c4acf2f6eea0c184686ce9d8756866..85743a43bee203790a3bdbd290702dfb845460fa 100644 (file)
@@ -5,9 +5,9 @@
 
 #include "i915_drv.h"
 #include "intel_display.h"
+#include "intel_display_types.h"
 #include "intel_dp_mst.h"
 #include "intel_tc.h"
-#include "intel_drv.h"
 
 static const char *tc_port_mode_name(enum tc_port_mode mode)
 {
index 0a95df6c6a57f52401facfbaf88623780963fd8b..b70221f5112a78179d1885fd3d011cbcb55eb6dd 100644 (file)
@@ -37,7 +37,7 @@
 
 #include "i915_drv.h"
 #include "intel_connector.h"
-#include "intel_drv.h"
+#include "intel_display_types.h"
 #include "intel_hotplug.h"
 #include "intel_tv.h"
 
index 4ab19c432ef56965b0eb8627ddc73ed8c2e33aea..598ddb60f9fb5cfb9e45af6cee18dc18ebfbe1ff 100644 (file)
@@ -9,7 +9,7 @@
 #include <drm/i915_drm.h>
 
 #include "i915_drv.h"
-#include "intel_drv.h"
+#include "intel_display_types.h"
 #include "intel_vdsc.h"
 
 enum ROW_INDEX_BPP {
index c8002ffd29e79f08f4535f6bdcfb784d64505efd..6d535855e64e9a40177651e62faf56d2fbd03955 100644 (file)
@@ -34,7 +34,7 @@
 #include "i915_drv.h"
 #include "intel_atomic.h"
 #include "intel_connector.h"
-#include "intel_drv.h"
+#include "intel_display_types.h"
 #include "intel_dsi.h"
 #include "intel_fifo_underrun.h"
 #include "intel_panel.h"
index f016a776a39e32bf96f77dbd363997b7ad5caf1b..126edbaa814c526635ecc37c32a4e99f00009c89 100644 (file)
@@ -28,7 +28,7 @@
 #include <linux/kernel.h>
 
 #include "i915_drv.h"
-#include "intel_drv.h"
+#include "intel_display_types.h"
 #include "intel_dsi.h"
 #include "intel_sideband.h"
 
index 997e122545bc3cf4f6e23ad5b73c81a636434bec..2f7a3736c2e56eb5b039db3a8c950f03db2183ee 100644 (file)
@@ -2,10 +2,11 @@
 /*
  * Copyright Â© 2019 Intel Corporation
  */
-#include "i915_gem_client_blt.h"
 
+#include "display/intel_display_types.h"
+
+#include "i915_gem_client_blt.h"
 #include "i915_gem_object_blt.h"
-#include "intel_drv.h"
 
 struct i915_sleeve {
        struct i915_vma *vma;
index 0c8c909743f194cf7db39d241420b8c626343468..4592c7da6007e388afea2cfd488c4770f385116c 100644 (file)
@@ -12,6 +12,7 @@
 #include <drm/drm_syncobj.h>
 #include <drm/i915_drm.h>
 
+#include "display/intel_display_types.h"
 #include "display/intel_frontbuffer.h"
 
 #include "gem/i915_gem_ioctls.h"
@@ -24,7 +25,6 @@
 #include "i915_gem_clflush.h"
 #include "i915_gem_context.h"
 #include "i915_trace.h"
-#include "intel_drv.h"
 
 enum {
        FORCE_CPU_RELOC = 1,
index 9a733c6853c4c252f90da8f522898d514a14422c..7b40ceb7566bd36990638ec3e8366a7481607a99 100644 (file)
@@ -7,6 +7,7 @@
 #include <linux/mman.h>
 #include <linux/sizes.h>
 
+#include "display/intel_display_types.h"
 #include "gt/intel_gt.h"
 
 #include "i915_drv.h"
@@ -15,7 +16,6 @@
 #include "i915_gem_object.h"
 #include "i915_trace.h"
 #include "i915_vma.h"
-#include "intel_drv.h"
 
 static inline bool
 __vma_matches(struct vm_area_struct *vma, struct file *filp,
index 685064af32d15909324252695662f826bb90b1aa..e6133880f9d05323eb749cd9efd317f5b369cd75 100644 (file)
@@ -3,10 +3,10 @@
  * Copyright Â© 2019 Intel Corporation
  */
 
-#include "i915_gem_object_blt.h"
+#include "display/intel_display_types.h"
 
+#include "i915_gem_object_blt.h"
 #include "i915_gem_clflush.h"
-#include "intel_drv.h"
 
 int intel_emit_vma_fill_blt(struct i915_request *rq,
                            struct i915_vma *vma,
index b9d2bb15e4a69b6b5c6cdc85399119451c75a7b2..51720b733cfe92347dcbf71119f2857a7f97c026 100644 (file)
 
 #include <drm/i915_drm.h>
 
+#include "display/intel_display_types.h"
+
 #include "i915_gem_ioctls.h"
 #include "i915_gem_object.h"
 #include "i915_scatterlist.h"
 #include "i915_trace.h"
-#include "intel_drv.h"
 
 struct i915_mm_struct {
        struct mm_struct *mm;
index cdba6cd29327ad95787e2820ea75086f07bba89e..ec85740de942f582602e31f18b411db6e6463fff 100644 (file)
@@ -7,6 +7,7 @@
 #include <linux/sched/mm.h>
 #include <linux/stop_machine.h>
 
+#include "display/intel_display_types.h"
 #include "display/intel_overlay.h"
 
 #include "gem/i915_gem_context.h"
index b197aae101e48a1f618acaf472d2dff9cf8cb7a5..3b15266c54fdf7cc45a3f904e21b6b2c723a12b6 100644 (file)
@@ -32,6 +32,7 @@
 #include <drm/drm_debugfs.h>
 #include <drm/drm_fourcc.h>
 
+#include "display/intel_display_types.h"
 #include "display/intel_dp.h"
 #include "display/intel_fbc.h"
 #include "display/intel_hdcp.h"
@@ -46,7 +47,6 @@
 #include "i915_irq.h"
 #include "i915_trace.h"
 #include "intel_csr.h"
-#include "intel_drv.h"
 #include "intel_pm.h"
 #include "intel_sideband.h"
 
index bea440ac8b0f05bf819f53872a4356d23e83fe1b..ff26c4d1f20dfdb411cfe9a1a979b2f546f2177a 100644 (file)
@@ -51,6 +51,7 @@
 #include "display/intel_audio.h"
 #include "display/intel_bw.h"
 #include "display/intel_cdclk.h"
+#include "display/intel_display_types.h"
 #include "display/intel_dp.h"
 #include "display/intel_fbdev.h"
 #include "display/intel_gmbus.h"
@@ -76,7 +77,6 @@
 #include "i915_trace.h"
 #include "i915_vgpu.h"
 #include "intel_csr.h"
-#include "intel_drv.h"
 #include "intel_pm.h"
 
 static struct drm_driver driver;
index 7efff14b9137d241d53b38781aca8f8023561e66..6e22a8ddacc81f17c6ff73673dd8c9d4b89f8086 100644 (file)
@@ -39,6 +39,7 @@
 #include <linux/mman.h>
 
 #include "display/intel_display.h"
+#include "display/intel_display_types.h"
 #include "display/intel_frontbuffer.h"
 
 #include "gem/i915_gem_clflush.h"
@@ -59,7 +60,6 @@
 #include "i915_trace.h"
 #include "i915_vgpu.h"
 
-#include "intel_drv.h"
 #include "intel_pm.h"
 
 static int
index a5783c4cb98b3d2b7e5f89a5f0ba697ba27c2d90..ca5040761376a701ec68f7191b0fab195fc7d462 100644 (file)
 
 #include <drm/i915_drm.h>
 
+#include "display/intel_display_types.h"
 #include "gem/i915_gem_context.h"
 
 #include "i915_drv.h"
-#include "intel_drv.h"
 #include "i915_trace.h"
 
 I915_SELFTEST_DECLARE(static struct igt_evict_ctl {
index bcac359ec66194f06953879bb06567f5b1317945..45c34b1c4d93e280a2fb48a94776fa3813afb214 100644 (file)
@@ -23,6 +23,8 @@
 
 #include <drm/i915_drm.h>
 
+#include "display/intel_display_types.h"
+
 #include "i915_drv.h"
 #include "i915_scatterlist.h"
 #include "i915_vgpu.h"
index c3028722d4e365f918cbf4171d91f755a8b4ddea..c19e4fa70a4f6c5abc314324474c6fa03327b783 100644 (file)
@@ -35,6 +35,7 @@
 
 #include <drm/i915_drm.h>
 
+#include "display/intel_display_types.h"
 #include "display/intel_frontbuffer.h"
 #include "gt/intel_gt.h"
 
@@ -42,7 +43,6 @@
 #include "i915_scatterlist.h"
 #include "i915_trace.h"
 #include "i915_vgpu.h"
-#include "intel_drv.h"
 
 #define I915_GFP_ALLOW_FAIL (GFP_KERNEL | __GFP_RETRY_MAYFAIL | __GFP_NOWARN)
 
index 019ae347f45c2c9ae96373afd6a439eedff9b693..75359c2763957c1cbe6b116633204b4e77a1f341 100644 (file)
@@ -37,6 +37,7 @@
 #include <drm/drm_irq.h>
 #include <drm/i915_drm.h>
 
+#include "display/intel_display_types.h"
 #include "display/intel_fifo_underrun.h"
 #include "display/intel_hotplug.h"
 #include "display/intel_lpe_audio.h"
@@ -47,7 +48,6 @@
 #include "i915_drv.h"
 #include "i915_irq.h"
 #include "i915_trace.h"
-#include "intel_drv.h"
 #include "intel_pm.h"
 
 /**
index a08d7d16621b794fda4dca89cc9cc86325b08398..9b95084737c1e7270874d6e517cacae522263fe5 100644 (file)
 
 #include <drm/i915_drm.h>
 
+#include "display/intel_display_types.h"
 #include "display/intel_fbc.h"
 #include "display/intel_gmbus.h"
 
 #include "i915_reg.h"
-#include "intel_drv.h"
 
 static void i915_save_display(struct drm_i915_private *dev_priv)
 {
index ecac1c3861091f32b605323ef9ef6b251ec606d2..1a356a68af9387b060f31e0cffa70c65088984c7 100644 (file)
@@ -30,8 +30,9 @@
 #include <linux/stat.h>
 #include <linux/sysfs.h>
 
+#include "display/intel_display_types.h"
+
 #include "i915_drv.h"
-#include "intel_drv.h"
 #include "intel_pm.h"
 #include "intel_sideband.h"
 
index 1d11245c4c87a3092e28406bc79d6e6411b24448..24f2944da09de8296976f9532970b99271b7a3ca 100644 (file)
@@ -8,11 +8,11 @@
 
 #include <drm/drm_drv.h>
 
+#include "display/intel_display_types.h"
 #include "gt/intel_engine.h"
 
 #include "i915_drv.h"
 #include "i915_irq.h"
-#include "intel_drv.h"
 
 #undef TRACE_SYSTEM
 #define TRACE_SYSTEM i915
index dbd1fa3c7d9071f3d5da25d2b281119a545a837f..4982428f9af380eac032005f4c0f724fe5dc1b2a 100644 (file)
@@ -21,7 +21,7 @@
  * SOFTWARE.
  */
 
-#include "intel_drv.h"
+#include "display/intel_display_types.h"
 #include "i915_vgpu.h"
 
 /**
diff --git a/drivers/gpu/drm/i915/intel_drv.h b/drivers/gpu/drm/i915/intel_drv.h
deleted file mode 100644 (file)
index d6f851d..0000000
+++ /dev/null
@@ -1,1509 +0,0 @@
-/*
- * Copyright (c) 2006 Dave Airlie <airlied@linux.ie>
- * Copyright (c) 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 (including the next
- * paragraph) 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 AUTHORS OR COPYRIGHT HOLDERS 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 __INTEL_DRV_H__
-#define __INTEL_DRV_H__
-
-#include <linux/async.h>
-#include <linux/i2c.h>
-#include <linux/sched/clock.h>
-
-#include <drm/drm_atomic.h>
-#include <drm/drm_crtc.h>
-#include <drm/drm_dp_dual_mode_helper.h>
-#include <drm/drm_dp_mst_helper.h>
-#include <drm/drm_encoder.h>
-#include <drm/drm_fb_helper.h>
-#include <drm/drm_probe_helper.h>
-#include <drm/drm_rect.h>
-#include <drm/drm_vblank.h>
-#include <drm/i915_drm.h>
-#include <drm/i915_mei_hdcp_interface.h>
-#include <media/cec-notifier.h>
-
-#include "i915_drv.h"
-
-struct drm_printer;
-
-/*
- * Display related stuff
- */
-
-/* these are outputs from the chip - integrated only
-   external chips are via DVO or SDVO output */
-enum intel_output_type {
-       INTEL_OUTPUT_UNUSED = 0,
-       INTEL_OUTPUT_ANALOG = 1,
-       INTEL_OUTPUT_DVO = 2,
-       INTEL_OUTPUT_SDVO = 3,
-       INTEL_OUTPUT_LVDS = 4,
-       INTEL_OUTPUT_TVOUT = 5,
-       INTEL_OUTPUT_HDMI = 6,
-       INTEL_OUTPUT_DP = 7,
-       INTEL_OUTPUT_EDP = 8,
-       INTEL_OUTPUT_DSI = 9,
-       INTEL_OUTPUT_DDI = 10,
-       INTEL_OUTPUT_DP_MST = 11,
-};
-
-struct intel_framebuffer {
-       struct drm_framebuffer base;
-       struct intel_rotation_info rot_info;
-
-       /* for each plane in the normal GTT view */
-       struct {
-               unsigned int x, y;
-       } normal[2];
-       /* for each plane in the rotated GTT view */
-       struct {
-               unsigned int x, y;
-               unsigned int pitch; /* pixels */
-       } rotated[2];
-};
-
-struct intel_fbdev {
-       struct drm_fb_helper helper;
-       struct intel_framebuffer *fb;
-       struct i915_vma *vma;
-       unsigned long vma_flags;
-       async_cookie_t cookie;
-       int preferred_bpp;
-
-       /* Whether or not fbdev hpd processing is temporarily suspended */
-       bool hpd_suspended : 1;
-       /* Set when a hotplug was received while HPD processing was
-        * suspended
-        */
-       bool hpd_waiting : 1;
-
-       /* Protects hpd_suspended */
-       struct mutex hpd_lock;
-};
-
-enum intel_hotplug_state {
-       INTEL_HOTPLUG_UNCHANGED,
-       INTEL_HOTPLUG_CHANGED,
-       INTEL_HOTPLUG_RETRY,
-};
-
-struct intel_encoder {
-       struct drm_encoder base;
-
-       enum intel_output_type type;
-       enum port port;
-       unsigned int cloneable;
-       enum intel_hotplug_state (*hotplug)(struct intel_encoder *encoder,
-                                           struct intel_connector *connector,
-                                           bool irq_received);
-       enum intel_output_type (*compute_output_type)(struct intel_encoder *,
-                                                     struct intel_crtc_state *,
-                                                     struct drm_connector_state *);
-       int (*compute_config)(struct intel_encoder *,
-                             struct intel_crtc_state *,
-                             struct drm_connector_state *);
-       void (*update_prepare)(struct intel_atomic_state *,
-                              struct intel_encoder *,
-                              struct intel_crtc *);
-       void (*pre_pll_enable)(struct intel_encoder *,
-                              const struct intel_crtc_state *,
-                              const struct drm_connector_state *);
-       void (*pre_enable)(struct intel_encoder *,
-                          const struct intel_crtc_state *,
-                          const struct drm_connector_state *);
-       void (*enable)(struct intel_encoder *,
-                      const struct intel_crtc_state *,
-                      const struct drm_connector_state *);
-       void (*update_complete)(struct intel_atomic_state *,
-                               struct intel_encoder *,
-                               struct intel_crtc *);
-       void (*disable)(struct intel_encoder *,
-                       const struct intel_crtc_state *,
-                       const struct drm_connector_state *);
-       void (*post_disable)(struct intel_encoder *,
-                            const struct intel_crtc_state *,
-                            const struct drm_connector_state *);
-       void (*post_pll_disable)(struct intel_encoder *,
-                                const struct intel_crtc_state *,
-                                const struct drm_connector_state *);
-       void (*update_pipe)(struct intel_encoder *,
-                           const struct intel_crtc_state *,
-                           const struct drm_connector_state *);
-       /* Read out the current hw state of this connector, returning true if
-        * the encoder is active. If the encoder is enabled it also set the pipe
-        * it is connected to in the pipe parameter. */
-       bool (*get_hw_state)(struct intel_encoder *, enum pipe *pipe);
-       /* Reconstructs the equivalent mode flags for the current hardware
-        * state. This must be called _after_ display->get_pipe_config has
-        * pre-filled the pipe config. Note that intel_encoder->base.crtc must
-        * be set correctly before calling this function. */
-       void (*get_config)(struct intel_encoder *,
-                          struct intel_crtc_state *pipe_config);
-       /*
-        * Acquires the power domains needed for an active encoder during
-        * hardware state readout.
-        */
-       void (*get_power_domains)(struct intel_encoder *encoder,
-                                 struct intel_crtc_state *crtc_state);
-       /*
-        * Called during system suspend after all pending requests for the
-        * encoder are flushed (for example for DP AUX transactions) and
-        * device interrupts are disabled.
-        */
-       void (*suspend)(struct intel_encoder *);
-       int crtc_mask;
-       enum hpd_pin hpd_pin;
-       enum intel_display_power_domain power_domain;
-       /* for communication with audio component; protected by av_mutex */
-       const struct drm_connector *audio_connector;
-};
-
-struct intel_panel {
-       struct drm_display_mode *fixed_mode;
-       struct drm_display_mode *downclock_mode;
-
-       /* backlight */
-       struct {
-               bool present;
-               u32 level;
-               u32 min;
-               u32 max;
-               bool enabled;
-               bool combination_mode;  /* gen 2/4 only */
-               bool active_low_pwm;
-               bool alternate_pwm_increment;   /* lpt+ */
-
-               /* PWM chip */
-               bool util_pin_active_low;       /* bxt+ */
-               u8 controller;          /* bxt+ only */
-               struct pwm_device *pwm;
-
-               struct backlight_device *device;
-
-               /* Connector and platform specific backlight functions */
-               int (*setup)(struct intel_connector *connector, enum pipe pipe);
-               u32 (*get)(struct intel_connector *connector);
-               void (*set)(const struct drm_connector_state *conn_state, u32 level);
-               void (*disable)(const struct drm_connector_state *conn_state);
-               void (*enable)(const struct intel_crtc_state *crtc_state,
-                              const struct drm_connector_state *conn_state);
-               u32 (*hz_to_pwm)(struct intel_connector *connector, u32 hz);
-               void (*power)(struct intel_connector *, bool enable);
-       } backlight;
-};
-
-struct intel_digital_port;
-
-enum check_link_response {
-       HDCP_LINK_PROTECTED     = 0,
-       HDCP_TOPOLOGY_CHANGE,
-       HDCP_LINK_INTEGRITY_FAILURE,
-       HDCP_REAUTH_REQUEST
-};
-
-/*
- * This structure serves as a translation layer between the generic HDCP code
- * and the bus-specific code. What that means is that HDCP over HDMI differs
- * from HDCP over DP, so to account for these differences, we need to
- * communicate with the receiver through this shim.
- *
- * For completeness, the 2 buses differ in the following ways:
- *     - DP AUX vs. DDC
- *             HDCP registers on the receiver are set via DP AUX for DP, and
- *             they are set via DDC for HDMI.
- *     - Receiver register offsets
- *             The offsets of the registers are different for DP vs. HDMI
- *     - Receiver register masks/offsets
- *             For instance, the ready bit for the KSV fifo is in a different
- *             place on DP vs HDMI
- *     - Receiver register names
- *             Seriously. In the DP spec, the 16-bit register containing
- *             downstream information is called BINFO, on HDMI it's called
- *             BSTATUS. To confuse matters further, DP has a BSTATUS register
- *             with a completely different definition.
- *     - KSV FIFO
- *             On HDMI, the ksv fifo is read all at once, whereas on DP it must
- *             be read 3 keys at a time
- *     - Aksv output
- *             Since Aksv is hidden in hardware, there's different procedures
- *             to send it over DP AUX vs DDC
- */
-struct intel_hdcp_shim {
-       /* Outputs the transmitter's An and Aksv values to the receiver. */
-       int (*write_an_aksv)(struct intel_digital_port *intel_dig_port, u8 *an);
-
-       /* Reads the receiver's key selection vector */
-       int (*read_bksv)(struct intel_digital_port *intel_dig_port, u8 *bksv);
-
-       /*
-        * Reads BINFO from DP receivers and BSTATUS from HDMI receivers. The
-        * definitions are the same in the respective specs, but the names are
-        * different. Call it BSTATUS since that's the name the HDMI spec
-        * uses and it was there first.
-        */
-       int (*read_bstatus)(struct intel_digital_port *intel_dig_port,
-                           u8 *bstatus);
-
-       /* Determines whether a repeater is present downstream */
-       int (*repeater_present)(struct intel_digital_port *intel_dig_port,
-                               bool *repeater_present);
-
-       /* Reads the receiver's Ri' value */
-       int (*read_ri_prime)(struct intel_digital_port *intel_dig_port, u8 *ri);
-
-       /* Determines if the receiver's KSV FIFO is ready for consumption */
-       int (*read_ksv_ready)(struct intel_digital_port *intel_dig_port,
-                             bool *ksv_ready);
-
-       /* Reads the ksv fifo for num_downstream devices */
-       int (*read_ksv_fifo)(struct intel_digital_port *intel_dig_port,
-                            int num_downstream, u8 *ksv_fifo);
-
-       /* Reads a 32-bit part of V' from the receiver */
-       int (*read_v_prime_part)(struct intel_digital_port *intel_dig_port,
-                                int i, u32 *part);
-
-       /* Enables HDCP signalling on the port */
-       int (*toggle_signalling)(struct intel_digital_port *intel_dig_port,
-                                bool enable);
-
-       /* Ensures the link is still protected */
-       bool (*check_link)(struct intel_digital_port *intel_dig_port);
-
-       /* Detects panel's hdcp capability. This is optional for HDMI. */
-       int (*hdcp_capable)(struct intel_digital_port *intel_dig_port,
-                           bool *hdcp_capable);
-
-       /* HDCP adaptation(DP/HDMI) required on the port */
-       enum hdcp_wired_protocol protocol;
-
-       /* Detects whether sink is HDCP2.2 capable */
-       int (*hdcp_2_2_capable)(struct intel_digital_port *intel_dig_port,
-                               bool *capable);
-
-       /* Write HDCP2.2 messages */
-       int (*write_2_2_msg)(struct intel_digital_port *intel_dig_port,
-                            void *buf, size_t size);
-
-       /* Read HDCP2.2 messages */
-       int (*read_2_2_msg)(struct intel_digital_port *intel_dig_port,
-                           u8 msg_id, void *buf, size_t size);
-
-       /*
-        * Implementation of DP HDCP2.2 Errata for the communication of stream
-        * type to Receivers. In DP HDCP2.2 Stream type is one of the input to
-        * the HDCP2.2 Cipher for En/De-Cryption. Not applicable for HDMI.
-        */
-       int (*config_stream_type)(struct intel_digital_port *intel_dig_port,
-                                 bool is_repeater, u8 type);
-
-       /* HDCP2.2 Link Integrity Check */
-       int (*check_2_2_link)(struct intel_digital_port *intel_dig_port);
-};
-
-struct intel_hdcp {
-       const struct intel_hdcp_shim *shim;
-       /* Mutex for hdcp state of the connector */
-       struct mutex mutex;
-       u64 value;
-       struct delayed_work check_work;
-       struct work_struct prop_work;
-
-       /* HDCP1.4 Encryption status */
-       bool hdcp_encrypted;
-
-       /* HDCP2.2 related definitions */
-       /* Flag indicates whether this connector supports HDCP2.2 or not. */
-       bool hdcp2_supported;
-
-       /* HDCP2.2 Encryption status */
-       bool hdcp2_encrypted;
-
-       /*
-        * Content Stream Type defined by content owner. TYPE0(0x0) content can
-        * flow in the link protected by HDCP2.2 or HDCP1.4, where as TYPE1(0x1)
-        * content can flow only through a link protected by HDCP2.2.
-        */
-       u8 content_type;
-       struct hdcp_port_data port_data;
-
-       bool is_paired;
-       bool is_repeater;
-
-       /*
-        * Count of ReceiverID_List received. Initialized to 0 at AKE_INIT.
-        * Incremented after processing the RepeaterAuth_Send_ReceiverID_List.
-        * When it rolls over re-auth has to be triggered.
-        */
-       u32 seq_num_v;
-
-       /*
-        * Count of RepeaterAuth_Stream_Manage msg propagated.
-        * Initialized to 0 on AKE_INIT. Incremented after every successful
-        * transmission of RepeaterAuth_Stream_Manage message. When it rolls
-        * over re-Auth has to be triggered.
-        */
-       u32 seq_num_m;
-
-       /*
-        * Work queue to signal the CP_IRQ. Used for the waiters to read the
-        * available information from HDCP DP sink.
-        */
-       wait_queue_head_t cp_irq_queue;
-       atomic_t cp_irq_count;
-       int cp_irq_count_cached;
-};
-
-struct intel_connector {
-       struct drm_connector base;
-       /*
-        * The fixed encoder this connector is connected to.
-        */
-       struct intel_encoder *encoder;
-
-       /* ACPI device id for ACPI and driver cooperation */
-       u32 acpi_device_id;
-
-       /* Reads out the current hw, returning true if the connector is enabled
-        * and active (i.e. dpms ON state). */
-       bool (*get_hw_state)(struct intel_connector *);
-
-       /* Panel info for eDP and LVDS */
-       struct intel_panel panel;
-
-       /* Cached EDID for eDP and LVDS. May hold ERR_PTR for invalid EDID. */
-       struct edid *edid;
-       struct edid *detect_edid;
-
-       /* since POLL and HPD connectors may use the same HPD line keep the native
-          state of connector->polled in case hotplug storm detection changes it */
-       u8 polled;
-
-       void *port; /* store this opaque as its illegal to dereference it */
-
-       struct intel_dp *mst_port;
-
-       /* Work struct to schedule a uevent on link train failure */
-       struct work_struct modeset_retry_work;
-
-       struct intel_hdcp hdcp;
-};
-
-struct intel_digital_connector_state {
-       struct drm_connector_state base;
-
-       enum hdmi_force_audio force_audio;
-       int broadcast_rgb;
-};
-
-#define to_intel_digital_connector_state(x) container_of(x, struct intel_digital_connector_state, base)
-
-struct dpll {
-       /* given values */
-       int n;
-       int m1, m2;
-       int p1, p2;
-       /* derived values */
-       int     dot;
-       int     vco;
-       int     m;
-       int     p;
-};
-
-struct intel_atomic_state {
-       struct drm_atomic_state base;
-
-       intel_wakeref_t wakeref;
-
-       struct {
-               /*
-                * Logical state of cdclk (used for all scaling, watermark,
-                * etc. calculations and checks). This is computed as if all
-                * enabled crtcs were active.
-                */
-               struct intel_cdclk_state logical;
-
-               /*
-                * Actual state of cdclk, can be different from the logical
-                * state only when all crtc's are DPMS off.
-                */
-               struct intel_cdclk_state actual;
-
-               int force_min_cdclk;
-               bool force_min_cdclk_changed;
-               /* pipe to which cd2x update is synchronized */
-               enum pipe pipe;
-       } cdclk;
-
-       bool dpll_set, modeset;
-
-       /*
-        * Does this transaction change the pipes that are active?  This mask
-        * tracks which CRTC's have changed their active state at the end of
-        * the transaction (not counting the temporary disable during modesets).
-        * This mask should only be non-zero when intel_state->modeset is true,
-        * but the converse is not necessarily true; simply changing a mode may
-        * not flip the final active status of any CRTC's
-        */
-       unsigned int active_pipe_changes;
-
-       unsigned int active_crtcs;
-       /* minimum acceptable cdclk for each pipe */
-       int min_cdclk[I915_MAX_PIPES];
-       /* minimum acceptable voltage level for each pipe */
-       u8 min_voltage_level[I915_MAX_PIPES];
-
-       struct intel_shared_dpll_state shared_dpll[I915_NUM_PLLS];
-
-       /*
-        * Current watermarks can't be trusted during hardware readout, so
-        * don't bother calculating intermediate watermarks.
-        */
-       bool skip_intermediate_wm;
-
-       bool rps_interactive;
-
-       /* Gen9+ only */
-       struct skl_ddb_values wm_results;
-
-       struct i915_sw_fence commit_ready;
-
-       struct llist_node freed;
-};
-
-struct intel_plane_state {
-       struct drm_plane_state base;
-       struct i915_ggtt_view view;
-       struct i915_vma *vma;
-       unsigned long flags;
-#define PLANE_HAS_FENCE BIT(0)
-
-       struct {
-               u32 offset;
-               /*
-                * Plane stride in:
-                * bytes for 0/180 degree rotation
-                * pixels for 90/270 degree rotation
-                */
-               u32 stride;
-               int x, y;
-       } color_plane[2];
-
-       /* plane control register */
-       u32 ctl;
-
-       /* plane color control register */
-       u32 color_ctl;
-
-       /*
-        * scaler_id
-        *    = -1 : not using a scaler
-        *    >=  0 : using a scalers
-        *
-        * plane requiring a scaler:
-        *   - During check_plane, its bit is set in
-        *     crtc_state->scaler_state.scaler_users by calling helper function
-        *     update_scaler_plane.
-        *   - scaler_id indicates the scaler it got assigned.
-        *
-        * plane doesn't require a scaler:
-        *   - this can happen when scaling is no more required or plane simply
-        *     got disabled.
-        *   - During check_plane, corresponding bit is reset in
-        *     crtc_state->scaler_state.scaler_users by calling helper function
-        *     update_scaler_plane.
-        */
-       int scaler_id;
-
-       /*
-        * linked_plane:
-        *
-        * ICL planar formats require 2 planes that are updated as pairs.
-        * This member is used to make sure the other plane is also updated
-        * when required, and for update_slave() to find the correct
-        * plane_state to pass as argument.
-        */
-       struct intel_plane *linked_plane;
-
-       /*
-        * slave:
-        * If set don't update use the linked plane's state for updating
-        * this plane during atomic commit with the update_slave() callback.
-        *
-        * It's also used by the watermark code to ignore wm calculations on
-        * this plane. They're calculated by the linked plane's wm code.
-        */
-       u32 slave;
-
-       struct drm_intel_sprite_colorkey ckey;
-};
-
-struct intel_initial_plane_config {
-       struct intel_framebuffer *fb;
-       unsigned int tiling;
-       int size;
-       u32 base;
-       u8 rotation;
-};
-
-struct intel_scaler {
-       int in_use;
-       u32 mode;
-};
-
-struct intel_crtc_scaler_state {
-#define SKL_NUM_SCALERS 2
-       struct intel_scaler scalers[SKL_NUM_SCALERS];
-
-       /*
-        * scaler_users: keeps track of users requesting scalers on this crtc.
-        *
-        *     If a bit is set, a user is using a scaler.
-        *     Here user can be a plane or crtc as defined below:
-        *       bits 0-30 - plane (bit position is index from drm_plane_index)
-        *       bit 31    - crtc
-        *
-        * Instead of creating a new index to cover planes and crtc, using
-        * existing drm_plane_index for planes which is well less than 31
-        * planes and bit 31 for crtc. This should be fine to cover all
-        * our platforms.
-        *
-        * intel_atomic_setup_scalers will setup available scalers to users
-        * requesting scalers. It will gracefully fail if request exceeds
-        * avilability.
-        */
-#define SKL_CRTC_INDEX 31
-       unsigned scaler_users;
-
-       /* scaler used by crtc for panel fitting purpose */
-       int scaler_id;
-};
-
-/* drm_mode->private_flags */
-#define I915_MODE_FLAG_INHERITED (1<<0)
-/* Flag to get scanline using frame time stamps */
-#define I915_MODE_FLAG_GET_SCANLINE_FROM_TIMESTAMP (1<<1)
-/* Flag to use the scanline counter instead of the pixel counter */
-#define I915_MODE_FLAG_USE_SCANLINE_COUNTER (1<<2)
-
-struct intel_pipe_wm {
-       struct intel_wm_level wm[5];
-       u32 linetime;
-       bool fbc_wm_enabled;
-       bool pipe_enabled;
-       bool sprites_enabled;
-       bool sprites_scaled;
-};
-
-struct skl_plane_wm {
-       struct skl_wm_level wm[8];
-       struct skl_wm_level uv_wm[8];
-       struct skl_wm_level trans_wm;
-       bool is_planar;
-};
-
-struct skl_pipe_wm {
-       struct skl_plane_wm planes[I915_MAX_PLANES];
-       u32 linetime;
-};
-
-enum vlv_wm_level {
-       VLV_WM_LEVEL_PM2,
-       VLV_WM_LEVEL_PM5,
-       VLV_WM_LEVEL_DDR_DVFS,
-       NUM_VLV_WM_LEVELS,
-};
-
-struct vlv_wm_state {
-       struct g4x_pipe_wm wm[NUM_VLV_WM_LEVELS];
-       struct g4x_sr_wm sr[NUM_VLV_WM_LEVELS];
-       u8 num_levels;
-       bool cxsr;
-};
-
-struct vlv_fifo_state {
-       u16 plane[I915_MAX_PLANES];
-};
-
-enum g4x_wm_level {
-       G4X_WM_LEVEL_NORMAL,
-       G4X_WM_LEVEL_SR,
-       G4X_WM_LEVEL_HPLL,
-       NUM_G4X_WM_LEVELS,
-};
-
-struct g4x_wm_state {
-       struct g4x_pipe_wm wm;
-       struct g4x_sr_wm sr;
-       struct g4x_sr_wm hpll;
-       bool cxsr;
-       bool hpll_en;
-       bool fbc_en;
-};
-
-struct intel_crtc_wm_state {
-       union {
-               struct {
-                       /*
-                        * Intermediate watermarks; these can be
-                        * programmed immediately since they satisfy
-                        * both the current configuration we're
-                        * switching away from and the new
-                        * configuration we're switching to.
-                        */
-                       struct intel_pipe_wm intermediate;
-
-                       /*
-                        * Optimal watermarks, programmed post-vblank
-                        * when this state is committed.
-                        */
-                       struct intel_pipe_wm optimal;
-               } ilk;
-
-               struct {
-                       /* gen9+ only needs 1-step wm programming */
-                       struct skl_pipe_wm optimal;
-                       struct skl_ddb_entry ddb;
-                       struct skl_ddb_entry plane_ddb_y[I915_MAX_PLANES];
-                       struct skl_ddb_entry plane_ddb_uv[I915_MAX_PLANES];
-               } skl;
-
-               struct {
-                       /* "raw" watermarks (not inverted) */
-                       struct g4x_pipe_wm raw[NUM_VLV_WM_LEVELS];
-                       /* intermediate watermarks (inverted) */
-                       struct vlv_wm_state intermediate;
-                       /* optimal watermarks (inverted) */
-                       struct vlv_wm_state optimal;
-                       /* display FIFO split */
-                       struct vlv_fifo_state fifo_state;
-               } vlv;
-
-               struct {
-                       /* "raw" watermarks */
-                       struct g4x_pipe_wm raw[NUM_G4X_WM_LEVELS];
-                       /* intermediate watermarks */
-                       struct g4x_wm_state intermediate;
-                       /* optimal watermarks */
-                       struct g4x_wm_state optimal;
-               } g4x;
-       };
-
-       /*
-        * Platforms with two-step watermark programming will need to
-        * update watermark programming post-vblank to switch from the
-        * safe intermediate watermarks to the optimal final
-        * watermarks.
-        */
-       bool need_postvbl_update;
-};
-
-enum intel_output_format {
-       INTEL_OUTPUT_FORMAT_INVALID,
-       INTEL_OUTPUT_FORMAT_RGB,
-       INTEL_OUTPUT_FORMAT_YCBCR420,
-       INTEL_OUTPUT_FORMAT_YCBCR444,
-};
-
-struct intel_crtc_state {
-       struct drm_crtc_state base;
-
-       /**
-        * quirks - bitfield with hw state readout quirks
-        *
-        * For various reasons the hw state readout code might not be able to
-        * completely faithfully read out the current state. These cases are
-        * tracked with quirk flags so that fastboot and state checker can act
-        * accordingly.
-        */
-#define PIPE_CONFIG_QUIRK_MODE_SYNC_FLAGS      (1<<0) /* unreliable sync mode.flags */
-       unsigned long quirks;
-
-       unsigned fb_bits; /* framebuffers to flip */
-       bool update_pipe; /* can a fast modeset be performed? */
-       bool disable_cxsr;
-       bool update_wm_pre, update_wm_post; /* watermarks are updated */
-       bool fb_changed; /* fb on any of the planes is changed */
-       bool fifo_changed; /* FIFO split is changed */
-
-       /* Pipe source size (ie. panel fitter input size)
-        * All planes will be positioned inside this space,
-        * and get clipped at the edges. */
-       int pipe_src_w, pipe_src_h;
-
-       /*
-        * Pipe pixel rate, adjusted for
-        * panel fitter/pipe scaler downscaling.
-        */
-       unsigned int pixel_rate;
-
-       /* Whether to set up the PCH/FDI. Note that we never allow sharing
-        * between pch encoders and cpu encoders. */
-       bool has_pch_encoder;
-
-       /* Are we sending infoframes on the attached port */
-       bool has_infoframe;
-
-       /* CPU Transcoder for the pipe. Currently this can only differ from the
-        * pipe on Haswell and later (where we have a special eDP transcoder)
-        * and Broxton (where we have special DSI transcoders). */
-       enum transcoder cpu_transcoder;
-
-       /*
-        * Use reduced/limited/broadcast rbg range, compressing from the full
-        * range fed into the crtcs.
-        */
-       bool limited_color_range;
-
-       /* Bitmask of encoder types (enum intel_output_type)
-        * driven by the pipe.
-        */
-       unsigned int output_types;
-
-       /* Whether we should send NULL infoframes. Required for audio. */
-       bool has_hdmi_sink;
-
-       /* Audio enabled on this pipe. Only valid if either has_hdmi_sink or
-        * has_dp_encoder is set. */
-       bool has_audio;
-
-       /*
-        * Enable dithering, used when the selected pipe bpp doesn't match the
-        * plane bpp.
-        */
-       bool dither;
-
-       /*
-        * Dither gets enabled for 18bpp which causes CRC mismatch errors for
-        * compliance video pattern tests.
-        * Disable dither only if it is a compliance test request for
-        * 18bpp.
-        */
-       bool dither_force_disable;
-
-       /* Controls for the clock computation, to override various stages. */
-       bool clock_set;
-
-       /* SDVO TV has a bunch of special case. To make multifunction encoders
-        * work correctly, we need to track this at runtime.*/
-       bool sdvo_tv_clock;
-
-       /*
-        * crtc bandwidth limit, don't increase pipe bpp or clock if not really
-        * required. This is set in the 2nd loop of calling encoder's
-        * ->compute_config if the first pick doesn't work out.
-        */
-       bool bw_constrained;
-
-       /* Settings for the intel dpll used on pretty much everything but
-        * haswell. */
-       struct dpll dpll;
-
-       /* Selected dpll when shared or NULL. */
-       struct intel_shared_dpll *shared_dpll;
-
-       /* Actual register state of the dpll, for shared dpll cross-checking. */
-       struct intel_dpll_hw_state dpll_hw_state;
-
-       /*
-        * ICL reserved DPLLs for the CRTC/port. The active PLL is selected by
-        * setting shared_dpll and dpll_hw_state to one of these reserved ones.
-        */
-       struct icl_port_dpll {
-               struct intel_shared_dpll *pll;
-               struct intel_dpll_hw_state hw_state;
-       } icl_port_dplls[ICL_PORT_DPLL_COUNT];
-
-       /* DSI PLL registers */
-       struct {
-               u32 ctrl, div;
-       } dsi_pll;
-
-       int pipe_bpp;
-       struct intel_link_m_n dp_m_n;
-
-       /* m2_n2 for eDP downclock */
-       struct intel_link_m_n dp_m2_n2;
-       bool has_drrs;
-
-       bool has_psr;
-       bool has_psr2;
-
-       /*
-        * Frequence the dpll for the port should run at. Differs from the
-        * adjusted dotclock e.g. for DP or 12bpc hdmi mode. This is also
-        * already multiplied by pixel_multiplier.
-        */
-       int port_clock;
-
-       /* Used by SDVO (and if we ever fix it, HDMI). */
-       unsigned pixel_multiplier;
-
-       u8 lane_count;
-
-       /*
-        * Used by platforms having DP/HDMI PHY with programmable lane
-        * latency optimization.
-        */
-       u8 lane_lat_optim_mask;
-
-       /* minimum acceptable voltage level */
-       u8 min_voltage_level;
-
-       /* Panel fitter controls for gen2-gen4 + VLV */
-       struct {
-               u32 control;
-               u32 pgm_ratios;
-               u32 lvds_border_bits;
-       } gmch_pfit;
-
-       /* Panel fitter placement and size for Ironlake+ */
-       struct {
-               u32 pos;
-               u32 size;
-               bool enabled;
-               bool force_thru;
-       } pch_pfit;
-
-       /* FDI configuration, only valid if has_pch_encoder is set. */
-       int fdi_lanes;
-       struct intel_link_m_n fdi_m_n;
-
-       bool ips_enabled;
-
-       bool crc_enabled;
-
-       bool enable_fbc;
-
-       bool double_wide;
-
-       int pbn;
-
-       struct intel_crtc_scaler_state scaler_state;
-
-       /* w/a for waiting 2 vblanks during crtc enable */
-       enum pipe hsw_workaround_pipe;
-
-       /* IVB sprite scaling w/a (WaCxSRDisabledForSpriteScaling:ivb) */
-       bool disable_lp_wm;
-
-       struct intel_crtc_wm_state wm;
-
-       u32 data_rate[I915_MAX_PLANES];
-
-       /* Gamma mode programmed on the pipe */
-       u32 gamma_mode;
-
-       union {
-               /* CSC mode programmed on the pipe */
-               u32 csc_mode;
-
-               /* CHV CGM mode */
-               u32 cgm_mode;
-       };
-
-       /* bitmask of visible planes (enum plane_id) */
-       u8 active_planes;
-       u8 nv12_planes;
-       u8 c8_planes;
-
-       /* bitmask of planes that will be updated during the commit */
-       u8 update_planes;
-
-       struct {
-               u32 enable;
-               u32 gcp;
-               union hdmi_infoframe avi;
-               union hdmi_infoframe spd;
-               union hdmi_infoframe hdmi;
-               union hdmi_infoframe drm;
-       } infoframes;
-
-       /* HDMI scrambling status */
-       bool hdmi_scrambling;
-
-       /* HDMI High TMDS char rate ratio */
-       bool hdmi_high_tmds_clock_ratio;
-
-       /* Output format RGB/YCBCR etc */
-       enum intel_output_format output_format;
-
-       /* Output down scaling is done in LSPCON device */
-       bool lspcon_downsampling;
-
-       /* enable pipe gamma? */
-       bool gamma_enable;
-
-       /* enable pipe csc? */
-       bool csc_enable;
-
-       /* Display Stream compression state */
-       struct {
-               bool compression_enable;
-               bool dsc_split;
-               u16 compressed_bpp;
-               u8 slice_count;
-       } dsc_params;
-       struct drm_dsc_config dp_dsc_cfg;
-
-       /* Forward Error correction State */
-       bool fec_enable;
-};
-
-struct intel_crtc {
-       struct drm_crtc base;
-       enum pipe pipe;
-       /*
-        * Whether the crtc and the connected output pipeline is active. Implies
-        * that crtc->enabled is set, i.e. the current mode configuration has
-        * some outputs connected to this crtc.
-        */
-       bool active;
-       u8 plane_ids_mask;
-       unsigned long long enabled_power_domains;
-       struct intel_overlay *overlay;
-
-       struct intel_crtc_state *config;
-
-       /* Access to these should be protected by dev_priv->irq_lock. */
-       bool cpu_fifo_underrun_disabled;
-       bool pch_fifo_underrun_disabled;
-
-       /* per-pipe watermark state */
-       struct {
-               /* watermarks currently being used  */
-               union {
-                       struct intel_pipe_wm ilk;
-                       struct vlv_wm_state vlv;
-                       struct g4x_wm_state g4x;
-               } active;
-       } wm;
-
-       int scanline_offset;
-
-       struct {
-               unsigned start_vbl_count;
-               ktime_t start_vbl_time;
-               int min_vbl, max_vbl;
-               int scanline_start;
-       } debug;
-
-       /* scalers available on this crtc */
-       int num_scalers;
-};
-
-struct intel_plane {
-       struct drm_plane base;
-       enum i9xx_plane_id i9xx_plane;
-       enum plane_id id;
-       enum pipe pipe;
-       bool has_fbc;
-       bool has_ccs;
-       u32 frontbuffer_bit;
-
-       struct {
-               u32 base, cntl, size;
-       } cursor;
-
-       /*
-        * NOTE: Do not place new plane state fields here (e.g., when adding
-        * new plane properties).  New runtime state should now be placed in
-        * the intel_plane_state structure and accessed via plane_state.
-        */
-
-       unsigned int (*max_stride)(struct intel_plane *plane,
-                                  u32 pixel_format, u64 modifier,
-                                  unsigned int rotation);
-       void (*update_plane)(struct intel_plane *plane,
-                            const struct intel_crtc_state *crtc_state,
-                            const struct intel_plane_state *plane_state);
-       void (*update_slave)(struct intel_plane *plane,
-                            const struct intel_crtc_state *crtc_state,
-                            const struct intel_plane_state *plane_state);
-       void (*disable_plane)(struct intel_plane *plane,
-                             const struct intel_crtc_state *crtc_state);
-       bool (*get_hw_state)(struct intel_plane *plane, enum pipe *pipe);
-       int (*check_plane)(struct intel_crtc_state *crtc_state,
-                          struct intel_plane_state *plane_state);
-};
-
-struct intel_watermark_params {
-       u16 fifo_size;
-       u16 max_wm;
-       u8 default_wm;
-       u8 guard_size;
-       u8 cacheline_size;
-};
-
-struct cxsr_latency {
-       bool is_desktop : 1;
-       bool is_ddr3 : 1;
-       u16 fsb_freq;
-       u16 mem_freq;
-       u16 display_sr;
-       u16 display_hpll_disable;
-       u16 cursor_sr;
-       u16 cursor_hpll_disable;
-};
-
-#define to_intel_atomic_state(x) container_of(x, struct intel_atomic_state, base)
-#define to_intel_crtc(x) container_of(x, struct intel_crtc, base)
-#define to_intel_crtc_state(x) container_of(x, struct intel_crtc_state, base)
-#define to_intel_connector(x) container_of(x, struct intel_connector, base)
-#define to_intel_encoder(x) container_of(x, struct intel_encoder, base)
-#define to_intel_framebuffer(x) container_of(x, struct intel_framebuffer, base)
-#define to_intel_plane(x) container_of(x, struct intel_plane, base)
-#define to_intel_plane_state(x) container_of(x, struct intel_plane_state, base)
-#define intel_fb_obj(x) ((x) ? to_intel_bo((x)->obj[0]) : NULL)
-
-struct intel_hdmi {
-       i915_reg_t hdmi_reg;
-       int ddc_bus;
-       struct {
-               enum drm_dp_dual_mode_type type;
-               int max_tmds_clock;
-       } dp_dual_mode;
-       bool has_hdmi_sink;
-       bool has_audio;
-       struct intel_connector *attached_connector;
-       struct cec_notifier *cec_notifier;
-};
-
-struct intel_dp_mst_encoder;
-#define DP_MAX_DOWNSTREAM_PORTS                0x10
-
-/*
- * enum link_m_n_set:
- *     When platform provides two set of M_N registers for dp, we can
- *     program them and switch between them incase of DRRS.
- *     But When only one such register is provided, we have to program the
- *     required divider value on that registers itself based on the DRRS state.
- *
- * M1_N1       : Program dp_m_n on M1_N1 registers
- *                       dp_m2_n2 on M2_N2 registers (If supported)
- *
- * M2_N2       : Program dp_m2_n2 on M1_N1 registers
- *                       M2_N2 registers are not supported
- */
-
-enum link_m_n_set {
-       /* Sets the m1_n1 and m2_n2 */
-       M1_N1 = 0,
-       M2_N2
-};
-
-struct intel_dp_compliance_data {
-       unsigned long edid;
-       u8 video_pattern;
-       u16 hdisplay, vdisplay;
-       u8 bpc;
-};
-
-struct intel_dp_compliance {
-       unsigned long test_type;
-       struct intel_dp_compliance_data test_data;
-       bool test_active;
-       int test_link_rate;
-       u8 test_lane_count;
-};
-
-struct intel_dp {
-       i915_reg_t output_reg;
-       u32 DP;
-       int link_rate;
-       u8 lane_count;
-       u8 sink_count;
-       bool link_mst;
-       bool link_trained;
-       bool has_audio;
-       bool reset_link_params;
-       u8 dpcd[DP_RECEIVER_CAP_SIZE];
-       u8 psr_dpcd[EDP_PSR_RECEIVER_CAP_SIZE];
-       u8 downstream_ports[DP_MAX_DOWNSTREAM_PORTS];
-       u8 edp_dpcd[EDP_DISPLAY_CTL_CAP_SIZE];
-       u8 dsc_dpcd[DP_DSC_RECEIVER_CAP_SIZE];
-       u8 fec_capable;
-       /* source rates */
-       int num_source_rates;
-       const int *source_rates;
-       /* sink rates as reported by DP_MAX_LINK_RATE/DP_SUPPORTED_LINK_RATES */
-       int num_sink_rates;
-       int sink_rates[DP_MAX_SUPPORTED_RATES];
-       bool use_rate_select;
-       /* intersection of source and sink rates */
-       int num_common_rates;
-       int common_rates[DP_MAX_SUPPORTED_RATES];
-       /* Max lane count for the current link */
-       int max_link_lane_count;
-       /* Max rate for the current link */
-       int max_link_rate;
-       /* sink or branch descriptor */
-       struct drm_dp_desc desc;
-       struct drm_dp_aux aux;
-       u8 train_set[4];
-       int panel_power_up_delay;
-       int panel_power_down_delay;
-       int panel_power_cycle_delay;
-       int backlight_on_delay;
-       int backlight_off_delay;
-       struct delayed_work panel_vdd_work;
-       bool want_panel_vdd;
-       unsigned long last_power_on;
-       unsigned long last_backlight_off;
-       ktime_t panel_power_off_time;
-
-       struct notifier_block edp_notifier;
-
-       /*
-        * Pipe whose power sequencer is currently locked into
-        * this port. Only relevant on VLV/CHV.
-        */
-       enum pipe pps_pipe;
-       /*
-        * Pipe currently driving the port. Used for preventing
-        * the use of the PPS for any pipe currentrly driving
-        * external DP as that will mess things up on VLV.
-        */
-       enum pipe active_pipe;
-       /*
-        * Set if the sequencer may be reset due to a power transition,
-        * requiring a reinitialization. Only relevant on BXT.
-        */
-       bool pps_reset;
-       struct edp_power_seq pps_delays;
-
-       bool can_mst; /* this port supports mst */
-       bool is_mst;
-       int active_mst_links;
-       /* connector directly attached - won't be use for modeset in mst world */
-       struct intel_connector *attached_connector;
-
-       /* mst connector list */
-       struct intel_dp_mst_encoder *mst_encoders[I915_MAX_PIPES];
-       struct drm_dp_mst_topology_mgr mst_mgr;
-
-       u32 (*get_aux_clock_divider)(struct intel_dp *dp, int index);
-       /*
-        * This function returns the value we have to program the AUX_CTL
-        * register with to kick off an AUX transaction.
-        */
-       u32 (*get_aux_send_ctl)(struct intel_dp *dp, int send_bytes,
-                               u32 aux_clock_divider);
-
-       i915_reg_t (*aux_ch_ctl_reg)(struct intel_dp *dp);
-       i915_reg_t (*aux_ch_data_reg)(struct intel_dp *dp, int index);
-
-       /* This is called before a link training is starterd */
-       void (*prepare_link_retrain)(struct intel_dp *intel_dp);
-
-       /* Displayport compliance testing */
-       struct intel_dp_compliance compliance;
-
-       /* Display stream compression testing */
-       bool force_dsc_en;
-};
-
-enum lspcon_vendor {
-       LSPCON_VENDOR_MCA,
-       LSPCON_VENDOR_PARADE
-};
-
-struct intel_lspcon {
-       bool active;
-       enum drm_lspcon_mode mode;
-       enum lspcon_vendor vendor;
-};
-
-struct intel_digital_port {
-       struct intel_encoder base;
-       u32 saved_port_bits;
-       struct intel_dp dp;
-       struct intel_hdmi hdmi;
-       struct intel_lspcon lspcon;
-       enum irqreturn (*hpd_pulse)(struct intel_digital_port *, bool);
-       bool release_cl2_override;
-       u8 max_lanes;
-       /* Used for DP and ICL+ TypeC/DP and TypeC/HDMI ports. */
-       enum aux_ch aux_ch;
-       enum intel_display_power_domain ddi_io_power_domain;
-       struct mutex tc_lock;   /* protects the TypeC port mode */
-       intel_wakeref_t tc_lock_wakeref;
-       int tc_link_refcount;
-       bool tc_legacy_port:1;
-       char tc_port_name[8];
-       enum tc_port_mode tc_mode;
-       enum phy_fia tc_phy_fia;
-
-       void (*write_infoframe)(struct intel_encoder *encoder,
-                               const struct intel_crtc_state *crtc_state,
-                               unsigned int type,
-                               const void *frame, ssize_t len);
-       void (*read_infoframe)(struct intel_encoder *encoder,
-                              const struct intel_crtc_state *crtc_state,
-                              unsigned int type,
-                              void *frame, ssize_t len);
-       void (*set_infoframes)(struct intel_encoder *encoder,
-                              bool enable,
-                              const struct intel_crtc_state *crtc_state,
-                              const struct drm_connector_state *conn_state);
-       u32 (*infoframes_enabled)(struct intel_encoder *encoder,
-                                 const struct intel_crtc_state *pipe_config);
-};
-
-struct intel_dp_mst_encoder {
-       struct intel_encoder base;
-       enum pipe pipe;
-       struct intel_digital_port *primary;
-       struct intel_connector *connector;
-};
-
-static inline enum dpio_channel
-vlv_dport_to_channel(struct intel_digital_port *dport)
-{
-       switch (dport->base.port) {
-       case PORT_B:
-       case PORT_D:
-               return DPIO_CH0;
-       case PORT_C:
-               return DPIO_CH1;
-       default:
-               BUG();
-       }
-}
-
-static inline enum dpio_phy
-vlv_dport_to_phy(struct intel_digital_port *dport)
-{
-       switch (dport->base.port) {
-       case PORT_B:
-       case PORT_C:
-               return DPIO_PHY0;
-       case PORT_D:
-               return DPIO_PHY1;
-       default:
-               BUG();
-       }
-}
-
-static inline enum dpio_channel
-vlv_pipe_to_channel(enum pipe pipe)
-{
-       switch (pipe) {
-       case PIPE_A:
-       case PIPE_C:
-               return DPIO_CH0;
-       case PIPE_B:
-               return DPIO_CH1;
-       default:
-               BUG();
-       }
-}
-
-static inline struct intel_crtc *
-intel_get_crtc_for_pipe(struct drm_i915_private *dev_priv, enum pipe pipe)
-{
-       return dev_priv->pipe_to_crtc_mapping[pipe];
-}
-
-static inline struct intel_crtc *
-intel_get_crtc_for_plane(struct drm_i915_private *dev_priv, enum i9xx_plane_id plane)
-{
-       return dev_priv->plane_to_crtc_mapping[plane];
-}
-
-struct intel_load_detect_pipe {
-       struct drm_atomic_state *restore_state;
-};
-
-static inline struct intel_encoder *
-intel_attached_encoder(struct drm_connector *connector)
-{
-       return to_intel_connector(connector)->encoder;
-}
-
-static inline bool intel_encoder_is_dig_port(struct intel_encoder *encoder)
-{
-       switch (encoder->type) {
-       case INTEL_OUTPUT_DDI:
-       case INTEL_OUTPUT_DP:
-       case INTEL_OUTPUT_EDP:
-       case INTEL_OUTPUT_HDMI:
-               return true;
-       default:
-               return false;
-       }
-}
-
-static inline struct intel_digital_port *
-enc_to_dig_port(struct drm_encoder *encoder)
-{
-       struct intel_encoder *intel_encoder = to_intel_encoder(encoder);
-
-       if (intel_encoder_is_dig_port(intel_encoder))
-               return container_of(encoder, struct intel_digital_port,
-                                   base.base);
-       else
-               return NULL;
-}
-
-static inline struct intel_digital_port *
-conn_to_dig_port(struct intel_connector *connector)
-{
-       return enc_to_dig_port(&intel_attached_encoder(&connector->base)->base);
-}
-
-static inline struct intel_dp_mst_encoder *
-enc_to_mst(struct drm_encoder *encoder)
-{
-       return container_of(encoder, struct intel_dp_mst_encoder, base.base);
-}
-
-static inline struct intel_dp *enc_to_intel_dp(struct drm_encoder *encoder)
-{
-       return &enc_to_dig_port(encoder)->dp;
-}
-
-static inline bool intel_encoder_is_dp(struct intel_encoder *encoder)
-{
-       switch (encoder->type) {
-       case INTEL_OUTPUT_DP:
-       case INTEL_OUTPUT_EDP:
-               return true;
-       case INTEL_OUTPUT_DDI:
-               /* Skip pure HDMI/DVI DDI encoders */
-               return i915_mmio_reg_valid(enc_to_intel_dp(&encoder->base)->output_reg);
-       default:
-               return false;
-       }
-}
-
-static inline struct intel_lspcon *
-enc_to_intel_lspcon(struct drm_encoder *encoder)
-{
-       return &enc_to_dig_port(encoder)->lspcon;
-}
-
-static inline struct intel_digital_port *
-dp_to_dig_port(struct intel_dp *intel_dp)
-{
-       return container_of(intel_dp, struct intel_digital_port, dp);
-}
-
-static inline struct intel_lspcon *
-dp_to_lspcon(struct intel_dp *intel_dp)
-{
-       return &dp_to_dig_port(intel_dp)->lspcon;
-}
-
-static inline struct drm_i915_private *
-dp_to_i915(struct intel_dp *intel_dp)
-{
-       return to_i915(dp_to_dig_port(intel_dp)->base.base.dev);
-}
-
-static inline struct intel_digital_port *
-hdmi_to_dig_port(struct intel_hdmi *intel_hdmi)
-{
-       return container_of(intel_hdmi, struct intel_digital_port, hdmi);
-}
-
-static inline struct intel_plane_state *
-intel_atomic_get_plane_state(struct intel_atomic_state *state,
-                                struct intel_plane *plane)
-{
-       struct drm_plane_state *ret =
-               drm_atomic_get_plane_state(&state->base, &plane->base);
-
-       if (IS_ERR(ret))
-               return ERR_CAST(ret);
-
-       return to_intel_plane_state(ret);
-}
-
-static inline struct intel_plane_state *
-intel_atomic_get_old_plane_state(struct intel_atomic_state *state,
-                                struct intel_plane *plane)
-{
-       return to_intel_plane_state(drm_atomic_get_old_plane_state(&state->base,
-                                                                  &plane->base));
-}
-
-static inline struct intel_plane_state *
-intel_atomic_get_new_plane_state(struct intel_atomic_state *state,
-                                struct intel_plane *plane)
-{
-       return to_intel_plane_state(drm_atomic_get_new_plane_state(&state->base,
-                                                                  &plane->base));
-}
-
-static inline struct intel_crtc_state *
-intel_atomic_get_old_crtc_state(struct intel_atomic_state *state,
-                               struct intel_crtc *crtc)
-{
-       return to_intel_crtc_state(drm_atomic_get_old_crtc_state(&state->base,
-                                                                &crtc->base));
-}
-
-static inline struct intel_crtc_state *
-intel_atomic_get_new_crtc_state(struct intel_atomic_state *state,
-                               struct intel_crtc *crtc)
-{
-       return to_intel_crtc_state(drm_atomic_get_new_crtc_state(&state->base,
-                                                                &crtc->base));
-}
-
-/* intel_display.c */
-static inline bool
-intel_crtc_has_type(const struct intel_crtc_state *crtc_state,
-                   enum intel_output_type type)
-{
-       return crtc_state->output_types & (1 << type);
-}
-static inline bool
-intel_crtc_has_dp_encoder(const struct intel_crtc_state *crtc_state)
-{
-       return crtc_state->output_types &
-               ((1 << INTEL_OUTPUT_DP) |
-                (1 << INTEL_OUTPUT_DP_MST) |
-                (1 << INTEL_OUTPUT_EDP));
-}
-static inline void
-intel_wait_for_vblank(struct drm_i915_private *dev_priv, enum pipe pipe)
-{
-       drm_wait_one_vblank(&dev_priv->drm, pipe);
-}
-static inline void
-intel_wait_for_vblank_if_active(struct drm_i915_private *dev_priv, int pipe)
-{
-       const struct intel_crtc *crtc = intel_get_crtc_for_pipe(dev_priv, pipe);
-
-       if (crtc->active)
-               intel_wait_for_vblank(dev_priv, pipe);
-}
-
-static inline u32 intel_plane_ggtt_offset(const struct intel_plane_state *state)
-{
-       return i915_ggtt_offset(state->vma);
-}
-
-#endif /* __INTEL_DRV_H__ */
index 91a6068a29db1531584811516422419e23f64471..780df8db2eba71bdbcc9a529336f9a5d40b25c80 100644 (file)
 #include <drm/drm_plane_helper.h>
 
 #include "display/intel_atomic.h"
+#include "display/intel_display_types.h"
 #include "display/intel_fbc.h"
 #include "display/intel_sprite.h"
 
 #include "i915_drv.h"
 #include "i915_irq.h"
 #include "i915_trace.h"
-#include "intel_drv.h"
 #include "intel_pm.h"
 #include "intel_sideband.h"
 #include "../../../platform/x86/intel_ips.h"
index a115625e980c4416204fec8e90fb3ee09b1e22bb..9e82e98bb7898c4bf1477c7ec85613b1f6213a69 100644 (file)
 
 #include <asm/iosf_mbi.h>
 
-#include "intel_sideband.h"
+#include "display/intel_display_types.h"
 
 #include "i915_drv.h"
-#include "intel_drv.h"
+#include "intel_sideband.h"
 
 /*
  * IOSF sideband, see VLV2_SidebandMsg_HAS.docx and
index 18104d6542b87c2c636b969766169ff6561c91ec..4a584ee4327938402bfbe9cefe594e1124db4f53 100644 (file)
 #include <linux/pm_runtime.h>
 #include <asm/iosf_mbi.h>
 
+#include "display/intel_display_types.h"
+
 #include "i915_drv.h"
 #include "i915_trace.h"
 #include "i915_vgpu.h"
-#include "intel_drv.h"
 #include "intel_pm.h"
 
 #define FORCEWAKE_ACK_TIMEOUT_MS 50