diff options
-rw-r--r-- | src/im-sandbox.c | 15 |
1 files changed, 8 insertions, 7 deletions
diff --git a/src/im-sandbox.c b/src/im-sandbox.c index 55ed939c..171ecf80 100644 --- a/src/im-sandbox.c +++ b/src/im-sandbox.c @@ -189,6 +189,7 @@ static char *read_prefixed_filename(struct get_pattern_ctx *gpctx, char **event) if ( !feof(gpctx->fh) ) { ERROR("Input file read error.\n"); } + free(line); return NULL; } chomp(line); @@ -392,7 +393,8 @@ static void run_work(const struct index_args *iargs, Stream *st, /* Get the event from the queue */ set_last_task(sb->shared->last_task[cookie], "read_queue"); pthread_mutex_lock(&sb->shared->queue_lock); - if ( sb->shared->no_more ) { + if ( (sb->shared->n_events==0) && (sb->shared->no_more) ) { + /* Queue is empty and no more coming, so exit */ pthread_mutex_unlock(&sb->shared->queue_lock); allDone = 1; continue; @@ -1003,7 +1005,6 @@ int create_sandbox(struct index_args *iargs, int n_proc, char *prefix, char semname_q[64]; struct sigaction sa; int r; - int no_more = 0; int allDone = 0; TimeAccounts *taccs; struct get_pattern_ctx gpctx; @@ -1071,8 +1072,7 @@ int create_sandbox(struct index_args *iargs, int n_proc, char *prefix, /* Fill the queue */ pthread_mutex_lock(&sb->shared->queue_lock); sb->shared->n_events = 0; - fill_queue(&gpctx, sb); - sb->shared->no_more = 0; + sb->shared->no_more = fill_queue(&gpctx, sb); pthread_mutex_unlock(&sb->shared->queue_lock); /* Fork the right number of times */ @@ -1124,8 +1124,9 @@ int create_sandbox(struct index_args *iargs, int n_proc, char *prefix, /* Top up the queue if necessary */ time_accounts_set(taccs, TACC_QUEUETOPUP); pthread_mutex_lock(&sb->shared->queue_lock); - if ( !no_more && (sb->shared->n_events < QUEUE_SIZE/2) ) { - if ( fill_queue(&gpctx, sb) ) no_more = 1; + if ( !sb->shared->no_more && (sb->shared->n_events < QUEUE_SIZE/2) ) { + STATUS("filling: %i %i\n", sb->shared->no_more, sb->shared->n_events); + if ( fill_queue(&gpctx, sb) ) sb->shared->no_more = 1; } pthread_mutex_unlock(&sb->shared->queue_lock); @@ -1137,7 +1138,7 @@ int create_sandbox(struct index_args *iargs, int n_proc, char *prefix, /* Have all the events been swallowed? */ time_accounts_set(taccs, TACC_ENDCHECK); pthread_mutex_lock(&sb->shared->queue_lock); - if ( no_more && (sb->shared->n_events == 0) ) allDone = 1; + if ( sb->shared->no_more && (sb->shared->n_events == 0) ) allDone = 1; pthread_mutex_unlock(&sb->shared->queue_lock); } while ( !allDone ); |