mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2026-05-16 16:01:44 -04:00
drm/gma500: Make oaktrail lvds use ddc adapter from drm_connector
We're moving all uses of ddc_bus to drm_connector where they belong. The initialization of the gma_i2c_chan for Oaktrail is a bit backwards so it required improvements. Also cleanup the error handling in oaktrail_lvds_init(). Since this is the last user of gma_encoder->ddc_bus we can remove it. Signed-off-by: Patrik Jakobsson <patrik.r.jakobsson@gmail.com> Acked-by: Thomas Zimmermann <tzimmermann@suse.de> Link: https://patchwork.freedesktop.org/patch/msgid/20220601092311.22648-8-patrik.r.jakobsson@gmail.com
This commit is contained in:
@@ -293,12 +293,14 @@ void oaktrail_lvds_init(struct drm_device *dev,
|
|||||||
{
|
{
|
||||||
struct gma_encoder *gma_encoder;
|
struct gma_encoder *gma_encoder;
|
||||||
struct gma_connector *gma_connector;
|
struct gma_connector *gma_connector;
|
||||||
|
struct gma_i2c_chan *ddc_bus;
|
||||||
struct drm_connector *connector;
|
struct drm_connector *connector;
|
||||||
struct drm_encoder *encoder;
|
struct drm_encoder *encoder;
|
||||||
struct drm_psb_private *dev_priv = to_drm_psb_private(dev);
|
struct drm_psb_private *dev_priv = to_drm_psb_private(dev);
|
||||||
struct edid *edid;
|
struct edid *edid;
|
||||||
struct i2c_adapter *i2c_adap;
|
struct i2c_adapter *i2c_adap;
|
||||||
struct drm_display_mode *scan; /* *modes, *bios_mode; */
|
struct drm_display_mode *scan; /* *modes, *bios_mode; */
|
||||||
|
int ret;
|
||||||
|
|
||||||
gma_encoder = kzalloc(sizeof(struct gma_encoder), GFP_KERNEL);
|
gma_encoder = kzalloc(sizeof(struct gma_encoder), GFP_KERNEL);
|
||||||
if (!gma_encoder)
|
if (!gma_encoder)
|
||||||
@@ -306,16 +308,20 @@ void oaktrail_lvds_init(struct drm_device *dev,
|
|||||||
|
|
||||||
gma_connector = kzalloc(sizeof(struct gma_connector), GFP_KERNEL);
|
gma_connector = kzalloc(sizeof(struct gma_connector), GFP_KERNEL);
|
||||||
if (!gma_connector)
|
if (!gma_connector)
|
||||||
goto failed_connector;
|
goto err_free_encoder;
|
||||||
|
|
||||||
connector = &gma_connector->base;
|
connector = &gma_connector->base;
|
||||||
encoder = &gma_encoder->base;
|
encoder = &gma_encoder->base;
|
||||||
dev_priv->is_lvds_on = true;
|
dev_priv->is_lvds_on = true;
|
||||||
drm_connector_init(dev, connector,
|
ret = drm_connector_init(dev, connector,
|
||||||
&psb_intel_lvds_connector_funcs,
|
&psb_intel_lvds_connector_funcs,
|
||||||
DRM_MODE_CONNECTOR_LVDS);
|
DRM_MODE_CONNECTOR_LVDS);
|
||||||
|
if (ret)
|
||||||
|
goto err_free_connector;
|
||||||
|
|
||||||
drm_simple_encoder_init(dev, encoder, DRM_MODE_ENCODER_LVDS);
|
ret = drm_simple_encoder_init(dev, encoder, DRM_MODE_ENCODER_LVDS);
|
||||||
|
if (ret)
|
||||||
|
goto err_connector_cleanup;
|
||||||
|
|
||||||
gma_connector_attach_encoder(gma_connector, gma_encoder);
|
gma_connector_attach_encoder(gma_connector, gma_encoder);
|
||||||
gma_encoder->type = INTEL_OUTPUT_LVDS;
|
gma_encoder->type = INTEL_OUTPUT_LVDS;
|
||||||
@@ -353,16 +359,26 @@ void oaktrail_lvds_init(struct drm_device *dev,
|
|||||||
|
|
||||||
edid = NULL;
|
edid = NULL;
|
||||||
mutex_lock(&dev->mode_config.mutex);
|
mutex_lock(&dev->mode_config.mutex);
|
||||||
|
|
||||||
i2c_adap = i2c_get_adapter(dev_priv->ops->i2c_bus);
|
i2c_adap = i2c_get_adapter(dev_priv->ops->i2c_bus);
|
||||||
if (i2c_adap)
|
if (i2c_adap)
|
||||||
edid = drm_get_edid(connector, i2c_adap);
|
edid = drm_get_edid(connector, i2c_adap);
|
||||||
|
|
||||||
if (edid == NULL && dev_priv->lpc_gpio_base) {
|
if (edid == NULL && dev_priv->lpc_gpio_base) {
|
||||||
oaktrail_lvds_i2c_init(encoder);
|
ddc_bus = oaktrail_lvds_i2c_init(dev);
|
||||||
if (gma_encoder->ddc_bus != NULL) {
|
if (!IS_ERR(ddc_bus)) {
|
||||||
i2c_adap = &gma_encoder->ddc_bus->base;
|
i2c_adap = &ddc_bus->base;
|
||||||
edid = drm_get_edid(connector, i2c_adap);
|
edid = drm_get_edid(connector, i2c_adap);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Due to the logic in probing for i2c buses above we do not know the
|
||||||
|
* i2c_adap until now. Hence we cannot use drm_connector_init_with_ddc()
|
||||||
|
* but must instead set connector->ddc manually here.
|
||||||
|
*/
|
||||||
|
connector->ddc = i2c_adap;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Attempt to get the fixed panel mode from DDC. Assume that the
|
* Attempt to get the fixed panel mode from DDC. Assume that the
|
||||||
* preferred mode is the right one.
|
* preferred mode is the right one.
|
||||||
@@ -395,7 +411,7 @@ void oaktrail_lvds_init(struct drm_device *dev,
|
|||||||
/* If we still don't have a mode after all that, give up. */
|
/* If we still don't have a mode after all that, give up. */
|
||||||
if (!mode_dev->panel_fixed_mode) {
|
if (!mode_dev->panel_fixed_mode) {
|
||||||
dev_err(dev->dev, "Found no modes on the lvds, ignoring the LVDS\n");
|
dev_err(dev->dev, "Found no modes on the lvds, ignoring the LVDS\n");
|
||||||
goto failed_find;
|
goto err_unlock;
|
||||||
}
|
}
|
||||||
|
|
||||||
out:
|
out:
|
||||||
@@ -403,21 +419,15 @@ void oaktrail_lvds_init(struct drm_device *dev,
|
|||||||
|
|
||||||
return;
|
return;
|
||||||
|
|
||||||
failed_find:
|
err_unlock:
|
||||||
mutex_unlock(&dev->mode_config.mutex);
|
mutex_unlock(&dev->mode_config.mutex);
|
||||||
|
gma_i2c_destroy(to_gma_i2c_chan(connector->ddc));
|
||||||
dev_dbg(dev->dev, "No LVDS modes found, disabling.\n");
|
|
||||||
if (gma_encoder->ddc_bus) {
|
|
||||||
gma_i2c_destroy(gma_encoder->ddc_bus);
|
|
||||||
gma_encoder->ddc_bus = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* failed_ddc: */
|
|
||||||
|
|
||||||
drm_encoder_cleanup(encoder);
|
drm_encoder_cleanup(encoder);
|
||||||
|
err_connector_cleanup:
|
||||||
drm_connector_cleanup(connector);
|
drm_connector_cleanup(connector);
|
||||||
|
err_free_connector:
|
||||||
kfree(gma_connector);
|
kfree(gma_connector);
|
||||||
failed_connector:
|
err_free_encoder:
|
||||||
kfree(gma_encoder);
|
kfree(gma_encoder);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -129,16 +129,15 @@ static void set_data(void *data, int state_high)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void oaktrail_lvds_i2c_init(struct drm_encoder *encoder)
|
struct gma_i2c_chan *oaktrail_lvds_i2c_init(struct drm_device *dev)
|
||||||
{
|
{
|
||||||
struct drm_device *dev = encoder->dev;
|
|
||||||
struct gma_encoder *gma_encoder = to_gma_encoder(encoder);
|
|
||||||
struct drm_psb_private *dev_priv = to_drm_psb_private(dev);
|
struct drm_psb_private *dev_priv = to_drm_psb_private(dev);
|
||||||
struct gma_i2c_chan *chan;
|
struct gma_i2c_chan *chan;
|
||||||
|
int ret;
|
||||||
|
|
||||||
chan = kzalloc(sizeof(struct gma_i2c_chan), GFP_KERNEL);
|
chan = kzalloc(sizeof(struct gma_i2c_chan), GFP_KERNEL);
|
||||||
if (!chan)
|
if (!chan)
|
||||||
return;
|
return ERR_PTR(-ENOMEM);
|
||||||
|
|
||||||
chan->drm_dev = dev;
|
chan->drm_dev = dev;
|
||||||
chan->reg = dev_priv->lpc_gpio_base;
|
chan->reg = dev_priv->lpc_gpio_base;
|
||||||
@@ -160,10 +159,11 @@ void oaktrail_lvds_i2c_init(struct drm_encoder *encoder)
|
|||||||
set_clock(chan, 1);
|
set_clock(chan, 1);
|
||||||
udelay(50);
|
udelay(50);
|
||||||
|
|
||||||
if (i2c_bit_add_bus(&chan->base)) {
|
ret = i2c_bit_add_bus(&chan->base);
|
||||||
|
if (ret < 0) {
|
||||||
kfree(chan);
|
kfree(chan);
|
||||||
return;
|
return ERR_PTR(ret);
|
||||||
}
|
}
|
||||||
|
|
||||||
gma_encoder->ddc_bus = chan;
|
return chan;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -105,7 +105,6 @@ struct gma_encoder {
|
|||||||
/* FIXME: Either make SDVO and LVDS store it's i2c here or give CDV it's
|
/* FIXME: Either make SDVO and LVDS store it's i2c here or give CDV it's
|
||||||
own set of output privates */
|
own set of output privates */
|
||||||
struct gma_i2c_chan *i2c_bus;
|
struct gma_i2c_chan *i2c_bus;
|
||||||
struct gma_i2c_chan *ddc_bus;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
struct gma_connector {
|
struct gma_connector {
|
||||||
@@ -200,7 +199,7 @@ extern void oaktrail_lvds_init(struct drm_device *dev,
|
|||||||
extern void oaktrail_wait_for_INTR_PKT_SENT(struct drm_device *dev);
|
extern void oaktrail_wait_for_INTR_PKT_SENT(struct drm_device *dev);
|
||||||
extern void oaktrail_dsi_init(struct drm_device *dev,
|
extern void oaktrail_dsi_init(struct drm_device *dev,
|
||||||
struct psb_intel_mode_device *mode_dev);
|
struct psb_intel_mode_device *mode_dev);
|
||||||
extern void oaktrail_lvds_i2c_init(struct drm_encoder *encoder);
|
struct gma_i2c_chan *oaktrail_lvds_i2c_init(struct drm_device *dev);
|
||||||
extern void mid_dsi_init(struct drm_device *dev,
|
extern void mid_dsi_init(struct drm_device *dev,
|
||||||
struct psb_intel_mode_device *mode_dev, int dsi_num);
|
struct psb_intel_mode_device *mode_dev, int dsi_num);
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user