Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp5329789ybl; Tue, 14 Jan 2020 07:13:34 -0800 (PST) X-Google-Smtp-Source: APXvYqyEY6YZydatEKler+F8Pt4oOp5ZA5c0h9FRQTUWld3INRIhEvgDudRfX44nQQwCjxfCXgD+ X-Received: by 2002:a9d:2965:: with SMTP id d92mr16026864otb.175.1579014814493; Tue, 14 Jan 2020 07:13:34 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1579014814; cv=none; d=google.com; s=arc-20160816; b=oOpWRlbpfuQCT3CgEY5mmdE36vEHPmxNiseCmF8YuvwCPATtKzWujidwKMg8ZuZ1ej 3DSPd/pjkzymn/QkiEVjm+9BUmJJ75pG9fIFh2cabkLTah8b7XxbE6y33OB/oREO9NJP LQ6eEN0v9F1qKid+fGcpGMcx4hYyz2Ka7NTBMk/sCXhFlTcfhcN2qP3Xl4IwcGViQIT6 mFBes0Npt9swBR08Z9ZYtT2tJ5RS+gLxfsOQHzxudR6TPKqmG0H+XSGvZu4uObqrb8R3 Feb/fL4/6f9AXI+YYtt38G7h2K836GxkwFCieTPvomsfCN+KrwEyx++HQ0H8lCwv0mZ8 FTkA== 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=nkGZG7SrCg/dkC5ag7U6FC/+BJoAtyAPaz4N+sK3NTU=; b=SW6ZBy1H3zoR29qP2KLubihYvg18tQSN/4YfUFZF4KlawZP4v4NNCoi/k1kyvnfGSi XlJLYwSmAnCQ3SZ86zdHl21rpwfdKsx0oPTYJynDWZptOKBlZoXjPPWs82Ho2j/K31q6 G6RaIata6pBWdWPfQgvxkupFCHz69o+lit7P9La68oJjEL2YeVYdMhHH+cbhQEPQml+v o9Ps4/TaDi0vh/nuNtxDmHun1QzIj2qVMd6pxBEnbZxHzSnhvBU4uGfYxPF0JsNEQUIa 0TEFAQrDJhNSrW0NCUc6zBXZByYKraY+/z34rEj7rIzXp4GnZI3wjK+SUl+Pz/kUTwEq N3cw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=google header.b=UXrUv4mD; 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 g10si8901011otn.12.2020.01.14.07.13.23; Tue, 14 Jan 2020 07:13:34 -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; dkim=pass header.i=@linuxfoundation.org header.s=google header.b=UXrUv4mD; 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 S1729045AbgANPMY (ORCPT + 99 others); Tue, 14 Jan 2020 10:12:24 -0500 Received: from mail-io1-f67.google.com ([209.85.166.67]:39849 "EHLO mail-io1-f67.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726297AbgANPMX (ORCPT ); Tue, 14 Jan 2020 10:12:23 -0500 Received: by mail-io1-f67.google.com with SMTP id c16so14162803ioh.6 for ; Tue, 14 Jan 2020 07:12:23 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linuxfoundation.org; s=google; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=nkGZG7SrCg/dkC5ag7U6FC/+BJoAtyAPaz4N+sK3NTU=; b=UXrUv4mDNhE+LH+9At0LmtyxUu2Z40+9NS0Ktltdfw4q6iyq6yksNKateEPraVHvkM b9GWB7C4mBdDiOES6HOfWXBe/0MMUg5+9nNgoB52WFEDKHAt8UkdzxeI+IadsQBCsBd5 EArO0SwQWXOGFiXKu7oun4s5rm2kd2HdlRlto= 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=nkGZG7SrCg/dkC5ag7U6FC/+BJoAtyAPaz4N+sK3NTU=; b=FFTEJ51fIXcBaXoJm3L06CwCI1J1hZewLUkoFF5Yw+dDWKc5o7K/TaLK9BNmDxt5e1 I7LqrgBpVFIc7WmluKxE/0tMq75UG+OGiY5xYG0yGUF+kKjMXcyvz/xs7C+ieeHxqeAb Z0S3KLRkqQRc1B3Qg93XH9LpR43Wt/Ee9I6DDlgv2kBnoA0lkDlBdCfzFCFvPTjvg0hv UQ9eWMgKlTNDRyjxcB2Hdg3cMbzwVCg/RtGerH/kbv5BDVCfgf3BM2cXw9qoVggYxC2K UYu3WP6FcbSLwpHaYfC4viCHLND3Rc85qsm4PnhNBr90s6LLe6WhZ3gAsphq/fK2RtY6 70qg== X-Gm-Message-State: APjAAAVIBtJV+gzQWW4fGPbVujiTgOHXtyflVJ3pv2C37CkIkpT3fZdr QgCQ+ajs2a+PmUApWleXeh3ZFQ== X-Received: by 2002:a05:6602:235b:: with SMTP id r27mr17579379iot.51.1579014743030; Tue, 14 Jan 2020 07:12:23 -0800 (PST) Received: from shuah-t480s.internal (c-24-9-64-241.hsd1.co.comcast.net. [24.9.64.241]) by smtp.gmail.com with ESMTPSA id a9sm4958922ilk.14.2020.01.14.07.12.22 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 14 Jan 2020 07:12:22 -0800 (PST) From: Shuah Khan To: joro@8bytes.org Cc: Shuah Khan , iommu@lists.linux-foundation.org, linux-kernel@vger.kernel.org Subject: [PATCH] iommu: amd: Fix IOMMU perf counter clobbering during init Date: Tue, 14 Jan 2020 08:12:20 -0700 Message-Id: <20200114151220.29578-1-skhan@linuxfoundation.org> X-Mailer: git-send-email 2.20.1 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 init_iommu_perf_ctr() clobbers the register when it checks write access to IOMMU perf counters and fails to restore when they are writable. Add save and restore to fix it. Signed-off-by: Shuah Khan --- drivers/iommu/amd_iommu_init.c | 22 ++++++++++++++++------ 1 file changed, 16 insertions(+), 6 deletions(-) diff --git a/drivers/iommu/amd_iommu_init.c b/drivers/iommu/amd_iommu_init.c index 568c52317757..c0ad4f293522 100644 --- a/drivers/iommu/amd_iommu_init.c +++ b/drivers/iommu/amd_iommu_init.c @@ -1655,27 +1655,37 @@ static int iommu_pc_get_set_reg(struct amd_iommu *iommu, u8 bank, u8 cntr, static void init_iommu_perf_ctr(struct amd_iommu *iommu) { struct pci_dev *pdev = iommu->dev; - u64 val = 0xabcd, val2 = 0; + u64 val = 0xabcd, val2 = 0, save_reg = 0; if (!iommu_feature(iommu, FEATURE_PC)) return; amd_iommu_pc_present = true; + /* save the value to restore, if writable */ + if (iommu_pc_get_set_reg(iommu, 0, 0, 0, &save_reg, false)) + goto pc_false; + /* Check if the performance counters can be written to */ if ((iommu_pc_get_set_reg(iommu, 0, 0, 0, &val, true)) || (iommu_pc_get_set_reg(iommu, 0, 0, 0, &val2, false)) || - (val != val2)) { - pci_err(pdev, "Unable to write to IOMMU perf counter.\n"); - amd_iommu_pc_present = false; - return; - } + (val != val2)) + goto pc_false; + + /* restore */ + if (iommu_pc_get_set_reg(iommu, 0, 0, 0, &save_reg, true)) + goto pc_false; pci_info(pdev, "IOMMU performance counters supported\n"); val = readl(iommu->mmio_base + MMIO_CNTR_CONF_OFFSET); iommu->max_banks = (u8) ((val >> 12) & 0x3f); iommu->max_counters = (u8) ((val >> 7) & 0xf); + +pc_false: + pci_err(pdev, "Unable to read/write to IOMMU perf counter.\n"); + amd_iommu_pc_present = false; + return; } static ssize_t amd_iommu_show_cap(struct device *dev, -- 2.20.1