Received: by 2002:ac0:950c:0:0:0:0:0 with SMTP id f12csp2298899imc; Tue, 12 Mar 2019 10:53:17 -0700 (PDT) X-Google-Smtp-Source: APXvYqwwl1wmUnb4g7pJlXnZr9Jl7drPzTlrMhcoLhVlVNMn5otAZxSdxcwKIUvuPkuJC/5xxvqL X-Received: by 2002:aa7:8019:: with SMTP id j25mr39728453pfi.82.1552413197357; Tue, 12 Mar 2019 10:53:17 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1552413197; cv=none; d=google.com; s=arc-20160816; b=x8Kj/i8HxqgTlOkmfxBjMwTkS1zHD052AINKkzCavHUMxTI0wCBD2XcRbppUvCE5nq DxOHvkcJVxC9GfF4zRokMRc67rdMTJpNp8kfRG/7d3UOl2LrpEii+9PYx1f7TFgG0F+N 1j5ySwE/U8Oagax/pBZGr2j3tVJNDlQf/bYkZm6h76XqGkS8SAQfd6x/3bc/Hxp/UtlO 8ZY/BODY0KoRPl4mIf/JFa/R8Os0qTolUB5JbFU/K7KGPh7ESS72uvg/eLWR6ueT89G/ ygLI4fXSy8k7ZueTzPLHYmg47OPJrHAho0swY45jUc11tiOAk2BNsUAsb/9jg/d8m8iZ LfwA== 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 :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=5Priyeo+X1A+g1T5qii+EkBiW9nTJVon1i6QxvIK34Y=; b=xrnuRXooy44stRhSYnswlNP1q02RTqIfRZAjMFeyB2OrHvk42393t/2oK/NYdlcsGo 24XgHlVlclELH/qTDV6Yt/LgzmMgrvs/moLhUSHSAUqxIPKCZWPZI8Bf92a5PRU4g1Fg 7Wun4i552Wz37nQxyA1gyOx2Fgc8p3Jhrqmx2HUqz9HffMKs2yhMdydckuMIqzHHlQLb R8PRgp9Z0PT+K3zJ2D31TViKWdtDIrVIKdHyI1m6Odel7DdQjeKiOa+qamxatcgd4/wF Lm2UR6T5Agx0OZidxY2OHJkV8ErWqSpRCkA2SqAynqu/bCA+9CGnGpupP8n/8j+XU8iX TD6w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=Wy8nzkH3; 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 o5si8354371pfi.22.2019.03.12.10.53.01; Tue, 12 Mar 2019 10:53:17 -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=@kernel.org header.s=default header.b=Wy8nzkH3; 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 S1728973AbfCLRux (ORCPT + 99 others); Tue, 12 Mar 2019 13:50:53 -0400 Received: from mail.kernel.org ([198.145.29.99]:53792 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728452AbfCLROl (ORCPT ); Tue, 12 Mar 2019 13:14:41 -0400 Received: from localhost (unknown [104.133.8.98]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 8536C2173C; Tue, 12 Mar 2019 17:14:40 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1552410880; bh=xMMf58w3cq9Kdg7wZEht9pbeRB9U6Hu79rqUj3nOp9A=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=Wy8nzkH3b2RMoH9Mk8kKen7dOKy8bfVLJcbYAfiTKprHmvwJHFuKLhhuji5+R9JVo Y7t6ppTHEsTCtFlIHuppH24lVk9qYVYTpM87uzusnoyQgt3InrdBOSw1k/y3mwAowe 92FsssO3HF9MynSqnQZJZr0BU45y5A+OH6YOotYc= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Evan Quan , Alex Deucher , Sasha Levin Subject: [PATCH 4.19 086/149] drm/radeon: check if device is root before getting pci speed caps Date: Tue, 12 Mar 2019 10:08:24 -0700 Message-Id: <20190312170356.950544269@linuxfoundation.org> X-Mailer: git-send-email 2.21.0 In-Reply-To: <20190312170349.421581206@linuxfoundation.org> References: <20190312170349.421581206@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review X-Patchwork-Hint: ignore 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 4.19-stable review patch. If anyone has any objections, please let me know. ------------------ [ Upstream commit afeff4c16edaa6275b903f82b0561406259aa3a3 ] Check if the device is root rather before attempting to see what speeds the pcie port supports. Fixes a crash with pci passthrough in a VM. Bug: https://bugs.freedesktop.org/show_bug.cgi?id=109366 Reviewed-by: Evan Quan Signed-off-by: Alex Deucher Signed-off-by: Sasha Levin --- drivers/gpu/drm/radeon/ci_dpm.c | 5 +++-- drivers/gpu/drm/radeon/si_dpm.c | 5 +++-- 2 files changed, 6 insertions(+), 4 deletions(-) diff --git a/drivers/gpu/drm/radeon/ci_dpm.c b/drivers/gpu/drm/radeon/ci_dpm.c index d587779a80b4..a97294ac96d5 100644 --- a/drivers/gpu/drm/radeon/ci_dpm.c +++ b/drivers/gpu/drm/radeon/ci_dpm.c @@ -5676,7 +5676,7 @@ int ci_dpm_init(struct radeon_device *rdev) u16 data_offset, size; u8 frev, crev; struct ci_power_info *pi; - enum pci_bus_speed speed_cap; + enum pci_bus_speed speed_cap = PCI_SPEED_UNKNOWN; struct pci_dev *root = rdev->pdev->bus->self; int ret; @@ -5685,7 +5685,8 @@ int ci_dpm_init(struct radeon_device *rdev) return -ENOMEM; rdev->pm.dpm.priv = pi; - speed_cap = pcie_get_speed_cap(root); + if (!pci_is_root_bus(rdev->pdev->bus)) + speed_cap = pcie_get_speed_cap(root); if (speed_cap == PCI_SPEED_UNKNOWN) { pi->sys_pcie_mask = 0; } else { diff --git a/drivers/gpu/drm/radeon/si_dpm.c b/drivers/gpu/drm/radeon/si_dpm.c index 8fb60b3af015..0a785ef0ab66 100644 --- a/drivers/gpu/drm/radeon/si_dpm.c +++ b/drivers/gpu/drm/radeon/si_dpm.c @@ -6899,7 +6899,7 @@ int si_dpm_init(struct radeon_device *rdev) struct ni_power_info *ni_pi; struct si_power_info *si_pi; struct atom_clock_dividers dividers; - enum pci_bus_speed speed_cap; + enum pci_bus_speed speed_cap = PCI_SPEED_UNKNOWN; struct pci_dev *root = rdev->pdev->bus->self; int ret; @@ -6911,7 +6911,8 @@ int si_dpm_init(struct radeon_device *rdev) eg_pi = &ni_pi->eg; pi = &eg_pi->rv7xx; - speed_cap = pcie_get_speed_cap(root); + if (!pci_is_root_bus(rdev->pdev->bus)) + speed_cap = pcie_get_speed_cap(root); if (speed_cap == PCI_SPEED_UNKNOWN) { si_pi->sys_pcie_mask = 0; } else { -- 2.19.1