| /* SPDX-License-Identifier: GPL-2.0-or-later */ |
| /* |
| * ALSA SoC Audio Layer - Rockchip SAI Controller driver |
| * |
| * Copyright (c) 2022 Rockchip Electronics Co. Ltd. |
| */ |
| |
| #ifndef _ROCKCHIP_SAI_H |
| #define _ROCKCHIP_SAI_H |
| |
| /* XCR Transmit / Receive Control Register */ |
| #define SAI_XCR_START_SEL_MASK BIT(23) |
| #define SAI_XCR_START_SEL_CHAINED BIT(23) |
| #define SAI_XCR_START_SEL_STANDALONE 0 |
| #define SAI_XCR_EDGE_SHIFT_MASK BIT(22) |
| #define SAI_XCR_EDGE_SHIFT_1 BIT(22) |
| #define SAI_XCR_EDGE_SHIFT_0 0 |
| #define SAI_XCR_CSR_MASK GENMASK(21, 20) |
| #define SAI_XCR_CSR(x) ((x - 1) << 20) |
| #define SAI_XCR_CSR_V(v) ((((v) & SAI_XCR_CSR_MASK) >> 20) + 1) |
| #define SAI_XCR_SJM_MASK BIT(19) |
| #define SAI_XCR_SJM_L BIT(19) |
| #define SAI_XCR_SJM_R 0 |
| #define SAI_XCR_FBM_MASK BIT(18) |
| #define SAI_XCR_FBM_LSB BIT(18) |
| #define SAI_XCR_FBM_MSB 0 |
| #define SAI_XCR_SNB_MASK GENMASK(17, 11) |
| #define SAI_XCR_SNB(x) ((x - 1) << 11) |
| #define SAI_XCR_VDJ_MASK BIT(10) |
| #define SAI_XCR_VDJ_L BIT(10) |
| #define SAI_XCR_VDJ_R 0 |
| #define SAI_XCR_SBW_MASK GENMASK(9, 5) |
| #define SAI_XCR_SBW(x) ((x - 1) << 5) |
| #define SAI_XCR_SBW_V(v) ((((v) & SAI_XCR_SBW_MASK) >> 5) + 1) |
| #define SAI_XCR_VDW_MASK GENMASK(4, 0) |
| #define SAI_XCR_VDW(x) ((x - 1) << 0) |
| |
| /* FSCR Frame Sync Control Register */ |
| #define SAI_FSCR_EDGE_MASK BIT(24) |
| #define SAI_FSCR_EDGE_DUAL BIT(24) |
| #define SAI_FSCR_EDGE_RISING 0 |
| #define SAI_FSCR_FPW_MASK GENMASK(23, 12) |
| #define SAI_FSCR_FPW(x) ((x - 1) << 12) |
| #define SAI_FSCR_FW_MASK GENMASK(11, 0) |
| #define SAI_FSCR_FW(x) ((x - 1) << 0) |
| #define SAI_FSCR_FW_V(v) ((((v) & SAI_FSCR_FW_MASK) >> 0) + 1) |
| |
| /* MONO_CR Mono Control Register */ |
| #define SAI_MCR_RX_MONO_SLOT_MASK GENMASK(8, 2) |
| #define SAI_MCR_RX_MONO_SLOT_SEL(x) ((x - 1) << 2) |
| #define SAI_MCR_RX_MONO_MASK BIT(1) |
| #define SAI_MCR_RX_MONO_EN BIT(1) |
| #define SAI_MCR_RX_MONO_DIS 0 |
| #define SAI_MCR_TX_MONO_MASK BIT(0) |
| #define SAI_MCR_TX_MONO_EN BIT(0) |
| #define SAI_MCR_TX_MONO_DIS 0 |
| |
| /* XFER Transfer Start Register */ |
| #define SAI_XFER_RX_IDLE BIT(8) |
| #define SAI_XFER_TX_IDLE BIT(7) |
| #define SAI_XFER_FS_IDLE BIT(6) |
| /* |
| * Used for TX only (VERSION >= SAI_VER_2311) |
| * |
| * SCLK/FSYNC auto gated when TX FIFO empty. |
| */ |
| #define SAI_XFER_TX_AUTO_MASK BIT(6) |
| #define SAI_XFER_TX_AUTO_EN BIT(6) |
| #define SAI_XFER_TX_AUTO_DIS 0 |
| #define SAI_XFER_RX_CNT_MASK BIT(5) |
| #define SAI_XFER_RX_CNT_EN BIT(5) |
| #define SAI_XFER_RX_CNT_DIS 0 |
| #define SAI_XFER_TX_CNT_MASK BIT(4) |
| #define SAI_XFER_TX_CNT_EN BIT(4) |
| #define SAI_XFER_TX_CNT_DIS 0 |
| #define SAI_XFER_RXS_MASK BIT(3) |
| #define SAI_XFER_RXS_EN BIT(3) |
| #define SAI_XFER_RXS_DIS 0 |
| #define SAI_XFER_TXS_MASK BIT(2) |
| #define SAI_XFER_TXS_EN BIT(2) |
| #define SAI_XFER_TXS_DIS 0 |
| #define SAI_XFER_FSS_MASK BIT(1) |
| #define SAI_XFER_FSS_EN BIT(1) |
| #define SAI_XFER_FSS_DIS 0 |
| #define SAI_XFER_CLK_MASK BIT(0) |
| #define SAI_XFER_CLK_EN BIT(0) |
| #define SAI_XFER_CLK_DIS 0 |
| |
| /* CLR Clear Logic Register */ |
| #define SAI_CLR_FCR BIT(3) /* TODO: what is this? */ |
| #define SAI_CLR_FSC BIT(2) |
| #define SAI_CLR_RXC BIT(1) |
| #define SAI_CLR_TXC BIT(0) |
| |
| /* CKR Clock Generation Register */ |
| #define SAI_CKR_MDIV_MASK GENMASK(14, 3) |
| #define SAI_CKR_MDIV(x) ((x - 1) << 3) |
| #define SAI_CKR_MSS_MASK BIT(2) |
| #define SAI_CKR_MSS_SLAVE BIT(2) |
| #define SAI_CKR_MSS_MASTER 0 |
| #define SAI_CKR_CKP_MASK BIT(1) |
| #define SAI_CKR_CKP_INVERTED BIT(1) |
| #define SAI_CKR_CKP_NORMAL 0 |
| #define SAI_CKR_FSP_MASK BIT(0) |
| #define SAI_CKR_FSP_INVERTED BIT(0) |
| #define SAI_CKR_FSP_NORMAL 0 |
| |
| /* DMACR DMA Control Register */ |
| #define SAI_DMACR_RDE_MASK BIT(24) |
| #define SAI_DMACR_RDE(x) ((x) << 24) |
| #define SAI_DMACR_RDL_MASK GENMASK(20, 16) |
| #define SAI_DMACR_RDL(x) ((x - 1) << 16) |
| #define SAI_DMACR_RDL_V(v) ((((v) & SAI_DMACR_RDL_MASK) >> 16) + 1) |
| #define SAI_DMACR_TDE_MASK BIT(8) |
| #define SAI_DMACR_TDE(x) ((x) << 8) |
| #define SAI_DMACR_TDL_MASK GENMASK(4, 0) |
| #define SAI_DMACR_TDL(x) ((x) << 0) |
| #define SAI_DMACR_TDL_V(v) (((v) & SAI_DMACR_TDL_MASK) >> 0) |
| |
| /* INTCR Interrupt Ctrl Register */ |
| #define SAI_INTCR_FSLOSTC BIT(28) |
| #define SAI_INTCR_FSLOST_MASK BIT(27) |
| #define SAI_INTCR_FSLOST(x) ((x) << 27) |
| #define SAI_INTCR_FSERRC BIT(26) |
| #define SAI_INTCR_FSERR_MASK BIT(25) |
| #define SAI_INTCR_FSERR(x) ((x) << 25) |
| #define SAI_INTCR_RXOIC BIT(18) |
| #define SAI_INTCR_RXOIE_MASK BIT(17) |
| #define SAI_INTCR_RXOIE(x) ((x) << 17) |
| #define SAI_INTCR_TXUIC BIT(2) |
| #define SAI_INTCR_TXUIE_MASK BIT(1) |
| #define SAI_INTCR_TXUIE(x) ((x) << 1) |
| |
| /* INTSR Interrupt Status Register */ |
| #define SAI_INTSR_FSLOSTI_INA 0 |
| #define SAI_INTSR_FSLOSTI_ACT BIT(19) |
| #define SAI_INTSR_FSERRI_INA 0 |
| #define SAI_INTSR_FSERRI_ACT BIT(18) |
| #define SAI_INTSR_RXOI_INA 0 |
| #define SAI_INTSR_RXOI_ACT BIT(17) |
| #define SAI_INTSR_TXUI_INA 0 |
| #define SAI_INTSR_TXUI_ACT BIT(1) |
| |
| /* PATH_SEL: Transfer / Receive Path Select Register */ |
| #define SAI_RX_PATH_SHIFT(x) (8 + (x) * 2) |
| #define SAI_RX_PATH_MASK(x) (0x3 << SAI_RX_PATH_SHIFT(x)) |
| #define SAI_RX_PATH(x, v) ((v) << SAI_RX_PATH_SHIFT(x)) |
| #define SAI_TX_PATH_SHIFT(x) (0 + (x) * 2) |
| #define SAI_TX_PATH_MASK(x) (0x3 << SAI_TX_PATH_SHIFT(x)) |
| #define SAI_TX_PATH(x, v) ((v) << SAI_TX_PATH_SHIFT(x)) |
| |
| /* XSHIFT: Transfer / Receive Frame Sync Shift Register */ |
| |
| /* |
| * TX-ONLY: LEFT Direction Feature |
| * +------------------------------------------------+ |
| * | DATA LEFTx (step: 0.5 cycle) | FSYNC Edge | |
| * +------------------------------------------------+ |
| */ |
| #define SAI_XSHIFT_LEFT_MASK GENMASK(25, 24) |
| #define SAI_XSHIFT_LEFT(x) ((x) << 24) |
| /* |
| * +------------------------------------------------+ |
| * | FSYNC Edge | DATA RIGHTx (step: 0.5 cycle) | |
| * +------------------------------------------------+ |
| */ |
| #define SAI_XSHIFT_RIGHT_MASK GENMASK(23, 0) |
| #define SAI_XSHIFT_RIGHT(x) (x) |
| |
| /* XFIFOLR: Transfer / Receive FIFO Level Register */ |
| #define SAI_FIFOLR_XFL3_SHIFT 18 |
| #define SAI_FIFOLR_XFL3_MASK GENMASK(23, 18) |
| #define SAI_FIFOLR_XFL2_SHIFT 12 |
| #define SAI_FIFOLR_XFL2_MASK GENMASK(17, 12) |
| #define SAI_FIFOLR_XFL1_SHIFT 6 |
| #define SAI_FIFOLR_XFL1_MASK GENMASK(11, 6) |
| #define SAI_FIFOLR_XFL0_SHIFT 0 |
| #define SAI_FIFOLR_XFL0_MASK GENMASK(5, 0) |
| |
| /* STATUS Status Register (VERSION >= SAI_VER_2307) */ |
| #define SAI_STATUS_RX_IDLE BIT(3) |
| #define SAI_STATUS_TX_IDLE BIT(2) |
| #define SAI_STATUS_FS_IDLE BIT(1) |
| |
| /* VERSION */ |
| /* |
| * Updates: |
| * |
| * VERSION >= SAI_VER_2311 |
| * |
| * Support Frame Sync xN (FSXN) |
| * Support Frame Sync Error Detect (FSE) |
| * Support Frame Sync Lost Detect (FSLOST) |
| * Support Force Clear (FCR) |
| * Support SAIn-Chained (e.g. SAI0-CLK-DATA + SAI3-DATA +...) |
| * Support Transmit Auto Gate Mode |
| * Support Timing Shift Left for TX |
| * |
| * Optimize SCLK/FSYNC Timing Alignment |
| * |
| * VERSION >= SAI_VER_2403 |
| * |
| * Support Loopback LR Select (e.g. L:MIC R:LP) |
| * |
| */ |
| #define SAI_VER_2307 0x23073576 |
| #define SAI_VER_2311 0x23112118 |
| #define SAI_VER_2401 0x24013506 |
| #define SAI_VER_2403 0x24031103 |
| |
| /* FS_TIMEOUT: Frame Sync Timeout Register */ |
| #define SAI_FS_TIMEOUT_VAL_MASK GENMASK(31, 1) |
| #define SAI_FS_TIMEOUT_VAL(x) ((x) << 1) |
| #define SAI_FS_TIMEOUT_EN_MASK BIT(0) |
| #define SAI_FS_TIMEOUT_EN(x) ((x) << 0) |
| |
| /* SAI Registers */ |
| #define SAI_TXCR (0x0000) |
| #define SAI_FSCR (0x0004) |
| #define SAI_RXCR (0x0008) |
| #define SAI_MONO_CR (0x000c) |
| #define SAI_XFER (0x0010) |
| #define SAI_CLR (0x0014) |
| #define SAI_CKR (0x0018) |
| #define SAI_TXFIFOLR (0x001c) |
| #define SAI_RXFIFOLR (0x0020) |
| #define SAI_DMACR (0x0024) |
| #define SAI_INTCR (0x0028) |
| #define SAI_INTSR (0x002c) |
| #define SAI_TXDR (0x0030) |
| #define SAI_RXDR (0x0034) |
| #define SAI_PATH_SEL (0x0038) |
| #define SAI_TX_SLOT_MASK0 (0x003c) |
| #define SAI_TX_SLOT_MASK1 (0x0040) |
| #define SAI_TX_SLOT_MASK2 (0x0044) |
| #define SAI_TX_SLOT_MASK3 (0x0048) |
| #define SAI_RX_SLOT_MASK0 (0x004c) |
| #define SAI_RX_SLOT_MASK1 (0x0050) |
| #define SAI_RX_SLOT_MASK2 (0x0054) |
| #define SAI_RX_SLOT_MASK3 (0x0058) |
| #define SAI_TX_DATA_CNT (0x005c) |
| #define SAI_RX_DATA_CNT (0x0060) |
| #define SAI_TX_SHIFT (0x0064) |
| #define SAI_RX_SHIFT (0x0068) |
| #define SAI_STATUS (0x006c) |
| #define SAI_VERSION (0x0070) |
| #define SAI_FSXN (0x0074) |
| #define SAI_FS_TIMEOUT (0x0078) |
| #define SAI_LOOPBACK_LR (0x007c) |
| |
| #endif /* _ROCKCHIP_SAI_H */ |