1. 29 Dec, 2017 22 commits
  2. 28 Dec, 2017 14 commits
    • Fengguang Wu's avatar
      media: fix semicolon.cocci warnings · 201b5673
      Fengguang Wu authored
      drivers/media/common/videobuf/videobuf2-core.c:2525:34-35: Unneeded semicolon
      
       Remove unneeded semicolon.
      
      Generated by: scripts/coccinelle/misc/semicolon.cocci
      
      Fixes: 03fbdb2f ("media: move videobuf2 to drivers/media/common")
      Signed-off-by: default avatarFengguang Wu <fengguang.wu@intel.com>
      201b5673
    • Mauro Carvalho Chehab's avatar
      media: don't include drivers/media/i2c at cflags · ada79555
      Mauro Carvalho Chehab authored
      Most of the I2C headers got moved a long time ago to
      include/media/i2c. Stop including them at the patch.
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@s-opensource.com>
      ada79555
    • Mauro Carvalho Chehab's avatar
      media: move dvb kAPI headers to include/media · fada1935
      Mauro Carvalho Chehab authored
      Except for DVB, all media kAPI headers are at include/media.
      
      Move the headers to it.
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@s-opensource.com>
      fada1935
    • Mauro Carvalho Chehab's avatar
      media: dvb-core: get rid of mmap reserved field · a114a585
      Mauro Carvalho Chehab authored
      The "reserved" field was a way, used at V4L2 API, to add new
      data to existing structs without breaking userspace. However,
      there are now clever ways of doing that, without needing to add
      an uneeded overhead. So, get rid of them.
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@s-opensource.com>
      a114a585
    • Mauro Carvalho Chehab's avatar
      media: dvb uAPI docs: document mmap-related ioctls · a1f18fdc
      Mauro Carvalho Chehab authored
      5 new ioctls were added to the DVB demux API, in order to
      handle memory maped I/O. Add documentation for them.
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@s-opensource.com>
      a1f18fdc
    • Mauro Carvalho Chehab's avatar
      media: dvb uAPI docs: document demux mmap/munmap syscalls · f8aaf487
      Mauro Carvalho Chehab authored
      With the new dmx mmap interface, those two syscalls are now
      handled by the subsystem. Document them.
      
      This patch is based on the V4L2 text for those ioctls.
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@s-opensource.com>
      f8aaf487
    • Mauro Carvalho Chehab's avatar
      media: move videobuf2 to drivers/media/common · 03fbdb2f
      Mauro Carvalho Chehab authored
      Now that VB2 is used by both V4L2 and DVB core, move it to
      the common part of the subsystem.
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@s-opensource.com>
      03fbdb2f
    • Mauro Carvalho Chehab's avatar
      media: dvb-core: make DVB mmap API optional · 4021053e
      Mauro Carvalho Chehab authored
      This API is still experimental. Make it optional, allowing to
      compile the code without it.
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@s-opensource.com>
      4021053e
    • Mauro Carvalho Chehab's avatar
      fs: compat_ioctl: add new DVB demux ioctls · 651d6666
      Mauro Carvalho Chehab authored
      Use trivial handling for the new DVB demux ioctls, as none
      of them passes a pointer inside their structures.
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@s-opensource.com>
      651d6666
    • Mauro Carvalho Chehab's avatar
      media: dvb_vb2: add SPDX headers · 7b361cf0
      Mauro Carvalho Chehab authored
      This code is released under GPL. Add the corresponding SPDX
      headers.
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@s-opensource.com>
      7b361cf0
    • Mauro Carvalho Chehab's avatar
      media: dvb_vb2: Use the sanitized value after processed by VB2 core · 19393a03
      Mauro Carvalho Chehab authored
      if the number of buffers requested by the user is too big, the
      VB core will truncate to a valid value.
      
      Use it, instead of what the user requested.
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@s-opensource.com>
      19393a03
    • Mauro Carvalho Chehab's avatar
      media: dvb_vb2: limit reqbufs size to a sane value · 2c06aa7c
      Mauro Carvalho Chehab authored
      It is not a good idea to let users to request a very high buffer
      size.
      
      So, add an upper limit.
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@s-opensource.com>
      2c06aa7c
    • 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
    • Satendra Singh Thakur's avatar
      media: videobuf2: Add new uAPI for DVB streaming I/O · 57868acc
      Satendra Singh Thakur authored
      Adds a new uAPI for DVB to use streaming I/O which is implemented
      based on videobuf2, using those new ioctls:
      
      - DMX_REQBUFS:  Request kernel to allocate buffers which count and size
      	        are dedicated by user.
      - DMX_QUERYBUF: Get the buffer information like a memory offset which
      		will mmap() and be shared with user-space.
      - DMX_EXPBUF:   Just for testing whether buffer-exporting success or not.
      - DMX_QBUF:     Pass the buffer to kernel-space.
      - DMX_DQBUF:    Get back the buffer which may contain TS data.
      
      Originally developed by: Junghak Sung <jh1009.sung@samsung.com>, as
      seen at:
      	https://patchwork.linuxtv.org/patch/31613/
      	https://patchwork.kernel.org/patch/7334301/
      
      The original patch was written before merging VB2-core functionalities
      upstream. When such series was added, several adjustments were made,
      fixing some issues with	V4L2, causing the original patch to be
      non-trivially rebased.
      
      After rebased, a few bugs in the patch were fixed. The patch was
      also enhanced it and polling functionality got added.
      
      The main changes over the original patch are:
      
      dvb_vb2_fill_buffer():
      	- Set the size of the outgoing buffer after while loop using
      	  vb2_set_plane_payload;
      
      	- Added NULL check for source buffer as per normal convention
      	  of demux driver, this is called twice, first time with valid
      	  buffer second time with NULL pointer, if its not handled,
      	  it will result in  crash
      
      	- Restricted spinlock for only list_* operations
      
      dvb_vb2_init():
      	- Restricted q->io_modes to only VB2_MMAP as its the only
      	  supported mode
      
      dvb_vb2_release():
      	- Replaced the && in if condiion with &, because otherwise
      	  it was always getting satisfied.
      
      dvb_vb2_stream_off():
      	- Added list_del code for enqueud buffers upon stream off
      
      dvb_vb2_poll():
      	- Added this new function in order to support polling
      
      dvb_demux_poll() and dvb_dvr_poll()
      	- dvb_vb2_poll() is now called from these functions
      
      - Ported this patch and latest videobuf2 to lower kernel versions and
        tested auto scan.
      Co-developed-by: default avatarJunghak Sung <jh1009.sung@samsung.com>
      
      [mchehab@s-opensource.com: checkpatch fixes]
      Signed-off-by: default avatarJunghak Sung <jh1009.sung@samsung.com>
      Signed-off-by: default avatarGeunyoung Kim <nenggun.kim@samsung.com>
      Acked-by: default avatarSeung-Woo Kim <sw0312.kim@samsung.com>
      Acked-by: default avatarInki Dae <inki.dae@samsung.com>
      Signed-off-by: default avatarSatendra Singh Thakur <satendra.t@samsung.com>
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@s-opensource.com>
      57868acc
  3. 22 Dec, 2017 1 commit
    • Mauro Carvalho Chehab's avatar
      Merge branch 'docs-next' of git://git.lwn.net/linux into patchwork · 9eb124fe
      Mauro Carvalho Chehab authored
      * 'docs-next' of git://git.lwn.net/linux: (888 commits)
        w1_netlink.h: add support for nested structs
        scripts: kernel-doc: apply filtering rules to warnings
        scripts: kernel-doc: improve nested logic to handle multiple identifiers
        scripts: kernel-doc: handle nested struct function arguments
        scripts: kernel-doc: print the declaration name on warnings
        scripts: kernel-doc: get rid of $nested parameter
        scripts: kernel-doc: parse next structs/unions
        scripts: kernel-doc: replace tabs by spaces
        scripts: kernel-doc: change default to ReST format
        scripts: kernel-doc: improve argument handling
        scripts: kernel-doc: get rid of unused output formats
        docs: get rid of kernel-doc-nano-HOWTO.txt
        docs: kernel-doc.rst: add documentation about man pages
        docs: kernel-doc.rst: improve typedef documentation
        docs: kernel-doc.rst: improve structs chapter
        docs: kernel-doc.rst: improve function documentation section
        docs: kernel-doc.rst: improve private members description
        docs: kernel-doc.rst: better describe kernel-doc arguments
        docs: fix process/submit-checklist.rst Sphinx warning
        docs: ftrace-uses.rst fix varios code-block directives
        ...
      9eb124fe
  4. 21 Dec, 2017 3 commits
    • Mauro Carvalho Chehab's avatar
      w1_netlink.h: add support for nested structs · aa931b44
      Mauro Carvalho Chehab authored
      Now that kernel-doc can hanle nested structs/unions, describe
      such fields at w1_netlink_message_types.
      Acked-by: default avatarEvgeniy Polyakov <zbr@ioremap.net>
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@s-opensource.com>
      Signed-off-by: default avatarJonathan Corbet <corbet@lwn.net>
      aa931b44
    • Mauro Carvalho Chehab's avatar
      scripts: kernel-doc: apply filtering rules to warnings · 2defb272
      Mauro Carvalho Chehab authored
      When kernel-doc is called with output selection filters,
      it will be called lots of time for a single file. If
      there is a warning present there, it means that it may
      print hundreds of identical warnings.
      
      Worse than that, the -function NAME actually filters only
      functions. So, it makes no sense at all to print warnings
      for structs or enums.
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@s-opensource.com>
      Signed-off-by: default avatarJonathan Corbet <corbet@lwn.net>
      2defb272
    • Mauro Carvalho Chehab's avatar
      scripts: kernel-doc: improve nested logic to handle multiple identifiers · 84ce5b98
      Mauro Carvalho Chehab authored
      It is possible to use nested structs like:
      
      struct {
      	struct {
      		void *arg1;
      	} st1, st2, *st3, st4;
      };
      
      Handling it requires to split each parameter. Change the logic
      to allow such definitions.
      
      In order to test the new nested logic, the following file
      was used to test
      
      <code>
      struct foo { int a; }; /* Just to avoid errors if compiled */
      
      /**
       * struct my_struct - a struct with nested unions and structs
       * @arg1: first argument of anonymous union/anonymous struct
       * @arg2: second argument of anonymous union/anonymous struct
       * @arg1b: first argument of anonymous union/anonymous struct
       * @arg2b: second argument of anonymous union/anonymous struct
       * @arg3: third argument of anonymous union/anonymous struct
       * @arg4: fourth argument of anonymous union/anonymous struct
       * @bar.st1.arg1: first argument of struct st1 on union bar
       * @bar.st1.arg2: second argument of struct st1 on union bar
       * @bar.st1.bar1: bar1 at st1
       * @bar.st1.bar2: bar2 at st1
       * @bar.st2.arg1: first argument of struct st2 on union bar
       * @bar.st2.arg2: second argument of struct st2 on union bar
       * @bar.st3.arg2: second argument of struct st3 on union bar
       * @f1: nested function on anonimous union/struct
       * @bar.st2.f2: nested function on named union/struct
       */
      struct my_struct {
         /* Anonymous union/struct*/
         union {
      	struct {
      	    char arg1 : 1;
      	    char arg2 : 3;
      	};
             struct {
                 int arg1b;
                 int arg2b;
             };
             struct {
                 void *arg3;
                 int arg4;
                 int (*f1)(char foo, int bar);
             };
         };
         union {
             struct {
                 int arg1;
                 int arg2;
      	   struct foo bar1, *bar2;
             } st1;           /* bar.st1 is undocumented, cause a warning */
             struct {
                 void *arg1;  /* bar.st3.arg1 is undocumented, cause a warning */
      	    int arg2;
                int (*f2)(char foo, int bar); /* bar.st3.fn2 is undocumented, cause a warning */
             } st2, st3, *st4;
             int (*f3)(char foo, int bar); /* f3 is undocumented, cause a warning */
         } bar;               /* bar is undocumented, cause a warning */
      
         /* private: */
         int undoc_privat;    /* is undocumented but private, no warning */
      
         /* public: */
         int undoc_public;    /* is undocumented, cause a warning */
      };
      </code>
      
      It produces the following warnings, as expected:
      
      test2.h:57: warning: Function parameter or member 'bar' not described in 'my_struct'
      test2.h:57: warning: Function parameter or member 'bar.st1' not described in 'my_struct'
      test2.h:57: warning: Function parameter or member 'bar.st2' not described in 'my_struct'
      test2.h:57: warning: Function parameter or member 'bar.st3' not described in 'my_struct'
      test2.h:57: warning: Function parameter or member 'bar.st3.arg1' not described in 'my_struct'
      test2.h:57: warning: Function parameter or member 'bar.st3.f2' not described in 'my_struct'
      test2.h:57: warning: Function parameter or member 'bar.st4' not described in 'my_struct'
      test2.h:57: warning: Function parameter or member 'bar.st4.arg1' not described in 'my_struct'
      test2.h:57: warning: Function parameter or member 'bar.st4.arg2' not described in 'my_struct'
      test2.h:57: warning: Function parameter or member 'bar.st4.f2' not described in 'my_struct'
      test2.h:57: warning: Function parameter or member 'bar.f3' not described in 'my_struct'
      test2.h:57: warning: Function parameter or member 'undoc_public' not described in 'my_struct'
      Suggested-by: default avatarMarkus Heiser <markus.heiser@darmarit.de>
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@s-opensource.com>
      Signed-off-by: default avatarJonathan Corbet <corbet@lwn.net>
      84ce5b98