Received: by 2002:ac0:a594:0:0:0:0:0 with SMTP id m20-v6csp1922904imm; Wed, 16 May 2018 05:16:03 -0700 (PDT) X-Google-Smtp-Source: AB8JxZo+54fODmlETOsOqr2TE95A/19GEOuVCs7qoltvSglT5wigB0MPJ3nI0OK8fZtetV9tbXlc X-Received: by 2002:a63:7207:: with SMTP id n7-v6mr541284pgc.195.1526472963102; Wed, 16 May 2018 05:16:03 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1526472963; cv=none; d=google.com; s=arc-20160816; b=sRo+WKJqA5a9eldtsvLEcNmynmIq7zslwwedSK3CS06TaFnFdMA1c61BZ2kTKPW6kr jxf7b1Iow/pDNN3Ez4M1Qu4+tMlAnZ4+6gKC3PUX6MprR6jsL5QFkDQtEXfWuXUonNvA L8DykOK0W8rgk1VqBkuPRL7MfDJzjqPhhBVVHz17jFd8iWNleg1zHx9Ipc5BMu8DWUW9 Moz8iWJQKWSp4nKJ68zTm7ihDcZ4mGKIf9+W2qSXLMjqMS/lzsBDZTKodgjXA/m+iIRd glrS7hyViMVteWJZUscp0nKcEHyGQToq5HUQpnKyF4xVIWr7vlPQuytflnGoIskt/HUs XQQA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :arc-authentication-results; bh=B/xMmPe8z15Lp3moZwUe4fIR/Cl1UC/jTHqwjJ7bgIo=; b=CJYC3UE/vsQOn/gHzoaYjO4tjI9P2L1+iDgfrZPC4L/V02ivXr6mTubaXsCWYeO/jl FjbDsbjtmUy1Kuttpv9X1dwbbVPnTtk15rnqzzl0qCLfvd+j13KpNewLD+KwcPKoxvFM /HADJuwDWUGo+9a15DyolQ7Vgv7QRzdwp1OuLuEY2IRYZy9npCnYQY4ZRq0BNgq7sKRh EQhtt8RzNVSSH3o3dzCBIHz+wLNdvYZZ/5QJr7oqZ1tkdbYpoRhxOPt9XZZaQ8fSRrc9 FrxgpWmsmSGesjWAGqXXvQwqvVDSoCGD0WVDqjuiaB9Hm0BeZdAbj7358PnyMr0YdXir +nng== 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 j12-v6si1968430pgf.222.2018.05.16.05.15.48; Wed, 16 May 2018 05:16:03 -0700 (PDT) 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 S1752666AbeEPMOV (ORCPT + 99 others); Wed, 16 May 2018 08:14:21 -0400 Received: from cloudserver094114.home.pl ([79.96.170.134]:51141 "EHLO cloudserver094114.home.pl" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751510AbeEPMOS (ORCPT ); Wed, 16 May 2018 08:14:18 -0400 Received: from 79.184.254.241.ipv4.supernova.orange.pl (79.184.254.241) (HELO aspire.rjw.lan) by serwer1319399.home.pl (79.96.170.134) with SMTP (IdeaSmtpServer 0.83) id e5b0b212c9089b8c; Wed, 16 May 2018 14:14:17 +0200 From: "Rafael J. Wysocki" To: Linux ACPI Cc: Zhang Rui , Linux PM , LKML , Erik Schmauss , Bob Moore , "Wang, Wendy" Subject: [PATCH 1/2] ACPICA: Introduce acpi_dispatch_gpe() Date: Wed, 16 May 2018 14:12:03 +0200 Message-ID: <1877957.ohNgiH8Sko@aspire.rjw.lan> In-Reply-To: <2406722.gU2bUHd7bl@aspire.rjw.lan> References: <2406722.gU2bUHd7bl@aspire.rjw.lan> MIME-Version: 1.0 Content-Transfer-Encoding: 7Bit Content-Type: text/plain; charset="us-ascii" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Rafael J. Wysocki Introduce acpi_dispatch_gpe() as a wrapper around acpi_ev_detect_gpe() for checking if the given GPE (as represented by a GPE device handle and a GPE number) is currently active and dispatching it (if that's the case) outside of interrupt context. Signed-off-by: Rafael J. Wysocki --- drivers/acpi/acpica/evgpe.c | 6 ++++++ drivers/acpi/acpica/evxfgpe.c | 22 ++++++++++++++++++++++ include/acpi/acpixf.h | 1 + 3 files changed, 29 insertions(+) Index: linux-pm/drivers/acpi/acpica/evgpe.c =================================================================== --- linux-pm.orig/drivers/acpi/acpica/evgpe.c +++ linux-pm/drivers/acpi/acpica/evgpe.c @@ -634,6 +634,12 @@ acpi_ev_detect_gpe(struct acpi_namespace flags = acpi_os_acquire_lock(acpi_gbl_gpe_lock); + if (!gpe_event_info) { + gpe_event_info = acpi_ev_get_gpe_event_info(gpe_device, gpe_number); + if (!gpe_event_info) + goto error_exit; + } + /* Get the info block for the entire GPE register */ gpe_register_info = gpe_event_info->register_info; Index: linux-pm/drivers/acpi/acpica/evxfgpe.c =================================================================== --- linux-pm.orig/drivers/acpi/acpica/evxfgpe.c +++ linux-pm/drivers/acpi/acpica/evxfgpe.c @@ -639,6 +639,28 @@ ACPI_EXPORT_SYMBOL(acpi_get_gpe_status) /******************************************************************************* * + * FUNCTION: acpi_gispatch_gpe + * + * PARAMETERS: gpe_device - Parent GPE Device. NULL for GPE0/GPE1 + * gpe_number - GPE level within the GPE block + * + * RETURN: None + * + * DESCRIPTION: Detect and dispatch a General Purpose Event to either a function + * (e.g. EC) or method (e.g. _Lxx/_Exx) handler. + * + ******************************************************************************/ +void acpi_dispatch_gpe(acpi_handle gpe_device, u32 gpe_number) +{ + ACPI_FUNCTION_TRACE(acpi_dispatch_gpe); + + acpi_ev_detect_gpe(gpe_device, NULL, gpe_number); +} + +ACPI_EXPORT_SYMBOL(acpi_dispatch_gpe) + +/******************************************************************************* + * * FUNCTION: acpi_finish_gpe * * PARAMETERS: gpe_device - Namespace node for the GPE Block Index: linux-pm/include/acpi/acpixf.h =================================================================== --- linux-pm.orig/include/acpi/acpixf.h +++ linux-pm/include/acpi/acpixf.h @@ -753,6 +753,7 @@ ACPI_HW_DEPENDENT_RETURN_STATUS(acpi_sta u32 gpe_number, acpi_event_status *event_status)) +void acpi_dispatch_gpe(acpi_handle gpe_device, u32 gpe_number); ACPI_HW_DEPENDENT_RETURN_STATUS(acpi_status acpi_disable_all_gpes(void)) ACPI_HW_DEPENDENT_RETURN_STATUS(acpi_status acpi_enable_all_runtime_gpes(void)) ACPI_HW_DEPENDENT_RETURN_STATUS(acpi_status acpi_enable_all_wakeup_gpes(void))