1. 13 7月, 2010 1 次提交
  2. 19 6月, 2010 1 次提交
    • S
      ieee1394: remove unused variables · 5030c807
      Stefan Richter 提交于
      which caused gcc 4.6 to warn about
          variable 'XYZ' set but not used.
      
      sbp2.c, unit_characteristics:
      
      The underlying problem which was spotted here --- an incomplete
      implementation --- is already 50% fixed in drivers/firewire/sbp2.c which
      observes mgt_ORB_timeout but not yet ORB_size.
      
      raw1394.c, length_conflict; dv1394.c, ts_off:
      
      Impossible to tell why these variables are there.  We can safely remove
      them though because we don't need a compiler warning to realize that we
      are dealing with (at least stylistically) flawed code here.
      
      dv1394.c, packet_time:
      
      This was used in debug macro that is only compiled in with
      DV1394_DEBUG_LEVEL >= 2 defined at compile-time.  Just drop it since
      nobody debugs dv1394 anymore.  Avoids noise in regular kernel builds.
      
      dv1394.c, ohci; eth1394.c, priv:
      
      These variables clearly can go away.  Somebody wanted to use them but
      then didn't (or not anymore).
      
      Note, all of this code is considered to be at its end of life and is
      thus not really meant to receive janitorial updates anymore.  But if we
      can easily remove noisy warnings from kernel builds, we should.
      Reported-by: NJustin P. Mattock <justinmattock@gmail.com>
      Signed-off-by: NStefan Richter <stefanr@s5r6.in-berlin.de>
      5030c807
  3. 10 4月, 2010 1 次提交
    • S
      ieee1394: mark char device files as not seekable · 7cfe21aa
      Stefan Richter 提交于
      The
        - raw1394   (/dev/raw1394),
        - video1394 (/dev/video1394/*),
        - dv1394    (/dev/dv1394/*)
      character device file ABIs do not make any use of lseek(), pread(), or
      pwrite().  Therefore use nonseekable_open() and, redundantly, set
      file_operations.llseek to no_llseek to remove any doubt whether the BKL-
      grabbing default_llseek handler is used.
      
      Although all this is legacy code which should be left in peace until it
      is eventually removed (as it is superseded by firewire-core's
      <linux/firewire-cdev.h> ABI), this change seems still worth doing to
      further minimize the presence of BKL usage in the kernel.
      Signed-off-by: NStefan Richter <stefanr@s5r6.in-berlin.de>
      7cfe21aa
  4. 12 10月, 2009 1 次提交
  5. 12 9月, 2009 1 次提交
  6. 25 3月, 2009 3 次提交
  7. 05 1月, 2009 1 次提交
  8. 31 10月, 2008 1 次提交
    • S
      ieee1394: raw1394: fix possible deadlock in multithreaded clients · 638570b5
      Stefan Richter 提交于
      Regression in 2.6.28-rc1:  When I added the new state_mutex which
      prevents corruption of raw1394's internal state when accessed by
      multithreaded client applications, the following possible though
      highly unlikely deadlock slipped in:
      
      Thread A:                  Thread B:
       - acquire mmap_sem         - raw1394_write() or raw1394_ioctl()
       - raw1394_mmap()           - acquire state_mutex
       - acquire state_mutex      - copy_to/from_user(), possible page fault:
                                    acquire mmap_sem
      
      The simplest fix is to use mutex_trylock() instead of mutex_lock() in
      raw1394_mmap().  This changes the behavior under contention in a way
      which is visible to userspace clients.  However, since multithreaded
      access was entirely buggy before state_mutex was added and libraw1394's
      documentation advised application programmers to use a handle only in a
      single thread, this change in behaviour should not be an issue in
      practice at all.
      
      Since we have to use mutex_trylock() in raw1394_mmap() regardless
      whether /dev/raw1394 was opened with O_NONBLOCK or not, we now use
      mutex_trylock() unconditionally everywhere for state_mutex, just to have
      consistent behavior.
      Reported-by: NJohannes Weiner <hannes@saeurebad.de>
      Signed-off-by: NStefan Richter <stefanr@s5r6.in-berlin.de>
      638570b5
  9. 17 10月, 2008 1 次提交
  10. 16 10月, 2008 3 次提交
    • S
      ieee1394: raw1394: make write() thread-safe · f22e52b8
      Stefan Richter 提交于
      Application programs should use a libraw1394 handle only in a single
      thread.  The raw1394 driver was apparently relying on this, because it
      did nothing to protect its fi->state variable from corruption due to
      concurrent accesses.
      
      We now serialize the fi->state accesses.  This affects the write() path.
      We re-use the state_mutex which was introduced to protect fi->iso_state
      accesses in the ioctl() path.  These paths and accesses are independent
      of each other, hence separate mutexes could be used.  But I don't see
      much benefit in that.
      Signed-off-by: NStefan Richter <stefanr@s5r6.in-berlin.de>
      f22e52b8
    • S
      ieee1394: raw1394: narrow down the state_mutex protected region · ddfb908d
      Stefan Richter 提交于
      Refactor the ioctl dispatcher in order to move a fraction of it out of
      the section which is serialized by fi->state_mutex.  This is not so much
      about performance but more about self-documentation:  The mutex_lock()/
      mutex_unlock() calls are now closer to the data accesses which the mutex
      protects, i.e. to the iso_state switch.
      Signed-off-by: NStefan Richter <stefanr@s5r6.in-berlin.de>
      ddfb908d
    • S
      ieee1394: raw1394: replace BKL by local mutex, make ioctl() and mmap() thread-safe · 10963ea1
      Stefan Richter 提交于
      This removes the last usage of the Big Kernel Lock from the ieee1394
      stack, i.e. from raw1394's (unlocked_)ioctl and compat_ioctl.
      
      The ioctl()s don't need to take the BKL, but they need to be serialized
      per struct file *.  In particular, accesses to ->iso_state need to be
      serial.  We simply use a blocking mutex for this purpose because
      libraw1394 does not use O_NONBLOCK.  In practice, there is no lock
      contention anyway because most if not all libraw1394 clients use a
      libraw1394 handle only in a single thread.
      
      mmap() also accesses ->iso_state.  Until now this was unprotected
      against concurrent changes by ioctls.  Fix this bug while we are at it.
      Signed-off-by: NStefan Richter <stefanr@s5r6.in-berlin.de>
      10963ea1
  11. 22 7月, 2008 1 次提交
  12. 14 7月, 2008 1 次提交
  13. 26 4月, 2008 2 次提交
    • T
      ieee1394: silence defined but not used warning in non-modular builds · e3864970
      Tony Breeds 提交于
      Currently the kernel will issue the following warning:
      drivers/ieee1394/raw1394.c:2938: warning: 'raw1394_id_table' defined but not used
      Add #ifdef MODULE guards around the declaration.
      Signed-off-by: NTony Breeds <tony@bakeyournoodle.com>
      
      Ditto with dv1394_id_table and video1394_id_table.
      Signed-off-by: NStefan Richter <stefanr@s5r6.in-berlin.de>
      e3864970
    • P
      ieee1394: rawiso: requeue packet for transmission after skipped cycle · cc9429bc
      Pieter Palmers 提交于
      As it seems, some host controllers have issues that can cause them to
      skip cycles now and then when using large packets. I suspect that this
      is due to DMA not succeeding in time. If the transmit fifo can't contain
      more than one packet (big packets), the DMA should provide a new packet
      each cycle (125us). I am under the impression that my current PCI
      express test system can't guarantee this.
      
      In any case, the patch tries to provide a workaround as follows:
      The DMA program descriptors are modified such that when an error occurs,
      the DMA engine retries the descriptor the next cycle instead of
      stalling. This way no data is lost. The side effect of this is that
      packets are sent with one cycle delay. This however might not be that
      much of a problem for certain protocols (e.g. AM824). If they use
      padding packets for e.g. rate matching they can drop one of those to
      resync the streams.
      
      The amount of skips between two userspace wakeups is counted. This
      number is then propagated to userspace through the upper 16 bits of the
      'dropped' parameter. This allows unmodified userspace applications due
      to the following:
      1) libraw simply passes this dropped parameter to the user application
      2) the meaning of the dropped parameter is: if it's nonzero, something
      bad has happened. The actual value of the parameter at this moment does
      not have a specific meaning.
      
      A libraw client can then retrieve the number of skipped cycles and
      account for them if needed.
      Signed-off-by: NPieter Palmers <pieterp@joow.be>
      Signed-off-by: NStefan Richter <stefanr@s5r6.in-berlin.de>
      cc9429bc
  14. 18 4月, 2008 2 次提交
  15. 31 1月, 2008 1 次提交
  16. 27 7月, 2007 1 次提交
  17. 10 7月, 2007 7 次提交
  18. 28 5月, 2007 1 次提交
  19. 09 5月, 2007 1 次提交
  20. 30 4月, 2007 1 次提交
  21. 17 2月, 2007 1 次提交
  22. 13 2月, 2007 1 次提交
  23. 09 2月, 2007 1 次提交
  24. 08 12月, 2006 4 次提交
  25. 23 9月, 2006 1 次提交