• Mauro Carvalho Chehab's avatar
    media: dvb_vb2: fix a warning about streamoff logic · 7b6c96d5
    Mauro Carvalho Chehab authored
    The streamoff logic is causing those warnings:
    
     WARNING: CPU: 3 PID: 3382 at drivers/media/v4l2-core/videobuf2-core.c:1652 __vb2_queue_cancel+0x177/0x250 [videobuf2_core]
     Modules linked in: bnep fuse xt_CHECKSUM iptable_mangle tun ebtable_filter ebtables ip6table_filter ip6_tables xt_physdev br_netfilter bluetooth bridge rfkill ecdh_generic stp llc nf_log_ipv4 nf_log_common xt_LOG xt_conntrack ipt_MASQUERADE nf_nat_masquerade_ipv4 iptable_nat nf_conntrack_ipv4 nf_defrag_ipv4 nf_nat_ipv4 nf_nat nf_conntrack libcrc32c sunrpc vfat fat snd_hda_codec_hdmi rc_dib0700_nec i915 rc_pinnacle_pctv_hd em28xx_rc a8293 ts2020 m88ds3103 i2c_mux em28xx_dvb dib8000 dvb_usb_dib0700 dib0070 dib7000m dib0090 dvb_usb dvb_core uvcvideo snd_usb_audio videobuf2_v4l2 dib3000mc videobuf2_vmalloc videobuf2_memops dibx000_common videobuf2_core rc_core snd_usbmidi_lib snd_rawmidi em28xx tveeprom v4l2_common videodev media intel_rapl x86_pkg_temp_thermal intel_powerclamp coretemp snd_hda_intel
     kvm_intel snd_hda_codec kvm snd_hwdep snd_hda_core snd_seq irqbypass crct10dif_pclmul crc32_pclmul i2c_algo_bit ghash_clmulni_intel snd_seq_device drm_kms_helper snd_pcm intel_cstate intel_uncore snd_timer tpm_tis drm mei_wdt iTCO_wdt iTCO_vendor_support tpm_tis_core snd intel_rapl_perf mei_me mei tpm i2c_i801 soundcore lpc_ich video binfmt_misc hid_logitech_hidpp hid_logitech_dj e1000e crc32c_intel ptp pps_core analog gameport joydev
     CPU: 3 PID: 3382 Comm: lt-dvbv5-zap Not tainted 4.14.0+ #3
     Hardware name:                  /D53427RKE, BIOS RKPPT10H.86A.0048.2017.0506.1545 05/06/2017
     task: ffff94b93bbe1e40 task.stack: ffffb7a98320c000
     RIP: 0010:__vb2_queue_cancel+0x177/0x250 [videobuf2_core]
     RSP: 0018:ffffb7a98320fd40 EFLAGS: 00010202
     RAX: 0000000000000001 RBX: ffff94b92ff72428 RCX: 0000000000000000
     RDX: 0000000000000001 RSI: 0000000000000001 RDI: ffff94b92ff72428
     RBP: ffffb7a98320fd68 R08: ffff94b92ff725d8 R09: ffffb7a98320fcc8
     R10: ffff94b978003d98 R11: ffff94b92ff72428 R12: ffff94b92ff72428
     R13: 0000000000000282 R14: ffff94b92059ae20 R15: dead000000000100
     FS:  0000000000000000(0000) GS:ffff94b99e380000(0000) knlGS:0000000000000000
     CS:  0010 DS: 0000 ES: 0000 CR0: 0000000080050033
     CR2: 0000555953007d70 CR3: 000000012be09004 CR4: 00000000001606e0
     Call Trace:
      vb2_core_streamoff+0x28/0x90 [videobuf2_core]
      dvb_vb2_stream_off+0xd1/0x150 [dvb_core]
      dvb_dvr_release+0x114/0x120 [dvb_core]
      __fput+0xdf/0x1e0
      ____fput+0xe/0x10
      task_work_run+0x94/0xc0
      do_exit+0x2dc/0xba0
      do_group_exit+0x47/0xb0
      SyS_exit_group+0x14/0x20
      entry_SYSCALL_64_fastpath+0x1a/0xa5
     RIP: 0033:0x7f775e931ed8
     RSP: 002b:00007fff07019d68 EFLAGS: 00000246 ORIG_RAX: 00000000000000e7
     RAX: ffffffffffffffda RBX: 0000000001d02690 RCX: 00007f775e931ed8
     RDX: 0000000000000001 RSI: 000000000000003c RDI: 0000000000000001
     RBP: 00007fff0701a500 R08: 00000000000000e7 R09: ffffffffffffff70
     R10: 00007f775e854dd8 R11: 0000000000000246 R12: 0000000000000000
     R13: 00000000035fa000 R14: 000000000000000a R15: 000000000000000a
     Code: 00 00 04 74 1c 44 89 e8 49 83 c5 01 41 39 84 24 88 01 00 00 77 8a 5b 41 5c 41 5d 41 5e 41 5f 5d c3 48 89 df e8 bb fd ff ff eb da <0f> ff 41 8b b4 24 88 01 00 00 85 f6 74 34 bb 01 00 00 00 eb 10
    
    There are actually two issues here:
    
    1) list_del() should be called when changing the buffer state;
    
    2) The logic with marks the buffers as done is at the wrong place.
    Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@s-opensource.com>
    7b6c96d5
dvb_vb2.c 9.56 KB