drm/i915: Mark ns2501 as LVDS without a fixed mode
ns2501 has a builtin scaler so it doesn't need a fixed mode, but let's still mark it as LVDS instead of TMDS/DVI to make life less confusing. Signed-off-by: Ville Syrjälä <ville.syrjala@linux.intel.com> Link: https://patchwork.freedesktop.org/patch/msgid/20200121171100.4370-7-ville.syrjala@linux.intel.com Reviewed-by: Jani Nikula <jani.nikula@intel.com>
This commit is contained in:
parent
9d552c22f7
commit
45608c5049
|
@ -44,6 +44,7 @@
|
||||||
#define INTEL_DVO_CHIP_LVDS 1
|
#define INTEL_DVO_CHIP_LVDS 1
|
||||||
#define INTEL_DVO_CHIP_TMDS 2
|
#define INTEL_DVO_CHIP_TMDS 2
|
||||||
#define INTEL_DVO_CHIP_TVOUT 4
|
#define INTEL_DVO_CHIP_TVOUT 4
|
||||||
|
#define INTEL_DVO_CHIP_LVDS_NO_FIXED 5
|
||||||
|
|
||||||
#define SIL164_ADDR 0x38
|
#define SIL164_ADDR 0x38
|
||||||
#define CH7xxx_ADDR 0x76
|
#define CH7xxx_ADDR 0x76
|
||||||
|
@ -101,13 +102,13 @@ static const struct intel_dvo_device intel_dvo_devices[] = {
|
||||||
.dev_ops = &ch7017_ops,
|
.dev_ops = &ch7017_ops,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
.type = INTEL_DVO_CHIP_TMDS,
|
.type = INTEL_DVO_CHIP_LVDS_NO_FIXED,
|
||||||
.name = "ns2501",
|
.name = "ns2501",
|
||||||
.dvo_reg = DVOB,
|
.dvo_reg = DVOB,
|
||||||
.dvo_srcdim_reg = DVOB_SRCDIM,
|
.dvo_srcdim_reg = DVOB_SRCDIM,
|
||||||
.slave_addr = NS2501_ADDR,
|
.slave_addr = NS2501_ADDR,
|
||||||
.dev_ops = &ns2501_ops,
|
.dev_ops = &ns2501_ops,
|
||||||
}
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
struct intel_dvo {
|
struct intel_dvo {
|
||||||
|
@ -507,17 +508,19 @@ void intel_dvo_init(struct drm_i915_private *dev_priv)
|
||||||
intel_encoder->port = port;
|
intel_encoder->port = port;
|
||||||
intel_encoder->pipe_mask = ~0;
|
intel_encoder->pipe_mask = ~0;
|
||||||
|
|
||||||
switch (dvo->type) {
|
if (dvo->type != INTEL_DVO_CHIP_LVDS)
|
||||||
case INTEL_DVO_CHIP_TMDS:
|
|
||||||
intel_encoder->cloneable = (1 << INTEL_OUTPUT_ANALOG) |
|
intel_encoder->cloneable = (1 << INTEL_OUTPUT_ANALOG) |
|
||||||
(1 << INTEL_OUTPUT_DVO);
|
(1 << INTEL_OUTPUT_DVO);
|
||||||
|
|
||||||
|
switch (dvo->type) {
|
||||||
|
case INTEL_DVO_CHIP_TMDS:
|
||||||
drm_connector_init(&dev_priv->drm, connector,
|
drm_connector_init(&dev_priv->drm, connector,
|
||||||
&intel_dvo_connector_funcs,
|
&intel_dvo_connector_funcs,
|
||||||
DRM_MODE_CONNECTOR_DVII);
|
DRM_MODE_CONNECTOR_DVII);
|
||||||
encoder_type = DRM_MODE_ENCODER_TMDS;
|
encoder_type = DRM_MODE_ENCODER_TMDS;
|
||||||
break;
|
break;
|
||||||
|
case INTEL_DVO_CHIP_LVDS_NO_FIXED:
|
||||||
case INTEL_DVO_CHIP_LVDS:
|
case INTEL_DVO_CHIP_LVDS:
|
||||||
intel_encoder->cloneable = 0;
|
|
||||||
drm_connector_init(&dev_priv->drm, connector,
|
drm_connector_init(&dev_priv->drm, connector,
|
||||||
&intel_dvo_connector_funcs,
|
&intel_dvo_connector_funcs,
|
||||||
DRM_MODE_CONNECTOR_LVDS);
|
DRM_MODE_CONNECTOR_LVDS);
|
||||||
|
|
Loading…
Reference in New Issue