Commit 9f0e7ff4 authored by Jesse Barnes's avatar Jesse Barnes Committed by Chris Wilson

drm/i915: fetch eDP configuration data from the VBT

We need to use some of these values in eDP configurations, so be sure to
fetch them and store them in the i915 private structure.
Signed-off-by: default avatarJesse Barnes <jbarnes@virtuousgeek.org>
Signed-off-by: default avatarChris Wilson <chris@chris-wilson.co.uk>
parent 723bfd70
...@@ -339,16 +339,16 @@ typedef struct drm_i915_private { ...@@ -339,16 +339,16 @@ typedef struct drm_i915_private {
unsigned int int_crt_support:1; unsigned int int_crt_support:1;
unsigned int lvds_use_ssc:1; unsigned int lvds_use_ssc:1;
int lvds_ssc_freq; int lvds_ssc_freq;
struct { struct {
u8 rate:4; int rate;
u8 lanes:4; int lanes;
u8 preemphasis:4; int preemphasis;
u8 vswing:4; int vswing;
u8 initialized:1; bool initialized;
u8 support:1; bool support;
u8 bpp:6; int bpp;
struct edp_power_seq pps;
} edp; } edp;
struct notifier_block lid_notifier; struct notifier_block lid_notifier;
......
...@@ -24,6 +24,7 @@ ...@@ -24,6 +24,7 @@
* Eric Anholt <eric@anholt.net> * Eric Anholt <eric@anholt.net>
* *
*/ */
#include <drm/drm_dp_helper.h>
#include "drmP.h" #include "drmP.h"
#include "drm.h" #include "drm.h"
#include "i915_drm.h" #include "i915_drm.h"
...@@ -413,6 +414,8 @@ static void ...@@ -413,6 +414,8 @@ static void
parse_edp(struct drm_i915_private *dev_priv, struct bdb_header *bdb) parse_edp(struct drm_i915_private *dev_priv, struct bdb_header *bdb)
{ {
struct bdb_edp *edp; struct bdb_edp *edp;
struct edp_power_seq *edp_pps;
struct edp_link_params *edp_link_params;
edp = find_section(bdb, BDB_EDP); edp = find_section(bdb, BDB_EDP);
if (!edp) { if (!edp) {
...@@ -437,19 +440,54 @@ parse_edp(struct drm_i915_private *dev_priv, struct bdb_header *bdb) ...@@ -437,19 +440,54 @@ parse_edp(struct drm_i915_private *dev_priv, struct bdb_header *bdb)
break; break;
} }
dev_priv->edp.rate = edp->link_params[panel_type].rate; /* Get the eDP sequencing and link info */
dev_priv->edp.lanes = edp->link_params[panel_type].lanes; edp_pps = &edp->power_seqs[panel_type];
dev_priv->edp.preemphasis = edp->link_params[panel_type].preemphasis; edp_link_params = &edp->link_params[panel_type];
dev_priv->edp.vswing = edp->link_params[panel_type].vswing;
DRM_DEBUG_KMS("eDP vBIOS settings: bpp=%d, rate=%d, lanes=%d, preemphasis=%d, vswing=%d\n", dev_priv->edp.pps = *edp_pps;
dev_priv->edp.bpp,
dev_priv->edp.rate,
dev_priv->edp.lanes,
dev_priv->edp.preemphasis,
dev_priv->edp.vswing);
dev_priv->edp.initialized = true; dev_priv->edp.rate = edp_link_params->rate ? DP_LINK_BW_2_7 :
DP_LINK_BW_1_62;
switch (edp_link_params->lanes) {
case 0:
dev_priv->edp.lanes = 1;
break;
case 1:
dev_priv->edp.lanes = 2;
break;
case 3:
default:
dev_priv->edp.lanes = 4;
break;
}
switch (edp_link_params->preemphasis) {
case 0:
dev_priv->edp.preemphasis = DP_TRAIN_PRE_EMPHASIS_0;
break;
case 1:
dev_priv->edp.preemphasis = DP_TRAIN_PRE_EMPHASIS_3_5;
break;
case 2:
dev_priv->edp.preemphasis = DP_TRAIN_PRE_EMPHASIS_6;
break;
case 3:
dev_priv->edp.preemphasis = DP_TRAIN_PRE_EMPHASIS_9_5;
break;
}
switch (edp_link_params->vswing) {
case 0:
dev_priv->edp.vswing = DP_TRAIN_VOLTAGE_SWING_400;
break;
case 1:
dev_priv->edp.vswing = DP_TRAIN_VOLTAGE_SWING_600;
break;
case 2:
dev_priv->edp.vswing = DP_TRAIN_VOLTAGE_SWING_800;
break;
case 3:
dev_priv->edp.vswing = DP_TRAIN_VOLTAGE_SWING_1200;
break;
}
} }
static void static void
......
...@@ -23,6 +23,9 @@ ...@@ -23,6 +23,9 @@
#ifndef _DRM_DP_HELPER_H_ #ifndef _DRM_DP_HELPER_H_
#define _DRM_DP_HELPER_H_ #define _DRM_DP_HELPER_H_
#include <linux/types.h>
#include <linux/i2c.h>
/* From the VESA DisplayPort spec */ /* From the VESA DisplayPort spec */
#define AUX_NATIVE_WRITE 0x8 #define AUX_NATIVE_WRITE 0x8
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment