Path: blob/master/sound/soc/rockchip/rockchip_i2s_tdm.h
26444 views
/* SPDX-License-Identifier: GPL-2.0-only */1/*2* ALSA SoC Audio Layer - Rockchip I2S/TDM Controller driver3*4* Copyright (c) 2018 Rockchip Electronics Co. Ltd.5* Author: Sugar Zhang <[email protected]>6*7*/89#ifndef _ROCKCHIP_I2S_TDM_H10#define _ROCKCHIP_I2S_TDM_H1112/*13* TXCR14* transmit operation control register15*/16#define I2S_TXCR_PATH_SHIFT(x) (23 + (x) * 2)17#define I2S_TXCR_PATH_MASK(x) (0x3 << I2S_TXCR_PATH_SHIFT(x))18#define I2S_TXCR_PATH(x, v) ((v) << I2S_TXCR_PATH_SHIFT(x))19#define I2S_TXCR_RCNT_SHIFT 1720#define I2S_TXCR_RCNT_MASK (0x3f << I2S_TXCR_RCNT_SHIFT)21#define I2S_TXCR_CSR_SHIFT 1522#define I2S_TXCR_CSR(x) ((x) << I2S_TXCR_CSR_SHIFT)23#define I2S_TXCR_CSR_MASK (3 << I2S_TXCR_CSR_SHIFT)24#define I2S_TXCR_HWT BIT(14)25#define I2S_TXCR_SJM_SHIFT 1226#define I2S_TXCR_SJM_R (0 << I2S_TXCR_SJM_SHIFT)27#define I2S_TXCR_SJM_L (1 << I2S_TXCR_SJM_SHIFT)28#define I2S_TXCR_FBM_SHIFT 1129#define I2S_TXCR_FBM_MSB (0 << I2S_TXCR_FBM_SHIFT)30#define I2S_TXCR_FBM_LSB (1 << I2S_TXCR_FBM_SHIFT)31#define I2S_TXCR_IBM_SHIFT 932#define I2S_TXCR_IBM_NORMAL (0 << I2S_TXCR_IBM_SHIFT)33#define I2S_TXCR_IBM_LSJM (1 << I2S_TXCR_IBM_SHIFT)34#define I2S_TXCR_IBM_RSJM (2 << I2S_TXCR_IBM_SHIFT)35#define I2S_TXCR_IBM_MASK (3 << I2S_TXCR_IBM_SHIFT)36#define I2S_TXCR_PBM_SHIFT 737#define I2S_TXCR_PBM_MODE(x) ((x) << I2S_TXCR_PBM_SHIFT)38#define I2S_TXCR_PBM_MASK (3 << I2S_TXCR_PBM_SHIFT)39#define I2S_TXCR_TFS_SHIFT 540#define I2S_TXCR_TFS_I2S (0 << I2S_TXCR_TFS_SHIFT)41#define I2S_TXCR_TFS_PCM (1 << I2S_TXCR_TFS_SHIFT)42#define I2S_TXCR_TFS_TDM_PCM (2 << I2S_TXCR_TFS_SHIFT)43#define I2S_TXCR_TFS_TDM_I2S (3 << I2S_TXCR_TFS_SHIFT)44#define I2S_TXCR_TFS_MASK (3 << I2S_TXCR_TFS_SHIFT)45#define I2S_TXCR_VDW_SHIFT 046#define I2S_TXCR_VDW(x) (((x) - 1) << I2S_TXCR_VDW_SHIFT)47#define I2S_TXCR_VDW_MASK (0x1f << I2S_TXCR_VDW_SHIFT)4849/*50* RXCR51* receive operation control register52*/53#define I2S_RXCR_PATH_SHIFT(x) (17 + (x) * 2)54#define I2S_RXCR_PATH_MASK(x) (0x3 << I2S_RXCR_PATH_SHIFT(x))55#define I2S_RXCR_PATH(x, v) ((v) << I2S_RXCR_PATH_SHIFT(x))56#define I2S_RXCR_CSR_SHIFT 1557#define I2S_RXCR_CSR(x) ((x) << I2S_RXCR_CSR_SHIFT)58#define I2S_RXCR_CSR_MASK (3 << I2S_RXCR_CSR_SHIFT)59#define I2S_RXCR_HWT BIT(14)60#define I2S_RXCR_SJM_SHIFT 1261#define I2S_RXCR_SJM_R (0 << I2S_RXCR_SJM_SHIFT)62#define I2S_RXCR_SJM_L (1 << I2S_RXCR_SJM_SHIFT)63#define I2S_RXCR_FBM_SHIFT 1164#define I2S_RXCR_FBM_MSB (0 << I2S_RXCR_FBM_SHIFT)65#define I2S_RXCR_FBM_LSB (1 << I2S_RXCR_FBM_SHIFT)66#define I2S_RXCR_IBM_SHIFT 967#define I2S_RXCR_IBM_NORMAL (0 << I2S_RXCR_IBM_SHIFT)68#define I2S_RXCR_IBM_LSJM (1 << I2S_RXCR_IBM_SHIFT)69#define I2S_RXCR_IBM_RSJM (2 << I2S_RXCR_IBM_SHIFT)70#define I2S_RXCR_IBM_MASK (3 << I2S_RXCR_IBM_SHIFT)71#define I2S_RXCR_PBM_SHIFT 772#define I2S_RXCR_PBM_MODE(x) ((x) << I2S_RXCR_PBM_SHIFT)73#define I2S_RXCR_PBM_MASK (3 << I2S_RXCR_PBM_SHIFT)74#define I2S_RXCR_TFS_SHIFT 575#define I2S_RXCR_TFS_I2S (0 << I2S_RXCR_TFS_SHIFT)76#define I2S_RXCR_TFS_PCM (1 << I2S_RXCR_TFS_SHIFT)77#define I2S_RXCR_TFS_TDM_PCM (2 << I2S_RXCR_TFS_SHIFT)78#define I2S_RXCR_TFS_TDM_I2S (3 << I2S_RXCR_TFS_SHIFT)79#define I2S_RXCR_TFS_MASK (3 << I2S_RXCR_TFS_SHIFT)80#define I2S_RXCR_VDW_SHIFT 081#define I2S_RXCR_VDW(x) (((x) - 1) << I2S_RXCR_VDW_SHIFT)82#define I2S_RXCR_VDW_MASK (0x1f << I2S_RXCR_VDW_SHIFT)8384/*85* CKR86* clock generation register87*/88#define I2S_CKR_TRCM_SHIFT 2889#define I2S_CKR_TRCM(x) ((x) << I2S_CKR_TRCM_SHIFT)90#define I2S_CKR_TRCM_TXRX (0 << I2S_CKR_TRCM_SHIFT)91#define I2S_CKR_TRCM_TXONLY (1 << I2S_CKR_TRCM_SHIFT)92#define I2S_CKR_TRCM_RXONLY (2 << I2S_CKR_TRCM_SHIFT)93#define I2S_CKR_TRCM_MASK (3 << I2S_CKR_TRCM_SHIFT)94#define I2S_CKR_MSS_SHIFT 2795#define I2S_CKR_MSS_MASTER (0 << I2S_CKR_MSS_SHIFT)96#define I2S_CKR_MSS_SLAVE (1 << I2S_CKR_MSS_SHIFT)97#define I2S_CKR_MSS_MASK (1 << I2S_CKR_MSS_SHIFT)98#define I2S_CKR_CKP_SHIFT 2699#define I2S_CKR_CKP_NORMAL (0 << I2S_CKR_CKP_SHIFT)100#define I2S_CKR_CKP_INVERTED (1 << I2S_CKR_CKP_SHIFT)101#define I2S_CKR_CKP_MASK (1 << I2S_CKR_CKP_SHIFT)102#define I2S_CKR_RLP_SHIFT 25103#define I2S_CKR_RLP_NORMAL (0 << I2S_CKR_RLP_SHIFT)104#define I2S_CKR_RLP_INVERTED (1 << I2S_CKR_RLP_SHIFT)105#define I2S_CKR_RLP_MASK (1 << I2S_CKR_RLP_SHIFT)106#define I2S_CKR_TLP_SHIFT 24107#define I2S_CKR_TLP_NORMAL (0 << I2S_CKR_TLP_SHIFT)108#define I2S_CKR_TLP_INVERTED (1 << I2S_CKR_TLP_SHIFT)109#define I2S_CKR_TLP_MASK (1 << I2S_CKR_TLP_SHIFT)110#define I2S_CKR_MDIV_SHIFT 16111#define I2S_CKR_MDIV(x) (((x) - 1) << I2S_CKR_MDIV_SHIFT)112#define I2S_CKR_MDIV_MASK (0xff << I2S_CKR_MDIV_SHIFT)113#define I2S_CKR_RSD_SHIFT 8114#define I2S_CKR_RSD(x) (((x) - 1) << I2S_CKR_RSD_SHIFT)115#define I2S_CKR_RSD_MASK (0xff << I2S_CKR_RSD_SHIFT)116#define I2S_CKR_TSD_SHIFT 0117#define I2S_CKR_TSD(x) (((x) - 1) << I2S_CKR_TSD_SHIFT)118#define I2S_CKR_TSD_MASK (0xff << I2S_CKR_TSD_SHIFT)119120/*121* FIFOLR122* FIFO level register123*/124#define I2S_FIFOLR_RFL_SHIFT 24125#define I2S_FIFOLR_RFL_MASK (0x3f << I2S_FIFOLR_RFL_SHIFT)126#define I2S_FIFOLR_TFL3_SHIFT 18127#define I2S_FIFOLR_TFL3_MASK (0x3f << I2S_FIFOLR_TFL3_SHIFT)128#define I2S_FIFOLR_TFL2_SHIFT 12129#define I2S_FIFOLR_TFL2_MASK (0x3f << I2S_FIFOLR_TFL2_SHIFT)130#define I2S_FIFOLR_TFL1_SHIFT 6131#define I2S_FIFOLR_TFL1_MASK (0x3f << I2S_FIFOLR_TFL1_SHIFT)132#define I2S_FIFOLR_TFL0_SHIFT 0133#define I2S_FIFOLR_TFL0_MASK (0x3f << I2S_FIFOLR_TFL0_SHIFT)134135/*136* DMACR137* DMA control register138*/139#define I2S_DMACR_RDE_SHIFT 24140#define I2S_DMACR_RDE_DISABLE (0 << I2S_DMACR_RDE_SHIFT)141#define I2S_DMACR_RDE_ENABLE (1 << I2S_DMACR_RDE_SHIFT)142#define I2S_DMACR_RDL_SHIFT 16143#define I2S_DMACR_RDL(x) (((x) - 1) << I2S_DMACR_RDL_SHIFT)144#define I2S_DMACR_RDL_MASK (0x1f << I2S_DMACR_RDL_SHIFT)145#define I2S_DMACR_TDE_SHIFT 8146#define I2S_DMACR_TDE_DISABLE (0 << I2S_DMACR_TDE_SHIFT)147#define I2S_DMACR_TDE_ENABLE (1 << I2S_DMACR_TDE_SHIFT)148#define I2S_DMACR_TDL_SHIFT 0149#define I2S_DMACR_TDL(x) ((x) << I2S_DMACR_TDL_SHIFT)150#define I2S_DMACR_TDL_MASK (0x1f << I2S_DMACR_TDL_SHIFT)151152/*153* INTCR154* interrupt control register155*/156#define I2S_INTCR_RFT_SHIFT 20157#define I2S_INTCR_RFT(x) (((x) - 1) << I2S_INTCR_RFT_SHIFT)158#define I2S_INTCR_RXOIC BIT(18)159#define I2S_INTCR_RXOIE_SHIFT 17160#define I2S_INTCR_RXOIE_DISABLE (0 << I2S_INTCR_RXOIE_SHIFT)161#define I2S_INTCR_RXOIE_ENABLE (1 << I2S_INTCR_RXOIE_SHIFT)162#define I2S_INTCR_RXFIE_SHIFT 16163#define I2S_INTCR_RXFIE_DISABLE (0 << I2S_INTCR_RXFIE_SHIFT)164#define I2S_INTCR_RXFIE_ENABLE (1 << I2S_INTCR_RXFIE_SHIFT)165#define I2S_INTCR_TFT_SHIFT 4166#define I2S_INTCR_TFT(x) (((x) - 1) << I2S_INTCR_TFT_SHIFT)167#define I2S_INTCR_TFT_MASK (0x1f << I2S_INTCR_TFT_SHIFT)168#define I2S_INTCR_TXUIC BIT(2)169#define I2S_INTCR_TXUIE_SHIFT 1170#define I2S_INTCR_TXUIE_DISABLE (0 << I2S_INTCR_TXUIE_SHIFT)171#define I2S_INTCR_TXUIE_ENABLE (1 << I2S_INTCR_TXUIE_SHIFT)172173/*174* INTSR175* interrupt status register176*/177#define I2S_INTSR_TXEIE_SHIFT 0178#define I2S_INTSR_TXEIE_DISABLE (0 << I2S_INTSR_TXEIE_SHIFT)179#define I2S_INTSR_TXEIE_ENABLE (1 << I2S_INTSR_TXEIE_SHIFT)180#define I2S_INTSR_RXOI_SHIFT 17181#define I2S_INTSR_RXOI_INA (0 << I2S_INTSR_RXOI_SHIFT)182#define I2S_INTSR_RXOI_ACT (1 << I2S_INTSR_RXOI_SHIFT)183#define I2S_INTSR_RXFI_SHIFT 16184#define I2S_INTSR_RXFI_INA (0 << I2S_INTSR_RXFI_SHIFT)185#define I2S_INTSR_RXFI_ACT (1 << I2S_INTSR_RXFI_SHIFT)186#define I2S_INTSR_TXUI_SHIFT 1187#define I2S_INTSR_TXUI_INA (0 << I2S_INTSR_TXUI_SHIFT)188#define I2S_INTSR_TXUI_ACT (1 << I2S_INTSR_TXUI_SHIFT)189#define I2S_INTSR_TXEI_SHIFT 0190#define I2S_INTSR_TXEI_INA (0 << I2S_INTSR_TXEI_SHIFT)191#define I2S_INTSR_TXEI_ACT (1 << I2S_INTSR_TXEI_SHIFT)192193/*194* XFER195* Transfer start register196*/197#define I2S_XFER_RXS_SHIFT 1198#define I2S_XFER_RXS_STOP (0 << I2S_XFER_RXS_SHIFT)199#define I2S_XFER_RXS_START (1 << I2S_XFER_RXS_SHIFT)200#define I2S_XFER_TXS_SHIFT 0201#define I2S_XFER_TXS_STOP (0 << I2S_XFER_TXS_SHIFT)202#define I2S_XFER_TXS_START (1 << I2S_XFER_TXS_SHIFT)203204/*205* CLR206* clear SCLK domain logic register207*/208#define I2S_CLR_RXC BIT(1)209#define I2S_CLR_TXC BIT(0)210211/*212* TXDR213* Transimt FIFO data register, write only.214*/215#define I2S_TXDR_MASK (0xff)216217/*218* RXDR219* Receive FIFO data register, write only.220*/221#define I2S_RXDR_MASK (0xff)222223/*224* TDM_CTRL225* TDM ctrl register226*/227#define TDM_FSYNC_WIDTH_SEL1_MSK GENMASK(20, 18)228#define TDM_FSYNC_WIDTH_SEL1(x) (((x) - 1) << 18)229#define TDM_FSYNC_WIDTH_SEL0_MSK BIT(17)230#define TDM_FSYNC_WIDTH_HALF_FRAME 0231#define TDM_FSYNC_WIDTH_ONE_FRAME BIT(17)232#define TDM_SHIFT_CTRL_MSK GENMASK(16, 14)233#define TDM_SHIFT_CTRL(x) ((x) << 14)234#define TDM_SLOT_BIT_WIDTH_MSK GENMASK(13, 9)235#define TDM_SLOT_BIT_WIDTH(x) (((x) - 1) << 9)236#define TDM_FRAME_WIDTH_MSK GENMASK(8, 0)237#define TDM_FRAME_WIDTH(x) (((x) - 1) << 0)238239/*240* CLKDIV241* Mclk div register242*/243#define I2S_CLKDIV_TXM_SHIFT 0244#define I2S_CLKDIV_TXM(x) (((x) - 1) << I2S_CLKDIV_TXM_SHIFT)245#define I2S_CLKDIV_TXM_MASK (0xff << I2S_CLKDIV_TXM_SHIFT)246#define I2S_CLKDIV_RXM_SHIFT 8247#define I2S_CLKDIV_RXM(x) (((x) - 1) << I2S_CLKDIV_RXM_SHIFT)248#define I2S_CLKDIV_RXM_MASK (0xff << I2S_CLKDIV_RXM_SHIFT)249250/* Clock divider id */251enum {252ROCKCHIP_DIV_MCLK = 0,253ROCKCHIP_DIV_BCLK,254};255256/* channel select */257#define I2S_CSR_SHIFT 15258#define I2S_CHN_2 (0 << I2S_CSR_SHIFT)259#define I2S_CHN_4 (1 << I2S_CSR_SHIFT)260#define I2S_CHN_6 (2 << I2S_CSR_SHIFT)261#define I2S_CHN_8 (3 << I2S_CSR_SHIFT)262263/* io direction cfg register */264#define I2S_IO_DIRECTION_MASK (7)265#define I2S_IO_8CH_OUT_2CH_IN (7)266#define I2S_IO_6CH_OUT_4CH_IN (3)267#define I2S_IO_4CH_OUT_6CH_IN (1)268#define I2S_IO_2CH_OUT_8CH_IN (0)269270/* I2S REGS */271#define I2S_TXCR (0x0000)272#define I2S_RXCR (0x0004)273#define I2S_CKR (0x0008)274#define I2S_TXFIFOLR (0x000c)275#define I2S_DMACR (0x0010)276#define I2S_INTCR (0x0014)277#define I2S_INTSR (0x0018)278#define I2S_XFER (0x001c)279#define I2S_CLR (0x0020)280#define I2S_TXDR (0x0024)281#define I2S_RXDR (0x0028)282#define I2S_RXFIFOLR (0x002c)283#define I2S_TDM_TXCR (0x0030)284#define I2S_TDM_RXCR (0x0034)285#define I2S_CLKDIV (0x0038)286287#define HIWORD_UPDATE(v, h, l) (((v) << (l)) | (GENMASK((h), (l)) << 16))288289/* PX30 GRF CONFIGS */290#define PX30_I2S0_CLK_IN_SRC_FROM_TX HIWORD_UPDATE(1, 13, 12)291#define PX30_I2S0_CLK_IN_SRC_FROM_RX HIWORD_UPDATE(2, 13, 12)292#define PX30_I2S0_MCLK_OUT_SRC_FROM_TX HIWORD_UPDATE(1, 5, 5)293#define PX30_I2S0_MCLK_OUT_SRC_FROM_RX HIWORD_UPDATE(0, 5, 5)294295#define PX30_I2S0_CLK_TXONLY \296(PX30_I2S0_MCLK_OUT_SRC_FROM_TX | PX30_I2S0_CLK_IN_SRC_FROM_TX)297298#define PX30_I2S0_CLK_RXONLY \299(PX30_I2S0_MCLK_OUT_SRC_FROM_RX | PX30_I2S0_CLK_IN_SRC_FROM_RX)300301/* RK1808 GRF CONFIGS */302#define RK1808_I2S0_MCLK_OUT_SRC_FROM_RX HIWORD_UPDATE(1, 2, 2)303#define RK1808_I2S0_MCLK_OUT_SRC_FROM_TX HIWORD_UPDATE(0, 2, 2)304#define RK1808_I2S0_CLK_IN_SRC_FROM_TX HIWORD_UPDATE(1, 1, 0)305#define RK1808_I2S0_CLK_IN_SRC_FROM_RX HIWORD_UPDATE(2, 1, 0)306307#define RK1808_I2S0_CLK_TXONLY \308(RK1808_I2S0_MCLK_OUT_SRC_FROM_TX | RK1808_I2S0_CLK_IN_SRC_FROM_TX)309310#define RK1808_I2S0_CLK_RXONLY \311(RK1808_I2S0_MCLK_OUT_SRC_FROM_RX | RK1808_I2S0_CLK_IN_SRC_FROM_RX)312313/* RK3308 GRF CONFIGS */314#define RK3308_I2S0_8CH_MCLK_OUT_SRC_FROM_RX HIWORD_UPDATE(1, 10, 10)315#define RK3308_I2S0_8CH_MCLK_OUT_SRC_FROM_TX HIWORD_UPDATE(0, 10, 10)316#define RK3308_I2S0_8CH_CLK_IN_RX_SRC_FROM_TX HIWORD_UPDATE(1, 9, 9)317#define RK3308_I2S0_8CH_CLK_IN_RX_SRC_FROM_RX HIWORD_UPDATE(0, 9, 9)318#define RK3308_I2S0_8CH_CLK_IN_TX_SRC_FROM_RX HIWORD_UPDATE(1, 8, 8)319#define RK3308_I2S0_8CH_CLK_IN_TX_SRC_FROM_TX HIWORD_UPDATE(0, 8, 8)320#define RK3308_I2S1_8CH_MCLK_OUT_SRC_FROM_RX HIWORD_UPDATE(1, 2, 2)321#define RK3308_I2S1_8CH_MCLK_OUT_SRC_FROM_TX HIWORD_UPDATE(0, 2, 2)322#define RK3308_I2S1_8CH_CLK_IN_RX_SRC_FROM_TX HIWORD_UPDATE(1, 1, 1)323#define RK3308_I2S1_8CH_CLK_IN_RX_SRC_FROM_RX HIWORD_UPDATE(0, 1, 1)324#define RK3308_I2S1_8CH_CLK_IN_TX_SRC_FROM_RX HIWORD_UPDATE(1, 0, 0)325#define RK3308_I2S1_8CH_CLK_IN_TX_SRC_FROM_TX HIWORD_UPDATE(0, 0, 0)326327#define RK3308_I2S0_CLK_TXONLY \328(RK3308_I2S0_8CH_MCLK_OUT_SRC_FROM_TX | \329RK3308_I2S0_8CH_CLK_IN_RX_SRC_FROM_TX | \330RK3308_I2S0_8CH_CLK_IN_TX_SRC_FROM_TX)331332#define RK3308_I2S0_CLK_RXONLY \333(RK3308_I2S0_8CH_MCLK_OUT_SRC_FROM_RX | \334RK3308_I2S0_8CH_CLK_IN_RX_SRC_FROM_RX | \335RK3308_I2S0_8CH_CLK_IN_TX_SRC_FROM_RX)336337#define RK3308_I2S1_CLK_TXONLY \338(RK3308_I2S1_8CH_MCLK_OUT_SRC_FROM_TX | \339RK3308_I2S1_8CH_CLK_IN_RX_SRC_FROM_TX | \340RK3308_I2S1_8CH_CLK_IN_TX_SRC_FROM_TX)341342#define RK3308_I2S1_CLK_RXONLY \343(RK3308_I2S1_8CH_MCLK_OUT_SRC_FROM_RX | \344RK3308_I2S1_8CH_CLK_IN_RX_SRC_FROM_RX | \345RK3308_I2S1_8CH_CLK_IN_TX_SRC_FROM_RX)346347/* RK3568 GRF CONFIGS */348#define RK3568_I2S1_MCLK_OUT_SRC_FROM_TX HIWORD_UPDATE(1, 5, 5)349#define RK3568_I2S1_MCLK_OUT_SRC_FROM_RX HIWORD_UPDATE(0, 5, 5)350351#define RK3568_I2S1_CLK_TXONLY \352RK3568_I2S1_MCLK_OUT_SRC_FROM_TX353354#define RK3568_I2S1_CLK_RXONLY \355RK3568_I2S1_MCLK_OUT_SRC_FROM_RX356357#define RK3568_I2S3_MCLK_OUT_SRC_FROM_TX HIWORD_UPDATE(1, 15, 15)358#define RK3568_I2S3_MCLK_OUT_SRC_FROM_RX HIWORD_UPDATE(0, 15, 15)359#define RK3568_I2S3_SCLK_SRC_FROM_TX HIWORD_UPDATE(1, 7, 7)360#define RK3568_I2S3_SCLK_SRC_FROM_RX HIWORD_UPDATE(0, 7, 7)361#define RK3568_I2S3_LRCK_SRC_FROM_TX HIWORD_UPDATE(1, 6, 6)362#define RK3568_I2S3_LRCK_SRC_FROM_RX HIWORD_UPDATE(0, 6, 6)363364#define RK3568_I2S3_MCLK_TXONLY \365RK3568_I2S3_MCLK_OUT_SRC_FROM_TX366367#define RK3568_I2S3_CLK_TXONLY \368(RK3568_I2S3_SCLK_SRC_FROM_TX | \369RK3568_I2S3_LRCK_SRC_FROM_TX)370371#define RK3568_I2S3_MCLK_RXONLY \372RK3568_I2S3_MCLK_OUT_SRC_FROM_RX373374#define RK3568_I2S3_CLK_RXONLY \375(RK3568_I2S3_SCLK_SRC_FROM_RX | \376RK3568_I2S3_LRCK_SRC_FROM_RX)377378#define RK3568_I2S3_MCLK_IE HIWORD_UPDATE(0, 3, 3)379#define RK3568_I2S3_MCLK_OE HIWORD_UPDATE(1, 3, 3)380#define RK3568_I2S2_MCLK_IE HIWORD_UPDATE(0, 2, 2)381#define RK3568_I2S2_MCLK_OE HIWORD_UPDATE(1, 2, 2)382#define RK3568_I2S1_MCLK_TX_IE HIWORD_UPDATE(0, 1, 1)383#define RK3568_I2S1_MCLK_TX_OE HIWORD_UPDATE(1, 1, 1)384#define RK3568_I2S1_MCLK_RX_IE HIWORD_UPDATE(0, 0, 0)385#define RK3568_I2S1_MCLK_RX_OE HIWORD_UPDATE(1, 0, 0)386387/* RV1126 GRF CONFIGS */388#define RV1126_I2S0_MCLK_OUT_SRC_FROM_TX HIWORD_UPDATE(0, 9, 9)389#define RV1126_I2S0_MCLK_OUT_SRC_FROM_RX HIWORD_UPDATE(1, 9, 9)390391#define RV1126_I2S0_CLK_TXONLY \392RV1126_I2S0_MCLK_OUT_SRC_FROM_TX393394#define RV1126_I2S0_CLK_RXONLY \395RV1126_I2S0_MCLK_OUT_SRC_FROM_RX396397#endif /* _ROCKCHIP_I2S_TDM_H */398399400