0001
0002
0003
0004
0005
0006 #ifndef _FSL_AUD2HTX_H
0007 #define _FSL_AUD2HTX_H
0008
0009 #define FSL_AUD2HTX_FORMATS (SNDRV_PCM_FMTBIT_S24_LE | \
0010 SNDRV_PCM_FMTBIT_S32_LE)
0011
0012
0013 #define AUD2HTX_CTRL 0x0
0014 #define AUD2HTX_CTRL_EXT 0x4
0015 #define AUD2HTX_WR 0x8
0016 #define AUD2HTX_STATUS 0xC
0017 #define AUD2HTX_IRQ_NOMASK 0x10
0018 #define AUD2HTX_IRQ_MASKED 0x14
0019 #define AUD2HTX_IRQ_MASK 0x18
0020
0021
0022 #define AUD2HTX_CTRL_EN BIT(0)
0023
0024
0025 #define AUD2HTX_CTRE_DE BIT(0)
0026 #define AUD2HTX_CTRE_DT_SHIFT 0x1
0027 #define AUD2HTX_CTRE_DT_WIDTH 0x2
0028 #define AUD2HTX_CTRE_DT_MASK ((BIT(AUD2HTX_CTRE_DT_WIDTH) - 1) \
0029 << AUD2HTX_CTRE_DT_SHIFT)
0030 #define AUD2HTX_CTRE_WL_SHIFT 16
0031 #define AUD2HTX_CTRE_WL_WIDTH 5
0032 #define AUD2HTX_CTRE_WL_MASK ((BIT(AUD2HTX_CTRE_WL_WIDTH) - 1) \
0033 << AUD2HTX_CTRE_WL_SHIFT)
0034 #define AUD2HTX_CTRE_WH_SHIFT 24
0035 #define AUD2HTX_CTRE_WH_WIDTH 5
0036 #define AUD2HTX_CTRE_WH_MASK ((BIT(AUD2HTX_CTRE_WH_WIDTH) - 1) \
0037 << AUD2HTX_CTRE_WH_SHIFT)
0038
0039
0040 #define AUD2HTX_WM_HIGH_IRQ_MASK BIT(2)
0041 #define AUD2HTX_WM_LOW_IRQ_MASK BIT(1)
0042 #define AUD2HTX_OVF_MASK BIT(0)
0043
0044 #define AUD2HTX_FIFO_DEPTH 0x20
0045 #define AUD2HTX_WTMK_LOW 0x10
0046 #define AUD2HTX_WTMK_HIGH 0x10
0047 #define AUD2HTX_MAXBURST 0x10
0048
0049
0050
0051
0052
0053
0054
0055
0056
0057
0058 struct fsl_aud2htx {
0059 struct platform_device *pdev;
0060 struct regmap *regmap;
0061 struct clk *bus_clk;
0062
0063 struct snd_dmaengine_dai_dma_data dma_params_rx;
0064 struct snd_dmaengine_dai_dma_data dma_params_tx;
0065 };
0066
0067 #endif