1ec8f24b7SThomas Gleixner# SPDX-License-Identifier: GPL-2.0-only 22ba9471bSStephen Warrenconfig SND_SOC_TEGRA 38b75d714SStephen Warren tristate "SoC Audio for the Tegra System-on-Chip" 422abf843SMark Brown depends on (ARCH_TEGRA && TEGRA20_APB_DMA) || COMPILE_TEST 55185e0acSStephen Warren depends on COMMON_CLK 65185e0acSStephen Warren depends on RESET_CONTROLLER 7d19e779bSStephen Warren select REGMAP_MMIO 82086d078SMark Brown select SND_SOC_GENERIC_DMAENGINE_PCM 98b75d714SStephen Warren help 108b75d714SStephen Warren Say Y or M here if you want support for SoC audio on Tegra. 118b75d714SStephen Warren 12e86caa01SGeert Uytterhoevenif SND_SOC_TEGRA 13e86caa01SGeert Uytterhoeven 14609dad9bSLucas Stachconfig SND_SOC_TEGRA20_AC97 153bcfe80fSPaul Kocialkowski tristate "Tegra20 AC97 interface" 16609dad9bSLucas Stach select SND_SOC_AC97_BUS 17609dad9bSLucas Stach select SND_SOC_TEGRA20_DAS 18609dad9bSLucas Stach help 19609dad9bSLucas Stach Say Y or M if you want to add support for codecs attached to the 20609dad9bSLucas Stach Tegra20 AC97 interface. You will also need to select the individual 21609dad9bSLucas Stach machine drivers to support below. 22609dad9bSLucas Stach 23896637acSStephen Warrenconfig SND_SOC_TEGRA20_DAS 243bcfe80fSPaul Kocialkowski tristate "Tegra20 DAS module" 25d9bba496SStephen Warren help 26896637acSStephen Warren Say Y or M if you want to add support for the Tegra20 DAS module. 27d9bba496SStephen Warren You will also need to select the individual machine drivers to 28d9bba496SStephen Warren support below. 29d9bba496SStephen Warren 30896637acSStephen Warrenconfig SND_SOC_TEGRA20_I2S 313bcfe80fSPaul Kocialkowski tristate "Tegra20 I2S interface" 32896637acSStephen Warren select SND_SOC_TEGRA20_DAS 338b75d714SStephen Warren help 348b75d714SStephen Warren Say Y or M if you want to add support for codecs attached to the 35896637acSStephen Warren Tegra20 I2S interface. You will also need to select the individual 368b75d714SStephen Warren machine drivers to support below. 378b75d714SStephen Warren 38896637acSStephen Warrenconfig SND_SOC_TEGRA20_SPDIF 393bcfe80fSPaul Kocialkowski tristate "Tegra20 SPDIF interface" 40774fec33SStephen Warren help 41896637acSStephen Warren Say Y or M if you want to add support for the Tegra20 SPDIF interface. 42774fec33SStephen Warren You will also need to select the individual machine drivers to support 43774fec33SStephen Warren below. 44774fec33SStephen Warren 45cdc04fd1SStephen Warrenconfig SND_SOC_TEGRA30_AHUB 463bcfe80fSPaul Kocialkowski tristate "Tegra30 AHUB module" 47cdc04fd1SStephen Warren help 483bcfe80fSPaul Kocialkowski Say Y or M if you want to add support for the Tegra30 AHUB module. 49cdc04fd1SStephen Warren You will also need to select the individual machine drivers to 50cdc04fd1SStephen Warren support below. 51cdc04fd1SStephen Warren 52cdc04fd1SStephen Warrenconfig SND_SOC_TEGRA30_I2S 533bcfe80fSPaul Kocialkowski tristate "Tegra30 I2S interface" 54cdc04fd1SStephen Warren select SND_SOC_TEGRA30_AHUB 55cdc04fd1SStephen Warren help 56cdc04fd1SStephen Warren Say Y or M if you want to add support for codecs attached to the 57cdc04fd1SStephen Warren Tegra30 I2S interface. You will also need to select the individual 58cdc04fd1SStephen Warren machine drivers to support below. 59cdc04fd1SStephen Warren 6016e1bcc2SSameer Pujarconfig SND_SOC_TEGRA210_AHUB 6116e1bcc2SSameer Pujar tristate "Tegra210 AHUB module" 6216e1bcc2SSameer Pujar help 6316e1bcc2SSameer Pujar Config to enable Audio Hub (AHUB) module, which comprises of a 6416e1bcc2SSameer Pujar switch called Audio Crossbar (AXBAR) used to configure or modify 6516e1bcc2SSameer Pujar the audio routing path between various HW accelerators present in 6616e1bcc2SSameer Pujar AHUB. 6716e1bcc2SSameer Pujar Say Y or M if you want to add support for Tegra210 AHUB module. 6816e1bcc2SSameer Pujar 698c8ff982SSameer Pujarconfig SND_SOC_TEGRA210_DMIC 708c8ff982SSameer Pujar tristate "Tegra210 DMIC module" 718c8ff982SSameer Pujar help 728c8ff982SSameer Pujar Config to enable the Digital MIC (DMIC) controller which is used 738c8ff982SSameer Pujar to interface with Pulse Density Modulation (PDM) input devices. 748c8ff982SSameer Pujar The DMIC controller implements a converter to convert PDM signals 758c8ff982SSameer Pujar to Pulse Code Modulation (PCM) signals. This can be viewed as a 768c8ff982SSameer Pujar PDM receiver. 778c8ff982SSameer Pujar Say Y or M if you want to add support for Tegra210 DMIC module. 788c8ff982SSameer Pujar 79c0bfa983SSameer Pujarconfig SND_SOC_TEGRA210_I2S 80c0bfa983SSameer Pujar tristate "Tegra210 I2S module" 81c0bfa983SSameer Pujar help 82c0bfa983SSameer Pujar Config to enable the Inter-IC Sound (I2S) Controller which 83c0bfa983SSameer Pujar implements full-duplex and bidirectional and single direction 84c0bfa983SSameer Pujar point-to-point serial interfaces. It can interface with I2S 85c0bfa983SSameer Pujar compatible devices. 86c0bfa983SSameer Pujar Say Y or M if you want to add support for Tegra210 I2S module. 87c0bfa983SSameer Pujar 887358a803SSameer Pujarconfig SND_SOC_TEGRA210_OPE 897358a803SSameer Pujar tristate "Tegra210 OPE module" 907358a803SSameer Pujar help 917358a803SSameer Pujar Config to enable the Output Processing Engine (OPE) which includes 927358a803SSameer Pujar Parametric Equalizer (PEQ) and Multi Band Dynamic Range Compressor 937358a803SSameer Pujar (MBDRC) sub blocks for data processing. It can support up to 8 947358a803SSameer Pujar channels. 957358a803SSameer Pujar Say Y or M if you want to add support for Tegra210 OPE module. 967358a803SSameer Pujar 97a2df8c2dSSameer Pujarconfig SND_SOC_TEGRA186_ASRC 98a2df8c2dSSameer Pujar tristate "Tegra186 ASRC module" 99a2df8c2dSSameer Pujar help 100a2df8c2dSSameer Pujar Config to enable the Asynchronous Sample Rate Converter (ASRC), 101a2df8c2dSSameer Pujar which converts the sampling frequency of the input signal from 102a2df8c2dSSameer Pujar one frequency to another. It can handle over a wide range of 103a2df8c2dSSameer Pujar sample rate ratios (freq_in/freq_out) from 1:24 to 24:1. 104a2df8c2dSSameer Pujar ASRC has two modes of operation. One where ratio can be programmed 105a2df8c2dSSameer Pujar in SW and the other where it gets information from ratio estimator 106a2df8c2dSSameer Pujar module. 107a2df8c2dSSameer Pujar Say Y or M if you want to add support for Tegra186 ASRC module. 108a2df8c2dSSameer Pujar 109327ef647SSameer Pujarconfig SND_SOC_TEGRA186_DSPK 110327ef647SSameer Pujar tristate "Tegra186 DSPK module" 111327ef647SSameer Pujar help 112327ef647SSameer Pujar Config to enable the Digital Speaker Controller (DSPK) which 113327ef647SSameer Pujar converts the multi-bit Pulse Code Modulation (PCM) audio input to 114327ef647SSameer Pujar oversampled 1-bit Pulse Density Modulation (PDM) output. From the 115327ef647SSameer Pujar signal flow perspective DSPK can be viewed as a PDM transmitter 116327ef647SSameer Pujar that up-samples the input to the desired sampling rate by 117327ef647SSameer Pujar interpolation and then converts the oversampled PCM input to 118327ef647SSameer Pujar the desired 1-bit output via Delta Sigma Modulation (DSM). 119327ef647SSameer Pujar Say Y or M if you want to add support for Tegra186 DSPK module. 120327ef647SSameer Pujar 121f74028e1SSameer Pujarconfig SND_SOC_TEGRA210_ADMAIF 122f74028e1SSameer Pujar tristate "Tegra210 ADMAIF module" 123f74028e1SSameer Pujar help 124f74028e1SSameer Pujar Config to enable ADMAIF which is the interface between ADMA and 125f74028e1SSameer Pujar Audio Hub (AHUB). Each ADMA channel that sends/receives data to/ 126f74028e1SSameer Pujar from AHUB must interface through an ADMAIF channel. ADMA channel 127f74028e1SSameer Pujar sending data to AHUB pairs with an ADMAIF Tx channel, where as 128f74028e1SSameer Pujar ADMA channel receiving data from AHUB pairs with an ADMAIF Rx 129f74028e1SSameer Pujar channel. Buffer size is configurable for each ADMAIIF channel. 130f74028e1SSameer Pujar Say Y or M if you want to add support for Tegra210 ADMAIF module. 131f74028e1SSameer Pujar 132e539891fSSameer Pujarconfig SND_SOC_TEGRA210_MVC 133e539891fSSameer Pujar tristate "Tegra210 MVC module" 134e539891fSSameer Pujar help 135e539891fSSameer Pujar Config to enable the digital Master Volume Controller (MVC) which 136e539891fSSameer Pujar provides gain or attenuation to a digital signal path. It can be 137e539891fSSameer Pujar used in input or output signal path. It can be used either for 138e539891fSSameer Pujar per-stream volume control or for master volume control. 139e539891fSSameer Pujar Say Y or M if you want to add support for Tegra210 MVC module. 140e539891fSSameer Pujar 141b2f74ec5SSameer Pujarconfig SND_SOC_TEGRA210_SFC 142b2f74ec5SSameer Pujar tristate "Tegra210 SFC module" 143b2f74ec5SSameer Pujar help 144b2f74ec5SSameer Pujar Config to enable the Sampling Frequency Converter (SFC) which 145b2f74ec5SSameer Pujar converts the sampling frequency of input signal to another 146b2f74ec5SSameer Pujar frequency. It supports sampling frequency conversion of streams 147b2f74ec5SSameer Pujar up to 2 channels (stereo). 148b2f74ec5SSameer Pujar Say Y or M if you want to add support for Tegra210 SFC module. 149b2f74ec5SSameer Pujar 15077f7df34SSameer Pujarconfig SND_SOC_TEGRA210_AMX 15177f7df34SSameer Pujar tristate "Tegra210 AMX module" 15277f7df34SSameer Pujar help 15377f7df34SSameer Pujar Config to enable the Audio Multiplexer (AMX) which can multiplex 15477f7df34SSameer Pujar four input streams (each of up to 16 channels) and generate 15577f7df34SSameer Pujar output stream (of up to 16 channels). A byte RAM helps to form an 15677f7df34SSameer Pujar output frame by any combination of bytes from the input frames. 15777f7df34SSameer Pujar Say Y or M if you want to add support for Tegra210 AMX module. 15877f7df34SSameer Pujar 159a99ab6f3SSameer Pujarconfig SND_SOC_TEGRA210_ADX 160a99ab6f3SSameer Pujar tristate "Tegra210 ADX module" 161a99ab6f3SSameer Pujar help 162a99ab6f3SSameer Pujar Config to enable the Audio Demultiplexer (ADX) which takes an 163a99ab6f3SSameer Pujar input stream (up to 16 channels) and demultiplexes it into four 164a99ab6f3SSameer Pujar output streams (each of up to 16 channels). A byte RAM helps to 165a99ab6f3SSameer Pujar form output frames by any combination of bytes from the input 166a99ab6f3SSameer Pujar frame. Its design is identical to that of byte RAM in the AMX 167a99ab6f3SSameer Pujar except that the data flow direction is reversed. 168a99ab6f3SSameer Pujar Say Y or M if you want to add support for Tegra210 ADX module. 169a99ab6f3SSameer Pujar 17005bb3d5eSSameer Pujarconfig SND_SOC_TEGRA210_MIXER 17105bb3d5eSSameer Pujar tristate "Tegra210 Mixer module" 17205bb3d5eSSameer Pujar help 17305bb3d5eSSameer Pujar Config to enable the Mixer module which can help to mix multiple 17405bb3d5eSSameer Pujar audio streams. It supports mixing of up to 10 input streams, 17505bb3d5eSSameer Pujar where each stream can contain maximum of 8 channels. It supports 17605bb3d5eSSameer Pujar 5 output each of which can be a mix of any combination of 10 17705bb3d5eSSameer Pujar input streams. 17805bb3d5eSSameer Pujar Say Y or M if you want to add support for Tegra210 Mixer module. 17905bb3d5eSSameer Pujar 180202e2f77SSameer Pujarconfig SND_SOC_TEGRA_AUDIO_GRAPH_CARD 181202e2f77SSameer Pujar tristate "Audio Graph Card based Tegra driver" 182202e2f77SSameer Pujar depends on SND_AUDIO_GRAPH_CARD 183202e2f77SSameer Pujar help 184202e2f77SSameer Pujar Config to enable Tegra audio machine driver based on generic 185202e2f77SSameer Pujar audio graph driver. It is a thin driver written to customize 186202e2f77SSameer Pujar few things for Tegra audio. Most of the code is re-used from 187202e2f77SSameer Pujar audio graph driver and the same DT bindings are used. 188202e2f77SSameer Pujar 189cc8f70f5SDmitry Osipenkoconfig SND_SOC_TEGRA_MACHINE_DRV 190cc8f70f5SDmitry Osipenko tristate 191cc8f70f5SDmitry Osipenko 19244b2fc2eSSvyatoslav Ryhelconfig SND_SOC_TEGRA_RT5631 19344b2fc2eSSvyatoslav Ryhel tristate "SoC Audio support for Tegra boards using an RT5631 codec" 19444b2fc2eSSvyatoslav Ryhel depends on SND_SOC_TEGRA && I2C && GPIOLIB 19544b2fc2eSSvyatoslav Ryhel select SND_SOC_TEGRA_MACHINE_DRV 19644b2fc2eSSvyatoslav Ryhel select SND_SOC_RT5631 19744b2fc2eSSvyatoslav Ryhel help 19844b2fc2eSSvyatoslav Ryhel Say Y or M here if you want to add support for SoC audio on Tegra 19944b2fc2eSSvyatoslav Ryhel boards using the RT5631 codec, such as Transformer. 20044b2fc2eSSvyatoslav Ryhel 201040a62cfSStephen Warrenconfig SND_SOC_TEGRA_RT5640 202040a62cfSStephen Warren tristate "SoC Audio support for Tegra boards using an RT5640 codec" 203e86caa01SGeert Uytterhoeven depends on I2C && GPIOLIB 204cc8f70f5SDmitry Osipenko select SND_SOC_TEGRA_MACHINE_DRV 205040a62cfSStephen Warren select SND_SOC_RT5640 206040a62cfSStephen Warren help 207040a62cfSStephen Warren Say Y or M here if you want to add support for SoC audio on Tegra 208040a62cfSStephen Warren boards using the RT5640 codec, such as Dalmore. 209040a62cfSStephen Warren 210d8259ca5SStephen Warrenconfig SND_SOC_TEGRA_WM8753 211d8259ca5SStephen Warren tristate "SoC Audio support for Tegra boards using a WM8753 codec" 212e86caa01SGeert Uytterhoeven depends on I2C && GPIOLIB 213cc8f70f5SDmitry Osipenko select SND_SOC_TEGRA_MACHINE_DRV 214d8259ca5SStephen Warren select SND_SOC_WM8753 215d8259ca5SStephen Warren help 216d8259ca5SStephen Warren Say Y or M here if you want to add support for SoC audio on Tegra 217d8259ca5SStephen Warren boards using the WM8753 codec, such as Whistler. 218d8259ca5SStephen Warren 2192ba9471bSStephen Warrenconfig SND_SOC_TEGRA_WM8903 220dc0a50afSStephen Warren tristate "SoC Audio support for Tegra boards using a WM8903 codec" 221e86caa01SGeert Uytterhoeven depends on I2C && GPIOLIB 222cc8f70f5SDmitry Osipenko select SND_SOC_TEGRA_MACHINE_DRV 2238b75d714SStephen Warren select SND_SOC_WM8903 2248b75d714SStephen Warren help 225dc0a50afSStephen Warren Say Y or M here if you want to add support for SoC audio on Tegra 226773b1d3dSStephen Warren boards using the WM8093 codec. Currently, the supported boards are 227773b1d3dSStephen Warren Harmony, Ventana, Seaboard, Kaen, and Aebl. 2288b75d714SStephen Warren 2296995b8cbSLucas Stachconfig SND_SOC_TEGRA_WM9712 2306995b8cbSLucas Stach tristate "SoC Audio support for Tegra boards using a WM9712 codec" 231e86caa01SGeert Uytterhoeven depends on GPIOLIB 232cc8f70f5SDmitry Osipenko select SND_SOC_TEGRA_MACHINE_DRV 2336995b8cbSLucas Stach select SND_SOC_TEGRA20_AC97 2346995b8cbSLucas Stach select SND_SOC_WM9712 2356995b8cbSLucas Stach help 2366995b8cbSLucas Stach Say Y or M here if you want to add support for SoC audio on Tegra 2376995b8cbSLucas Stach boards using the WM9712 (or compatible) codec. 2386995b8cbSLucas Stach 2391307394aSMike Rapoportconfig SND_SOC_TEGRA_TRIMSLICE 2401307394aSMike Rapoport tristate "SoC Audio support for TrimSlice board" 241e86caa01SGeert Uytterhoeven depends on I2C 242cc8f70f5SDmitry Osipenko select SND_SOC_TEGRA_MACHINE_DRV 243cc1bc54aSMax Filippov select SND_SOC_TLV320AIC23_I2C 2441307394aSMike Rapoport help 2451307394aSMike Rapoport Say Y or M here if you want to add support for SoC audio on the 2461307394aSMike Rapoport TrimSlice platform. 24758783fafSLeon Romanovsky 24858783fafSLeon Romanovskyconfig SND_SOC_TEGRA_ALC5632 24958783fafSLeon Romanovsky tristate "SoC Audio support for Tegra boards using an ALC5632 codec" 250e86caa01SGeert Uytterhoeven depends on I2C && GPIOLIB 251cc8f70f5SDmitry Osipenko select SND_SOC_TEGRA_MACHINE_DRV 25258783fafSLeon Romanovsky select SND_SOC_ALC5632 25358783fafSLeon Romanovsky help 25458783fafSLeon Romanovsky Say Y or M here if you want to add support for SoC audio on the 25558783fafSLeon Romanovsky Toshiba AC100 netbook. 2567637af2eSStephen Warren 2577637af2eSStephen Warrenconfig SND_SOC_TEGRA_MAX98090 2587637af2eSStephen Warren tristate "SoC Audio support for Tegra boards using a MAX98090 codec" 259e86caa01SGeert Uytterhoeven depends on I2C && GPIOLIB 260cc8f70f5SDmitry Osipenko select SND_SOC_TEGRA_MACHINE_DRV 2617637af2eSStephen Warren select SND_SOC_MAX98090 2627637af2eSStephen Warren help 2637637af2eSStephen Warren Say Y or M here if you want to add support for SoC audio on Tegra 2647637af2eSStephen Warren boards using the MAX98090 codec, such as Venice2. 265a37f1b8fSAnatol Pomozov 266*d007a87bSSvyatoslav Ryhelconfig SND_SOC_TEGRA_MAX98088 267*d007a87bSSvyatoslav Ryhel tristate "SoC Audio support for Tegra boards using a MAX9808x codec" 268*d007a87bSSvyatoslav Ryhel depends on I2C && GPIOLIB 269*d007a87bSSvyatoslav Ryhel select SND_SOC_TEGRA_MACHINE_DRV 270*d007a87bSSvyatoslav Ryhel select SND_SOC_MAX98088 271*d007a87bSSvyatoslav Ryhel help 272*d007a87bSSvyatoslav Ryhel Say Y or M here if you want to add support for SoC audio on Tegra 273*d007a87bSSvyatoslav Ryhel boards using the MAX98088 codec, such as LG X3. 274*d007a87bSSvyatoslav Ryhel 275a37f1b8fSAnatol Pomozovconfig SND_SOC_TEGRA_RT5677 276a37f1b8fSAnatol Pomozov tristate "SoC Audio support for Tegra boards using a RT5677 codec" 277e86caa01SGeert Uytterhoeven depends on I2C && GPIOLIB 278cc8f70f5SDmitry Osipenko select SND_SOC_TEGRA_MACHINE_DRV 279a37f1b8fSAnatol Pomozov select SND_SOC_RT5677 280a37f1b8fSAnatol Pomozov help 281a37f1b8fSAnatol Pomozov Say Y or M here if you want to add support for SoC audio on Tegra 282a37f1b8fSAnatol Pomozov boards using the RT5677 codec, such as Ryu. 28304445681SMarcel Ziswiler 28404445681SMarcel Ziswilerconfig SND_SOC_TEGRA_SGTL5000 28504445681SMarcel Ziswiler tristate "SoC Audio support for Tegra boards using a SGTL5000 codec" 286e86caa01SGeert Uytterhoeven depends on I2C && GPIOLIB 287cc8f70f5SDmitry Osipenko select SND_SOC_TEGRA_MACHINE_DRV 28804445681SMarcel Ziswiler select SND_SOC_SGTL5000 28904445681SMarcel Ziswiler help 29004445681SMarcel Ziswiler Say Y or M here if you want to add support for SoC audio on Tegra 29104445681SMarcel Ziswiler boards using the SGTL5000 codec, such as Apalis T30, Apalis TK1 or 29204445681SMarcel Ziswiler Colibri T30. 293e86caa01SGeert Uytterhoeven 294e86caa01SGeert Uytterhoevenendif 295