Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp3524975pxf; Mon, 15 Mar 2021 11:29:24 -0700 (PDT) X-Google-Smtp-Source: ABdhPJylX8d5beyjJ2+nNFNrrXG6J9LRxkX2Gkh+SQttAyxoWs9VvhI08TY0HQzwCJGtD0+a2W6v X-Received: by 2002:a17:906:8447:: with SMTP id e7mr25818263ejy.523.1615832964074; Mon, 15 Mar 2021 11:29:24 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1615832964; cv=none; d=google.com; s=arc-20160816; b=VySNFtwx+KUfofXfy5k+vXBU+vyNFrXxwQ6ypkcsNV3jr7qjErVISPNA+ZjtPptFrI zzQVM4HUllO68gW8bcM8IRzo18/g0JI+7E0JjjUvA2xlDNdwxQSwf8pnMJt6SloTJOd+ ykjRlbIV65ZArgJPewL+oRoEBVcod7jvw9AtRR8ZqeaB/6X0AVgZHsk9cl2AcuLaIWv4 azKhbOU8shTYPNkXT1mNfo9K2yKEHuOy5kkMoexCCwXxIip+8uAKTaHczFfvsZoHmngM oa57iUnHKCfzxxAo/CcHAKfpIlyIjP3ys44GYaQceMMx76muEJEQuxAmZYyGnreQzt6M vMAw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=7bChpBRcWl4ZwjgV6/BjZj8YyxhUXCzV7F8TSRK3jAo=; b=wGUO1pNy2aob3i2iUvPNFuRS9TJIY98mXV5K80YiNJmdhJ2E3ldymgprqIFOwV+CEC MDz2UzHDd4gTf4TdcXSUYW2CScxvZZ/cOF3tyBDfuUyxqucNax/NeQeIiJOPQqmt+hB7 EQRD3wgZ7lcjojZBCwpz5KDPnnE2SS8TYxsOvqPl2S5tSxd2OcpTfRisgPxlD1xV5sOh KGFVzm2mEQAOzCxzFM3DRZXV3f5KtickDLtkHQAxSMPhQo9KbH7x0mSlX0Rv5fw+8QR5 6/eCGnK+dU0WpMaIVvuI5MLzRKY9vO8NtoDCSxDVY2gYwfFl/wBM5ReG8QiNDAnB/AGm fuPQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=px7rFIwA; 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=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id e18si12411180edj.485.2021.03.15.11.28.57; Mon, 15 Mar 2021 11:29:24 -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; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=px7rFIwA; 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=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S240089AbhCOOd2 (ORCPT + 99 others); Mon, 15 Mar 2021 10:33:28 -0400 Received: from mail.kernel.org ([198.145.29.99]:35904 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231776AbhCOOAp (ORCPT ); Mon, 15 Mar 2021 10:00:45 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id A628B64EEC; Mon, 15 Mar 2021 14:00:15 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1615816817; bh=N/eHAXzvXyN+mREmoj93Pa8P0PQs52ow+Si4Lnh6rnQ=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=px7rFIwAz1dqdxb3WZoChCkvpSnvFlokJQ03mE/GTRf9Drah6m+P6d5Cnof9o9XSd JgwmpmkBj8bCKVv4/jksl/NakLNtGyUCq8hf9PRJakD9TPkkqv41tGVRPbtB7PGw3a 5Job7ZclAAXd0DLgDMiVU9CJTEFBo3tmArwGu9mw= From: gregkh@linuxfoundation.org To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Suravee Suthikulpanit , "Tj (Elloe Linux)" , Joerg Roedel , Sasha Levin Subject: [PATCH 5.11 142/306] iommu/amd: Fix performance counter initialization Date: Mon, 15 Mar 2021 14:53:25 +0100 Message-Id: <20210315135512.447963867@linuxfoundation.org> X-Mailer: git-send-email 2.30.2 In-Reply-To: <20210315135507.611436477@linuxfoundation.org> References: <20210315135507.611436477@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Greg Kroah-Hartman From: Suravee Suthikulpanit [ Upstream commit 6778ff5b21bd8e78c8bd547fd66437cf2657fd9b ] Certain AMD platforms enable power gating feature for IOMMU PMC, which prevents the IOMMU driver from updating the counter while trying to validate the PMC functionality in the init_iommu_perf_ctr(). This results in disabling PMC support and the following error message: "AMD-Vi: Unable to read/write to IOMMU perf counter" To workaround this issue, disable power gating temporarily by programming the counter source to non-zero value while validating the counter, and restore the prior state afterward. Signed-off-by: Suravee Suthikulpanit Tested-by: Tj (Elloe Linux) Link: https://lore.kernel.org/r/20210208122712.5048-1-suravee.suthikulpanit@amd.com Bugzilla: https://bugzilla.kernel.org/show_bug.cgi?id=201753 Signed-off-by: Joerg Roedel Signed-off-by: Sasha Levin --- drivers/iommu/amd/init.c | 45 ++++++++++++++++++++++++++++++---------- 1 file changed, 34 insertions(+), 11 deletions(-) diff --git a/drivers/iommu/amd/init.c b/drivers/iommu/amd/init.c index 83d8ab2aed9f..01da76dc1caa 100644 --- a/drivers/iommu/amd/init.c +++ b/drivers/iommu/amd/init.c @@ -12,6 +12,7 @@ #include #include #include +#include #include #include #include @@ -254,6 +255,8 @@ static enum iommu_init_state init_state = IOMMU_START_STATE; static int amd_iommu_enable_interrupts(void); static int __init iommu_go_to_state(enum iommu_init_state state); static void init_device_table_dma(void); +static int iommu_pc_get_set_reg(struct amd_iommu *iommu, u8 bank, u8 cntr, + u8 fxn, u64 *value, bool is_write); static bool amd_iommu_pre_enabled = true; @@ -1712,13 +1715,11 @@ static int __init init_iommu_all(struct acpi_table_header *table) return 0; } -static int iommu_pc_get_set_reg(struct amd_iommu *iommu, u8 bank, u8 cntr, - u8 fxn, u64 *value, bool is_write); - -static void init_iommu_perf_ctr(struct amd_iommu *iommu) +static void __init init_iommu_perf_ctr(struct amd_iommu *iommu) { + int retry; struct pci_dev *pdev = iommu->dev; - u64 val = 0xabcd, val2 = 0, save_reg = 0; + u64 val = 0xabcd, val2 = 0, save_reg, save_src; if (!iommu_feature(iommu, FEATURE_PC)) return; @@ -1726,17 +1727,39 @@ static void init_iommu_perf_ctr(struct amd_iommu *iommu) 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)) + if (iommu_pc_get_set_reg(iommu, 0, 0, 0, &save_reg, false) || + iommu_pc_get_set_reg(iommu, 0, 0, 8, &save_src, 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)) + /* + * Disable power gating by programing the performance counter + * source to 20 (i.e. counts the reads and writes from/to IOMMU + * Reserved Register [MMIO Offset 1FF8h] that are ignored.), + * which never get incremented during this init phase. + * (Note: The event is also deprecated.) + */ + val = 20; + if (iommu_pc_get_set_reg(iommu, 0, 0, 8, &val, true)) goto pc_false; + /* Check if the performance counters can be written to */ + val = 0xabcd; + for (retry = 5; retry; retry--) { + if (iommu_pc_get_set_reg(iommu, 0, 0, 0, &val, true) || + iommu_pc_get_set_reg(iommu, 0, 0, 0, &val2, false) || + val2) + break; + + /* Wait about 20 msec for power gating to disable and retry. */ + msleep(20); + } + /* restore */ - if (iommu_pc_get_set_reg(iommu, 0, 0, 0, &save_reg, true)) + if (iommu_pc_get_set_reg(iommu, 0, 0, 0, &save_reg, true) || + iommu_pc_get_set_reg(iommu, 0, 0, 8, &save_src, true)) + goto pc_false; + + if (val != val2) goto pc_false; pci_info(pdev, "IOMMU performance counters supported\n"); -- 2.30.1