1. 16 10月, 2007 1 次提交
  2. 13 10月, 2007 1 次提交
  3. 24 7月, 2007 1 次提交
  4. 18 7月, 2007 1 次提交
  5. 10 7月, 2007 1 次提交
  6. 30 4月, 2007 1 次提交
  7. 27 3月, 2007 1 次提交
  8. 12 2月, 2007 2 次提交
  9. 24 1月, 2007 1 次提交
    • L
      [PATCH] elevator: move clearing of unplug flag earlier · 95543179
      Linas Vepstas 提交于
      A flag was recently added to the elevator code to avoid
      performing an unplug when reuests are being re-queued.
      The goal of this flag was to avoid a deep recursion that
      can occur when re-queueing requests after a SCSI device/host
      reset.  See http://lkml.org/lkml/2006/5/17/254
      
      However, that fix added the flag near the bottom of a case
      statement, where an earlier break (in an if statement) could
      transport one out of the case, without setting the flag.
      This patch sets the flag earlier in the case statement.
      
      I re-discovered the deep recursion recently during testing;
      I was told that it was a known problem, and the fix to it was
      in the kernel I was testing. Indeed it was ... but it didn't
      fix the bug. With the patch below, I no longer see the bug.
      
      Signed-off by: Linas Vepstas <linas@austin.ibm.com>
      Signed-off-by: NJens Axboe <axboe@suse.de>
      Cc: Chris Wright <chrisw@sous-sol.org>
      Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
      95543179
  10. 22 12月, 2006 1 次提交
  11. 20 12月, 2006 1 次提交
    • J
      [PATCH] cfq-iosched: don't allow sync merges across queues · da775265
      Jens Axboe 提交于
      Currently we allow any merge, even if the io originates from different
      processes. This can cause really bad starvation and unfairness, if those
      ios happen to be synchronous (reads or direct writes).
      
      So add a allow_merge hook to the io scheduler ops, so an io scheduler can
      help decide whether a bio/process combination may be merged with an
      existing request.
      Signed-off-by: NJens Axboe <jens.axboe@oracle.com>
      da775265
  12. 01 12月, 2006 1 次提交
  13. 12 10月, 2006 2 次提交
  14. 01 10月, 2006 7 次提交
  15. 23 8月, 2006 1 次提交
  16. 01 7月, 2006 1 次提交
  17. 23 6月, 2006 1 次提交
  18. 09 6月, 2006 1 次提交
    • J
      [PATCH] elevator switching race · bc1c1169
      Jens Axboe 提交于
      There's a race between shutting down one io scheduler and firing up the
      next, in which a new io could enter and cause the io scheduler to be
      invoked with bad or NULL data.
      
      To fix this, we need to maintain the queue lock for a bit longer.
      Unfortunately we cannot do that, since the elevator init requires to be
      run without the lock held.  This isn't easily fixable, without also
      changing the mempool API.  So split the initialization into two parts,
      and alloc-init operation and an attach operation.  Then we can
      preallocate the io scheduler and related structures, and run the attach
      inside the lock after we detach the old one.
      
      This patch has survived 30 minutes of 1 second io scheduler switching
      with a very busy io load.
      Signed-off-by: NJens Axboe <axboe@suse.de>
      Signed-off-by: NLinus Torvalds <torvalds@osdl.org>
      bc1c1169
  19. 12 5月, 2006 1 次提交
    • J
      [BLOCK] limit request_fn recursion · dac07ec1
      Jens Axboe 提交于
      Don't recurse back into the driver even if the unplug threshold is met,
      when the driver asks for a requeue. This is both silly from a logical
      point of view (requeues typically happen due to driver/hardware
      shortage), and also dangerous since we could hit an endless request_fn
      -> requeue -> unplug -> request_fn loop and crash on stack overrun.
      
      Also limit blk_run_queue() to one level of recursion, similar to how
      blk_start_queue() works.
      
      This patch fixed a real problem with SLES10 and lpfc, and it could hit
      any SCSI lld that returns non-zero from it's ->queuecommand() handler.
      Signed-off-by: NJens Axboe <axboe@suse.de>
      Signed-off-by: NLinus Torvalds <torvalds@osdl.org>
      dac07ec1
  20. 20 4月, 2006 1 次提交
  21. 01 4月, 2006 1 次提交
    • O
      [PATCH] Don't pass boot parameters to argv_init[] · 9b41046c
      OGAWA Hirofumi 提交于
      The boot cmdline is parsed in parse_early_param() and
      parse_args(,unknown_bootoption).
      
      And __setup() is used in obsolete_checksetup().
      
      	start_kernel()
      		-> parse_args()
      			-> unknown_bootoption()
      				-> obsolete_checksetup()
      
      If __setup()'s callback (->setup_func()) returns 1 in
      obsolete_checksetup(), obsolete_checksetup() thinks a parameter was
      handled.
      
      If ->setup_func() returns 0, obsolete_checksetup() tries other
      ->setup_func().  If all ->setup_func() that matched a parameter returns 0,
      a parameter is seted to argv_init[].
      
      Then, when runing /sbin/init or init=app, argv_init[] is passed to the app.
      If the app doesn't ignore those arguments, it will warning and exit.
      
      This patch fixes a wrong usage of it, however fixes obvious one only.
      Signed-off-by: NOGAWA Hirofumi <hirofumi@mail.parknet.co.jp>
      Signed-off-by: NAndrew Morton <akpm@osdl.org>
      Signed-off-by: NLinus Torvalds <torvalds@osdl.org>
      9b41046c
  22. 25 3月, 2006 1 次提交
  23. 24 3月, 2006 1 次提交
  24. 19 3月, 2006 3 次提交
  25. 08 2月, 2006 1 次提交
  26. 06 2月, 2006 1 次提交
  27. 24 1月, 2006 2 次提交
    • N
      [BLOCK] elevator: allow default scheduler to potentially be modular · 248d5ca5
      Nate Diller 提交于
      Jens has decided that allowing the default scheduler to be a module is
      a bug, and should not be allowed under kconfig.  However, I find that
      scenario useful for debugging, and wish for the kernel to be able to
      handle this situation without OOPSing, if I enable such an option in
      the .config directly.  This patch dynamically checks for the presence
      of the compiled-in default, and falls back to no-op, emitting a
      suitable error message, when the default is not available
      
      Tested for a range of boot options on 2.6.16-rc1-mm2.
      Signed-off-by: NNate Diller <nate.diller@gmail.com>
      Signed-off-by: NJens Axboe <axboe@suse.de>
      248d5ca5
    • N
      [BLOCK] elevator: default choice selection · 5f003976
      Nate Diller 提交于
      My previous default iosched patch did a poor job dealing with the
      'elevator=' boot-time option.  The old behavior falls back to the
      compiled-in default if the requested one is not registered at boot
      time.  This patch dynamically evaluates which default
      to use, and emits a suitable error message when the requested scheduler
      is not available.  It also does the 'as' -> 'anticipatory' conversion
      before elevator registration, which along with a modified registration
      function, allows it to correctly indicate which default scheduler is
      in use.
      
      Tested for a range of boot options on 2.6.16-rc1-mm2.
      Signed-off-by: NNate Diller <nate.diller@gmail.com>
      Signed-off-by: NJens Axboe <axboe@suse.de>
      5f003976
  28. 17 1月, 2006 1 次提交
  29. 16 1月, 2006 1 次提交