xref: /linux/sound/soc/tegra/Kconfig (revision a1ff5a7d78a036d6c2178ee5acd6ba4946243800)
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