Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp1346492pxk; Thu, 10 Sep 2020 13:07:39 -0700 (PDT) X-Google-Smtp-Source: ABdhPJztWMAoZ7wv5mKsU7kh7J903r7fMrsJWKOQxKlWLVLJGHGm28kRo2gIR2JPY4sdIorRPl12 X-Received: by 2002:a50:8e17:: with SMTP id 23mr10967405edw.42.1599768459108; Thu, 10 Sep 2020 13:07:39 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1599768459; cv=none; d=google.com; s=arc-20160816; b=oSlDr699yNpHY0+s4BibbKBAl4fGDEtBMyAsvw71TGJs5hni8dlXpR/Sijdw+AXQWw ekz/X+KleNWi/uQu822b2sWzM55xENtNTiGF9Ks+EIU1HjKgrwgXvlF3V4uZ7CgLfZyU 5TCoylhrIv3NPvdFSHIqx/rUD3EVRyC2qA4GveWYnMdL2Xx6DzvqwE4cy8cEnOnBD0Ov vhRIl0kEWlgTqGf2q1GuBmwq58WK7+1gHWmIeIHPCET2cy6T6CDKoze2NxYW1A8llupg 2hxvTYlCm87qMhpRZYWqkW4oAoB/Xi564A0dg5otkaP/9FqDG/RfRN9R1CVzCF6NlP1k FfRQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from; bh=cfK2dGk6h7pNSBsX1XLw+NnNld/bzm/dX0/PPcFZBm8=; b=NybQW8FZJuee+R1StTaBfI6PmiidiTrZ3Jqh/nAveyxk3ExcuCEHWXUgfzjlQ866qy 5KvGVpeTVV6YZYcGwt78BnCxiRvhE0NMqBwg5dfZg2PFYIiL872oa93UNoxOJjl+2N2g lmc4qpuTVtxzrIdR11KbjtupJ62/F2YhpXAcGA88odk4gfxY+37D+ZL5btpGpHshZn16 xceJwz1eZSVVng88LPrrqvsIjdwYpY4dsjnaep4CieDqAtwphL3OK7ksIIUaQCSysME/ ujUoSu/o12Ol+/iQm4v74MMhcxOtg2khZFf/m1KH3j/r2OZmvwpCL0mV6lz3XALYL/ZM LuPA== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=NONE sp=NONE dis=NONE) header.from=collabora.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id m18si4148208ejk.743.2020.09.10.13.07.16; Thu, 10 Sep 2020 13:07:39 -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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=collabora.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726662AbgIJUGb (ORCPT + 99 others); Thu, 10 Sep 2020 16:06:31 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:52042 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726844AbgIJUDb (ORCPT ); Thu, 10 Sep 2020 16:03:31 -0400 Received: from bhuna.collabora.co.uk (bhuna.collabora.co.uk [IPv6:2a00:1098:0:82:1000:25:2eeb:e3e3]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 3A68AC061757 for ; Thu, 10 Sep 2020 13:03:31 -0700 (PDT) Received: from [127.0.0.1] (localhost [127.0.0.1]) (Authenticated sender: dafna) with ESMTPSA id 426C529B6F0 From: Dafna Hirschfeld To: linux-kernel@vger.kernel.org, alsa-devel@alsa-project.org, broonie@kernel.org Cc: tiwai@suse.com, enric.balletbo@collabora.com, kernel@collabora.com, dafna3@gmail.com, lgirdwood@gmail.com, perex@perex.cz, linux-mediatek@lists.infradead.org, ranjani.sridharan@linux.intel.com, matthias.bgg@gmail.com, dmitry.baryshkov@linaro.org, Dafna Hirschfeld Subject: [PATCH] ASoC: core: Optionaly add the component driver name to the component name Date: Thu, 10 Sep 2020 22:03:08 +0200 Message-Id: <20200910200308.9125-1-dafna.hirschfeld@collabora.com> X-Mailer: git-send-email 2.17.1 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The ASoC platform driver for Mediatek MT8173 registers several components with identical name. This cause an error: "Directory '11220000.audio-controller' with parent 'mtk-rt5650' already present!" when adding debugfs directory for those components. To fix this, the function 'fmt_single_name' can receive the name of the component driver and concatenate it to the name of the debugfs directory for the component. Signed-off-by: Dafna Hirschfeld --- sound/soc/soc-core.c | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) diff --git a/sound/soc/soc-core.c b/sound/soc/soc-core.c index 74df22486e30..f470e713b030 100644 --- a/sound/soc/soc-core.c +++ b/sound/soc/soc-core.c @@ -2227,7 +2227,7 @@ EXPORT_SYMBOL_GPL(snd_soc_unregister_card); * Simplify DAI link configuration by removing ".-1" from device names * and sanitizing names. */ -static char *fmt_single_name(struct device *dev, int *id) +static char *fmt_single_name(struct device *dev, int *id, const char *component_driver_name) { const char *devname = dev_name(dev); char *found, *name; @@ -2263,6 +2263,12 @@ static char *fmt_single_name(struct device *dev, int *id) *id = 0; } + if (component_driver_name) { + char *tmp = name; + + name = devm_kasprintf(dev, GFP_KERNEL, "%s-%s", name, component_driver_name); + devm_kfree(dev, tmp); + } return name; } @@ -2327,7 +2333,7 @@ struct snd_soc_dai *snd_soc_register_dai(struct snd_soc_component *component, */ if (legacy_dai_naming && (dai_drv->id == 0 || dai_drv->name == NULL)) { - dai->name = fmt_single_name(dev, &dai->id); + dai->name = fmt_single_name(dev, &dai->id, NULL); } else { dai->name = fmt_multiple_name(dev, dai_drv); if (dai_drv->id) @@ -2460,7 +2466,7 @@ int snd_soc_component_initialize(struct snd_soc_component *component, INIT_LIST_HEAD(&component->card_list); mutex_init(&component->io_mutex); - component->name = fmt_single_name(dev, &component->id); + component->name = fmt_single_name(dev, &component->id, driver->name); if (!component->name) { dev_err(dev, "ASoC: Failed to allocate name\n"); return -ENOMEM; -- 2.17.1