Regression in TTM driver w/Linus' master

Tobias Klausmann tobias.johannes.klausmann at mni.thm.de
Thu Nov 23 14:24:38 UTC 2017


On 11/23/17 2:58 AM, Dave Airlie wrote:
> On 23 November 2017 at 11:17, Laura Abbott <labbott at redhat.com> wrote:
>> Hi,
>>
>> Fedora QA testing reported a panic when booting up VMs
>> using qmeu vga drivers
>> (https://paste.fedoraproject.org/paste/498yRWTCJv2LKIrmj4EliQ)
>>
>> [   30.108507] ------------[ cut here ]------------
>> [   30.108920] kernel BUG at ./include/linux/gfp.h:408!
>> [   30.109356] invalid opcode: 0000 [#1] SMP
>> [   30.109700] Modules linked in: fuse nf_conntrack_netbios_ns
>> nf_conntrack_broadcast xt_CT ip6t_rpfilter ip6t_REJECT nf_reject_ipv6
>> xt_conntrack devlink ip_set nfnetlink ebtable_nat ebtable_broute bridge
>> ip6table_nat nf_conntrack_ipv6 nf_defrag_ipv6 nf_nat_ipv6 ip6table_mangle
>> ip6table_raw ip6table_security iptable_nat nf_conntrack_ipv4 nf_defrag_ipv4
>> nf_nat_ipv4 nf_nat nf_conntrack libcrc32c iptable_mangle iptable_raw
>> iptable_security ebtable_filter ebtables ip6table_filter ip6_tables
>> snd_hda_codec_generic kvm_intel kvm snd_hda_intel snd_hda_codec irqbypass
>> ppdev snd_hda_core snd_hwdep snd_seq snd_seq_device snd_pcm bochs_drm ttm
>> joydev drm_kms_helper virtio_balloon snd_timer snd parport_pc drm soundcore
>> parport i2c_piix4 nls_utf8 isofs squashfs zstd_decompress xxhash 8021q garp
>> mrp stp llc virtio_net
>> [   30.115605]  virtio_console virtio_scsi crct10dif_pclmul crc32_pclmul
>> crc32c_intel ghash_clmulni_intel serio_raw virtio_pci virtio_ring virtio
>> ata_generic pata_acpi qemu_fw_cfg sunrpc scsi_transport_iscsi loop
>> [   30.117425] CPU: 0 PID: 1347 Comm: gnome-shell Not tainted
>> 4.15.0-0.rc0.git6.1.fc28.x86_64 #1
>> [   30.118141] Hardware name: QEMU Standard PC (i440FX + PIIX, 1996), BIOS
>> 1.10.2-2.fc27 04/01/2014
>> [   30.118866] task: ffff923a77e03380 task.stack: ffffa78182228000
>> [   30.119366] RIP: 0010:__alloc_pages_nodemask+0x35e/0x430
>> [   30.119810] RSP: 0000:ffffa7818222bba8 EFLAGS: 00010202
>> [   30.120250] RAX: 0000000000000001 RBX: 00000000014382c6 RCX:
>> 0000000000000006
>> [   30.120840] RDX: 0000000000000000 RSI: 0000000000000009 RDI:
>> 0000000000000000
>> [   30.121443] RBP: ffff923a760d6000 R08: 0000000000000000 R09:
>> 0000000000000006
>> [   30.122039] R10: 0000000000000040 R11: 0000000000000300 R12:
>> ffff923a729273c0
>> [   30.122629] R13: 0000000000000000 R14: 0000000000000000 R15:
>> ffff923a7483d400
>> [   30.123223] FS:  00007fe48da7dac0(0000) GS:ffff923a7cc00000(0000)
>> knlGS:0000000000000000
>> [   30.123896] CS:  0010 DS: 0000 ES: 0000 CR0: 0000000080050033
>> [   30.124373] CR2: 00007fe457b73000 CR3: 0000000078313000 CR4:
>> 00000000000006f0
>> [   30.124968] Call Trace:
>> [   30.125186]  ttm_pool_populate+0x19b/0x400 [ttm]
>> [   30.125578]  ttm_bo_vm_fault+0x325/0x570 [ttm]
>> [   30.125964]  __do_fault+0x19/0x11e
>> [   30.126255]  __handle_mm_fault+0xcd3/0x1260
>> [   30.126609]  handle_mm_fault+0x14c/0x310
>> [   30.126947]  __do_page_fault+0x28c/0x530
>> [   30.127282]  do_page_fault+0x32/0x270
>> [   30.127593]  async_page_fault+0x22/0x30
>> [   30.127922] RIP: 0033:0x7fe48aae39a8
>> [   30.128225] RSP: 002b:00007ffc21c4d928 EFLAGS: 00010206
>> [   30.128664] RAX: 00007fe457b73000 RBX: 000055cd4c1041a0 RCX:
>> 00007fe457b73040
>> [   30.129259] RDX: 0000000000300000 RSI: 0000000000000000 RDI:
>> 00007fe457b73000
>> [   30.129855] RBP: 0000000000000300 R08: 000000000000000c R09:
>> 0000000100000000
>> [   30.130457] R10: 0000000000000001 R11: 0000000000000246 R12:
>> 000055cd4c1041a0
>> [   30.131054] R13: 000055cd4bdfe990 R14: 000055cd4c104110 R15:
>> 0000000000000400
>> [   30.131648] Code: 11 01 00 0f 84 a9 00 00 00 65 ff 0d 6d cc dd 44 e9 0f
>> ff ff ff 40 80 cd 80 e9 99 fe ff ff 48 89 c7 e8 e7 f6 01 00 e9 b7 fe ff ff
>> <0f> 0b 0f ff e9 40 fd ff ff 65 48 8b 04 25 80 d5 00 00 8b 40 4c
>> [   30.133245] RIP: __alloc_pages_nodemask+0x35e/0x430 RSP: ffffa7818222bba8
>> [   30.133836] ---[ end trace d4f1deb60784f40a ]---
>>
>> This is based off of Linus' master branch at
>> c8a0739b185d11d6e2ca7ad9f5835841d1cfc765
>> Configs are at
>> https://git.kernel.org/pub/scm/linux/kernel/git/jwboyer/fedora.git/commit/?h=rawhide&id=0be14662c54f49b4e640868b9d67df18d39edff0
>>
> Looks like a TTM regression due to:
>
> 0284f1ead87463bc17cf5e81a24fc65c052486f3
> drm/ttm: add transparent huge page support for cached allocations v2
>
> If the driver requests dma32 pages, we can end up trying to alloc huge
> dma32 pages which triggers the oops. The bochs driver always requests
> dma32 here.
>
> I'll send a rough patch once I boot it.
>
> Dave.


Hi Dave,

fyi only: It looks like this is not the only regression in this cycle 
with ttm, novueau seems to suffer as well [1].

Greetings,

Tobias


[1]:


[  404.918139] ------------[ cut here ]------------
[  404.918147] kernel BUG at mm/shmem.c:4334!
[  404.918152] invalid opcode: 0000 [#2] PREEMPT SMP
[  404.918157] Modules linked in: rfcomm af_packet bnep uvcvideo 
videobuf2_vmalloc videobuf2_memops rtsx_usb_ms videobuf2_v4l2 memstick 
videodev videobuf2_core btusb btrtl btbcm arc4 msr snd_hda_codec_hdmi 
snd_hda_codec_realtek snd_hda_codec_generic joydev nls_iso8859_1 
nls_cp437 hid_multitouch vfat fat iTCO_wdt iTCO_vendor_support 
intel_rapl x86_pkg_temp_thermal intel_powerclamp ath10k_pci coretemp 
ath10k_core ath kvm_intel mac80211 kvm irqbypass crct10dif_pclmul 
crc32_pclmul crc32c_intel ghash_clmulni_intel r8169 mii snd_hda_intel 
pcbc cfg80211 snd_hda_codec wmi_bmof snd_hda_core snd_hwdep acer_wmi 
sparse_keymap snd_pcm intel_wmi_thunderbolt aesni_intel snd_timer 
aes_x86_64 crypto_simd glue_helper cryptd snd soundcore idma64 pcspkr 
i2c_i801 mei_me shpchp intel_pch_thermal mei intel_lpss_pci ucsi_acpi
[  404.918239]  typec_ucsi thermal hci_uart serdev btqca tps6598x typec 
btintel tpm_crb ac bluetooth tpm_tis intel_lpss_acpi tpm_tis_core 
ecdh_generic battery pinctrl_sunrisepoint rfkill pinctrl_intel 
intel_lpss tpm acpi_pad hid_generic usbhid rtsx_usb_sdmmc mmc_core 
rtsx_usb nouveau mxm_wmi ttm serio_raw i915 i2c_algo_bit drm_kms_helper 
syscopyarea xhci_pci sysfillrect sysimgblt fb_sys_fops xhci_hcd drm 
usbcore i2c_hid wmi video button sg efivarfs
[  404.918289] CPU: 1 PID: 2739 Comm: Civ6 Tainted: G D          
4.14.0-desktop-rc0-debug+ #1
[  404.918295] Hardware name: Acer Aspire VN7-593G/Pluto_KLS, BIOS V1.06 
07/05/2017
[  404.918301] task: ffff9b3b49c7e280 task.stack: ffffb9a2035b4000
[  404.918308] RIP: 0010:shmem_read_mapping_page_gfp+0x4c/0x50
[  404.918313] RSP: 0018:ffffb9a2035b79c0 EFLAGS: 00010206
[  404.918317] RAX: ffff9b3b4dd17700 RBX: ffff9b3b759cb900 RCX: 
ffffe4f10ac8b2c0
[  404.918322] RDX: 00000000014200ca RSI: 0000000000000000 RDI: 
ffff9b3b4dd174e0
[  404.918327] RBP: ffffb9a2035b79c8 R08: 0000000000000000 R09: 
ffffffffffffffff
[  404.918332] R10: 0000000000000000 R11: 0000000000000000 R12: 
0000000000000000
[  404.918337] R13: ffff9b3b4dd17700 R14: ffff9b3b7253eb38 R15: 
ffff9b3b75341000
[  404.918343] FS:  00007fa952f69700(0000) GS:ffff9b3b7ec40000(0000) 
knlGS:0000000000000000
[  404.918348] CS:  0010 DS: 0000 ES: 0000 CR0: 0000000080050033
[  404.918353] CR2: 0000560940b5d000 CR3: 0000000193e94004 CR4: 
00000000003606e0
[  404.918358] Call Trace:
[  404.918365]  ttm_tt_swapout+0x156/0x280 [ttm]
[  404.918371]  ttm_bo_swapout+0x217/0x260 [ttm]
[  404.918379]  ttm_shrink+0xab/0xe0 [ttm]
[  404.918384]  ttm_mem_global_alloc_zone.constprop.6+0xd1/0x140 [ttm]
[  404.918391]  ttm_mem_global_alloc+0x11/0x20 [ttm]
[  404.918397]  ttm_bo_init_reserved+0x47/0x4f0 [ttm]
[  404.918403]  ttm_bo_init+0x29/0xa0 [ttm]
[  404.918430]  ? nouveau_bo_invalidate_caches+0x10/0x10 [nouveau]
[  404.918454]  nouveau_bo_new+0x3f5/0x550 [nouveau]
[  404.918474]  ? nouveau_bo_invalidate_caches+0x10/0x10 [nouveau]
[  404.918495]  nouveau_gem_new+0x48/0x100 [nouveau]
[  404.918514]  nouveau_gem_ioctl_new+0x45/0xc0 [nouveau]
[  404.918532]  ? nouveau_gem_new+0x100/0x100 [nouveau]
[  404.918543]  drm_ioctl_kernel+0x58/0xb0 [drm]
[  404.918551]  drm_ioctl+0x315/0x3d0 [drm]
[  404.918568]  ? nouveau_gem_new+0x100/0x100 [nouveau]
[  404.918576]  ? trace_hardirqs_on+0xd/0x10
[  404.918595]  nouveau_drm_ioctl+0x6d/0xb0 [nouveau]
[  404.918601]  do_vfs_ioctl+0x8e/0x660
[  404.918605]  ? __fget+0x102/0x1f0
[  404.918609]  SyS_ioctl+0x74/0x80
[  404.918615]  entry_SYSCALL_64_fastpath+0x23/0x9a
[  404.918619] RIP: 0033:0x7fa96396d2f7
[  404.918622] RSP: 002b:00007fa952f43728 EFLAGS: 00000246 ORIG_RAX: 
0000000000000010
[  404.918628] RAX: ffffffffffffffda RBX: 00007fa93cad59c0 RCX: 
00007fa96396d2f7
[  404.918633] RDX: 00007fa952f43780 RSI: 00000000c0306480 RDI: 
0000000000000022
[  404.918638] RBP: 0000000000100000 R08: 0000000000000000 R09: 
0000000000000000
[  404.918643] R10: 00007fa852fa0260 R11: 0000000000000246 R12: 
00007fa91c053370
[  404.918648] R13: 0000000000100000 R14: 00007fa93e579a70 R15: 
00007fa8530a1aa0
[  404.918656] Code: 8d 55 f8 6a 00 45 31 c9 b9 01 00 00 00 e8 6d f0 ff 
ff 85 c0 5a 59 74 04 48 98 c9 c3 48 8b 7d f8 e8 fa de fd ff 48 8b 45 f8 
c9 c3 <0f> 0b 66 90 55 48 89 e5 41 56 41 55 41 54 53 48 89 fb 48 83 ec
[  404.918698] RIP: shmem_read_mapping_page_gfp+0x4c/0x50 RSP: 
ffffb9a2035b79c0
[  404.918711] ---[ end trace 53b254d8157cf0e7 ]---






More information about the dri-devel mailing list