Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 201939
b: refs/heads/master
c: 54b7860
h: refs/heads/master
i:
  201937: b49479a
  201935: 6110093
v: v3
  • Loading branch information
Mauro Carvalho Chehab committed Aug 2, 2010
1 parent c235a13 commit 188fce3
Show file tree
Hide file tree
Showing 3 changed files with 33 additions and 32 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 0e57ff8d5c3d98abbd2137872a8e663e553a7245
refs/heads/master: 54b78608c6f4a30b4d64ec17bc36636c2a081506
59 changes: 32 additions & 27 deletions trunk/drivers/staging/tm6000/tm6000-alsa.c
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@
#include <linux/interrupt.h>
#include <linux/usb.h>
#include <linux/slab.h>
#include <linux/vmalloc.h>

#include <asm/delay.h>
#include <sound/core.h>
Expand Down Expand Up @@ -106,19 +107,39 @@ static int _tm6000_stop_audio_dma(struct snd_tm6000_card *chip)
return 0;
}

static int dsp_buffer_free(struct snd_tm6000_card *chip)
static void dsp_buffer_free(struct snd_pcm_substream *substream)
{
BUG_ON(!chip->bufsize);
struct snd_tm6000_card *chip = snd_pcm_substream_chip(substream);

dprintk(2, "Freeing buffer\n");

/* FIXME: Frees buffer */
vfree(substream->runtime->dma_area);
substream->runtime->dma_area = NULL;
substream->runtime->dma_bytes = 0;
}

chip->bufsize = 0;
static int dsp_buffer_alloc(struct snd_pcm_substream *substream, int size)
{
struct snd_tm6000_card *chip = snd_pcm_substream_chip(substream);

return 0;
dprintk(2, "Allocating buffer\n");

if (substream->runtime->dma_area) {
if (substream->runtime->dma_bytes > size)
return 0;
dsp_buffer_free(substream);
}

substream->runtime->dma_area = vmalloc(size);
if (!substream->runtime->dma_area)
return -ENOMEM;

substream->runtime->dma_bytes = size;

return 0;
}


/****************************************************************************
ALSA PCM Interface
****************************************************************************/
Expand Down Expand Up @@ -185,23 +206,13 @@ static int snd_tm6000_close(struct snd_pcm_substream *substream)
static int snd_tm6000_hw_params(struct snd_pcm_substream *substream,
struct snd_pcm_hw_params *hw_params)
{
struct snd_tm6000_card *chip = snd_pcm_substream_chip(substream);
int size, rc;

if (substream->runtime->dma_area) {
dsp_buffer_free(chip);
substream->runtime->dma_area = NULL;
}

chip->period_size = params_period_bytes(hw_params);
chip->num_periods = params_periods(hw_params);
chip->bufsize = chip->period_size * params_periods(hw_params);

BUG_ON(!chip->bufsize);

dprintk(1, "Setting buffer\n");

/* FIXME: Allocate buffer for audio */
size = params_period_bytes(hw_params) * params_periods(hw_params);

rc = dsp_buffer_alloc(substream, size);
if (rc < 0)
return rc;

return 0;
}
Expand All @@ -211,13 +222,7 @@ static int snd_tm6000_hw_params(struct snd_pcm_substream *substream,
*/
static int snd_tm6000_hw_free(struct snd_pcm_substream *substream)
{

struct snd_tm6000_card *chip = snd_pcm_substream_chip(substream);

if (substream->runtime->dma_area) {
dsp_buffer_free(chip);
substream->runtime->dma_area = NULL;
}
dsp_buffer_free(substream);

return 0;
}
Expand Down
4 changes: 0 additions & 4 deletions trunk/drivers/staging/tm6000/tm6000.h
Original file line number Diff line number Diff line change
Expand Up @@ -136,11 +136,7 @@ struct snd_tm6000_card {
struct snd_card *card;
spinlock_t reg_lock;
atomic_t count;
unsigned int period_size;
unsigned int num_periods;
struct tm6000_core *core;
struct tm6000_buffer *buf;
int bufsize;
struct snd_pcm_substream *substream;
};

Expand Down

0 comments on commit 188fce3

Please sign in to comment.