#include #include #include #include #include #include #include #include #include // not correctly in the headers yet!! #ifndef O_DIRECT #define O_DIRECT 040000 /* direct disk access hint */ #endif int main(int argc, char **argv) { int fd; char *buf; int blocks, seek_blocks; long len; off64_t seek; struct stat64 st; int rc; if (argc != 4) { printf("Usage: %s file seek nr_blocks\n", argv[0]); return 1; } seek_blocks = strtoul(argv[2], 0, 0); blocks = strtoul(argv[3], 0, 0); fd = open(argv[1], O_LARGEFILE | O_DIRECT | O_RDWR | O_CREAT, 0644); if (fd == -1) { printf("Cannot open %s: %s\n", argv[1], strerror(errno)); return 1; } if (fstat64(fd, &st) < 0) { printf("Cannot stat %s: %s\n", argv[1], strerror(errno)); return 1; } printf("directio on %s for %dx%lu bytes \n", argv[1], blocks, st.st_blksize); seek = (off64_t)seek_blocks * (off64_t)st.st_blksize; if (lseek64(fd, seek, SEEK_SET) < 0) { printf("lseek64 failed: %s\n", strerror(errno)); return 1; } len = blocks * st.st_blksize; buf = mmap(0, len, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANON, 0, 0); if (!buf) { printf("No memory %s\n", strerror(errno)); return 1; } memset(buf, 0xba, len); rc = write(fd, buf, len); if (rc != len) { printf("Write error %s (rc = %d)\n", strerror(errno), rc); return 1; } if (lseek64(fd, seek, SEEK_SET) < 0) { printf("Cannot seek %s\n", strerror(errno)); return 1; } rc = read(fd, buf, len); if (rc != len) { printf("Read error: %s (rc = %d)\n", strerror(errno), rc); return 1; } printf("PASS\n"); return 0; }