On Tue, Nov 01, 2011 at 05:27:26PM -0400, Alex Deucher wrote:
> On Fri, Oct 28, 2011 at 5:52 PM,  <j.glisse at gmail.com> wrote:
> > From: Jerome Glisse <jglisse at redhat.com>
> >
> > Polarity needs to be set accordingly to connector status (connected
> > or disconnected). Set it up at module init so first hotplug works
> > reliably no matter what is the initial set of connector.
> 
> Thinking about this more, we should probably do this on resume as
> well.  Calling it in hpd_init should cover all the bases.
> 
> Alex
> 

Good catch :)

Reviewed-by: Jerome Glisse <jglisse at redhat.com>

> >
> > Signed-off-by: Jerome Glisse <jglisse at redhat.com>
> > cc: stable at kernel.org
> > ---
> > ?drivers/gpu/drm/radeon/radeon_connectors.c | ? ?1 +
> > ?1 files changed, 1 insertions(+), 0 deletions(-)
> >
> > diff --git a/drivers/gpu/drm/radeon/radeon_connectors.c 
> > b/drivers/gpu/drm/radeon/radeon_connectors.c
> > index dec6cbe..bfdd48b 100644
> > --- a/drivers/gpu/drm/radeon/radeon_connectors.c
> > +++ b/drivers/gpu/drm/radeon/radeon_connectors.c
> > @@ -1789,6 +1789,7 @@ radeon_add_atom_connector(struct drm_device *dev,
> > ? ? ? ? ? ? ? ? ? ? ? ?connector->polled = DRM_CONNECTOR_POLL_CONNECT;
> > ? ? ? ?} else
> > ? ? ? ? ? ? ? ?connector->polled = DRM_CONNECTOR_POLL_HPD;
> > + ? ? ? radeon_hpd_set_polarity(rdev, radeon_connector->hpd.hpd);
> >
> > ? ? ? ?connector->display_info.subpixel_order = subpixel_order;
> > ? ? ? ?drm_sysfs_connector_add(connector);
> > --
> > 1.7.6.4
> >
> > _______________________________________________
> > dri-devel mailing list
> > dri-devel at lists.freedesktop.org
> > http://lists.freedesktop.org/mailman/listinfo/dri-devel
> >

> From 90a532b643cbe882497eaadb78f7d1997af6e22b Mon Sep 17 00:00:00 2001
> From: Alex Deucher <alexander.deucher at amd.com>
> Date: Tue, 1 Nov 2011 17:23:15 -0400
> Subject: [PATCH] drm/radeon/kms: set HPD polarity in hpd_init()
> 
> Polarity needs to be set accordingly to connector status (connected
> or disconnected). Set it up in hpd_init() so first hotplug works
> reliably no matter what is the initial set of connector. hpd_init()
> also covers resume so HPD will work correctly after resume as well.
> 
> Signed-off-by: Alex Deucher <alexander.deucher at amd.com>
> Cc: stable at kernel.org
> ---
>  drivers/gpu/drm/radeon/evergreen.c |    1 +
>  drivers/gpu/drm/radeon/r100.c      |    1 +
>  drivers/gpu/drm/radeon/r600.c      |   19 +++++++++----------
>  drivers/gpu/drm/radeon/rs600.c     |    1 +
>  4 files changed, 12 insertions(+), 10 deletions(-)
> 
> diff --git a/drivers/gpu/drm/radeon/evergreen.c 
> b/drivers/gpu/drm/radeon/evergreen.c
> index db9027d..7ce9c87 100644
> --- a/drivers/gpu/drm/radeon/evergreen.c
> +++ b/drivers/gpu/drm/radeon/evergreen.c
> @@ -353,6 +353,7 @@ void evergreen_hpd_init(struct radeon_device *rdev)
>               default:
>                       break;
>               }
> +             radeon_hpd_set_polarity(rdev, radeon_connector->hpd.hpd);
>       }
>       if (rdev->irq.installed)
>               evergreen_irq_set(rdev);
> diff --git a/drivers/gpu/drm/radeon/r100.c b/drivers/gpu/drm/radeon/r100.c
> index 8f8b8fa..4191eaf 100644
> --- a/drivers/gpu/drm/radeon/r100.c
> +++ b/drivers/gpu/drm/radeon/r100.c
> @@ -536,6 +536,7 @@ void r100_hpd_init(struct radeon_device *rdev)
>               default:
>                       break;
>               }
> +             radeon_hpd_set_polarity(rdev, radeon_connector->hpd.hpd);
>       }
>       if (rdev->irq.installed)
>               r100_irq_set(rdev);
> diff --git a/drivers/gpu/drm/radeon/r600.c b/drivers/gpu/drm/radeon/r600.c
> index 3aa46d7..4d85398 100644
> --- a/drivers/gpu/drm/radeon/r600.c
> +++ b/drivers/gpu/drm/radeon/r600.c
> @@ -762,13 +762,14 @@ void r600_hpd_init(struct radeon_device *rdev)
>       struct drm_device *dev = rdev->ddev;
>       struct drm_connector *connector;
>  
> -     if (ASIC_IS_DCE3(rdev)) {
> -             u32 tmp = DC_HPDx_CONNECTION_TIMER(0x9c4) | 
> DC_HPDx_RX_INT_TIMER(0xfa);
> -             if (ASIC_IS_DCE32(rdev))
> -                     tmp |= DC_HPDx_EN;
> +     list_for_each_entry(connector, &dev->mode_config.connector_list, head) {
> +             struct radeon_connector *radeon_connector = 
> to_radeon_connector(connector);
> +
> +             if (ASIC_IS_DCE3(rdev)) {
> +                     u32 tmp = DC_HPDx_CONNECTION_TIMER(0x9c4) | 
> DC_HPDx_RX_INT_TIMER(0xfa);
> +                     if (ASIC_IS_DCE32(rdev))
> +                             tmp |= DC_HPDx_EN;
>  
> -             list_for_each_entry(connector, 
> &dev->mode_config.connector_list, head) {
> -                     struct radeon_connector *radeon_connector = 
> to_radeon_connector(connector);
>                       switch (radeon_connector->hpd.hpd) {
>                       case RADEON_HPD_1:
>                               WREG32(DC_HPD1_CONTROL, tmp);
> @@ -798,10 +799,7 @@ void r600_hpd_init(struct radeon_device *rdev)
>                       default:
>                               break;
>                       }
> -             }
> -     } else {
> -             list_for_each_entry(connector, 
> &dev->mode_config.connector_list, head) {
> -                     struct radeon_connector *radeon_connector = 
> to_radeon_connector(connector);
> +             } else {
>                       switch (radeon_connector->hpd.hpd) {
>                       case RADEON_HPD_1:
>                               WREG32(DC_HOT_PLUG_DETECT1_CONTROL, 
> DC_HOT_PLUG_DETECTx_EN);
> @@ -819,6 +817,7 @@ void r600_hpd_init(struct radeon_device *rdev)
>                               break;
>                       }
>               }
> +             radeon_hpd_set_polarity(rdev, radeon_connector->hpd.hpd);
>       }
>       if (rdev->irq.installed)
>               r600_irq_set(rdev);
> diff --git a/drivers/gpu/drm/radeon/rs600.c b/drivers/gpu/drm/radeon/rs600.c
> index 9320dd6..02e0390 100644
> --- a/drivers/gpu/drm/radeon/rs600.c
> +++ b/drivers/gpu/drm/radeon/rs600.c
> @@ -287,6 +287,7 @@ void rs600_hpd_init(struct radeon_device *rdev)
>               default:
>                       break;
>               }
> +             radeon_hpd_set_polarity(rdev, radeon_connector->hpd.hpd);
>       }
>       if (rdev->irq.installed)
>               rs600_irq_set(rdev);
> -- 
> 1.7.3.4
> 

Reply via email to