Received: by 10.213.65.68 with SMTP id h4csp768776imn; Tue, 13 Mar 2018 22:23:24 -0700 (PDT) X-Google-Smtp-Source: AG47ELtGXBWv57a/0swBPGSZZPFlbBk1oOPyH8vJ7qH0SNYBsuLai+eTKKt84B3HsX/nTbENzLy7 X-Received: by 10.98.70.89 with SMTP id t86mr3032592pfa.215.1521005004816; Tue, 13 Mar 2018 22:23:24 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1521005004; cv=none; d=google.com; s=arc-20160816; b=y4+YC1vXdYduJOvvbSaSAJE05uMaVDS1dKwAJXprglCzcMB+ZXhQbhEYrFu+fsLU5o hPAZrWdNoM1HUsRtsuiy767bdWuEXtmJEEdw+nNOcy3BG8MpeTvwT/8m2a4Z1GEyq7w1 0boYGBixkPDnJwX1Ls4HWbgy49dHa9LB2pwu6sKB7M8eGHiwp9p2atOMxam8r7o0u4u3 GfsMnTLG8EdpLASIHvAhvYDsc4jjkImvSDYcr9fh4X6VJHY11LjNo8nrFggTEP+O9+qQ IWDFM7YioOG9vBXTlmswx/rvC36AVeisvaY/VBGjskV+cYV0COePJ2SrB6lhtzxqShTq eqGA== 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 :message-id:date:subject:cc:to:from:arc-authentication-results; bh=MoRd7ikhgE0Rhi7uiyp6cMFvtDcZJLOdbRmVUeCb8UY=; b=skQJXJN0JuVF7ev0hqtMm0h4rdHRuES95z5T4FnjMMj4kMsjL80M7Cg87CWgJQmkx9 HLhb69rPI/6VcPlGQb6vccwEjj3Nerzk+U/hDtNkjNNBpp0M+UxcMvwumtWg4UFnfD3w PlMXr4bjJwK326OSk280k/8mAoH3rAKN90TOfFBgLn60Ksga0sxAx2+G5b2v3WKEESZv rtl4v5QMgi25eJxOFiDqFi4xgffYlVBC6dP0ic/mcJLeY+Pp54kiCmh/J9KuVEGmM3EI NG4BTk0URSjTJSWhsBtynLa3tM1mbeQetSDbkRXXqqPrZZEvx0UtEgzGQtFoRP+qj9lu HwBQ== 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 b187si1293243pgc.205.2018.03.13.22.23.10; Tue, 13 Mar 2018 22:23:24 -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 S1753270AbeCNFWR (ORCPT + 99 others); Wed, 14 Mar 2018 01:22:17 -0400 Received: from mga09.intel.com ([134.134.136.24]:34179 "EHLO mga09.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751270AbeCNFWQ (ORCPT ); Wed, 14 Mar 2018 01:22:16 -0400 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga008.jf.intel.com ([10.7.209.65]) by orsmga102.jf.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 13 Mar 2018 22:22:16 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.47,468,1515484800"; d="scan'208,223";a="25064915" Received: from raj-desk2.iind.intel.com ([10.223.107.30]) by orsmga008.jf.intel.com with ESMTP; 13 Mar 2018 22:22:12 -0700 From: Rajneesh Bhardwaj To: x86@kernel.org Cc: tglx@linutronix.de, mingo@redhat.com, hpa@zytor.com, rjw@rjwysocki.net, anshuman.gupta@intel.com, andriy.shevchenko@linux.intel.com, linux-kernel@vger.kernel.org, Rajneesh Bhardwaj , Alan Cox Subject: [PATCH v2] x86: i8237: Register based on FADT legacy boot flag Date: Wed, 14 Mar 2018 10:47:07 +0530 Message-Id: <1521004627-30329-1-git-send-email-rajneesh.bhardwaj@intel.com> X-Mailer: git-send-email 2.7.4 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From Skylake onwards, the platform controller hub (Sunrisepoint PCH) does not support legacy DMA operations to IO ports 81h-83h, 87h, 89h-8Bh, 8Fh. Currently this driver registers as syscore ops and its resume function is called on every resume from S3. On Skylake and Kabylake, this causes a resume delay of around 100ms due to port IO operations, which is a problem. This change allows to load the driver only when the platform bios explicitly supports such devices or has a cut-off date earlier than 2017. Please refer to chapter 21 of 6th Generation Intel® Core™ Processor Platform Controller Hub Family: BIOS Specification. https://www.intel.in/content/www/in/en/embedded/products/skylake/u-mobile/software-and-drivers.html Cc: Alan Cox Reviewed-by: Andy Shevchenko Signed-off-by: Anshuman Gupta Signed-off-by: Rajneesh Bhardwaj --- Changes in v2: * changed to dma_inb() This depends on recently introduced dmi_get_bios_year() helper. https://patchwork.kernel.org/patch/10252151/ arch/x86/kernel/i8237.c | 25 +++++++++++++++++++++++++ 1 file changed, 25 insertions(+) diff --git a/arch/x86/kernel/i8237.c b/arch/x86/kernel/i8237.c index 8eeaa81de066..bf5d8104e17b 100644 --- a/arch/x86/kernel/i8237.c +++ b/arch/x86/kernel/i8237.c @@ -9,6 +9,7 @@ * your option) any later version. */ +#include #include #include @@ -49,6 +50,30 @@ static struct syscore_ops i8237_syscore_ops = { static int __init i8237A_init_ops(void) { + /* + * From SKL PCH onwards, the port 0x61 bit 4 would stop toggle and + * the legacy DMA device is removed in which the I/O ports (81h-83h, + * 87h, 89h-8Bh, 8Fh) related to it are removed as well. All + * removed ports must return 0xff for a inb() request. + * + * Note: DMA_PAGE_2 (port 0x81) should not be checked for detecting + * the presence of DMA device since it may be used by BIOS to decode + * LPC traffic for POST codes. Original LPC only decodes one byte of + * port 0x80 but some BIOS may choose to enhance PCH LPC port 0x8x + * decoding. + */ + if (dma_inb(DMA_PAGE_0) == 0xFF) + return -ENODEV; + + /* + * It should be OK to not load this driver as newer SoC may not + * support 8237 DMA or bus mastering from LPC. Platform firmware + * must announce the support for such legacy devices via + * ACPI_FADT_LEGACY_DEVICES field in FADT table. + */ + if (!x86_platform.legacy.devices.pnpbios && dmi_get_bios_year() >= 2017) + return -ENODEV; + register_syscore_ops(&i8237_syscore_ops); return 0; } -- 2.7.4