1. 24 Sep, 2011 11 commits
  2. 23 Sep, 2011 10 commits
  3. 22 Sep, 2011 10 commits
  4. 21 Sep, 2011 9 commits
    • Lutz Sammer's avatar
      [media] TT-budget S2-3200 cannot tune on HB13E DVBS2 transponder · 699cc196
      Lutz Sammer authored
      The FEC fix patch fixed locking on 11,681 Ghz, but not on 12,692 Ghz for
      me.
      Reviewed-by: default avatarManu Abraham <manu@linuxtv.org>
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@redhat.com>
      699cc196
    • tvboxspy's avatar
      [media] [2/2,ver,1.90] DM04/QQBOX Reduce USB buffer size · 810fda9b
      tvboxspy authored
      Reduced unused buffer size to 64.
      Signed-off-by: default avatarMalcolm Priestley <tvboxspy@gmail.com>
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@redhat.com>
      810fda9b
    • tvboxspy's avatar
      [media] [1/2,ver,1.89] DM04/QQBOX Interupt Urb and Timing changes · 95c21c41
      tvboxspy authored
      Reduce buffer size of Interupt urb to 128 bytes and polling
      interval to 8.
      
      The devices buffer appears to only handle a maxium of 40 bytes.
      If the buffer is full a slowing effect is noticed causing occasionnal
      dropped streaming packets.
      Signed-off-by: default avatarMalcolm Priestley <tvboxspy@gmail.com>
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@redhat.com>
      95c21c41
    • Yang Ruirui's avatar
      [media] v4l2: uvcvideo use after free bug fix · 69803ecf
      Yang Ruirui authored
      Unplugging uvc video camera trigger following oops:
      
      eeepc kernel: [ 1393.500719] usb 3-2: USB disconnect, device number 4
      eeepc kernel: [ 1393.504351] uvcvideo: Failed to resubmit video URB (-19).
      eeepc kernel: [ 1495.428853] BUG: unable to handle kernel paging request at 6b6b6bcb
      eeepc kernel: [ 1495.429017] IP: [<b0358d37>] dev_get_drvdata+0x17/0x20
      eeepc kernel: [ 1495.429017] *pde = 00000000
      eeepc kernel: [ 1495.429017] Oops: 0000 [#1] DEBUG_PAGEALLOC
      eeepc kernel: [ 1495.429017]
      eeepc kernel: [ 1495.429017] Pid: 3476, comm: cheese Not tainted 3.1.0-rc3-00270-g7a54f5e1-dirty #485 ASUSTeK Computer INC. 900/900
      eeepc kernel: [ 1495.429017] EIP: 0060:[<b0358d37>] EFLAGS: 00010202 CPU: 0
      eeepc kernel: [ 1495.429017] EIP is at dev_get_drvdata+0x17/0x20
      eeepc kernel: [ 1495.429017] EAX: 6b6b6b6b EBX: eb08d870 ECX: 00000000 EDX: eb08d930
      eeepc kernel: [ 1495.429017] ESI: eb08d870 EDI: eb08d870 EBP: d3249cac ESP: d3249cac
      eeepc kernel: [ 1495.429017]  DS: 007b ES: 007b FS: 0000 GS: 00e0 SS: 0068
      eeepc kernel: [ 1495.429017] Process cheese (pid: 3476, ti=d3248000 task=df46d870 task.ti=d3248000)
      eeepc kernel: [ 1495.429017] Stack:
      eeepc kernel: [ 1495.429017]  d3249cb8 b03e77a1 d307b840 d3249ccc b03e77d1 d307b840 eb08d870 eb08d830
      eeepc kernel: [ 1495.429017]  d3249ce4 b03ed3b7 00000246 d307b840 eb08d870 d3021b80 d3249cec b03ed565
      eeepc kernel: [ 1495.429017]  d3249cfc b03e044d e8323d10 b06e013c d3249d18 b0355fb9 fffffffe d3249d1c
      eeepc kernel: [ 1495.429017] Call Trace:
      eeepc kernel: [ 1495.429017]  [<b03e77a1>] v4l2_device_disconnect+0x11/0x30
      eeepc kernel: [ 1495.429017]  [<b03e77d1>] v4l2_device_unregister+0x11/0x50
      eeepc kernel: [ 1495.429017]  [<b03ed3b7>] uvc_delete+0x37/0x110
      eeepc kernel: [ 1495.429017]  [<b03ed565>] uvc_release+0x25/0x30
      eeepc kernel: [ 1495.429017]  [<b03e044d>] v4l2_device_release+0x9d/0xc0
      eeepc kernel: [ 1495.429017]  [<b0355fb9>] device_release+0x19/0x90
      eeepc kernel: [ 1495.429017]  [<b03adfdc>] ? usb_hcd_unlink_urb+0x7c/0x90
      eeepc kernel: [ 1495.429017]  [<b026b99c>] kobject_release+0x3c/0x90
      eeepc kernel: [ 1495.429017]  [<b026b960>] ? kobject_del+0x30/0x30
      eeepc kernel: [ 1495.429017]  [<b026ca4c>] kref_put+0x2c/0x60
      eeepc kernel: [ 1495.429017]  [<b026b88d>] kobject_put+0x1d/0x50
      eeepc kernel: [ 1495.429017]  [<b03b2385>] ? usb_autopm_put_interface+0x25/0x30
      eeepc kernel: [ 1495.429017]  [<b03f0e5d>] ? uvc_v4l2_release+0x5d/0xd0
      eeepc kernel: [ 1495.429017]  [<b0355d2f>] put_device+0xf/0x20
      eeepc kernel: [ 1495.429017]  [<b03dfa96>] v4l2_release+0x56/0x60
      eeepc kernel: [ 1495.429017]  [<b019c8dc>] fput+0xcc/0x220
      eeepc kernel: [ 1495.429017]  [<b01990f4>] filp_close+0x44/0x70
      eeepc kernel: [ 1495.429017]  [<b012b238>] put_files_struct+0x158/0x180
      eeepc kernel: [ 1495.429017]  [<b012b100>] ? put_files_struct+0x20/0x180
      eeepc kernel: [ 1495.429017]  [<b012b2a0>] exit_files+0x40/0x50
      eeepc kernel: [ 1495.429017]  [<b012b9e7>] do_exit+0x5a7/0x660
      eeepc kernel: [ 1495.429017]  [<b0135f72>] ? __dequeue_signal+0x12/0x120
      eeepc kernel: [ 1495.429017]  [<b055edf2>] ? _raw_spin_unlock_irq+0x22/0x30
      eeepc kernel: [ 1495.429017]  [<b012badc>] do_group_exit+0x3c/0xb0
      eeepc kernel: [ 1495.429017]  [<b015792b>] ? trace_hardirqs_on+0xb/0x10
      eeepc kernel: [ 1495.429017]  [<b013755f>] get_signal_to_deliver+0x18f/0x570
      eeepc kernel: [ 1495.429017]  [<b01020f7>] do_signal+0x47/0x9e0
      eeepc kernel: [ 1495.429017]  [<b055edf2>] ? _raw_spin_unlock_irq+0x22/0x30
      eeepc kernel: [ 1495.429017]  [<b015792b>] ? trace_hardirqs_on+0xb/0x10
      eeepc kernel: [ 1495.429017]  [<b0123300>] ? T.1034+0x30/0xc0
      eeepc kernel: [ 1495.429017]  [<b055c45f>] ? schedule+0x29f/0x640
      eeepc kernel: [ 1495.429017]  [<b0102ac8>] do_notify_resume+0x38/0x40
      eeepc kernel: [ 1495.429017]  [<b055f154>] work_notifysig+0x9/0x11
      eeepc kernel: [ 1495.429017] Code: e5 5d 83 f8 01 19 c0 f7 d0 83 e0 f0 c3 8d b4 26 00 00 00 00 55 85 c0 89 e5 75 09 31 c0 5d c3 90 8d 74 26 00 8b 40 04 85 c0 74 f0 <8b> 40 60 5d c3 8d 74 26 00 55 89 e5 53 89 c3 83 ec 04 8b 40 04
      eeepc kernel: [ 1495.429017] EIP: [<b0358d37>] dev_get_drvdata+0x17/0x20 SS:ESP 0068:d3249cac
      eeepc kernel: [ 1495.429017] CR2: 000000006b6b6bcb
      eeepc kernel: [ 1495.466975] uvcvideo: Failed to resubmit video URB (-27).
      eeepc kernel: [ 1495.467860] uvcvideo: Failed to resubmit video URB (-27).
      eeepc kernel: last message repeated 3 times
      eeepc kernel: [ 1495.512610] ---[ end trace 73ec16848794e5a5 ]---
      
      For uvc device, dev->vdev.dev is the &intf->dev,
      uvc_delete code is as below:
      	usb_put_intf(dev->intf);
      	usb_put_dev(dev->udev);
      
      	uvc_status_cleanup(dev);
      	uvc_ctrl_cleanup_device(dev);
      
      	if (dev->vdev.dev)
      		v4l2_device_unregister(&dev->vdev);
      
      Fix it by get_device in v4l2_device_register and put_device in v4l2_device_disconnect
      Reported-by: default avatarSitsofe Wheeler <sitsofe@yahoo.com>
      Signed-off-by: default avatarDave Young <hidave.darkstar@gmail.com>
      Tested-by: default avatarSitsofe Wheeler <sitsofe@yahoo.com>
      Acked-by: default avatarLaurent Pinchart <laurent.pinchart@ideasonboard.com>
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@redhat.com>
      69803ecf
    • Chris Rankin's avatar
      [media] em28xx: Fix em28xx_devused cleanup logic on error · 9da9f356
      Chris Rankin authored
      On 04/09/11 00:49, Mauro Carvalho Chehab wrote:
      > This is an automatic generated email to let you know that the following patch were queued at the
      > http://git.linuxtv.org/media_tree.git tree:
      >
      > Subject: [media] em28xx: use atomic bit operations for devices-in-use mask
      > Author:  Chris Rankin<rankincj@yahoo.com>
      > Date:    Sat Aug 20 08:21:03 2011 -0300
      >
      > Use atomic bit operations for the em28xx_devused mask, to prevent an
      > unlikely race condition should two adapters be plugged in
      > simultaneously. The operations also clearer than explicit bit
      > manipulation anyway.
      >
      > Signed-off-by: Chris Rankin<rankincj@yahoo.com>
      > Signed-off-by: Mauro Carvalho Chehab<mchehab@redhat.com>
      >
      >   drivers/media/video/em28xx/em28xx-cards.c |   33 ++++++++++++++---------------
      
      I think you missed this line in the merge.
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@redhat.com>
      9da9f356
    • Thierry Reding's avatar
      [media] tm6000: Enable fast USB quirk on Cinergy Hybrid · 6e896481
      Thierry Reding authored
      The Cinergy Hybrid cards are known not to need an artificial delay after
      USB accesses so the quirk can safely be enabled.
      Signed-off-by: default avatarThierry Reding <thierry.reding@avionic-design.de>
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@redhat.com>
      6e896481
    • Thierry Reding's avatar
      [media] tm6000: Add fast USB access quirk · 42845708
      Thierry Reding authored
      Some devices support fast access to registers using the USB interface
      while others require a certain delay after each operation. This commit
      adds a quirk that can be enabled by devices that don't need the delay.
      Signed-off-by: default avatarThierry Reding <thierry.reding@avionic-design.de>
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@redhat.com>
      42845708
    • Laurent Pinchart's avatar
      [media] mt9t001: Aptina (Micron) MT9T001 3MP sensor driver · 0a54b86a
      Laurent Pinchart authored
      The MT9T001 is a parallel 3MP sensor from Aptina (formerly Micron)
      controlled through I2C.
      
      The driver creates a V4L2 subdevice. It currently supports binning and
      cropping, and the gain, exposure, test pattern and black level controls.
      Signed-off-by: default avatarLaurent Pinchart <laurent.pinchart@ideasonboard.com>
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@redhat.com>
      0a54b86a
    • Laurent Pinchart's avatar
      [media] omap3isp: video: Avoid crashes when pipeline set stream operation fails · 5b6c3ef0
      Laurent Pinchart authored
      If streaming can't be enabled on the pipeline, the DMA buffers queue is
      not emptied. If the buffers then get freed the queue will end up
      referencing free memory. This is usually not an issue, as the DMA queue
      will be reinitialized the next time streaming is enabled, before
      enabling the hardware.
      
      However, if the sensor connected at the pipeline input is free-running,
      the CCDC will start generating interrupts as soon as it gets powered up,
      before the streaming gets enabled on the hardware. This will make the
      CCDC interrupt handler access freed memory, causing a crash.
      
      Reinitialize the DMA buffers queue in isp_video_streamon() if the error
      path to make sure this situation won't happen.
      Signed-off-by: default avatarLaurent Pinchart <laurent.pinchart@ideasonboard.com>
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@redhat.com>
      5b6c3ef0