Back to home page

OSCL-LXR

 
 

    


0001 /* SPDX-License-Identifier: GPL-2.0 */
0002 /*
0003  * fsl_spdif.h - ALSA S/PDIF interface for the Freescale i.MX SoC
0004  *
0005  * Copyright (C) 2013 Freescale Semiconductor, Inc.
0006  *
0007  * Author: Nicolin Chen <b42378@freescale.com>
0008  *
0009  * Based on fsl_ssi.h
0010  * Author: Timur Tabi <timur@freescale.com>
0011  * Copyright 2007-2008 Freescale Semiconductor, Inc.
0012  */
0013 
0014 #ifndef _FSL_SPDIF_DAI_H
0015 #define _FSL_SPDIF_DAI_H
0016 
0017 /* S/PDIF Register Map */
0018 #define REG_SPDIF_SCR           0x0 /* SPDIF Configuration Register */
0019 #define REG_SPDIF_SRCD          0x4 /* CDText Control Register */
0020 #define REG_SPDIF_SRPC          0x8 /* PhaseConfig Register */
0021 #define REG_SPDIF_SIE           0xc /* InterruptEn Register */
0022 #define REG_SPDIF_SIS           0x10    /* InterruptStat Register */
0023 #define REG_SPDIF_SIC           0x10    /* InterruptClear Register */
0024 #define REG_SPDIF_SRL           0x14    /* SPDIFRxLeft Register */
0025 #define REG_SPDIF_SRR           0x18    /* SPDIFRxRight Register */
0026 #define REG_SPDIF_SRCSH         0x1c    /* SPDIFRxCChannel_h Register */
0027 #define REG_SPDIF_SRCSL         0x20    /* SPDIFRxCChannel_l Register */
0028 #define REG_SPDIF_SRU           0x24    /* UchannelRx Register */
0029 #define REG_SPDIF_SRQ           0x28    /* QchannelRx Register */
0030 #define REG_SPDIF_STL           0x2C    /* SPDIFTxLeft Register */
0031 #define REG_SPDIF_STR           0x30    /* SPDIFTxRight Register */
0032 #define REG_SPDIF_STCSCH        0x34    /* SPDIFTxCChannelCons_h Register */
0033 #define REG_SPDIF_STCSCL        0x38    /* SPDIFTxCChannelCons_l Register */
0034 #define REG_SPDIF_STCSPH        0x3C    /* SPDIFTxCChannel_Prof_h Register */
0035 #define REG_SPDIF_STCSPL        0x40    /* SPDIFTxCChannel_Prof_l Register */
0036 #define REG_SPDIF_SRFM          0x44    /* FreqMeas Register */
0037 #define REG_SPDIF_STC           0x50    /* SPDIFTxClk Register */
0038 
0039 #define REG_SPDIF_SRCCA_31_0        0x60    /* SPDIF receive C channel register, bits 31-0 */
0040 #define REG_SPDIF_SRCCA_63_32       0x64    /* SPDIF receive C channel register, bits 63-32 */
0041 #define REG_SPDIF_SRCCA_95_64       0x68    /* SPDIF receive C channel register, bits 95-64 */
0042 #define REG_SPDIF_SRCCA_127_96      0x6C    /* SPDIF receive C channel register, bits 127-96 */
0043 #define REG_SPDIF_SRCCA_159_128     0x70    /* SPDIF receive C channel register, bits 159-128 */
0044 #define REG_SPDIF_SRCCA_191_160     0x74    /* SPDIF receive C channel register, bits 191-160 */
0045 #define REG_SPDIF_STCCA_31_0        0x78    /* SPDIF transmit C channel register, bits 31-0 */
0046 #define REG_SPDIF_STCCA_63_32       0x7C    /* SPDIF transmit C channel register, bits 63-32 */
0047 #define REG_SPDIF_STCCA_95_64       0x80    /* SPDIF transmit C channel register, bits 95-64 */
0048 #define REG_SPDIF_STCCA_127_96      0x84    /* SPDIF transmit C channel register, bits 127-96 */
0049 #define REG_SPDIF_STCCA_159_128     0x88    /* SPDIF transmit C channel register, bits 159-128 */
0050 #define REG_SPDIF_STCCA_191_160     0x8C    /* SPDIF transmit C channel register, bits 191-160 */
0051 
0052 /* SPDIF Configuration register */
0053 #define SCR_RXFIFO_CTL_OFFSET       23
0054 #define SCR_RXFIFO_CTL_MASK     (1 << SCR_RXFIFO_CTL_OFFSET)
0055 #define SCR_RXFIFO_CTL_ZERO     (1 << SCR_RXFIFO_CTL_OFFSET)
0056 #define SCR_RXFIFO_OFF_OFFSET       22
0057 #define SCR_RXFIFO_OFF_MASK     (1 << SCR_RXFIFO_OFF_OFFSET)
0058 #define SCR_RXFIFO_OFF          (1 << SCR_RXFIFO_OFF_OFFSET)
0059 #define SCR_RXFIFO_RST_OFFSET       21
0060 #define SCR_RXFIFO_RST_MASK     (1 << SCR_RXFIFO_RST_OFFSET)
0061 #define SCR_RXFIFO_RST          (1 << SCR_RXFIFO_RST_OFFSET)
0062 #define SCR_RXFIFO_FSEL_OFFSET      19
0063 #define SCR_RXFIFO_FSEL_MASK        (0x3 << SCR_RXFIFO_FSEL_OFFSET)
0064 #define SCR_RXFIFO_FSEL_IF0     (0x0 << SCR_RXFIFO_FSEL_OFFSET)
0065 #define SCR_RXFIFO_FSEL_IF4     (0x1 << SCR_RXFIFO_FSEL_OFFSET)
0066 #define SCR_RXFIFO_FSEL_IF8     (0x2 << SCR_RXFIFO_FSEL_OFFSET)
0067 #define SCR_RXFIFO_FSEL_IF12        (0x3 << SCR_RXFIFO_FSEL_OFFSET)
0068 #define SCR_RXFIFO_AUTOSYNC_OFFSET  18
0069 #define SCR_RXFIFO_AUTOSYNC_MASK    (1 << SCR_RXFIFO_AUTOSYNC_OFFSET)
0070 #define SCR_RXFIFO_AUTOSYNC     (1 << SCR_RXFIFO_AUTOSYNC_OFFSET)
0071 #define SCR_TXFIFO_AUTOSYNC_OFFSET  17
0072 #define SCR_TXFIFO_AUTOSYNC_MASK    (1 << SCR_TXFIFO_AUTOSYNC_OFFSET)
0073 #define SCR_TXFIFO_AUTOSYNC     (1 << SCR_TXFIFO_AUTOSYNC_OFFSET)
0074 #define SCR_TXFIFO_FSEL_OFFSET      15
0075 #define SCR_TXFIFO_FSEL_MASK        (0x3 << SCR_TXFIFO_FSEL_OFFSET)
0076 #define SCR_TXFIFO_FSEL_IF0     (0x0 << SCR_TXFIFO_FSEL_OFFSET)
0077 #define SCR_TXFIFO_FSEL_IF4     (0x1 << SCR_TXFIFO_FSEL_OFFSET)
0078 #define SCR_TXFIFO_FSEL_IF8     (0x2 << SCR_TXFIFO_FSEL_OFFSET)
0079 #define SCR_TXFIFO_FSEL_IF12        (0x3 << SCR_TXFIFO_FSEL_OFFSET)
0080 #define SCR_RAW_CAPTURE_MODE        BIT(14)
0081 #define SCR_LOW_POWER           (1 << 13)
0082 #define SCR_SOFT_RESET          (1 << 12)
0083 #define SCR_TXFIFO_CTRL_OFFSET      10
0084 #define SCR_TXFIFO_CTRL_MASK        (0x3 << SCR_TXFIFO_CTRL_OFFSET)
0085 #define SCR_TXFIFO_CTRL_ZERO        (0x0 << SCR_TXFIFO_CTRL_OFFSET)
0086 #define SCR_TXFIFO_CTRL_NORMAL      (0x1 << SCR_TXFIFO_CTRL_OFFSET)
0087 #define SCR_TXFIFO_CTRL_ONESAMPLE   (0x2 << SCR_TXFIFO_CTRL_OFFSET)
0088 #define SCR_DMA_RX_EN_OFFSET        9
0089 #define SCR_DMA_RX_EN_MASK      (1 << SCR_DMA_RX_EN_OFFSET)
0090 #define SCR_DMA_RX_EN           (1 << SCR_DMA_RX_EN_OFFSET)
0091 #define SCR_DMA_TX_EN_OFFSET        8
0092 #define SCR_DMA_TX_EN_MASK      (1 << SCR_DMA_TX_EN_OFFSET)
0093 #define SCR_DMA_TX_EN           (1 << SCR_DMA_TX_EN_OFFSET)
0094 #define SCR_VAL_OFFSET          5
0095 #define SCR_VAL_MASK            (1 << SCR_VAL_OFFSET)
0096 #define SCR_VAL_CLEAR           (1 << SCR_VAL_OFFSET)
0097 #define SCR_TXSEL_OFFSET        2
0098 #define SCR_TXSEL_MASK          (0x7 << SCR_TXSEL_OFFSET)
0099 #define SCR_TXSEL_OFF           (0 << SCR_TXSEL_OFFSET)
0100 #define SCR_TXSEL_RX            (1 << SCR_TXSEL_OFFSET)
0101 #define SCR_TXSEL_NORMAL        (0x5 << SCR_TXSEL_OFFSET)
0102 #define SCR_USRC_SEL_OFFSET     0x0
0103 #define SCR_USRC_SEL_MASK       (0x3 << SCR_USRC_SEL_OFFSET)
0104 #define SCR_USRC_SEL_NONE       (0x0 << SCR_USRC_SEL_OFFSET)
0105 #define SCR_USRC_SEL_RECV       (0x1 << SCR_USRC_SEL_OFFSET)
0106 #define SCR_USRC_SEL_CHIP       (0x3 << SCR_USRC_SEL_OFFSET)
0107 
0108 #define SCR_DMA_xX_EN(tx)       (tx ? SCR_DMA_TX_EN : SCR_DMA_RX_EN)
0109 
0110 /* SPDIF CDText control */
0111 #define SRCD_CD_USER_OFFSET     1
0112 #define SRCD_CD_USER            (1 << SRCD_CD_USER_OFFSET)
0113 
0114 /* SPDIF Phase Configuration register */
0115 #define SRPC_DPLL_LOCKED        (1 << 6)
0116 #define SRPC_CLKSRC_SEL_OFFSET      7
0117 #define SRPC_CLKSRC_SEL_MASK        (0xf << SRPC_CLKSRC_SEL_OFFSET)
0118 #define SRPC_CLKSRC_SEL_SET(x)      ((x << SRPC_CLKSRC_SEL_OFFSET) & SRPC_CLKSRC_SEL_MASK)
0119 #define SRPC_CLKSRC_SEL_LOCKED_OFFSET1  5
0120 #define SRPC_CLKSRC_SEL_LOCKED_OFFSET2  2
0121 #define SRPC_GAINSEL_OFFSET     3
0122 #define SRPC_GAINSEL_MASK       (0x7 << SRPC_GAINSEL_OFFSET)
0123 #define SRPC_GAINSEL_SET(x)     ((x << SRPC_GAINSEL_OFFSET) & SRPC_GAINSEL_MASK)
0124 
0125 #define SRPC_CLKSRC_MAX         16
0126 
0127 enum spdif_gainsel {
0128     GAINSEL_MULTI_24 = 0,
0129     GAINSEL_MULTI_16,
0130     GAINSEL_MULTI_12,
0131     GAINSEL_MULTI_8,
0132     GAINSEL_MULTI_6,
0133     GAINSEL_MULTI_4,
0134     GAINSEL_MULTI_3,
0135 };
0136 #define GAINSEL_MULTI_MAX       (GAINSEL_MULTI_3 + 1)
0137 #define SPDIF_DEFAULT_GAINSEL       GAINSEL_MULTI_8
0138 
0139 /* SPDIF interrupt mask define */
0140 #define INT_DPLL_LOCKED         (1 << 20)
0141 #define INT_TXFIFO_UNOV         (1 << 19)
0142 #define INT_TXFIFO_RESYNC       (1 << 18)
0143 #define INT_CNEW            (1 << 17)
0144 #define INT_VAL_NOGOOD          (1 << 16)
0145 #define INT_SYM_ERR         (1 << 15)
0146 #define INT_BIT_ERR         (1 << 14)
0147 #define INT_URX_FUL         (1 << 10)
0148 #define INT_URX_OV          (1 << 9)
0149 #define INT_QRX_FUL         (1 << 8)
0150 #define INT_QRX_OV          (1 << 7)
0151 #define INT_UQ_SYNC         (1 << 6)
0152 #define INT_UQ_ERR          (1 << 5)
0153 #define INT_RXFIFO_UNOV         (1 << 4)
0154 #define INT_RXFIFO_RESYNC       (1 << 3)
0155 #define INT_LOSS_LOCK           (1 << 2)
0156 #define INT_TX_EM           (1 << 1)
0157 #define INT_RXFIFO_FUL          (1 << 0)
0158 
0159 /* SPDIF Clock register */
0160 #define STC_SYSCLK_DF_OFFSET        11
0161 #define STC_SYSCLK_DF_MASK      (0x1ff << STC_SYSCLK_DF_OFFSET)
0162 #define STC_SYSCLK_DF(x)        ((((x) - 1) << STC_SYSCLK_DF_OFFSET) & STC_SYSCLK_DF_MASK)
0163 #define STC_TXCLK_SRC_OFFSET        8
0164 #define STC_TXCLK_SRC_MASK      (0x7 << STC_TXCLK_SRC_OFFSET)
0165 #define STC_TXCLK_SRC_SET(x)        ((x << STC_TXCLK_SRC_OFFSET) & STC_TXCLK_SRC_MASK)
0166 #define STC_TXCLK_ALL_EN_OFFSET     7
0167 #define STC_TXCLK_ALL_EN_MASK       (1 << STC_TXCLK_ALL_EN_OFFSET)
0168 #define STC_TXCLK_ALL_EN        (1 << STC_TXCLK_ALL_EN_OFFSET)
0169 #define STC_TXCLK_DF_OFFSET     0
0170 #define STC_TXCLK_DF_MASK       (0x7f << STC_TXCLK_DF_OFFSET)
0171 #define STC_TXCLK_DF(x)     ((((x) - 1) << STC_TXCLK_DF_OFFSET) & STC_TXCLK_DF_MASK)
0172 #define STC_TXCLK_SRC_MAX       8
0173 
0174 #define STC_TXCLK_SPDIF_ROOT        1
0175 
0176 /* SPDIF tx rate */
0177 enum spdif_txrate {
0178     SPDIF_TXRATE_32000 = 0,
0179     SPDIF_TXRATE_44100,
0180     SPDIF_TXRATE_48000,
0181     SPDIF_TXRATE_88200,
0182     SPDIF_TXRATE_96000,
0183     SPDIF_TXRATE_176400,
0184     SPDIF_TXRATE_192000,
0185 };
0186 #define SPDIF_TXRATE_MAX        (SPDIF_TXRATE_192000 + 1)
0187 
0188 
0189 #define SPDIF_CSTATUS_BYTE      6
0190 #define SPDIF_UBITS_SIZE        96
0191 #define SPDIF_QSUB_SIZE         (SPDIF_UBITS_SIZE / 8)
0192 
0193 
0194 #define FSL_SPDIF_RATES_PLAYBACK    (SNDRV_PCM_RATE_32000 | \
0195                      SNDRV_PCM_RATE_44100 | \
0196                      SNDRV_PCM_RATE_48000 | \
0197                      SNDRV_PCM_RATE_88200 | \
0198                      SNDRV_PCM_RATE_96000 | \
0199                      SNDRV_PCM_RATE_176400 | \
0200                      SNDRV_PCM_RATE_192000)
0201 
0202 #define FSL_SPDIF_RATES_CAPTURE     (SNDRV_PCM_RATE_16000 | \
0203                      SNDRV_PCM_RATE_32000 | \
0204                      SNDRV_PCM_RATE_44100 | \
0205                      SNDRV_PCM_RATE_48000 | \
0206                      SNDRV_PCM_RATE_88200 | \
0207                      SNDRV_PCM_RATE_64000 | \
0208                      SNDRV_PCM_RATE_96000 | \
0209                      SNDRV_PCM_RATE_176400 | \
0210                      SNDRV_PCM_RATE_192000)
0211 
0212 #define FSL_SPDIF_FORMATS_PLAYBACK  (SNDRV_PCM_FMTBIT_S16_LE | \
0213                      SNDRV_PCM_FMTBIT_S20_3LE | \
0214                      SNDRV_PCM_FMTBIT_S24_LE)
0215 
0216 #define FSL_SPDIF_FORMATS_CAPTURE   (SNDRV_PCM_FMTBIT_S24_LE)
0217 
0218 #endif /* _FSL_SPDIF_DAI_H */