Received: by 2002:a05:6a10:1287:0:0:0:0 with SMTP id d7csp3667205pxv; Mon, 26 Jul 2021 09:02:53 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwRIAXJpMZK952TLoQi2cijH4XKyg+lUbtzyRBCiw1UsOn5k2Qu6SbkSGlLxi1lr/8pnEkw X-Received: by 2002:a05:6e02:1ba3:: with SMTP id n3mr9209557ili.213.1627315373723; Mon, 26 Jul 2021 09:02:53 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1627315373; cv=none; d=google.com; s=arc-20160816; b=hntEVcPJ4VAUyLBz9ADe9WR/TyEXlj49MIVx/jgbSFVrQkm9WtgapVu1P1J+e7X8HF x6zdv4puaT1/FXSD4NTVU8qYOp6ZUxGO7NZ8WVEekc0nCX/tncl/vlhn/xjp81Gxr6jT aVTCp9h1FvzK63B+z4rvMKrz4F+IFKA6jdmLtiDpQ+8MR5EpNeoZ4oycJUe+u1fo1xgM uCCXd+PGsTUQjE2CcAXbuFiUpNvevOR7OPG76Eu7+xs4YzmSbUNuSblLWUHGyKFbhG7h rKOPBBWcUCBN6J2Yf4rmRPloea7B+Xx1/YbWjOM0gHjBHu0CzCg8hf2i91G2/xEWVUDl 9BTg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=ouGzQMWVnLjx3/vIcBRqKIy4X2p8Cn1McodyMChUTuM=; b=qZNKoFQ+eg7Ur2DaX8UYnsGuidQj48yHeZMnAaT1ZJRI8x/pWbUQXtYUe3ssYZsv74 0wtzgPGrXDLL5GSdzUniymeYlaElEtE1JZgYQw+xw4tF4UjlP7l5PU7qzDKicvfCuERp utu2Y+CTjyqry8xld4gb6jgrl5rybVZTzSjx6O+auqoV9vVwi4NLZNtPKxo9CIMxGDfI SNrZnvjm0b9WZ8xgXa1ax5kj0/3JnGNkr4ECqqV4swRXHFlPDLWE7NbGQR+Sjv5yZWWL ebdodSoakRFoVN3p5i3Eqw8bEuShG17QFHS6E2G48XERjn9SkHR9GRj9DmyVQvn9IPms Db6g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=tmK7OXeA; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id s8si298862ilo.76.2021.07.26.09.02.41; Mon, 26 Jul 2021 09:02:53 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=tmK7OXeA; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S236941AbhGZPUD (ORCPT + 99 others); Mon, 26 Jul 2021 11:20:03 -0400 Received: from mail.kernel.org ([198.145.29.99]:47822 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236385AbhGZPIQ (ORCPT ); Mon, 26 Jul 2021 11:08:16 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id C775A60F6B; Mon, 26 Jul 2021 15:48:42 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1627314523; bh=Pz5znl3oCRXX/Ot8HGsKGVlif7ze/TLXcSlFz9LJoDk=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=tmK7OXeAhWRA70gpMl7U976uiA5+4Fy8lqvyNHHaFOgK4zoiz30Ul6BllG+Vx01dL U69NsJO7msiDNx1eiMJWiD3QYwFgloJE8iiWIJ8rOBBP++JNf41gjzykNRlSD6GP4G W09xk9VulgeQ6C9cuCQ6KmBEkQvhR4j+8R3lcyGQ= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Jia-Ju Bai , Takashi Iwai Subject: [PATCH 4.14 61/82] ALSA: sb: Fix potential ABBA deadlock in CSP driver Date: Mon, 26 Jul 2021 17:39:01 +0200 Message-Id: <20210726153830.156174967@linuxfoundation.org> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20210726153828.144714469@linuxfoundation.org> References: <20210726153828.144714469@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Takashi Iwai commit 1c2b9519159b470ef24b2638f4794e86e2952ab7 upstream. SB16 CSP driver may hit potentially a typical ABBA deadlock in two code paths: In snd_sb_csp_stop(): spin_lock_irqsave(&p->chip->mixer_lock, flags); spin_lock(&p->chip->reg_lock); In snd_sb_csp_load(): spin_lock_irqsave(&p->chip->reg_lock, flags); spin_lock(&p->chip->mixer_lock); Also the similar pattern is seen in snd_sb_csp_start(). Although the practical impact is very small (those states aren't triggered in the same running state and this happens only on a real hardware, decades old ISA sound boards -- which must be very difficult to find nowadays), it's a real scenario and has to be fixed. This patch addresses those deadlocks by splitting the locks in snd_sb_csp_start() and snd_sb_csp_stop() for avoiding the nested locks. Reported-by: Jia-Ju Bai Cc: Link: https://lore.kernel.org/r/7b0fcdaf-cd4f-4728-2eae-48c151a92e10@gmail.com Link: https://lore.kernel.org/r/20210716132723.13216-1-tiwai@suse.de Signed-off-by: Takashi Iwai Signed-off-by: Greg Kroah-Hartman --- sound/isa/sb/sb16_csp.c | 4 ++++ 1 file changed, 4 insertions(+) --- a/sound/isa/sb/sb16_csp.c +++ b/sound/isa/sb/sb16_csp.c @@ -828,6 +828,7 @@ static int snd_sb_csp_start(struct snd_s mixR = snd_sbmixer_read(p->chip, SB_DSP4_PCM_DEV + 1); snd_sbmixer_write(p->chip, SB_DSP4_PCM_DEV, mixL & 0x7); snd_sbmixer_write(p->chip, SB_DSP4_PCM_DEV + 1, mixR & 0x7); + spin_unlock_irqrestore(&p->chip->mixer_lock, flags); spin_lock(&p->chip->reg_lock); set_mode_register(p->chip, 0xc0); /* c0 = STOP */ @@ -867,6 +868,7 @@ static int snd_sb_csp_start(struct snd_s spin_unlock(&p->chip->reg_lock); /* restore PCM volume */ + spin_lock_irqsave(&p->chip->mixer_lock, flags); snd_sbmixer_write(p->chip, SB_DSP4_PCM_DEV, mixL); snd_sbmixer_write(p->chip, SB_DSP4_PCM_DEV + 1, mixR); spin_unlock_irqrestore(&p->chip->mixer_lock, flags); @@ -892,6 +894,7 @@ static int snd_sb_csp_stop(struct snd_sb mixR = snd_sbmixer_read(p->chip, SB_DSP4_PCM_DEV + 1); snd_sbmixer_write(p->chip, SB_DSP4_PCM_DEV, mixL & 0x7); snd_sbmixer_write(p->chip, SB_DSP4_PCM_DEV + 1, mixR & 0x7); + spin_unlock_irqrestore(&p->chip->mixer_lock, flags); spin_lock(&p->chip->reg_lock); if (p->running & SNDRV_SB_CSP_ST_QSOUND) { @@ -906,6 +909,7 @@ static int snd_sb_csp_stop(struct snd_sb spin_unlock(&p->chip->reg_lock); /* restore PCM volume */ + spin_lock_irqsave(&p->chip->mixer_lock, flags); snd_sbmixer_write(p->chip, SB_DSP4_PCM_DEV, mixL); snd_sbmixer_write(p->chip, SB_DSP4_PCM_DEV + 1, mixR); spin_unlock_irqrestore(&p->chip->mixer_lock, flags);