2013-04-16 23:58:55 -04:00
|
|
|
/* Verify that toku_os_full_pwrite does the right thing when writing beyond 4GB. */
|
2013-04-16 23:59:01 -04:00
|
|
|
#include <test.h>
|
2013-04-16 23:57:42 -04:00
|
|
|
#include <fcntl.h>
|
2013-04-16 23:59:00 -04:00
|
|
|
#include <toku_assert.h>
|
2013-04-16 23:59:01 -04:00
|
|
|
#include <string.h>
|
|
|
|
#include <stdio.h>
|
2013-04-16 23:57:54 -04:00
|
|
|
|
|
|
|
static int iszero(char *cp, size_t n) {
|
|
|
|
size_t i;
|
|
|
|
for (i=0; i<n; i++)
|
|
|
|
if (cp[i] != 0)
|
|
|
|
return 0;
|
|
|
|
return 1;
|
|
|
|
}
|
2013-04-16 23:57:42 -04:00
|
|
|
|
2013-04-16 23:59:01 -04:00
|
|
|
int test_main(int argc, char *const argv[]) {
|
|
|
|
assert(argc==2); // first arg is the directory to put the data file into.
|
|
|
|
char short_fname[] = "pwrite4g.data";
|
|
|
|
int fname_len = strlen(short_fname) + strlen(argv[1]) + 5;
|
|
|
|
char fname[fname_len];
|
|
|
|
snprintf(fname, fname_len, "%s/%s", argv[1], short_fname);
|
2013-04-16 23:57:43 -04:00
|
|
|
int r;
|
|
|
|
unlink(fname);
|
2013-04-16 23:57:42 -04:00
|
|
|
int fd = open(fname, O_RDWR | O_CREAT | O_BINARY, S_IRWXU|S_IRWXG|S_IRWXO);
|
|
|
|
assert(fd>=0);
|
|
|
|
char buf[] = "hello";
|
2013-04-16 23:57:43 -04:00
|
|
|
int64_t offset = (1LL<<32) + 100;
|
2013-04-16 23:58:55 -04:00
|
|
|
toku_os_full_pwrite(fd, buf, sizeof buf, offset);
|
2013-04-16 23:57:54 -04:00
|
|
|
char newbuf[sizeof buf];
|
|
|
|
r = pread(fd, newbuf, sizeof newbuf, 100);
|
|
|
|
assert(r==sizeof newbuf);
|
|
|
|
assert(iszero(newbuf, sizeof newbuf));
|
|
|
|
r = pread(fd, newbuf, sizeof newbuf, offset);
|
|
|
|
assert(r==sizeof newbuf);
|
|
|
|
assert(memcmp(newbuf, buf, sizeof newbuf) == 0);
|
2013-04-16 23:57:43 -04:00
|
|
|
int64_t fsize;
|
|
|
|
r = toku_os_get_file_size(fd, &fsize);
|
|
|
|
assert(r == 0);
|
|
|
|
assert(fsize > 100 + (signed)sizeof(buf));
|
2013-04-16 23:57:42 -04:00
|
|
|
r = close(fd);
|
|
|
|
assert(r==0);
|
|
|
|
return 0;
|
|
|
|
}
|