root/sound/soc/rockchip/rockchip_spdif.h
/* SPDX-License-Identifier: GPL-2.0-only */
/*
 * ALSA SoC Audio Layer - Rockchip SPDIF transceiver driver
 *
 * Copyright (c) 2015-2026 Collabora Ltd.
 * Author: Sjoerd Simons <sjoerd.simons@collabora.co.uk>
 */

#ifndef _ROCKCHIP_SPDIF_H
#define _ROCKCHIP_SPDIF_H

/*
 * CFGR
 * transfer configuration register
*/
#define SPDIF_CFGR_CLK_DIV_MASK         GENMASK(23, 16)
#define SPDIF_CFGR_CLK_DIV(x)           FIELD_PREP(SPDIF_CFGR_CLK_DIV_MASK, x-1)

#define SPDIF_CFGR_CLR_MASK             BIT(7)
#define SPDIF_CFGR_CLR_EN               FIELD_PREP(SPDIF_CFGR_CLR_MASK, 1)
#define SPDIF_CFGR_CLR_DIS              FIELD_PREP(SPDIF_CFGR_CLR_MASK, 0)

#define SPDIF_CFGR_CSE_MASK             BIT(6)
#define SPDIF_CFGR_CSE_EN               FIELD_PREP(SPDIF_CFGR_CSE_MASK, 1)
#define SPDIF_CFGR_CSE_DIS              FIELD_PREP(SPDIF_CFGR_CSE_MASK, 0)

#define SPDIF_CFGR_ADJ_MASK             BIT(3)
#define SPDIF_CFGR_ADJ_LEFT_J           FIELD_PREP(SPDIF_CFGR_ADJ_MASK, 1)
#define SPDIF_CFGR_ADJ_RIGHT_J          FIELD_PREP(SPDIF_CFGR_ADJ_MASK, 0)

#define SPDIF_CFGR_HALFWORD_MASK        BIT(2)
#define SPDIF_CFGR_HALFWORD_DISABLE     FIELD_PREP(SPDIF_CFGR_HALFWORD_MASK, 0)
#define SPDIF_CFGR_HALFWORD_ENABLE      FIELD_PREP(SPDIF_CFGR_HALFWORD_MASK, 1)

#define SDPIF_CFGR_VDW_MASK             GENMASK(1, 0)
#define SPDIF_CFGR_VDW(x)               FIELD_PREP(SDPIF_CFGR_VDW_MASK, x)

#define SPDIF_CFGR_VDW_16               SPDIF_CFGR_VDW(0x0)
#define SPDIF_CFGR_VDW_20               SPDIF_CFGR_VDW(0x1)
#define SPDIF_CFGR_VDW_24               SPDIF_CFGR_VDW(0x2)

/*
 * DMACR
 * DMA control register
*/
#define SPDIF_DMACR_TDE_MASK            BIT(5)
#define SPDIF_DMACR_TDE_DISABLE         FIELD_PREP(SPDIF_DMACR_TDE_MASK, 0)
#define SPDIF_DMACR_TDE_ENABLE          FIELD_PREP(SPDIF_DMACR_TDE_MASK, 1)

#define SPDIF_DMACR_TDL_MASK            GENMASK(4, 0)
#define SPDIF_DMACR_TDL(x)              FIELD_PREP(SPDIF_DMACR_TDL_MASK, x)

/*
 * XFER
 * Transfer control register
*/
#define SPDIF_XFER_TXS_MASK             BIT(0)
#define SPDIF_XFER_TXS_STOP             FIELD_PREP(SPDIF_XFER_TXS_MASK, 0)
#define SPDIF_XFER_TXS_START            FIELD_PREP(SPDIF_XFER_TXS_MASK, 1)

#define SPDIF_CFGR      (0x0000)
#define SPDIF_SDBLR     (0x0004)
#define SPDIF_DMACR     (0x0008)
#define SPDIF_INTCR     (0x000c)
#define SPDIF_INTSR     (0x0010)
#define SPDIF_XFER      (0x0018)
#define SPDIF_SMPDR     (0x0020)
#define SPDIF_VLDFRn(x) (0x0060 + (x) * 4)
#define SPDIF_USRDRn(x) (0x0090 + (x) * 4)
#define SPDIF_CHNSRn(x) (0x00c0 + (x) * 4)
#define SPDIF_VERSION   (0x01c0)

#endif /* _ROCKCHIP_SPDIF_H */