1*7358a803SSameer Pujar /* SPDX-License-Identifier: GPL-2.0-only */ 2*7358a803SSameer Pujar /* 3*7358a803SSameer Pujar * tegra210_ope.h - Definitions for Tegra210 OPE driver 4*7358a803SSameer Pujar * 5*7358a803SSameer Pujar * Copyright (c) 2022, NVIDIA CORPORATION. All rights reserved. 6*7358a803SSameer Pujar * 7*7358a803SSameer Pujar */ 8*7358a803SSameer Pujar 9*7358a803SSameer Pujar #ifndef __TEGRA210_OPE_H__ 10*7358a803SSameer Pujar #define __TEGRA210_OPE_H__ 11*7358a803SSameer Pujar 12*7358a803SSameer Pujar #include <linux/regmap.h> 13*7358a803SSameer Pujar #include <sound/soc.h> 14*7358a803SSameer Pujar 15*7358a803SSameer Pujar #include "tegra210_peq.h" 16*7358a803SSameer Pujar 17*7358a803SSameer Pujar /* 18*7358a803SSameer Pujar * OPE_RX registers are with respect to XBAR. 19*7358a803SSameer Pujar * The data comes from XBAR to OPE 20*7358a803SSameer Pujar */ 21*7358a803SSameer Pujar #define TEGRA210_OPE_RX_STATUS 0xc 22*7358a803SSameer Pujar #define TEGRA210_OPE_RX_INT_STATUS 0x10 23*7358a803SSameer Pujar #define TEGRA210_OPE_RX_INT_MASK 0x14 24*7358a803SSameer Pujar #define TEGRA210_OPE_RX_INT_SET 0x18 25*7358a803SSameer Pujar #define TEGRA210_OPE_RX_INT_CLEAR 0x1c 26*7358a803SSameer Pujar #define TEGRA210_OPE_RX_CIF_CTRL 0x20 27*7358a803SSameer Pujar 28*7358a803SSameer Pujar /* 29*7358a803SSameer Pujar * OPE_TX registers are with respect to XBAR. 30*7358a803SSameer Pujar * The data goes out from OPE to XBAR 31*7358a803SSameer Pujar */ 32*7358a803SSameer Pujar #define TEGRA210_OPE_TX_STATUS 0x4c 33*7358a803SSameer Pujar #define TEGRA210_OPE_TX_INT_STATUS 0x50 34*7358a803SSameer Pujar #define TEGRA210_OPE_TX_INT_MASK 0x54 35*7358a803SSameer Pujar #define TEGRA210_OPE_TX_INT_SET 0x58 36*7358a803SSameer Pujar #define TEGRA210_OPE_TX_INT_CLEAR 0x5c 37*7358a803SSameer Pujar #define TEGRA210_OPE_TX_CIF_CTRL 0x60 38*7358a803SSameer Pujar 39*7358a803SSameer Pujar /* OPE Gloabal registers */ 40*7358a803SSameer Pujar #define TEGRA210_OPE_ENABLE 0x80 41*7358a803SSameer Pujar #define TEGRA210_OPE_SOFT_RESET 0x84 42*7358a803SSameer Pujar #define TEGRA210_OPE_CG 0x88 43*7358a803SSameer Pujar #define TEGRA210_OPE_STATUS 0x8c 44*7358a803SSameer Pujar #define TEGRA210_OPE_INT_STATUS 0x90 45*7358a803SSameer Pujar #define TEGRA210_OPE_DIR 0x94 46*7358a803SSameer Pujar 47*7358a803SSameer Pujar /* Fields for TEGRA210_OPE_ENABLE */ 48*7358a803SSameer Pujar #define TEGRA210_OPE_EN_SHIFT 0 49*7358a803SSameer Pujar #define TEGRA210_OPE_EN (1 << TEGRA210_OPE_EN_SHIFT) 50*7358a803SSameer Pujar 51*7358a803SSameer Pujar /* Fields for TEGRA210_OPE_SOFT_RESET */ 52*7358a803SSameer Pujar #define TEGRA210_OPE_SOFT_RESET_SHIFT 0 53*7358a803SSameer Pujar #define TEGRA210_OPE_SOFT_RESET_EN (1 << TEGRA210_OPE_SOFT_RESET_SHIFT) 54*7358a803SSameer Pujar 55*7358a803SSameer Pujar #define TEGRA210_OPE_DIR_SHIFT 0 56*7358a803SSameer Pujar 57*7358a803SSameer Pujar struct tegra210_ope { 58*7358a803SSameer Pujar struct regmap *regmap; 59*7358a803SSameer Pujar struct regmap *peq_regmap; 60*7358a803SSameer Pujar struct regmap *mbdrc_regmap; 61*7358a803SSameer Pujar u32 peq_biquad_gains[TEGRA210_PEQ_GAIN_PARAM_SIZE_PER_CH]; 62*7358a803SSameer Pujar u32 peq_biquad_shifts[TEGRA210_PEQ_SHIFT_PARAM_SIZE_PER_CH]; 63*7358a803SSameer Pujar unsigned int data_dir; 64*7358a803SSameer Pujar }; 65*7358a803SSameer Pujar 66*7358a803SSameer Pujar /* Extension of soc_bytes structure defined in sound/soc.h */ 67*7358a803SSameer Pujar struct tegra_soc_bytes { 68*7358a803SSameer Pujar struct soc_bytes soc; 69*7358a803SSameer Pujar u32 shift; /* Used as offset for AHUB RAM related programing */ 70*7358a803SSameer Pujar }; 71*7358a803SSameer Pujar 72*7358a803SSameer Pujar /* Utility structures for using mixer control of type snd_soc_bytes */ 73*7358a803SSameer Pujar #define TEGRA_SOC_BYTES_EXT(xname, xbase, xregs, xshift, xmask, \ 74*7358a803SSameer Pujar xhandler_get, xhandler_put, xinfo) \ 75*7358a803SSameer Pujar { \ 76*7358a803SSameer Pujar .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \ 77*7358a803SSameer Pujar .name = xname, \ 78*7358a803SSameer Pujar .info = xinfo, \ 79*7358a803SSameer Pujar .get = xhandler_get, \ 80*7358a803SSameer Pujar .put = xhandler_put, \ 81*7358a803SSameer Pujar .private_value = ((unsigned long)&(struct tegra_soc_bytes) \ 82*7358a803SSameer Pujar { \ 83*7358a803SSameer Pujar .soc.base = xbase, \ 84*7358a803SSameer Pujar .soc.num_regs = xregs, \ 85*7358a803SSameer Pujar .soc.mask = xmask, \ 86*7358a803SSameer Pujar .shift = xshift \ 87*7358a803SSameer Pujar }) \ 88*7358a803SSameer Pujar } 89*7358a803SSameer Pujar 90*7358a803SSameer Pujar #endif 91