1. 06 1月, 2012 2 次提交
    • H
      [media] pwc: Rework locking · c20d78cd
      Hans de Goede 提交于
      While testing gtk-v4l's new ctrl event code, I hit the following deadlock
      in the pwc driver:
      
      Thread 1:
      -Does a VIDIOC_G_CTRL
      -video2_ioctl takes the modlock
      -video2_ioctl calls v4l2_g_ctrl
      -v4l2_g_ctrl takes the ctrl_handler lock
      -v4l2_g_ctrl calls pwc_g_volatile_ctrl
      -pwc_g_volatile_ctrl releases the modlock as the usb transfer can take a
       significant amount of time and we don't want to block DQBUF / QBUF too long
      Thread 2:
      -Does a VIDIOC_FOO_CTRL
      -video2_ioctl takes the modlock
      -video2_ioctl calls v4l2_foo_ctrl
      -v4l2_foo_ctrl blocks while trying to take the ctrl_handler lock
      Thread 1:
      -Blocks while trying to re-take the modlock, as its caller will eventually
       unlock that
      
      Now we have thread 1 waiting for the modlock while holding the ctrl_handler
      lock and thread 2 waiting for the ctrl_handler lock while holding the
      modlock -> deadlock.
      
      Conclusion:
      1) We cannot unlock modlock from pwc_s_ctrl / pwc_g_volatile_ctrl,
         but this can cause QBUF / DQBUF to block for up to a full second
      2) After evaluating various option I came to the conclusion that pwc should
         stop using the v4l2 core locking, and instead do its own locking
      
      Thus this patch stops pwc using the v4l2 core locking, and replaces that with
      it doing its own locking where necessary.
      Signed-off-by: NHans de Goede <hdegoede@redhat.com>
      Signed-off-by: NMauro Carvalho Chehab <mchehab@redhat.com>
      c20d78cd
    • H
      [media] pwc: Make auto white balance speed and delay available as v4l2 controls · f4af6595
      Hans de Goede 提交于
      Currently auto white balance speed and delay are only available through custom
      ioctls, which are deprecated and will be going away in 3.3 .
      Signed-off-by: NHans de Goede <hdegoede@redhat.com>
      Signed-off-by: NMauro Carvalho Chehab <mchehab@redhat.com>
      f4af6595
  2. 25 11月, 2011 1 次提交
  3. 28 7月, 2011 6 次提交
  4. 22 6月, 2011 1 次提交
    • H
      [media] pwc: better usb disconnect handling · 9a7b2d1f
      Hans de Goede 提交于
      Unplugging a pwc cam while an app has the /dev/video# node open leads
      to an oops in pwc_video_close when the app closes the node, because
      the disconnect handler has free-ed the pdev struct pwc_video_close
      tries to use. Instead of adding some sort of bandaid for this.
      fix it properly using the v4l2 core's new(ish) behavior of keeping the
      v4l2_dev structure around until both unregister has been called, and
      all file handles referring  to it have been closed:
      
      Embed the v4l2_dev structure in the pdev structure and define a v4l2 dev
      release callback releasing the pdev structure (and thus also the embedded
      v4l2 dev structure.
      Signed-off-by: NHans de Goede <hdegoede@redhat.com>
      Cc: stable@kernel.org
      Signed-off-by: NMauro Carvalho Chehab <mchehab@redhat.com>
      9a7b2d1f
  5. 29 12月, 2010 1 次提交
  6. 21 10月, 2010 1 次提交
  7. 19 2月, 2010 1 次提交
  8. 24 4月, 2009 1 次提交
  9. 03 1月, 2009 1 次提交
  10. 12 10月, 2008 1 次提交
  11. 04 9月, 2008 1 次提交
  12. 20 7月, 2008 1 次提交
  13. 10 10月, 2007 1 次提交
  14. 28 4月, 2007 1 次提交
  15. 25 6月, 2006 3 次提交
  16. 25 3月, 2006 2 次提交
  17. 21 3月, 2006 1 次提交
  18. 01 2月, 2006 1 次提交
  19. 05 1月, 2006 1 次提交
  20. 29 5月, 2005 1 次提交
  21. 27 5月, 2005 1 次提交
    • A
      [PATCH] remove non-cleanroom pwc driver compression · 88c18346
      Alan Cox 提交于
      The original pwc author raised some questions about the reverse
      engineering of the decompressor algorithms used in the pwc driver.
      Having done some detailed investigation it appears those concerns that
      clean room policy was not followed are reasonable.  I've also had a
      friendly discussion with Philips to ask their view on this.
      
      This removes the problem items of code which reduces the pwc
      functionality in the kernel a little but leaves all the framework for
      setup that will be needed for decompressors in user space (where they
      eventually belong).  This change set is designed to be the minimal risk
      change set given that 2.6.12 is hopefully close to hand, with a view to
      merging the much updated pwc code in 2.6.13 series kernels.
      
      Someone else can then redo the decompressors properly (clean room) in
      user space.
      
      Note that while its easy to say that it should have been caught earlier,
      but the violation was really only obvious to someone who had access to
      both the proprietary source and the 'GPL' source.
      88c18346
  22. 04 5月, 2005 1 次提交
    • S
      [PATCH] USB: Spelling fixes for drivers/usb. · 093cf723
      Steven Cole 提交于
      Here are some spelling corrections for drivers/usb.
      
      cancelation -> cancellation
      succesful -> successful
      cancelation -> cancellation
      decriptor -> descriptor
      Initalize -> Initialize
      wierd -> weird
      Protocoll -> Protocol
      occured -> occurred
      successfull -> successful
      Procesing -> Processing
      devide -> divide
      Isochronuous -> Isochronous
      noticable -> noticeable
      Basicly -> Basically
      transfering -> transferring
      intialize -> initialize
      Incomming -> Incoming
      additionnal -> additional
      asume -> assume
      Unfortunatly -> Unfortunately
      retreive -> retrieve
      tranceiver -> transceiver
      Compatiblity -> Compatibility
      Incorprated -> Incorporated
      existance -> existence
      Ununsual -> Unusual
      Signed-off-by: NSteven Cole <elenstev@mesatop.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@suse.de>
      093cf723
  23. 23 4月, 2005 1 次提交
  24. 17 4月, 2005 1 次提交
    • L
      Linux-2.6.12-rc2 · 1da177e4
      Linus Torvalds 提交于
      Initial git repository build. I'm not bothering with the full history,
      even though we have it. We can create a separate "historical" git
      archive of that later if we want to, and in the meantime it's about
      3.2GB when imported into git - space that would just make the early
      git days unnecessarily complicated, when we don't have a lot of good
      infrastructure for it.
      
      Let it rip!
      1da177e4