From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1755464Ab0BAWeU (ORCPT ); Mon, 1 Feb 2010 17:34:20 -0500 Received: from smtp1.linux-foundation.org ([140.211.169.13]:43373 "EHLO smtp1.linux-foundation.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1755421Ab0BAWeS (ORCPT ); Mon, 1 Feb 2010 17:34:18 -0500 Date: Mon, 1 Feb 2010 14:33:48 -0800 From: Andrew Morton To: Thomas Meyer Cc: Jesse Barnes , Eric Anholt , Linux Kernel Mailing List , "Rafael J. Wysocki" Subject: Re: [PATCH] i915: slow acpi_lid_open() causes flickering Message-Id: <20100201143348.cb9fa1e3.akpm@linux-foundation.org> In-Reply-To: <1265048453.2619.8.camel@localhost.localdomain> References: <1265048453.2619.8.camel@localhost.localdomain> X-Mailer: Sylpheed 2.4.8 (GTK+ 2.12.9; x86_64-pc-linux-gnu) Mime-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, 01 Feb 2010 19:20:53 +0100 Thomas Meyer wrote: > acpi_lid_open() could take up to 10ms on my computer. > Some component is calling the drm GETCONNECTOR ioctl many times in a row. > This results in flickering (for example, when starting a video). > Fix it by assuming an always connected lid status. > > This fixes bug http://bugzilla.kernel.org/show_bug.cgi?id=14670 > > --- > drivers/gpu/drm/i915/intel_lvds.c | 15 ++++++++++++++- > 1 files changed, 14 insertions(+), 1 deletions(-) > > diff --git a/drivers/gpu/drm/i915/intel_lvds.c b/drivers/gpu/drm/i915/intel_lvds.c > index aa74e59..0f0779c 100644 > --- a/drivers/gpu/drm/i915/intel_lvds.c > +++ b/drivers/gpu/drm/i915/intel_lvds.c > @@ -632,6 +632,18 @@ static const struct dmi_system_id bad_lid_status[] = { > { } > }; > > +/* Some lid devices take a long time to report the lid status, assume they're connected*/ > +static const struct dmi_system_id slow_lid_status[] = { > + { > + .ident = "Aspire 1810T", > + .matches = { > + DMI_MATCH(DMI_SYS_VENDOR, "Acer"), > + DMI_MATCH(DMI_PRODUCT_NAME, "Aspire 1810T"), > + }, > + }, > + { } > +}; > + > /** > * Detect the LVDS connection. > * > @@ -643,7 +655,8 @@ static enum drm_connector_status intel_lvds_detect(struct drm_connector *connect > { > enum drm_connector_status status = connector_status_connected; > > - if (!acpi_lid_open() && !dmi_check_system(bad_lid_status)) > + if (!dmi_check_system(slow_lid_status) && !dmi_check_system(bad_lid_status)) > + if (!acpi_lid_open()) > status = connector_status_disconnected; > > return status; The patch is missing your Signed-off-by: line. I cheekily added it. Please check Documentation/SubmittingPatches, let me know if you disagree with this, thanks.