source: roaraudio/roard/driver_pwmled.c @ 1987:32d935a33fca

Last change on this file since 1987:32d935a33fca was 1987:32d935a33fca, checked in by phi, 15 years ago

accept ROAR_VIO_CTL_SET_DMXSCHAN

File size: 3.2 KB
Line 
1//driver_pwmled.c:
2
3/*
4 *      Copyright (C) Philipp 'ph3-der-loewe' Schafft - 2009
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
27int driver_pwmled_open_vio  (struct roar_vio_calls * inst, char * device, struct roar_audio_info * info, int fh) {
28 struct roar_vio_defaults def;
29 struct driver_pwmled * self = malloc(sizeof(struct driver_pwmled));
30
31 if ( self == NULL )
32  return -1;
33
34 if ( fh == -1 ) {
35  if ( device == NULL )
36   device = "/dev/ttyS0";
37
38  if ( roar_vio_dstr_init_defaults(&def, ROAR_VIO_DEF_TYPE_NONE, O_WRONLY, 0644) == -1 ) {
39   free(self);
40   return -1;
41  }
42
43  if ( roar_vio_open_dstr(&(self->vio), device, &def, 1) == -1 ) {
44   free(self);
45   return -1;
46  }
47
48  inst->inst = self;
49 } else {
50/*
51  if ( roar_vio_open_fh(inst, fh) == -1 )
52   return -1;
53*/
54  free(self);
55  return -1;
56 }
57
58 inst->read     = NULL;
59 inst->write    = driver_pwmled_write;
60 inst->lseek    = NULL;
61 inst->nonblock = NULL;
62 inst->sync     = NULL;
63 inst->ctl      = driver_pwmled_ctl;
64 inst->close    = driver_pwmled_close;
65
66 info->codec = ROAR_CODEC_DMX512;
67
68 if ( info->rate == g_sa->rate ) {
69  self->rate = 9600;
70 } else {
71  self->rate = info->rate;
72 }
73
74 self->channel = 0;
75
76 if ( roar_light_pwm_new(&(self->state), 16) == -1 ) {
77  free(self);
78  return -1;
79 }
80
81 return 0;
82}
83
84int     driver_pwmled_close (struct roar_vio_calls * vio) {
85 int ret = roar_vio_close(&(((struct driver_pwmled*)(vio->inst))->vio));
86
87 if ( vio->inst != NULL )
88  free(vio->inst);
89
90 return ret;
91}
92
93// TODO: this function should be optimized.
94ssize_t driver_pwmled_write (struct roar_vio_calls * vio,  void *buf, size_t count) {
95 struct driver_pwmled * self = vio->inst;
96
97 if ( vio == NULL || buf == NULL )
98  return -1;
99
100 if ( count != 512 )
101  return -1;
102
103 if ( roar_light_pwm_set(&(self->state), ((unsigned char*)buf)[self->channel] / 16) == -1 )
104  return -1;
105
106                                                                    // bit per word, bit per byte
107 return roar_light_pwm_send(&(self->state), &(self->vio), self->rate/11/8/100) == 0 ? count : -1;
108}
109
110int driver_pwmled_ctl(struct roar_vio_calls * vio, int cmd, void * data) {
111
112 if ( vio == NULL )
113  return -1;
114
115 switch (cmd) {
116  case ROAR_VIO_CTL_SET_SSTREAM:
117    ROAR_STREAM(data)->dir = ROAR_DIR_LIGHT_OUT;
118    ROAR_STREAM_SERVER(data)->codec_orgi = ROAR_CODEC_DMX512;
119   break;
120  case ROAR_VIO_CTL_SET_DMXSCHAN:
121    self->channel = *(uint16_t*)data;
122   break;
123  default:
124   return -1;
125 }
126
127 return 0;
128}
129
130//ll
Note: See TracBrowser for help on using the repository browser.