Received: by 2002:a25:824b:0:0:0:0:0 with SMTP id d11csp3767704ybn; Fri, 27 Sep 2019 11:03:27 -0700 (PDT) X-Google-Smtp-Source: APXvYqzcVj9kunbCmnh6D3VBQ5s+/QgTjbMsdgqtDw5x6YWMHYpzR2o47QWcinfwqccB1iMr342u X-Received: by 2002:a50:8a9d:: with SMTP id j29mr6137183edj.283.1569607405102; Fri, 27 Sep 2019 11:03:25 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1569607405; cv=none; d=google.com; s=arc-20160816; b=i0nlZB0ykMPh1OTJxmaM1j/ZgAc3lgmWHOsgfcQW4W2IaamknUwOVeMlqeGe6DFLgR zSIcMKpDAfoCfuspNAL8giWkUP2FFMOPDcghXT3cZwvMz+RUXN7tHdK7mTtXsF/jrRPJ WqBvQafN8X1fsj18Im2+ULQ/W5EoE5fYkisxPMdClhBZ7tzKzWVzxarHpPSScuu95e93 7Fr21chDo8sXDOd0kwMCQfNFF6NT8GNP5FC5rQDQsGI+yMd7gb1sSE7RmLPMeakK2GFF Y1wRN+/KH0A5cj4jVsRbg81QlfqbZ+l+WnewQHOVKI3pM5pSpLe3VQFSoaNrd7+hivqI gfCw== 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:dkim-signature; bh=qmaYsyRcatgzXQsy0tcn1VuhcXwzjzV5wqW3owNkQCI=; b=yZSj04TWRjz0NKEFcmmuMQpUCmBIF4+vdx1E5UZbSd0HGGSSnpMVWoeyCkQ08UsFAt bjpUqaReZrT99NPgd9VqQr/srP307LQi1JWlDVrzpHVb6XvIEhhF5y9wFb6MROKB90/1 H7NnEG1vbQHB/B7nHaj/XbdMdl0prcbr8BB/RcfkMPYFCfzlEEJmrvXDLoHzkuFhjwma Dadoju9Mop8GxDR7TioYcDweu8ez5lb1ob8SdNlQNIYqKx7yeD2xVCUgkM3mxmd6qiId WkHScJz7VDiWNDZpN6S7UFwR88c8U37zHb9wReXeF4v/PfCbvHilSwZup2mVsMHltWtG /vJw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=OGg+TwHV; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id j5si3129174ejb.212.2019.09.27.11.02.32; Fri, 27 Sep 2019 11:03:25 -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; dkim=pass header.i=@gmail.com header.s=20161025 header.b=OGg+TwHV; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727983AbfI0R7p (ORCPT + 99 others); Fri, 27 Sep 2019 13:59:45 -0400 Received: from mail-pf1-f193.google.com ([209.85.210.193]:42255 "EHLO mail-pf1-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726394AbfI0R7p (ORCPT ); Fri, 27 Sep 2019 13:59:45 -0400 Received: by mail-pf1-f193.google.com with SMTP id q12so2002895pff.9 for ; Fri, 27 Sep 2019 10:59:45 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=qmaYsyRcatgzXQsy0tcn1VuhcXwzjzV5wqW3owNkQCI=; b=OGg+TwHVpitznJ+6fsRfw+2/ZLEYfePM3aO42uWqzOSJqUb3CyecEISYJ+GK46A0L8 ti0lV0hbEmE8VeN/gh/eAm6eTAwmA3CDfKZfsCeGhv5sJscyFhaaSL+GIJ6pK8UTt4GF +nOgcyUtYkF5sWmV+vgWDTdhRUwX7VKhheT4viYW9xUodXY+MsvcQYWg99m1WJ+V/vfq HVMrVtTD/KL3AtzQYCm6NvtoQFEcJXCEX6oy74wBITWu4XtcdgKOIDJyY0CBA6il5KZo ehyf3sTzM0FxXIoFN37tsak33QDEBqvHzcKMSFq6fvCAyAApX0vc2ITA+f6c3gCxb9R1 cKrg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=qmaYsyRcatgzXQsy0tcn1VuhcXwzjzV5wqW3owNkQCI=; b=EEm0uMW3uaMgxQod3NYyY20dP84HWEK7Z6dT+fAjKauDj7k3PIs4Q0ihyRXe1nJ1wz cXP7tMbi6D1khDqmkz3ZcM2AdfrGc2l0OyU5s1YT2ulJIHqOndgI/IapAefomF5UIBYd 24b0leFCqR0h8TFfYmmwlBfa6pwXlm/VSamUTfPT/4WEWk0CgfQK6WlSVzYu80wjd8sy yOOervNR0wgoUtUDDmcpVKZ6hcnvNj8NRpFvkJWqCUtq5t7M11PCNTn1MvLBwLinELBX 1ab2ZcAhMaAshMnUBIrl+7rTQb57ItUdU6O1JUnFtPuA3Z98dMuPjKWUE/XhSJ8Ycl6j 9ong== X-Gm-Message-State: APjAAAVNR6wY4F4aTEEHWS1V+T8jjIMo8Pe+z7wDCzg9m1ceVc81ZSLN /ncRcT5cju4IDxAAo9kqR/k= X-Received: by 2002:a62:190f:: with SMTP id 15mr5922269pfz.172.1569607184260; Fri, 27 Sep 2019 10:59:44 -0700 (PDT) Received: from iclxps.lan (155-97-232-235.usahousing.utah.edu. [155.97.232.235]) by smtp.googlemail.com with ESMTPSA id z12sm3582206pfj.41.2019.09.27.10.59.43 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 27 Sep 2019 10:59:43 -0700 (PDT) From: Tuowen Zhao To: lee.jones@linaro.org, linux-kernel@vger.kernel.org Cc: andriy.shevchenko@linux.intel.com, mika.westerberg@linux.intel.com, acelan.kao@canonical.com, bhelgaas@google.com, kai.heng.feng@canonical.com, Tuowen Zhao Subject: [PATCH] mfd: intel-lpss: use devm_ioremap_uc for mmio Date: Fri, 27 Sep 2019 11:55:13 -0600 Message-Id: <20190927175513.31054-1-ztuowen@gmail.com> X-Mailer: git-send-email 2.23.0 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Write-combining BAR for intel-lpss-pci in MTRR causes system hangs during boot. This patch adds devm_ioremap_uc as a new managed wrapper to ioremap_uc and with it forces the use of strongly uncachable mmio in intel-lpss. This bahavior is seen on Dell XPS 13 7390 2-in-1: [ 0.001734] 5 base 4000000000 mask 6000000000 write-combining 4000000000-7fffffffff : PCI Bus 0000:00 4000000000-400fffffff : 0000:00:02.0 (i915) 4010000000-4010000fff : 0000:00:15.0 (intel-lpss-pci) Link: https://bugzilla.kernel.org/show_bug.cgi?id=203485 Signed-off-by: Tuowen Zhao --- drivers/mfd/intel-lpss.c | 2 +- include/linux/io.h | 2 ++ lib/devres.c | 19 +++++++++++++++++++ 3 files changed, 22 insertions(+), 1 deletion(-) diff --git a/drivers/mfd/intel-lpss.c b/drivers/mfd/intel-lpss.c index 277f48f1cc1c..06106c9320bb 100644 --- a/drivers/mfd/intel-lpss.c +++ b/drivers/mfd/intel-lpss.c @@ -395,7 +395,7 @@ int intel_lpss_probe(struct device *dev, if (!lpss) return -ENOMEM; - lpss->priv = devm_ioremap(dev, info->mem->start + LPSS_PRIV_OFFSET, + lpss->priv = devm_ioremap_uc(dev, info->mem->start + LPSS_PRIV_OFFSET, LPSS_PRIV_SIZE); if (!lpss->priv) return -ENOMEM; diff --git a/include/linux/io.h b/include/linux/io.h index accac822336a..a59834bc0a11 100644 --- a/include/linux/io.h +++ b/include/linux/io.h @@ -64,6 +64,8 @@ static inline void devm_ioport_unmap(struct device *dev, void __iomem *addr) void __iomem *devm_ioremap(struct device *dev, resource_size_t offset, resource_size_t size); +void __iomem *devm_ioremap_uc(struct device *dev, resource_size_t offset, + resource_size_t size); void __iomem *devm_ioremap_nocache(struct device *dev, resource_size_t offset, resource_size_t size); void __iomem *devm_ioremap_wc(struct device *dev, resource_size_t offset, diff --git a/lib/devres.c b/lib/devres.c index 6a0e9bd6524a..beb0a064b891 100644 --- a/lib/devres.c +++ b/lib/devres.c @@ -9,6 +9,7 @@ enum devm_ioremap_type { DEVM_IOREMAP = 0, DEVM_IOREMAP_NC, + DEVM_IOREMAP_UC, DEVM_IOREMAP_WC, }; @@ -39,6 +40,9 @@ static void __iomem *__devm_ioremap(struct device *dev, resource_size_t offset, case DEVM_IOREMAP_NC: addr = ioremap_nocache(offset, size); break; + case DEVM_IOREMAP_UC: + addr = ioremap_uc(offset, size); + break; case DEVM_IOREMAP_WC: addr = ioremap_wc(offset, size); break; @@ -68,6 +72,21 @@ void __iomem *devm_ioremap(struct device *dev, resource_size_t offset, } EXPORT_SYMBOL(devm_ioremap); +/** + * devm_ioremap_uc - Managed ioremap_uc() + * @dev: Generic device to remap IO address for + * @offset: Resource address to map + * @size: Size of map + * + * Managed ioremap_uc(). Map is automatically unmapped on driver detach. + */ +void __iomem *devm_ioremap_uc(struct device *dev, resource_size_t offset, + resource_size_t size) +{ + return __devm_ioremap(dev, offset, size, DEVM_IOREMAP_UC); +} +EXPORT_SYMBOL(devm_ioremap_uc); + /** * devm_ioremap_nocache - Managed ioremap_nocache() * @dev: Generic device to remap IO address for -- 2.23.0