Charles Keepax | 472e5df | 2019-06-25 16:37:27 +0100 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0-only */ |
Richard Fitzgerald | 2735b68 | 2019-06-19 14:41:56 +0100 | [diff] [blame] | 2 | /* |
| 3 | * Platform data for Madera codec driver |
| 4 | * |
| 5 | * Copyright (C) 2016-2019 Cirrus Logic, Inc. and |
| 6 | * Cirrus Logic International Semiconductor Ltd. |
Richard Fitzgerald | 2735b68 | 2019-06-19 14:41:56 +0100 | [diff] [blame] | 7 | */ |
| 8 | |
| 9 | #ifndef MADERA_CODEC_PDATA_H |
| 10 | #define MADERA_CODEC_PDATA_H |
| 11 | |
| 12 | #include <linux/kernel.h> |
| 13 | |
| 14 | #define MADERA_MAX_INPUT 6 |
| 15 | #define MADERA_MAX_MUXED_CHANNELS 4 |
| 16 | #define MADERA_MAX_OUTPUT 6 |
| 17 | #define MADERA_MAX_AIF 4 |
| 18 | #define MADERA_MAX_PDM_SPK 2 |
| 19 | #define MADERA_MAX_DSP 7 |
| 20 | |
| 21 | /** |
| 22 | * struct madera_codec_pdata |
| 23 | * |
| 24 | * @max_channels_clocked: Maximum number of channels that I2S clocks will be |
| 25 | * generated for. Useful when clock master for systems |
| 26 | * where the I2S bus has multiple data lines. |
| 27 | * @dmic_ref: Indicates how the MICBIAS pins have been externally |
| 28 | * connected to DMICs on each input. A value of 0 |
| 29 | * indicates MICVDD and is the default. Other values are: |
| 30 | * For CS47L35 one of the CS47L35_DMIC_REF_xxx values |
| 31 | * For all other codecs one of the MADERA_DMIC_REF_xxx |
| 32 | * Also see the datasheet for a description of the |
| 33 | * INn_DMIC_SUP field. |
| 34 | * @inmode: Mode for the ADC inputs. One of the MADERA_INMODE_xxx |
| 35 | * values. Two-dimensional array |
| 36 | * [input_number][channel number], with four slots per |
| 37 | * input in the order |
| 38 | * [n][0]=INnAL [n][1]=INnAR [n][2]=INnBL [n][3]=INnBR |
| 39 | * @out_mono: For each output set the value to TRUE to indicate that |
| 40 | * the output is mono. [0]=OUT1, [1]=OUT2, ... |
| 41 | * @pdm_fmt: PDM speaker data format. See the PDM_SPKn_FMT field in |
| 42 | * the datasheet for a description of this value. |
| 43 | * @pdm_mute: PDM mute format. See the PDM_SPKn_CTRL_1 register |
| 44 | * in the datasheet for a description of this value. |
| 45 | */ |
| 46 | struct madera_codec_pdata { |
| 47 | u32 max_channels_clocked[MADERA_MAX_AIF]; |
| 48 | |
| 49 | u32 dmic_ref[MADERA_MAX_INPUT]; |
| 50 | |
| 51 | u32 inmode[MADERA_MAX_INPUT][MADERA_MAX_MUXED_CHANNELS]; |
| 52 | |
| 53 | bool out_mono[MADERA_MAX_OUTPUT]; |
| 54 | |
| 55 | u32 pdm_fmt[MADERA_MAX_PDM_SPK]; |
| 56 | u32 pdm_mute[MADERA_MAX_PDM_SPK]; |
| 57 | }; |
| 58 | |
| 59 | #endif |