[linux-lvm] __ll_rw_block(): more generalized q->make_request_fn()
Heinz Mauelshagen
mauelsha at ez-darmstadt.telekom.de
Fri Feb 18 07:12:29 UTC 2000
Hi Linus and Ingo,
heading for a more generalized make_request_fn()/generic_make_request()
calling convention in __ll_rw_block(), which helps us to avoid to implement
stacking support in each volume driver (like MD, LVM and POOL), i propose
the following changes to 2.3.46 ll_rw_blk.c.
Ingo: can MD deal with that as well?
Linus: comments?
--- linux-2.3.46.orig/drivers/block/ll_rw_blk.c Thu Feb 17 23:10:39 2000
+++ linux-2.3.46/drivers/block/ll_rw_blk.c Fri Feb 18 01:13:20 2000
@@ -1029,14 +1031,16 @@
}
set_bit(BH_Req, &bh[i]->b_state);
- if (q->make_request_fn)
+ /* loop thru all make request functions until we don't
+ hit a volume driver any longer */
+ q = blk_get_queue(bh[i]->b_dev);
+ bh[i]->b_rdev = bh[i]->b_dev;
+ bh[i]->b_rsector = bh[i]->b_blocknr*(bh[i]->b_size>>9);
+ while ( q->make_request_fn) {
q->make_request_fn(rw, bh[i]);
- else {
- bh[i]->b_rdev = bh[i]->b_dev;
- bh[i]->b_rsector = bh[i]->b_blocknr*(bh[i]->b_size>>9);
-
- generic_make_request(rw, bh[i]);
- }
+ q = blk_get_queue(bh[i]->b_rdev);
+ }
+ generic_make_request(rw, bh[i]);
}
return;
BTW: I have deleted cosmetic changes i needed to avoid compile stoppers in
other places i made.
Heinz
--
=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-
Systemmanagement CS-TS T-Nova
Entwicklungszentrum Darmstadt
Heinz Mauelshagen Otto-Roehm-Strasse 71c
Senior Systems Engineer Postfach 10 05 41
64205 Darmstadt
mge at EZ-Darmstadt.Telekom.de Germany
+49 6151 886-425
FAX-386
=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-
More information about the linux-lvm
mailing list