Received: by 2002:a25:1506:0:0:0:0:0 with SMTP id 6csp1624450ybv; Fri, 21 Feb 2020 00:30:36 -0800 (PST) X-Google-Smtp-Source: APXvYqwywJ6z6tq+/DAepZ1qj/tbyQtZ7vo3FyboNfHqti7aRgjrtJ9F3zA4WStqeXWkHdzShZeE X-Received: by 2002:a05:6830:1f0c:: with SMTP id u12mr26688134otg.253.1582273835906; Fri, 21 Feb 2020 00:30:35 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1582273835; cv=none; d=google.com; s=arc-20160816; b=DeCvPk/s8Inu8Jh9cddBKem5Q0hTBibrjiCZONQckh/m/vCRyDjw/JKjHg6UA+bKxu aGPnx50mO3YYm6r2XTWhP8nVn+HgcVlb9mQ6RrChBApuS5fxPTD1CvbschOkYtg7FoWj YzsjbHj1tbjHDFXLTTATPBnvZsSr9W3Ovp+OpIdp7BzPTGk2W0Zxmj4WzqseRCu05Ugj 7x75oF1YsBePiEcsPpRIe2fKHofuB0o8Fq+m4kQz8jGa045dk7uORfZfXeove3YBOU3Z mZXVeGNuz8F/uwwW3rKHrboYvl1BxRzOqakWmsRA8T4PsWNYPcZZ0cyh72+IzIalCy1F HaPw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=LcgGW4uXXwyTjPk1mjzVkj/hm3zuDWQZb1105ff86is=; b=aCYB6qwaZ/EvJGV2PU1lN19ZWMhd81lksCSuLTVrNaZOeqkourMZlT9pmQsb5PNSBm GoHqakJndCJsX7cW09y2w9HUiQSUGg+Qc01CSExIsey8FbQKAOK2n37mnAw+44nOdud+ QXSGrvrw44i+5EHHOeTfVVZxa7axb16s40ypijnbFYEm8vDdAxh3hda4n0WZZpKFc4L+ 8tYvbVuEQdM6L64UOWupLckmWZ8HyDtElle15QEXA5951aR8zVqHKtMgEA8NOWRVGBhH JZk8fM32MmXT1w0RNx2Qx8nmi/fxfSDigTojDKVPm/u4OrT+KHRFSqXIKJLHlzNJn56i YBSQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=q2DdOPom; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id a11si1128755otq.223.2020.02.21.00.30.24; Fri, 21 Feb 2020 00:30:35 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=q2DdOPom; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2387604AbgBUIRA (ORCPT + 99 others); Fri, 21 Feb 2020 03:17:00 -0500 Received: from mail.kernel.org ([198.145.29.99]:54232 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2387599AbgBUIQ6 (ORCPT ); Fri, 21 Feb 2020 03:16:58 -0500 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 9651524682; Fri, 21 Feb 2020 08:16:57 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1582273018; bh=Kg5IVRnEpP2SMZz+UVMqxwQ0BK2QI7KyO+6LMZWsYPg=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=q2DdOPomZNiJOYs5W6UA6yfQT9qWWlG/e4K+VlnI49PhhY5k0OTAzq8PPL6vYf0Ju qeschWZgHi1eV/uirIEUj0QzPPdvkFJBpOM/R7zZEPubpCuEin693UFZFPv1vCovcr eIWF2iuFdrL+wFnK0gG5p/6DgbR6wo+zGnzEizhw= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Takashi Sakamoto , Jaroslav Kysela , Takashi Iwai , Sasha Levin Subject: [PATCH 4.19 017/191] ALSA: ctl: allow TLV read operation for callback type of element in locked case Date: Fri, 21 Feb 2020 08:39:50 +0100 Message-Id: <20200221072253.251887423@linuxfoundation.org> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20200221072250.732482588@linuxfoundation.org> References: <20200221072250.732482588@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Takashi Sakamoto [ Upstream commit d61fe22c2ae42d9fd76c34ef4224064cca4b04b0 ] A design of ALSA control core allows applications to execute three operations for TLV feature; read, write and command. Furthermore, it allows driver developers to process the operations by two ways; allocated array or callback function. In the former, read operation is just allowed, thus developers uses the latter when device driver supports variety of models or the target model is expected to dynamically change information stored in TLV container. The core also allows applications to lock any element so that the other applications can't perform write operation to the element for element value and TLV information. When the element is locked, write and command operation for TLV information are prohibited as well as element value. Any read operation should be allowed in the case. At present, when an element has callback function for TLV information, TLV read operation returns EPERM if the element is locked. On the other hand, the read operation is success when an element has allocated array for TLV information. In both cases, read operation is success for element value expectedly. This commit fixes the bug. This change can be backported to v4.14 kernel or later. Signed-off-by: Takashi Sakamoto Reviewed-by: Jaroslav Kysela Link: https://lore.kernel.org/r/20191223093347.15279-1-o-takashi@sakamocchi.jp Signed-off-by: Takashi Iwai Signed-off-by: Sasha Levin --- sound/core/control.c | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/sound/core/control.c b/sound/core/control.c index 649d3217590ed..d1312f14d78fb 100644 --- a/sound/core/control.c +++ b/sound/core/control.c @@ -1468,8 +1468,9 @@ static int call_tlv_handler(struct snd_ctl_file *file, int op_flag, if (kctl->tlv.c == NULL) return -ENXIO; - /* When locked, this is unavailable. */ - if (vd->owner != NULL && vd->owner != file) + /* Write and command operations are not allowed for locked element. */ + if (op_flag != SNDRV_CTL_TLV_OP_READ && + vd->owner != NULL && vd->owner != file) return -EPERM; return kctl->tlv.c(kctl, op_flag, size, buf); -- 2.20.1