Received: by 10.223.164.202 with SMTP id h10csp123975wrb; Wed, 22 Nov 2017 04:53:17 -0800 (PST) X-Google-Smtp-Source: AGs4zMajBsgqYcvYNGtBAjIYPf4/omVFmPJW/K9FvN1jIufPfUoSIUL09jMMbngEKgo1aYKJKB1E X-Received: by 10.99.191.69 with SMTP id i5mr20615034pgo.13.1511355196971; Wed, 22 Nov 2017 04:53:16 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1511355196; cv=none; d=google.com; s=arc-20160816; b=Pgh/EhBNQvHxEd0npBhA5g49+ITds4YOrjUcfg2x+FXqIw/7VIzgjqfji0Rba9TS25 L7VE9FcDvlN7Ul+7AmGckIqEx2Q8hpwGCzJKtMvvUjJmBgMD+Dm/95ydWrn/LvfX/M9O k/9Erp7Mbp+Dw5Y/8/rSLCQUKPAKzaJUx07aoFHcqvR6bu1zleOoOCKxfjYRbLjBpyAA msHLOyS8LH2q/4kqozY9Oy0wzW13Lt3CdBqUAs8KfN09HG9cbtBe4ds7qY/FSNFVrnAU Kz/npj9WXMVn5Ow4toO8Qx/VSjb28F4s30W0djospMSSUxr8CUj8QCnD8aZK6llwVvtm vi6Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:content-transfer-encoding :dlp-reaction:dlp-version:dlp-product:content-language :accept-language:in-reply-to:references:message-id:date:thread-index :thread-topic:subject:cc:to:from:arc-authentication-results; bh=txoyXP2pjNHLDgmEIpcPf+ULYMHqvOL1Arn5QoE/LWQ=; b=J/p1ANy21aiLy7wHqJ8qoB0XEkBE4bkWoZ7OaS81FtARwcwaPtmO7TN0wz0zH87kbr GwyvPVHpPaXz+V+Cn3zMQcRi1ca4WFWvrQuAuWabp1G64ICpCyAGnxyqmChgOR2HCChF tRJPajOLzjj3cMF4kJZ/FEmYyHJqPQcFpko2NOHL8g7mQgMuan8Oeh3Kq4w0+o0X8+mV 7VZBRj4E6EfNAVxFGTtdVhYEHcXvA6X1IXAVjtW3N27SFlMlZPd7jizGdiOTVgoTE11r uObXIGeCfGHkN7UldrhAvO1SDAsP5Oefd0P26aH+W53TlYE5jsDCWI7Qv+FRG04uxcyk 2osA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id v10si13238772plz.525.2017.11.22.04.53.05; Wed, 22 Nov 2017 04:53:16 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751371AbdKVMw2 convert rfc822-to-8bit (ORCPT + 77 others); Wed, 22 Nov 2017 07:52:28 -0500 Received: from mga09.intel.com ([134.134.136.24]:30716 "EHLO mga09.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751216AbdKVMw0 (ORCPT ); Wed, 22 Nov 2017 07:52:26 -0500 Received: from orsmga003.jf.intel.com ([10.7.209.27]) by orsmga102.jf.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 22 Nov 2017 04:52:25 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.44,436,1505804400"; d="scan'208";a="5175958" Received: from fmsmsx107.amr.corp.intel.com ([10.18.124.205]) by orsmga003.jf.intel.com with ESMTP; 22 Nov 2017 04:52:25 -0800 Received: from fmsmsx101.amr.corp.intel.com (10.18.124.199) by fmsmsx107.amr.corp.intel.com (10.18.124.205) with Microsoft SMTP Server (TLS) id 14.3.319.2; Wed, 22 Nov 2017 04:52:24 -0800 Received: from shsmsx151.ccr.corp.intel.com (10.239.6.50) by fmsmsx101.amr.corp.intel.com (10.18.124.199) with Microsoft SMTP Server (TLS) id 14.3.319.2; Wed, 22 Nov 2017 04:52:24 -0800 Received: from shsmsx101.ccr.corp.intel.com ([169.254.1.159]) by SHSMSX151.ccr.corp.intel.com ([169.254.3.218]) with mapi id 14.03.0319.002; Wed, 22 Nov 2017 20:52:22 +0800 From: "Zhang, Rui" To: "Zheng, Lv" , "Wysocki, Rafael J" , "Rafael J . Wysocki" , "Brown, Len" CC: "Zheng, Lv" , Lv Zheng , "linux-kernel@vger.kernel.org" , "linux-acpi@vger.kernel.org" Subject: RE: [RFC PATCH v6 1/3] ACPI / EC: Fix possible driver order issue by moving EC event handling earlier Thread-Topic: [RFC PATCH v6 1/3] ACPI / EC: Fix possible driver order issue by moving EC event handling earlier Thread-Index: AQHTOM3ikWuhXU6ROkSiK3P04AdqIaMgpUOQ Date: Wed, 22 Nov 2017 12:52:21 +0000 Message-ID: <744357E9AAD1214791ACBA4B0B9092636BE5557C@SHSMSX101.ccr.corp.intel.com> References: <99f23db65bbe89ee856018629654584a96734c84.1501141963.git.lv.zheng@intel.com> <88fd3a8dd4a99d25525b55b8ac5274067ddc4195.1506653046.git.lv.zheng@intel.com> In-Reply-To: <88fd3a8dd4a99d25525b55b8ac5274067ddc4195.1506653046.git.lv.zheng@intel.com> Accept-Language: en-US Content-Language: en-US X-MS-Has-Attach: X-MS-TNEF-Correlator: x-titus-metadata-40: eyJDYXRlZ29yeUxhYmVscyI6IiIsIk1ldGFkYXRhIjp7Im5zIjoiaHR0cDpcL1wvd3d3LnRpdHVzLmNvbVwvbnNcL0ludGVsMyIsImlkIjoiYzU4ZWY0MjctOTkwMi00YjM4LWI2ODYtMThmMWMxZWM0ZjQyIiwicHJvcHMiOlt7Im4iOiJDVFBDbGFzc2lmaWNhdGlvbiIsInZhbHMiOlt7InZhbHVlIjoiQ1RQX1BVQkxJQyJ9XX1dfSwiU3ViamVjdExhYmVscyI6W10sIlRNQ1ZlcnNpb24iOiIxNy4yLjUuMTgiLCJUcnVzdGVkTGFiZWxIYXNoIjoiY3ZQUDFOcFhkRkd3NGs1MzNZSzJRcEwrMEt2c2hCc1dqZGt1T2VwXC9qUkcxRFpKVlhlZGJDTUJBVWMzcmxRM0QifQ== x-ctpclassification: CTP_PUBLIC dlp-product: dlpe-windows dlp-version: 11.0.0.116 dlp-reaction: no-action x-originating-ip: [10.239.127.40] Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 8BIT MIME-Version: 1.0 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org > -----Original Message----- > From: linux-acpi-owner@vger.kernel.org [mailto:linux-acpi- > owner@vger.kernel.org] On Behalf Of Lv Zheng > Sent: Friday, September 29, 2017 10:50 AM > To: Wysocki, Rafael J ; Rafael J . Wysocki > ; Brown, Len > Cc: Zheng, Lv ; Lv Zheng ; linux- > kernel@vger.kernel.org; linux-acpi@vger.kernel.org > Subject: [RFC PATCH v6 1/3] ACPI / EC: Fix possible driver order issue by > moving EC event handling earlier > > This patch tries to detect EC events earlier after resume, so that if an event > occurred before invoking acpi_ec_unblock_transactions(), it could be > detected by acpi_ec_unblock_transactions() which is the earliest EC driver > call after resume. > > However after the noirq stage, if an event ocurred after > acpi_ec_unblock_transactions() and before acpi_ec_resume(), there was no > mean to detect and trigger it right then, but can only detect it and handle it > after acpi_ec_resume(). > > Now the final logic is: > 1. If ec_freeze_events=Y, event handling is stopped in acpi_ec_suspend(), > restarted in acpi_ec_resume(); > 2. If ec_freeze_events=N, event handling is stopped in > acpi_ec_block_transactions(), restarted in > acpi_ec_unblock_transactions(); > 3. In order to handling the conflict of the edge-trigger nature of EC IRQ > and the Linux noirq stage, advance_transaction() is invoked where the > event handling is enabled and the noirq stage is ended. > > Known issue: > 1. Event ocurred between acpi_ec_unblock_transactions() and > acpi_ec_resume() may still lead to the order issue. This can only be > fixed by adding a periodic detection mechanism during the noirq stage. > > Signed-off-by: Lv Zheng > Tested-by: Tomislav Ivek > Tested-by: Luya Tshimbalanga I don't know what issue this patch has been tested for. Lv, can you please clarify? I agree with lv that it can probably fix some issues brought by the device order issue. And I'll be glad to push this after we have verified it is really helpful. Lv, Do you still remember the bug report for the lid issue? Thanks, rui > --- > drivers/acpi/ec.c | 35 ++++++++++++++++++++++++++--------- > 1 file changed, 26 insertions(+), 9 deletions(-) > > diff --git a/drivers/acpi/ec.c b/drivers/acpi/ec.c index df84246..f1f320b > 100644 > --- a/drivers/acpi/ec.c > +++ b/drivers/acpi/ec.c > @@ -249,6 +249,11 @@ static bool acpi_ec_started(struct acpi_ec *ec) > !test_bit(EC_FLAGS_STOPPED, &ec->flags); } > > +static bool acpi_ec_no_sleep_events(void) { > + return acpi_sleep_no_ec_events() && ec_freeze_events; } > + > static bool acpi_ec_event_enabled(struct acpi_ec *ec) { > /* > @@ -260,14 +265,14 @@ static bool acpi_ec_event_enabled(struct acpi_ec > *ec) > return false; > /* > * However, disabling the event handling is experimental for late > - * stage (suspend), and is controlled by the boot parameter of > - * "ec_freeze_events": > + * stage (suspend), and is controlled by > + * "acpi_ec_no_sleep_events()": > * 1. true: The EC event handling is disabled before entering > * the noirq stage. > * 2. false: The EC event handling is automatically disabled as > * soon as the EC driver is stopped. > */ > - if (ec_freeze_events) > + if (acpi_ec_no_sleep_events()) > return acpi_ec_started(ec); > else > return test_bit(EC_FLAGS_STARTED, &ec->flags); @@ -524,8 > +529,8 @@ static bool acpi_ec_query_flushed(struct acpi_ec *ec) static void > __acpi_ec_flush_event(struct acpi_ec *ec) { > /* > - * When ec_freeze_events is true, we need to flush events in > - * the proper position before entering the noirq stage. > + * When acpi_ec_no_sleep_events() is true, we need to flush events > + * in the proper position before entering the noirq stage. > */ > wait_event(ec->wait, acpi_ec_query_flushed(ec)); > if (ec_query_wq) > @@ -948,7 +953,8 @@ static void acpi_ec_start(struct acpi_ec *ec, bool > resuming) > if (!resuming) { > acpi_ec_submit_request(ec); > ec_dbg_ref(ec, "Increase driver"); > - } > + } else if (!acpi_ec_no_sleep_events()) > + __acpi_ec_enable_event(ec); > ec_log_drv("EC started"); > } > spin_unlock_irqrestore(&ec->lock, flags); @@ -980,7 +986,7 @@ > static void acpi_ec_stop(struct acpi_ec *ec, bool suspending) > if (!suspending) { > acpi_ec_complete_request(ec); > ec_dbg_ref(ec, "Decrease driver"); > - } else if (!ec_freeze_events) > + } else if (!acpi_ec_no_sleep_events()) > __acpi_ec_disable_event(ec); > clear_bit(EC_FLAGS_STARTED, &ec->flags); > clear_bit(EC_FLAGS_STOPPED, &ec->flags); @@ -1910,7 > +1916,7 @@ static int acpi_ec_suspend(struct device *dev) > struct acpi_ec *ec = > acpi_driver_data(to_acpi_device(dev)); > > - if (acpi_sleep_no_ec_events() && ec_freeze_events) > + if (acpi_ec_no_sleep_events()) > acpi_ec_disable_event(ec); > return 0; > } > @@ -1946,7 +1952,18 @@ static int acpi_ec_resume(struct device *dev) > struct acpi_ec *ec = > acpi_driver_data(to_acpi_device(dev)); > > - acpi_ec_enable_event(ec); > + if (acpi_ec_no_sleep_events()) > + acpi_ec_enable_event(ec); > + else { > + /* > + * Though whether there is an event pending has been > + * checked in acpi_ec_unblock_transactions() when > + * acpi_ec_no_sleep_events() is false, check it one more > + * time after noirq stage to detect events occurred after > + * acpi_ec_unblock_transactions(). > + */ > + advance_transaction(ec); > + } > return 0; > } > #endif > -- > 2.7.4 > > -- > To unsubscribe from this list: send the line "unsubscribe linux-acpi" in the > body of a message to majordomo@vger.kernel.org More majordomo info at > http://vger.kernel.org/majordomo-info.html From 1579840676282581389@xxx Fri Sep 29 02:51:16 +0000 2017 X-GM-THRID: 1577233563469529260 X-Gmail-Labels: Inbox,Category Forums