#2738 refs[t:2738] merge dbufio bug fix to main

git-svn-id: file:///svn/toku/tokudb@21260 c7de825b-a66e-492c-adef-691d508d4ae1
This commit is contained in:
Rich Prohaska 2013-04-16 23:59:19 -04:00 committed by Yoni Fogel
parent 76dcd3fe21
commit c37567705f
4 changed files with 21 additions and 25 deletions

View file

@ -1688,6 +1688,8 @@ static int merge_some_files (const BOOL to_q, FIDX dest_data, QUEUE q, int n_sou
}
if (bfs!=NULL) {
if (result != 0)
(void) panic_dbufio_fileset(bfs, result);
int r = destroy_dbufio_fileset(bfs);
if (r!=0 && result==0) result=r;
bfs = NULL;

View file

@ -149,7 +149,10 @@ static void* io_thread (void *v)
{
int r = toku_pthread_mutex_lock(&bfs->mutex);
if (r!=0) { panic(bfs, r); return 0; }
if (paniced(bfs)) return 0;
if (paniced(bfs)) {
toku_pthread_mutex_unlock(&bfs->mutex); // ignore any error
return 0;
}
}
// Now that we have the mutex, we can decrement n_not_done (if applicable) and set second_buf_ready
if (readcode<=0) {
@ -267,6 +270,14 @@ int create_dbufio_fileset (DBUFIO_FILESET *bfsp, int N, int fds[/*N*/], size_t b
return result;
}
int panic_dbufio_fileset(DBUFIO_FILESET bfs, int error) {
int r;
r = toku_pthread_mutex_lock(&bfs->mutex); assert(r==0);
panic(bfs, error);
r = toku_pthread_cond_broadcast(&bfs->cond); assert(r==0);
r = toku_pthread_mutex_unlock(&bfs->mutex); assert(r==0);
return 0;
}
int destroy_dbufio_fileset (DBUFIO_FILESET bfs) {
int result = 0;

View file

@ -22,6 +22,8 @@ int destroy_dbufio_fileset(DBUFIO_FILESET);
int dbufio_fileset_read (DBUFIO_FILESET bfs, int filenum, void *buf_v, size_t count, size_t *n_read);
int panic_dbufio_fileset(DBUFIO_FILESET, int error);
C_END
#endif

View file

@ -39,30 +39,11 @@ static void test1 (size_t chars_per_file, size_t bytes_per_read) {
int r = create_dbufio_fileset(&bfs, N, fds, M);
assert(r==0);
}
#if 0
while (n_live>0) {
int indirectnum = random()%n_live;
int filenum = still_live[indirectnum];
char buf[bytes_per_read];
size_t n_read_here=0;
int r = dbufio_fileset_read(bfs, filenum, buf, bytes_per_read, &n_read_here);
//printf("read(%d) -> %d (%ld) (old n_read=%ld)\n", filenum, r, n_read_here, n_read[filenum]);
if (r==0) {
// did read something
assert(n_read_here==bytes_per_read);
n_read[filenum]+=n_read_here;
//printf(" new n_read=%ld\n", n_read[filenum]);
assert(n_read[filenum]<=chars_per_file);
} else {
assert(r==EOF);
assert(n_read[filenum]==chars_per_file);
still_live[indirectnum] = still_live[n_live-1];
n_live--;
}
}
#else
n_live = n_live; bytes_per_read = bytes_per_read;
#endif
{ int r = panic_dbufio_fileset(bfs, EIO); assert(r == 0); }
{
int r = destroy_dbufio_fileset(bfs);
assert(r==0);
@ -76,7 +57,7 @@ static void test1 (size_t chars_per_file, size_t bytes_per_read) {
int r = close(fds[i]);
assert(r==0);
}
assert(n_read[i]==chars_per_file);
assert(n_read[i]==0);
}
}