Skip to content
Snippets Groups Projects
Commit 57d44370 authored by Andreas Dilger's avatar Andreas Dilger
Browse files

Branch b1_6

Update multiop to do aligned read/write for O_DIRECT files.
b=11737
parent ecdf12dd
No related branches found
No related tags found
No related merge requests found
...@@ -17,7 +17,10 @@ ...@@ -17,7 +17,10 @@
#define T1 "write data before unlink\n" #define T1 "write data before unlink\n"
#define T2 "write data after unlink\n" #define T2 "write data after unlink\n"
char buf[] = "yabba dabba doo, I'm coming for you, I live in a shoe, I don't know what to do.\n'Bigger, bigger,and bigger yet!' cried the Creator. 'You are not yet substantial enough for my boundless intents!' And ever greater and greater the object became, until all was lost 'neath its momentus bulk.\n"; char msg[] = "yabba dabba doo, I'm coming for you, I live in a shoe, I don't know what to do.\n'Bigger, bigger,and bigger yet!' cried the Creator. 'You are not yet substantial enough for my boundless intents!' And ever greater and greater the object became, until all was lost 'neath its momentus bulk.\n";
char *buf, *buf_align;
int bufsize = 0;
#define ALIGN 65535
char usage[] = char usage[] =
"Usage: %s filename command-sequence\n" "Usage: %s filename command-sequence\n"
...@@ -250,21 +253,28 @@ int main(int argc, char **argv) ...@@ -250,21 +253,28 @@ int main(int argc, char **argv)
len = atoi(commands+1); len = atoi(commands+1);
if (len <= 0) if (len <= 0)
len = 1; len = 1;
while(len > 0) { if (bufsize < len) {
if (read(fd, &buf, buf = realloc(buf, len + ALIGN);
min(len,sizeof(buf))) == -1) { if (buf == NULL) {
save_errno = errno; save_errno = errno;
perror("read"); perror("allocating buf for read\n");
exit(save_errno); exit(save_errno);
} }
len -= sizeof(buf); bufsize = len;
buf_align = (char *)((long)(buf + ALIGN) &
~ALIGN);
} }
break; while (len > 0) {
case 'S': rc = read(fd, buf_align, len);
if (fstat(fd, &st) == -1) { if (rc == -1) {
save_errno = errno; save_errno = errno;
perror("fstat"); perror("read");
exit(save_errno); exit(save_errno);
}
if (rc < len)
fprintf(stderr, "short read: %u/%u\n",
rc, len);
len -= rc;
} }
break; break;
case 'R': case 'R':
...@@ -278,6 +288,13 @@ int main(int argc, char **argv) ...@@ -278,6 +288,13 @@ int main(int argc, char **argv)
exit(save_errno); exit(save_errno);
} }
break; break;
case 'S':
if (fstat(fd, &st) == -1) {
save_errno = errno;
perror("fstat");
exit(save_errno);
}
break;
case 't': case 't':
if (fchmod(fd, 0) == -1) { if (fchmod(fd, 0) == -1) {
save_errno = errno; save_errno = errno;
...@@ -312,15 +329,29 @@ int main(int argc, char **argv) ...@@ -312,15 +329,29 @@ int main(int argc, char **argv)
len = atoi(commands+1); len = atoi(commands+1);
if (len <= 0) if (len <= 0)
len = 1; len = 1;
while(len > 0) { if (bufsize < len) {
if ((rc = write(fd, buf, buf = realloc(buf, len + ALIGN);
min(len, sizeof(buf)))) if (buf == NULL) {
== -1) { save_errno = errno;
perror("allocating buf for write\n");
exit(save_errno);
}
bufsize = len;
buf_align = (char *)((long)(buf + ALIGN) &
~ALIGN);
strncpy(buf_align, msg, bufsize);
}
while (len > 0) {
rc = write(fd, buf_align, len);
if (rc == -1) {
save_errno = errno; save_errno = errno;
perror("write"); perror("write");
exit(save_errno); exit(save_errno);
} }
len -= sizeof(buf); if (rc < len)
fprintf(stderr, "short write: %u/%u\n",
rc, len);
len -= rc;
} }
break; break;
case 'W': case 'W':
...@@ -366,5 +397,8 @@ int main(int argc, char **argv) ...@@ -366,5 +397,8 @@ int main(int argc, char **argv)
} }
} }
if (buf)
free(buf);
return 0; return 0;
} }
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment