ALSA: fm801: Use guard() for spin locks

Clean up the code using guard() for spin locks.

Merely code refactoring, and no behavior change.

Signed-off-by: Takashi Iwai <tiwai@suse.de>
Link: https://patch.msgid.link/20250829144342.4290-34-tiwai@suse.de
This commit is contained in:
Takashi Iwai 2025-08-29 16:43:08 +02:00
parent 3ea4db1f20
commit 2b429331f5
1 changed files with 30 additions and 41 deletions

View File

@ -279,16 +279,14 @@ static int snd_fm801_update_bits(struct fm801 *chip, unsigned short reg,
unsigned short mask, unsigned short value) unsigned short mask, unsigned short value)
{ {
int change; int change;
unsigned long flags;
unsigned short old, new; unsigned short old, new;
spin_lock_irqsave(&chip->reg_lock, flags); guard(spinlock_irqsave)(&chip->reg_lock);
old = fm801_ioread16(chip, reg); old = fm801_ioread16(chip, reg);
new = (old & ~mask) | value; new = (old & ~mask) | value;
change = old != new; change = old != new;
if (change) if (change)
fm801_iowrite16(chip, reg, new); fm801_iowrite16(chip, reg, new);
spin_unlock_irqrestore(&chip->reg_lock, flags);
return change; return change;
} }
@ -393,7 +391,7 @@ static int snd_fm801_playback_trigger(struct snd_pcm_substream *substream,
{ {
struct fm801 *chip = snd_pcm_substream_chip(substream); struct fm801 *chip = snd_pcm_substream_chip(substream);
spin_lock(&chip->reg_lock); guard(spinlock)(&chip->reg_lock);
switch (cmd) { switch (cmd) {
case SNDRV_PCM_TRIGGER_START: case SNDRV_PCM_TRIGGER_START:
chip->ply_ctrl &= ~(FM801_BUF1_LAST | chip->ply_ctrl &= ~(FM801_BUF1_LAST |
@ -414,12 +412,10 @@ static int snd_fm801_playback_trigger(struct snd_pcm_substream *substream,
chip->ply_ctrl &= ~FM801_PAUSE; chip->ply_ctrl &= ~FM801_PAUSE;
break; break;
default: default:
spin_unlock(&chip->reg_lock);
snd_BUG(); snd_BUG();
return -EINVAL; return -EINVAL;
} }
fm801_writew(chip, PLY_CTRL, chip->ply_ctrl); fm801_writew(chip, PLY_CTRL, chip->ply_ctrl);
spin_unlock(&chip->reg_lock);
return 0; return 0;
} }
@ -428,7 +424,7 @@ static int snd_fm801_capture_trigger(struct snd_pcm_substream *substream,
{ {
struct fm801 *chip = snd_pcm_substream_chip(substream); struct fm801 *chip = snd_pcm_substream_chip(substream);
spin_lock(&chip->reg_lock); guard(spinlock)(&chip->reg_lock);
switch (cmd) { switch (cmd) {
case SNDRV_PCM_TRIGGER_START: case SNDRV_PCM_TRIGGER_START:
chip->cap_ctrl &= ~(FM801_BUF1_LAST | chip->cap_ctrl &= ~(FM801_BUF1_LAST |
@ -449,12 +445,10 @@ static int snd_fm801_capture_trigger(struct snd_pcm_substream *substream,
chip->cap_ctrl &= ~FM801_PAUSE; chip->cap_ctrl &= ~FM801_PAUSE;
break; break;
default: default:
spin_unlock(&chip->reg_lock);
snd_BUG(); snd_BUG();
return -EINVAL; return -EINVAL;
} }
fm801_writew(chip, CAP_CTRL, chip->cap_ctrl); fm801_writew(chip, CAP_CTRL, chip->cap_ctrl);
spin_unlock(&chip->reg_lock);
return 0; return 0;
} }
@ -465,7 +459,7 @@ static int snd_fm801_playback_prepare(struct snd_pcm_substream *substream)
chip->ply_size = snd_pcm_lib_buffer_bytes(substream); chip->ply_size = snd_pcm_lib_buffer_bytes(substream);
chip->ply_count = snd_pcm_lib_period_bytes(substream); chip->ply_count = snd_pcm_lib_period_bytes(substream);
spin_lock_irq(&chip->reg_lock); guard(spinlock_irq)(&chip->reg_lock);
chip->ply_ctrl &= ~(FM801_START | FM801_16BIT | chip->ply_ctrl &= ~(FM801_START | FM801_16BIT |
FM801_STEREO | FM801_RATE_MASK | FM801_STEREO | FM801_RATE_MASK |
FM801_CHANNELS_MASK); FM801_CHANNELS_MASK);
@ -487,7 +481,6 @@ static int snd_fm801_playback_prepare(struct snd_pcm_substream *substream)
fm801_writel(chip, PLY_BUF1, chip->ply_buffer); fm801_writel(chip, PLY_BUF1, chip->ply_buffer);
fm801_writel(chip, PLY_BUF2, fm801_writel(chip, PLY_BUF2,
chip->ply_buffer + (chip->ply_count % chip->ply_size)); chip->ply_buffer + (chip->ply_count % chip->ply_size));
spin_unlock_irq(&chip->reg_lock);
return 0; return 0;
} }
@ -498,7 +491,7 @@ static int snd_fm801_capture_prepare(struct snd_pcm_substream *substream)
chip->cap_size = snd_pcm_lib_buffer_bytes(substream); chip->cap_size = snd_pcm_lib_buffer_bytes(substream);
chip->cap_count = snd_pcm_lib_period_bytes(substream); chip->cap_count = snd_pcm_lib_period_bytes(substream);
spin_lock_irq(&chip->reg_lock); guard(spinlock_irq)(&chip->reg_lock);
chip->cap_ctrl &= ~(FM801_START | FM801_16BIT | chip->cap_ctrl &= ~(FM801_START | FM801_16BIT |
FM801_STEREO | FM801_RATE_MASK); FM801_STEREO | FM801_RATE_MASK);
if (snd_pcm_format_width(runtime->format) == 16) if (snd_pcm_format_width(runtime->format) == 16)
@ -514,7 +507,6 @@ static int snd_fm801_capture_prepare(struct snd_pcm_substream *substream)
fm801_writel(chip, CAP_BUF1, chip->cap_buffer); fm801_writel(chip, CAP_BUF1, chip->cap_buffer);
fm801_writel(chip, CAP_BUF2, fm801_writel(chip, CAP_BUF2,
chip->cap_buffer + (chip->cap_count % chip->cap_size)); chip->cap_buffer + (chip->cap_count % chip->cap_size));
spin_unlock_irq(&chip->reg_lock);
return 0; return 0;
} }
@ -525,13 +517,12 @@ static snd_pcm_uframes_t snd_fm801_playback_pointer(struct snd_pcm_substream *su
if (!(chip->ply_ctrl & FM801_START)) if (!(chip->ply_ctrl & FM801_START))
return 0; return 0;
spin_lock(&chip->reg_lock); guard(spinlock)(&chip->reg_lock);
ptr = chip->ply_pos + (chip->ply_count - 1) - fm801_readw(chip, PLY_COUNT); ptr = chip->ply_pos + (chip->ply_count - 1) - fm801_readw(chip, PLY_COUNT);
if (fm801_readw(chip, IRQ_STATUS) & FM801_IRQ_PLAYBACK) { if (fm801_readw(chip, IRQ_STATUS) & FM801_IRQ_PLAYBACK) {
ptr += chip->ply_count; ptr += chip->ply_count;
ptr %= chip->ply_size; ptr %= chip->ply_size;
} }
spin_unlock(&chip->reg_lock);
return bytes_to_frames(substream->runtime, ptr); return bytes_to_frames(substream->runtime, ptr);
} }
@ -542,13 +533,12 @@ static snd_pcm_uframes_t snd_fm801_capture_pointer(struct snd_pcm_substream *sub
if (!(chip->cap_ctrl & FM801_START)) if (!(chip->cap_ctrl & FM801_START))
return 0; return 0;
spin_lock(&chip->reg_lock); guard(spinlock)(&chip->reg_lock);
ptr = chip->cap_pos + (chip->cap_count - 1) - fm801_readw(chip, CAP_COUNT); ptr = chip->cap_pos + (chip->cap_count - 1) - fm801_readw(chip, CAP_COUNT);
if (fm801_readw(chip, IRQ_STATUS) & FM801_IRQ_CAPTURE) { if (fm801_readw(chip, IRQ_STATUS) & FM801_IRQ_CAPTURE) {
ptr += chip->cap_count; ptr += chip->cap_count;
ptr %= chip->cap_size; ptr %= chip->cap_size;
} }
spin_unlock(&chip->reg_lock);
return bytes_to_frames(substream->runtime, ptr); return bytes_to_frames(substream->runtime, ptr);
} }
@ -565,31 +555,31 @@ static irqreturn_t snd_fm801_interrupt(int irq, void *dev_id)
/* ack first */ /* ack first */
fm801_writew(chip, IRQ_STATUS, status); fm801_writew(chip, IRQ_STATUS, status);
if (chip->pcm && (status & FM801_IRQ_PLAYBACK) && chip->playback_substream) { if (chip->pcm && (status & FM801_IRQ_PLAYBACK) && chip->playback_substream) {
spin_lock(&chip->reg_lock); scoped_guard(spinlock, &chip->reg_lock) {
chip->ply_buf++; chip->ply_buf++;
chip->ply_pos += chip->ply_count; chip->ply_pos += chip->ply_count;
chip->ply_pos %= chip->ply_size; chip->ply_pos %= chip->ply_size;
tmp = chip->ply_pos + chip->ply_count; tmp = chip->ply_pos + chip->ply_count;
tmp %= chip->ply_size; tmp %= chip->ply_size;
if (chip->ply_buf & 1) if (chip->ply_buf & 1)
fm801_writel(chip, PLY_BUF1, chip->ply_buffer + tmp); fm801_writel(chip, PLY_BUF1, chip->ply_buffer + tmp);
else else
fm801_writel(chip, PLY_BUF2, chip->ply_buffer + tmp); fm801_writel(chip, PLY_BUF2, chip->ply_buffer + tmp);
spin_unlock(&chip->reg_lock); }
snd_pcm_period_elapsed(chip->playback_substream); snd_pcm_period_elapsed(chip->playback_substream);
} }
if (chip->pcm && (status & FM801_IRQ_CAPTURE) && chip->capture_substream) { if (chip->pcm && (status & FM801_IRQ_CAPTURE) && chip->capture_substream) {
spin_lock(&chip->reg_lock); scoped_guard(spinlock, &chip->reg_lock) {
chip->cap_buf++; chip->cap_buf++;
chip->cap_pos += chip->cap_count; chip->cap_pos += chip->cap_count;
chip->cap_pos %= chip->cap_size; chip->cap_pos %= chip->cap_size;
tmp = chip->cap_pos + chip->cap_count; tmp = chip->cap_pos + chip->cap_count;
tmp %= chip->cap_size; tmp %= chip->cap_size;
if (chip->cap_buf & 1) if (chip->cap_buf & 1)
fm801_writel(chip, CAP_BUF1, chip->cap_buffer + tmp); fm801_writel(chip, CAP_BUF1, chip->cap_buffer + tmp);
else else
fm801_writel(chip, CAP_BUF2, chip->cap_buffer + tmp); fm801_writel(chip, CAP_BUF2, chip->cap_buffer + tmp);
spin_unlock(&chip->reg_lock); }
snd_pcm_period_elapsed(chip->capture_substream); snd_pcm_period_elapsed(chip->capture_substream);
} }
if (chip->rmidi && (status & FM801_IRQ_MPU)) if (chip->rmidi && (status & FM801_IRQ_MPU))
@ -924,10 +914,9 @@ static int snd_fm801_get_double(struct snd_kcontrol *kcontrol,
int invert = (kcontrol->private_value >> 24) & 0xff; int invert = (kcontrol->private_value >> 24) & 0xff;
long *value = ucontrol->value.integer.value; long *value = ucontrol->value.integer.value;
spin_lock_irq(&chip->reg_lock); guard(spinlock_irq)(&chip->reg_lock);
value[0] = (fm801_ioread16(chip, reg) >> shift_left) & mask; value[0] = (fm801_ioread16(chip, reg) >> shift_left) & mask;
value[1] = (fm801_ioread16(chip, reg) >> shift_right) & mask; value[1] = (fm801_ioread16(chip, reg) >> shift_right) & mask;
spin_unlock_irq(&chip->reg_lock);
if (invert) { if (invert) {
value[0] = mask - value[0]; value[0] = mask - value[0];
value[1] = mask - value[1]; value[1] = mask - value[1];