X-Git-Url: http://git.tuebingen.mpg.de/?p=paraslash.git;a=blobdiff_plain;f=wav_filter.c;h=e749160d3337e87dc7c908c023ea100c955590e4;hp=ea3236c7f56a0ee1b2719b47a80dc4e4754154ad;hb=HEAD;hpb=72e9bdf7c5c09ca4c20cad56c68a9a155cceff43 diff --git a/wav_filter.c b/wav_filter.c index ea3236c7..de4a3e6a 100644 --- a/wav_filter.c +++ b/wav_filter.c @@ -1,8 +1,4 @@ -/* - * Copyright (C) 2005-2014 Andre Noll - * - * Licensed under the GPL v2. For licencing details see COPYING. - */ +/* Copyright (C) 2005 Andre Noll , see file COPYING. */ /** \file wav_filter.c A filter that inserts a wave header. */ @@ -12,7 +8,6 @@ #include "error.h" #include "list.h" #include "sched.h" -#include "ggo.h" #include "buffer_tree.h" #include "filter.h" #include "string.h" @@ -31,7 +26,7 @@ static void make_wav_header(unsigned int channels, unsigned int sample_rate, int bytespersec = channels * sample_rate * BITS / 8; int align = channels * BITS / 8; - PARA_DEBUG_LOG("writing wave header: %d channels, %d KHz\n", channels, sample_rate); + PARA_DEBUG_LOG("writing wave header: %u channels, %u KHz\n", channels, sample_rate); memset(headbuf, 0, WAV_HEADER_LEN); memcpy(headbuf, "RIFF", 4); write_u32(headbuf + 4, size - 8); @@ -58,25 +53,24 @@ static void wav_open(struct filter_node *fn) { int *bof; - fn->private_data = para_malloc(sizeof(int)); + fn->private_data = alloc(sizeof(int)); bof = fn->private_data; *bof = 1; } -static void wav_pre_select(struct sched *s, struct task *t) +static void wav_pre_monitor(struct sched *s, void *context) { - struct filter_node *fn = container_of(t, struct filter_node, task); + struct filter_node *fn = context; size_t iqs = btr_get_input_queue_size(fn->btrn); - t->error = 0; if (iqs == 0) return; sched_min_delay(s); } -static int wav_post_select(__a_unused struct sched *s, struct task *t) +static int wav_post_monitor(__a_unused struct sched *s, void *context) { - struct filter_node *fn = container_of(t, struct filter_node, task); + struct filter_node *fn = context; struct btr_node *btrn = fn->btrn; size_t iqs = btr_get_input_queue_size(btrn); int ret; @@ -84,7 +78,7 @@ static int wav_post_select(__a_unused struct sched *s, struct task *t) int32_t rate, ch; if (iqs == 0) { - ret = -E_WAV_EOF; + ret = -E_EOF; if (btr_no_parent(btrn)) goto err; return 0; @@ -107,7 +101,7 @@ static int wav_post_select(__a_unused struct sched *s, struct task *t) free(buf); if (ret < 0) goto err; - header = para_malloc(WAV_HEADER_LEN); + header = alloc(WAV_HEADER_LEN); make_wav_header(ch, rate, header); btr_add_output(header, WAV_HEADER_LEN, btrn); ret = -E_WAV_SUCCESS; @@ -121,15 +115,9 @@ err: return ret; } -/** - * The init function of the wav filter. - * - * \param f Structure to initialize. - */ -void wav_filter_init(struct filter *f) -{ - f->close = wav_close; - f->open = wav_open; - f->pre_select = wav_pre_select; - f->post_select = wav_post_select; -} +const struct filter lsg_filter_cmd_com_wav_user_data = { + .close = wav_close, + .open = wav_open, + .pre_monitor = wav_pre_monitor, + .post_monitor = wav_post_monitor, +};