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" 81*83340b85SArnd Bergmann select SND_SIMPLE_CARD_UTILS 82c0bfa983SSameer Pujar help 83c0bfa983SSameer Pujar Config to enable the Inter-IC Sound (I2S) Controller which 84c0bfa983SSameer Pujar implements full-duplex and bidirectional and single direction 85c0bfa983SSameer Pujar point-to-point serial interfaces. It can interface with I2S 86c0bfa983SSameer Pujar compatible devices. 87c0bfa983SSameer Pujar Say Y or M if you want to add support for Tegra210 I2S module. 88c0bfa983SSameer Pujar 897358a803SSameer Pujarconfig SND_SOC_TEGRA210_OPE 907358a803SSameer Pujar tristate "Tegra210 OPE module" 917358a803SSameer Pujar help 927358a803SSameer Pujar Config to enable the Output Processing Engine (OPE) which includes 937358a803SSameer Pujar Parametric Equalizer (PEQ) and Multi Band Dynamic Range Compressor 947358a803SSameer Pujar (MBDRC) sub blocks for data processing. It can support up to 8 957358a803SSameer Pujar channels. 967358a803SSameer Pujar Say Y or M if you want to add support for Tegra210 OPE module. 977358a803SSameer Pujar 98a2df8c2dSSameer Pujarconfig SND_SOC_TEGRA186_ASRC 99a2df8c2dSSameer Pujar tristate "Tegra186 ASRC module" 100a2df8c2dSSameer Pujar help 101a2df8c2dSSameer Pujar Config to enable the Asynchronous Sample Rate Converter (ASRC), 102a2df8c2dSSameer Pujar which converts the sampling frequency of the input signal from 103a2df8c2dSSameer Pujar one frequency to another. It can handle over a wide range of 104a2df8c2dSSameer Pujar sample rate ratios (freq_in/freq_out) from 1:24 to 24:1. 105a2df8c2dSSameer Pujar ASRC has two modes of operation. One where ratio can be programmed 106a2df8c2dSSameer Pujar in SW and the other where it gets information from ratio estimator 107a2df8c2dSSameer Pujar module. 108a2df8c2dSSameer Pujar Say Y or M if you want to add support for Tegra186 ASRC module. 109a2df8c2dSSameer Pujar 110327ef647SSameer Pujarconfig SND_SOC_TEGRA186_DSPK 111327ef647SSameer Pujar tristate "Tegra186 DSPK module" 112327ef647SSameer Pujar help 113327ef647SSameer Pujar Config to enable the Digital Speaker Controller (DSPK) which 114327ef647SSameer Pujar converts the multi-bit Pulse Code Modulation (PCM) audio input to 115327ef647SSameer Pujar oversampled 1-bit Pulse Density Modulation (PDM) output. From the 116327ef647SSameer Pujar signal flow perspective DSPK can be viewed as a PDM transmitter 117327ef647SSameer Pujar that up-samples the input to the desired sampling rate by 118327ef647SSameer Pujar interpolation and then converts the oversampled PCM input to 119327ef647SSameer Pujar the desired 1-bit output via Delta Sigma Modulation (DSM). 120327ef647SSameer Pujar Say Y or M if you want to add support for Tegra186 DSPK module. 121327ef647SSameer Pujar 122f74028e1SSameer Pujarconfig SND_SOC_TEGRA210_ADMAIF 123f74028e1SSameer Pujar tristate "Tegra210 ADMAIF module" 124f74028e1SSameer Pujar help 125f74028e1SSameer Pujar Config to enable ADMAIF which is the interface between ADMA and 126f74028e1SSameer Pujar Audio Hub (AHUB). Each ADMA channel that sends/receives data to/ 127f74028e1SSameer Pujar from AHUB must interface through an ADMAIF channel. ADMA channel 128f74028e1SSameer Pujar sending data to AHUB pairs with an ADMAIF Tx channel, where as 129f74028e1SSameer Pujar ADMA channel receiving data from AHUB pairs with an ADMAIF Rx 130f74028e1SSameer Pujar channel. Buffer size is configurable for each ADMAIIF channel. 131f74028e1SSameer Pujar Say Y or M if you want to add support for Tegra210 ADMAIF module. 132f74028e1SSameer Pujar 133e539891fSSameer Pujarconfig SND_SOC_TEGRA210_MVC 134e539891fSSameer Pujar tristate "Tegra210 MVC module" 135e539891fSSameer Pujar help 136e539891fSSameer Pujar Config to enable the digital Master Volume Controller (MVC) which 137e539891fSSameer Pujar provides gain or attenuation to a digital signal path. It can be 138e539891fSSameer Pujar used in input or output signal path. It can be used either for 139e539891fSSameer Pujar per-stream volume control or for master volume control. 140e539891fSSameer Pujar Say Y or M if you want to add support for Tegra210 MVC module. 141e539891fSSameer Pujar 142b2f74ec5SSameer Pujarconfig SND_SOC_TEGRA210_SFC 143b2f74ec5SSameer Pujar tristate "Tegra210 SFC module" 144b2f74ec5SSameer Pujar help 145b2f74ec5SSameer Pujar Config to enable the Sampling Frequency Converter (SFC) which 146b2f74ec5SSameer Pujar converts the sampling frequency of input signal to another 147b2f74ec5SSameer Pujar frequency. It supports sampling frequency conversion of streams 148b2f74ec5SSameer Pujar up to 2 channels (stereo). 149b2f74ec5SSameer Pujar Say Y or M if you want to add support for Tegra210 SFC module. 150b2f74ec5SSameer Pujar 15177f7df34SSameer Pujarconfig SND_SOC_TEGRA210_AMX 15277f7df34SSameer Pujar tristate "Tegra210 AMX module" 15377f7df34SSameer Pujar help 15477f7df34SSameer Pujar Config to enable the Audio Multiplexer (AMX) which can multiplex 15577f7df34SSameer Pujar four input streams (each of up to 16 channels) and generate 15677f7df34SSameer Pujar output stream (of up to 16 channels). A byte RAM helps to form an 15777f7df34SSameer Pujar output frame by any combination of bytes from the input frames. 15877f7df34SSameer Pujar Say Y or M if you want to add support for Tegra210 AMX module. 15977f7df34SSameer Pujar 160a99ab6f3SSameer Pujarconfig SND_SOC_TEGRA210_ADX 161a99ab6f3SSameer Pujar tristate "Tegra210 ADX module" 162a99ab6f3SSameer Pujar help 163a99ab6f3SSameer Pujar Config to enable the Audio Demultiplexer (ADX) which takes an 164a99ab6f3SSameer Pujar input stream (up to 16 channels) and demultiplexes it into four 165a99ab6f3SSameer Pujar output streams (each of up to 16 channels). A byte RAM helps to 166a99ab6f3SSameer Pujar form output frames by any combination of bytes from the input 167a99ab6f3SSameer Pujar frame. Its design is identical to that of byte RAM in the AMX 168a99ab6f3SSameer Pujar except that the data flow direction is reversed. 169a99ab6f3SSameer Pujar Say Y or M if you want to add support for Tegra210 ADX module. 170a99ab6f3SSameer Pujar 17105bb3d5eSSameer Pujarconfig SND_SOC_TEGRA210_MIXER 17205bb3d5eSSameer Pujar tristate "Tegra210 Mixer module" 17305bb3d5eSSameer Pujar help 17405bb3d5eSSameer Pujar Config to enable the Mixer module which can help to mix multiple 17505bb3d5eSSameer Pujar audio streams. It supports mixing of up to 10 input streams, 17605bb3d5eSSameer Pujar where each stream can contain maximum of 8 channels. It supports 17705bb3d5eSSameer Pujar 5 output each of which can be a mix of any combination of 10 17805bb3d5eSSameer Pujar input streams. 17905bb3d5eSSameer Pujar Say Y or M if you want to add support for Tegra210 Mixer module. 18005bb3d5eSSameer Pujar 181202e2f77SSameer Pujarconfig SND_SOC_TEGRA_AUDIO_GRAPH_CARD 182202e2f77SSameer Pujar tristate "Audio Graph Card based Tegra driver" 183202e2f77SSameer Pujar depends on SND_AUDIO_GRAPH_CARD 184202e2f77SSameer Pujar help 185202e2f77SSameer Pujar Config to enable Tegra audio machine driver based on generic 186202e2f77SSameer Pujar audio graph driver. It is a thin driver written to customize 187202e2f77SSameer Pujar few things for Tegra audio. Most of the code is re-used from 188202e2f77SSameer Pujar audio graph driver and the same DT bindings are used. 189202e2f77SSameer Pujar 190cc8f70f5SDmitry Osipenkoconfig SND_SOC_TEGRA_MACHINE_DRV 191cc8f70f5SDmitry Osipenko tristate 192cc8f70f5SDmitry Osipenko 19344b2fc2eSSvyatoslav Ryhelconfig SND_SOC_TEGRA_RT5631 19444b2fc2eSSvyatoslav Ryhel tristate "SoC Audio support for Tegra boards using an RT5631 codec" 19544b2fc2eSSvyatoslav Ryhel depends on SND_SOC_TEGRA && I2C && GPIOLIB 19644b2fc2eSSvyatoslav Ryhel select SND_SOC_TEGRA_MACHINE_DRV 19744b2fc2eSSvyatoslav Ryhel select SND_SOC_RT5631 19844b2fc2eSSvyatoslav Ryhel help 19944b2fc2eSSvyatoslav Ryhel Say Y or M here if you want to add support for SoC audio on Tegra 20044b2fc2eSSvyatoslav Ryhel boards using the RT5631 codec, such as Transformer. 20144b2fc2eSSvyatoslav Ryhel 202040a62cfSStephen Warrenconfig SND_SOC_TEGRA_RT5640 203040a62cfSStephen Warren tristate "SoC Audio support for Tegra boards using an RT5640 codec" 204e86caa01SGeert Uytterhoeven depends on I2C && GPIOLIB 205cc8f70f5SDmitry Osipenko select SND_SOC_TEGRA_MACHINE_DRV 206040a62cfSStephen Warren select SND_SOC_RT5640 207040a62cfSStephen Warren help 208040a62cfSStephen Warren Say Y or M here if you want to add support for SoC audio on Tegra 209040a62cfSStephen Warren boards using the RT5640 codec, such as Dalmore. 210040a62cfSStephen Warren 211d8259ca5SStephen Warrenconfig SND_SOC_TEGRA_WM8753 212d8259ca5SStephen Warren tristate "SoC Audio support for Tegra boards using a WM8753 codec" 213e86caa01SGeert Uytterhoeven depends on I2C && GPIOLIB 214cc8f70f5SDmitry Osipenko select SND_SOC_TEGRA_MACHINE_DRV 215d8259ca5SStephen Warren select SND_SOC_WM8753 216d8259ca5SStephen Warren help 217d8259ca5SStephen Warren Say Y or M here if you want to add support for SoC audio on Tegra 218d8259ca5SStephen Warren boards using the WM8753 codec, such as Whistler. 219d8259ca5SStephen Warren 2202ba9471bSStephen Warrenconfig SND_SOC_TEGRA_WM8903 221dc0a50afSStephen Warren tristate "SoC Audio support for Tegra boards using a WM8903 codec" 222e86caa01SGeert Uytterhoeven depends on I2C && GPIOLIB 223cc8f70f5SDmitry Osipenko select SND_SOC_TEGRA_MACHINE_DRV 2248b75d714SStephen Warren select SND_SOC_WM8903 2258b75d714SStephen Warren help 226dc0a50afSStephen Warren Say Y or M here if you want to add support for SoC audio on Tegra 227773b1d3dSStephen Warren boards using the WM8093 codec. Currently, the supported boards are 228773b1d3dSStephen Warren Harmony, Ventana, Seaboard, Kaen, and Aebl. 2298b75d714SStephen Warren 2306995b8cbSLucas Stachconfig SND_SOC_TEGRA_WM9712 2316995b8cbSLucas Stach tristate "SoC Audio support for Tegra boards using a WM9712 codec" 232e86caa01SGeert Uytterhoeven depends on GPIOLIB 233cc8f70f5SDmitry Osipenko select SND_SOC_TEGRA_MACHINE_DRV 2346995b8cbSLucas Stach select SND_SOC_TEGRA20_AC97 2356995b8cbSLucas Stach select SND_SOC_WM9712 2366995b8cbSLucas Stach help 2376995b8cbSLucas Stach Say Y or M here if you want to add support for SoC audio on Tegra 2386995b8cbSLucas Stach boards using the WM9712 (or compatible) codec. 2396995b8cbSLucas Stach 2401307394aSMike Rapoportconfig SND_SOC_TEGRA_TRIMSLICE 2411307394aSMike Rapoport tristate "SoC Audio support for TrimSlice board" 242e86caa01SGeert Uytterhoeven depends on I2C 243cc8f70f5SDmitry Osipenko select SND_SOC_TEGRA_MACHINE_DRV 244cc1bc54aSMax Filippov select SND_SOC_TLV320AIC23_I2C 2451307394aSMike Rapoport help 2461307394aSMike Rapoport Say Y or M here if you want to add support for SoC audio on the 2471307394aSMike Rapoport TrimSlice platform. 24858783fafSLeon Romanovsky 24958783fafSLeon Romanovskyconfig SND_SOC_TEGRA_ALC5632 25058783fafSLeon Romanovsky tristate "SoC Audio support for Tegra boards using an ALC5632 codec" 251e86caa01SGeert Uytterhoeven depends on I2C && GPIOLIB 252cc8f70f5SDmitry Osipenko select SND_SOC_TEGRA_MACHINE_DRV 25358783fafSLeon Romanovsky select SND_SOC_ALC5632 25458783fafSLeon Romanovsky help 25558783fafSLeon Romanovsky Say Y or M here if you want to add support for SoC audio on the 25658783fafSLeon Romanovsky Toshiba AC100 netbook. 2577637af2eSStephen Warren 2587637af2eSStephen Warrenconfig SND_SOC_TEGRA_MAX98090 2597637af2eSStephen Warren tristate "SoC Audio support for Tegra boards using a MAX98090 codec" 260e86caa01SGeert Uytterhoeven depends on I2C && GPIOLIB 261cc8f70f5SDmitry Osipenko select SND_SOC_TEGRA_MACHINE_DRV 2627637af2eSStephen Warren select SND_SOC_MAX98090 2637637af2eSStephen Warren help 2647637af2eSStephen Warren Say Y or M here if you want to add support for SoC audio on Tegra 2657637af2eSStephen Warren boards using the MAX98090 codec, such as Venice2. 266a37f1b8fSAnatol Pomozov 267d007a87bSSvyatoslav Ryhelconfig SND_SOC_TEGRA_MAX98088 268d007a87bSSvyatoslav Ryhel tristate "SoC Audio support for Tegra boards using a MAX9808x codec" 269d007a87bSSvyatoslav Ryhel depends on I2C && GPIOLIB 270d007a87bSSvyatoslav Ryhel select SND_SOC_TEGRA_MACHINE_DRV 271d007a87bSSvyatoslav Ryhel select SND_SOC_MAX98088 272d007a87bSSvyatoslav Ryhel help 273d007a87bSSvyatoslav Ryhel Say Y or M here if you want to add support for SoC audio on Tegra 274d007a87bSSvyatoslav Ryhel boards using the MAX98088 codec, such as LG X3. 275d007a87bSSvyatoslav Ryhel 276a37f1b8fSAnatol Pomozovconfig SND_SOC_TEGRA_RT5677 277a37f1b8fSAnatol Pomozov tristate "SoC Audio support for Tegra boards using a RT5677 codec" 278e86caa01SGeert Uytterhoeven depends on I2C && GPIOLIB 279cc8f70f5SDmitry Osipenko select SND_SOC_TEGRA_MACHINE_DRV 280a37f1b8fSAnatol Pomozov select SND_SOC_RT5677 281a37f1b8fSAnatol Pomozov help 282a37f1b8fSAnatol Pomozov Say Y or M here if you want to add support for SoC audio on Tegra 283a37f1b8fSAnatol Pomozov boards using the RT5677 codec, such as Ryu. 28404445681SMarcel Ziswiler 28504445681SMarcel Ziswilerconfig SND_SOC_TEGRA_SGTL5000 28604445681SMarcel Ziswiler tristate "SoC Audio support for Tegra boards using a SGTL5000 codec" 287e86caa01SGeert Uytterhoeven depends on I2C && GPIOLIB 288cc8f70f5SDmitry Osipenko select SND_SOC_TEGRA_MACHINE_DRV 28904445681SMarcel Ziswiler select SND_SOC_SGTL5000 29004445681SMarcel Ziswiler help 29104445681SMarcel Ziswiler Say Y or M here if you want to add support for SoC audio on Tegra 29204445681SMarcel Ziswiler boards using the SGTL5000 codec, such as Apalis T30, Apalis TK1 or 29304445681SMarcel Ziswiler Colibri T30. 294e86caa01SGeert Uytterhoeven 295e86caa01SGeert Uytterhoevenendif 296