• Zhenyu Wang's avatar
    drm/i915/gvt: Add mutual lock for ppgtt mm LRU list · 72aabfb8
    Zhenyu Wang authored
    This adds mutex to guard against update of global ppgtt mm LRU list.
    To resolve error found as below warning.
    
    [73130.012162] ------------[ cut here ]------------
    [73130.012168] list_add corruption. prev->next should be next (ffff995f970cca50), but was 0000000000000000. (prev=ffff995f0dc5bdf8).
    [73130.012181] WARNING: CPU: 3 PID: 82 at lib/list_debug.c:28 __list_add_valid+0x4d/0x70
    [73130.012183] Modules linked in: btrfs(E) xor(E) zstd_decompress(E) zstd_compress(E) raid6_pq(E) dm_mod(E) kvmgt(E) fuse(E) xt_addrtype(E) nft_compat(E) xt_conntrack(E) nf_nat(E) nf_conntrack(E) nf_defrag_ipv6(E) nf_defrag_ipv4(E) libcrc32c(E) br_netfilter(E) bridge(E) stp(E) llc(E) overlay(E) devlink(E) nf_tables(E) nfnetlink(E) loop(E) x86_pkg_temp_thermal(E) intel_powerclamp(E) coretemp(E) crct10dif_pclmul(E) crc32_pclmul(E) ghash_clmulni_intel(E) mei_me(E) aesni_intel(E) aes_x86_64(E) crypto_simd(E) cryptd(E) glue_helper(E) intel_cstate(E) intel_uncore(E) mei(E) intel_pch_thermal(E) intel_rapl_perf(E) pcspkr(E) iTCO_wdt(E) iTCO_vendor_support(E) idma64(E) sg(E) virt_dma(E) acpi_pad(E) evdev(E) binfmt_misc(E) ip_tables(E) x_tables(E) ipv6(E) autofs4(E) hid_generic(E) usbhid(E) hid(E) ext4(E) crc32c_generic(E) crc16(E) mbcache(E) jbd2(E) fscrypto(E) xhci_pci(E) sdhci_pci(E) cqhci(E) intel_lpss_pci(E) intel_lpss(E) crc32c_intel(E) xhci_hcd(E) sdhci(E) i2c_i801(E) e1000e(E) mmc_core(E)
    [73130.012218]  ptp(E) pps_core(E) usbcore(E) mfd_core(E) sd_mod(E) fan(E) thermal(E)
    [73130.012227] CPU: 3 PID: 82 Comm: gvt workload 0 Tainted: G        W   E     5.0.0-rc7-staging-190226+ #282
    [73130.012228] Hardware name:  /NUC6i5SYB, BIOS SYSKLi35.86A.0039.2016.0316.1747 03/16/2016
    [73130.012232] RIP: 0010:__list_add_valid+0x4d/0x70
    [73130.012234] Code: c3 48 89 d1 48 c7 c7 e0 82 91 bb 48 89 c2 e8 44 8a cc ff 0f 0b 31 c0 c3 48 89 c1 4c 89 c6 48 c7 c7 30 83 91 bb e8 2d 8a cc ff <0f> 0b 31 c0 c3 48 89 f2 4c 89 c1 48 89 fe 48 c7 c7 80 83 91 bb e8
    [73130.012236] RSP: 0018:ffffa4924107fdd0 EFLAGS: 00010286
    [73130.012238] RAX: 0000000000000000 RBX: ffff995d8a5ccf00 RCX: 0000000000000006
    [73130.012240] RDX: 0000000000000007 RSI: 0000000000000086 RDI: ffff995faad96680
    [73130.012241] RBP: 0000000000000000 R08: 0000000000213a28 R09: 0000000000000084
    [73130.012243] R10: 0000000000000000 R11: ffffa4924107fc70 R12: ffff995d8a5ccf78
    [73130.012245] R13: ffff995f970c8000 R14: ffff995f0dc5bdf8 R15: ffff995f970cca50
    [73130.012247] FS:  0000000000000000(0000) GS:ffff995faad80000(0000) knlGS:0000000000000000
    [73130.012249] CS:  0010 DS: 0000 ES: 0000 CR0: 0000000080050033
    [73130.012250] CR2: 00000222e1891000 CR3: 0000000116848002 CR4: 00000000003626e0
    [73130.012252] Call Trace:
    [73130.012258]  intel_vgpu_pin_mm+0x7a/0xa0
    [73130.012262]  workload_thread+0x683/0x12a0
    [73130.012266]  ? do_wait_intr_irq+0xb0/0xb0
    [73130.012269]  ? finish_wait+0x80/0x80
    [73130.012271]  ? intel_vgpu_clean_workloads+0x110/0x110
    [73130.012274]  kthread+0x116/0x130
    [73130.012276]  ? kthread_bind+0x30/0x30
    [73130.012280]  ret_from_fork+0x35/0x40
    [73130.012285] WARNING: CPU: 3 PID: 82 at lib/list_debug.c:28 __list_add_valid+0x4d/0x70
    [73130.012286] ---[ end trace 458a2e792eec21c0 ]---
    
    v2:
    - simplify lock handling
    Reviewed-by: default avatarXiong Zhang <xiong.y.zhang@intel.com>
    Cc: Xiong Zhang <xiong.y.zhang@intel.com>
    Signed-off-by: default avatarZhenyu Wang <zhenyuw@linux.intel.com>
    72aabfb8
gtt.c 72.5 KB