Probably not. There are all sorts of issues about when to go to the next
bio (bi_next) and when just to grab the next bvec by increasing bi_idx.
It can be pretty hairy for a driver to do.
> > I would suggest also moving DAC960 to the
> > pci dma api (this is a must) and then move it to use the generic block
> > helpers for mapping requests. That way there isn't a lot of nasty
> > duplication there as well, plus it will automatically get the multi-page
> > issues right.
>
> My first concern is to get something working any way I can so that I can
> start doing regression testing. True/false: the bad old way of doing dma
I think that's a really bad idea. Yes it's a lot of work to do the pci
dma conversion (but it's not _hard_), but you'll get the rest for free
once that is done. Really. If you do it your way, then you'll just fix
up the old driver only to rewrite the dma handling (and then convert to
the block helpers) later on. Twice the work. Did I sell the idea or
what?
> will still work, it's just deprecated? If true, then I should (trivially)
> switch back to the old way of doing things, get the rest working, then
> convert to the dma api. Maybe *you* could make all the changes at the same
> time and expect to end up with something that works, but I can't.
See above :)
> The alternative is to go back many kernel versions and find the first one
> that broke something, but I don't want to do that because too much else was
> broken at the time.
Well, you'll go back to 2.5.1-preX and find that the breaking point is
when the bio stuff got merged. And you'll find that the DAC960 driver is
about the same as it is now. So that will buy you nothing, I'm afraid.
> > Hmm, is DAC960 using a full major per controller?!
>
> As you saw, it implements the top level block interface instead of being a
> scsi device as it should be. So for disk subsystems we have: 1) IDE 2) SCSI
> 3) DAC960. Eep. At some point it's all going to be SCSI, right?
Nah not really, at some point it will just be the 'disk' sub system.
BTW, you also forgot at least cpqarray and cciss :-)
-- Jens Axboe- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/