qemu-devel
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[Qemu-devel] [4377] Revert 4367


From: Blue Swirl
Subject: [Qemu-devel] [4377] Revert 4367
Date: Wed, 07 May 2008 15:26:23 +0000

Revision: 4377
          http://svn.sv.gnu.org/viewvc/?view=rev&root=qemu&revision=4377
Author:   blueswir1
Date:     2008-05-07 15:26:22 +0000 (Wed, 07 May 2008)

Log Message:
-----------
Revert 4367

Modified Paths:
--------------
    trunk/block-raw-posix.c

Modified: trunk/block-raw-posix.c
===================================================================
--- trunk/block-raw-posix.c     2008-05-07 15:24:53 UTC (rev 4376)
+++ trunk/block-raw-posix.c     2008-05-07 15:26:22 UTC (rev 4377)
@@ -77,10 +77,10 @@
 typedef struct BDRVRawState {
     int fd;
     int type;
-    int open_flags;
     unsigned int lseek_err_cnt;
 #if defined(__linux__)
     /* linux floppy specific */
+    int fd_open_flags;
     int64_t fd_open_time;
     int64_t fd_error_time;
     int fd_got_error;
@@ -111,7 +111,6 @@
         open_flags |= O_DIRECT;
 #endif
 
-    s->open_flags = open_flags;
     s->type = FTYPE_FILE;
 
     fd = open(filename, open_flags, 0644);
@@ -142,14 +141,7 @@
 #endif
 */
 
-/* 
- * offset and count are in bytes, but must be multiples of 512 for files 
- * opened with O_DIRECT. buf must be aligned to 512 bytes then.
- *
- * This function may be called without alignment if the caller ensures
- * that O_DIRECT is not in effect.
- */
-static int raw_pread_aligned(BlockDriverState *bs, int64_t offset,
+static int raw_pread(BlockDriverState *bs, int64_t offset,
                      uint8_t *buf, int count)
 {
     BDRVRawState *s = bs->opaque;
@@ -202,14 +194,7 @@
     return ret;
 }
 
-/* 
- * offset and count are in bytes, but must be multiples of 512 for files 
- * opened with O_DIRECT. buf must be aligned to 512 bytes then.
- *
- * This function may be called without alignment if the caller ensures
- * that O_DIRECT is not in effect.
- */
-static int raw_pwrite_aligned(BlockDriverState *bs, int64_t offset,
+static int raw_pwrite(BlockDriverState *bs, int64_t offset,
                       const uint8_t *buf, int count)
 {
     BDRVRawState *s = bs->opaque;
@@ -245,67 +230,6 @@
     return ret;
 }
 
-
-#ifdef O_DIRECT
-/* 
- * offset and count are in bytes and possibly not aligned. For files opened 
- * with O_DIRECT, necessary alignments are ensured before calling 
- * raw_pread_aligned to do the actual read.
- */
-static int raw_pread(BlockDriverState *bs, int64_t offset,
-                     uint8_t *buf, int count)
-{
-    BDRVRawState *s = bs->opaque;
-
-    if (unlikely((s->open_flags & O_DIRECT) &&
-            (offset % 512 || count % 512 || (uintptr_t) buf % 512))) {
-
-        int ret;
-
-        // Temporarily disable O_DIRECT for unaligned access
-        fcntl(s->fd, F_SETFL, s->open_flags & ~O_DIRECT);
-        ret = raw_pread_aligned(bs, offset, buf, count);
-        fcntl(s->fd, F_SETFL, s->open_flags);
-
-        return ret;
-
-    } else {
-        return raw_pread_aligned(bs, offset, buf, count);
-    }
-}
-
-/* 
- * offset and count are in bytes and possibly not aligned. For files opened 
- * with O_DIRECT, necessary alignments are ensured before calling 
- * raw_pwrite_aligned to do the actual write.
- */
-static int raw_pwrite(BlockDriverState *bs, int64_t offset,
-                      const uint8_t *buf, int count)
-{
-    BDRVRawState *s = bs->opaque;
-
-    if (unlikely((s->open_flags & O_DIRECT) &&
-            (offset % 512 || count % 512 || (uintptr_t) buf % 512))) {
-
-        int ret;
-
-        // Temporarily disable O_DIRECT for unaligned access
-        fcntl(s->fd, F_SETFL, s->open_flags & ~O_DIRECT);
-        ret = raw_pwrite_aligned(bs, offset, buf, count);
-        fcntl(s->fd, F_SETFL, s->open_flags);
-
-        return ret;
-    } else {
-        return raw_pwrite_aligned(bs, offset, buf, count);
-    }
-}
-
-#else
-#define raw_pread raw_pread_aligned
-#define raw_pwrite raw_pwrite_aligned
-#endif
-
-
 /***********************************************************/
 /* Unix AIO using POSIX AIO */
 
@@ -478,26 +402,10 @@
         BlockDriverCompletionFunc *cb, void *opaque)
 {
     RawAIOCB *acb;
-    BDRVRawState *s = bs->opaque;
 
-    /* 
-     * If O_DIRECT is used and the buffer is not aligned fall back
-     * to synchronous IO.
-     */
-    if (unlikely((s->open_flags & O_DIRECT) && ((uintptr_t) buf % 512))) {
-        int ret;
-
-        acb = qemu_aio_get(bs, cb, opaque);
-        ret = raw_pread(bs, 512 * sector_num, buf, 512 * nb_sectors);
-        acb->common.cb(acb->common.opaque, ret);
-        qemu_aio_release(acb);
-        return &acb->common;
-    }
-
     acb = raw_aio_setup(bs, sector_num, buf, nb_sectors, cb, opaque);
     if (!acb)
         return NULL;
-
     if (aio_read(&acb->aiocb) < 0) {
         qemu_aio_release(acb);
         return NULL;
@@ -510,22 +418,7 @@
         BlockDriverCompletionFunc *cb, void *opaque)
 {
     RawAIOCB *acb;
-    BDRVRawState *s = bs->opaque;
 
-    /* 
-     * If O_DIRECT is used and the buffer is not aligned fall back
-     * to synchronous IO.
-     */
-    if (unlikely((s->open_flags & O_DIRECT) && ((uintptr_t) buf % 512))) {
-        int ret;
-
-        acb = qemu_aio_get(bs, cb, opaque);
-        ret = raw_pwrite(bs, 512 * sector_num, buf, 512 * nb_sectors);
-        acb->common.cb(acb->common.opaque, ret);
-        qemu_aio_release(acb);
-        return &acb->common;
-    }
-
     acb = raw_aio_setup(bs, sector_num, (uint8_t*)buf, nb_sectors, cb, opaque);
     if (!acb)
         return NULL;
@@ -786,7 +679,7 @@
         s->type = FTYPE_CD;
     } else if (strstart(filename, "/dev/fd", NULL)) {
         s->type = FTYPE_FD;
-        s->open_flags = open_flags;
+        s->fd_open_flags = open_flags;
         /* open will not fail even if no floppy is inserted */
         open_flags |= O_NONBLOCK;
     } else if (strstart(filename, "/dev/sg", NULL)) {
@@ -841,7 +734,7 @@
 #endif
             return -EIO;
         }
-        s->fd = open(bs->filename, s->open_flags);
+        s->fd = open(bs->filename, s->fd_open_flags);
         if (s->fd < 0) {
             s->fd_error_time = qemu_get_clock(rt_clock);
             s->fd_got_error = 1;
@@ -938,7 +831,7 @@
                 close(s->fd);
                 s->fd = -1;
             }
-            fd = open(bs->filename, s->open_flags | O_NONBLOCK);
+            fd = open(bs->filename, s->fd_open_flags | O_NONBLOCK);
             if (fd >= 0) {
                 if (ioctl(fd, FDEJECT, 0) < 0)
                     perror("FDEJECT");






reply via email to

[Prev in Thread] Current Thread [Next in Thread]