158 lines
7.7 KiB
C
158 lines
7.7 KiB
C
|
/* SPDX-License-Identifier: GPL-2.0 */
|
||
|
/*
|
||
|
* Lochnagar1 register definitions
|
||
|
*
|
||
|
* Copyright (c) 2017-2018 Cirrus Logic, Inc. and
|
||
|
* Cirrus Logic International Semiconductor Ltd.
|
||
|
*
|
||
|
* Author: Charles Keepax <ckeepax@opensource.cirrus.com>
|
||
|
*/
|
||
|
|
||
|
#ifndef LOCHNAGAR1_REGISTERS_H
|
||
|
#define LOCHNAGAR1_REGISTERS_H
|
||
|
|
||
|
/* Register Addresses */
|
||
|
#define LOCHNAGAR1_CDC_AIF1_SEL 0x0008
|
||
|
#define LOCHNAGAR1_CDC_AIF2_SEL 0x0009
|
||
|
#define LOCHNAGAR1_CDC_AIF3_SEL 0x000A
|
||
|
#define LOCHNAGAR1_CDC_MCLK1_SEL 0x000B
|
||
|
#define LOCHNAGAR1_CDC_MCLK2_SEL 0x000C
|
||
|
#define LOCHNAGAR1_CDC_AIF_CTRL1 0x000D
|
||
|
#define LOCHNAGAR1_CDC_AIF_CTRL2 0x000E
|
||
|
#define LOCHNAGAR1_EXT_AIF_CTRL 0x000F
|
||
|
#define LOCHNAGAR1_DSP_AIF1_SEL 0x0010
|
||
|
#define LOCHNAGAR1_DSP_AIF2_SEL 0x0011
|
||
|
#define LOCHNAGAR1_DSP_CLKIN_SEL 0x0012
|
||
|
#define LOCHNAGAR1_DSP_AIF 0x0013
|
||
|
#define LOCHNAGAR1_GF_AIF1 0x0014
|
||
|
#define LOCHNAGAR1_GF_AIF2 0x0015
|
||
|
#define LOCHNAGAR1_PSIA_AIF 0x0016
|
||
|
#define LOCHNAGAR1_PSIA1_SEL 0x0017
|
||
|
#define LOCHNAGAR1_PSIA2_SEL 0x0018
|
||
|
#define LOCHNAGAR1_SPDIF_AIF_SEL 0x0019
|
||
|
#define LOCHNAGAR1_GF_AIF3_SEL 0x001C
|
||
|
#define LOCHNAGAR1_GF_AIF4_SEL 0x001D
|
||
|
#define LOCHNAGAR1_GF_CLKOUT1_SEL 0x001E
|
||
|
#define LOCHNAGAR1_GF_AIF1_SEL 0x001F
|
||
|
#define LOCHNAGAR1_GF_AIF2_SEL 0x0020
|
||
|
#define LOCHNAGAR1_GF_GPIO2 0x0026
|
||
|
#define LOCHNAGAR1_GF_GPIO3 0x0027
|
||
|
#define LOCHNAGAR1_GF_GPIO7 0x0028
|
||
|
#define LOCHNAGAR1_RST 0x0029
|
||
|
#define LOCHNAGAR1_LED1 0x002A
|
||
|
#define LOCHNAGAR1_LED2 0x002B
|
||
|
#define LOCHNAGAR1_I2C_CTRL 0x0046
|
||
|
|
||
|
/*
|
||
|
* (0x0008 - 0x000C, 0x0010 - 0x0012, 0x0017 - 0x0020)
|
||
|
* CDC_AIF1_SEL - GF_AIF2_SEL
|
||
|
*/
|
||
|
#define LOCHNAGAR1_SRC_MASK 0xFF
|
||
|
#define LOCHNAGAR1_SRC_SHIFT 0
|
||
|
|
||
|
/* (0x000D) CDC_AIF_CTRL1 */
|
||
|
#define LOCHNAGAR1_CDC_AIF2_LRCLK_DIR_MASK 0x40
|
||
|
#define LOCHNAGAR1_CDC_AIF2_LRCLK_DIR_SHIFT 6
|
||
|
#define LOCHNAGAR1_CDC_AIF2_BCLK_DIR_MASK 0x20
|
||
|
#define LOCHNAGAR1_CDC_AIF2_BCLK_DIR_SHIFT 5
|
||
|
#define LOCHNAGAR1_CDC_AIF2_ENA_MASK 0x10
|
||
|
#define LOCHNAGAR1_CDC_AIF2_ENA_SHIFT 4
|
||
|
#define LOCHNAGAR1_CDC_AIF1_LRCLK_DIR_MASK 0x04
|
||
|
#define LOCHNAGAR1_CDC_AIF1_LRCLK_DIR_SHIFT 2
|
||
|
#define LOCHNAGAR1_CDC_AIF1_BCLK_DIR_MASK 0x02
|
||
|
#define LOCHNAGAR1_CDC_AIF1_BCLK_DIR_SHIFT 1
|
||
|
#define LOCHNAGAR1_CDC_AIF1_ENA_MASK 0x01
|
||
|
#define LOCHNAGAR1_CDC_AIF1_ENA_SHIFT 0
|
||
|
|
||
|
/* (0x000E) CDC_AIF_CTRL2 */
|
||
|
#define LOCHNAGAR1_CDC_AIF3_LRCLK_DIR_MASK 0x40
|
||
|
#define LOCHNAGAR1_CDC_AIF3_LRCLK_DIR_SHIFT 6
|
||
|
#define LOCHNAGAR1_CDC_AIF3_BCLK_DIR_MASK 0x20
|
||
|
#define LOCHNAGAR1_CDC_AIF3_BCLK_DIR_SHIFT 5
|
||
|
#define LOCHNAGAR1_CDC_AIF3_ENA_MASK 0x10
|
||
|
#define LOCHNAGAR1_CDC_AIF3_ENA_SHIFT 4
|
||
|
#define LOCHNAGAR1_CDC_MCLK1_ENA_MASK 0x02
|
||
|
#define LOCHNAGAR1_CDC_MCLK1_ENA_SHIFT 1
|
||
|
#define LOCHNAGAR1_CDC_MCLK2_ENA_MASK 0x01
|
||
|
#define LOCHNAGAR1_CDC_MCLK2_ENA_SHIFT 0
|
||
|
|
||
|
/* (0x000F) EXT_AIF_CTRL */
|
||
|
#define LOCHNAGAR1_SPDIF_AIF_LRCLK_DIR_MASK 0x20
|
||
|
#define LOCHNAGAR1_SPDIF_AIF_LRCLK_DIR_SHIFT 5
|
||
|
#define LOCHNAGAR1_SPDIF_AIF_BCLK_DIR_MASK 0x10
|
||
|
#define LOCHNAGAR1_SPDIF_AIF_BCLK_DIR_SHIFT 4
|
||
|
#define LOCHNAGAR1_SPDIF_AIF_ENA_MASK 0x08
|
||
|
#define LOCHNAGAR1_SPDIF_AIF_ENA_SHIFT 3
|
||
|
|
||
|
/* (0x0013) DSP_AIF */
|
||
|
#define LOCHNAGAR1_DSP_AIF2_LRCLK_DIR_MASK 0x40
|
||
|
#define LOCHNAGAR1_DSP_AIF2_LRCLK_DIR_SHIFT 6
|
||
|
#define LOCHNAGAR1_DSP_AIF2_BCLK_DIR_MASK 0x20
|
||
|
#define LOCHNAGAR1_DSP_AIF2_BCLK_DIR_SHIFT 5
|
||
|
#define LOCHNAGAR1_DSP_AIF2_ENA_MASK 0x10
|
||
|
#define LOCHNAGAR1_DSP_AIF2_ENA_SHIFT 4
|
||
|
#define LOCHNAGAR1_DSP_CLKIN_ENA_MASK 0x08
|
||
|
#define LOCHNAGAR1_DSP_CLKIN_ENA_SHIFT 3
|
||
|
#define LOCHNAGAR1_DSP_AIF1_LRCLK_DIR_MASK 0x04
|
||
|
#define LOCHNAGAR1_DSP_AIF1_LRCLK_DIR_SHIFT 2
|
||
|
#define LOCHNAGAR1_DSP_AIF1_BCLK_DIR_MASK 0x02
|
||
|
#define LOCHNAGAR1_DSP_AIF1_BCLK_DIR_SHIFT 1
|
||
|
#define LOCHNAGAR1_DSP_AIF1_ENA_MASK 0x01
|
||
|
#define LOCHNAGAR1_DSP_AIF1_ENA_SHIFT 0
|
||
|
|
||
|
/* (0x0014) GF_AIF1 */
|
||
|
#define LOCHNAGAR1_GF_CLKOUT1_ENA_MASK 0x40
|
||
|
#define LOCHNAGAR1_GF_CLKOUT1_ENA_SHIFT 6
|
||
|
#define LOCHNAGAR1_GF_AIF3_LRCLK_DIR_MASK 0x20
|
||
|
#define LOCHNAGAR1_GF_AIF3_LRCLK_DIR_SHIFT 5
|
||
|
#define LOCHNAGAR1_GF_AIF3_BCLK_DIR_MASK 0x10
|
||
|
#define LOCHNAGAR1_GF_AIF3_BCLK_DIR_SHIFT 4
|
||
|
#define LOCHNAGAR1_GF_AIF3_ENA_MASK 0x08
|
||
|
#define LOCHNAGAR1_GF_AIF3_ENA_SHIFT 3
|
||
|
#define LOCHNAGAR1_GF_AIF1_LRCLK_DIR_MASK 0x04
|
||
|
#define LOCHNAGAR1_GF_AIF1_LRCLK_DIR_SHIFT 2
|
||
|
#define LOCHNAGAR1_GF_AIF1_BCLK_DIR_MASK 0x02
|
||
|
#define LOCHNAGAR1_GF_AIF1_BCLK_DIR_SHIFT 1
|
||
|
#define LOCHNAGAR1_GF_AIF1_ENA_MASK 0x01
|
||
|
#define LOCHNAGAR1_GF_AIF1_ENA_SHIFT 0
|
||
|
|
||
|
/* (0x0015) GF_AIF2 */
|
||
|
#define LOCHNAGAR1_GF_AIF4_LRCLK_DIR_MASK 0x20
|
||
|
#define LOCHNAGAR1_GF_AIF4_LRCLK_DIR_SHIFT 5
|
||
|
#define LOCHNAGAR1_GF_AIF4_BCLK_DIR_MASK 0x10
|
||
|
#define LOCHNAGAR1_GF_AIF4_BCLK_DIR_SHIFT 4
|
||
|
#define LOCHNAGAR1_GF_AIF4_ENA_MASK 0x08
|
||
|
#define LOCHNAGAR1_GF_AIF4_ENA_SHIFT 3
|
||
|
#define LOCHNAGAR1_GF_AIF2_LRCLK_DIR_MASK 0x04
|
||
|
#define LOCHNAGAR1_GF_AIF2_LRCLK_DIR_SHIFT 2
|
||
|
#define LOCHNAGAR1_GF_AIF2_BCLK_DIR_MASK 0x02
|
||
|
#define LOCHNAGAR1_GF_AIF2_BCLK_DIR_SHIFT 1
|
||
|
#define LOCHNAGAR1_GF_AIF2_ENA_MASK 0x01
|
||
|
#define LOCHNAGAR1_GF_AIF2_ENA_SHIFT 0
|
||
|
|
||
|
/* (0x0016) PSIA_AIF */
|
||
|
#define LOCHNAGAR1_PSIA2_LRCLK_DIR_MASK 0x40
|
||
|
#define LOCHNAGAR1_PSIA2_LRCLK_DIR_SHIFT 6
|
||
|
#define LOCHNAGAR1_PSIA2_BCLK_DIR_MASK 0x20
|
||
|
#define LOCHNAGAR1_PSIA2_BCLK_DIR_SHIFT 5
|
||
|
#define LOCHNAGAR1_PSIA2_ENA_MASK 0x10
|
||
|
#define LOCHNAGAR1_PSIA2_ENA_SHIFT 4
|
||
|
#define LOCHNAGAR1_PSIA1_LRCLK_DIR_MASK 0x04
|
||
|
#define LOCHNAGAR1_PSIA1_LRCLK_DIR_SHIFT 2
|
||
|
#define LOCHNAGAR1_PSIA1_BCLK_DIR_MASK 0x02
|
||
|
#define LOCHNAGAR1_PSIA1_BCLK_DIR_SHIFT 1
|
||
|
#define LOCHNAGAR1_PSIA1_ENA_MASK 0x01
|
||
|
#define LOCHNAGAR1_PSIA1_ENA_SHIFT 0
|
||
|
|
||
|
/* (0x0029) RST */
|
||
|
#define LOCHNAGAR1_DSP_RESET_MASK 0x02
|
||
|
#define LOCHNAGAR1_DSP_RESET_SHIFT 1
|
||
|
#define LOCHNAGAR1_CDC_RESET_MASK 0x01
|
||
|
#define LOCHNAGAR1_CDC_RESET_SHIFT 0
|
||
|
|
||
|
/* (0x0046) I2C_CTRL */
|
||
|
#define LOCHNAGAR1_CDC_CIF_MODE_MASK 0x01
|
||
|
#define LOCHNAGAR1_CDC_CIF_MODE_SHIFT 0
|
||
|
|
||
|
#endif
|