X-Git-Url: http://git.tuebingen.mpg.de/?a=blobdiff_plain;f=grab_client.c;h=ef3f34a76216e3b677e82e435ef5d5f947667891;hb=1cefe6a503c74d609db4e99e689d46575a5e40fd;hp=9109c2f8f6c5f1978eddd356ff7f8e979d73dd8a;hpb=32e646780461f96682d1191d31e08e4602ab125e;p=paraslash.git diff --git a/grab_client.c b/grab_client.c index 9109c2f8..ef3f34a7 100644 --- a/grab_client.c +++ b/grab_client.c @@ -1,5 +1,5 @@ /* - * Copyright (C) 2006-2011 Andre Noll + * Copyright (C) 2006-2012 Andre Noll * * Licensed under the GPL v2. For licencing details see COPYING. */ @@ -8,7 +8,6 @@ #include #include -#include #include "para.h" #include "list.h" @@ -116,7 +115,7 @@ static void gc_post_select(struct sched *s, struct task *t); * * \param gc The grab client to activate. */ -static void gc_activate(struct grab_client *gc) +static void gc_activate(struct grab_client *gc, struct sched *s) { struct btr_node *root = audiod_get_btr_root(), *parent; char *name = gc->name? gc->name : "grab"; @@ -135,7 +134,7 @@ static void gc_activate(struct grab_client *gc) snprintf(gc->task.status, sizeof(gc->task.status) - 1, "%s", name); gc->task.status[sizeof(gc->task.status) - 1] = '\0'; gc->task.error = 0; - register_task(&gc->task); + register_task(s, &gc->task); } /** @@ -149,7 +148,7 @@ static void gc_activate(struct grab_client *gc) * This function also garbage collects all grab clients whose tasks have been * unscheduled. */ -void activate_grab_clients(void) +void activate_grab_clients(struct sched *s) { struct grab_client *gc, *tmp; @@ -159,7 +158,7 @@ void activate_grab_clients(void) free(gc); continue; } - gc_activate(gc); + gc_activate(gc, s); } } @@ -266,6 +265,7 @@ static int gc_check_args(int argc, char **argv, struct grab_client *gc) * \param fd The file descriptor of the client. * \param argc Argument count. * \param argv Argument vector. + * \param s The scheduler to register the grab client task to. * * If the command line options given by \a argc and \a argv are valid. * allocate a struct grab_client and initialize it with this valid @@ -276,7 +276,7 @@ static int gc_check_args(int argc, char **argv, struct grab_client *gc) * * \return Standard. */ -int grab_client_new(int fd, int argc, char **argv) +int grab_client_new(int fd, int argc, char **argv, struct sched *s) { int ret; struct grab_client *gc = para_calloc(sizeof(struct grab_client)); @@ -286,7 +286,7 @@ int grab_client_new(int fd, int argc, char **argv) goto err_out; gc->fd = fd; para_list_add(&gc->node, &inactive_grab_client_list); - gc_activate(gc); + gc_activate(gc, s); return 1; err_out: free(gc);