/* 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) (0 x3 << 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) (0 x3 << 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 0 x23073576
#define SAI_VER_2311 0 x23112118
#define SAI_VER_2401 0 x24013506
#define SAI_VER_2403 0 x24031103
/* 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 (0 x0000)
#define SAI_FSCR (0 x0004)
#define SAI_RXCR (0 x0008)
#define SAI_MONO_CR (0 x000c)
#define SAI_XFER (0 x0010)
#define SAI_CLR (0 x0014)
#define SAI_CKR (0 x0018)
#define SAI_TXFIFOLR (0 x001c)
#define SAI_RXFIFOLR (0 x0020)
#define SAI_DMACR (0 x0024)
#define SAI_INTCR (0 x0028)
#define SAI_INTSR (0 x002c)
#define SAI_TXDR (0 x0030)
#define SAI_RXDR (0 x0034)
#define SAI_PATH_SEL (0 x0038)
#define SAI_TX_SLOT_MASK0 (0 x003c)
#define SAI_TX_SLOT_MASK1 (0 x0040)
#define SAI_TX_SLOT_MASK2 (0 x0044)
#define SAI_TX_SLOT_MASK3 (0 x0048)
#define SAI_RX_SLOT_MASK0 (0 x004c)
#define SAI_RX_SLOT_MASK1 (0 x0050)
#define SAI_RX_SLOT_MASK2 (0 x0054)
#define SAI_RX_SLOT_MASK3 (0 x0058)
#define SAI_TX_DATA_CNT (0 x005c)
#define SAI_RX_DATA_CNT (0 x0060)
#define SAI_TX_SHIFT (0 x0064)
#define SAI_RX_SHIFT (0 x0068)
#define SAI_STATUS (0 x006c)
#define SAI_VERSION (0 x0070)
#define SAI_FSXN (0 x0074)
#define SAI_FS_TIMEOUT (0 x0078)
#define SAI_LOOPBACK_LR (0 x007c)
#endif /* _ROCKCHIP_SAI_H */
Messung V0.5 in Prozent C=98 H=97 G=97
¤ Dauer der Verarbeitung: 0.10 Sekunden
(vorverarbeitet am 2026-06-07)
¤
*© Formatika GbR, Deutschland