]> git.karo-electronics.de Git - karo-tx-linux.git/commitdiff
kvm tools: Return correct values from disk IOV functions
authorSasha Levin <levinsasha928@gmail.com>
Sun, 15 May 2011 10:22:39 +0000 (13:22 +0300)
committerPekka Enberg <penberg@kernel.org>
Sun, 15 May 2011 10:52:18 +0000 (13:52 +0300)
Currently read/write IOV functions return an incorrect
value instead of the amount of bytes read/written.

This incorrect value may cause errors within the virtio layer.

Return correct amount of bytes read/written from _iov functions.

[ penberg@kernel.org: don't use 'inline' for out-of-line functions ]
Signed-off-by: Sasha Levin <levinsasha928@gmail.com>
Signed-off-by: Pekka Enberg <penberg@kernel.org>
tools/kvm/disk-image.c
tools/kvm/include/kvm/disk-image.h

index 1a704b3de9d6cdea9d46ef5a274cf56594da8372..4172b059c427a252343fb4ec72e4bff133c8db90 100644 (file)
@@ -172,3 +172,41 @@ void disk_image__close(struct disk_image *disk)
 
        free(disk);
 }
+
+/* Fill iov with disk data, starting from sector 'sector'. Return amount of bytes read. */
+ssize_t disk_image__read_sector_iov(struct disk_image *disk, u64 sector, const struct iovec *iov, int iovcount)
+{
+       u64 first_sector = sector;
+
+       if (disk->ops->read_sector_iov)
+               return disk->ops->read_sector_iov(disk, sector, iov, iovcount);
+
+       while (iovcount--) {
+               if (disk->ops->read_sector(disk, sector, iov->iov_base, iov->iov_len) < 0)
+                       return -1;
+
+               sector += iov->iov_len >> SECTOR_SHIFT;
+               iov++;
+       }
+
+       return (sector - first_sector) << SECTOR_SHIFT;
+}
+
+/* Write iov to disk, starting from sector 'sector'. Return amount of bytes written. */
+ssize_t disk_image__write_sector_iov(struct disk_image *disk, u64 sector, const struct iovec *iov, int iovcount)
+{
+       u64 first_sector = sector;
+
+       if (disk->ops->write_sector_iov)
+               return disk->ops->write_sector_iov(disk, sector, iov, iovcount);
+
+       while (iovcount--) {
+               if (disk->ops->write_sector(disk, sector, iov->iov_base, iov->iov_len) < 0)
+                       return -1;
+
+               sector += iov->iov_len >> SECTOR_SHIFT;
+               iov++;
+       }
+
+       return (sector - first_sector) << SECTOR_SHIFT;
+}
\ No newline at end of file
index 6cc94417ea2e117481e25f63500474f2fd8cb00d..cc83f38e38fae46bad04752eb637b09ff7672987 100644 (file)
@@ -42,37 +42,8 @@ static inline int disk_image__write_sector(struct disk_image *disk, u64 sector,
        return disk->ops->write_sector(disk, sector, src, src_len);
 }
 
-static inline ssize_t disk_image__read_sector_iov(struct disk_image *disk, u64 sector, const struct iovec *iov, int iovcount)
-{
-       if (disk->ops->read_sector_iov)
-               return disk->ops->read_sector_iov(disk, sector, iov, iovcount);
-
-       while (iovcount--) {
-               if (disk->ops->read_sector(disk, sector, iov->iov_base, iov->iov_len) < 0)
-                       return -1;
-
-               sector += iov->iov_len >> SECTOR_SHIFT;
-               iov++;
-       }
-
-       return sector << SECTOR_SHIFT;
-}
-
-static inline ssize_t disk_image__write_sector_iov(struct disk_image *disk, u64 sector, const struct iovec *iov, int iovcount)
-{
-       if (disk->ops->write_sector_iov)
-               return disk->ops->write_sector_iov(disk, sector, iov, iovcount);
-
-       while (iovcount--) {
-               if (disk->ops->write_sector(disk, sector, iov->iov_base, iov->iov_len) < 0)
-                       return -1;
-
-               sector += iov->iov_len >> SECTOR_SHIFT;
-               iov++;
-       }
-
-       return sector << SECTOR_SHIFT;
-}
+ssize_t disk_image__read_sector_iov(struct disk_image *disk, u64 sector, const struct iovec *iov, int iovcount);
+ssize_t disk_image__write_sector_iov(struct disk_image *disk, u64 sector, const struct iovec *iov, int iovcount);
 
 static inline int disk_image__flush(struct disk_image *disk)
 {