From nobody Sun Feb 8 13:10:35 2026 Received: from mail-wm1-f65.google.com (mail-wm1-f65.google.com [209.85.128.65]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 028CB3EF0C0 for ; Fri, 6 Feb 2026 17:34:39 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.128.65 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1770399280; cv=none; b=Ml0dso6oKjyvx9EC8lFHdgBR3xUxKm5JvRGNyOdoMwMVHAirE9d4su7iLuRD10CL8Psw/AysJgP819fpndau4o+yeNW3+RoqtoUNmYHqLAnTTU1XLSOzuf8ZpbGjDKGCvOH0U/VMSaAB/WP7kLxZrfAIFm0mRJaNpgYiI44Yq+8= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1770399280; c=relaxed/simple; bh=tT4egkhAh/4FJlYjxvVmOIEurMTvY9gcIWgBMYTPX9o=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=oEKnqrmFzA9jn/SzJsa5cSF2ljfPZ9pbk0WkR5pTgJNSGtXiyEZgqliKDE/QY1tu8KdjwQyk+RJ21sjXB1bKAKBXw7vwOF1kEwumJNO3I7+UBn0UcDjmicFIs26zfJRJTtAoMEnAFckCQE9eq9X1daoikWMSRACR2+pMNNFSdBI= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com; spf=pass smtp.mailfrom=gmail.com; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b=hJFtEl6x; arc=none smtp.client-ip=209.85.128.65 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="hJFtEl6x" Received: by mail-wm1-f65.google.com with SMTP id 5b1f17b1804b1-4801c2fae63so19359325e9.2 for ; Fri, 06 Feb 2026 09:34:39 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1770399278; x=1771004078; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=kF1hhqYZPeYTY+vJ3xTMx17h8TLzRw6tKr0GpQ4bJnw=; b=hJFtEl6xfrQ2/cNaRZIZABNmoMqTD2SLl3r35x3WiN1L3+sqYWiFb8+vOv8qYPyrlV iORAqPKpc6gf7+zCQhX1EYjUCszDOMslrXkL03mG8n1NuF38FNjwGZq7QlmkJhwQlpZx U2tJ/J2Xn7h0gwifWjUHHsOXhPPMuv8M8fxCQq5C+ns6jlQTLgJlVevF0VHelpHqg0Yq i4P2rnjh6yMpon/6hmBcedPC1KK+ufC8GagUlS4FEWmsFJifEUIo0/UigFJ2A/yAOYgu arYSw7qVWa78ayal3S37fXV9fVap3yviKFsrmEP05E27dateN/f/K2EuK1cJL6pLTTA3 uykA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1770399278; x=1771004078; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-gg:x-gm-message-state:from :to:cc:subject:date:message-id:reply-to; bh=kF1hhqYZPeYTY+vJ3xTMx17h8TLzRw6tKr0GpQ4bJnw=; b=bjcWA1AM8q33JQ5dQFO8rQie7Yuzlvgh4+tpW8qirAZBPeRN450CwtngSarEuo2y/4 Gf7QI/+G1MMF70T4wW5wFFRJK2S0MB7fvJl0YHy5Hcim3V91p9XHYpbM6J5MCBznngKY RiiDx+WqfQ32WFOHpPbD45BwTzVwXye8aLm1kjbCQyjTcWffPUFAtasPWnOwk5UUW/WH vykec5ytzqfiA1BE8LuIHc7NG2tQr03MGoF5s5KG4iaNGpzRV1AEBRC0UMdH7DNR1Pum X4Tp+hN+o13F05Tdf7F0F+hrO6MeCBBV/TCFwjiEzV3GI6GmyMHKtiM8dd2+BTHRMCbG UCvw== X-Forwarded-Encrypted: i=1; AJvYcCUCGmDVLC793iTokla22xIbhBE9qg0O5NlAEjC0Dus1mwY+NZlL1OMF+ZpOdDbr1DJRTQTi+F3uUkjXwG4=@vger.kernel.org X-Gm-Message-State: AOJu0Yw26jntE6/NCdIT0eTEGznSSQuxY3cPXP2T0dQM3aBk2zbMihOw wRVnjObQNiPsKDi3auE2L3n+/QioE4qVc7SsVtnQKQDEwgsFMV7pBQqH X-Gm-Gg: AZuq6aIVkkPX60KrIHv8Lh6/oahiAR0bODQyXm+lSNCk6HmOprb/urDUd7eVUlkJOkJ 2dAYQpN55rZAczp3GnJti9Mc8gU4VS2TDoSrDL0G2jcS1oG/5EscqMMI31CZixHzW1TTJoEOh0Y IMwt7J3pX5gxiPu4h9x00qSeMMO/2oq5aTGnRB9XIht9dKhk76wIP0WIkA6wZ2uoEjSUueClEbc D7nhRMFGRhmsJoINQaoyajsFc/1fBqD5QbniYLpj+gU6Y2ouZi9I0b5KxhYEqARTZTTXNfby+4B i0NftFc3mlthMcxSe8Mqt2ZApSLOEOz4b7Z6TcuFdjkwYx5lkLepvvFkpV29jb1yMPStyvgwRMX Gb+FH/zx7F31+3u0+lugHtqSeyUQvfXKvBZ5mQhvq9wFikpvkfKFrejnE3vCqEXV+EPMSmIj/Kc ce/RIUAoJIxM8= X-Received: by 2002:a05:600c:a08:b0:480:4d37:e742 with SMTP id 5b1f17b1804b1-483201dd276mr48259315e9.10.1770399278112; Fri, 06 Feb 2026 09:34:38 -0800 (PST) Received: from xeon ([188.163.112.49]) by smtp.gmail.com with ESMTPSA id ffacd0b85a97d-436296bd4a1sm7454523f8f.17.2026.02.06.09.34.37 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 06 Feb 2026 09:34:37 -0800 (PST) From: Svyatoslav Ryhel To: Liam Girdwood , Mark Brown , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Thierry Reding , Jonathan Hunter , Jaroslav Kysela , Takashi Iwai , Svyatoslav Ryhel , =?UTF-8?q?Jonas=20Schw=C3=B6bel?= Cc: linux-sound@vger.kernel.org, devicetree@vger.kernel.org, linux-tegra@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH v2 1/5] ASoC: dt-bindings: nvidia,tegra-audio: document CPCAP CODEC Date: Fri, 6 Feb 2026 19:34:18 +0200 Message-ID: <20260206173423.145954-2-clamor95@gmail.com> X-Mailer: git-send-email 2.51.0 In-Reply-To: <20260206173423.145954-1-clamor95@gmail.com> References: <20260206173423.145954-1-clamor95@gmail.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable Content-Type: text/plain; charset="utf-8" Add dt-binding for CPCAP CODEC. Signed-off-by: Svyatoslav Ryhel --- .../sound/nvidia,tegra-audio-cpcap.yaml | 90 +++++++++++++++++++ 1 file changed, 90 insertions(+) create mode 100644 Documentation/devicetree/bindings/sound/nvidia,tegra-au= dio-cpcap.yaml diff --git a/Documentation/devicetree/bindings/sound/nvidia,tegra-audio-cpc= ap.yaml b/Documentation/devicetree/bindings/sound/nvidia,tegra-audio-cpcap.= yaml new file mode 100644 index 000000000000..5335fa56fb3c --- /dev/null +++ b/Documentation/devicetree/bindings/sound/nvidia,tegra-audio-cpcap.yaml @@ -0,0 +1,90 @@ +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) +%YAML 1.2 +--- +$id: http://devicetree.org/schemas/sound/nvidia,tegra-audio-cpcap.yaml# +$schema: http://devicetree.org/meta-schemas/core.yaml# + +title: NVIDIA Tegra audio complex with CPCAP CODEC + +maintainers: + - Svyatoslav Ryhel + +allOf: + - $ref: nvidia,tegra-audio-common.yaml# + +properties: + compatible: + items: + - pattern: '^[a-z0-9]+,tegra-audio-cpcap(-[a-z0-9]+)+$' + - const: nvidia,tegra-audio-cpcap + + nvidia,audio-routing: + $ref: /schemas/types.yaml#/definitions/non-unique-string-array + description: + A list of the connections between audio components. Each entry is a + pair of strings, the first being the connection's sink, the second + being the connection's source. Valid names for sources and sinks are + the pins (documented in the binding document), and the jacks on the + board. + minItems: 2 + items: + enum: + # Board Connectors + - Speakers + - Int Spk + - Earpiece + - Int Mic + - Headset Mic + - Internal Mic 1 + - Internal Mic 2 + - Headphone + - Headphones + - Headphone Jack + - Mic Jack + + # CODEC Pins + - MICR + - HSMIC + - EMUMIC + - MICL + - EXTR + - EXTL + - EP + - SPKR + - SPKL + - LINER + - LINEL + - HSR + - HSL + - EMUR + - EMUL + +unevaluatedProperties: false + +examples: + - | + #include + #include + sound { + compatible =3D "motorola,tegra-audio-cpcap-mot", + "nvidia,tegra-audio-cpcap"; + nvidia,model =3D "Motorola Atrix 4G (MB860) CPCAP"; + + nvidia,audio-routing =3D + "Headphones", "HSR", + "Headphones", "HSL", + "Int Spk", "SPKR", + "Int Spk", "SPKL", + "Earpiece", "EP", + "HSMIC", "Mic Jack", + "MICR", "Internal Mic 1", + "MICL", "Internal Mic 2"; + + nvidia,i2s-controller =3D <&tegra_i2s1>; + nvidia,audio-codec =3D <&cpcap_audio>; + + clocks =3D <&tegra_car TEGRA20_CLK_PLL_A>, + <&tegra_car TEGRA20_CLK_PLL_A_OUT0>, + <&tegra_car TEGRA20_CLK_CDEV1>; + clock-names =3D "pll_a", "pll_a_out0", "mclk"; + }; --=20 2.51.0 From nobody Sun Feb 8 13:10:35 2026 Received: from mail-wr1-f42.google.com (mail-wr1-f42.google.com [209.85.221.42]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id EFDB041B34F for ; Fri, 6 Feb 2026 17:34:40 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.221.42 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1770399281; cv=none; b=H2aFzccbq0zl/NM1ffyas6piE3pbkpJIYhqX1kBMB+hoztL+eeY579ku+o+eASW20Hh8LlhELo/i4QXtN3su5H9OCDSYJEleJhr19ovatGgSYKN5z5/n/9mmGAd1UZMHwMxqSRLRv6hl7ebvo3ElfYEa9qWcZJMCF4J4rAA/XQw= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1770399281; c=relaxed/simple; bh=xM19W5y6sBZhK63TGYfPq7Dcx+S+y11DhFbKJgJ2kiA=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=Blr+mdy5A0zDOu+tI/TUKb6SQYSjT73pEIJjmA6nU7TK0eOBtZqs0xo4we/TvfEhG4M7zqvTsY+ihwg98T6wO8buw9onDj6yvvAuQ/0KU3/tVczjU2hnfOpDUMgbEug52qkrEl23nUPgtWoJ+PGNNDNueQYjgRYrWWuNDyAEQXM= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com; spf=pass smtp.mailfrom=gmail.com; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b=LCBLrlXm; arc=none smtp.client-ip=209.85.221.42 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="LCBLrlXm" Received: by mail-wr1-f42.google.com with SMTP id ffacd0b85a97d-4359a316d89so1963604f8f.0 for ; Fri, 06 Feb 2026 09:34:40 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1770399279; x=1771004079; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=S1uE9SbozYnquR9REkQsKIr4GVqaAJFPEg6pyN2tdEE=; b=LCBLrlXmGPDxM+vdCHjLYlxhSDszn0WfxISbJVKJYEL6IjQJ1WaSAFawaE1/hd6WjS lLgCj2wFxzIvz8BI23nSkEMKJMqTp8soqYS1qwQTGRiS6QMhn/PPdvSpIMo2GpomzJJ/ 6iA6MbKsouvpZeiKJrR80Ap6VjdwjEdLbkKQvJupfn4IDril9Je2mV06s2admJHaSyEa JocKfoX3+APeJxoitxyEgVs851iiNyT7JsHjUlJY5JGzy86/xN8Uea1FDceKrg8CGi3S TyoVLkxQtvOJU5aixf+ol+K3RwWPgu02gGdCg/5P4Gyq5FBM9zZUEl0kRzG5ExDXZPAI Bo6g== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1770399279; x=1771004079; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-gg:x-gm-message-state:from :to:cc:subject:date:message-id:reply-to; bh=S1uE9SbozYnquR9REkQsKIr4GVqaAJFPEg6pyN2tdEE=; b=Lny4din0UD8NBR6lCeJkaL/2ZtsyUkt4R+ETxW4/+1fWwmK+Gb9FWp2qVVlr8z2dFy qkXBkOpVz+E5YtBw/AkaDQctS+7l0zyypdctNmB0yfRZxGKMGabYyj54tNqr2G2cn53g u7OvAano3NnNTgnRjFpt51cWD3xj3TqCDLUxF9v7eyMFw3ugxFeKB+W6PYgl4hqj/vAi YGtbvCMYwWYGt8jB4qCmCBEpwmXEytxYAY/za652fvSbTsgOzhDCfIMZ12Ry8yuI01Gj 5JpZ0E6t4hNpfRGonDUqsGhDFeEcic+m9NfDziY1P59VGsWRGqKCJBaMUvFMjjwM4Go8 URBw== X-Forwarded-Encrypted: i=1; AJvYcCX8z/OCAH2RYG8aVUOUPq1RR5uOeZ175zbTHfI//TlnM/wFXVxePJBpXIcUUM2AiAe9UeFCQw3UlCbuMb4=@vger.kernel.org X-Gm-Message-State: AOJu0YwXiesK7LTqUMo6AaEFDB+c8D1yRNX45TUXTYuDx8WVrRHWSdBk b848xaaK4IIwr+fWzwjgMeQ5mPb2o1zywByMhWCiZ0KO7RcTZsWWJ+SG X-Gm-Gg: AZuq6aLXfiKMhnoiBb8U8tB+ftq5f8DZB/DAa6UKaJlqB7i+DKyKYNzkLm1+XSfeIRN fvzhT14ZKLWObtxkezTATjb01e4nAAIIlwPl0wVUAvvzAgr+jtasYx9nskyoZOk72Kc4+Naw0YN /hXtUsz7BBHejiXwWFU33TVoTGOGRblSAFvf/xAuGx45g2jG0OE7NAzbVYE8Se6PVXI8PqKbbIh gJJs9FHNhaozHnkHybEJaI+meba9TjAynDUzcB8X1KvrRgrEtp6E15h3rZEDqtSLxOdj6SKp7em JgvU5jKWuqGiDqZopozFfUo6BTT6NSiydBh9XjZJLsbITu8+/3mRWq41J+cFCVLROMc2f2F6xZQ 4WtKlUOTJ+HL228DiE6WQtxHKjjkqWC63YbTTNo7jT9i1b1g5CTongO0hpWUp14avERP9n5VtDC I7 X-Received: by 2002:a05:6000:186d:b0:433:42d1:f71f with SMTP id ffacd0b85a97d-4362934c50amr5948476f8f.38.1770399279228; Fri, 06 Feb 2026 09:34:39 -0800 (PST) Received: from xeon ([188.163.112.49]) by smtp.gmail.com with ESMTPSA id ffacd0b85a97d-436296bd4a1sm7454523f8f.17.2026.02.06.09.34.38 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 06 Feb 2026 09:34:38 -0800 (PST) From: Svyatoslav Ryhel To: Liam Girdwood , Mark Brown , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Thierry Reding , Jonathan Hunter , Jaroslav Kysela , Takashi Iwai , Svyatoslav Ryhel , =?UTF-8?q?Jonas=20Schw=C3=B6bel?= Cc: linux-sound@vger.kernel.org, devicetree@vger.kernel.org, linux-tegra@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH v2 2/5] ASoC: tegra: Support CPCAP by machine driver Date: Fri, 6 Feb 2026 19:34:19 +0200 Message-ID: <20260206173423.145954-3-clamor95@gmail.com> X-Mailer: git-send-email 2.51.0 In-Reply-To: <20260206173423.145954-1-clamor95@gmail.com> References: <20260206173423.145954-1-clamor95@gmail.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable Content-Type: text/plain; charset="utf-8" Add CPCAP codec support to the Tegra ASoC machine driver. This codec is found in Motorola T20 devices like Atrix 4G and Droid X2. Signed-off-by: Svyatoslav Ryhel --- sound/soc/tegra/Kconfig | 9 +++++ sound/soc/tegra/tegra_asoc_machine.c | 52 ++++++++++++++++++++++++++++ 2 files changed, 61 insertions(+) diff --git a/sound/soc/tegra/Kconfig b/sound/soc/tegra/Kconfig index 9dbd589879fb..dd58525b7079 100644 --- a/sound/soc/tegra/Kconfig +++ b/sound/soc/tegra/Kconfig @@ -294,6 +294,15 @@ config SND_SOC_TEGRA_SGTL5000 boards using the SGTL5000 codec, such as Apalis T30, Apalis TK1 or Colibri T30. =20 +config SND_SOC_TEGRA_CPCAP + tristate "SoC Audio support for Tegra boards using a CPCAP codec" + depends on I2C && GPIOLIB && MFD_CPCAP + select SND_SOC_TEGRA_MACHINE_DRV + select SND_SOC_CPCAP + help + Say Y or M here if you want to add support for SoC audio on Tegra + boards using the CPCAP codec, such as Motorola Atrix 4G or Droid X2. + endif =20 endmenu diff --git a/sound/soc/tegra/tegra_asoc_machine.c b/sound/soc/tegra/tegra_a= soc_machine.c index d48463ac16fc..10834f9c3422 100644 --- a/sound/soc/tegra/tegra_asoc_machine.c +++ b/sound/soc/tegra/tegra_asoc_machine.c @@ -287,6 +287,25 @@ static unsigned int tegra_machine_mclk_rate_6mhz(unsig= ned int srate) return mclk; } =20 +static unsigned int tegra_machine_mclk_rate_cpcap(unsigned int srate) +{ + unsigned int mclk; + + switch (srate) { + case 11025: + case 22050: + case 44100: + case 88200: + mclk =3D 26000000; + break; + default: + mclk =3D 256 * srate; + break; + } + + return mclk; +} + static int tegra_machine_hw_params(struct snd_pcm_substream *substream, struct snd_pcm_hw_params *params) { @@ -985,6 +1004,38 @@ static const struct tegra_asoc_data tegra_rt5631_data= =3D { .add_hp_jack =3D true, }; =20 +/* CPCAP machine */ + +SND_SOC_DAILINK_DEFS(cpcap_hifi, + DAILINK_COMP_ARRAY(COMP_EMPTY()), + DAILINK_COMP_ARRAY(COMP_CODEC(NULL, "cpcap-hifi")), + DAILINK_COMP_ARRAY(COMP_EMPTY())); + +static struct snd_soc_dai_link tegra_cpcap_dai =3D { + .name =3D "CPCAP", + .stream_name =3D "CPCAP PCM", + .init =3D tegra_asoc_machine_init, + .dai_fmt =3D SND_SOC_DAIFMT_I2S | + SND_SOC_DAIFMT_NB_NF | + SND_SOC_DAIFMT_CBP_CFP, + SND_SOC_DAILINK_REG(cpcap_hifi), +}; + +static struct snd_soc_card snd_soc_tegra_cpcap =3D { + .components =3D "codec:cpcap", + .dai_link =3D &tegra_cpcap_dai, + .num_links =3D 1, + .fully_routed =3D true, +}; + +static const struct tegra_asoc_data tegra_cpcap_data =3D { + .mclk_rate =3D tegra_machine_mclk_rate_cpcap, + .card =3D &snd_soc_tegra_cpcap, + .add_common_dapm_widgets =3D true, + .add_common_controls =3D true, + .add_common_snd_ops =3D true, +}; + static const struct of_device_id tegra_machine_of_match[] =3D { { .compatible =3D "nvidia,tegra-audio-trimslice", .data =3D &tegra_trimsl= ice_data }, { .compatible =3D "nvidia,tegra-audio-max98090", .data =3D &tegra_max9809= 0_data }, @@ -997,6 +1048,7 @@ static const struct of_device_id tegra_machine_of_matc= h[] =3D { { .compatible =3D "nvidia,tegra-audio-rt5640", .data =3D &tegra_rt5640_da= ta }, { .compatible =3D "nvidia,tegra-audio-alc5632", .data =3D &tegra_rt5632_d= ata }, { .compatible =3D "nvidia,tegra-audio-rt5631", .data =3D &tegra_rt5631_da= ta }, + { .compatible =3D "nvidia,tegra-audio-cpcap", .data =3D &tegra_cpcap_data= }, {}, }; MODULE_DEVICE_TABLE(of, tegra_machine_of_match); --=20 2.51.0 From nobody Sun Feb 8 13:10:35 2026 Received: from mail-wm1-f67.google.com (mail-wm1-f67.google.com [209.85.128.67]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 2677640FD87 for ; Fri, 6 Feb 2026 17:34:41 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.128.67 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1770399282; cv=none; b=mNufPkX3YLaohpottvpX9NsLKbexDtdEAsqIOVY8PI8hYX7+PJPvnGxv+g8aB8WDCJjBAnQyCWt0B//L3HDSxp70ybJwHyiwzWynp3yK4uc6XzbugS+zZ3WA3XyEc5PFYjqv+47uDvlK+OEWerFa/BfEt9tbXZKwVnmfJB1Z8Dc= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1770399282; c=relaxed/simple; bh=E50Z0kZ8QEC/+gID4A4p9F54kc2DuevigG1LcHQ1FUU=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=PEiYYK6v2o36sMdDpKS17RfELttrEyIENJ7b1ukx5N9X5pva7tc/4psDcH8F634Wxh+NonHHD2L7aB6XnHdnUo3rYmnalCcRRWh8d2yJvZx/BlTYcKbQGWUK823cwmRLoiFzc5LUN/EXyC/lr7WM89GiklB+8Lycw0LD0cOUvVk= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com; spf=pass smtp.mailfrom=gmail.com; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b=L3kZA4RD; arc=none smtp.client-ip=209.85.128.67 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="L3kZA4RD" Received: by mail-wm1-f67.google.com with SMTP id 5b1f17b1804b1-47f5c2283b6so21650285e9.1 for ; Fri, 06 Feb 2026 09:34:41 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1770399280; x=1771004080; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=CDk6pvEbCDbKFm0MEs5hS5v1vRZPcd+sQDBn0D1BQXQ=; b=L3kZA4RDeGJ0TEanrpd2NjUfonzD8ktbuKDOeJd5Pyk0kMqRbfHehb8/a6TUJcVP1+ ESzEFwDwXi6iVRmQWsLzKgt1O2SVi78zp/WEpQVbMB6+oVFdw0gz+AGjKF08u9yhiMIa BuWJYjopuPXTGPMT2O8wuWiFNyXbJPk+fchTjtQhqY0Omr9b2j/JcMOIRaXCS3EOFclC 2tybReXUEWSZ2ZZ/nVcJ88/iE412kEkNfC5fWppu8mc85V8r6XseiZ5TaOc27lI0FYEt QYO9o+2B1tB+YNiQV2KsRYoU0YHp4w/7dXTWNWbdDBOkgs8Qwr7wpuUjyiY4YlPbCKHk kbjg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1770399280; x=1771004080; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-gg:x-gm-message-state:from :to:cc:subject:date:message-id:reply-to; bh=CDk6pvEbCDbKFm0MEs5hS5v1vRZPcd+sQDBn0D1BQXQ=; b=NFFS21JmM+gYrpc7neQ9q3FIbb1G0Ey6NQMyOvwX5kxLKPXe8bT9AScyX66itY4M9a i4K8BPzsjml7pND3gmbFhO3ZzuTBPxxXeWIYil40uGJMGJirhrMoN4cubdz2Rkn0upXq vV607Fd/Bu/i6FEuswpL6r9OjPThDbJTzBbKMlfle6BMp9WBgl9LgdoBM3F0CioXqvP0 oDPpNCgoLvxINzInHH/ULE79MiNPvg8syaUTBuo9x+X0DysrdMLufLwFfcTRc8UFhzbf LmBHwUTB/CPSKp59IUjH8pHxPCIsnbQQpA18Ffc59ArIVP4dbXcsaBi+7LKiOLt6wDyB PmqA== X-Forwarded-Encrypted: i=1; AJvYcCUjY7VROC9ANAttFVnI8yO/a8pkz9SdtwR1cbXQA2BHB+j61GtHadUr0VglGodbjZ31do5zxeOpPhNy8KE=@vger.kernel.org X-Gm-Message-State: AOJu0YxtgWgAjdWwKG1T8z+lkkQiJgUuupC8JfVwaoSVln1h6ovNgJ1L 90piiBV2BzIB1c4CHFWP6ZJOxQYMAoFOUY9UyfNFvL/NFBY2k15fX8WM X-Gm-Gg: AZuq6aLs4fj2VTRlpokK4q20VQ9bY3VLfX8ES+WyZu9BT30TV4rzw9SHTEdo+bbQkCz dXNf/mnNYBvdoXg11nNpwBpwNsKSBvfQB5KKyoWpwy/HU7EeruCfQUYtpR4jROuVDKAztO6aEnJ vTAHpUsCFo3eTZ+dtioRTbL75rbi1cSlzZkbb+6meXcHQGt9ne65WFjnAt03JymFz5AsjBtrEf3 682rL4PzQK2Y81zOxvLzqta+2r4qgE92vYWysOCRPGuRklrIbEUgeRO+fGufqrQNGzWfJ8ulPJW Qen2pLlLLgxG2n6KlGM9VUULCeNW/JZiXbIZVwQVoUfkW4rTB2KJF/zG935I42pTrzLyFiwypIs IwWqxrww/aD/LdviurB1KNlB9akmLL38zOf7ULuQuBAg7DJRaQbcRjaTwjsTALb97Y1R65/GpEr Un X-Received: by 2002:a05:600c:3b20:b0:47a:9560:ec28 with SMTP id 5b1f17b1804b1-4832020df6amr48124095e9.13.1770399280411; Fri, 06 Feb 2026 09:34:40 -0800 (PST) Received: from xeon ([188.163.112.49]) by smtp.gmail.com with ESMTPSA id ffacd0b85a97d-436296bd4a1sm7454523f8f.17.2026.02.06.09.34.39 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 06 Feb 2026 09:34:40 -0800 (PST) From: Svyatoslav Ryhel To: Liam Girdwood , Mark Brown , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Thierry Reding , Jonathan Hunter , Jaroslav Kysela , Takashi Iwai , Svyatoslav Ryhel , =?UTF-8?q?Jonas=20Schw=C3=B6bel?= Cc: linux-sound@vger.kernel.org, devicetree@vger.kernel.org, linux-tegra@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH v2 3/5] ASoC: dt-bindings: nvidia,tegra-audio: document WM8962 CODEC Date: Fri, 6 Feb 2026 19:34:20 +0200 Message-ID: <20260206173423.145954-4-clamor95@gmail.com> X-Mailer: git-send-email 2.51.0 In-Reply-To: <20260206173423.145954-1-clamor95@gmail.com> References: <20260206173423.145954-1-clamor95@gmail.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable Content-Type: text/plain; charset="utf-8" Add dt-binding for WM8962 CODEC. Signed-off-by: Svyatoslav Ryhel --- .../sound/nvidia,tegra-audio-wm8962.yaml | 88 +++++++++++++++++++ 1 file changed, 88 insertions(+) create mode 100644 Documentation/devicetree/bindings/sound/nvidia,tegra-au= dio-wm8962.yaml diff --git a/Documentation/devicetree/bindings/sound/nvidia,tegra-audio-wm8= 962.yaml b/Documentation/devicetree/bindings/sound/nvidia,tegra-audio-wm896= 2.yaml new file mode 100644 index 000000000000..2c3bf5a02a34 --- /dev/null +++ b/Documentation/devicetree/bindings/sound/nvidia,tegra-audio-wm8962.yaml @@ -0,0 +1,88 @@ +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) +%YAML 1.2 +--- +$id: http://devicetree.org/schemas/sound/nvidia,tegra-audio-wm8962.yaml# +$schema: http://devicetree.org/meta-schemas/core.yaml# + +title: NVIDIA Tegra audio complex with WM8962 CODEC + +maintainers: + - Svyatoslav Ryhel + +allOf: + - $ref: nvidia,tegra-audio-common.yaml# + +properties: + compatible: + items: + - pattern: '^[a-z0-9]+,tegra-audio-wm8962(-[a-z0-9]+)+$' + - const: nvidia,tegra-audio-wm8962 + + nvidia,audio-routing: + $ref: /schemas/types.yaml#/definitions/non-unique-string-array + description: + A list of the connections between audio components. Each entry is a + pair of strings, the first being the connection's sink, the second + being the connection's source. Valid names for sources and sinks are + the pins (documented in the binding document), and the jacks on the + board. + minItems: 2 + items: + enum: + # Board Connectors + - Speakers + - Int Spk + - Earpiece + - Int Mic + - Headset Mic + - Internal Mic 1 + - Internal Mic 2 + - Headphone + - Headphones + - Headphone Jack + - Mic Jack + + # CODEC Pins + - IN1L + - IN1R + - IN2L + - IN2R + - IN3L + - IN3R + - IN4L + - IN4R + - DMICDAT + - HPOUTL + - HPOUTR + - SPKOUT + - SPKOUTL + - SPKOUTR + +required: + - nvidia,i2s-controller + +unevaluatedProperties: false + +examples: + - | + #include + #include + sound { + compatible =3D "microsoft,tegra-audio-wm8962-surface-rt", + "nvidia,tegra-audio-wm8962"; + nvidia,model =3D "Microsoft Surface RT WM8962"; + + nvidia,audio-routing =3D + "Headphone Jack", "HPOUTR", + "Headphone Jack", "HPOUTL", + "Int Spk", "SPKOUTR", + "Int Spk", "SPKOUTL"; + + nvidia,i2s-controller =3D <&tegra_i2s1>; + nvidia,audio-codec =3D <&wm8962>; + + clocks =3D <&tegra_car TEGRA30_CLK_PLL_A>, + <&tegra_car TEGRA30_CLK_PLL_A_OUT0>, + <&tegra_pmc TEGRA_PMC_CLK_OUT_1>; + clock-names =3D "pll_a", "pll_a_out0", "mclk"; + }; --=20 2.51.0 From nobody Sun Feb 8 13:10:35 2026 Received: from mail-wr1-f50.google.com (mail-wr1-f50.google.com [209.85.221.50]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 4379141C2FA for ; Fri, 6 Feb 2026 17:34:43 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.221.50 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1770399283; cv=none; b=qEPrtAOiLRJ3VR6sO0jQEB/rY5Bf3mNIasRqSWd/uFbHvQCFWxhBfS8O7eA33s+44MkYutsl7H7/kca7wRQV+wGyXvqV/xypGDUlETD25oPPDjMzmA/6+Im/IyX+jb5O2+77s+rvtdMoA05yl5Ka1RzshX+wxkaNPyBx/hGg8FA= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1770399283; c=relaxed/simple; bh=yQseu6gM2haEIm/ayUoG3639fNPMyxWFXUHZI+hw/MA=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version:Content-Type; b=jKZNlB3OB6cYFmeyWOWOS28Qd6LPB2O66lms9m/76cYVCf3beCxdnWZs7TC+w9FBGijzrXZXuylj9eZwMyOJbw/5nXFhmIyD/fQLjql9C1gyeii6OVoAUWsn3srklHWhbd/6+SmgybtQcsm8h4Tm+x3fCqW/WrwTh/IBufyiZco= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com; spf=pass smtp.mailfrom=gmail.com; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b=htxHN6H2; arc=none smtp.client-ip=209.85.221.50 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="htxHN6H2" Received: by mail-wr1-f50.google.com with SMTP id ffacd0b85a97d-4359a302794so679655f8f.1 for ; Fri, 06 Feb 2026 09:34:43 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1770399282; x=1771004082; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=htXBvNPgxXNOHZBCLFJRJ5Aq3ZtCWpOxvSqLp1RXyrk=; b=htxHN6H22fQr/tKGomUm5OBCFkj9D12sMw6/K965cBZryy/B5OEPN7H9Dmq0Ve42Ek gszRnMchhmdmi33NNEH+JFdEFc/4/EDmbroQ80++H1ad2blP0jRX6RAMUI1uJ3a9kWsU ABS24H7qx/9RTAhoVb9KyuL6hh+cjyq5XmFUAVvE3B8dPfb5sGtZhAxMrLzddX9gF0DB Mr2ES0zKHByOtK9SHdgL6/cJGm4+NvSw4cl0IXruJeN+lnSjLDFP9NGYT/7HLFF9soXE 1lioujO79aWT46UO5c88A4P7znIo1v+jTZlhwQSrvBY96xSQ1mezIJVdZVQ0fJKZhKHm Oywg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1770399282; x=1771004082; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-gg:x-gm-message-state:from :to:cc:subject:date:message-id:reply-to; bh=htXBvNPgxXNOHZBCLFJRJ5Aq3ZtCWpOxvSqLp1RXyrk=; b=H+u8w9K0BL7r1n8tMEo8tzzZx7E5C86UQMhMxneIypfpU+WfOOPmcuuhxrWZWQ+rSJ Z7kJ7gGQ15bZVWNXgEUTDObQnNhpH1bEQJ9CSXEA3mPtUjyNl2BDyEhLyFMV3S+9NLNM SnUxvgZX4XR0Pyfl98oIFK4CYDQYc3rZoJbVkaTz9YtGxcMZ8SPsB82Nul97Ua0DmCD/ hcoMuNUtSV/9weRGxC2cjQKdFREIwP08L/mB68hKLex2Y22fZy/+M3HsJ/pJkOnZRwhw W0xfmjmlJgW3F6B5JDubmuI4k3dB03yxXej4dGwbJTNOEOZrY0oJZXjP5yZV5ehx0uqw 7ddw== X-Forwarded-Encrypted: i=1; AJvYcCXm6HELSvYk95hl5+K12NQDC+H3B6PpfSAuvXRrOd5TXVXBfjK+B7u75b1IENoUcQru0iocEwZ9rmthGdc=@vger.kernel.org X-Gm-Message-State: AOJu0YwSSh7oLbITpvcHsZFqgSL8FCDk1ACHqCyj4pMiHjdos4L2NPuB erR5VIdBDoWa9aO8+dQXY6iGZlNfD1Y8EIdPgTPjeuIZPWpXkW5CNRDO X-Gm-Gg: AZuq6aIRVL+HZggL7TKHbMu6thB7PpFZfvv8Gf3JFQdW+YpC8jm7KW05PpcqkEphXPl 1m5X99Jkr49hYIB8j3DJwvY4O5rRvLYSIYrzCZeKEwl7jIY88nGu+Ij1RoMt1u65AAwI93MEqsC paa+YOozuRTc1zssyFRWx8xVbOgWdDVtrWi+ARVCFTAQXqideaGxlVIjMnl0GGOoXXA+mrsuRTM sGX30c5vL5RIbYzjq0JouVW6s+BpQedL7wh3WbnjtMrvCSn/05RoLxrq8JZaDGXq4egQBW9k+cX +jtfNbI+2zevS31o6VgiQIFS/AqFCDWMywflDM/1cfg48tLVI8y1/geV/VTL3ewuOx/zfaJ+X9G STARrVPYQRMr2r2XCOvpDLoOBVujzIXeoVhXj/xPEjUu/sY53a5Uv0l1tchLJNGFew4MxmsvwEE Xk X-Received: by 2002:a05:600c:19c7:b0:45d:dc85:c009 with SMTP id 5b1f17b1804b1-483201e160dmr47405795e9.10.1770399281553; Fri, 06 Feb 2026 09:34:41 -0800 (PST) Received: from xeon ([188.163.112.49]) by smtp.gmail.com with ESMTPSA id ffacd0b85a97d-436296bd4a1sm7454523f8f.17.2026.02.06.09.34.40 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 06 Feb 2026 09:34:41 -0800 (PST) From: Svyatoslav Ryhel To: Liam Girdwood , Mark Brown , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Thierry Reding , Jonathan Hunter , Jaroslav Kysela , Takashi Iwai , Svyatoslav Ryhel , =?UTF-8?q?Jonas=20Schw=C3=B6bel?= Cc: linux-sound@vger.kernel.org, devicetree@vger.kernel.org, linux-tegra@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH v2 4/5] ASoC: tegra: Support WM8962 by machine driver Date: Fri, 6 Feb 2026 19:34:21 +0200 Message-ID: <20260206173423.145954-5-clamor95@gmail.com> X-Mailer: git-send-email 2.51.0 In-Reply-To: <20260206173423.145954-1-clamor95@gmail.com> References: <20260206173423.145954-1-clamor95@gmail.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: quoted-printable From: Jonas Schw=C3=B6bel Add Wolfson Microelectronics WM8962 codec support to the Tegra ASoC machine driver. The WM8962 codec is found on devices like Microsoft Surface RT and Microsoft Surface 2 Windows RT based tablets. Co-developed-by: Svyatoslav Ryhel Signed-off-by: Svyatoslav Ryhel Signed-off-by: Jonas Schw=C3=B6bel --- sound/soc/tegra/Kconfig | 10 ++ sound/soc/tegra/Makefile | 2 + sound/soc/tegra/tegra_wm8962.c | 165 +++++++++++++++++++++++++++++++++ 3 files changed, 177 insertions(+) create mode 100644 sound/soc/tegra/tegra_wm8962.c diff --git a/sound/soc/tegra/Kconfig b/sound/soc/tegra/Kconfig index dd58525b7079..fdc954028d62 100644 --- a/sound/soc/tegra/Kconfig +++ b/sound/soc/tegra/Kconfig @@ -229,6 +229,16 @@ config SND_SOC_TEGRA_WM8903 boards using the WM8093 codec. Currently, the supported boards are Harmony, Ventana, Seaboard, Kaen, and Aebl. =20 +config SND_SOC_TEGRA_WM8962 + tristate "SoC Audio support for Tegra boards using a WM8962 codec" + depends on I2C && INPUT && GPIOLIB + select SND_SOC_TEGRA_MACHINE_DRV + select SND_SOC_WM8962 + help + Say Y or M here if you want to add support for SoC audio on Tegra + boards using the WM8962 codec. Currently, the supported boards are + Microsoft Surface RT. + config SND_SOC_TEGRA_WM9712 tristate "SoC Audio support for Tegra boards using a WM9712 codec" depends on GPIOLIB diff --git a/sound/soc/tegra/Makefile b/sound/soc/tegra/Makefile index defea7f53f11..3f396c87802e 100644 --- a/sound/soc/tegra/Makefile +++ b/sound/soc/tegra/Makefile @@ -43,9 +43,11 @@ obj-$(CONFIG_SND_SOC_TEGRA210_OPE) +=3D snd-soc-tegra210= -ope.o =20 # Tegra machine Support snd-soc-tegra-wm8903-y :=3D tegra_wm8903.o +snd-soc-tegra-wm8962-y :=3D tegra_wm8962.o snd-soc-tegra-machine-y :=3D tegra_asoc_machine.o snd-soc-tegra-audio-graph-card-y :=3D tegra_audio_graph_card.o =20 obj-$(CONFIG_SND_SOC_TEGRA_WM8903) +=3D snd-soc-tegra-wm8903.o +obj-$(CONFIG_SND_SOC_TEGRA_WM8962) +=3D snd-soc-tegra-wm8962.o obj-$(CONFIG_SND_SOC_TEGRA_MACHINE_DRV) +=3D snd-soc-tegra-machine.o obj-$(CONFIG_SND_SOC_TEGRA_AUDIO_GRAPH_CARD) +=3D snd-soc-tegra-audio-grap= h-card.o diff --git a/sound/soc/tegra/tegra_wm8962.c b/sound/soc/tegra/tegra_wm8962.c new file mode 100644 index 000000000000..31f9d9181595 --- /dev/null +++ b/sound/soc/tegra/tegra_wm8962.c @@ -0,0 +1,165 @@ +// SPDX-License-Identifier: GPL-2.0-only +/* + * tegra_wm8962.c - Tegra machine ASoC driver for boards using WM8962 code= c. + * + * Copyright (C) 2021-2024 Jonas Schw=C3=B6bel + * Svyatoslav Ryhel + * + * Based on tegra_wm8903 code copyright/by: + * + * Author: Stephen Warren + * Copyright (C) 2010-2012 - NVIDIA, Inc. + * + * Based on code copyright/by: + * + * (c) 2009, 2010 Nvidia Graphics Pvt. Ltd. + * + * Copyright 2007 Wolfson Microelectronics PLC. + * Author: Graeme Gregory + * graeme.gregory@wolfsonmicro.com or linux@wolfsonmicro.com + */ + +#include +#include +#include +#include + +#include +#include +#include + +#include "../codecs/wm8962.h" + +#include "tegra_asoc_machine.h" + +static struct snd_soc_jack_pin tegra_wm8962_mic_jack_pins[] =3D { + { .pin =3D "Mic Jack", .mask =3D SND_JACK_MICROPHONE }, +}; + +static unsigned int tegra_wm8962_mclk_rate(unsigned int srate) +{ + unsigned int mclk; + + switch (srate) { + case 8000: + case 16000: + case 24000: + case 32000: + case 48000: + case 64000: + case 96000: + mclk =3D 12288000; + break; + case 11025: + case 22050: + case 44100: + case 88200: + mclk =3D 11289600; + break; + default: + mclk =3D 12000000; + break; + } + + return mclk; +} + +static int tegra_wm8962_init(struct snd_soc_pcm_runtime *rtd) +{ + struct tegra_machine *machine =3D snd_soc_card_get_drvdata(rtd->card); + struct snd_soc_card *card =3D rtd->card; + struct snd_soc_dapm_context *dapm =3D snd_soc_card_to_dapm(card); + int err; + + err =3D tegra_asoc_machine_init(rtd); + if (err) + return err; + + if (!machine->gpiod_mic_det && machine->asoc->add_mic_jack) { + struct snd_soc_dai *codec_dai =3D snd_soc_rtd_to_codec(rtd, 0); + struct snd_soc_component *component =3D codec_dai->component; + + err =3D snd_soc_card_jack_new_pins(rtd->card, "Mic Jack", + SND_JACK_MICROPHONE, + machine->mic_jack, + tegra_wm8962_mic_jack_pins, + ARRAY_SIZE(tegra_wm8962_mic_jack_pins)); + if (err) { + dev_err(rtd->dev, "Mic Jack creation failed: %d\n", err); + return err; + } + + wm8962_mic_detect(component, machine->mic_jack); + } + + snd_soc_dapm_force_enable_pin(dapm, "MICBIAS"); + + return 0; +} + +static int tegra_wm8962_remove(struct snd_soc_card *card) +{ + struct snd_soc_dai_link *link =3D &card->dai_link[0]; + struct snd_soc_pcm_runtime *rtd =3D snd_soc_get_pcm_runtime(card, link); + struct snd_soc_dai *codec_dai =3D snd_soc_rtd_to_codec(rtd, 0); + struct snd_soc_component *component =3D codec_dai->component; + + wm8962_mic_detect(component, NULL); + + return 0; +} + +SND_SOC_DAILINK_DEFS(wm8962_hifi, + DAILINK_COMP_ARRAY(COMP_EMPTY()), + DAILINK_COMP_ARRAY(COMP_CODEC(NULL, "wm8962")), + DAILINK_COMP_ARRAY(COMP_EMPTY())); + +static struct snd_soc_dai_link tegra_wm8962_dai =3D { + .name =3D "WM8962", + .stream_name =3D "WM8962 PCM", + .init =3D tegra_wm8962_init, + .dai_fmt =3D SND_SOC_DAIFMT_I2S | + SND_SOC_DAIFMT_NB_NF | + SND_SOC_DAIFMT_CBC_CFC, + SND_SOC_DAILINK_REG(wm8962_hifi), +}; + +static struct snd_soc_card snd_soc_tegra_wm8962 =3D { + .components =3D "codec:wm8962", + .owner =3D THIS_MODULE, + .dai_link =3D &tegra_wm8962_dai, + .num_links =3D 1, + .remove =3D tegra_wm8962_remove, + .fully_routed =3D true, +}; + +static const struct tegra_asoc_data tegra_wm8962_data =3D { + .mclk_rate =3D tegra_wm8962_mclk_rate, + .card =3D &snd_soc_tegra_wm8962, + .add_common_dapm_widgets =3D true, + .add_common_controls =3D true, + .add_common_snd_ops =3D true, + .add_mic_jack =3D true, + .add_hp_jack =3D true, +}; + +static const struct of_device_id tegra_wm8962_of_match[] =3D { + { .compatible =3D "nvidia,tegra-audio-wm8962", .data =3D &tegra_wm8962_da= ta }, + {}, +}; +MODULE_DEVICE_TABLE(of, tegra_wm8962_of_match); + +static struct platform_driver tegra_wm8962_driver =3D { + .driver =3D { + .name =3D "tegra-wm8962", + .of_match_table =3D tegra_wm8962_of_match, + .pm =3D &snd_soc_pm_ops, + }, + .probe =3D tegra_asoc_machine_probe, +}; +module_platform_driver(tegra_wm8962_driver); + +MODULE_AUTHOR("Jonas Schw=C3=B6bel "); +MODULE_AUTHOR("Svyatoslav Ryhel "); +MODULE_DESCRIPTION("Tegra+WM8962 machine ASoC driver"); +MODULE_LICENSE("GPL"); --=20 2.51.0 From nobody Sun Feb 8 13:10:35 2026 Received: from mail-wm1-f65.google.com (mail-wm1-f65.google.com [209.85.128.65]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 4852142188A for ; Fri, 6 Feb 2026 17:34:46 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.128.65 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1770399286; cv=none; b=dfeidlHLf8TEDTmqcGptRCnLUhHn8wXZ/cX1VtU1XwuI5Adl5WatK9f8fDYYe8PtjEpoZh1dHzLfQtQ6abQ5OPYxJcqd9PcqqBMkXWsq/0PSz53KNTHU2lhpP/3ELpUMS6T25vlRMm/5KesG4L5ZK+Rjgrd6kJXl/YKpNPKkTmw= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1770399286; c=relaxed/simple; bh=NpuLlSvp0rt7DE2FRksRcz4gv2u4yN/jMLTiXBFh070=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=miob15aWHl37xFCTHcvy9mIIJlE1U9wdL9zRGRM/U4GXyMALdDS7xx1Rv5KoZqVjHXtASV9XdF1ATOuN48DudGeWu80YDRcR/UccXGBgqBMe/sMJXG1YLOtCAji03x8ci0YHGVYj06SDpwA1E+r39uDJ4jR3z29ycv7dXzhh4s4= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com; spf=pass smtp.mailfrom=gmail.com; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b=RYDRu9Bl; arc=none smtp.client-ip=209.85.128.65 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="RYDRu9Bl" Received: by mail-wm1-f65.google.com with SMTP id 5b1f17b1804b1-482f454be5bso28482555e9.0 for ; Fri, 06 Feb 2026 09:34:46 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1770399283; x=1771004083; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=WG1BWUJ7TOLktFU2J54JTHa25r13uiqnW4MFnSd73FU=; b=RYDRu9BlkXYIIJCpOEfJvhBKgylOBGDe+7YY8VIvDB//PpqghpwxYmtl6LOESxPtgG kc2ip49N4wAgA6TdGUBCH+MDgmn7WwMUz6fZ79iKRmp/JN/TOBzZU0KtCRInDj2Rr71i jLTlLQ6kGVzDRSgowMlMZjOmTQNoy4+ovKhj8kw/mQogcC03c8nQk7ZGFvnUMDeBB+rZ VYm/BkNIiUdXNpD3FUT1IWhg2c88iZvDViipLPGfrH7dzv4rlbcAnh8rmw6l4J3T/x0H l6MFco2YsmC/zjXbW5DUMCiHj+P3SRgE4klPOYlMhpyjWkIlicCyRkqItECyVTsbLcEs xwmA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1770399283; x=1771004083; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-gg:x-gm-message-state:from :to:cc:subject:date:message-id:reply-to; bh=WG1BWUJ7TOLktFU2J54JTHa25r13uiqnW4MFnSd73FU=; b=eY1/0DzN955hLVMX6IRRysgoSxquE4bs9jBhOeWgnToKn4jyYu+Yje8LXvl92xEh7f xgAtSxKolSGQTVeMZGoiFR5pBcCi3XdVbEkUIq/Kd0m83gMV1fnhr3NM0+1h/8p7RFa/ sFYJsGXmYbEIc8JcPlY2lCpgHfDJ/W2GGJLrQvGz/ehxInLKuRRWtatCZAi3OOlVtpEt 2P2FbY+vL9KNX0Iv2x2uhl+mksatsXGd/19FXTVx4OYG0yFT2xrSKxtZMoYwDl/ITTHN 6oqD0ZaectsN2zO6V2PTIxLV5ojb+9im8jCnhkZVCYG4/IDK0jZU8GaBJv39LD+PK9CI zPfw== X-Forwarded-Encrypted: i=1; AJvYcCVu8RNT1gb55DrXlYwYbBck4iaZkZJjMZzljezHXrPpSL/OYd9yPGyRrFgtQu0w+tB0Cb7yowOTOcR9t2M=@vger.kernel.org X-Gm-Message-State: AOJu0YyoPakQnyxbLavmeg/lraEZYxqrZkesq8D/uVsUb6JiBkNm1Wg9 ieSZlQEUPEgAoAWpIfO98uN+cx5QIVTUekB1nI9zgKTm+oNqdS2syBYK X-Gm-Gg: AZuq6aIDXHyx2zU22qufoS+MhrNpUjly587btJN/IoMHHEVD9C6+vStrt5jkymVHWCi RkuzJlF5JjC0ONEtSFCWy7hGGipKft+jaU61ERvFT9eTQoyNsoFivfAprP52QEKoEvccC+eEyES MHuCxnO+2Zl/exzfxM9QgPi+DWaEeYB5RRE74sELo0axsjskvK+ecibVutffNzUCMsf59+VeG4B IKqi/1TZ8mGJkZKjk/Z/EQGs76yC06suo+Dx2RaF7tRcqdcvi/vGU0HbTLPh8k459g5vIVsnloe ZXNKqT+v8lE0pa7krGCzOBrt0xrpmB2bo9lRXjzq3J27T3GTCAsib1DGy0JyJYPndZJ9BsYj0wh 7Qlpgt/mIu9kzPhD73i0igQ7XB0Bllw9qMdZ6J6ExJVQzdmG9WFmH+YBZugmC/7SS6v5cTJfQJ6 8H X-Received: by 2002:a05:600c:3588:b0:481:a662:b3f3 with SMTP id 5b1f17b1804b1-483203ab7b0mr59042215e9.7.1770399282694; Fri, 06 Feb 2026 09:34:42 -0800 (PST) Received: from xeon ([188.163.112.49]) by smtp.gmail.com with ESMTPSA id ffacd0b85a97d-436296bd4a1sm7454523f8f.17.2026.02.06.09.34.41 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 06 Feb 2026 09:34:42 -0800 (PST) From: Svyatoslav Ryhel To: Liam Girdwood , Mark Brown , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Thierry Reding , Jonathan Hunter , Jaroslav Kysela , Takashi Iwai , Svyatoslav Ryhel , =?UTF-8?q?Jonas=20Schw=C3=B6bel?= Cc: linux-sound@vger.kernel.org, devicetree@vger.kernel.org, linux-tegra@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH v2 5/5] ASoC: dt-bindings: nvidia,tegra-audio-max9808x: document additional board pins Date: Fri, 6 Feb 2026 19:34:22 +0200 Message-ID: <20260206173423.145954-6-clamor95@gmail.com> X-Mailer: git-send-email 2.51.0 In-Reply-To: <20260206173423.145954-1-clamor95@gmail.com> References: <20260206173423.145954-1-clamor95@gmail.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable Content-Type: text/plain; charset="utf-8" Document additional board pins that may be used in routing. Signed-off-by: Svyatoslav Ryhel --- .../bindings/sound/nvidia,tegra-audio-max9808x.yaml | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/Documentation/devicetree/bindings/sound/nvidia,tegra-audio-max= 9808x.yaml b/Documentation/devicetree/bindings/sound/nvidia,tegra-audio-max= 9808x.yaml index 241d20f3aad0..4957645a8e03 100644 --- a/Documentation/devicetree/bindings/sound/nvidia,tegra-audio-max9808x.y= aml +++ b/Documentation/devicetree/bindings/sound/nvidia,tegra-audio-max9808x.y= aml @@ -35,10 +35,15 @@ properties: items: enum: # Board Connectors + - Speakers - Int Spk + - Headphone + - Headphones - Headphone Jack - Earpiece - Headset Mic + - Mic Jack + - Int Mic - Internal Mic 1 - Internal Mic 2 =20 --=20 2.51.0