Received: by 2002:a05:6a10:6d25:0:0:0:0 with SMTP id gq37csp1962130pxb; Mon, 13 Sep 2021 09:02:57 -0700 (PDT) X-Google-Smtp-Source: ABdhPJykf/O01y3IiCFoIj1d7mRd4uGlbxmdB38ukv0wia7Yv1KmC6h3w17hMCgj4+m+7Ca8LOQM X-Received: by 2002:a05:6602:3284:: with SMTP id d4mr9401065ioz.100.1631548977305; Mon, 13 Sep 2021 09:02:57 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1631548977; cv=none; d=google.com; s=arc-20160816; b=hb3o5vL6u9XfrU5bTgHeM0Oq4+2Ask5ApKxoJFvMgNOhMlvCAZdO1143HwpXvMQlBx A/acK8poCzgteUBVcARK/rtQeZ26q1UNwGAt4XLHgP28GNo8fAuMifhfoV3LPk3VYU7D SfFVah3zMkmE/gWCLK0zfvite6EMxWIjW/XVWnT3LyeEBrgd4dJ3lV1Yr+Ev2KIhKfUN O4ODS7kT43EtirLYMDc5juYjXhqlihR+SjUeGAH0XGV4UDLLECrWBHpX4Xbn9zkrPsjw Q9kVkT9WLuP+aEZtt7+7JVNvQk9FoEHLQvdk9yc2xnBjbsRrrpF7/dwXTRku2fSx0Sqk PX/Q== 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 :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=/0zRk4bgJkrH0dwJlv8Bv+YE3XNYKWjZnfXNPmvVpXU=; b=LxxGIuqRK8bvhdAa8dXSpoQVwaWojftGPOiJQHsOKc9eVIDLzgKZYyf/fj4/+jFRkc 2oVz13Kchu1Dey30Xlx1HokC6WB9C/RmxWVQD5qN2zYB/agn1FFaImZpuaRs/qaBp/O7 8d9KwevrMVCyQSzEcf6h3hAt+7qdmxi63w/HsX8ztTeDOh/buwkuFGXb6ejmSj2nKKb2 j9Akwih1k8CbMPHgMTz1y7k1J11VDBoOWqaBTV+o6uOcMBvTkUdTjbqXtz8LGJJ7L5ej oim3hMk9CBfawVzbLXcMaEZvYc60FTW05WTzgtFqn0053L3pHWE/Uu67OHq376GFTANd ixtw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@cirrus.com header.s=PODMain02222019 header.b=EtT7p3xH; 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=REJECT sp=REJECT dis=NONE) header.from=cirrus.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id i12si6570679jac.26.2021.09.13.09.02.44; Mon, 13 Sep 2021 09:02:57 -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=@cirrus.com header.s=PODMain02222019 header.b=EtT7p3xH; 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=REJECT sp=REJECT dis=NONE) header.from=cirrus.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1345018AbhIMQDB (ORCPT + 99 others); Mon, 13 Sep 2021 12:03:01 -0400 Received: from mx0b-001ae601.pphosted.com ([67.231.152.168]:64462 "EHLO mx0b-001ae601.pphosted.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1343617AbhIMQCo (ORCPT ); Mon, 13 Sep 2021 12:02:44 -0400 Received: from pps.filterd (m0077474.ppops.net [127.0.0.1]) by mx0b-001ae601.pphosted.com (8.16.1.2/8.16.1.2) with SMTP id 18DFp9L8002377; Mon, 13 Sep 2021 11:01:21 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=cirrus.com; h=from : to : cc : subject : date : message-id : in-reply-to : references : mime-version : content-transfer-encoding : content-type; s=PODMain02222019; bh=/0zRk4bgJkrH0dwJlv8Bv+YE3XNYKWjZnfXNPmvVpXU=; b=EtT7p3xHNLUv6yuoWJALg3dceD6UUfZW070SFQroxEWJ0tbJCtbvw89RHhtrr0+6zL4T lRtxZNSlzsQCwI6Dz1lsep4sqAkh2StueVnsW43kz1D9GvqR5/+dHiS5y9zSSU0Sm51T 8gNcek+eXPO/+eyITLH8y+89NpK0TIUF8QjGp8PSazUvfJNYcBh2luF1GVI8DS/XZdIc Uz4KF1ujH41MPzavCax5aMfI5adIdrGbBdw9eF5whS7Lm2v8ONsM7s1nmGgXG/liGMt7 P294IPOVpBLWGPLAl3q35ZKQ3eXSeR3ImOwZHTdE6z3XTt/FI2grXFq+mGTw9U/l2i3C Ow== Received: from ediex01.ad.cirrus.com ([87.246.76.36]) by mx0b-001ae601.pphosted.com with ESMTP id 3b29n3r0ag-2 (version=TLSv1.2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128 verify=NOT); Mon, 13 Sep 2021 11:01:21 -0500 Received: from EDIEX01.ad.cirrus.com (198.61.84.80) by EDIEX01.ad.cirrus.com (198.61.84.80) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2242.12; Mon, 13 Sep 2021 17:01:18 +0100 Received: from ediswmail.ad.cirrus.com (198.61.86.93) by EDIEX01.ad.cirrus.com (198.61.84.80) with Microsoft SMTP Server id 15.1.2242.12 via Frontend Transport; Mon, 13 Sep 2021 17:01:18 +0100 Received: from simont-vb.lan?044ad.cirrus.com (unknown [198.90.238.152]) by ediswmail.ad.cirrus.com (Postfix) with ESMTP id 39D6FB2F; Mon, 13 Sep 2021 16:01:18 +0000 (UTC) From: Simon Trimmer To: , CC: , , , Charles Keepax , Simon Trimmer Subject: [PATCH 02/16] ASoC: wm_adsp: Move check for control existence Date: Mon, 13 Sep 2021 17:00:43 +0100 Message-ID: <20210913160057.103842-3-simont@opensource.cirrus.com> X-Mailer: git-send-email 2.33.0 In-Reply-To: <20210913160057.103842-1-simont@opensource.cirrus.com> References: <20210913160057.103842-1-simont@opensource.cirrus.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Content-Type: text/plain X-Proofpoint-GUID: 1YorRL9b9FhBxuapBYSWayCZRnnG7Z6l X-Proofpoint-ORIG-GUID: 1YorRL9b9FhBxuapBYSWayCZRnnG7Z6l X-Proofpoint-Spam-Reason: safe Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Charles Keepax Checking earlier in the function if a control already exists avoids superfluous string construction and also prepares for future refactoring. Signed-off-by: Charles Keepax Signed-off-by: Simon Trimmer --- sound/soc/codecs/wm_adsp.c | 21 +++++++++++++-------- 1 file changed, 13 insertions(+), 8 deletions(-) diff --git a/sound/soc/codecs/wm_adsp.c b/sound/soc/codecs/wm_adsp.c index f5db6e3b9f60..b300af6fdd41 100644 --- a/sound/soc/codecs/wm_adsp.c +++ b/sound/soc/codecs/wm_adsp.c @@ -1422,6 +1422,19 @@ static int wm_adsp_create_control(struct wm_adsp *dsp, const char *region_name; int ret; + list_for_each_entry(ctl, &dsp->ctl_list, list) { + if (ctl->fw_name == wm_adsp_fw_text[dsp->fw] && + ctl->alg_region.alg == alg_region->alg && + ctl->alg_region.type == alg_region->type) { + if ((!subname && !ctl->subname) || + (subname && !strncmp(ctl->subname, subname, ctl->subname_len))) { + if (!ctl->enabled) + ctl->enabled = 1; + return 0; + } + } + } + region_name = wm_adsp_mem_region_name(alg_region->type); if (!region_name) { adsp_err(dsp, "Unknown region type: %d\n", alg_region->type); @@ -1462,14 +1475,6 @@ static int wm_adsp_create_control(struct wm_adsp *dsp, " %.*s", subname_len - skip, subname + skip); } - list_for_each_entry(ctl, &dsp->ctl_list, list) { - if (!strcmp(ctl->name, name)) { - if (!ctl->enabled) - ctl->enabled = 1; - return 0; - } - } - ctl = kzalloc(sizeof(*ctl), GFP_KERNEL); if (!ctl) return -ENOMEM; -- 2.33.0