From patchwork Fri May 31 04:10:34 2013 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Chun-Yi Lee X-Patchwork-Id: 2640271 X-Patchwork-Delegate: rui.zhang@intel.com Return-Path: X-Original-To: patchwork-linux-acpi@patchwork.kernel.org Delivered-To: patchwork-process-083081@patchwork2.kernel.org Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by patchwork2.kernel.org (Postfix) with ESMTP id 1F8D2DFB79 for ; Fri, 31 May 2013 04:11:16 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751013Ab3EaELP (ORCPT ); Fri, 31 May 2013 00:11:15 -0400 Received: from mail-pd0-f180.google.com ([209.85.192.180]:42118 "EHLO mail-pd0-f180.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750873Ab3EaELJ (ORCPT ); Fri, 31 May 2013 00:11:09 -0400 Received: by mail-pd0-f180.google.com with SMTP id 14so1512511pdc.11 for ; Thu, 30 May 2013 21:11:09 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20120113; h=from:to:cc:subject:date:message-id:x-mailer:in-reply-to:references; bh=GZ0C7CTHJ1cXPf9gOdHeVXiQ546l7rVPKnf6LEv4N3E=; b=xIW1ZmTSwD3EJeLyrCMMp2CxqCW1dMegkR1pW6r1yRwTanXN9L2mbAZMGfNvrlBPJo pMxxbzeXst+UQYmIyuHlDo5L9hh+iwoUSSgob1jqFCFbUVy9h0Uttxg3Oh6myo1hlOm2 9sP6VZx7ATUXd21/L/NTjpG9ONO7SWYaYU8odw7jm6RCUnw09aSlbhvFwpJFobwEvl3m H1qbiSoVsUaqrGfSv1hzJuO37fTvyndvqa1HNkw0G/gvikYWUvwyqb5Y2VcDEOgfKYBT QaQMQQwvIIbR8sJDBUy7r0PP3v3iCFtrQ8H3LNzJCQbZASbwvH9u3WWc5QAG2Lq6d03U SOLg== X-Received: by 10.66.27.174 with SMTP id u14mr11527917pag.97.1369973468941; Thu, 30 May 2013 21:11:08 -0700 (PDT) Received: from localhost.localdomain (59-124-67-67.HINET-IP.hinet.net. [59.124.67.67]) by mx.google.com with ESMTPSA id gi2sm44800313pbb.2.2013.05.30.21.11.04 for (version=TLSv1 cipher=RC4-SHA bits=128/128); Thu, 30 May 2013 21:11:07 -0700 (PDT) From: "Lee, Chun-Yi" To: rui.zhang@intel.com, mjg@redhat.com, rjw@sisk.pl Cc: platform-driver-x86@vger.kernel.org, linux-acpi@vger.kernel.org, linux-kernel@vger.kernel.org, "Lee, Chun-Yi" , Len Brown , Carlos Corbacho , Dmitry Torokhov , Corentin Chary , Aaron Lu , Thomas Renninger Subject: [PATCH v2 2/2] acer-wmi: add Acer Aspire 5750G to video vendor list but keep acpi video driver Date: Fri, 31 May 2013 12:10:34 +0800 Message-Id: <1369973434-8742-2-git-send-email-jlee@suse.com> X-Mailer: git-send-email 1.6.0.2 In-Reply-To: <1369973434-8742-1-git-send-email-jlee@suse.com> References: <1369973434-8742-1-git-send-email-jlee@suse.com> Sender: linux-acpi-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-acpi@vger.kernel.org After Andrzej's testing, we found the acpi backlight methods broken on Acer Aspire 5750G but the i915 backlight control works when we set to vendor mode. And, we still want to keep the acpi/video driver for transfer acpi event to key event but not unregister whole acpi/video driver. This patch introduced a new capability flag is ACER_CAP_KEEP_VIDEO_KEY, it indicates the machine works fine with acpi/video driver for key event but want to unregister the backlight interface of acpi/video. Reference: bko#35622 https://bugzilla.kernel.org/show_bug.cgi?id=35622 v2: changed the information statement of keeping acpi video driver. Tested-by: Andrzej Krentosz Cc: Zhang Rui Cc: Len Brown Cc: Carlos Corbacho Cc: Matthew Garrett Cc: Dmitry Torokhov Cc: Corentin Chary Cc: Rafael J. Wysocki Cc: Aaron Lu Cc: Thomas Renninger Signed-off-by: Lee, Chun-Yi --- drivers/platform/x86/acer-wmi.c | 20 ++++++++++++++++++++ 1 files changed, 20 insertions(+), 0 deletions(-) diff --git a/drivers/platform/x86/acer-wmi.c b/drivers/platform/x86/acer-wmi.c index c9076bd..a81c9ed 100644 --- a/drivers/platform/x86/acer-wmi.c +++ b/drivers/platform/x86/acer-wmi.c @@ -207,6 +207,7 @@ struct hotkey_function_type_aa { #define ACER_CAP_BRIGHTNESS (1<<3) #define ACER_CAP_THREEG (1<<4) #define ACER_CAP_ACCEL (1<<5) +#define ACER_CAP_KEEP_VIDEO_KEY (1<<6) #define ACER_CAP_ANY (0xFFFFFFFF) /* @@ -539,6 +540,15 @@ static int video_set_backlight_video_vendor(const struct dmi_system_id *d) return 0; } +static int video_set_backlight_video_vendor_keep_acpi_video( + const struct dmi_system_id *d) +{ + video_set_backlight_video_vendor(d); + interface->capability |= ACER_CAP_KEEP_VIDEO_KEY; + pr_info("Keeping acpi video driver active to emit backlight brightness change key events\n"); + return 0; +} + static const struct dmi_system_id video_vendor_dmi_table[] = { { .callback = video_set_backlight_video_vendor, @@ -572,6 +582,14 @@ static const struct dmi_system_id video_vendor_dmi_table[] = { DMI_MATCH(DMI_PRODUCT_NAME, "Aspire 5750"), }, }, + { + .callback = video_set_backlight_video_vendor_keep_acpi_video, + .ident = "Acer Aspire 5750G", + .matches = { + DMI_MATCH(DMI_BOARD_VENDOR, "Acer"), + DMI_MATCH(DMI_PRODUCT_NAME, "Aspire 5750G"), + }, + }, {} }; @@ -2228,6 +2246,8 @@ static int __init acer_wmi_init(void) if (acpi_video_backlight_support()) { interface->capability &= ~ACER_CAP_BRIGHTNESS; pr_info("Brightness must be controlled by acpi video driver\n"); + } else if (interface->capability & ACER_CAP_KEEP_VIDEO_KEY) { + acpi_video_backlight_unregister(); } else { pr_info("Disabling ACPI video driver\n"); acpi_video_unregister();