2 * sh_dac_audio.c - SuperH DAC audio driver for ALSA
4 * Copyright (c) 2009 by Rafael Ignacio Zurita <rizurita@yahoo.com>
7 * Based on sh_dac_audio.c (Copyright (C) 2004, 2005 by Andriy Skulysh)
9 * This program is free software; you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation; either version 2 of the License, or
12 * (at your option) any later version.
14 * This program 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.
19 * You should have received a copy of the GNU General Public License
20 * along with this program; if not, write to the Free Software
21 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
25 #include <linux/hrtimer.h>
26 #include <linux/interrupt.h>
28 #include <linux/platform_device.h>
29 #include <linux/slab.h>
30 #include <linux/module.h>
31 #include <sound/core.h>
32 #include <sound/initval.h>
33 #include <sound/pcm.h>
34 #include <sound/sh_dac_audio.h>
35 #include <asm/clock.h>
36 #include <asm/hd64461.h>
37 #include <mach/hp6xx.h>
40 MODULE_AUTHOR("Rafael Ignacio Zurita <rizurita@yahoo.com>");
41 MODULE_DESCRIPTION("SuperH DAC audio driver");
42 MODULE_LICENSE("GPL");
43 MODULE_SUPPORTED_DEVICE("{{SuperH DAC audio support}}");
45 /* Module Parameters */
46 static int index
= SNDRV_DEFAULT_IDX1
;
47 static char *id
= SNDRV_DEFAULT_STR1
;
48 module_param(index
, int, 0444);
49 MODULE_PARM_DESC(index
, "Index value for SuperH DAC audio.");
50 module_param(id
, charp
, 0444);
51 MODULE_PARM_DESC(id
, "ID string for SuperH DAC audio.");
55 struct snd_card
*card
;
56 struct snd_pcm_substream
*substream
;
57 struct hrtimer hrtimer
;
58 ktime_t wakeups_per_second
;
62 char *data_buffer
, *buffer_begin
, *buffer_end
;
63 int processed
; /* bytes proccesed, to compare with period_size */
65 struct dac_audio_pdata
*pdata
;
69 static void dac_audio_start_timer(struct snd_sh_dac
*chip
)
71 hrtimer_start(&chip
->hrtimer
, chip
->wakeups_per_second
,
75 static void dac_audio_stop_timer(struct snd_sh_dac
*chip
)
77 hrtimer_cancel(&chip
->hrtimer
);
80 static void dac_audio_reset(struct snd_sh_dac
*chip
)
82 dac_audio_stop_timer(chip
);
83 chip
->buffer_begin
= chip
->buffer_end
= chip
->data_buffer
;
88 static void dac_audio_set_rate(struct snd_sh_dac
*chip
)
90 chip
->wakeups_per_second
= ktime_set(0, 1000000000 / chip
->rate
);
96 static struct snd_pcm_hardware snd_sh_dac_pcm_hw
= {
97 .info
= (SNDRV_PCM_INFO_MMAP
|
98 SNDRV_PCM_INFO_MMAP_VALID
|
99 SNDRV_PCM_INFO_INTERLEAVED
|
100 SNDRV_PCM_INFO_HALF_DUPLEX
),
101 .formats
= SNDRV_PCM_FMTBIT_U8
,
102 .rates
= SNDRV_PCM_RATE_8000
,
107 .buffer_bytes_max
= (48*1024),
108 .period_bytes_min
= 1,
109 .period_bytes_max
= (48*1024),
114 static int snd_sh_dac_pcm_open(struct snd_pcm_substream
*substream
)
116 struct snd_sh_dac
*chip
= snd_pcm_substream_chip(substream
);
117 struct snd_pcm_runtime
*runtime
= substream
->runtime
;
119 runtime
->hw
= snd_sh_dac_pcm_hw
;
121 chip
->substream
= substream
;
122 chip
->buffer_begin
= chip
->buffer_end
= chip
->data_buffer
;
126 chip
->pdata
->start(chip
->pdata
);
131 static int snd_sh_dac_pcm_close(struct snd_pcm_substream
*substream
)
133 struct snd_sh_dac
*chip
= snd_pcm_substream_chip(substream
);
135 chip
->substream
= NULL
;
137 dac_audio_stop_timer(chip
);
138 chip
->pdata
->stop(chip
->pdata
);
143 static int snd_sh_dac_pcm_hw_params(struct snd_pcm_substream
*substream
,
144 struct snd_pcm_hw_params
*hw_params
)
146 return snd_pcm_lib_malloc_pages(substream
,
147 params_buffer_bytes(hw_params
));
150 static int snd_sh_dac_pcm_hw_free(struct snd_pcm_substream
*substream
)
152 return snd_pcm_lib_free_pages(substream
);
155 static int snd_sh_dac_pcm_prepare(struct snd_pcm_substream
*substream
)
157 struct snd_sh_dac
*chip
= snd_pcm_substream_chip(substream
);
158 struct snd_pcm_runtime
*runtime
= chip
->substream
->runtime
;
160 chip
->buffer_size
= runtime
->buffer_size
;
161 memset(chip
->data_buffer
, 0, chip
->pdata
->buffer_size
);
166 static int snd_sh_dac_pcm_trigger(struct snd_pcm_substream
*substream
, int cmd
)
168 struct snd_sh_dac
*chip
= snd_pcm_substream_chip(substream
);
171 case SNDRV_PCM_TRIGGER_START
:
172 dac_audio_start_timer(chip
);
174 case SNDRV_PCM_TRIGGER_STOP
:
175 chip
->buffer_begin
= chip
->buffer_end
= chip
->data_buffer
;
178 dac_audio_stop_timer(chip
);
187 static int snd_sh_dac_pcm_copy(struct snd_pcm_substream
*substream
, int channel
,
188 snd_pcm_uframes_t pos
, void __user
*src
, snd_pcm_uframes_t count
)
190 /* channel is not used (interleaved data) */
191 struct snd_sh_dac
*chip
= snd_pcm_substream_chip(substream
);
192 struct snd_pcm_runtime
*runtime
= substream
->runtime
;
193 ssize_t b_count
= frames_to_bytes(runtime
, count
);
194 ssize_t b_pos
= frames_to_bytes(runtime
, pos
);
202 memcpy_toio(chip
->data_buffer
+ b_pos
, src
, b_count
);
203 chip
->buffer_end
= chip
->data_buffer
+ b_pos
+ b_count
;
207 dac_audio_start_timer(chip
);
213 static int snd_sh_dac_pcm_silence(struct snd_pcm_substream
*substream
,
214 int channel
, snd_pcm_uframes_t pos
,
215 snd_pcm_uframes_t count
)
217 /* channel is not used (interleaved data) */
218 struct snd_sh_dac
*chip
= snd_pcm_substream_chip(substream
);
219 struct snd_pcm_runtime
*runtime
= substream
->runtime
;
220 ssize_t b_count
= frames_to_bytes(runtime
, count
);
221 ssize_t b_pos
= frames_to_bytes(runtime
, pos
);
229 memset_io(chip
->data_buffer
+ b_pos
, 0, b_count
);
230 chip
->buffer_end
= chip
->data_buffer
+ b_pos
+ b_count
;
234 dac_audio_start_timer(chip
);
241 snd_pcm_uframes_t
snd_sh_dac_pcm_pointer(struct snd_pcm_substream
*substream
)
243 struct snd_sh_dac
*chip
= snd_pcm_substream_chip(substream
);
244 int pointer
= chip
->buffer_begin
- chip
->data_buffer
;
250 static struct snd_pcm_ops snd_sh_dac_pcm_ops
= {
251 .open
= snd_sh_dac_pcm_open
,
252 .close
= snd_sh_dac_pcm_close
,
253 .ioctl
= snd_pcm_lib_ioctl
,
254 .hw_params
= snd_sh_dac_pcm_hw_params
,
255 .hw_free
= snd_sh_dac_pcm_hw_free
,
256 .prepare
= snd_sh_dac_pcm_prepare
,
257 .trigger
= snd_sh_dac_pcm_trigger
,
258 .pointer
= snd_sh_dac_pcm_pointer
,
259 .copy
= snd_sh_dac_pcm_copy
,
260 .silence
= snd_sh_dac_pcm_silence
,
261 .mmap
= snd_pcm_lib_mmap_iomem
,
264 static int __devinit
snd_sh_dac_pcm(struct snd_sh_dac
*chip
, int device
)
269 /* device should be always 0 for us */
270 err
= snd_pcm_new(chip
->card
, "SH_DAC PCM", device
, 1, 0, &pcm
);
274 pcm
->private_data
= chip
;
275 strcpy(pcm
->name
, "SH_DAC PCM");
276 snd_pcm_set_ops(pcm
, SNDRV_PCM_STREAM_PLAYBACK
, &snd_sh_dac_pcm_ops
);
278 /* buffer size=48K */
279 snd_pcm_lib_preallocate_pages_for_all(pcm
, SNDRV_DMA_TYPE_CONTINUOUS
,
280 snd_dma_continuous_data(GFP_KERNEL
),
286 /* END OF PCM INTERFACE */
289 /* driver .remove -- destructor */
290 static int snd_sh_dac_remove(struct platform_device
*devptr
)
292 snd_card_free(platform_get_drvdata(devptr
));
293 platform_set_drvdata(devptr
, NULL
);
298 /* free -- it has been defined by create */
299 static int snd_sh_dac_free(struct snd_sh_dac
*chip
)
301 /* release the data */
302 kfree(chip
->data_buffer
);
308 static int snd_sh_dac_dev_free(struct snd_device
*device
)
310 struct snd_sh_dac
*chip
= device
->device_data
;
312 return snd_sh_dac_free(chip
);
315 static enum hrtimer_restart
sh_dac_audio_timer(struct hrtimer
*handle
)
317 struct snd_sh_dac
*chip
= container_of(handle
, struct snd_sh_dac
,
319 struct snd_pcm_runtime
*runtime
= chip
->substream
->runtime
;
320 ssize_t b_ps
= frames_to_bytes(runtime
, runtime
->period_size
);
323 sh_dac_output(*chip
->buffer_begin
, chip
->pdata
->channel
);
324 chip
->buffer_begin
++;
327 if (chip
->processed
>= b_ps
) {
328 chip
->processed
-= b_ps
;
329 snd_pcm_period_elapsed(chip
->substream
);
332 if (chip
->buffer_begin
== (chip
->data_buffer
+
333 chip
->buffer_size
- 1))
334 chip
->buffer_begin
= chip
->data_buffer
;
336 if (chip
->buffer_begin
== chip
->buffer_end
)
342 hrtimer_start(&chip
->hrtimer
, chip
->wakeups_per_second
,
345 return HRTIMER_NORESTART
;
348 /* create -- chip-specific constructor for the cards components */
349 static int __devinit
snd_sh_dac_create(struct snd_card
*card
,
350 struct platform_device
*devptr
,
351 struct snd_sh_dac
**rchip
)
353 struct snd_sh_dac
*chip
;
356 static struct snd_device_ops ops
= {
357 .dev_free
= snd_sh_dac_dev_free
,
362 chip
= kzalloc(sizeof(*chip
), GFP_KERNEL
);
368 hrtimer_init(&chip
->hrtimer
, CLOCK_MONOTONIC
, HRTIMER_MODE_REL
);
369 chip
->hrtimer
.function
= sh_dac_audio_timer
;
371 dac_audio_reset(chip
);
373 dac_audio_set_rate(chip
);
375 chip
->pdata
= devptr
->dev
.platform_data
;
377 chip
->data_buffer
= kmalloc(chip
->pdata
->buffer_size
, GFP_KERNEL
);
378 if (chip
->data_buffer
== NULL
) {
383 err
= snd_device_new(card
, SNDRV_DEV_LOWLEVEL
, chip
, &ops
);
385 snd_sh_dac_free(chip
);
394 /* driver .probe -- constructor */
395 static int __devinit
snd_sh_dac_probe(struct platform_device
*devptr
)
397 struct snd_sh_dac
*chip
;
398 struct snd_card
*card
;
401 err
= snd_card_create(index
, id
, THIS_MODULE
, 0, &card
);
403 snd_printk(KERN_ERR
"cannot allocate the card\n");
407 err
= snd_sh_dac_create(card
, devptr
, &chip
);
411 err
= snd_sh_dac_pcm(chip
, 0);
415 strcpy(card
->driver
, "snd_sh_dac");
416 strcpy(card
->shortname
, "SuperH DAC audio driver");
417 printk(KERN_INFO
"%s %s", card
->longname
, card
->shortname
);
419 err
= snd_card_register(card
);
423 snd_printk("ALSA driver for SuperH DAC audio");
425 platform_set_drvdata(devptr
, card
);
434 * "driver" definition
436 static struct platform_driver driver
= {
437 .probe
= snd_sh_dac_probe
,
438 .remove
= snd_sh_dac_remove
,
444 static int __init
sh_dac_init(void)
446 return platform_driver_register(&driver
);
449 static void __exit
sh_dac_exit(void)
451 platform_driver_unregister(&driver
);
454 module_init(sh_dac_init
);
455 module_exit(sh_dac_exit
);