Al Viro <[email protected]> wrote:

> > @@ -1060,6 +1074,9 @@ void iov_iter_revert(struct iov_iter *i, size_t 
> > unroll)
> >     }
> >     unroll -= i->iov_offset;
> >     switch (iov_iter_type(i)) {
> > +   case ITER_DISCARD:
> > +           i->iov_offset = 0;
> > +           return;
> 
> ... the hell?  That makes no sense whatsoever; what, besides this and 
> immediately
> preceding part of iov_iter_revert() so much as looks at ->iov_offset for 
> those?
> Just have it bugger off before the
>         if (unroll <= i->iov_offset) {
>                 i->iov_offset -= unroll;
>                 return;
>         }
> bit...

I didn't want to add another case before that if I could avoid it.  If
iov_offset > unroll, the discard iterator really doesn't care.  Maybe I should
just ignore iov_offset for the discard iterator.

David

Reply via email to