source: roaraudio/roard/driver.c @ 944:64b819ce2b96

Last change on this file since 944:64b819ce2b96 was 944:64b819ce2b96, checked in by phi, 15 years ago

ported null driver to vio

File size: 5.7 KB
Line 
1//driver.c:
2
3/*
4 *      Copyright (C) Philipp 'ph3-der-loewe' Schafft - 2008
5 *
6 *  This file is part of roard 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 *  RoarAudio 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 "roard.h"
26
27struct roar_driver g_driver[] = {
28 { "null", "null audio driver", "/dev/null", NULL, NULL, NULL, NULL, NULL, NULL, NULL},
29#ifdef ROAR_HAVE_ESD
30 { "esd", "EsounD audio driver", "localhost, remote.host.dom", NULL, driver_esd_close, driver_esd_pause, NULL, NULL, driver_esd_flush, driver_esd_open_vio},
31#endif
32 { "roar", "RoarAudio driver", "localhost, remote.host.dom", driver_roar_open, driver_roar_close, driver_roar_pause, driver_roar_write, driver_roar_read, driver_roar_flush, NULL},
33 { "raw",  "RAW PCM driver", "/some/file", driver_raw_open, driver_raw_close, driver_roar_pause, driver_raw_write, driver_raw_read, driver_raw_flush, NULL},
34#if defined(ROAR_HAVE_OSS_BSD) || defined(ROAR_HAVE_OSS)
35#ifndef ROAR_DEFAULT_OSS_DEV
36#define ROAR_DEFAULT_OSS_DEV "no default device"
37#endif
38 { "oss", "Open Sound System", ROAR_DEFAULT_OSS_DEV, NULL, driver_oss_close, NULL, NULL, NULL, NULL, driver_oss_open},
39#endif
40#ifdef ROAR_HAVE_LIBAO
41 { "ao", "libao audio driver", "DRIVER", driver_ao_open, driver_ao_close, driver_ao_pause, driver_ao_write, driver_ao_read, driver_ao_flush, NULL},
42#endif
43 {NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL} // end of list
44                                };
45
46void print_driverlist (void) {
47 int i;
48
49 for (i = 0; g_driver[i].name != NULL; i++) {
50  printf("  %-8s - %s (devices: %s)\n", g_driver[i].name, g_driver[i].desc, g_driver[i].devices);
51 }
52}
53
54int driver_open (DRIVER_USERDATA_T * inst, int * driver_id, char * driver, char * device, struct roar_audio_info * info) {
55 int i;
56
57 if ( driver == NULL )
58  driver = ROAR_DRIVER_DEFAULT;
59
60 for (i = 0; g_driver[i].name != NULL; i++) {
61  if ( strcmp(g_driver[i].name, driver) == 0 ) {
62   ROAR_DBG("driver_open(*): found driver: id = %i", i);
63
64   *driver_id = i;
65
66   if ( g_driver[i].vio_init != NULL ) {
67    if ( (*inst = malloc(sizeof(struct roar_vio_calls))) == NULL )
68     return -1;
69
70    memset(*inst, 0, sizeof(struct roar_vio_calls));
71
72    if ( (i = g_driver[i].vio_init(*inst, device, info, -1)) == -1 ) {
73     free(*inst);
74     return -1;
75    }
76    return i;
77   }
78
79   if ( g_driver[i].open ) {
80    ROAR_WARN("driver_open(*): driver(%s) uses old non-vio interface!", driver);
81    return g_driver[i].open(inst, device, info);
82   }
83
84   return 0;
85  }
86 }
87
88 return -1;
89}
90
91int driver_openvio(struct roar_vio_calls * calls,
92                 int * driver_id, char * driver /* NOTE: this is not part of struct roar_driver's def! */,
93                 char * device, struct roar_audio_info * info, int fh) {
94 int i;
95
96 if ( driver == NULL )
97  driver = ROAR_DRIVER_DEFAULT;
98
99 for (i = 0; g_driver[i].name != NULL; i++) {
100  if ( strcmp(g_driver[i].name, driver) == 0 ) {
101   ROAR_DBG("driver_open(*): found driver: id = %i", i);
102
103   *driver_id = i;
104
105   if ( g_driver[i].vio_init == NULL ) {
106    if ( g_driver[i].open == NULL ) { // this is the null driver
107     memset(calls, 0, sizeof(struct roar_vio_calls));
108     calls->read  = roar_vio_null_rw;
109     calls->write = roar_vio_null_rw;
110     return 0;
111    }
112
113    ROAR_WARN("driver_open(*): driver(%s) uses old non-vio interface!", driver);
114    ROAR_ERR("driver_openvio(calls=%p, driver_id={%i}, driver='%s', device='%s', info=%p, fh=%i): not a VIO driver!",
115        calls, i, driver, device, info, fh);
116    return -1;
117   }
118
119   return g_driver[i].vio_init(calls, device, info, fh);
120  }
121 }
122 return -1;
123}
124
125int driver_close(DRIVER_USERDATA_T   inst, int driver) {
126 int ret = 0;
127 ROAR_DBG("driver_close(inst=%p, driver=%i) = ?", inst, driver);
128
129 if ( driver == -1 )
130  return -1;
131
132 if ( g_driver[driver].close )
133  ret = g_driver[driver].close(inst);
134
135 if ( g_driver[driver].vio_init != NULL )
136  free(inst);
137
138 return ret;
139}
140
141int driver_closevio(struct roar_vio_calls * calls, int driver) {
142 ROAR_DBG("driver_closevio(calls=%p, driver=%i) = ?", calls, driver);
143
144 if ( driver == -1 )
145  return -1;
146
147 if ( g_driver[driver].close )
148  return g_driver[driver].close((DRIVER_USERDATA_T)calls);
149
150 return 0;
151}
152
153int driver_pause(DRIVER_USERDATA_T   inst, int driver, int newstate) {
154 if ( driver == -1 )
155  return -1;
156
157 if ( g_driver[driver].pause )
158  return g_driver[driver].pause(inst, newstate);
159
160 return 0;
161}
162
163int driver_write(DRIVER_USERDATA_T   inst, int driver, char * buf, int len) {
164 if ( driver == -1 )
165  return -1;
166
167 if ( g_driver[driver].vio_init != NULL )
168  return roar_vio_write((struct roar_vio_calls *) inst, buf, len);
169
170 if ( g_driver[driver].write )
171  return g_driver[driver].write(inst, buf, len);
172
173 return 0;
174}
175
176int driver_read (DRIVER_USERDATA_T   inst, int driver, char * buf, int len) {
177 if ( driver == -1 )
178  return -1;
179
180 if ( g_driver[driver].vio_init != NULL )
181  return roar_vio_read((struct roar_vio_calls *) inst, buf, len);
182
183 if ( g_driver[driver].read )
184  return g_driver[driver].read(inst, buf, len);
185
186 return 0;
187}
188
189int driver_flush(DRIVER_USERDATA_T   inst, int driver) {
190 if ( driver == -1 )
191  return -1;
192
193 if ( g_driver[driver].flush )
194  return g_driver[driver].flush(inst);
195
196 return 0;
197}
198
199//ll
Note: See TracBrowser for help on using the repository browser.