From patchwork Tue Dec 31 18:44:20 2024 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Martin Blumenstingl X-Patchwork-Id: 13923926 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id 125F5E77194 for ; Tue, 31 Dec 2024 18:44:40 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender:List-Subscribe:List-Help :List-Post:List-Archive:List-Unsubscribe:List-Id:Content-Type:Cc:To:Subject: Message-ID:Date:From:MIME-Version:Reply-To:Content-Transfer-Encoding: Content-ID:Content-Description:Resent-Date:Resent-From:Resent-Sender: Resent-To:Resent-Cc:Resent-Message-ID:In-Reply-To:References:List-Owner; bh=BfHEIfdE/hx7BkBQ+V8RexoN/w3Y5tazSAXXQwn3VZE=; b=ISwKKh9167THCKtOjqx7BGwDdI wLUw8BPqWywhIN5Lkq/TB2EjqtI/1BEXcML9PmOhdeuH/o+F6jPKN2ufQzfEwE0ZqGUTbjok2Sk4A 5GxhgAdUnY7r8RHGA/WmGEMGQ+Co6TS/QDx4F6G1FRn6vCOR0sn7M8GBs/Lw2pSqsAayFX7ZaBjSh ZcQhvlskZWij40OpZDgdihznEiKnr60ha11WjfulhFD8LMBulot6yrqHcympBYReEKWQ6ndpbUTx+ 3yNyreuZEOlKWwmQyO/CeinMQkQor0jNpXH14OSzX2xSr9XGShCHsdbt3NxL5D09byWP9/eW/42qV WhJmA+lA==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.98 #2 (Red Hat Linux)) id 1tShEJ-00000007bxy-2P5L; Tue, 31 Dec 2024 18:44:35 +0000 Received: from mail-pl1-x62c.google.com ([2607:f8b0:4864:20::62c]) by bombadil.infradead.org with esmtps (Exim 4.98 #2 (Red Hat Linux)) id 1tShEG-00000007bxI-2KkC; Tue, 31 Dec 2024 18:44:33 +0000 Received: by mail-pl1-x62c.google.com with SMTP id d9443c01a7336-21649a7bcdcso133612465ad.1; Tue, 31 Dec 2024 10:44:32 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=googlemail.com; s=20230601; t=1735670671; x=1736275471; darn=lists.infradead.org; h=cc:to:subject:message-id:date:from:mime-version:from:to:cc:subject :date:message-id:reply-to; bh=rx/BAtYz+YSmLVs6o5kW+gu0D5xRt+OIkNVnblY2Dys=; b=iCpncPllezxmh9dfcaffwJdOSwHN2bgSBj10zQGTni7jhXsD0V2WSNfYPzzWcfFLHo +BM8jcFBgzlHEfeUIaopuBqmHPod5IwDk41UhaVh+zZH7kEiIfDvbnH5sQtYb9j87Mjc D9e6nSqXyxkfTuMUlpn58BonkKsev0zBbh7eTg/z8e3hJf9pz6QgakgG0wxv6BC2H0b9 0BSL5dmuud88SsEQBVFP+opruoR2u8ghVE+fnY7VgptrBO+QWX9pvv8FkoZl1x/+FU0t kktwgEcBreOlF018sSRMxyBZLuBe49fkNcuiKH79Sii7iG6+soT2A3O6wR0mfbc9pNMy Jb8g== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1735670671; x=1736275471; h=cc:to:subject:message-id:date:from:mime-version:x-gm-message-state :from:to:cc:subject:date:message-id:reply-to; bh=rx/BAtYz+YSmLVs6o5kW+gu0D5xRt+OIkNVnblY2Dys=; b=LtqX1p+luWP9R+g64M1u80VlXVkTwNuShlT/CEw48O/2wz4UXn1NZCc09sYfICrGse rX61iXU67/7jdLkVqd6+L+eQUNN7I1cXVGpIsGmPbsgtnvK5JFpwPgas0EHIg3nsoDZJ /z6Ys9ynWEs+e6jGZ7tDqgRSJ0Kpi6WHLR9tKz+vw/lioLGNMx6ClvdFFz2NUvRb6dPZ jzTOFCRVRj+Fbdjx9486aPlICo7kpIAkKpErnkLdTkDcY4v3x5i9vgSXDZ3Uo/tXJxLf 7wOWdoyJA8fEUAN+h7fZ6FLe30KAEDg8rj9mjyQhIAHQknEVxde4GxUCbNw5lh7DVymb XzUQ== X-Forwarded-Encrypted: i=1; AJvYcCVsh2X6ZILYnvGtA5cHXP9gnVsJsSHSAEudC552ZpNy39TlLYd0noBMbDOxr4o9PiBizZBg6lxJiuTqssqJQbja@lists.infradead.org X-Gm-Message-State: AOJu0Yz9z+3QcxOcqr6RHmfkdcVn/j/wHLykM3D+vbnSS5WRmICo/FSb 5KHNtflMqrVcw0XiEFLzLbDRqazHJgzMf5EoUslp2BACaPtryYhsN+ac9TudcXkaINDLALu6xwI CPzOAJTnFLYGWCgx4KWw/U6WG35eqFVhl X-Gm-Gg: ASbGnct/vsF0n0NdR6Irx0dlZfaxjYMoLe+IYqb2FSxonYVstZQA6uEkEf4BSkhvQI9 olmNb5zbyIYXAXL3YqemN5bAaTSaPVeD3ldJOALX4RRc2FlITdf+75QsmY1wqKOltm7GUv8w= X-Google-Smtp-Source: AGHT+IH0eYkv9jMWnNWk5clNdXDiJhTdGXywUxzL8uXyNgWAEqJCW8pgacoyM8OKkm7iaQpFDbJb+dG7SSGKuIkyu6Q= X-Received: by 2002:a17:903:32c5:b0:215:bb50:6a05 with SMTP id d9443c01a7336-219e6e894f4mr583339975ad.9.1735670671350; Tue, 31 Dec 2024 10:44:31 -0800 (PST) MIME-Version: 1.0 From: Martin Blumenstingl Date: Tue, 31 Dec 2024 19:44:20 +0100 Message-ID: Subject: meson-aiu: HDMI codec .prepare() callback not called To: linux-amlogic@lists.infradead.org, jbrunet@baylibre.com Cc: linux-sound@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, dmitry.baryshkov@linaro.org X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20241231_104432_635406_C7BADD00 X-CRM114-Status: GOOD ( 17.19 ) X-BeenThere: linux-amlogic@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Sender: "linux-amlogic" Errors-To: linux-amlogic-bounces+linux-amlogic=archiver.kernel.org@lists.infradead.org Hi Jerome, I am still working on a HDMI controller driver for Meson8/8b/8m2. HDMI output would be incomplete without audio. There's a great series from Dmitry [0] which simplifies the HDMI controller driver implementation by moving all the hdmi-codec related management to a generic framework. I tried integrating Dmitry's work [0] into my HDMI controller driver. While testing I found that hdmi-codec's .prepare() callback is not called at all and asked Dmitry for help [1]. All other callbacks (.hw_params, .startup, .shutdown, ...) however are called. On his board (Qualcomm SDM845, sdm845-db845c.dts) hdmi_codec_prepare() is called by snd_soc_pcm_dai_prepare() (core sound framework, not platform specific). However, on my Odroid-C1 this is not happening. Looking further snd_soc_pcm_dai_prepare() I can see that for_each_rtd_dais() has three entries: snd_soc_pcm_dai_prepare(), dai name=I2S Encoder, id=2 snd_soc_pcm_dai_prepare(), dai name=CODEC CTRL HDMI I2S IN, id=0 snd_soc_pcm_dai_prepare(), dai name=I2S FIFO, id=0 What I'm missing here is a dai name "i2s-hifi" (from sound/soc/codecs/hdmi-codec.c, see hdmi_i2s_dai) My hdmi_tx node looks like this (abbreviated): hdmi_tx: hdmi-tx@42000 { compatible = "amlogic,meson8b-hdmi-tx"; reg = <0x42000 0xc>; #sound-dai-cells = <1>; ... }; Then I have a "amlogic,gx-sound-card" instance with the following dai-links: dai-link-0 { sound-dai = <&aiu AIU_CPU CPU_I2S_FIFO>; }; dai-link-1 { sound-dai = <&aiu AIU_CPU CPU_I2S_ENCODER>; dai-format = "i2s"; mclk-fs = <256>; codec-0 { sound-dai = <&aiu AIU_HDMI CTRL_I2S>; }; }; dai-link-2 { sound-dai = <&aiu AIU_HDMI CTRL_OUT>; codec-0 { sound-dai = <&hdmi_tx 0>; }; }; So apart from the additional cell in the sound-dai towards hdmi_tx (Meson8/8b/8m2's HDMI controller has two inputs: I2C and SPDIF. I2C is the first one, hence &hdmi_tx 0) this is identical to arch/arm64/boot/dts/amlogic/meson-gxbb-odroidc2.dts. I have further verified that the gx-card parsing does find the HDMi controller and links it correctly. To me it's odd that only the .prepare() callback is not called, all others (as mentioned above: .hw_params, .startup, ...) are working fine. I'm not familiar with the sound stack and I'm hoping that you have some ideas on how to either debug or fix it. Thanks in advance and best regards, Martin [0] https://lore.kernel.org/dri-devel/20241224-drm-bridge-hdmi-connector-v10-0-dc89577cd438@linaro.org/ [1] https://lore.kernel.org/dri-devel/20241231004311.2574720-1-martin.blumenstingl@googlemail.com/ [2] https://lore.kernel.org/dri-devel/l3u3wtnxyhrwjynevkwfjwarisc4yt4xy2rbzf5kb7k5l5dw3n@lxqtimymyjg6/ diff --git a/drivers/gpu/drm/display/drm_hdmi_audio_helper.c b/drivers/gpu/drm/display/drm_hdmi_audio_helper.c index aa3a5d0329dc..05afc9f0bdd6 100644 --- a/drivers/gpu/drm/display/drm_hdmi_audio_helper.c +++ b/drivers/gpu/drm/display/drm_hdmi_audio_helper.c @@ -129,7 +129,6 @@ EXPORT_SYMBOL(drm_connector_hdmi_audio_plugged_notify); static const struct hdmi_codec_ops drm_connector_hdmi_audio_ops = { .audio_startup = drm_connector_hdmi_audio_startup, .prepare = drm_connector_hdmi_audio_prepare, - .hw_params = drm_connector_hdmi_audio_prepare, .audio_shutdown = drm_connector_hdmi_audio_shutdown, .mute_stream = drm_connector_hdmi_audio_mute_stream, .get_eld = drm_connector_hdmi_audio_get_eld, diff --git a/sound/soc/codecs/hdmi-codec.c b/sound/soc/codecs/hdmi-codec.c index 69f98975e14a..a931d05ba89e 100644 --- a/sound/soc/codecs/hdmi-codec.c +++ b/sound/soc/codecs/hdmi-codec.c @@ -570,13 +570,13 @@ static int hdmi_codec_hw_params(struct snd_pcm_substream *substream, }; int ret; - if (!hcp->hcd.ops->hw_params) - return 0; - - dev_dbg(dai->dev, "%s() width %d rate %d channels %d\n", __func__, + dev_info(dai->dev, "%s() width %d rate %d channels %d\n", __func__, params_width(params), params_rate(params), params_channels(params)); + if (!hcp->hcd.ops->hw_params) + return 0; + ret = hdmi_codec_fill_codec_params(dai, params_width(params), params_rate(params), @@ -611,12 +611,12 @@ static int hdmi_codec_prepare(struct snd_pcm_substream *substream, struct hdmi_codec_params hp; int ret; + dev_info(dai->dev, "%s() width %d rate %d channels %d\n", __func__, + width, rate, channels); + if (!hcp->hcd.ops->prepare) return 0; - dev_dbg(dai->dev, "%s() width %d rate %d channels %d\n", __func__, - width, rate, channels); - ret = hdmi_codec_fill_codec_params(dai, width, rate, channels, &hp); if (ret < 0) return ret; diff --git a/sound/soc/soc-dai.c b/sound/soc/soc-dai.c index 34ba1a93a4c9..030c573753cc 100644 --- a/sound/soc/soc-dai.c +++ b/sound/soc/soc-dai.c @@ -577,6 +577,7 @@ int snd_soc_pcm_dai_prepare(struct snd_pcm_substream *substream) int i, ret; for_each_rtd_dais(rtd, i, dai) { + pr_info("%s(), dai name=%s, id=%d\n", __func__, dai->name, dai->id); if (!snd_soc_dai_stream_valid(dai, substream->stream)) continue; if (dai->driver->ops &&