On Thu, Apr 30, 2009 at 04:19:29PM +0900, Tejun Heo wrote: > Borislav Petkov wrote: > >> Fancy words aside, it basically boils down to allowing llds to do > >> either "rq->resid_len = blk_rq_bytes() - xferred" on completion or > >> "rq->resid_len = blk_rq_bytes()" on issue and "rq->resid_len -= > >> increments" while processing. > > > > Actually, the second one sounds more natural: resid_len == data_len on > > issue and decrementing while travelling through block layer and LLDD, > > while resid_len == 0 in issue might get confused somewhere. > > Yeap, it depends on how the specific low level driver is doing it. > > > And I like it too, we've been coming up with all sorts of hacks in > > ide-atapi wrt to residual completion and accounting of what got xferred > > already and rq->resid_len is much more cleaner, IMHO. > > > > /me testing... > > AFAICT, residual count handling in ide was most broken. Tell me about it :). > This patch doesn't fix anything other than making it report 0 > resid_len on SG_IO which is usually better than reporting full > residual count. The only place inside ide where residual count is used > in the tape driver to determine actually transferred size. That part > works okay with the patch applied. > Hmmm... maybe it's about time to finally clean up residual count > handling in ide and libata, which BTW doesn't do anything about it at > the moment. Completely agreed. This doesn't do anything about it right now but with rq->resid_len in place I could get rid of a bunch of pc->xferred, cmd->nleft and similar on-stack structs we've been introducing, and use solely an rq in the LLD. I'll get to do some experimenting tomorrow and whip up some cleanup patches in order to see how it could look exactly. Stay tuned. Thanks. -- Regards/Gruss, Boris. -- To unsubscribe from this list: send the line "unsubscribe linux-scsi" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html