1. 14 3月, 2014 5 次提交
    • A
      cciss: Fallback to MSI rather than to INTx if MSI-X failed · 371ff93a
      Alexander Gordeev 提交于
      Currently the driver falls back to INTx mode when MSI-X
      initialization failed. This is a suboptimal behaviour
      for chips that also support MSI. This update changes that
      behaviour and falls back to MSI mode in case MSI-X mode
      initialization failed.
      Signed-off-by: NAlexander Gordeev <agordeev@redhat.com>
      Cc: Mike Miller <mike.miller@hp.com>
      Cc: iss_storagedev@hp.com
      Cc: Jens Axboe <axboe@kernel.dk>
      Cc: linux-pci@vger.kernel.org
      Signed-off-by: NJens Axboe <axboe@fb.com>
      371ff93a
    • A
      swim3: fix interruptible_sleep_on race · 106fd892
      Arnd Bergmann 提交于
      interruptible_sleep_on is racy and going away. This replaces the one
      caller in the swim3 driver with the equivalent race-free
      wait_event_interruptible call. Since we're here already, this
      also fixes the case where we get interrupted from atomic context,
      which used to just spin in the loop.
      Signed-off-by: NArnd Bergmann <arnd@arndb.de>
      Cc: Jens Axboe <axboe@kernel.dk>
      Signed-off-by: NJens Axboe <axboe@fb.com>
      106fd892
    • A
      ataflop: fix sleep_on races · 7b8a3d22
      Arnd Bergmann 提交于
      sleep_on() is inherently racy, and has been deprecated for a long time.
      This fixes two instances in the atari floppy driver:
      
      * fdc_wait/fdc_busy becomes an open-coded mutex. We cannot use the
        regular mutex since it gets released in interrupt context. The
        open-coded version using wait_event() and cmpxchg() is equivalent
        to the existing code but does the checks atomically, and we can
        now safely check the condition with irqs enabled.
      
      * format_wait becomes a completion, which is the natural structure
        here. The format ioctl waits for the background task to either
        complete or abort.
      
      This does not attempt to fix the preexisting bug of calling schedule
      with local interrupts disabled.
      Signed-off-by: NArnd Bergmann <arnd@arndb.de>
      Cc: Jens Axboe <axboe@kernel.dk>
      Cc: Geert Uytterhoeven <geert@linux-m68k.org>
      Cc: Michael Schmitz <schmitz@biophys.uni-duesseldorf.de>
      Signed-off-by: NJens Axboe <axboe@fb.com>
      7b8a3d22
    • A
      DAC960: remove sleep_on usage · 9c552e1d
      Arnd Bergmann 提交于
      sleep_on and its variants are going away. The use of sleep_on() in
      DAC960_V2_ExecuteUserCommand seems to be bogus because the command
      by the time we get there, the command has completed already and
      we just enter the timeout. Based on this interpretation, I concluded
      that we can replace it with a simple msleep(1000) and rearrange the
      code around it slightly.
      
      The interruptible_sleep_on_timeout in DAC960_gam_ioctl seems equivalent
      to the race-free version using wait_event_interruptible_timeout.
      I left the driver to return -EINTR rather than -ERESTARTSYS to preserve
      the timeout behavior.
      Signed-off-by: NArnd Bergmann <arnd@arndb.de>
      Cc: Jens Axboe <axboe@kernel.dk>
      Signed-off-by: NJens Axboe <axboe@fb.com>
      9c552e1d
    • A
      mtip32xx: Use pci_enable_msi() instead of pci_enable_msi_range() · c94efe36
      Alexander Gordeev 提交于
      Commit "mtip32xx: Use pci_enable_msix_range() instead of
      pci_enable_msix()" was unnecessary, since pci_enable_msi()
      function is not deprecated and is still preferable for
      enabling the single MSI mode. This update reverts usage of
      pci_enable_msi() function.
      
      Besides, the changelog for that commit was bogus, since
      mtip32xx driver uses MSI interrupt, not MSI-X.
      
      Cc: Jens Axboe <axboe@kernel.dk>
      Cc: Asai Thambi S P <asamymuthupa@micron.com>
      Cc: linux-pci@vger.kernel.org
      Signed-off-by: NJens Axboe <axboe@fb.com>
      c94efe36
  2. 22 2月, 2014 7 次提交
  3. 17 2月, 2014 28 次提交