echo-cancel-test: Enable debug log level
[platform/upstream/pulseaudio.git] / src / modules / module-native-protocol-fd.c
1 /***
2   This file is part of PulseAudio.
3
4   Copyright 2004-2006 Lennart Poettering
5
6   PulseAudio is free software; you can redistribute it and/or modify
7   it under the terms of the GNU Lesser General Public License as published
8   by the Free Software Foundation; either version 2.1 of the License,
9   or (at your option) any later version.
10
11   PulseAudio is distributed in the hope that it will be useful, but
12   WITHOUT ANY WARRANTY; without even the implied warranty of
13   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14   General Public License for more details.
15
16   You should have received a copy of the GNU Lesser General Public License
17   along with PulseAudio; if not, write to the Free Software
18   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
19   USA.
20 ***/
21
22 #ifdef HAVE_CONFIG_H
23 #include <config.h>
24 #endif
25
26 #include <stdio.h>
27 #include <unistd.h>
28
29 #include <pulsecore/module.h>
30 #include <pulsecore/macro.h>
31 #include <pulsecore/iochannel.h>
32 #include <pulsecore/modargs.h>
33 #include <pulsecore/protocol-native.h>
34 #include <pulsecore/log.h>
35
36 #include "module-native-protocol-fd-symdef.h"
37
38 PA_MODULE_AUTHOR("Lennart Poettering");
39 PA_MODULE_DESCRIPTION("Native protocol autospawn helper");
40 PA_MODULE_VERSION(PACKAGE_VERSION);
41 PA_MODULE_LOAD_ONCE(TRUE);
42
43 static const char* const valid_modargs[] = {
44     "fd",
45     NULL,
46 };
47
48 int pa__init(pa_module*m) {
49     pa_iochannel *io;
50     pa_modargs *ma;
51     int32_t fd = -1;
52     int r = -1;
53     pa_native_options *options = NULL;
54
55     pa_assert(m);
56
57     if (!(ma = pa_modargs_new(m->argument, valid_modargs))) {
58         pa_log("Failed to parse module arguments.");
59         goto finish;
60     }
61
62     if (pa_modargs_get_value_s32(ma, "fd", &fd) < 0 || fd < 0) {
63         pa_log("Invalid file descriptor.");
64         goto finish;
65     }
66
67     m->userdata = pa_native_protocol_get(m->core);
68
69     io = pa_iochannel_new(m->core->mainloop, fd, fd);
70
71     options = pa_native_options_new();
72     options->module = m;
73     options->auth_anonymous = TRUE;
74
75     pa_native_protocol_connect(m->userdata, io, options);
76
77     r = 0;
78
79 finish:
80     if (ma)
81         pa_modargs_free(ma);
82
83     if (options)
84         pa_native_options_unref(options);
85
86     return r;
87 }
88
89 void pa__done(pa_module*m) {
90     pa_assert(m);
91
92     if (m->userdata) {
93         pa_native_protocol_disconnect(m->userdata, m);
94         pa_native_protocol_unref(m->userdata);
95     }
96 }