X-Git-Url: http://git.tuebingen.mpg.de/?p=paraslash.git;a=blobdiff_plain;f=prebuffer_filter.c;h=9a801900c157e1da2da979c92d7bd60d03e21b9c;hp=ad2373767a8b8df5793472b795ac3d5b85327b55;hb=c22c653634658511cd10c423840ca462ba8b12b3;hpb=767a4a54c967bc4b80bd14d02e89fe91acd848dd diff --git a/prebuffer_filter.c b/prebuffer_filter.c index ad237376..9a801900 100644 --- a/prebuffer_filter.c +++ b/prebuffer_filter.c @@ -57,7 +57,14 @@ static int prebuffer_post_select(__a_unused struct sched *s, void *context) size_t iqs = btr_get_input_queue_size(btrn); struct private_prebuffer_data *ppd = fn->private_data; uint32_t size = FILTER_CMD_OPT_UINT32_VAL(PREBUFFER, SIZE, fn->lpr); + int ret; + ret = task_get_notification(fn->task); + if (ret < 0) + goto fail; + ret = btr_node_status(btrn, size, BTR_NT_INTERNAL); + if (ret < 0) + goto fail; if (ppd->barrier.tv_sec == 0) return 0; if (tv_diff(now, &ppd->barrier, NULL) < 0) @@ -66,6 +73,9 @@ static int prebuffer_post_select(__a_unused struct sched *s, void *context) return 0; btr_splice_out_node(&fn->btrn); return -E_PREBUFFER_SUCCESS; +fail: + btr_remove_node(&fn->btrn); + return ret; } static void prebuffer_open(struct filter_node *fn)