source: roaraudio/libroarlight/roardmx.c @ 1959:06366789e3a5

Last change on this file since 1959:06366789e3a5 was 1959:06366789e3a5, checked in by phi, 15 years ago

small optimations, wrote roar_roardmx_message_get_chanval() and roar_roardmx_message_numchannels()

File size: 4.6 KB
Line 
1//roardmx.c:
2
3/*
4 *      Copyright (C) Philipp 'ph3-der-loewe' Schafft - 2009
5 *
6 *  This file is part of libroardsp a part of RoarAudio,
7 *  a cross-platform sound system for both, home and professional use.
8 *  See README for details.
9 *
10 *  This file is free software; you can redistribute it and/or modify
11 *  it under the terms of the GNU General Public License version 3
12 *  as published by the Free Software Foundation.
13 *
14 *  libroardsp is distributed in the hope that it will be useful,
15 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
16 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17 *  GNU General Public License for more details.
18 *
19 *  You should have received a copy of the GNU General Public License
20 *  along with this software; see the file COPYING.  If not, write to
21 *  the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
22 *
23 */
24
25#include "libroarlight.h"
26
27// base(ic) check
28#define BCHK(x) if ( (x) == NULL ) return -1
29
30int roar_roardmx_message_new (struct roar_roardmx_message * mes) {
31 BCHK(mes);
32
33 memset(mes, 0, sizeof(struct roar_roardmx_message));
34
35 mes->version = ROAR_ROARDMX_VERSION;
36
37 return 0;
38}
39
40// low level:
41//int roar_roardmx_message_set_flag(struct roar_roardmx_message * mes, unsigned char   flag);
42//int roar_roardmx_message_set_len (struct roar_roardmx_message * mes, size_t          type);
43//int roar_roardmx_message_get_data(struct roar_roardmx_message * mes, unsigned char ** data);
44
45// mdium level:
46int roar_roardmx_message_set_type(struct roar_roardmx_message * mes, unsigned char   type) {
47 BCHK(mes);
48
49 if ( (type | ROAR_ROARDMX_MASK_TYPE) - ROAR_ROARDMX_MASK_TYPE )
50  return -1;
51
52 mes->type = type;
53
54 return 0;
55}
56
57int roar_roardmx_message_get_flag(struct roar_roardmx_message * mes, unsigned char * flag) {
58 BCHK(mes);
59
60 *flag = mes->flags;
61
62 return 0;
63}
64
65int roar_roardmx_message_get_type(struct roar_roardmx_message * mes, unsigned char * type) {
66 BCHK(mes);
67
68 *type = mes->type;
69
70 return 0;
71}
72
73int roar_roardmx_message_get_len (struct roar_roardmx_message * mes, size_t        * length) {
74 BCHK(mes);
75
76 *length = mes->length;
77
78 return 0;
79}
80
81
82// IO:
83int roar_roardmx_message_send(struct roar_roardmx_message * mes, struct roar_vio_calls * vio) {
84 BCHK(mes);
85 BCHK(vio);
86
87 if ( mes->length > ROAR_ROARDMX_DATA_LENGTH ) // this is very fatal!
88  return -1;
89
90 mes->data[0] =  mes->version;
91 mes->data[1] = (mes->flags & ROAR_ROARDMX_MASK_FLAGS) |
92                (mes->type  & ROAR_ROARDMX_MASK_TYPE ) ;
93
94 mes->data[2] = mes->length;
95
96 return roar_vio_write(vio, mes->data, mes->length + 3) == (mes->length + 3) ? 0 : -1;
97}
98
99int roar_roardmx_message_recv(struct roar_roardmx_message * mes, struct roar_vio_calls * vio) {
100 BCHK(mes);
101 BCHK(vio);
102
103 if ( roar_vio_read(vio, mes->data, 3) != 3 )
104  return -1;
105
106 mes->version = mes->data[0];
107
108 if ( mes->version != 0 )
109  return -1;
110
111 mes->flags  = mes->data[1] & ROAR_ROARDMX_MASK_FLAGS;
112 mes->type   = mes->data[1] & ROAR_ROARDMX_MASK_TYPE;
113
114 mes->length = mes->data[3];
115
116 if ( roar_vio_read(vio, &(mes->data[3]), mes->length) != mes->length )
117  return -1;
118
119 return 0;
120}
121
122// Data/high level:
123// * SSET:
124int roar_roardmx_message_new_sset   (struct roar_roardmx_message * mes) {
125 if ( roar_roardmx_message_new(mes) == -1 )
126  return -1;
127
128 mes->type = ROAR_ROARDMX_TYPE_SSET;
129
130 return 0;
131}
132
133int roar_roardmx_message_add_chanval(struct roar_roardmx_message * mes, uint16_t channel, unsigned char val) {
134 register uint16_t * chan;
135
136 BCHK(mes);
137
138 if ( (mes->length + 3) > ROAR_ROARDMX_DATA_LENGTH ) // message would be to long
139  return -1;
140
141 chan = (uint16_t *) &(mes->data[mes->length + 3]);
142
143 *chan = ROAR_HOST2NET16(channel);
144
145 mes->data[mes->length + 2 + 3] = val;
146
147 mes->length += 3;
148
149 return 0;
150}
151
152int roar_roardmx_message_get_chanval(struct roar_roardmx_message * mes, uint16_t * channel, unsigned char * val, int index) {
153 register uint16_t * chan;
154
155 BCHK(mes);
156
157 if ( index < 0 )
158  return -1;
159
160 if ( mes->version != 0 )
161  return -1;
162
163 switch (mes->type) {
164  case ROAR_ROARDMX_TYPE_SSET:
165  case ROAR_ROARDMX_TYPE_INC8S:
166    if ( index >= (ROAR_ROARDMX_DATA_LENGTH/3) )
167     return -1;
168
169    *val     = mes->data[3 * index + 2 + 3];
170    chan     = (uint16_t *) &(mes->data[3 + 3 * index]);
171    *channel = ROAR_NET2HOST16(*chan);
172   break;
173 }
174
175 return -1;
176}
177
178int roar_roardmx_message_numchannels(struct roar_roardmx_message * mes) {
179 BCHK(mes);
180
181 if ( mes->version != 0 )
182  return -1;
183
184 switch (mes->type) {
185  case ROAR_ROARDMX_TYPE_SSET:
186  case ROAR_ROARDMX_TYPE_INC8S:
187    return mes->length /  3;
188   break;
189  case ROAR_ROARDMX_TYPE_IPO1:
190    return mes->length /  6;
191   break;
192  case ROAR_ROARDMX_TYPE_IPO4:
193    return mes->length / 12;
194   break;
195 }
196
197 return -1;
198}
199
200//ll
Note: See TracBrowser for help on using the repository browser.