lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Date:   Tue, 19 Jun 2018 15:47:56 +0800
From:   Caicai <caizhaopeng@...pin.com>
To:     gustavo@...ovan.org
Cc:     maarten.lankhorst@...ux.intel.com, seanpaul@...omium.org,
        airlied@...ux.ie, dri-devel@...ts.freedesktop.org,
        linux-kernel@...r.kernel.org, Caicai <caizhaopeng@...pin.com>
Subject: [PATCH] drm: fix pci_dev root device is NULL without check.

    on my laptop with ATI Radeon R7 350 graphics card,I found root was NULL,we should check
    the device before get/set pcie speed cap mask. Here is my messages.
    [    8.996093] [drm] radeon kernel modesetting enabled.
    [    8.996093] [drm] initializing kernel modesetting (OLAND 0x1002:0x6610 0x174B:0xA00B).
    [    8.996093] [drm] register mmio base: 0x10000000
    [    8.996093] [drm] register mmio size: 262144
    [    9.121093] ATOM BIOS: C55001
    [    9.121093] [drm] GPU not posted. posting now...
    [    9.125000] radeon 0001:20:00.0: VRAM: 2048M 0x0000000000000000 - 0x000000007FFFFFFF (2048M used)
    [    9.125000] radeon 0001:20:00.0: GTT: 2048M 0x0000000080000000 - 0x00000000FFFFFFFF
    [    9.125000] [drm] Detected VRAM RAM=2048M, BAR=256M
    [    9.125000] [drm] RAM width 128bits DDR
    [    9.125000] [drm] radeon: 2048M of VRAM memory ready
    [    9.125000] [drm] radeon: 2048M of GTT memory ready.
    [    9.125000] [drm] Loading oland Microcode
    [    9.128906] [drm] Internal thermal controller with fan control
    [    9.128906] Unable to handle kernel paging request at virtual address 000000000000003c
    [    9.128906] CPU 3 systemd-udevd(148): Oops 0
    [    9.128906] pc = [<ffffffff80e63824>]  ra = [<fffffffc03faf914>]  ps = 0000    Not tainted
    [    9.128906] pc is at drm_pcie_get_speed_cap_mask+0x3c/0x12c
    [    9.128906] ra is at si_dpm_init+0x64/0x1398 [radeon]
    [    9.128906] v0 = ffffffffffffffea  t0 = fffffc07fcc3a400  t1 = 0000000000001106
    [    9.128906] t2 = 0000000000001166  t3 = 0000000000000000  t4 = fffffc018eafc000
    [    9.128906] t5 = ffffffffffffff80  t6 = 000000000000003f  t7 = fffffc07f6a90000
    [    9.128906] s0 = fffffc07f6a9390c  s1 = 0000000000000000  s2 = fffffc07f59119b0
    [    9.128906] s3 = 0000000000000001  s4 = fffffffffffffff4  s5 = fffffc07f5910000
    [    9.128906] s6 = 0000000000000000
    [    9.128906] a0 = fffffc07f706c800  a1 = fffffc07f6a9390c  a2 = fffffffffffffffc
    [    9.128906] a3 = ffffffff815fb510  a4 = ffffffff815fb4c8  a5 = 0000000000000000
    [    9.128906] t8 = 000000000000007f  t9 = ffffffff80d86c14  t10= 0000000000000001
    [    9.128906] t11= 00000000000003c0  pv = ffffffff80e637e8  at = 0000000000000000
    [    9.128906] gp = ffffffff815e9230  sp = fffffc07f6a93868
    [    9.128906] Disabling lock debugging due to kernel taint
    [    9.128906] Trace:
    [    9.128906] [<ffffffff80e61260>] drm_dev_register+0xb0/0x138
    [    9.128906] [<ffffffff80e64368>] drm_get_pci_dev+0x120/0x208
    [    9.128906] [<ffffffff80dcced4>] local_pci_probe+0x38/0x8c
    [    9.128906] [<ffffffff80dcdac0>] pci_device_probe+0x170/0x1d0
    [    9.128906] [<ffffffff80e9d654>] driver_probe_device+0x168/0x2fc
    [    9.128906] [<ffffffff80e9d87c>] __driver_attach+0x94/0xe8
    [    9.128906] [<ffffffff80e9acf4>] bus_for_each_dev+0x94/0xd4
    [    9.128906] [<ffffffff80e9d7e8>] __driver_attach+0x0/0xe8
    [    9.128906] [<ffffffff80e9ce98>] driver_attach+0x2c/0x40
    [    9.128906] [<ffffffff80e9c870>] bus_add_driver+0x140/0x2d4
    [    9.128906] [<ffffffff80e9e28c>] driver_register+0x100/0x180
    [    9.128906] [<ffffffff80dccda0>] __pci_register_driver+0x48/0x5c
    [    9.128906] [<ffffffff80e644cc>] drm_pci_init+0x7c/0x168
    [    9.128906] [<ffffffff809102fc>] do_one_initcall+0x188/0x25c
    [    9.128906] [<ffffffff809f5f00>] do_init_module+0x8c/0x2c8
    [    9.128906] [<ffffffff80a5b698>] kmem_cache_alloc+0x1f8/0x22c
    [    9.128906] [<ffffffff809f5eb4>] do_init_module+0x40/0x2c8
    [    9.128906] [<ffffffff809b36c8>] load_module+0x1ea8/0x263c
    [    9.128906] [<ffffffff809af9fc>] unknown_module_param_cb+0x0/0xc8
    [    9.128906] [<ffffffff809b40a4>] SYSC_finit_module+0x94/0xb4
    [    9.128906] [<ffffffff809aeb68>] module_notes_read+0x0/0x4c
    [    9.128906] [<ffffffff80911040>] entSys+0xa0/0xc0

    [    9.128906] Code: 8c300188  c020003b  8c210010  f85f1106  f87f1166  8d410038 <842a003c> 40220502
    [    9.128906] systemd-udevd[136]: worker [148] terminated by signal 11 (Segmentation fault)

Signed-off-by: Caicai <caizhaopeng@...pin.com>
---
 drivers/gpu/drm/drm_pci.c | 4 +++-
 1 file changed, 3 insertions(+), 1 deletion(-)

diff --git a/drivers/gpu/drm/drm_pci.c b/drivers/gpu/drm/drm_pci.c
index 4db9c515b74f..3d1cd760b79c 100644
--- a/drivers/gpu/drm/drm_pci.c
+++ b/drivers/gpu/drm/drm_pci.c
@@ -332,10 +332,12 @@ int drm_pcie_get_speed_cap_mask(struct drm_device *dev, u32 *mask)
 	u32 lnkcap, lnkcap2;
 
 	*mask = 0;
-	if (!dev->pdev)
+	if (!dev->pdev || !dev->pdev->bus)
 		return -EINVAL;
 
 	root = dev->pdev->bus->self;
+	if (!root)
+		return -EINVAL;
 
 	/* we've been informed via and serverworks don't make the cut */
 	if (root->vendor == PCI_VENDOR_ID_VIA ||
-- 
2.13.3



Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ