RE: [PATCH] drm/radeon: check if device is root before getting pci speed caps

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Reviewed-by: Evan Quan <evan.quan@xxxxxxx>

> -----Original Message-----
> From: amd-gfx <amd-gfx-bounces@xxxxxxxxxxxxxxxxxxxxx> On Behalf Of Alex
> Deucher
> Sent: 2019年1月22日 2:59
> To: amd-gfx list <amd-gfx@xxxxxxxxxxxxxxxxxxxxx>
> Cc: Deucher, Alexander <Alexander.Deucher@xxxxxxx>
> Subject: Re: [PATCH] drm/radeon: check if device is root before getting pci
> speed caps
> 
> Ping?
> 
> On Thu, Jan 17, 2019 at 2:44 PM Alex Deucher <alexdeucher@xxxxxxxxx>
> wrote:
> >
> > 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
> > Signed-off-by: Alex Deucher <alexander.deucher@xxxxxxx>
> > ---
> >  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.20.1
> >
> _______________________________________________
> amd-gfx mailing list
> amd-gfx@xxxxxxxxxxxxxxxxxxxxx
> https://lists.freedesktop.org/mailman/listinfo/amd-gfx
_______________________________________________
amd-gfx mailing list
amd-gfx@xxxxxxxxxxxxxxxxxxxxx
https://lists.freedesktop.org/mailman/listinfo/amd-gfx




[Index of Archives]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux