On 23.12.2014 02:45, Christoph Hellwig wrote: > > static int __bio_copy_iov(struct bio *bio, const struct iov_iter *iter, > > + int to_iov) > > { > > + int i; > > struct bio_vec *bvec; > > struct iov_iter iov_iter = *iter; > > Why not pass the iov_iter by value?
Agreed. > > bio_for_each_segment_all(bvec, bio, i) { > > + ssize_t ret; > > + > > + if (to_iov == WRITE) > > + ret = copy_page_to_iter(bvec->bv_page, > > + bvec->bv_offset, > > + bvec->bv_len, > > + &iov_iter); > > + else > > + ret = copy_page_from_iter(bvec->bv_page, > > + bvec->bv_offset, > > + bvec->bv_len, > > + &iov_iter); > > + > > + if (!iov_iter_count(&iov_iter)) > > + break; > > > > + if (ret < bvec->bv_len) > > + return -EFAULT; > > } > > > > + return 0; > > Seems like this should be split into two functions for the read > and write cases? Agreed. I'll update it in the next round. Thanks, Dongsu -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/