1ca2cd6bcSanish kumar /* 2ca2cd6bcSanish kumar * max98371.h -- MAX98371 ALSA SoC Audio driver 3ca2cd6bcSanish kumar * 4ca2cd6bcSanish kumar * Copyright 2011-2012 Maxim Integrated Products 5ca2cd6bcSanish kumar * 6ca2cd6bcSanish kumar * This program is free software; you can redistribute it and/or modify 7ca2cd6bcSanish kumar * it under the terms of the GNU General Public License version 2 as 8ca2cd6bcSanish kumar * published by the Free Software Foundation. 9ca2cd6bcSanish kumar */ 10ca2cd6bcSanish kumar 11ca2cd6bcSanish kumar #ifndef _MAX98371_H 12ca2cd6bcSanish kumar #define _MAX98371_H 13ca2cd6bcSanish kumar 14ca2cd6bcSanish kumar #define MAX98371_IRQ_CLEAR1 0x01 15ca2cd6bcSanish kumar #define MAX98371_IRQ_CLEAR2 0x02 16ca2cd6bcSanish kumar #define MAX98371_IRQ_CLEAR3 0x03 17ca2cd6bcSanish kumar #define MAX98371_DAI_CLK 0x10 18ca2cd6bcSanish kumar #define MAX98371_DAI_BSEL_MASK 0xF 19ca2cd6bcSanish kumar #define MAX98371_DAI_BSEL_32 2 20ca2cd6bcSanish kumar #define MAX98371_DAI_BSEL_48 3 21ca2cd6bcSanish kumar #define MAX98371_DAI_BSEL_64 4 22ca2cd6bcSanish kumar #define MAX98371_SPK_SR 0x11 23ca2cd6bcSanish kumar #define MAX98371_SPK_SR_MASK 0xF 24ca2cd6bcSanish kumar #define MAX98371_SPK_SR_32 6 25ca2cd6bcSanish kumar #define MAX98371_SPK_SR_44 7 26ca2cd6bcSanish kumar #define MAX98371_SPK_SR_48 8 27ca2cd6bcSanish kumar #define MAX98371_SPK_SR_88 10 28ca2cd6bcSanish kumar #define MAX98371_SPK_SR_96 11 29ca2cd6bcSanish kumar #define MAX98371_DAI_CHANNEL 0x15 30ca2cd6bcSanish kumar #define MAX98371_CHANNEL_MASK 0x3 31ca2cd6bcSanish kumar #define MAX98371_MONOMIX_SRC 0x18 32ca2cd6bcSanish kumar #define MAX98371_MONOMIX_CFG 0x19 33ca2cd6bcSanish kumar #define MAX98371_HPF 0x1C 34ca2cd6bcSanish kumar #define MAX98371_MONOMIX_SRC_MASK 0xFF 35ca2cd6bcSanish kumar #define MONOMIX_RX_0_1 ((0x1)<<(4)) 36ca2cd6bcSanish kumar #define M98371_DAI_CHANNEL_I2S 0x3 37ca2cd6bcSanish kumar #define MAX98371_DIGITAL_GAIN 0x2D 38ca2cd6bcSanish kumar #define MAX98371_DIGITAL_GAIN_WIDTH 0x7 39ca2cd6bcSanish kumar #define MAX98371_GAIN 0x2E 40ca2cd6bcSanish kumar #define MAX98371_GAIN_SHIFT 0x4 41ca2cd6bcSanish kumar #define MAX98371_GAIN_WIDTH 0x4 42ca2cd6bcSanish kumar #define MAX98371_DHT_MAX_WIDTH 4 43ca2cd6bcSanish kumar #define MAX98371_FMT 0x14 44ca2cd6bcSanish kumar #define MAX98371_CHANSZ_WIDTH 6 45ca2cd6bcSanish kumar #define MAX98371_FMT_MASK ((0x3)<<(MAX98371_CHANSZ_WIDTH)) 46ca2cd6bcSanish kumar #define MAX98371_FMT_MODE_MASK ((0x7)<<(3)) 47ca2cd6bcSanish kumar #define MAX98371_DAI_LEFT ((0x1)<<(3)) 48ca2cd6bcSanish kumar #define MAX98371_DAI_RIGHT ((0x2)<<(3)) 49ca2cd6bcSanish kumar #define MAX98371_DAI_CHANSZ_16 ((1)<<(MAX98371_CHANSZ_WIDTH)) 50ca2cd6bcSanish kumar #define MAX98371_DAI_CHANSZ_24 ((2)<<(MAX98371_CHANSZ_WIDTH)) 51ca2cd6bcSanish kumar #define MAX98371_DAI_CHANSZ_32 ((3)<<(MAX98371_CHANSZ_WIDTH)) 52ca2cd6bcSanish kumar #define MAX98371_DHT 0x32 53ca2cd6bcSanish kumar #define MAX98371_DHT_STEP 0x3 54ca2cd6bcSanish kumar #define MAX98371_DHT_GAIN 0x31 55ca2cd6bcSanish kumar #define MAX98371_DHT_GAIN_WIDTH 0x4 56ca2cd6bcSanish kumar #define MAX98371_DHT_ROT_WIDTH 0x4 57ca2cd6bcSanish kumar #define MAX98371_SPK_ENABLE 0x4A 58ca2cd6bcSanish kumar #define MAX98371_GLOBAL_ENABLE 0x50 59ca2cd6bcSanish kumar #define MAX98371_SOFT_RESET 0x51 60ca2cd6bcSanish kumar #define MAX98371_VERSION 0xFF 61ca2cd6bcSanish kumar 62ca2cd6bcSanish kumar 63ca2cd6bcSanish kumar struct max98371_priv { 64ca2cd6bcSanish kumar struct regmap *regmap; 65ca2cd6bcSanish kumar struct snd_soc_codec *codec; 66ca2cd6bcSanish kumar }; 67ca2cd6bcSanish kumar #endif 68