]> code.delx.au - pulseaudio/blob - src/pulse/internal.h
really create glitch-free branch
[pulseaudio] / src / pulse / internal.h
1 #ifndef foointernalhfoo
2 #define foointernalhfoo
3
4 /* $Id$ */
5
6 /***
7 This file is part of PulseAudio.
8
9 Copyright 2004-2006 Lennart Poettering
10 Copyright 2006 Pierre Ossman <ossman@cendio.se> for Cendio AB
11
12 PulseAudio is free software; you can redistribute it and/or modify
13 it under the terms of the GNU Lesser General Public License as published
14 by the Free Software Foundation; either version 2 of the License,
15 or (at your option) any later version.
16
17 PulseAudio is distributed in the hope that it will be useful, but
18 WITHOUT ANY WARRANTY; without even the implied warranty of
19 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
20 General Public License for more details.
21
22 You should have received a copy of the GNU Lesser General Public License
23 along with PulseAudio; if not, write to the Free Software
24 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
25 USA.
26 ***/
27
28 #include <pulse/mainloop-api.h>
29 #include <pulse/context.h>
30 #include <pulse/stream.h>
31 #include <pulse/operation.h>
32 #include <pulse/subscribe.h>
33
34 #include <pulsecore/socket-client.h>
35 #include <pulsecore/pstream.h>
36 #include <pulsecore/pdispatch.h>
37 #include <pulsecore/dynarray.h>
38 #include <pulsecore/llist.h>
39 #include <pulsecore/native-common.h>
40 #include <pulsecore/strlist.h>
41 #include <pulsecore/mcalign.h>
42 #include <pulsecore/memblockq.h>
43 #include <pulsecore/hashmap.h>
44 #include <pulsecore/refcnt.h>
45
46 #include "client-conf.h"
47
48 #define DEFAULT_TIMEOUT (30)
49
50 struct pa_context {
51 PA_REFCNT_DECLARE;
52
53 char *name;
54 pa_mainloop_api* mainloop;
55
56 pa_socket_client *client;
57 pa_pstream *pstream;
58 pa_pdispatch *pdispatch;
59
60 pa_dynarray *record_streams, *playback_streams;
61 PA_LLIST_HEAD(pa_stream, streams);
62 PA_LLIST_HEAD(pa_operation, operations);
63
64 uint32_t version;
65 uint32_t ctag;
66 uint32_t csyncid;
67 uint32_t error;
68 pa_context_state_t state;
69
70 pa_context_notify_cb_t state_callback;
71 void *state_userdata;
72
73 pa_context_subscribe_cb_t subscribe_callback;
74 void *subscribe_userdata;
75
76 pa_mempool *mempool;
77
78 int is_local;
79 int do_autospawn;
80 int autospawn_lock_fd;
81 pa_spawn_api spawn_api;
82
83 pa_strlist *server_list;
84
85 char *server;
86
87 pa_client_conf *conf;
88 };
89
90 #define PA_MAX_WRITE_INDEX_CORRECTIONS 10
91
92 typedef struct pa_index_correction {
93 uint32_t tag;
94 int valid;
95 int64_t value;
96 int absolute, corrupt;
97 } pa_index_correction;
98
99 struct pa_stream {
100 PA_REFCNT_DECLARE;
101 pa_context *context;
102 pa_mainloop_api *mainloop;
103 PA_LLIST_FIELDS(pa_stream);
104
105 char *name;
106 pa_bool_t manual_buffer_attr;
107 pa_buffer_attr buffer_attr;
108 pa_sample_spec sample_spec;
109 pa_channel_map channel_map;
110 pa_stream_flags_t flags;
111 uint32_t channel;
112 uint32_t syncid;
113 int channel_valid;
114 uint32_t stream_index;
115 pa_stream_direction_t direction;
116 pa_stream_state_t state;
117 pa_bool_t buffer_attr_not_ready, timing_info_not_ready;
118
119 uint32_t requested_bytes;
120
121 uint32_t device_index;
122 char *device_name;
123 pa_bool_t suspended;
124
125 pa_memchunk peek_memchunk;
126 void *peek_data;
127 pa_memblockq *record_memblockq;
128
129 int corked;
130
131 /* Store latest latency info */
132 pa_timing_info timing_info;
133 int timing_info_valid;
134
135 /* Use to make sure that time advances monotonically */
136 pa_usec_t previous_time;
137
138 /* time updates with tags older than these are invalid */
139 uint32_t write_index_not_before;
140 uint32_t read_index_not_before;
141
142 /* Data about individual timing update correctoins */
143 pa_index_correction write_index_corrections[PA_MAX_WRITE_INDEX_CORRECTIONS];
144 int current_write_index_correction;
145
146 /* Latency interpolation stuff */
147 pa_time_event *auto_timing_update_event;
148 int auto_timing_update_requested;
149
150 pa_usec_t cached_time;
151 int cached_time_valid;
152
153 /* Callbacks */
154 pa_stream_notify_cb_t state_callback;
155 void *state_userdata;
156 pa_stream_request_cb_t read_callback;
157 void *read_userdata;
158 pa_stream_request_cb_t write_callback;
159 void *write_userdata;
160 pa_stream_notify_cb_t overflow_callback;
161 void *overflow_userdata;
162 pa_stream_notify_cb_t underflow_callback;
163 void *underflow_userdata;
164 pa_stream_notify_cb_t latency_update_callback;
165 void *latency_update_userdata;
166 pa_stream_notify_cb_t moved_callback;
167 void *moved_userdata;
168 pa_stream_notify_cb_t suspended_callback;
169 void *suspended_userdata;
170 };
171
172 typedef void (*pa_operation_cb_t)(void);
173
174 struct pa_operation {
175 PA_REFCNT_DECLARE;
176
177 pa_context *context;
178 pa_stream *stream;
179
180 PA_LLIST_FIELDS(pa_operation);
181
182 pa_operation_state_t state;
183 void *userdata;
184 pa_operation_cb_t callback;
185
186 void *private; /* some operations might need this */
187 };
188
189 void pa_command_request(pa_pdispatch *pd, uint32_t command, uint32_t tag, pa_tagstruct *t, void *userdata);
190 void pa_command_stream_killed(pa_pdispatch *pd, uint32_t command, uint32_t tag, pa_tagstruct *t, void *userdata);
191 void pa_command_subscribe_event(pa_pdispatch *pd, uint32_t command, uint32_t tag, pa_tagstruct *t, void *userdata);
192 void pa_command_overflow_or_underflow(pa_pdispatch *pd, uint32_t command, uint32_t tag, pa_tagstruct *t, void *userdata);
193 void pa_command_stream_suspended(pa_pdispatch *pd, uint32_t command, uint32_t tag, pa_tagstruct *t, void *userdata);
194 void pa_command_stream_moved(pa_pdispatch *pd, uint32_t command, uint32_t tag, pa_tagstruct *t, void *userdata);
195
196 pa_operation *pa_operation_new(pa_context *c, pa_stream *s, pa_operation_cb_t callback, void *userdata);
197 void pa_operation_done(pa_operation *o);
198
199 void pa_create_stream_callback(pa_pdispatch *pd, uint32_t command, uint32_t tag, pa_tagstruct *t, void *userdata);
200 void pa_stream_disconnect_callback(pa_pdispatch *pd, uint32_t command, uint32_t tag, pa_tagstruct *t, void *userdata);
201 void pa_context_simple_ack_callback(pa_pdispatch *pd, uint32_t command, uint32_t tag, pa_tagstruct *t, void *userdata);
202 void pa_stream_simple_ack_callback(pa_pdispatch *pd, uint32_t command, uint32_t tag, pa_tagstruct *t, void *userdata);
203
204 void pa_context_fail(pa_context *c, int error);
205 int pa_context_set_error(pa_context *c, int error);
206 void pa_context_set_state(pa_context *c, pa_context_state_t st);
207 int pa_context_handle_error(pa_context *c, uint32_t command, pa_tagstruct *t);
208 pa_operation* pa_context_send_simple_command(pa_context *c, uint32_t command, void (*internal_callback)(pa_pdispatch *pd, uint32_t command, uint32_t tag, pa_tagstruct *t, void *userdata), void (*cb)(void), void *userdata);
209
210 void pa_stream_set_state(pa_stream *s, pa_stream_state_t st);
211
212 pa_tagstruct *pa_tagstruct_command(pa_context *c, uint32_t command, uint32_t *tag);
213
214 #define PA_CHECK_VALIDITY(context, expression, error) do { \
215 if (!(expression)) \
216 return -pa_context_set_error((context), (error)); \
217 } while(0)
218
219
220 #define PA_CHECK_VALIDITY_RETURN_ANY(context, expression, error, value) do { \
221 if (!(expression)) { \
222 pa_context_set_error((context), (error)); \
223 return value; \
224 } \
225 } while(0)
226
227 #define PA_CHECK_VALIDITY_RETURN_NULL(context, expression, error) PA_CHECK_VALIDITY_RETURN_ANY(context, expression, error, NULL)
228
229
230 #endif