Path: blob/master/sound/soc/rockchip/rockchip_i2s_tdm.h
29267 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#include <linux/hw_bitfield.h>1314/*15* TXCR16* transmit operation control register17*/18#define I2S_TXCR_PATH_SHIFT(x) (23 + (x) * 2)19#define I2S_TXCR_PATH_MASK(x) (0x3 << I2S_TXCR_PATH_SHIFT(x))20#define I2S_TXCR_PATH(x, v) ((v) << I2S_TXCR_PATH_SHIFT(x))21#define I2S_TXCR_RCNT_SHIFT 1722#define I2S_TXCR_RCNT_MASK (0x3f << I2S_TXCR_RCNT_SHIFT)23#define I2S_TXCR_CSR_SHIFT 1524#define I2S_TXCR_CSR(x) ((x) << I2S_TXCR_CSR_SHIFT)25#define I2S_TXCR_CSR_MASK (3 << I2S_TXCR_CSR_SHIFT)26#define I2S_TXCR_HWT BIT(14)27#define I2S_TXCR_SJM_SHIFT 1228#define I2S_TXCR_SJM_R (0 << I2S_TXCR_SJM_SHIFT)29#define I2S_TXCR_SJM_L (1 << I2S_TXCR_SJM_SHIFT)30#define I2S_TXCR_FBM_SHIFT 1131#define I2S_TXCR_FBM_MSB (0 << I2S_TXCR_FBM_SHIFT)32#define I2S_TXCR_FBM_LSB (1 << I2S_TXCR_FBM_SHIFT)33#define I2S_TXCR_IBM_SHIFT 934#define I2S_TXCR_IBM_NORMAL (0 << I2S_TXCR_IBM_SHIFT)35#define I2S_TXCR_IBM_LSJM (1 << I2S_TXCR_IBM_SHIFT)36#define I2S_TXCR_IBM_RSJM (2 << I2S_TXCR_IBM_SHIFT)37#define I2S_TXCR_IBM_MASK (3 << I2S_TXCR_IBM_SHIFT)38#define I2S_TXCR_PBM_SHIFT 739#define I2S_TXCR_PBM_MODE(x) ((x) << I2S_TXCR_PBM_SHIFT)40#define I2S_TXCR_PBM_MASK (3 << I2S_TXCR_PBM_SHIFT)41#define I2S_TXCR_TFS_SHIFT 542#define I2S_TXCR_TFS_I2S (0 << I2S_TXCR_TFS_SHIFT)43#define I2S_TXCR_TFS_PCM (1 << I2S_TXCR_TFS_SHIFT)44#define I2S_TXCR_TFS_TDM_PCM (2 << I2S_TXCR_TFS_SHIFT)45#define I2S_TXCR_TFS_TDM_I2S (3 << I2S_TXCR_TFS_SHIFT)46#define I2S_TXCR_TFS_MASK (3 << I2S_TXCR_TFS_SHIFT)47#define I2S_TXCR_VDW_SHIFT 048#define I2S_TXCR_VDW(x) (((x) - 1) << I2S_TXCR_VDW_SHIFT)49#define I2S_TXCR_VDW_MASK (0x1f << I2S_TXCR_VDW_SHIFT)5051/*52* RXCR53* receive operation control register54*/55#define I2S_RXCR_PATH_SHIFT(x) (17 + (x) * 2)56#define I2S_RXCR_PATH_MASK(x) (0x3 << I2S_RXCR_PATH_SHIFT(x))57#define I2S_RXCR_PATH(x, v) ((v) << I2S_RXCR_PATH_SHIFT(x))58#define I2S_RXCR_CSR_SHIFT 1559#define I2S_RXCR_CSR(x) ((x) << I2S_RXCR_CSR_SHIFT)60#define I2S_RXCR_CSR_MASK (3 << I2S_RXCR_CSR_SHIFT)61#define I2S_RXCR_HWT BIT(14)62#define I2S_RXCR_SJM_SHIFT 1263#define I2S_RXCR_SJM_R (0 << I2S_RXCR_SJM_SHIFT)64#define I2S_RXCR_SJM_L (1 << I2S_RXCR_SJM_SHIFT)65#define I2S_RXCR_FBM_SHIFT 1166#define I2S_RXCR_FBM_MSB (0 << I2S_RXCR_FBM_SHIFT)67#define I2S_RXCR_FBM_LSB (1 << I2S_RXCR_FBM_SHIFT)68#define I2S_RXCR_IBM_SHIFT 969#define I2S_RXCR_IBM_NORMAL (0 << I2S_RXCR_IBM_SHIFT)70#define I2S_RXCR_IBM_LSJM (1 << I2S_RXCR_IBM_SHIFT)71#define I2S_RXCR_IBM_RSJM (2 << I2S_RXCR_IBM_SHIFT)72#define I2S_RXCR_IBM_MASK (3 << I2S_RXCR_IBM_SHIFT)73#define I2S_RXCR_PBM_SHIFT 774#define I2S_RXCR_PBM_MODE(x) ((x) << I2S_RXCR_PBM_SHIFT)75#define I2S_RXCR_PBM_MASK (3 << I2S_RXCR_PBM_SHIFT)76#define I2S_RXCR_TFS_SHIFT 577#define I2S_RXCR_TFS_I2S (0 << I2S_RXCR_TFS_SHIFT)78#define I2S_RXCR_TFS_PCM (1 << I2S_RXCR_TFS_SHIFT)79#define I2S_RXCR_TFS_TDM_PCM (2 << I2S_RXCR_TFS_SHIFT)80#define I2S_RXCR_TFS_TDM_I2S (3 << I2S_RXCR_TFS_SHIFT)81#define I2S_RXCR_TFS_MASK (3 << I2S_RXCR_TFS_SHIFT)82#define I2S_RXCR_VDW_SHIFT 083#define I2S_RXCR_VDW(x) (((x) - 1) << I2S_RXCR_VDW_SHIFT)84#define I2S_RXCR_VDW_MASK (0x1f << I2S_RXCR_VDW_SHIFT)8586/*87* CKR88* clock generation register89*/90#define I2S_CKR_TRCM_SHIFT 2891#define I2S_CKR_TRCM(x) ((x) << I2S_CKR_TRCM_SHIFT)92#define I2S_CKR_TRCM_TXRX (0 << I2S_CKR_TRCM_SHIFT)93#define I2S_CKR_TRCM_TXONLY (1 << I2S_CKR_TRCM_SHIFT)94#define I2S_CKR_TRCM_RXONLY (2 << I2S_CKR_TRCM_SHIFT)95#define I2S_CKR_TRCM_MASK (3 << I2S_CKR_TRCM_SHIFT)96#define I2S_CKR_MSS_SHIFT 2797#define I2S_CKR_MSS_MASTER (0 << I2S_CKR_MSS_SHIFT)98#define I2S_CKR_MSS_SLAVE (1 << I2S_CKR_MSS_SHIFT)99#define I2S_CKR_MSS_MASK (1 << I2S_CKR_MSS_SHIFT)100#define I2S_CKR_CKP_SHIFT 26101#define I2S_CKR_CKP_NORMAL (0 << I2S_CKR_CKP_SHIFT)102#define I2S_CKR_CKP_INVERTED (1 << I2S_CKR_CKP_SHIFT)103#define I2S_CKR_CKP_MASK (1 << I2S_CKR_CKP_SHIFT)104#define I2S_CKR_RLP_SHIFT 25105#define I2S_CKR_RLP_NORMAL (0 << I2S_CKR_RLP_SHIFT)106#define I2S_CKR_RLP_INVERTED (1 << I2S_CKR_RLP_SHIFT)107#define I2S_CKR_RLP_MASK (1 << I2S_CKR_RLP_SHIFT)108#define I2S_CKR_TLP_SHIFT 24109#define I2S_CKR_TLP_NORMAL (0 << I2S_CKR_TLP_SHIFT)110#define I2S_CKR_TLP_INVERTED (1 << I2S_CKR_TLP_SHIFT)111#define I2S_CKR_TLP_MASK (1 << I2S_CKR_TLP_SHIFT)112#define I2S_CKR_MDIV_SHIFT 16113#define I2S_CKR_MDIV(x) (((x) - 1) << I2S_CKR_MDIV_SHIFT)114#define I2S_CKR_MDIV_MASK (0xff << I2S_CKR_MDIV_SHIFT)115#define I2S_CKR_RSD_SHIFT 8116#define I2S_CKR_RSD(x) (((x) - 1) << I2S_CKR_RSD_SHIFT)117#define I2S_CKR_RSD_MASK (0xff << I2S_CKR_RSD_SHIFT)118#define I2S_CKR_TSD_SHIFT 0119#define I2S_CKR_TSD(x) (((x) - 1) << I2S_CKR_TSD_SHIFT)120#define I2S_CKR_TSD_MASK (0xff << I2S_CKR_TSD_SHIFT)121122/*123* FIFOLR124* FIFO level register125*/126#define I2S_FIFOLR_RFL_SHIFT 24127#define I2S_FIFOLR_RFL_MASK (0x3f << I2S_FIFOLR_RFL_SHIFT)128#define I2S_FIFOLR_TFL3_SHIFT 18129#define I2S_FIFOLR_TFL3_MASK (0x3f << I2S_FIFOLR_TFL3_SHIFT)130#define I2S_FIFOLR_TFL2_SHIFT 12131#define I2S_FIFOLR_TFL2_MASK (0x3f << I2S_FIFOLR_TFL2_SHIFT)132#define I2S_FIFOLR_TFL1_SHIFT 6133#define I2S_FIFOLR_TFL1_MASK (0x3f << I2S_FIFOLR_TFL1_SHIFT)134#define I2S_FIFOLR_TFL0_SHIFT 0135#define I2S_FIFOLR_TFL0_MASK (0x3f << I2S_FIFOLR_TFL0_SHIFT)136137/*138* DMACR139* DMA control register140*/141#define I2S_DMACR_RDE_SHIFT 24142#define I2S_DMACR_RDE_DISABLE (0 << I2S_DMACR_RDE_SHIFT)143#define I2S_DMACR_RDE_ENABLE (1 << I2S_DMACR_RDE_SHIFT)144#define I2S_DMACR_RDL_SHIFT 16145#define I2S_DMACR_RDL(x) (((x) - 1) << I2S_DMACR_RDL_SHIFT)146#define I2S_DMACR_RDL_MASK (0x1f << I2S_DMACR_RDL_SHIFT)147#define I2S_DMACR_TDE_SHIFT 8148#define I2S_DMACR_TDE_DISABLE (0 << I2S_DMACR_TDE_SHIFT)149#define I2S_DMACR_TDE_ENABLE (1 << I2S_DMACR_TDE_SHIFT)150#define I2S_DMACR_TDL_SHIFT 0151#define I2S_DMACR_TDL(x) ((x) << I2S_DMACR_TDL_SHIFT)152#define I2S_DMACR_TDL_MASK (0x1f << I2S_DMACR_TDL_SHIFT)153154/*155* INTCR156* interrupt control register157*/158#define I2S_INTCR_RFT_SHIFT 20159#define I2S_INTCR_RFT(x) (((x) - 1) << I2S_INTCR_RFT_SHIFT)160#define I2S_INTCR_RXOIC BIT(18)161#define I2S_INTCR_RXOIE_SHIFT 17162#define I2S_INTCR_RXOIE_DISABLE (0 << I2S_INTCR_RXOIE_SHIFT)163#define I2S_INTCR_RXOIE_ENABLE (1 << I2S_INTCR_RXOIE_SHIFT)164#define I2S_INTCR_RXFIE_SHIFT 16165#define I2S_INTCR_RXFIE_DISABLE (0 << I2S_INTCR_RXFIE_SHIFT)166#define I2S_INTCR_RXFIE_ENABLE (1 << I2S_INTCR_RXFIE_SHIFT)167#define I2S_INTCR_TFT_SHIFT 4168#define I2S_INTCR_TFT(x) (((x) - 1) << I2S_INTCR_TFT_SHIFT)169#define I2S_INTCR_TFT_MASK (0x1f << I2S_INTCR_TFT_SHIFT)170#define I2S_INTCR_TXUIC BIT(2)171#define I2S_INTCR_TXUIE_SHIFT 1172#define I2S_INTCR_TXUIE_DISABLE (0 << I2S_INTCR_TXUIE_SHIFT)173#define I2S_INTCR_TXUIE_ENABLE (1 << I2S_INTCR_TXUIE_SHIFT)174175/*176* INTSR177* interrupt status register178*/179#define I2S_INTSR_TXEIE_SHIFT 0180#define I2S_INTSR_TXEIE_DISABLE (0 << I2S_INTSR_TXEIE_SHIFT)181#define I2S_INTSR_TXEIE_ENABLE (1 << I2S_INTSR_TXEIE_SHIFT)182#define I2S_INTSR_RXOI_SHIFT 17183#define I2S_INTSR_RXOI_INA (0 << I2S_INTSR_RXOI_SHIFT)184#define I2S_INTSR_RXOI_ACT (1 << I2S_INTSR_RXOI_SHIFT)185#define I2S_INTSR_RXFI_SHIFT 16186#define I2S_INTSR_RXFI_INA (0 << I2S_INTSR_RXFI_SHIFT)187#define I2S_INTSR_RXFI_ACT (1 << I2S_INTSR_RXFI_SHIFT)188#define I2S_INTSR_TXUI_SHIFT 1189#define I2S_INTSR_TXUI_INA (0 << I2S_INTSR_TXUI_SHIFT)190#define I2S_INTSR_TXUI_ACT (1 << I2S_INTSR_TXUI_SHIFT)191#define I2S_INTSR_TXEI_SHIFT 0192#define I2S_INTSR_TXEI_INA (0 << I2S_INTSR_TXEI_SHIFT)193#define I2S_INTSR_TXEI_ACT (1 << I2S_INTSR_TXEI_SHIFT)194195/*196* XFER197* Transfer start register198*/199#define I2S_XFER_RXS_SHIFT 1200#define I2S_XFER_RXS_STOP (0 << I2S_XFER_RXS_SHIFT)201#define I2S_XFER_RXS_START (1 << I2S_XFER_RXS_SHIFT)202#define I2S_XFER_TXS_SHIFT 0203#define I2S_XFER_TXS_STOP (0 << I2S_XFER_TXS_SHIFT)204#define I2S_XFER_TXS_START (1 << I2S_XFER_TXS_SHIFT)205206/*207* CLR208* clear SCLK domain logic register209*/210#define I2S_CLR_RXC BIT(1)211#define I2S_CLR_TXC BIT(0)212213/*214* TXDR215* Transimt FIFO data register, write only.216*/217#define I2S_TXDR_MASK (0xff)218219/*220* RXDR221* Receive FIFO data register, write only.222*/223#define I2S_RXDR_MASK (0xff)224225/*226* TDM_CTRL227* TDM ctrl register228*/229#define TDM_FSYNC_WIDTH_SEL1_MSK GENMASK(20, 18)230#define TDM_FSYNC_WIDTH_SEL1(x) (((x) - 1) << 18)231#define TDM_FSYNC_WIDTH_SEL0_MSK BIT(17)232#define TDM_FSYNC_WIDTH_HALF_FRAME 0233#define TDM_FSYNC_WIDTH_ONE_FRAME BIT(17)234#define TDM_SHIFT_CTRL_MSK GENMASK(16, 14)235#define TDM_SHIFT_CTRL(x) ((x) << 14)236#define TDM_SLOT_BIT_WIDTH_MSK GENMASK(13, 9)237#define TDM_SLOT_BIT_WIDTH(x) (((x) - 1) << 9)238#define TDM_FRAME_WIDTH_MSK GENMASK(8, 0)239#define TDM_FRAME_WIDTH(x) (((x) - 1) << 0)240241/*242* CLKDIV243* Mclk div register244*/245#define I2S_CLKDIV_TXM_SHIFT 0246#define I2S_CLKDIV_TXM(x) (((x) - 1) << I2S_CLKDIV_TXM_SHIFT)247#define I2S_CLKDIV_TXM_MASK (0xff << I2S_CLKDIV_TXM_SHIFT)248#define I2S_CLKDIV_RXM_SHIFT 8249#define I2S_CLKDIV_RXM(x) (((x) - 1) << I2S_CLKDIV_RXM_SHIFT)250#define I2S_CLKDIV_RXM_MASK (0xff << I2S_CLKDIV_RXM_SHIFT)251252/* Clock divider id */253enum {254ROCKCHIP_DIV_MCLK = 0,255ROCKCHIP_DIV_BCLK,256};257258/* channel select */259#define I2S_CSR_SHIFT 15260#define I2S_CHN_2 (0 << I2S_CSR_SHIFT)261#define I2S_CHN_4 (1 << I2S_CSR_SHIFT)262#define I2S_CHN_6 (2 << I2S_CSR_SHIFT)263#define I2S_CHN_8 (3 << I2S_CSR_SHIFT)264265/* io direction cfg register */266#define I2S_IO_DIRECTION_MASK (7)267#define I2S_IO_8CH_OUT_2CH_IN (7)268#define I2S_IO_6CH_OUT_4CH_IN (3)269#define I2S_IO_4CH_OUT_6CH_IN (1)270#define I2S_IO_2CH_OUT_8CH_IN (0)271272/* I2S REGS */273#define I2S_TXCR (0x0000)274#define I2S_RXCR (0x0004)275#define I2S_CKR (0x0008)276#define I2S_TXFIFOLR (0x000c)277#define I2S_DMACR (0x0010)278#define I2S_INTCR (0x0014)279#define I2S_INTSR (0x0018)280#define I2S_XFER (0x001c)281#define I2S_CLR (0x0020)282#define I2S_TXDR (0x0024)283#define I2S_RXDR (0x0028)284#define I2S_RXFIFOLR (0x002c)285#define I2S_TDM_TXCR (0x0030)286#define I2S_TDM_RXCR (0x0034)287#define I2S_CLKDIV (0x0038)288289#define HIWORD_UPDATE(v, h, l) (FIELD_PREP_WM16_CONST(GENMASK((h), (l)), (v)))290291/* PX30 GRF CONFIGS */292#define PX30_I2S0_CLK_IN_SRC_FROM_TX HIWORD_UPDATE(1, 13, 12)293#define PX30_I2S0_CLK_IN_SRC_FROM_RX HIWORD_UPDATE(2, 13, 12)294#define PX30_I2S0_MCLK_OUT_SRC_FROM_TX HIWORD_UPDATE(1, 5, 5)295#define PX30_I2S0_MCLK_OUT_SRC_FROM_RX HIWORD_UPDATE(0, 5, 5)296297#define PX30_I2S0_CLK_TXONLY \298(PX30_I2S0_MCLK_OUT_SRC_FROM_TX | PX30_I2S0_CLK_IN_SRC_FROM_TX)299300#define PX30_I2S0_CLK_RXONLY \301(PX30_I2S0_MCLK_OUT_SRC_FROM_RX | PX30_I2S0_CLK_IN_SRC_FROM_RX)302303/* RK1808 GRF CONFIGS */304#define RK1808_I2S0_MCLK_OUT_SRC_FROM_RX HIWORD_UPDATE(1, 2, 2)305#define RK1808_I2S0_MCLK_OUT_SRC_FROM_TX HIWORD_UPDATE(0, 2, 2)306#define RK1808_I2S0_CLK_IN_SRC_FROM_TX HIWORD_UPDATE(1, 1, 0)307#define RK1808_I2S0_CLK_IN_SRC_FROM_RX HIWORD_UPDATE(2, 1, 0)308309#define RK1808_I2S0_CLK_TXONLY \310(RK1808_I2S0_MCLK_OUT_SRC_FROM_TX | RK1808_I2S0_CLK_IN_SRC_FROM_TX)311312#define RK1808_I2S0_CLK_RXONLY \313(RK1808_I2S0_MCLK_OUT_SRC_FROM_RX | RK1808_I2S0_CLK_IN_SRC_FROM_RX)314315/* RK3308 GRF CONFIGS */316#define RK3308_I2S0_8CH_MCLK_OUT_SRC_FROM_RX HIWORD_UPDATE(1, 10, 10)317#define RK3308_I2S0_8CH_MCLK_OUT_SRC_FROM_TX HIWORD_UPDATE(0, 10, 10)318#define RK3308_I2S0_8CH_CLK_IN_RX_SRC_FROM_TX HIWORD_UPDATE(1, 9, 9)319#define RK3308_I2S0_8CH_CLK_IN_RX_SRC_FROM_RX HIWORD_UPDATE(0, 9, 9)320#define RK3308_I2S0_8CH_CLK_IN_TX_SRC_FROM_RX HIWORD_UPDATE(1, 8, 8)321#define RK3308_I2S0_8CH_CLK_IN_TX_SRC_FROM_TX HIWORD_UPDATE(0, 8, 8)322#define RK3308_I2S1_8CH_MCLK_OUT_SRC_FROM_RX HIWORD_UPDATE(1, 2, 2)323#define RK3308_I2S1_8CH_MCLK_OUT_SRC_FROM_TX HIWORD_UPDATE(0, 2, 2)324#define RK3308_I2S1_8CH_CLK_IN_RX_SRC_FROM_TX HIWORD_UPDATE(1, 1, 1)325#define RK3308_I2S1_8CH_CLK_IN_RX_SRC_FROM_RX HIWORD_UPDATE(0, 1, 1)326#define RK3308_I2S1_8CH_CLK_IN_TX_SRC_FROM_RX HIWORD_UPDATE(1, 0, 0)327#define RK3308_I2S1_8CH_CLK_IN_TX_SRC_FROM_TX HIWORD_UPDATE(0, 0, 0)328329#define RK3308_I2S0_CLK_TXONLY \330(RK3308_I2S0_8CH_MCLK_OUT_SRC_FROM_TX | \331RK3308_I2S0_8CH_CLK_IN_RX_SRC_FROM_TX | \332RK3308_I2S0_8CH_CLK_IN_TX_SRC_FROM_TX)333334#define RK3308_I2S0_CLK_RXONLY \335(RK3308_I2S0_8CH_MCLK_OUT_SRC_FROM_RX | \336RK3308_I2S0_8CH_CLK_IN_RX_SRC_FROM_RX | \337RK3308_I2S0_8CH_CLK_IN_TX_SRC_FROM_RX)338339#define RK3308_I2S1_CLK_TXONLY \340(RK3308_I2S1_8CH_MCLK_OUT_SRC_FROM_TX | \341RK3308_I2S1_8CH_CLK_IN_RX_SRC_FROM_TX | \342RK3308_I2S1_8CH_CLK_IN_TX_SRC_FROM_TX)343344#define RK3308_I2S1_CLK_RXONLY \345(RK3308_I2S1_8CH_MCLK_OUT_SRC_FROM_RX | \346RK3308_I2S1_8CH_CLK_IN_RX_SRC_FROM_RX | \347RK3308_I2S1_8CH_CLK_IN_TX_SRC_FROM_RX)348349/* RK3568 GRF CONFIGS */350#define RK3568_I2S1_MCLK_OUT_SRC_FROM_TX HIWORD_UPDATE(1, 5, 5)351#define RK3568_I2S1_MCLK_OUT_SRC_FROM_RX HIWORD_UPDATE(0, 5, 5)352353#define RK3568_I2S1_CLK_TXONLY \354RK3568_I2S1_MCLK_OUT_SRC_FROM_TX355356#define RK3568_I2S1_CLK_RXONLY \357RK3568_I2S1_MCLK_OUT_SRC_FROM_RX358359#define RK3568_I2S3_MCLK_OUT_SRC_FROM_TX HIWORD_UPDATE(1, 15, 15)360#define RK3568_I2S3_MCLK_OUT_SRC_FROM_RX HIWORD_UPDATE(0, 15, 15)361#define RK3568_I2S3_SCLK_SRC_FROM_TX HIWORD_UPDATE(1, 7, 7)362#define RK3568_I2S3_SCLK_SRC_FROM_RX HIWORD_UPDATE(0, 7, 7)363#define RK3568_I2S3_LRCK_SRC_FROM_TX HIWORD_UPDATE(1, 6, 6)364#define RK3568_I2S3_LRCK_SRC_FROM_RX HIWORD_UPDATE(0, 6, 6)365366#define RK3568_I2S3_MCLK_TXONLY \367RK3568_I2S3_MCLK_OUT_SRC_FROM_TX368369#define RK3568_I2S3_CLK_TXONLY \370(RK3568_I2S3_SCLK_SRC_FROM_TX | \371RK3568_I2S3_LRCK_SRC_FROM_TX)372373#define RK3568_I2S3_MCLK_RXONLY \374RK3568_I2S3_MCLK_OUT_SRC_FROM_RX375376#define RK3568_I2S3_CLK_RXONLY \377(RK3568_I2S3_SCLK_SRC_FROM_RX | \378RK3568_I2S3_LRCK_SRC_FROM_RX)379380#define RK3568_I2S3_MCLK_IE HIWORD_UPDATE(0, 3, 3)381#define RK3568_I2S3_MCLK_OE HIWORD_UPDATE(1, 3, 3)382#define RK3568_I2S2_MCLK_IE HIWORD_UPDATE(0, 2, 2)383#define RK3568_I2S2_MCLK_OE HIWORD_UPDATE(1, 2, 2)384#define RK3568_I2S1_MCLK_TX_IE HIWORD_UPDATE(0, 1, 1)385#define RK3568_I2S1_MCLK_TX_OE HIWORD_UPDATE(1, 1, 1)386#define RK3568_I2S1_MCLK_RX_IE HIWORD_UPDATE(0, 0, 0)387#define RK3568_I2S1_MCLK_RX_OE HIWORD_UPDATE(1, 0, 0)388389/* RV1126 GRF CONFIGS */390#define RV1126_I2S0_MCLK_OUT_SRC_FROM_TX HIWORD_UPDATE(0, 9, 9)391#define RV1126_I2S0_MCLK_OUT_SRC_FROM_RX HIWORD_UPDATE(1, 9, 9)392393#define RV1126_I2S0_CLK_TXONLY \394RV1126_I2S0_MCLK_OUT_SRC_FROM_TX395396#define RV1126_I2S0_CLK_RXONLY \397RV1126_I2S0_MCLK_OUT_SRC_FROM_RX398399#endif /* _ROCKCHIP_I2S_TDM_H */400401402