Commit 85122ea4 authored by Takashi Iwai's avatar Takashi Iwai

ALSA: Remove unneeded snd_pcm_substream.timer_lock

The timer callbacks are called in the protected status by the lock
of the timer instance, so there is no need for an extra lock in the
PCM substream.
Signed-off-by: default avatarTakashi Iwai <tiwai@suse.de>
parent ed3da3d9
...@@ -364,7 +364,6 @@ struct snd_pcm_substream { ...@@ -364,7 +364,6 @@ struct snd_pcm_substream {
/* -- timer section -- */ /* -- timer section -- */
struct snd_timer *timer; /* timer */ struct snd_timer *timer; /* timer */
unsigned timer_running: 1; /* time is running */ unsigned timer_running: 1; /* time is running */
spinlock_t timer_lock;
/* -- next substream -- */ /* -- next substream -- */
struct snd_pcm_substream *next; struct snd_pcm_substream *next;
/* -- linked substreams -- */ /* -- linked substreams -- */
......
...@@ -667,7 +667,6 @@ int snd_pcm_new_stream(struct snd_pcm *pcm, int stream, int substream_count) ...@@ -667,7 +667,6 @@ int snd_pcm_new_stream(struct snd_pcm *pcm, int stream, int substream_count)
spin_lock_init(&substream->self_group.lock); spin_lock_init(&substream->self_group.lock);
INIT_LIST_HEAD(&substream->self_group.substreams); INIT_LIST_HEAD(&substream->self_group.substreams);
list_add_tail(&substream->link_list, &substream->self_group.substreams); list_add_tail(&substream->link_list, &substream->self_group.substreams);
spin_lock_init(&substream->timer_lock);
atomic_set(&substream->mmap_count, 0); atomic_set(&substream->mmap_count, 0);
prev = substream; prev = substream;
} }
......
...@@ -85,25 +85,19 @@ static unsigned long snd_pcm_timer_resolution(struct snd_timer * timer) ...@@ -85,25 +85,19 @@ static unsigned long snd_pcm_timer_resolution(struct snd_timer * timer)
static int snd_pcm_timer_start(struct snd_timer * timer) static int snd_pcm_timer_start(struct snd_timer * timer)
{ {
unsigned long flags;
struct snd_pcm_substream *substream; struct snd_pcm_substream *substream;
substream = snd_timer_chip(timer); substream = snd_timer_chip(timer);
spin_lock_irqsave(&substream->timer_lock, flags);
substream->timer_running = 1; substream->timer_running = 1;
spin_unlock_irqrestore(&substream->timer_lock, flags);
return 0; return 0;
} }
static int snd_pcm_timer_stop(struct snd_timer * timer) static int snd_pcm_timer_stop(struct snd_timer * timer)
{ {
unsigned long flags;
struct snd_pcm_substream *substream; struct snd_pcm_substream *substream;
substream = snd_timer_chip(timer); substream = snd_timer_chip(timer);
spin_lock_irqsave(&substream->timer_lock, flags);
substream->timer_running = 0; substream->timer_running = 0;
spin_unlock_irqrestore(&substream->timer_lock, flags);
return 0; return 0;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment