1. 31 10月, 2017 2 次提交
  2. 05 10月, 2017 1 次提交
  3. 27 8月, 2017 1 次提交
  4. 26 8月, 2017 1 次提交
  5. 20 8月, 2017 3 次提交
  6. 09 8月, 2017 3 次提交
  7. 21 7月, 2017 1 次提交
  8. 06 6月, 2017 2 次提交
  9. 19 5月, 2017 1 次提交
    • M
      [media] media drivers: annotate fall-through · 06eeefe8
      Mauro Carvalho Chehab 提交于
      Avoid warnings like those:
      
      drivers/media/pci/ddbridge/ddbridge-core.c: In function 'dvb_input_detach':
      drivers/media/pci/ddbridge/ddbridge-core.c:787:6: warning: this statement may fall through [-Wimplicit-fallthrough=]
         if (input->fe) {
            ^
      drivers/media/pci/ddbridge/ddbridge-core.c:792:2: note: here
        case 4:
        ^~~~
      ...
      
      On several cases, it is just that gcc 7.1 is not capable of
      understanding the comment, but on other places, we need an
      annotation.
      Signed-off-by: NMauro Carvalho Chehab <mchehab@s-opensource.com>
      06eeefe8
  10. 19 4月, 2017 1 次提交
  11. 10 4月, 2017 3 次提交
  12. 03 3月, 2017 2 次提交
  13. 07 2月, 2017 2 次提交
  14. 30 1月, 2017 1 次提交
  15. 27 1月, 2017 1 次提交
    • S
      [media] media: Drop FSF's postal address from the source code files · bcb63314
      Sakari Ailus 提交于
      Drop the FSF's postal address from the source code files that typically
      contain mostly the license text. Of the 628 removed instances, 578 are
      outdated.
      
      The patch has been created with the following command without manual edits:
      
      git grep -l "675 Mass Ave\|59 Temple Place\|51 Franklin St" -- \
      	drivers/media/ include/media|while read i; do i=$i perl -e '
      open(F,"< $ENV{i}");
      $a=join("", <F>);
      $a =~ s/[ \t]*\*\n.*You should.*\n.*along with.*\n.*(\n.*USA.*$)?\n//m
      	&& $a =~ s/(^.*)Or, (point your browser to) /$1To obtain the license, $2\n$1/m;
      close(F);
      open(F, "> $ENV{i}");
      print F $a;
      close(F);'; done
      Signed-off-by: NSakari Ailus <sakari.ailus@linux.intel.com>
      bcb63314
  16. 21 10月, 2016 1 次提交
    • M
      [media] cx231xx: don't break long lines · ba1da97e
      Mauro Carvalho Chehab 提交于
      Due to the 80-cols restrictions, and latter due to checkpatch
      warnings, several strings were broken into multiple lines. This
      is not considered a good practice anymore, as it makes harder
      to grep for strings at the source code.
      
      As we're right now fixing other drivers due to KERN_CONT, we need
      to be able to identify what printk strings don't end with a "\n".
      It is a way easier to detect those if we don't break long lines.
      
      So, join those continuation lines.
      
      The patch was generated via the script below, and manually
      adjusted if needed.
      
      </script>
      use Text::Tabs;
      while (<>) {
      	if ($next ne "") {
      		$c=$_;
      		if ($c =~ /^\s+\"(.*)/) {
      			$c2=$1;
      			$next =~ s/\"\n$//;
      			$n = expand($next);
      			$funpos = index($n, '(');
      			$pos = index($c2, '",');
      			if ($funpos && $pos > 0) {
      				$s1 = substr $c2, 0, $pos + 2;
      				$s2 = ' ' x ($funpos + 1) . substr $c2, $pos + 2;
      				$s2 =~ s/^\s+//;
      
      				$s2 = ' ' x ($funpos + 1) . $s2 if ($s2 ne "");
      
      				print unexpand("$next$s1\n");
      				print unexpand("$s2\n") if ($s2 ne "");
      			} else {
      				print "$next$c2\n";
      			}
      			$next="";
      			next;
      		} else {
      			print $next;
      		}
      		$next="";
      	} else {
      		if (m/\"$/) {
      			if (!m/\\n\"$/) {
      				$next=$_;
      				next;
      			}
      		}
      	}
      	print $_;
      }
      </script>
      Signed-off-by: NMauro Carvalho Chehab <mchehab@s-opensource.com>
      ba1da97e
  17. 22 9月, 2016 2 次提交
  18. 20 9月, 2016 2 次提交
    • J
      [media] constify i2c_algorithm structures · 78f2c50b
      Julia Lawall 提交于
      These i2c_algorithm structures are only stored in the alg field of an
      i2c_adapter structure, which is declared as const.  This declare the
      structures as const as well.
      
      The semantic patch that makes this change is as follows:
      (http://coccinelle.lip6.fr/)
      
      // <smpl>
      @r disable optional_qualifier@
      identifier i;
      position p;
      @@
      static struct i2c_algorithm i@p = { ... };
      
      @ok@
      identifier r.i;
      struct i2c_adapter e;
      position p;
      @@
      e.alg = &i@p;
      
      @bad@
      position p != {r.p,ok.p};
      identifier r.i;
      @@
      i@p
      
      @depends on !bad disable optional_qualifier@
      identifier r.i;
      @@
      static
      +const
       struct i2c_algorithm i = { ... };
      // </smpl>
      Signed-off-by: NJulia Lawall <Julia.Lawall@lip6.fr>
      Signed-off-by: NHans Verkuil <hans.verkuil@cisco.com>
      Signed-off-by: NMauro Carvalho Chehab <mchehab@s-opensource.com>
      78f2c50b
    • J
      [media] usb: constify snd_pcm_ops structures · 22511cfa
      Julia Lawall 提交于
      Check for snd_pcm_ops structures that are only stored in the ops field of a
      snd_soc_platform_driver structure or passed as the third argument to
      snd_pcm_set_ops.  The corresponding field or parameter is declared const,
      so snd_pcm_ops structures that have this property can be declared as const
      also.
      
      The semantic patch that makes this change is as follows:
      (http://coccinelle.lip6.fr/)
      
      // <smpl>
      @r disable optional_qualifier@
      identifier i;
      position p;
      @@
      static struct snd_pcm_ops i@p = { ... };
      
      @ok1@
      identifier r.i;
      struct snd_soc_platform_driver e;
      position p;
      @@
      e.ops = &i@p;
      
      @ok2@
      identifier r.i;
      expression e1, e2;
      position p;
      @@
      snd_pcm_set_ops(e1, e2, &i@p)
      
      @bad@
      position p != {r.p,ok1.p,ok2.p};
      identifier r.i;
      struct snd_pcm_ops e;
      @@
      e@i@p
      
      @depends on !bad disable optional_qualifier@
      identifier r.i;
      @@
      static
      +const
       struct snd_pcm_ops i = { ... };
      // </smpl>
      Signed-off-by: NJulia Lawall <Julia.Lawall@lip6.fr>
      Signed-off-by: NHans Verkuil <hans.verkuil@cisco.com>
      Signed-off-by: NMauro Carvalho Chehab <mchehab@s-opensource.com>
      22511cfa
  19. 06 9月, 2016 7 次提交
    • M
      [media] cx231xx-cards: unregister IR earlier · 3c59bb47
      Mauro Carvalho Chehab 提交于
      Without this patch, a bug is issued when the module is removed:
      
      [ 1417.425863] cx231xx 1-3.1.4:1.1: Cx231xx dvb Extension removed
      [ 1417.571923] BUG: unable to handle kernel paging request at ffffffffc081a024
      [ 1417.571962] IP: [<ffffffff813da854>] string+0x24/0x80
      [ 1417.571987] PGD 1c09067 PUD 1c0b067 PMD 88e653067 PTE 0
      [ 1417.572013] Oops: 0000 [#1] SMP
      [ 1417.572026] Modules linked in: mb86a20s dvb_core cx231xx_alsa ir_kbd_i2c(-) tda18271 tea5767 tuner cx25840 cx231xx i2c_mux videobuf_vmalloc tveeprom cx2341x videobuf_core rc_core v4l2_common videodev media bnep usblp fuse xt_CHECKSUM iptable_mangle tun ebtable_filter ebtables ip6table_filter ip6_tables xt_physdev br_netfilter bridge 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 cpufreq_stats vfat fat snd_hda_codec_hdmi snd_hda_codec_realtek snd_hda_codec_generic intel_rapl x86_pkg_temp_thermal intel_powerclamp coretemp kvm_intel snd_hda_intel snd_hda_codec kvm snd_hda_core snd_hwdep snd_seq snd_seq_device snd_pcm irqbypass crct10dif_pclmul iTCO_wdt crc32_pclmul nfsd hci_uart iTCO_vendor_support
      [ 1417.572317]  snd_timer ghash_clmulni_intel btbcm intel_cstate btqca snd intel_uncore btintel intel_rapl_perf mei_me bluetooth mei shpchp soundcore pcspkr i2c_i801 auth_rpcgss wmi acpi_als kfifo_buf nfs_acl industrialio rfkill lockd pinctrl_sunrisepoint pinctrl_intel tpm_tis tpm intel_lpss_acpi intel_lpss acpi_pad grace sunrpc binfmt_misc hid_logitech_hidpp hid_logitech_dj 8021q garp stp llc mrp i915 i2c_algo_bit drm_kms_helper drm e1000e sdhci_pci sdhci mmc_core crc32c_intel ptp pps_core video i2c_hid fjes analog gameport joydev [last unloaded: rc_pixelview_002t]
      [ 1417.572487] CPU: 4 PID: 24493 Comm: rmmod Tainted: G        W       4.7.0+ #2
      [ 1417.572504] Hardware name:                  /NUC6i7KYB, BIOS KYSKLi70.86A.0041.2016.0817.1130 08/17/2016
      [ 1417.572526] task: ffff880894b81e80 ti: ffff880896bdc000 task.ti: ffff880896bdc000
      [ 1417.572544] RIP: 0010:[<ffffffff813da854>]  [<ffffffff813da854>] string+0x24/0x80
      [ 1417.572564] RSP: 0018:ffff880896bdfbe8  EFLAGS: 00010286
      [ 1417.572577] RAX: ffffffffc081a025 RBX: ffff8808935aa15c RCX: ffff0a00ffffff04
      [ 1417.572594] RDX: ffffffffc081a024 RSI: ffffffffffffffff RDI: ffff8808935aa15c
      [ 1417.572610] RBP: ffff880896bdfbe8 R08: fffffffffffffffe R09: ffff8808935aa91c
      [ 1417.572628] R10: ffffffffc07b85d6 R11: 0000000000000000 R12: ffff8808935aa91c
      [ 1417.572644] R13: 00000000000007c5 R14: ffffffffc07b85dd R15: ffffffffc07b85dd
      [ 1417.572662] FS:  00007f5a5392d700(0000) GS:ffff8808bed00000(0000) knlGS:0000000000000000
      [ 1417.572681] CS:  0010 DS: 0000 ES: 0000 CR0: 0000000080050033
      [ 1417.572705] CR2: ffffffffc081a024 CR3: 0000000897188000 CR4: 00000000003406e0
      [ 1417.572735] DR0: 0000000000000000 DR1: 0000000000000000 DR2: 0000000000000000
      [ 1417.572761] DR3: 0000000000000000 DR6: 00000000fffe0ff0 DR7: 0000000000000400
      [ 1417.572778] Stack:
      [ 1417.572785]  ffff880896bdfc48 ffffffff813dcf77 0000000000000005 ffff8808935aa157
      [ 1417.572806]  ffff880896bdfc58 ffff0a00ffffff04 000000009d27375e ffff8808935aa000
      [ 1417.572829]  0000000000000800 ffff880896182800 0000000000000000 ffff88089e898ae0
      [ 1417.572850] Call Trace:
      [ 1417.572860]  [<ffffffff813dcf77>] vsnprintf+0x2d7/0x500
      [ 1417.572873]  [<ffffffff813d3e12>] add_uevent_var+0x82/0x120
      [ 1417.572890]  [<ffffffffc07b534d>] rc_dev_uevent+0x2d/0x60 [rc_core]
      [ 1417.572907]  [<ffffffff81515969>] dev_uevent+0xd9/0x2d0
      [ 1417.572921]  [<ffffffff813d4309>] kobject_uevent_env+0x2d9/0x4f0
      [ 1417.572938]  [<ffffffff813d452b>] kobject_uevent+0xb/0x10
      [ 1417.572954]  [<ffffffff81513a3f>] device_del+0x18f/0x260
      [ 1417.572974]  [<ffffffff813d2db7>] ? kobject_put+0x27/0x50
      [ 1417.572998]  [<ffffffffc07b5e25>] rc_unregister_device+0x75/0xb0 [rc_core]
      [ 1417.573028]  [<ffffffffc07e6023>] ir_remove+0x23/0x30 [ir_kbd_i2c]
      [ 1417.573055]  [<ffffffff8162bf88>] i2c_device_remove+0x58/0xb0
      [ 1417.573078]  [<ffffffff81518191>] __device_release_driver+0xa1/0x160
      [ 1417.573102]  [<ffffffff81518de6>] driver_detach+0xa6/0xb0
      [ 1417.573122]  [<ffffffff81517b25>] bus_remove_driver+0x55/0xd0
      [ 1417.573146]  [<ffffffff815195bc>] driver_unregister+0x2c/0x50
      [ 1417.573168]  [<ffffffff8162cf62>] i2c_del_driver+0x22/0x50
      [ 1417.573194]  [<ffffffffc07e6ba4>] ir_kbd_driver_exit+0x10/0x46c [ir_kbd_i2c]
      [ 1417.573227]  [<ffffffff81126348>] SyS_delete_module+0x1b8/0x220
      [ 1417.573254]  [<ffffffff817debf2>] entry_SYSCALL_64_fastpath+0x1a/0xa4
      [ 1417.573279] Code: eb e9 76 ff ff ff 90 55 49 89 f1 48 89 ce 48 c1 fe 30 48 81 fa ff 0f 00 00 48 89 e5 4c 8d 46 ff 76 40 48 85 f6 74 4e 48 8d 42 01 <0f> b6 12 84 d2 74 43 49 01 c0 31 f6 eb 0c 48 83 c0 01 0f b6 50
      [ 1417.573437] RIP  [<ffffffff813da854>] string+0x24/0x80
      [ 1417.573455]  RSP <ffff880896bdfbe8>
      [ 1417.573465] CR2: ffffffffc081a024
      [ 1417.580053] ---[ end trace 4ca9e2eced326a62 ]---
      Signed-off-by: NMauro Carvalho Chehab <mchehab@s-opensource.com>
      3c59bb47
    • M
      [media] cx231xx: can't proceed if I2C bus register fails · 461af077
      Mauro Carvalho Chehab 提交于
      The driver should not ignore errors while registering the I2C
      bus, as this device can't even minimally work without the buses,
      as it uses those buses internally to talk with the several IP
      blocks inside the chip.
      
      Cc: stable@vger.kernel.org
      Signed-off-by: NMauro Carvalho Chehab <mchehab@s-opensource.com>
      461af077
    • M
      [media] cx231xx-i2c: handle errors with cx231xx_get_i2c_adap() · 4001dfb4
      Mauro Carvalho Chehab 提交于
      The cx231xx_get_i2c_adap() function should return the I2C
      adapter that will be used to talk with a device. It should never
      be NULL, as otherwise the driver will try to dereference a
      null pointer.
      
      We might instead fix the callers, but if this condition
      ever happens, it is really a driver bug, because i2c_port
      should always be a value from enum CX231XX_I2C_MASTER_PORT.
      
      Found when checking the code due to this bug:
      
      [   39.769021] BUG: unable to handle kernel NULL pointer dereference at 0000000000000002
      [   39.769105] IP: [<ffffffff81638393>] i2c_master_send+0x13/0x70
      Signed-off-by: NMauro Carvalho Chehab <mchehab@s-opensource.com>
      4001dfb4
    • M
      [media] cx231xx-core: fix GPIO comments · 7adc7998
      Mauro Carvalho Chehab 提交于
      The number of the cx231xx REQ for GPIO register set/get are wrong.
      They should follow what's there at cx231xx-pcb-cfg.h.
      
      Noticed while checking the cx231xx parser at the v4l-utils.
      Signed-off-by: NMauro Carvalho Chehab <mchehab@s-opensource.com>
      7adc7998
    • M
      [media] cx231xx: prints error code if can't switch TV mode · dc4af782
      Mauro Carvalho Chehab 提交于
      If something bad happens when switching between digital
      and analog mode, prints an error and outputs the returned code.
      Signed-off-by: NMauro Carvalho Chehab <mchehab@s-opensource.com>
      dc4af782
    • M
      [media] cx231xx: fix GPIOs for Pixelview SBTVD hybrid · 24b923f0
      Mauro Carvalho Chehab 提交于
      This device uses GPIOs: 28 to switch between analog and
      digital modes: on digital mode, it should be set to 1.
      
      The code that sets it on analog mode is OK, but it misses
      the logic that sets it on digital mode.
      
      Cc: stable@vger.kernel.org
      Signed-off-by: NMauro Carvalho Chehab <mchehab@s-opensource.com>
      24b923f0
    • M
      [media] cx231xx: don't return error on success · 1871d718
      Mauro Carvalho Chehab 提交于
      The cx231xx_set_agc_analog_digital_mux_select() callers
      expect it to return 0 or an error. Returning a positive value
      makes the first attempt to switch between analog/digital to fail.
      
      Cc: stable@vger.kernel.org
      Signed-off-by: NMauro Carvalho Chehab <mchehab@s-opensource.com>
      1871d718
  20. 31 8月, 2016 3 次提交