source: roaraudio/roard/driver.c @ 912:e0480ffcba74

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

got esd driver working via vio, changed driver interface a bit to get a memory leak away

File size: 4.1 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#ifdef ROAR_HAVE_LIBAO
35 { "ao", "libao audio driver", "DRIVER", driver_ao_open, driver_ao_close, driver_ao_pause, driver_ao_write, driver_ao_read, driver_ao_flush, NULL},
36#endif
37 {NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL} // end of list
38                                };
39
40void print_driverlist (void) {
41 int i;
42
43 for (i = 0; g_driver[i].name != NULL; i++) {
44  printf("  %-8s - %s (devices: %s)\n", g_driver[i].name, g_driver[i].desc, g_driver[i].devices);
45 }
46}
47
48int driver_open (DRIVER_USERDATA_T * inst, int * driver_id, char * driver, char * device, struct roar_audio_info * info) {
49 int i;
50
51 if ( driver == NULL )
52  driver = ROAR_DRIVER_DEFAULT;
53
54 for (i = 0; g_driver[i].name != NULL; i++) {
55  if ( strcmp(g_driver[i].name, driver) == 0 ) {
56   ROAR_DBG("driver_open(*): found driver: id = %i", i);
57
58   *driver_id = i;
59
60   if ( g_driver[i].vio_init != NULL ) {
61    if ( (*inst = malloc(sizeof(struct roar_vio_calls))) == NULL )
62     return -1;
63
64    memset(*inst, 0, sizeof(struct roar_vio_calls));
65
66    if ( (i = g_driver[i].vio_init(*inst, device, info)) == -1 ) {
67     free(*inst);
68     return -1;
69    }
70    return i;
71   }
72
73   ROAR_WARN("driver_open(*): driver uses old non-vio interface!");
74
75   if ( g_driver[i].open )
76    return g_driver[i].open(inst, device, info);
77   return 0;
78  }
79 }
80
81 return -1;
82}
83
84int driver_close(DRIVER_USERDATA_T   inst, int driver) {
85 int ret = 0;
86 ROAR_DBG("driver_close(inst=%p, driver=%i) = ?", inst, driver);
87
88 if ( driver == -1 )
89  return -1;
90
91 if ( g_driver[driver].close )
92  ret = g_driver[driver].close(inst);
93
94 if ( g_driver[driver].vio_init != NULL )
95  free(inst);
96
97 return ret;
98}
99
100int driver_pause(DRIVER_USERDATA_T   inst, int driver, int newstate) {
101 if ( driver == -1 )
102  return -1;
103
104 if ( g_driver[driver].pause )
105  return g_driver[driver].pause(inst, newstate);
106
107 return 0;
108}
109
110int driver_write(DRIVER_USERDATA_T   inst, int driver, char * buf, int len) {
111 if ( driver == -1 )
112  return -1;
113
114 if ( g_driver[driver].vio_init != NULL )
115  return roar_vio_write((struct roar_vio_calls *) inst, buf, len);
116
117 if ( g_driver[driver].write )
118  return g_driver[driver].write(inst, buf, len);
119
120 return 0;
121}
122
123int driver_read (DRIVER_USERDATA_T   inst, int driver, char * buf, int len) {
124 if ( driver == -1 )
125  return -1;
126
127 if ( g_driver[driver].vio_init != NULL )
128  return roar_vio_read((struct roar_vio_calls *) inst, buf, len);
129
130 if ( g_driver[driver].read )
131  return g_driver[driver].read(inst, buf, len);
132
133 return 0;
134}
135
136int driver_flush(DRIVER_USERDATA_T   inst, int driver) {
137 if ( driver == -1 )
138  return -1;
139
140 if ( g_driver[driver].flush )
141  return g_driver[driver].flush(inst);
142
143 return 0;
144}
145
146//ll
Note: See TracBrowser for help on using the repository browser.