Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp4455865pxf; Tue, 30 Mar 2021 08:14:29 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzRNk4Z33PQPX+FgUn0Qw6lQae/KhO0LJTL0Q5IsOtjAOgZ+7jGGiI7LBiqeA1bbn9g4zcz X-Received: by 2002:a17:906:4407:: with SMTP id x7mr33562537ejo.546.1617117269146; Tue, 30 Mar 2021 08:14:29 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1617117269; cv=none; d=google.com; s=arc-20160816; b=MkgW72F8o0GKQU43NyQhkUlioy0e+wu/PNMN1ZX2ZNMVHQHBK7ZrwuzXRIrPJplHJM tm3UU46pfyTEGFWX7eZkk8fwISVj2tWVsasVIWd0uheMQZMTja7b+xdkGDxhFkpFaoei YqMQZssAEkyhqMP6aFaFY2Tkf5M6YRtjYehhI8oE+rbmI28PusefgIh6W9lQWO+9dWYT HuH+5EftRKkOwQxT2uu36Y1qeLpfuGZggDGfXQxfxlhOgJJdvgeRGpHF2byXksGcOCFv 8y2LIjA9Xjp3WyKtHeBnpU07ZhqTw5iE4cca7VqY1W1XtSgRDNjqMbiP7PouxIIq2nMe b1gw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-language:content-transfer-encoding :in-reply-to:mime-version:user-agent:date:message-id:organization :from:references:cc:to:subject:ironport-sdr:ironport-sdr; bh=SON5svxhwEdTo6tEvbQQvZpCVlkW/g6s20Cl9zYGSXI=; b=M3jMmbM1fSVzMlcPjJCXYDBZDPrPVHpuPHQRzB8bo2mlQkN5FAVqPCPdw6+4Cnzfr9 J9mgTSPWE+PIBTLlmeJNxgruvLZuZP0IdZIalT8RBH87uG9A607+m6wvlWPuAgXVQRV/ od6p/EkBfCoYcr0XhbJr631B6/dVVCLRhss6yXznnOXwtUVHkVKnznKKmzRb4FQdD/kB XdLW9PkWQFgfxj/NtQ0FVSku3EuZ0wpGAF/abgS+ejfuTsI8mrfCFGgbEbjr/oAnuhsa ua6ylMTUMRfyjVYZJ3lhCk+XnrUZnRQdZWY6ih810nJYl7ttuzFkZPWKZ5bD13F8rHqo A4Zw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id l12si15635181edi.290.2021.03.30.08.14.05; Tue, 30 Mar 2021 08:14:29 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231875AbhC3PKM (ORCPT + 99 others); Tue, 30 Mar 2021 11:10:12 -0400 Received: from mga03.intel.com ([134.134.136.65]:32623 "EHLO mga03.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231874AbhC3PJs (ORCPT ); Tue, 30 Mar 2021 11:09:48 -0400 IronPort-SDR: rNJhceoetM/G+IuRfXSYgeVtGpKHpjneiwOI/JX+kKdAPHQOWiVFO7HORJmMfXN+2XXqQZXPML b2ibcOJzZNhw== X-IronPort-AV: E=McAfee;i="6000,8403,9939"; a="191816894" X-IronPort-AV: E=Sophos;i="5.81,291,1610438400"; d="scan'208";a="191816894" Received: from orsmga008.jf.intel.com ([10.7.209.65]) by orsmga103.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 30 Mar 2021 08:09:48 -0700 IronPort-SDR: LZBLF35OpbKsekZsYWYC8Kwt+pNmJHfS5HV++apvkmZsiAr5LchciB8UlW0OdA5iMRiVW1UvHP p3uWO5EkANUA== X-IronPort-AV: E=Sophos;i="5.81,291,1610438400"; d="scan'208";a="418210317" Received: from rjwysock-mobl1.ger.corp.intel.com (HELO [10.249.131.38]) ([10.249.131.38]) by orsmga008-auth.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 30 Mar 2021 08:09:45 -0700 Subject: Re: [PATCH] resource: Prevent irqresource_disabled() from erasing flags To: Angela Czubak , Mika Westerberg Cc: akpm@linux-foundation.org, john.garry@huawei.com, linux-kernel@vger.kernel.org, upstream@semihalf.com, dtor@chromium.org, linux-acpi , rafael@kernel.org References: <20210329195238.9455-1-acz@semihalf.com> From: "Rafael J. Wysocki" Organization: Intel Technology Poland Sp. z o. o., KRS 101882, ul. Slowackiego 173, 80-298 Gdansk Message-ID: <1c086b9e-d5c2-6e8d-1d81-748935b0dd64@intel.com> Date: Tue, 30 Mar 2021 17:09:42 +0200 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:78.0) Gecko/20100101 Thunderbird/78.8.1 MIME-Version: 1.0 In-Reply-To: <20210329195238.9455-1-acz@semihalf.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 8bit Content-Language: en-US Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 3/29/2021 9:52 PM, Angela Czubak wrote: > Do not overwrite flags as it leads to erasing triggering and polarity > information which might be useful in case of hard-coded interrupts. > This way the information can be read later on even though mapping to > APIC domain failed. > > Signed-off-by: Angela Czubak > --- > Some Chromebooks use hard-coded interrupts in their ACPI tables. > This is an excerpt as dumped on Relm: > > ... >             Name (_HID, "ELAN0001")  // _HID: Hardware ID >             Name (_DDN, "Elan Touchscreen ")  // _DDN: DOS Device Name >             Name (_UID, 0x05)  // _UID: Unique ID >             Name (ISTP, Zero) >             Method (_CRS, 0, NotSerialized)  // _CRS: Current Resource Settings >             { >                 Name (BUF0, ResourceTemplate () >                 { >                     I2cSerialBusV2 (0x0010, ControllerInitiated, 0x00061A80, >                         AddressingMode7Bit, "\\_SB.I2C1", >                         0x00, ResourceConsumer, , Exclusive, >                         ) >                     Interrupt (ResourceConsumer, Edge, ActiveLow, Exclusive, ,, ) >                     { >                         0x000000B8, >                     } >                 }) >                 Return (BUF0) /* \_SB_.I2C1.ETSA._CRS.BUF0 */ >             } > ... > > This interrupt is hard-coded to 0xB8 = 184 which is too high to be mapped > to IO-APIC, so no triggering information is propagated as acpi_register_gsi() > fails and irqresource_disabled() is issued, which leads to erasing triggering > and polarity information. > If that function added its flags instead of overwriting them the correct IRQ > type would be set even for the hard-coded interrupts, which allows device driver > to retrieve it. > Please, let me know if this kind of modification is acceptable. From the quick look it should not be problematic, but it needs to be checked more carefully. Mika, what do you think? > include/linux/ioport.h | 2 +- > 1 file changed, 1 insertion(+), 1 deletion(-) > > diff --git a/include/linux/ioport.h b/include/linux/ioport.h > index 55de385c839cf..647744d8514e0 100644 > --- a/include/linux/ioport.h > +++ b/include/linux/ioport.h > @@ -331,7 +331,7 @@ static inline void irqresource_disabled(struct resource *res, u32 irq) > { > res->start = irq; > res->end = irq; > - res->flags = IORESOURCE_IRQ | IORESOURCE_DISABLED | IORESOURCE_UNSET; > + res->flags |= IORESOURCE_IRQ | IORESOURCE_DISABLED | IORESOURCE_UNSET; > } > > extern struct address_space *iomem_get_mapping(void);