Commit 39b2d649 authored by Rich Prohaska's avatar Rich Prohaska Committed by Yoni Fogel

#2840 refs[t:2840] add debug prints to the loader to help fix the dbufio read...

#2840 refs[t:2840] add debug prints to the loader to help fix the dbufio read row problem, also remove the assert on this error path

git-svn-id: file:///svn/toku/tokudb@22673 c7de825b-a66e-492c-adef-691d508d4ae1
parent 7460fb68
...@@ -106,6 +106,7 @@ static FILE * (*t_fdopen)(int, const char *) = 0; ...@@ -106,6 +106,7 @@ static FILE * (*t_fdopen)(int, const char *) = 0;
static FILE * (*t_fopen)(const char *, const char *) = 0; static FILE * (*t_fopen)(const char *, const char *) = 0;
static int (*t_open)(const char *, int, int) = 0; // no implementation of variadic form until needed static int (*t_open)(const char *, int, int) = 0; // no implementation of variadic form until needed
static int (*t_fclose)(FILE *) = 0; static int (*t_fclose)(FILE *) = 0;
static ssize_t (*t_read)(int, void *, size_t) = 0;
int int
toku_set_func_write (ssize_t (*write_fun)(int, const void *, size_t)) { toku_set_func_write (ssize_t (*write_fun)(int, const void *, size_t)) {
...@@ -157,7 +158,11 @@ toku_set_func_fclose(int (*fclose_fun)(FILE*)) { ...@@ -157,7 +158,11 @@ toku_set_func_fclose(int (*fclose_fun)(FILE*)) {
return 0; return 0;
} }
int
toku_set_func_read (ssize_t (*read_fun)(int, void *, size_t)) {
t_read = read_fun;
return 0;
}
void void
toku_os_full_write (int fd, const void *buf, size_t len) { toku_os_full_write (int fd, const void *buf, size_t len) {
...@@ -305,6 +310,15 @@ toku_os_close (int fd) { // if EINTR, retry until success ...@@ -305,6 +310,15 @@ toku_os_close (int fd) { // if EINTR, retry until success
return r; return r;
} }
ssize_t
toku_os_read(int fd, void *buf, size_t count) {
ssize_t r;
if (t_read)
r = t_read(fd, buf, count);
else
r = read(fd, buf, count);
return r;
}
///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
// fsync logic: // fsync logic:
......
...@@ -1666,7 +1666,7 @@ int toku_merge_some_files_using_dbufio (const BOOL to_q, FIDX dest_data, QUEUE q ...@@ -1666,7 +1666,7 @@ int toku_merge_some_files_using_dbufio (const BOOL to_q, FIDX dest_data, QUEUE q
int r = pqueue_pop(pq, &node); int r = pqueue_pop(pq, &node);
if (r!=0) { if (r!=0) {
result = r; result = r;
lazy_assert(0); invariant(0);
break; break;
} }
mini = node->i; mini = node->i;
...@@ -1718,7 +1718,9 @@ int toku_merge_some_files_using_dbufio (const BOOL to_q, FIDX dest_data, QUEUE q ...@@ -1718,7 +1718,9 @@ int toku_merge_some_files_using_dbufio (const BOOL to_q, FIDX dest_data, QUEUE q
toku_free(keys[mini].data); keys[mini].data = NULL; toku_free(keys[mini].data); keys[mini].data = NULL;
toku_free(vals[mini].data); vals[mini].data = NULL; toku_free(vals[mini].data); vals[mini].data = NULL;
} else { } else {
lazy_assert(0); fprintf(stderr, "%s:%d r=%d errno=%d bfs=%p mini=%d\n", __FILE__, __LINE__, r, errno, bfs, mini);
dbufio_print(bfs);
// lazy_assert(0);
result = r; result = r;
break; break;
} }
...@@ -2301,7 +2303,7 @@ static int toku_loader_write_brt_from_q (BRTLOADER bl, ...@@ -2301,7 +2303,7 @@ static int toku_loader_write_brt_from_q (BRTLOADER bl,
seek_align(&out); seek_align(&out);
int64_t lblock; int64_t lblock;
result = allocate_block(&out, &lblock); result = allocate_block(&out, &lblock);
lazy_assert(result == 0); // can not fail since translations reserved above invariant(result == 0); // can not fail since translations reserved above
struct leaf_buf *lbuf = start_leaf(&out, descriptor, lblock); struct leaf_buf *lbuf = start_leaf(&out, descriptor, lblock);
u_int64_t n_rows_remaining = bl->n_rows; u_int64_t n_rows_remaining = bl->n_rows;
u_int64_t old_n_rows_remaining = bl->n_rows; u_int64_t old_n_rows_remaining = bl->n_rows;
......
...@@ -29,7 +29,6 @@ struct dbufio_file { ...@@ -29,7 +29,6 @@ struct dbufio_file {
int error_code[2]; // includes errno or eof. [0] is the error code associated with buf[0], [1] is the code for buf[1] int error_code[2]; // includes errno or eof. [0] is the error code associated with buf[0], [1] is the code for buf[1]
BOOL io_done; BOOL io_done;
}; };
...@@ -128,11 +127,13 @@ static void* io_thread (void *v) ...@@ -128,11 +127,13 @@ static void* io_thread (void *v)
} }
//printf("%s:%d Doing read fd=%d\n", __FILE__, __LINE__, dbf->fd); //printf("%s:%d Doing read fd=%d\n", __FILE__, __LINE__, dbf->fd);
{ {
ssize_t readcode = read(dbf->fd, dbf->buf[1], bfs->bufsize); ssize_t readcode = toku_os_read(dbf->fd, dbf->buf[1], bfs->bufsize);
//printf("%s:%d readcode=%ld\n", __FILE__, __LINE__, readcode); //printf("%s:%d readcode=%ld\n", __FILE__, __LINE__, readcode);
if (readcode==-1) { if (readcode==-1) {
// a real error. Save the real error. // a real error. Save the real error.
dbf->error_code[1] = errno; int the_errno = errno;
fprintf(stderr, "%s:%d dbf=%p fd=%d errno=%d\n", __FILE__, __LINE__, dbf, dbf->fd, the_errno);
dbf->error_code[1] = the_errno;
dbf->n_in_buf[1] = 0; dbf->n_in_buf[1] = 0;
} else if (readcode==0) { } else if (readcode==0) {
// End of file. Save it. // End of file. Save it.
...@@ -219,7 +220,7 @@ int create_dbufio_fileset (DBUFIO_FILESET *bfsp, int N, int fds[/*N*/], size_t b ...@@ -219,7 +220,7 @@ int create_dbufio_fileset (DBUFIO_FILESET *bfsp, int N, int fds[/*N*/], size_t b
} }
bfs->files[i].io_done = FALSE; bfs->files[i].io_done = FALSE;
{ {
ssize_t r = read(bfs->files[i].fd, bfs->files[i].buf[0], bufsize); ssize_t r = toku_os_read(bfs->files[i].fd, bfs->files[i].buf[0], bufsize);
if (r<0) { if (r<0) {
result=errno; result=errno;
break; break;
...@@ -371,3 +372,18 @@ int dbufio_fileset_read (DBUFIO_FILESET bfs, int filenum, void *buf_v, size_t co ...@@ -371,3 +372,18 @@ int dbufio_fileset_read (DBUFIO_FILESET bfs, int filenum, void *buf_v, size_t co
assert(0); // cannot get here. assert(0); // cannot get here.
} }
} }
void
dbufio_print(DBUFIO_FILESET bfs) {
fprintf(stderr, "%s:%d bfs=%p", __FILE__, __LINE__, bfs);
if (bfs->panic)
fprintf(stderr, " panic=%d", bfs->panic_errno);
fprintf(stderr, " N=%d %d %"PRIuMAX, bfs->N, bfs->n_not_done, bfs->bufsize);
for (int i = 0; i < bfs->N; i++) {
struct dbufio_file *dbf = &bfs->files[i];
if (dbf->error_code[0] || dbf->error_code[1])
fprintf(stderr, " %d=[%d,%d]", i, dbf->error_code[0], dbf->error_code[1]);
}
fprintf(stderr, "\n");
}
...@@ -24,6 +24,8 @@ int dbufio_fileset_read (DBUFIO_FILESET bfs, int filenum, void *buf_v, size_t co ...@@ -24,6 +24,8 @@ int dbufio_fileset_read (DBUFIO_FILESET bfs, int filenum, void *buf_v, size_t co
int panic_dbufio_fileset(DBUFIO_FILESET, int error); int panic_dbufio_fileset(DBUFIO_FILESET, int error);
void dbufio_print(DBUFIO_FILESET);
C_END C_END
#endif #endif
...@@ -140,7 +140,21 @@ bad_fclose(FILE * stream) { ...@@ -140,7 +140,21 @@ bad_fclose(FILE * stream) {
return rval; return rval;
} }
int bad_read_errno = 0;
static ssize_t
bad_read(int fd, void *buf, size_t count) {
ssize_t rval;
event_count++;
if (event_count_trigger == event_count) {
event_hit();
if (verbose) printf("%s %d\n", __FUNCTION__, event_count);
errno = bad_read_errno;
rval = -1;
} else
rval = read(fd, buf, count);
return rval;
}
static int my_malloc_event = 1; static int my_malloc_event = 1;
static int my_malloc_count = 0, my_big_malloc_count = 0; static int my_malloc_count = 0, my_big_malloc_count = 0;
...@@ -366,7 +380,7 @@ static void test (const char *directory, BOOL is_error) { ...@@ -366,7 +380,7 @@ static void test (const char *directory, BOOL is_error) {
toku_set_func_fopen(bad_fopen); toku_set_func_fopen(bad_fopen);
toku_set_func_open(bad_open); toku_set_func_open(bad_open);
toku_set_func_fclose(bad_fclose); toku_set_func_fclose(bad_fclose);
if (bad_read_errno) toku_set_func_read(bad_read);
int result = 0; int result = 0;
{ {
...@@ -392,6 +406,7 @@ static void test (const char *directory, BOOL is_error) { ...@@ -392,6 +406,7 @@ static void test (const char *directory, BOOL is_error) {
toku_set_func_fopen(NULL); toku_set_func_fopen(NULL);
toku_set_func_open(NULL); toku_set_func_open(NULL);
toku_set_func_fclose(NULL); toku_set_func_fclose(NULL);
toku_set_func_read(NULL);
do_assert_hook = my_assert_hook; do_assert_hook = my_assert_hook;
{ {
...@@ -445,6 +460,7 @@ static int usage(const char *progname, int n) { ...@@ -445,6 +460,7 @@ static int usage(const char *progname, int n) {
fprintf(stderr, "[-s] set the small loader size factor\n"); fprintf(stderr, "[-s] set the small loader size factor\n");
fprintf(stderr, "[-m] inject big malloc failures\n"); fprintf(stderr, "[-m] inject big malloc failures\n");
fprintf(stderr, "[-tend NEVENTS] stop testing after N events\n"); fprintf(stderr, "[-tend NEVENTS] stop testing after N events\n");
fprintf(stderr, "[-bad_read_errno ERRNO]\n");
return 1; return 1;
} }
...@@ -467,12 +483,15 @@ int test_main (int argc, const char *argv[]) { ...@@ -467,12 +483,15 @@ int test_main (int argc, const char *argv[]) {
toku_brtloader_set_size_factor(1); toku_brtloader_set_size_factor(1);
} else if (strcmp(argv[0],"-m") == 0) { } else if (strcmp(argv[0],"-m") == 0) {
my_malloc_event = 1; my_malloc_event = 1;
} else if (strcmp(argv[0],"-tend") == 0) { } else if (strcmp(argv[0],"-tend") == 0 && argc > 1) {
argc--; argv++; argc--; argv++;
tend = atoi(argv[0]); tend = atoi(argv[0]);
} else if (strcmp(argv[0],"-tstart") == 0) { } else if (strcmp(argv[0],"-tstart") == 0 && argc > 1) {
argc--; argv++; argc--; argv++;
tstart = atoi(argv[0]); tstart = atoi(argv[0]);
} else if (strcmp(argv[0], "-bad_read_errno") == 0 && argc > 1) {
argc--; argv++;
bad_read_errno = atoi(argv[0]);
} else if (argc!=1) { } else if (argc!=1) {
return usage(progname, N_RECORDS); return usage(progname, N_RECORDS);
} }
...@@ -514,7 +533,7 @@ int test_main (int argc, const char *argv[]) { ...@@ -514,7 +533,7 @@ int test_main (int argc, const char *argv[]) {
event_count_trigger = i; event_count_trigger = i;
r = system(unlink_all); CKERR(r); r = system(unlink_all); CKERR(r);
r = toku_os_mkdir(directory, 0755); CKERR(r); r = toku_os_mkdir(directory, 0755); CKERR(r);
if (verbose) printf("event=%d\n", i);
test(directory, TRUE); test(directory, TRUE);
} }
} }
......
...@@ -170,7 +170,7 @@ FILE * toku_os_fopen(const char *filename, const char *mode); ...@@ -170,7 +170,7 @@ FILE * toku_os_fopen(const char *filename, const char *mode);
int toku_os_open(const char *path, int oflag, int mode); int toku_os_open(const char *path, int oflag, int mode);
int toku_os_close(int fd); int toku_os_close(int fd);
int toku_os_fclose(FILE * stream); int toku_os_fclose(FILE * stream);
ssize_t toku_os_read(int fd, void *buf, size_t count);
// wrapper around fsync // wrapper around fsync
int toku_file_fsync_without_accounting(int fd); int toku_file_fsync_without_accounting(int fd);
...@@ -198,7 +198,7 @@ int toku_set_func_fdopen (FILE * (*)(int, const char *)); ...@@ -198,7 +198,7 @@ int toku_set_func_fdopen (FILE * (*)(int, const char *));
int toku_set_func_fopen (FILE * (*)(const char *, const char *)); int toku_set_func_fopen (FILE * (*)(const char *, const char *));
int toku_set_func_open (int (*)(const char *, int, int)); // variadic form not implemented until needed int toku_set_func_open (int (*)(const char *, int, int)); // variadic form not implemented until needed
int toku_set_func_fclose(int (*)(FILE*)); int toku_set_func_fclose(int (*)(FILE*));
int toku_set_func_read(ssize_t (*)(int, void *, size_t));
int toku_portability_init (void); int toku_portability_init (void);
int toku_portability_destroy (void); int toku_portability_destroy (void);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment