source: roaraudio/roard/driver.c @ 947:edb7ba2fe666

Last change on this file since 947:edb7ba2fe666 was 947:edb7ba2fe666, checked in by phi, 15 years ago

changed raw driver to use vio interface and display sysio vs. vio in driver list

File size: 6.0 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", NULL, driver_raw_close, driver_roar_pause, NULL, NULL, driver_raw_flush, driver_raw_open_vio},
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 %c%c - %s (devices: %s)\n", g_driver[i].name,
51                g_driver[i].open     != NULL || (g_driver[i].open == NULL && g_driver[i].vio_init == NULL) ? 'S' : ' ',
52                g_driver[i].vio_init != NULL || (g_driver[i].open == NULL && g_driver[i].vio_init == NULL) ? 'V' : ' ',
53                g_driver[i].desc, g_driver[i].devices);
54 }
55}
56
57int driver_open (DRIVER_USERDATA_T * inst, int * driver_id, char * driver, char * device, struct roar_audio_info * info) {
58 int i;
59
60 if ( driver == NULL )
61  driver = ROAR_DRIVER_DEFAULT;
62
63 for (i = 0; g_driver[i].name != NULL; i++) {
64  if ( strcmp(g_driver[i].name, driver) == 0 ) {
65   ROAR_DBG("driver_open(*): found driver: id = %i", i);
66
67   *driver_id = i;
68
69   if ( g_driver[i].vio_init != NULL ) {
70    if ( (*inst = malloc(sizeof(struct roar_vio_calls))) == NULL )
71     return -1;
72
73    memset(*inst, 0, sizeof(struct roar_vio_calls));
74
75    if ( (i = g_driver[i].vio_init(*inst, device, info, -1)) == -1 ) {
76     free(*inst);
77     return -1;
78    }
79    return i;
80   }
81
82   if ( g_driver[i].open ) {
83    ROAR_WARN("driver_open(*): driver(%s) uses old non-vio interface!", driver);
84    return g_driver[i].open(inst, device, info);
85   }
86
87   return 0;
88  }
89 }
90
91 return -1;
92}
93
94int driver_openvio(struct roar_vio_calls * calls,
95                 int * driver_id, char * driver /* NOTE: this is not part of struct roar_driver's def! */,
96                 char * device, struct roar_audio_info * info, int fh) {
97 int i;
98
99 if ( driver == NULL )
100  driver = ROAR_DRIVER_DEFAULT;
101
102 for (i = 0; g_driver[i].name != NULL; i++) {
103  if ( strcmp(g_driver[i].name, driver) == 0 ) {
104   ROAR_DBG("driver_open(*): found driver: id = %i", i);
105
106   *driver_id = i;
107
108   if ( g_driver[i].vio_init == NULL ) {
109    if ( g_driver[i].open == NULL ) { // this is the null driver
110     memset(calls, 0, sizeof(struct roar_vio_calls));
111     calls->read  = roar_vio_null_rw;
112     calls->write = roar_vio_null_rw;
113     return 0;
114    }
115
116    ROAR_WARN("driver_open(*): driver(%s) uses old non-vio interface!", driver);
117    ROAR_ERR("driver_openvio(calls=%p, driver_id={%i}, driver='%s', device='%s', info=%p, fh=%i): not a VIO driver!",
118        calls, i, driver, device, info, fh);
119    return -1;
120   }
121
122   return g_driver[i].vio_init(calls, device, info, fh);
123  }
124 }
125 return -1;
126}
127
128int driver_close(DRIVER_USERDATA_T   inst, int driver) {
129 int ret = 0;
130 ROAR_DBG("driver_close(inst=%p, driver=%i) = ?", inst, driver);
131
132 if ( driver == -1 )
133  return -1;
134
135 if ( g_driver[driver].close )
136  ret = g_driver[driver].close(inst);
137
138 if ( g_driver[driver].vio_init != NULL )
139  free(inst);
140
141 return ret;
142}
143
144int driver_closevio(struct roar_vio_calls * calls, int driver) {
145 ROAR_DBG("driver_closevio(calls=%p, driver=%i) = ?", calls, driver);
146
147 if ( driver == -1 )
148  return -1;
149
150 if ( g_driver[driver].close )
151  return g_driver[driver].close((DRIVER_USERDATA_T)calls);
152
153 return 0;
154}
155
156int driver_pause(DRIVER_USERDATA_T   inst, int driver, int newstate) {
157 if ( driver == -1 )
158  return -1;
159
160 if ( g_driver[driver].pause )
161  return g_driver[driver].pause(inst, newstate);
162
163 return 0;
164}
165
166int driver_write(DRIVER_USERDATA_T   inst, int driver, char * buf, int len) {
167 if ( driver == -1 )
168  return -1;
169
170 if ( g_driver[driver].vio_init != NULL )
171  return roar_vio_write((struct roar_vio_calls *) inst, buf, len);
172
173 if ( g_driver[driver].write )
174  return g_driver[driver].write(inst, buf, len);
175
176 return 0;
177}
178
179int driver_read (DRIVER_USERDATA_T   inst, int driver, char * buf, int len) {
180 if ( driver == -1 )
181  return -1;
182
183 if ( g_driver[driver].vio_init != NULL )
184  return roar_vio_read((struct roar_vio_calls *) inst, buf, len);
185
186 if ( g_driver[driver].read )
187  return g_driver[driver].read(inst, buf, len);
188
189 return 0;
190}
191
192int driver_flush(DRIVER_USERDATA_T   inst, int driver) {
193 if ( driver == -1 )
194  return -1;
195
196 if ( g_driver[driver].flush )
197  return g_driver[driver].flush(inst);
198
199 return 0;
200}
201
202//ll
Note: See TracBrowser for help on using the repository browser.