source: roaraudio/libroar/stream.c @ 496:a76b844d00c6

Last change on this file since 496:a76b844d00c6 was 496:a76b844d00c6, checked in by phi, 16 years ago

added support vor underrun vars to proto

File size: 4.7 KB
Line 
1//stream.c:
2
3#include "libroar.h"
4
5int roar_stream_connect (struct roar_connection * con, struct roar_stream * s, int dir) {
6 struct roar_message m;
7
8 s->dir = dir;
9
10 m.cmd     = ROAR_CMD_NEW_STREAM;
11 m.stream  = -1;
12 m.pos     = 0;
13
14 roar_stream_s2m(s, &m);
15
16 if ( roar_req(con, &m, NULL) != 0 )
17  return -1;
18
19 if ( m.cmd == ROAR_CMD_OK ) {
20  s->id = m.stream;
21
22  ROAR_DBG("roar_stream_connect(*) = 0");
23  return 0;
24 }
25
26 ROAR_ERR("roar_stream_connect(*): Connecting new stream faild!");
27 ROAR_DBG("roar_stream_connect(*) = -1");
28 return -1;
29}
30
31int roar_stream_new (struct roar_stream * s, unsigned int rate,
32                     unsigned int channels, unsigned int bits, unsigned int codec) {
33
34
35 s->fh         = -1;
36 s->id         = -1;
37 s->pos        = 0;
38 s->pos_rel_id = -1;
39
40 s->dir        = ROAR_DIR_DEFAULT;
41
42 s->datalen    = 0;
43 s->offset     = 0;
44
45 s->database   = NULL;
46 s->dataoff    = NULL;
47
48 s->info.rate     = rate;
49 s->info.channels = channels;
50 s->info.bits     = bits;
51 s->info.codec    = codec;
52
53 if ( bits > ROAR_BITS_MAX )
54  return -1;
55
56 return 0;
57}
58
59int roar_stream_exec    (struct roar_connection * con, struct roar_stream * s) {
60 struct roar_message m;
61
62 m.cmd     = ROAR_CMD_EXEC_STREAM;
63 m.stream  = s->id;
64 m.datalen = 0;
65 m.pos     = 0;
66
67 if ( roar_req(con, &m, NULL) == -1 )
68  return -1;
69
70 if ( m.cmd == ROAR_CMD_OK )
71  return 0;
72 return -1;
73}
74
75int roar_stream_connect_to (struct roar_connection * con, struct roar_stream * s, int type, char * host, int port) {
76 struct roar_message m;
77
78 if ( roar_stream_connect_to_ask(con, s, type, host, port) == -1 )
79  return -1;
80
81 if ( roar_recv_message(con, &m, NULL) == -1 )
82  return -1;
83
84 if ( m.cmd == ROAR_CMD_OK )
85  return 0;
86 return -1;
87}
88
89int roar_stream_connect_to_ask (struct roar_connection * con, struct roar_stream * s, int type, char * host, int port) {
90 struct roar_message m;
91 int len = 0;
92
93 if ( host == NULL )
94  return -1;
95
96 ROAR_DBG("roar_stream_connect_to_ask(*): Ask the server to connect to: %s:%i", host, port);
97
98 m.cmd     = ROAR_CMD_CON_STREAM;
99 m.stream  = s->id;
100 m.pos     = 0;
101
102 m.data[0] = 0;
103 m.data[1] = type;
104 ((uint16_t*)&(m.data))[1] = ROAR_HOST2NET16(port);
105
106 len = strlen(host);
107
108 if ( len > 76 )
109  return -1;
110
111 strncpy(&(m.data[4]), host, len);
112
113 m.datalen = len + 4;
114
115 if ( roar_send_message(con, &m, NULL) == -1 )
116  return -1;
117
118 return 0;
119}
120
121int roar_stream_add_data (struct roar_connection * con, struct roar_stream * s, char * data, size_t len) {
122 struct roar_message m;
123
124 m.cmd     = ROAR_CMD_ADD_DATA;
125 m.stream  = s->id;
126 m.pos     = 0;
127 m.datalen = len;
128
129// if ( roar_req(con, &m, (void**)&data) == -1 )
130//  return -1;
131 if ( roar_send_message(con, &m, data) != 0 )
132  return -1;
133
134 if ( roar_recv_message(con, &m, NULL) == -1 )
135  return -1;
136
137 if ( m.cmd == ROAR_CMD_OK )
138  return 0;
139 return -1;
140}
141
142int roar_stream_get_info (struct roar_connection * con, struct roar_stream * s, struct roar_stream_info * info) {
143 struct roar_message m;
144 uint16_t * data = (uint16_t *) m.data;
145 int i;
146
147 m.cmd     = ROAR_CMD_GET_STREAM_PARA;
148 m.stream  = s->id;
149 m.datalen = 4;
150 m.pos     = 0;
151
152 data[0] = 0; // Version and reserved
153 data[1] = 1; // stream
154
155 for (i = 0; i < m.datalen/2; i++) {
156  data[i] = ROAR_HOST2NET16(data[i]);
157 }
158
159 if ( roar_req(con, &m, NULL) == -1 )
160  return -1;
161
162 if ( m.cmd != ROAR_CMD_OK )
163  return -1;
164
165 for (i = 0; i < m.datalen/2; i++) {
166  data[i] = ROAR_NET2HOST16(data[i]);
167 }
168
169 if ( m.datalen < 3*2 )
170  return -1;
171
172 if ( data[0] != 0 || data[1] != 1 )
173  return -1;
174
175 info->block_size     = data[2];
176 info->pre_underruns  = data[3];
177 info->post_underruns = data[4];
178
179 return 0;
180}
181
182#define _ROAR_STREAM_MESSAGE_LEN ((5+1)*4)
183
184int roar_stream_s2m     (struct roar_stream * s, struct roar_message * m) {
185 uint32_t * data;
186 int i;
187
188 if ( !(s && m) )
189  return -1;
190
191 m->datalen = _ROAR_STREAM_MESSAGE_LEN;
192 data = (uint32_t*) m->data;
193
194 data[0] = s->dir;
195 data[1] = s->pos_rel_id;
196 data[2] = s->info.rate;
197 data[3] = s->info.bits;
198 data[4] = s->info.channels;
199 data[5] = s->info.codec;
200
201 for (i = 0; i < _ROAR_STREAM_MESSAGE_LEN/4; i++)
202  data[i] = ROAR_HOST2NET32(data[i]);
203
204 ROAR_DBG("roar_stream_s2m(*): s->info:");
205 roar_debug_audio_info_print(&s->info);
206
207 return 0;
208}
209int roar_stream_m2s     (struct roar_stream * s, struct roar_message * m) {
210 uint32_t * data;
211 int i;
212
213 if ( !(s && m) )
214  return -1;
215
216 if ( m->datalen != _ROAR_STREAM_MESSAGE_LEN )
217  return -1;
218
219 data = (uint32_t*) m->data;
220
221 for (i = 0; i < _ROAR_STREAM_MESSAGE_LEN/4; i++)
222  data[i] = ROAR_NET2HOST32(data[i]);
223
224 s->id            = m->stream;
225 s->dir           = data[0];
226 s->pos_rel_id    = data[1];
227 s->info.rate     = data[2];
228 s->info.bits     = data[3];
229 s->info.channels = data[4];
230 s->info.codec    = data[5];
231
232 ROAR_DBG("roar_stream_m2s(*): s->info:");
233 roar_debug_audio_info_print(&s->info);
234
235 return 0;
236}
237
238//ll
Note: See TracBrowser for help on using the repository browser.