Michael Holzheu 03cadd36d5 [S390] tape390: Fix request queue handling in block driver
When setting a channel attached tape online under Linux 2.6.31, the

"vol_id" process from udev hangs in sync_page():
 2 sync_page+144 [0x1dfaac]
 3 __wait_on_bit_lock+194 [0x58c23e]
 4 __lock_page+116 [0x1df9dc]
 5 truncate_inode_pages_range+728 [0x1ed7cc]
 6 __blkdev_put+244 [0x25f738]
 7 __fput+300 [0x229c4c]
 8 filp_close+122 [0x225a3a]

The reason for that is an error in the request queue handling. It can
happen that we fetch a request, but do not process it further because
the number of queued requests exceeds TAPEBLOCK_MIN_REQUEUE.
To fix this, we should call blk_peek_request() instead of
blk_fetch_request() in the while condition and fetch the request in
the loop body afterwards.

This bug was introduced with the patch "block: implement and enforce
request peek/start/fetch" (9934c8c04561413609d2bc38c6b9f268cba774a4)

Signed-off-by: Michael Holzheu <holzheu@linux.vnet.ibm.com>
Signed-off-by: Martin Schwidefsky <schwidefsky@de.ibm.com>
2009-10-14 12:43:52 +02:00
..
2009-06-22 12:08:23 +02:00
2006-12-08 15:53:52 +01:00
2009-09-11 10:29:49 +02:00
2007-10-17 08:42:52 -07:00
2007-10-17 08:42:52 -07:00
2009-09-11 10:29:49 +02:00
2009-10-06 10:35:05 +02:00
2009-09-11 10:29:49 +02:00
2009-09-11 10:29:49 +02:00
2009-03-26 15:24:25 +01:00
2009-03-26 15:24:25 +01:00
2009-06-12 10:27:33 +02:00
2007-07-17 13:36:19 +02:00
2009-09-23 18:13:10 -07:00