소스 검색

new helper: iov_iter_bvec()

similar to iov_iter_kvec(), for ITER_BVEC ones

Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
Al Viro 10 년 전
부모
커밋
05afcb77eb
4개의 변경된 파일22개의 추가작업 그리고 15개의 파일을 삭제
  1. 2 5
      fs/splice.c
  2. 3 1
      include/linux/uio.h
  3. 15 2
      mm/iov_iter.c
  4. 2 7
      mm/page_io.c

+ 2 - 5
fs/splice.c

@@ -1006,11 +1006,8 @@ iter_file_splice_write(struct pipe_inode_info *pipe, struct file *out,
 		}
 		}
 
 
 		/* ... iov_iter */
 		/* ... iov_iter */
-		from.type = ITER_BVEC | WRITE;
-		from.bvec = array;
-		from.nr_segs = n;
-		from.count = sd.total_len - left;
-		from.iov_offset = 0;
+		iov_iter_bvec(&from, ITER_BVEC | WRITE, array, n,
+			      sd.total_len - left);
 
 
 		/* ... and iocb */
 		/* ... and iocb */
 		init_sync_kiocb(&kiocb, out);
 		init_sync_kiocb(&kiocb, out);

+ 3 - 1
include/linux/uio.h

@@ -88,7 +88,9 @@ size_t iov_iter_zero(size_t bytes, struct iov_iter *);
 unsigned long iov_iter_alignment(const struct iov_iter *i);
 unsigned long iov_iter_alignment(const struct iov_iter *i);
 void iov_iter_init(struct iov_iter *i, int direction, const struct iovec *iov,
 void iov_iter_init(struct iov_iter *i, int direction, const struct iovec *iov,
 			unsigned long nr_segs, size_t count);
 			unsigned long nr_segs, size_t count);
-void iov_iter_kvec(struct iov_iter *i, int direction, const struct kvec *iov,
+void iov_iter_kvec(struct iov_iter *i, int direction, const struct kvec *kvec,
+			unsigned long nr_segs, size_t count);
+void iov_iter_bvec(struct iov_iter *i, int direction, const struct bio_vec *bvec,
 			unsigned long nr_segs, size_t count);
 			unsigned long nr_segs, size_t count);
 ssize_t iov_iter_get_pages(struct iov_iter *i, struct page **pages,
 ssize_t iov_iter_get_pages(struct iov_iter *i, struct page **pages,
 			size_t maxsize, unsigned maxpages, size_t *start);
 			size_t maxsize, unsigned maxpages, size_t *start);

+ 15 - 2
mm/iov_iter.c

@@ -501,18 +501,31 @@ size_t iov_iter_single_seg_count(const struct iov_iter *i)
 EXPORT_SYMBOL(iov_iter_single_seg_count);
 EXPORT_SYMBOL(iov_iter_single_seg_count);
 
 
 void iov_iter_kvec(struct iov_iter *i, int direction,
 void iov_iter_kvec(struct iov_iter *i, int direction,
-			const struct kvec *iov, unsigned long nr_segs,
+			const struct kvec *kvec, unsigned long nr_segs,
 			size_t count)
 			size_t count)
 {
 {
 	BUG_ON(!(direction & ITER_KVEC));
 	BUG_ON(!(direction & ITER_KVEC));
 	i->type = direction;
 	i->type = direction;
-	i->kvec = (struct kvec *)iov;
+	i->kvec = kvec;
 	i->nr_segs = nr_segs;
 	i->nr_segs = nr_segs;
 	i->iov_offset = 0;
 	i->iov_offset = 0;
 	i->count = count;
 	i->count = count;
 }
 }
 EXPORT_SYMBOL(iov_iter_kvec);
 EXPORT_SYMBOL(iov_iter_kvec);
 
 
+void iov_iter_bvec(struct iov_iter *i, int direction,
+			const struct bio_vec *bvec, unsigned long nr_segs,
+			size_t count)
+{
+	BUG_ON(!(direction & ITER_BVEC));
+	i->type = direction;
+	i->bvec = bvec;
+	i->nr_segs = nr_segs;
+	i->iov_offset = 0;
+	i->count = count;
+}
+EXPORT_SYMBOL(iov_iter_bvec);
+
 unsigned long iov_iter_alignment(const struct iov_iter *i)
 unsigned long iov_iter_alignment(const struct iov_iter *i)
 {
 {
 	unsigned long res = 0;
 	unsigned long res = 0;

+ 2 - 7
mm/page_io.c

@@ -269,14 +269,9 @@ int __swap_writepage(struct page *page, struct writeback_control *wbc,
 			.bv_len  = PAGE_SIZE,
 			.bv_len  = PAGE_SIZE,
 			.bv_offset = 0
 			.bv_offset = 0
 		};
 		};
-		struct iov_iter from = {
-			.type = ITER_BVEC | WRITE,
-			.count = PAGE_SIZE,
-			.iov_offset = 0,
-			.nr_segs = 1,
-		};
-		from.bvec = &bv;	/* older gcc versions are broken */
+		struct iov_iter from;
 
 
+		iov_iter_bvec(&from, ITER_BVEC | WRITE, &bv, 1, PAGE_SIZE);
 		init_sync_kiocb(&kiocb, swap_file);
 		init_sync_kiocb(&kiocb, swap_file);
 		kiocb.ki_pos = page_file_offset(page);
 		kiocb.ki_pos = page_file_offset(page);
 		kiocb.ki_nbytes = PAGE_SIZE;
 		kiocb.ki_nbytes = PAGE_SIZE;