1/* 2 * wm8400 private definitions. 3 * 4 * Copyright 2008 Wolfson Microelectronics plc 5 * 6 * This program is free software; you can redistribute it and/or modify 7 * it under the terms of the GNU General Public License as published by 8 * the Free Software Foundation; either version 2 of the License, or 9 * (at your option) any later version. 10 * 11 * This program is distributed in the hope that it will be useful, 12 * but WITHOUT ANY WARRANTY; without even the implied warranty of 13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 14 * GNU General Public License for more details. 15 * 16 * You should have received a copy of the GNU General Public License 17 * along with this program; if not, write to the Free Software 18 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. 19 */ 20 21#ifndef __LINUX_MFD_WM8400_PRIV_H 22#define __LINUX_MFD_WM8400_PRIV_H 23 24#include <linux/mfd/wm8400.h> 25#include <linux/mutex.h> 26#include <linux/platform_device.h> 27#include <linux/regmap.h> 28 29#define WM8400_REGISTER_COUNT 0x55 30 31struct wm8400 { 32 struct device *dev; 33 struct regmap *regmap; 34 35 struct platform_device regulators[6]; 36}; 37 38/* 39 * Register values. 40 */ 41#define WM8400_RESET_ID 0x00 42#define WM8400_ID 0x01 43#define WM8400_POWER_MANAGEMENT_1 0x02 44#define WM8400_POWER_MANAGEMENT_2 0x03 45#define WM8400_POWER_MANAGEMENT_3 0x04 46#define WM8400_AUDIO_INTERFACE_1 0x05 47#define WM8400_AUDIO_INTERFACE_2 0x06 48#define WM8400_CLOCKING_1 0x07 49#define WM8400_CLOCKING_2 0x08 50#define WM8400_AUDIO_INTERFACE_3 0x09 51#define WM8400_AUDIO_INTERFACE_4 0x0A 52#define WM8400_DAC_CTRL 0x0B 53#define WM8400_LEFT_DAC_DIGITAL_VOLUME 0x0C 54#define WM8400_RIGHT_DAC_DIGITAL_VOLUME 0x0D 55#define WM8400_DIGITAL_SIDE_TONE 0x0E 56#define WM8400_ADC_CTRL 0x0F 57#define WM8400_LEFT_ADC_DIGITAL_VOLUME 0x10 58#define WM8400_RIGHT_ADC_DIGITAL_VOLUME 0x11 59#define WM8400_GPIO_CTRL_1 0x12 60#define WM8400_GPIO1_GPIO2 0x13 61#define WM8400_GPIO3_GPIO4 0x14 62#define WM8400_GPIO5_GPIO6 0x15 63#define WM8400_GPIOCTRL_2 0x16 64#define WM8400_GPIO_POL 0x17 65#define WM8400_LEFT_LINE_INPUT_1_2_VOLUME 0x18 66#define WM8400_LEFT_LINE_INPUT_3_4_VOLUME 0x19 67#define WM8400_RIGHT_LINE_INPUT_1_2_VOLUME 0x1A 68#define WM8400_RIGHT_LINE_INPUT_3_4_VOLUME 0x1B 69#define WM8400_LEFT_OUTPUT_VOLUME 0x1C 70#define WM8400_RIGHT_OUTPUT_VOLUME 0x1D 71#define WM8400_LINE_OUTPUTS_VOLUME 0x1E 72#define WM8400_OUT3_4_VOLUME 0x1F 73#define WM8400_LEFT_OPGA_VOLUME 0x20 74#define WM8400_RIGHT_OPGA_VOLUME 0x21 75#define WM8400_SPEAKER_VOLUME 0x22 76#define WM8400_CLASSD1 0x23 77#define WM8400_CLASSD3 0x25 78#define WM8400_INPUT_MIXER1 0x27 79#define WM8400_INPUT_MIXER2 0x28 80#define WM8400_INPUT_MIXER3 0x29 81#define WM8400_INPUT_MIXER4 0x2A 82#define WM8400_INPUT_MIXER5 0x2B 83#define WM8400_INPUT_MIXER6 0x2C 84#define WM8400_OUTPUT_MIXER1 0x2D 85#define WM8400_OUTPUT_MIXER2 0x2E 86#define WM8400_OUTPUT_MIXER3 0x2F 87#define WM8400_OUTPUT_MIXER4 0x30 88#define WM8400_OUTPUT_MIXER5 0x31 89#define WM8400_OUTPUT_MIXER6 0x32 90#define WM8400_OUT3_4_MIXER 0x33 91#define WM8400_LINE_MIXER1 0x34 92#define WM8400_LINE_MIXER2 0x35 93#define WM8400_SPEAKER_MIXER 0x36 94#define WM8400_ADDITIONAL_CONTROL 0x37 95#define WM8400_ANTIPOP1 0x38 96#define WM8400_ANTIPOP2 0x39 97#define WM8400_MICBIAS 0x3A 98#define WM8400_FLL_CONTROL_1 0x3C 99#define WM8400_FLL_CONTROL_2 0x3D 100#define WM8400_FLL_CONTROL_3 0x3E 101#define WM8400_FLL_CONTROL_4 0x3F 102#define WM8400_LDO1_CONTROL 0x41 103#define WM8400_LDO2_CONTROL 0x42 104#define WM8400_LDO3_CONTROL 0x43 105#define WM8400_LDO4_CONTROL 0x44 106#define WM8400_DCDC1_CONTROL_1 0x46 107#define WM8400_DCDC1_CONTROL_2 0x47 108#define WM8400_DCDC2_CONTROL_1 0x48 109#define WM8400_DCDC2_CONTROL_2 0x49 110#define WM8400_INTERFACE 0x4B 111#define WM8400_PM_GENERAL 0x4C 112#define WM8400_PM_SHUTDOWN_CONTROL 0x4E 113#define WM8400_INTERRUPT_STATUS_1 0x4F 114#define WM8400_INTERRUPT_STATUS_1_MASK 0x50 115#define WM8400_INTERRUPT_LEVELS 0x51 116#define WM8400_SHUTDOWN_REASON 0x52 117#define WM8400_LINE_CIRCUITS 0x54 118 119/* 120 * Field Definitions. 121 */ 122 123/* 124 * R0 (0x00) - Reset/ID 125 */ 126#define WM8400_SW_RESET_CHIP_ID_MASK 0xFFFF /* SW_RESET/CHIP_ID - [15:0] */ 127#define WM8400_SW_RESET_CHIP_ID_SHIFT 0 /* SW_RESET/CHIP_ID - [15:0] */ 128#define WM8400_SW_RESET_CHIP_ID_WIDTH 16 /* SW_RESET/CHIP_ID - [15:0] */ 129 130/* 131 * R1 (0x01) - ID 132 */ 133#define WM8400_CHIP_REV_MASK 0x7000 /* CHIP_REV - [14:12] */ 134#define WM8400_CHIP_REV_SHIFT 12 /* CHIP_REV - [14:12] */ 135#define WM8400_CHIP_REV_WIDTH 3 /* CHIP_REV - [14:12] */ 136 137/* 138 * R18 (0x12) - GPIO CTRL 1 139 */ 140#define WM8400_IRQ 0x1000 /* IRQ */ 141#define WM8400_IRQ_MASK 0x1000 /* IRQ */ 142#define WM8400_IRQ_SHIFT 12 /* IRQ */ 143#define WM8400_IRQ_WIDTH 1 /* IRQ */ 144#define WM8400_TEMPOK 0x0800 /* TEMPOK */ 145#define WM8400_TEMPOK_MASK 0x0800 /* TEMPOK */ 146#define WM8400_TEMPOK_SHIFT 11 /* TEMPOK */ 147#define WM8400_TEMPOK_WIDTH 1 /* TEMPOK */ 148#define WM8400_MIC1SHRT 0x0400 /* MIC1SHRT */ 149#define WM8400_MIC1SHRT_MASK 0x0400 /* MIC1SHRT */ 150#define WM8400_MIC1SHRT_SHIFT 10 /* MIC1SHRT */ 151#define WM8400_MIC1SHRT_WIDTH 1 /* MIC1SHRT */ 152#define WM8400_MIC1DET 0x0200 /* MIC1DET */ 153#define WM8400_MIC1DET_MASK 0x0200 /* MIC1DET */ 154#define WM8400_MIC1DET_SHIFT 9 /* MIC1DET */ 155#define WM8400_MIC1DET_WIDTH 1 /* MIC1DET */ 156#define WM8400_FLL_LCK 0x0100 /* FLL_LCK */ 157#define WM8400_FLL_LCK_MASK 0x0100 /* FLL_LCK */ 158#define WM8400_FLL_LCK_SHIFT 8 /* FLL_LCK */ 159#define WM8400_FLL_LCK_WIDTH 1 /* FLL_LCK */ 160#define WM8400_GPIO_STATUS_MASK 0x00FF /* GPIO_STATUS - [7:0] */ 161#define WM8400_GPIO_STATUS_SHIFT 0 /* GPIO_STATUS - [7:0] */ 162#define WM8400_GPIO_STATUS_WIDTH 8 /* GPIO_STATUS - [7:0] */ 163 164/* 165 * R19 (0x13) - GPIO1 & GPIO2 166 */ 167#define WM8400_GPIO2_DEB_ENA 0x8000 /* GPIO2_DEB_ENA */ 168#define WM8400_GPIO2_DEB_ENA_MASK 0x8000 /* GPIO2_DEB_ENA */ 169#define WM8400_GPIO2_DEB_ENA_SHIFT 15 /* GPIO2_DEB_ENA */ 170#define WM8400_GPIO2_DEB_ENA_WIDTH 1 /* GPIO2_DEB_ENA */ 171#define WM8400_GPIO2_IRQ_ENA 0x4000 /* GPIO2_IRQ_ENA */ 172#define WM8400_GPIO2_IRQ_ENA_MASK 0x4000 /* GPIO2_IRQ_ENA */ 173#define WM8400_GPIO2_IRQ_ENA_SHIFT 14 /* GPIO2_IRQ_ENA */ 174#define WM8400_GPIO2_IRQ_ENA_WIDTH 1 /* GPIO2_IRQ_ENA */ 175#define WM8400_GPIO2_PU 0x2000 /* GPIO2_PU */ 176#define WM8400_GPIO2_PU_MASK 0x2000 /* GPIO2_PU */ 177#define WM8400_GPIO2_PU_SHIFT 13 /* GPIO2_PU */ 178#define WM8400_GPIO2_PU_WIDTH 1 /* GPIO2_PU */ 179#define WM8400_GPIO2_PD 0x1000 /* GPIO2_PD */ 180#define WM8400_GPIO2_PD_MASK 0x1000 /* GPIO2_PD */ 181#define WM8400_GPIO2_PD_SHIFT 12 /* GPIO2_PD */ 182#define WM8400_GPIO2_PD_WIDTH 1 /* GPIO2_PD */ 183#define WM8400_GPIO2_SEL_MASK 0x0F00 /* GPIO2_SEL - [11:8] */ 184#define WM8400_GPIO2_SEL_SHIFT 8 /* GPIO2_SEL - [11:8] */ 185#define WM8400_GPIO2_SEL_WIDTH 4 /* GPIO2_SEL - [11:8] */ 186#define WM8400_GPIO1_DEB_ENA 0x0080 /* GPIO1_DEB_ENA */ 187#define WM8400_GPIO1_DEB_ENA_MASK 0x0080 /* GPIO1_DEB_ENA */ 188#define WM8400_GPIO1_DEB_ENA_SHIFT 7 /* GPIO1_DEB_ENA */ 189#define WM8400_GPIO1_DEB_ENA_WIDTH 1 /* GPIO1_DEB_ENA */ 190#define WM8400_GPIO1_IRQ_ENA 0x0040 /* GPIO1_IRQ_ENA */ 191#define WM8400_GPIO1_IRQ_ENA_MASK 0x0040 /* GPIO1_IRQ_ENA */ 192#define WM8400_GPIO1_IRQ_ENA_SHIFT 6 /* GPIO1_IRQ_ENA */ 193#define WM8400_GPIO1_IRQ_ENA_WIDTH 1 /* GPIO1_IRQ_ENA */ 194#define WM8400_GPIO1_PU 0x0020 /* GPIO1_PU */ 195#define WM8400_GPIO1_PU_MASK 0x0020 /* GPIO1_PU */ 196#define WM8400_GPIO1_PU_SHIFT 5 /* GPIO1_PU */ 197#define WM8400_GPIO1_PU_WIDTH 1 /* GPIO1_PU */ 198#define WM8400_GPIO1_PD 0x0010 /* GPIO1_PD */ 199#define WM8400_GPIO1_PD_MASK 0x0010 /* GPIO1_PD */ 200#define WM8400_GPIO1_PD_SHIFT 4 /* GPIO1_PD */ 201#define WM8400_GPIO1_PD_WIDTH 1 /* GPIO1_PD */ 202#define WM8400_GPIO1_SEL_MASK 0x000F /* GPIO1_SEL - [3:0] */ 203#define WM8400_GPIO1_SEL_SHIFT 0 /* GPIO1_SEL - [3:0] */ 204#define WM8400_GPIO1_SEL_WIDTH 4 /* GPIO1_SEL - [3:0] */ 205 206/* 207 * R20 (0x14) - GPIO3 & GPIO4 208 */ 209#define WM8400_GPIO4_DEB_ENA 0x8000 /* GPIO4_DEB_ENA */ 210#define WM8400_GPIO4_DEB_ENA_MASK 0x8000 /* GPIO4_DEB_ENA */ 211#define WM8400_GPIO4_DEB_ENA_SHIFT 15 /* GPIO4_DEB_ENA */ 212#define WM8400_GPIO4_DEB_ENA_WIDTH 1 /* GPIO4_DEB_ENA */ 213#define WM8400_GPIO4_IRQ_ENA 0x4000 /* GPIO4_IRQ_ENA */ 214#define WM8400_GPIO4_IRQ_ENA_MASK 0x4000 /* GPIO4_IRQ_ENA */ 215#define WM8400_GPIO4_IRQ_ENA_SHIFT 14 /* GPIO4_IRQ_ENA */ 216#define WM8400_GPIO4_IRQ_ENA_WIDTH 1 /* GPIO4_IRQ_ENA */ 217#define WM8400_GPIO4_PU 0x2000 /* GPIO4_PU */ 218#define WM8400_GPIO4_PU_MASK 0x2000 /* GPIO4_PU */ 219#define WM8400_GPIO4_PU_SHIFT 13 /* GPIO4_PU */ 220#define WM8400_GPIO4_PU_WIDTH 1 /* GPIO4_PU */ 221#define WM8400_GPIO4_PD 0x1000 /* GPIO4_PD */ 222#define WM8400_GPIO4_PD_MASK 0x1000 /* GPIO4_PD */ 223#define WM8400_GPIO4_PD_SHIFT 12 /* GPIO4_PD */ 224#define WM8400_GPIO4_PD_WIDTH 1 /* GPIO4_PD */ 225#define WM8400_GPIO4_SEL_MASK 0x0F00 /* GPIO4_SEL - [11:8] */ 226#define WM8400_GPIO4_SEL_SHIFT 8 /* GPIO4_SEL - [11:8] */ 227#define WM8400_GPIO4_SEL_WIDTH 4 /* GPIO4_SEL - [11:8] */ 228#define WM8400_GPIO3_DEB_ENA 0x0080 /* GPIO3_DEB_ENA */ 229#define WM8400_GPIO3_DEB_ENA_MASK 0x0080 /* GPIO3_DEB_ENA */ 230#define WM8400_GPIO3_DEB_ENA_SHIFT 7 /* GPIO3_DEB_ENA */ 231#define WM8400_GPIO3_DEB_ENA_WIDTH 1 /* GPIO3_DEB_ENA */ 232#define WM8400_GPIO3_IRQ_ENA 0x0040 /* GPIO3_IRQ_ENA */ 233#define WM8400_GPIO3_IRQ_ENA_MASK 0x0040 /* GPIO3_IRQ_ENA */ 234#define WM8400_GPIO3_IRQ_ENA_SHIFT 6 /* GPIO3_IRQ_ENA */ 235#define WM8400_GPIO3_IRQ_ENA_WIDTH 1 /* GPIO3_IRQ_ENA */ 236#define WM8400_GPIO3_PU 0x0020 /* GPIO3_PU */ 237#define WM8400_GPIO3_PU_MASK 0x0020 /* GPIO3_PU */ 238#define WM8400_GPIO3_PU_SHIFT 5 /* GPIO3_PU */ 239#define WM8400_GPIO3_PU_WIDTH 1 /* GPIO3_PU */ 240#define WM8400_GPIO3_PD 0x0010 /* GPIO3_PD */ 241#define WM8400_GPIO3_PD_MASK 0x0010 /* GPIO3_PD */ 242#define WM8400_GPIO3_PD_SHIFT 4 /* GPIO3_PD */ 243#define WM8400_GPIO3_PD_WIDTH 1 /* GPIO3_PD */ 244#define WM8400_GPIO3_SEL_MASK 0x000F /* GPIO3_SEL - [3:0] */ 245#define WM8400_GPIO3_SEL_SHIFT 0 /* GPIO3_SEL - [3:0] */ 246#define WM8400_GPIO3_SEL_WIDTH 4 /* GPIO3_SEL - [3:0] */ 247 248/* 249 * R21 (0x15) - GPIO5 & GPIO6 250 */ 251#define WM8400_GPIO6_DEB_ENA 0x8000 /* GPIO6_DEB_ENA */ 252#define WM8400_GPIO6_DEB_ENA_MASK 0x8000 /* GPIO6_DEB_ENA */ 253#define WM8400_GPIO6_DEB_ENA_SHIFT 15 /* GPIO6_DEB_ENA */ 254#define WM8400_GPIO6_DEB_ENA_WIDTH 1 /* GPIO6_DEB_ENA */ 255#define WM8400_GPIO6_IRQ_ENA 0x4000 /* GPIO6_IRQ_ENA */ 256#define WM8400_GPIO6_IRQ_ENA_MASK 0x4000 /* GPIO6_IRQ_ENA */ 257#define WM8400_GPIO6_IRQ_ENA_SHIFT 14 /* GPIO6_IRQ_ENA */ 258#define WM8400_GPIO6_IRQ_ENA_WIDTH 1 /* GPIO6_IRQ_ENA */ 259#define WM8400_GPIO6_PU 0x2000 /* GPIO6_PU */ 260#define WM8400_GPIO6_PU_MASK 0x2000 /* GPIO6_PU */ 261#define WM8400_GPIO6_PU_SHIFT 13 /* GPIO6_PU */ 262#define WM8400_GPIO6_PU_WIDTH 1 /* GPIO6_PU */ 263#define WM8400_GPIO6_PD 0x1000 /* GPIO6_PD */ 264#define WM8400_GPIO6_PD_MASK 0x1000 /* GPIO6_PD */ 265#define WM8400_GPIO6_PD_SHIFT 12 /* GPIO6_PD */ 266#define WM8400_GPIO6_PD_WIDTH 1 /* GPIO6_PD */ 267#define WM8400_GPIO6_SEL_MASK 0x0F00 /* GPIO6_SEL - [11:8] */ 268#define WM8400_GPIO6_SEL_SHIFT 8 /* GPIO6_SEL - [11:8] */ 269#define WM8400_GPIO6_SEL_WIDTH 4 /* GPIO6_SEL - [11:8] */ 270#define WM8400_GPIO5_DEB_ENA 0x0080 /* GPIO5_DEB_ENA */ 271#define WM8400_GPIO5_DEB_ENA_MASK 0x0080 /* GPIO5_DEB_ENA */ 272#define WM8400_GPIO5_DEB_ENA_SHIFT 7 /* GPIO5_DEB_ENA */ 273#define WM8400_GPIO5_DEB_ENA_WIDTH 1 /* GPIO5_DEB_ENA */ 274#define WM8400_GPIO5_IRQ_ENA 0x0040 /* GPIO5_IRQ_ENA */ 275#define WM8400_GPIO5_IRQ_ENA_MASK 0x0040 /* GPIO5_IRQ_ENA */ 276#define WM8400_GPIO5_IRQ_ENA_SHIFT 6 /* GPIO5_IRQ_ENA */ 277#define WM8400_GPIO5_IRQ_ENA_WIDTH 1 /* GPIO5_IRQ_ENA */ 278#define WM8400_GPIO5_PU 0x0020 /* GPIO5_PU */ 279#define WM8400_GPIO5_PU_MASK 0x0020 /* GPIO5_PU */ 280#define WM8400_GPIO5_PU_SHIFT 5 /* GPIO5_PU */ 281#define WM8400_GPIO5_PU_WIDTH 1 /* GPIO5_PU */ 282#define WM8400_GPIO5_PD 0x0010 /* GPIO5_PD */ 283#define WM8400_GPIO5_PD_MASK 0x0010 /* GPIO5_PD */ 284#define WM8400_GPIO5_PD_SHIFT 4 /* GPIO5_PD */ 285#define WM8400_GPIO5_PD_WIDTH 1 /* GPIO5_PD */ 286#define WM8400_GPIO5_SEL_MASK 0x000F /* GPIO5_SEL - [3:0] */ 287#define WM8400_GPIO5_SEL_SHIFT 0 /* GPIO5_SEL - [3:0] */ 288#define WM8400_GPIO5_SEL_WIDTH 4 /* GPIO5_SEL - [3:0] */ 289 290/* 291 * R22 (0x16) - GPIOCTRL 2 292 */ 293#define WM8400_TEMPOK_IRQ_ENA 0x0800 /* TEMPOK_IRQ_ENA */ 294#define WM8400_TEMPOK_IRQ_ENA_MASK 0x0800 /* TEMPOK_IRQ_ENA */ 295#define WM8400_TEMPOK_IRQ_ENA_SHIFT 11 /* TEMPOK_IRQ_ENA */ 296#define WM8400_TEMPOK_IRQ_ENA_WIDTH 1 /* TEMPOK_IRQ_ENA */ 297#define WM8400_MIC1SHRT_IRQ_ENA 0x0400 /* MIC1SHRT_IRQ_ENA */ 298#define WM8400_MIC1SHRT_IRQ_ENA_MASK 0x0400 /* MIC1SHRT_IRQ_ENA */ 299#define WM8400_MIC1SHRT_IRQ_ENA_SHIFT 10 /* MIC1SHRT_IRQ_ENA */ 300#define WM8400_MIC1SHRT_IRQ_ENA_WIDTH 1 /* MIC1SHRT_IRQ_ENA */ 301#define WM8400_MIC1DET_IRQ_ENA 0x0200 /* MIC1DET_IRQ_ENA */ 302#define WM8400_MIC1DET_IRQ_ENA_MASK 0x0200 /* MIC1DET_IRQ_ENA */ 303#define WM8400_MIC1DET_IRQ_ENA_SHIFT 9 /* MIC1DET_IRQ_ENA */ 304#define WM8400_MIC1DET_IRQ_ENA_WIDTH 1 /* MIC1DET_IRQ_ENA */ 305#define WM8400_FLL_LCK_IRQ_ENA 0x0100 /* FLL_LCK_IRQ_ENA */ 306#define WM8400_FLL_LCK_IRQ_ENA_MASK 0x0100 /* FLL_LCK_IRQ_ENA */ 307#define WM8400_FLL_LCK_IRQ_ENA_SHIFT 8 /* FLL_LCK_IRQ_ENA */ 308#define WM8400_FLL_LCK_IRQ_ENA_WIDTH 1 /* FLL_LCK_IRQ_ENA */ 309#define WM8400_GPI8_DEB_ENA 0x0080 /* GPI8_DEB_ENA */ 310#define WM8400_GPI8_DEB_ENA_MASK 0x0080 /* GPI8_DEB_ENA */ 311#define WM8400_GPI8_DEB_ENA_SHIFT 7 /* GPI8_DEB_ENA */ 312#define WM8400_GPI8_DEB_ENA_WIDTH 1 /* GPI8_DEB_ENA */ 313#define WM8400_GPI8_IRQ_ENA 0x0040 /* GPI8_IRQ_ENA */ 314#define WM8400_GPI8_IRQ_ENA_MASK 0x0040 /* GPI8_IRQ_ENA */ 315#define WM8400_GPI8_IRQ_ENA_SHIFT 6 /* GPI8_IRQ_ENA */ 316#define WM8400_GPI8_IRQ_ENA_WIDTH 1 /* GPI8_IRQ_ENA */ 317#define WM8400_GPI8_ENA 0x0010 /* GPI8_ENA */ 318#define WM8400_GPI8_ENA_MASK 0x0010 /* GPI8_ENA */ 319#define WM8400_GPI8_ENA_SHIFT 4 /* GPI8_ENA */ 320#define WM8400_GPI8_ENA_WIDTH 1 /* GPI8_ENA */ 321#define WM8400_GPI7_DEB_ENA 0x0008 /* GPI7_DEB_ENA */ 322#define WM8400_GPI7_DEB_ENA_MASK 0x0008 /* GPI7_DEB_ENA */ 323#define WM8400_GPI7_DEB_ENA_SHIFT 3 /* GPI7_DEB_ENA */ 324#define WM8400_GPI7_DEB_ENA_WIDTH 1 /* GPI7_DEB_ENA */ 325#define WM8400_GPI7_IRQ_ENA 0x0004 /* GPI7_IRQ_ENA */ 326#define WM8400_GPI7_IRQ_ENA_MASK 0x0004 /* GPI7_IRQ_ENA */ 327#define WM8400_GPI7_IRQ_ENA_SHIFT 2 /* GPI7_IRQ_ENA */ 328#define WM8400_GPI7_IRQ_ENA_WIDTH 1 /* GPI7_IRQ_ENA */ 329#define WM8400_GPI7_ENA 0x0001 /* GPI7_ENA */ 330#define WM8400_GPI7_ENA_MASK 0x0001 /* GPI7_ENA */ 331#define WM8400_GPI7_ENA_SHIFT 0 /* GPI7_ENA */ 332#define WM8400_GPI7_ENA_WIDTH 1 /* GPI7_ENA */ 333 334/* 335 * R23 (0x17) - GPIO_POL 336 */ 337#define WM8400_IRQ_INV 0x1000 /* IRQ_INV */ 338#define WM8400_IRQ_INV_MASK 0x1000 /* IRQ_INV */ 339#define WM8400_IRQ_INV_SHIFT 12 /* IRQ_INV */ 340#define WM8400_IRQ_INV_WIDTH 1 /* IRQ_INV */ 341#define WM8400_TEMPOK_POL 0x0800 /* TEMPOK_POL */ 342#define WM8400_TEMPOK_POL_MASK 0x0800 /* TEMPOK_POL */ 343#define WM8400_TEMPOK_POL_SHIFT 11 /* TEMPOK_POL */ 344#define WM8400_TEMPOK_POL_WIDTH 1 /* TEMPOK_POL */ 345#define WM8400_MIC1SHRT_POL 0x0400 /* MIC1SHRT_POL */ 346#define WM8400_MIC1SHRT_POL_MASK 0x0400 /* MIC1SHRT_POL */ 347#define WM8400_MIC1SHRT_POL_SHIFT 10 /* MIC1SHRT_POL */ 348#define WM8400_MIC1SHRT_POL_WIDTH 1 /* MIC1SHRT_POL */ 349#define WM8400_MIC1DET_POL 0x0200 /* MIC1DET_POL */ 350#define WM8400_MIC1DET_POL_MASK 0x0200 /* MIC1DET_POL */ 351#define WM8400_MIC1DET_POL_SHIFT 9 /* MIC1DET_POL */ 352#define WM8400_MIC1DET_POL_WIDTH 1 /* MIC1DET_POL */ 353#define WM8400_FLL_LCK_POL 0x0100 /* FLL_LCK_POL */ 354#define WM8400_FLL_LCK_POL_MASK 0x0100 /* FLL_LCK_POL */ 355#define WM8400_FLL_LCK_POL_SHIFT 8 /* FLL_LCK_POL */ 356#define WM8400_FLL_LCK_POL_WIDTH 1 /* FLL_LCK_POL */ 357#define WM8400_GPIO_POL_MASK 0x00FF /* GPIO_POL - [7:0] */ 358#define WM8400_GPIO_POL_SHIFT 0 /* GPIO_POL - [7:0] */ 359#define WM8400_GPIO_POL_WIDTH 8 /* GPIO_POL - [7:0] */ 360 361/* 362 * R65 (0x41) - LDO 1 Control 363 */ 364#define WM8400_LDO1_ENA 0x8000 /* LDO1_ENA */ 365#define WM8400_LDO1_ENA_MASK 0x8000 /* LDO1_ENA */ 366#define WM8400_LDO1_ENA_SHIFT 15 /* LDO1_ENA */ 367#define WM8400_LDO1_ENA_WIDTH 1 /* LDO1_ENA */ 368#define WM8400_LDO1_SWI 0x4000 /* LDO1_SWI */ 369#define WM8400_LDO1_SWI_MASK 0x4000 /* LDO1_SWI */ 370#define WM8400_LDO1_SWI_SHIFT 14 /* LDO1_SWI */ 371#define WM8400_LDO1_SWI_WIDTH 1 /* LDO1_SWI */ 372#define WM8400_LDO1_OPFLT 0x1000 /* LDO1_OPFLT */ 373#define WM8400_LDO1_OPFLT_MASK 0x1000 /* LDO1_OPFLT */ 374#define WM8400_LDO1_OPFLT_SHIFT 12 /* LDO1_OPFLT */ 375#define WM8400_LDO1_OPFLT_WIDTH 1 /* LDO1_OPFLT */ 376#define WM8400_LDO1_ERRACT 0x0800 /* LDO1_ERRACT */ 377#define WM8400_LDO1_ERRACT_MASK 0x0800 /* LDO1_ERRACT */ 378#define WM8400_LDO1_ERRACT_SHIFT 11 /* LDO1_ERRACT */ 379#define WM8400_LDO1_ERRACT_WIDTH 1 /* LDO1_ERRACT */ 380#define WM8400_LDO1_HIB_MODE 0x0400 /* LDO1_HIB_MODE */ 381#define WM8400_LDO1_HIB_MODE_MASK 0x0400 /* LDO1_HIB_MODE */ 382#define WM8400_LDO1_HIB_MODE_SHIFT 10 /* LDO1_HIB_MODE */ 383#define WM8400_LDO1_HIB_MODE_WIDTH 1 /* LDO1_HIB_MODE */ 384#define WM8400_LDO1_VIMG_MASK 0x03E0 /* LDO1_VIMG - [9:5] */ 385#define WM8400_LDO1_VIMG_SHIFT 5 /* LDO1_VIMG - [9:5] */ 386#define WM8400_LDO1_VIMG_WIDTH 5 /* LDO1_VIMG - [9:5] */ 387#define WM8400_LDO1_VSEL_MASK 0x001F /* LDO1_VSEL - [4:0] */ 388#define WM8400_LDO1_VSEL_SHIFT 0 /* LDO1_VSEL - [4:0] */ 389#define WM8400_LDO1_VSEL_WIDTH 5 /* LDO1_VSEL - [4:0] */ 390 391/* 392 * R66 (0x42) - LDO 2 Control 393 */ 394#define WM8400_LDO2_ENA 0x8000 /* LDO2_ENA */ 395#define WM8400_LDO2_ENA_MASK 0x8000 /* LDO2_ENA */ 396#define WM8400_LDO2_ENA_SHIFT 15 /* LDO2_ENA */ 397#define WM8400_LDO2_ENA_WIDTH 1 /* LDO2_ENA */ 398#define WM8400_LDO2_SWI 0x4000 /* LDO2_SWI */ 399#define WM8400_LDO2_SWI_MASK 0x4000 /* LDO2_SWI */ 400#define WM8400_LDO2_SWI_SHIFT 14 /* LDO2_SWI */ 401#define WM8400_LDO2_SWI_WIDTH 1 /* LDO2_SWI */ 402#define WM8400_LDO2_OPFLT 0x1000 /* LDO2_OPFLT */ 403#define WM8400_LDO2_OPFLT_MASK 0x1000 /* LDO2_OPFLT */ 404#define WM8400_LDO2_OPFLT_SHIFT 12 /* LDO2_OPFLT */ 405#define WM8400_LDO2_OPFLT_WIDTH 1 /* LDO2_OPFLT */ 406#define WM8400_LDO2_ERRACT 0x0800 /* LDO2_ERRACT */ 407#define WM8400_LDO2_ERRACT_MASK 0x0800 /* LDO2_ERRACT */ 408#define WM8400_LDO2_ERRACT_SHIFT 11 /* LDO2_ERRACT */ 409#define WM8400_LDO2_ERRACT_WIDTH 1 /* LDO2_ERRACT */ 410#define WM8400_LDO2_HIB_MODE 0x0400 /* LDO2_HIB_MODE */ 411#define WM8400_LDO2_HIB_MODE_MASK 0x0400 /* LDO2_HIB_MODE */ 412#define WM8400_LDO2_HIB_MODE_SHIFT 10 /* LDO2_HIB_MODE */ 413#define WM8400_LDO2_HIB_MODE_WIDTH 1 /* LDO2_HIB_MODE */ 414#define WM8400_LDO2_VIMG_MASK 0x03E0 /* LDO2_VIMG - [9:5] */ 415#define WM8400_LDO2_VIMG_SHIFT 5 /* LDO2_VIMG - [9:5] */ 416#define WM8400_LDO2_VIMG_WIDTH 5 /* LDO2_VIMG - [9:5] */ 417#define WM8400_LDO2_VSEL_MASK 0x001F /* LDO2_VSEL - [4:0] */ 418#define WM8400_LDO2_VSEL_SHIFT 0 /* LDO2_VSEL - [4:0] */ 419#define WM8400_LDO2_VSEL_WIDTH 5 /* LDO2_VSEL - [4:0] */ 420 421/* 422 * R67 (0x43) - LDO 3 Control 423 */ 424#define WM8400_LDO3_ENA 0x8000 /* LDO3_ENA */ 425#define WM8400_LDO3_ENA_MASK 0x8000 /* LDO3_ENA */ 426#define WM8400_LDO3_ENA_SHIFT 15 /* LDO3_ENA */ 427#define WM8400_LDO3_ENA_WIDTH 1 /* LDO3_ENA */ 428#define WM8400_LDO3_SWI 0x4000 /* LDO3_SWI */ 429#define WM8400_LDO3_SWI_MASK 0x4000 /* LDO3_SWI */ 430#define WM8400_LDO3_SWI_SHIFT 14 /* LDO3_SWI */ 431#define WM8400_LDO3_SWI_WIDTH 1 /* LDO3_SWI */ 432#define WM8400_LDO3_OPFLT 0x1000 /* LDO3_OPFLT */ 433#define WM8400_LDO3_OPFLT_MASK 0x1000 /* LDO3_OPFLT */ 434#define WM8400_LDO3_OPFLT_SHIFT 12 /* LDO3_OPFLT */ 435#define WM8400_LDO3_OPFLT_WIDTH 1 /* LDO3_OPFLT */ 436#define WM8400_LDO3_ERRACT 0x0800 /* LDO3_ERRACT */ 437#define WM8400_LDO3_ERRACT_MASK 0x0800 /* LDO3_ERRACT */ 438#define WM8400_LDO3_ERRACT_SHIFT 11 /* LDO3_ERRACT */ 439#define WM8400_LDO3_ERRACT_WIDTH 1 /* LDO3_ERRACT */ 440#define WM8400_LDO3_HIB_MODE 0x0400 /* LDO3_HIB_MODE */ 441#define WM8400_LDO3_HIB_MODE_MASK 0x0400 /* LDO3_HIB_MODE */ 442#define WM8400_LDO3_HIB_MODE_SHIFT 10 /* LDO3_HIB_MODE */ 443#define WM8400_LDO3_HIB_MODE_WIDTH 1 /* LDO3_HIB_MODE */ 444#define WM8400_LDO3_VIMG_MASK 0x03E0 /* LDO3_VIMG - [9:5] */ 445#define WM8400_LDO3_VIMG_SHIFT 5 /* LDO3_VIMG - [9:5] */ 446#define WM8400_LDO3_VIMG_WIDTH 5 /* LDO3_VIMG - [9:5] */ 447#define WM8400_LDO3_VSEL_MASK 0x001F /* LDO3_VSEL - [4:0] */ 448#define WM8400_LDO3_VSEL_SHIFT 0 /* LDO3_VSEL - [4:0] */ 449#define WM8400_LDO3_VSEL_WIDTH 5 /* LDO3_VSEL - [4:0] */ 450 451/* 452 * R68 (0x44) - LDO 4 Control 453 */ 454#define WM8400_LDO4_ENA 0x8000 /* LDO4_ENA */ 455#define WM8400_LDO4_ENA_MASK 0x8000 /* LDO4_ENA */ 456#define WM8400_LDO4_ENA_SHIFT 15 /* LDO4_ENA */ 457#define WM8400_LDO4_ENA_WIDTH 1 /* LDO4_ENA */ 458#define WM8400_LDO4_SWI 0x4000 /* LDO4_SWI */ 459#define WM8400_LDO4_SWI_MASK 0x4000 /* LDO4_SWI */ 460#define WM8400_LDO4_SWI_SHIFT 14 /* LDO4_SWI */ 461#define WM8400_LDO4_SWI_WIDTH 1 /* LDO4_SWI */ 462#define WM8400_LDO4_OPFLT 0x1000 /* LDO4_OPFLT */ 463#define WM8400_LDO4_OPFLT_MASK 0x1000 /* LDO4_OPFLT */ 464#define WM8400_LDO4_OPFLT_SHIFT 12 /* LDO4_OPFLT */ 465#define WM8400_LDO4_OPFLT_WIDTH 1 /* LDO4_OPFLT */ 466#define WM8400_LDO4_ERRACT 0x0800 /* LDO4_ERRACT */ 467#define WM8400_LDO4_ERRACT_MASK 0x0800 /* LDO4_ERRACT */ 468#define WM8400_LDO4_ERRACT_SHIFT 11 /* LDO4_ERRACT */ 469#define WM8400_LDO4_ERRACT_WIDTH 1 /* LDO4_ERRACT */ 470#define WM8400_LDO4_HIB_MODE 0x0400 /* LDO4_HIB_MODE */ 471#define WM8400_LDO4_HIB_MODE_MASK 0x0400 /* LDO4_HIB_MODE */ 472#define WM8400_LDO4_HIB_MODE_SHIFT 10 /* LDO4_HIB_MODE */ 473#define WM8400_LDO4_HIB_MODE_WIDTH 1 /* LDO4_HIB_MODE */ 474#define WM8400_LDO4_VIMG_MASK 0x03E0 /* LDO4_VIMG - [9:5] */ 475#define WM8400_LDO4_VIMG_SHIFT 5 /* LDO4_VIMG - [9:5] */ 476#define WM8400_LDO4_VIMG_WIDTH 5 /* LDO4_VIMG - [9:5] */ 477#define WM8400_LDO4_VSEL_MASK 0x001F /* LDO4_VSEL - [4:0] */ 478#define WM8400_LDO4_VSEL_SHIFT 0 /* LDO4_VSEL - [4:0] */ 479#define WM8400_LDO4_VSEL_WIDTH 5 /* LDO4_VSEL - [4:0] */ 480 481/* 482 * R70 (0x46) - DCDC1 Control 1 483 */ 484#define WM8400_DC1_ENA 0x8000 /* DC1_ENA */ 485#define WM8400_DC1_ENA_MASK 0x8000 /* DC1_ENA */ 486#define WM8400_DC1_ENA_SHIFT 15 /* DC1_ENA */ 487#define WM8400_DC1_ENA_WIDTH 1 /* DC1_ENA */ 488#define WM8400_DC1_ACTIVE 0x4000 /* DC1_ACTIVE */ 489#define WM8400_DC1_ACTIVE_MASK 0x4000 /* DC1_ACTIVE */ 490#define WM8400_DC1_ACTIVE_SHIFT 14 /* DC1_ACTIVE */ 491#define WM8400_DC1_ACTIVE_WIDTH 1 /* DC1_ACTIVE */ 492#define WM8400_DC1_SLEEP 0x2000 /* DC1_SLEEP */ 493#define WM8400_DC1_SLEEP_MASK 0x2000 /* DC1_SLEEP */ 494#define WM8400_DC1_SLEEP_SHIFT 13 /* DC1_SLEEP */ 495#define WM8400_DC1_SLEEP_WIDTH 1 /* DC1_SLEEP */ 496#define WM8400_DC1_OPFLT 0x1000 /* DC1_OPFLT */ 497#define WM8400_DC1_OPFLT_MASK 0x1000 /* DC1_OPFLT */ 498#define WM8400_DC1_OPFLT_SHIFT 12 /* DC1_OPFLT */ 499#define WM8400_DC1_OPFLT_WIDTH 1 /* DC1_OPFLT */ 500#define WM8400_DC1_ERRACT 0x0800 /* DC1_ERRACT */ 501#define WM8400_DC1_ERRACT_MASK 0x0800 /* DC1_ERRACT */ 502#define WM8400_DC1_ERRACT_SHIFT 11 /* DC1_ERRACT */ 503#define WM8400_DC1_ERRACT_WIDTH 1 /* DC1_ERRACT */ 504#define WM8400_DC1_HIB_MODE 0x0400 /* DC1_HIB_MODE */ 505#define WM8400_DC1_HIB_MODE_MASK 0x0400 /* DC1_HIB_MODE */ 506#define WM8400_DC1_HIB_MODE_SHIFT 10 /* DC1_HIB_MODE */ 507#define WM8400_DC1_HIB_MODE_WIDTH 1 /* DC1_HIB_MODE */ 508#define WM8400_DC1_SOFTST_MASK 0x0300 /* DC1_SOFTST - [9:8] */ 509#define WM8400_DC1_SOFTST_SHIFT 8 /* DC1_SOFTST - [9:8] */ 510#define WM8400_DC1_SOFTST_WIDTH 2 /* DC1_SOFTST - [9:8] */ 511#define WM8400_DC1_OV_PROT 0x0080 /* DC1_OV_PROT */ 512#define WM8400_DC1_OV_PROT_MASK 0x0080 /* DC1_OV_PROT */ 513#define WM8400_DC1_OV_PROT_SHIFT 7 /* DC1_OV_PROT */ 514#define WM8400_DC1_OV_PROT_WIDTH 1 /* DC1_OV_PROT */ 515#define WM8400_DC1_VSEL_MASK 0x007F /* DC1_VSEL - [6:0] */ 516#define WM8400_DC1_VSEL_SHIFT 0 /* DC1_VSEL - [6:0] */ 517#define WM8400_DC1_VSEL_WIDTH 7 /* DC1_VSEL - [6:0] */ 518 519/* 520 * R71 (0x47) - DCDC1 Control 2 521 */ 522#define WM8400_DC1_FRC_PWM 0x2000 /* DC1_FRC_PWM */ 523#define WM8400_DC1_FRC_PWM_MASK 0x2000 /* DC1_FRC_PWM */ 524#define WM8400_DC1_FRC_PWM_SHIFT 13 /* DC1_FRC_PWM */ 525#define WM8400_DC1_FRC_PWM_WIDTH 1 /* DC1_FRC_PWM */ 526#define WM8400_DC1_STBY_LIM_MASK 0x0300 /* DC1_STBY_LIM - [9:8] */ 527#define WM8400_DC1_STBY_LIM_SHIFT 8 /* DC1_STBY_LIM - [9:8] */ 528#define WM8400_DC1_STBY_LIM_WIDTH 2 /* DC1_STBY_LIM - [9:8] */ 529#define WM8400_DC1_ACT_LIM 0x0080 /* DC1_ACT_LIM */ 530#define WM8400_DC1_ACT_LIM_MASK 0x0080 /* DC1_ACT_LIM */ 531#define WM8400_DC1_ACT_LIM_SHIFT 7 /* DC1_ACT_LIM */ 532#define WM8400_DC1_ACT_LIM_WIDTH 1 /* DC1_ACT_LIM */ 533#define WM8400_DC1_VIMG_MASK 0x007F /* DC1_VIMG - [6:0] */ 534#define WM8400_DC1_VIMG_SHIFT 0 /* DC1_VIMG - [6:0] */ 535#define WM8400_DC1_VIMG_WIDTH 7 /* DC1_VIMG - [6:0] */ 536 537/* 538 * R72 (0x48) - DCDC2 Control 1 539 */ 540#define WM8400_DC2_ENA 0x8000 /* DC2_ENA */ 541#define WM8400_DC2_ENA_MASK 0x8000 /* DC2_ENA */ 542#define WM8400_DC2_ENA_SHIFT 15 /* DC2_ENA */ 543#define WM8400_DC2_ENA_WIDTH 1 /* DC2_ENA */ 544#define WM8400_DC2_ACTIVE 0x4000 /* DC2_ACTIVE */ 545#define WM8400_DC2_ACTIVE_MASK 0x4000 /* DC2_ACTIVE */ 546#define WM8400_DC2_ACTIVE_SHIFT 14 /* DC2_ACTIVE */ 547#define WM8400_DC2_ACTIVE_WIDTH 1 /* DC2_ACTIVE */ 548#define WM8400_DC2_SLEEP 0x2000 /* DC2_SLEEP */ 549#define WM8400_DC2_SLEEP_MASK 0x2000 /* DC2_SLEEP */ 550#define WM8400_DC2_SLEEP_SHIFT 13 /* DC2_SLEEP */ 551#define WM8400_DC2_SLEEP_WIDTH 1 /* DC2_SLEEP */ 552#define WM8400_DC2_OPFLT 0x1000 /* DC2_OPFLT */ 553#define WM8400_DC2_OPFLT_MASK 0x1000 /* DC2_OPFLT */ 554#define WM8400_DC2_OPFLT_SHIFT 12 /* DC2_OPFLT */ 555#define WM8400_DC2_OPFLT_WIDTH 1 /* DC2_OPFLT */ 556#define WM8400_DC2_ERRACT 0x0800 /* DC2_ERRACT */ 557#define WM8400_DC2_ERRACT_MASK 0x0800 /* DC2_ERRACT */ 558#define WM8400_DC2_ERRACT_SHIFT 11 /* DC2_ERRACT */ 559#define WM8400_DC2_ERRACT_WIDTH 1 /* DC2_ERRACT */ 560#define WM8400_DC2_HIB_MODE 0x0400 /* DC2_HIB_MODE */ 561#define WM8400_DC2_HIB_MODE_MASK 0x0400 /* DC2_HIB_MODE */ 562#define WM8400_DC2_HIB_MODE_SHIFT 10 /* DC2_HIB_MODE */ 563#define WM8400_DC2_HIB_MODE_WIDTH 1 /* DC2_HIB_MODE */ 564#define WM8400_DC2_SOFTST_MASK 0x0300 /* DC2_SOFTST - [9:8] */ 565#define WM8400_DC2_SOFTST_SHIFT 8 /* DC2_SOFTST - [9:8] */ 566#define WM8400_DC2_SOFTST_WIDTH 2 /* DC2_SOFTST - [9:8] */ 567#define WM8400_DC2_OV_PROT 0x0080 /* DC2_OV_PROT */ 568#define WM8400_DC2_OV_PROT_MASK 0x0080 /* DC2_OV_PROT */ 569#define WM8400_DC2_OV_PROT_SHIFT 7 /* DC2_OV_PROT */ 570#define WM8400_DC2_OV_PROT_WIDTH 1 /* DC2_OV_PROT */ 571#define WM8400_DC2_VSEL_MASK 0x007F /* DC2_VSEL - [6:0] */ 572#define WM8400_DC2_VSEL_SHIFT 0 /* DC2_VSEL - [6:0] */ 573#define WM8400_DC2_VSEL_WIDTH 7 /* DC2_VSEL - [6:0] */ 574 575/* 576 * R73 (0x49) - DCDC2 Control 2 577 */ 578#define WM8400_DC2_FRC_PWM 0x2000 /* DC2_FRC_PWM */ 579#define WM8400_DC2_FRC_PWM_MASK 0x2000 /* DC2_FRC_PWM */ 580#define WM8400_DC2_FRC_PWM_SHIFT 13 /* DC2_FRC_PWM */ 581#define WM8400_DC2_FRC_PWM_WIDTH 1 /* DC2_FRC_PWM */ 582#define WM8400_DC2_STBY_LIM_MASK 0x0300 /* DC2_STBY_LIM - [9:8] */ 583#define WM8400_DC2_STBY_LIM_SHIFT 8 /* DC2_STBY_LIM - [9:8] */ 584#define WM8400_DC2_STBY_LIM_WIDTH 2 /* DC2_STBY_LIM - [9:8] */ 585#define WM8400_DC2_ACT_LIM 0x0080 /* DC2_ACT_LIM */ 586#define WM8400_DC2_ACT_LIM_MASK 0x0080 /* DC2_ACT_LIM */ 587#define WM8400_DC2_ACT_LIM_SHIFT 7 /* DC2_ACT_LIM */ 588#define WM8400_DC2_ACT_LIM_WIDTH 1 /* DC2_ACT_LIM */ 589#define WM8400_DC2_VIMG_MASK 0x007F /* DC2_VIMG - [6:0] */ 590#define WM8400_DC2_VIMG_SHIFT 0 /* DC2_VIMG - [6:0] */ 591#define WM8400_DC2_VIMG_WIDTH 7 /* DC2_VIMG - [6:0] */ 592 593/* 594 * R75 (0x4B) - Interface 595 */ 596#define WM8400_AUTOINC 0x0008 /* AUTOINC */ 597#define WM8400_AUTOINC_MASK 0x0008 /* AUTOINC */ 598#define WM8400_AUTOINC_SHIFT 3 /* AUTOINC */ 599#define WM8400_AUTOINC_WIDTH 1 /* AUTOINC */ 600#define WM8400_ARA_ENA 0x0004 /* ARA_ENA */ 601#define WM8400_ARA_ENA_MASK 0x0004 /* ARA_ENA */ 602#define WM8400_ARA_ENA_SHIFT 2 /* ARA_ENA */ 603#define WM8400_ARA_ENA_WIDTH 1 /* ARA_ENA */ 604#define WM8400_SPI_CFG 0x0002 /* SPI_CFG */ 605#define WM8400_SPI_CFG_MASK 0x0002 /* SPI_CFG */ 606#define WM8400_SPI_CFG_SHIFT 1 /* SPI_CFG */ 607#define WM8400_SPI_CFG_WIDTH 1 /* SPI_CFG */ 608 609/* 610 * R76 (0x4C) - PM GENERAL 611 */ 612#define WM8400_CODEC_SOFTST 0x8000 /* CODEC_SOFTST */ 613#define WM8400_CODEC_SOFTST_MASK 0x8000 /* CODEC_SOFTST */ 614#define WM8400_CODEC_SOFTST_SHIFT 15 /* CODEC_SOFTST */ 615#define WM8400_CODEC_SOFTST_WIDTH 1 /* CODEC_SOFTST */ 616#define WM8400_CODEC_SOFTSD 0x4000 /* CODEC_SOFTSD */ 617#define WM8400_CODEC_SOFTSD_MASK 0x4000 /* CODEC_SOFTSD */ 618#define WM8400_CODEC_SOFTSD_SHIFT 14 /* CODEC_SOFTSD */ 619#define WM8400_CODEC_SOFTSD_WIDTH 1 /* CODEC_SOFTSD */ 620#define WM8400_CHIP_SOFTSD 0x2000 /* CHIP_SOFTSD */ 621#define WM8400_CHIP_SOFTSD_MASK 0x2000 /* CHIP_SOFTSD */ 622#define WM8400_CHIP_SOFTSD_SHIFT 13 /* CHIP_SOFTSD */ 623#define WM8400_CHIP_SOFTSD_WIDTH 1 /* CHIP_SOFTSD */ 624#define WM8400_DSLEEP1_POL 0x0008 /* DSLEEP1_POL */ 625#define WM8400_DSLEEP1_POL_MASK 0x0008 /* DSLEEP1_POL */ 626#define WM8400_DSLEEP1_POL_SHIFT 3 /* DSLEEP1_POL */ 627#define WM8400_DSLEEP1_POL_WIDTH 1 /* DSLEEP1_POL */ 628#define WM8400_DSLEEP2_POL 0x0004 /* DSLEEP2_POL */ 629#define WM8400_DSLEEP2_POL_MASK 0x0004 /* DSLEEP2_POL */ 630#define WM8400_DSLEEP2_POL_SHIFT 2 /* DSLEEP2_POL */ 631#define WM8400_DSLEEP2_POL_WIDTH 1 /* DSLEEP2_POL */ 632#define WM8400_PWR_STATE_MASK 0x0003 /* PWR_STATE - [1:0] */ 633#define WM8400_PWR_STATE_SHIFT 0 /* PWR_STATE - [1:0] */ 634#define WM8400_PWR_STATE_WIDTH 2 /* PWR_STATE - [1:0] */ 635 636/* 637 * R78 (0x4E) - PM Shutdown Control 638 */ 639#define WM8400_CHIP_GT150_ERRACT 0x0200 /* CHIP_GT150_ERRACT */ 640#define WM8400_CHIP_GT150_ERRACT_MASK 0x0200 /* CHIP_GT150_ERRACT */ 641#define WM8400_CHIP_GT150_ERRACT_SHIFT 9 /* CHIP_GT150_ERRACT */ 642#define WM8400_CHIP_GT150_ERRACT_WIDTH 1 /* CHIP_GT150_ERRACT */ 643#define WM8400_CHIP_GT115_ERRACT 0x0100 /* CHIP_GT115_ERRACT */ 644#define WM8400_CHIP_GT115_ERRACT_MASK 0x0100 /* CHIP_GT115_ERRACT */ 645#define WM8400_CHIP_GT115_ERRACT_SHIFT 8 /* CHIP_GT115_ERRACT */ 646#define WM8400_CHIP_GT115_ERRACT_WIDTH 1 /* CHIP_GT115_ERRACT */ 647#define WM8400_LINE_CMP_ERRACT 0x0080 /* LINE_CMP_ERRACT */ 648#define WM8400_LINE_CMP_ERRACT_MASK 0x0080 /* LINE_CMP_ERRACT */ 649#define WM8400_LINE_CMP_ERRACT_SHIFT 7 /* LINE_CMP_ERRACT */ 650#define WM8400_LINE_CMP_ERRACT_WIDTH 1 /* LINE_CMP_ERRACT */ 651#define WM8400_UVLO_ERRACT 0x0040 /* UVLO_ERRACT */ 652#define WM8400_UVLO_ERRACT_MASK 0x0040 /* UVLO_ERRACT */ 653#define WM8400_UVLO_ERRACT_SHIFT 6 /* UVLO_ERRACT */ 654#define WM8400_UVLO_ERRACT_WIDTH 1 /* UVLO_ERRACT */ 655 656/* 657 * R79 (0x4F) - Interrupt Status 1 658 */ 659#define WM8400_MICD_CINT 0x8000 /* MICD_CINT */ 660#define WM8400_MICD_CINT_MASK 0x8000 /* MICD_CINT */ 661#define WM8400_MICD_CINT_SHIFT 15 /* MICD_CINT */ 662#define WM8400_MICD_CINT_WIDTH 1 /* MICD_CINT */ 663#define WM8400_MICSCD_CINT 0x4000 /* MICSCD_CINT */ 664#define WM8400_MICSCD_CINT_MASK 0x4000 /* MICSCD_CINT */ 665#define WM8400_MICSCD_CINT_SHIFT 14 /* MICSCD_CINT */ 666#define WM8400_MICSCD_CINT_WIDTH 1 /* MICSCD_CINT */ 667#define WM8400_JDL_CINT 0x2000 /* JDL_CINT */ 668#define WM8400_JDL_CINT_MASK 0x2000 /* JDL_CINT */ 669#define WM8400_JDL_CINT_SHIFT 13 /* JDL_CINT */ 670#define WM8400_JDL_CINT_WIDTH 1 /* JDL_CINT */ 671#define WM8400_JDR_CINT 0x1000 /* JDR_CINT */ 672#define WM8400_JDR_CINT_MASK 0x1000 /* JDR_CINT */ 673#define WM8400_JDR_CINT_SHIFT 12 /* JDR_CINT */ 674#define WM8400_JDR_CINT_WIDTH 1 /* JDR_CINT */ 675#define WM8400_CODEC_SEQ_END_EINT 0x0800 /* CODEC_SEQ_END_EINT */ 676#define WM8400_CODEC_SEQ_END_EINT_MASK 0x0800 /* CODEC_SEQ_END_EINT */ 677#define WM8400_CODEC_SEQ_END_EINT_SHIFT 11 /* CODEC_SEQ_END_EINT */ 678#define WM8400_CODEC_SEQ_END_EINT_WIDTH 1 /* CODEC_SEQ_END_EINT */ 679#define WM8400_CDEL_TO_EINT 0x0400 /* CDEL_TO_EINT */ 680#define WM8400_CDEL_TO_EINT_MASK 0x0400 /* CDEL_TO_EINT */ 681#define WM8400_CDEL_TO_EINT_SHIFT 10 /* CDEL_TO_EINT */ 682#define WM8400_CDEL_TO_EINT_WIDTH 1 /* CDEL_TO_EINT */ 683#define WM8400_CHIP_GT150_EINT 0x0200 /* CHIP_GT150_EINT */ 684#define WM8400_CHIP_GT150_EINT_MASK 0x0200 /* CHIP_GT150_EINT */ 685#define WM8400_CHIP_GT150_EINT_SHIFT 9 /* CHIP_GT150_EINT */ 686#define WM8400_CHIP_GT150_EINT_WIDTH 1 /* CHIP_GT150_EINT */ 687#define WM8400_CHIP_GT115_EINT 0x0100 /* CHIP_GT115_EINT */ 688#define WM8400_CHIP_GT115_EINT_MASK 0x0100 /* CHIP_GT115_EINT */ 689#define WM8400_CHIP_GT115_EINT_SHIFT 8 /* CHIP_GT115_EINT */ 690#define WM8400_CHIP_GT115_EINT_WIDTH 1 /* CHIP_GT115_EINT */ 691#define WM8400_LINE_CMP_EINT 0x0080 /* LINE_CMP_EINT */ 692#define WM8400_LINE_CMP_EINT_MASK 0x0080 /* LINE_CMP_EINT */ 693#define WM8400_LINE_CMP_EINT_SHIFT 7 /* LINE_CMP_EINT */ 694#define WM8400_LINE_CMP_EINT_WIDTH 1 /* LINE_CMP_EINT */ 695#define WM8400_UVLO_EINT 0x0040 /* UVLO_EINT */ 696#define WM8400_UVLO_EINT_MASK 0x0040 /* UVLO_EINT */ 697#define WM8400_UVLO_EINT_SHIFT 6 /* UVLO_EINT */ 698#define WM8400_UVLO_EINT_WIDTH 1 /* UVLO_EINT */ 699#define WM8400_DC2_UV_EINT 0x0020 /* DC2_UV_EINT */ 700#define WM8400_DC2_UV_EINT_MASK 0x0020 /* DC2_UV_EINT */ 701#define WM8400_DC2_UV_EINT_SHIFT 5 /* DC2_UV_EINT */ 702#define WM8400_DC2_UV_EINT_WIDTH 1 /* DC2_UV_EINT */ 703#define WM8400_DC1_UV_EINT 0x0010 /* DC1_UV_EINT */ 704#define WM8400_DC1_UV_EINT_MASK 0x0010 /* DC1_UV_EINT */ 705#define WM8400_DC1_UV_EINT_SHIFT 4 /* DC1_UV_EINT */ 706#define WM8400_DC1_UV_EINT_WIDTH 1 /* DC1_UV_EINT */ 707#define WM8400_LDO4_UV_EINT 0x0008 /* LDO4_UV_EINT */ 708#define WM8400_LDO4_UV_EINT_MASK 0x0008 /* LDO4_UV_EINT */ 709#define WM8400_LDO4_UV_EINT_SHIFT 3 /* LDO4_UV_EINT */ 710#define WM8400_LDO4_UV_EINT_WIDTH 1 /* LDO4_UV_EINT */ 711#define WM8400_LDO3_UV_EINT 0x0004 /* LDO3_UV_EINT */ 712#define WM8400_LDO3_UV_EINT_MASK 0x0004 /* LDO3_UV_EINT */ 713#define WM8400_LDO3_UV_EINT_SHIFT 2 /* LDO3_UV_EINT */ 714#define WM8400_LDO3_UV_EINT_WIDTH 1 /* LDO3_UV_EINT */ 715#define WM8400_LDO2_UV_EINT 0x0002 /* LDO2_UV_EINT */ 716#define WM8400_LDO2_UV_EINT_MASK 0x0002 /* LDO2_UV_EINT */ 717#define WM8400_LDO2_UV_EINT_SHIFT 1 /* LDO2_UV_EINT */ 718#define WM8400_LDO2_UV_EINT_WIDTH 1 /* LDO2_UV_EINT */ 719#define WM8400_LDO1_UV_EINT 0x0001 /* LDO1_UV_EINT */ 720#define WM8400_LDO1_UV_EINT_MASK 0x0001 /* LDO1_UV_EINT */ 721#define WM8400_LDO1_UV_EINT_SHIFT 0 /* LDO1_UV_EINT */ 722#define WM8400_LDO1_UV_EINT_WIDTH 1 /* LDO1_UV_EINT */ 723 724/* 725 * R80 (0x50) - Interrupt Status 1 Mask 726 */ 727#define WM8400_IM_MICD_CINT 0x8000 /* IM_MICD_CINT */ 728#define WM8400_IM_MICD_CINT_MASK 0x8000 /* IM_MICD_CINT */ 729#define WM8400_IM_MICD_CINT_SHIFT 15 /* IM_MICD_CINT */ 730#define WM8400_IM_MICD_CINT_WIDTH 1 /* IM_MICD_CINT */ 731#define WM8400_IM_MICSCD_CINT 0x4000 /* IM_MICSCD_CINT */ 732#define WM8400_IM_MICSCD_CINT_MASK 0x4000 /* IM_MICSCD_CINT */ 733#define WM8400_IM_MICSCD_CINT_SHIFT 14 /* IM_MICSCD_CINT */ 734#define WM8400_IM_MICSCD_CINT_WIDTH 1 /* IM_MICSCD_CINT */ 735#define WM8400_IM_JDL_CINT 0x2000 /* IM_JDL_CINT */ 736#define WM8400_IM_JDL_CINT_MASK 0x2000 /* IM_JDL_CINT */ 737#define WM8400_IM_JDL_CINT_SHIFT 13 /* IM_JDL_CINT */ 738#define WM8400_IM_JDL_CINT_WIDTH 1 /* IM_JDL_CINT */ 739#define WM8400_IM_JDR_CINT 0x1000 /* IM_JDR_CINT */ 740#define WM8400_IM_JDR_CINT_MASK 0x1000 /* IM_JDR_CINT */ 741#define WM8400_IM_JDR_CINT_SHIFT 12 /* IM_JDR_CINT */ 742#define WM8400_IM_JDR_CINT_WIDTH 1 /* IM_JDR_CINT */ 743#define WM8400_IM_CODEC_SEQ_END_EINT 0x0800 /* IM_CODEC_SEQ_END_EINT */ 744#define WM8400_IM_CODEC_SEQ_END_EINT_MASK 0x0800 /* IM_CODEC_SEQ_END_EINT */ 745#define WM8400_IM_CODEC_SEQ_END_EINT_SHIFT 11 /* IM_CODEC_SEQ_END_EINT */ 746#define WM8400_IM_CODEC_SEQ_END_EINT_WIDTH 1 /* IM_CODEC_SEQ_END_EINT */ 747#define WM8400_IM_CDEL_TO_EINT 0x0400 /* IM_CDEL_TO_EINT */ 748#define WM8400_IM_CDEL_TO_EINT_MASK 0x0400 /* IM_CDEL_TO_EINT */ 749#define WM8400_IM_CDEL_TO_EINT_SHIFT 10 /* IM_CDEL_TO_EINT */ 750#define WM8400_IM_CDEL_TO_EINT_WIDTH 1 /* IM_CDEL_TO_EINT */ 751#define WM8400_IM_CHIP_GT150_EINT 0x0200 /* IM_CHIP_GT150_EINT */ 752#define WM8400_IM_CHIP_GT150_EINT_MASK 0x0200 /* IM_CHIP_GT150_EINT */ 753#define WM8400_IM_CHIP_GT150_EINT_SHIFT 9 /* IM_CHIP_GT150_EINT */ 754#define WM8400_IM_CHIP_GT150_EINT_WIDTH 1 /* IM_CHIP_GT150_EINT */ 755#define WM8400_IM_CHIP_GT115_EINT 0x0100 /* IM_CHIP_GT115_EINT */ 756#define WM8400_IM_CHIP_GT115_EINT_MASK 0x0100 /* IM_CHIP_GT115_EINT */ 757#define WM8400_IM_CHIP_GT115_EINT_SHIFT 8 /* IM_CHIP_GT115_EINT */ 758#define WM8400_IM_CHIP_GT115_EINT_WIDTH 1 /* IM_CHIP_GT115_EINT */ 759#define WM8400_IM_LINE_CMP_EINT 0x0080 /* IM_LINE_CMP_EINT */ 760#define WM8400_IM_LINE_CMP_EINT_MASK 0x0080 /* IM_LINE_CMP_EINT */ 761#define WM8400_IM_LINE_CMP_EINT_SHIFT 7 /* IM_LINE_CMP_EINT */ 762#define WM8400_IM_LINE_CMP_EINT_WIDTH 1 /* IM_LINE_CMP_EINT */ 763#define WM8400_IM_UVLO_EINT 0x0040 /* IM_UVLO_EINT */ 764#define WM8400_IM_UVLO_EINT_MASK 0x0040 /* IM_UVLO_EINT */ 765#define WM8400_IM_UVLO_EINT_SHIFT 6 /* IM_UVLO_EINT */ 766#define WM8400_IM_UVLO_EINT_WIDTH 1 /* IM_UVLO_EINT */ 767#define WM8400_IM_DC2_UV_EINT 0x0020 /* IM_DC2_UV_EINT */ 768#define WM8400_IM_DC2_UV_EINT_MASK 0x0020 /* IM_DC2_UV_EINT */ 769#define WM8400_IM_DC2_UV_EINT_SHIFT 5 /* IM_DC2_UV_EINT */ 770#define WM8400_IM_DC2_UV_EINT_WIDTH 1 /* IM_DC2_UV_EINT */ 771#define WM8400_IM_DC1_UV_EINT 0x0010 /* IM_DC1_UV_EINT */ 772#define WM8400_IM_DC1_UV_EINT_MASK 0x0010 /* IM_DC1_UV_EINT */ 773#define WM8400_IM_DC1_UV_EINT_SHIFT 4 /* IM_DC1_UV_EINT */ 774#define WM8400_IM_DC1_UV_EINT_WIDTH 1 /* IM_DC1_UV_EINT */ 775#define WM8400_IM_LDO4_UV_EINT 0x0008 /* IM_LDO4_UV_EINT */ 776#define WM8400_IM_LDO4_UV_EINT_MASK 0x0008 /* IM_LDO4_UV_EINT */ 777#define WM8400_IM_LDO4_UV_EINT_SHIFT 3 /* IM_LDO4_UV_EINT */ 778#define WM8400_IM_LDO4_UV_EINT_WIDTH 1 /* IM_LDO4_UV_EINT */ 779#define WM8400_IM_LDO3_UV_EINT 0x0004 /* IM_LDO3_UV_EINT */ 780#define WM8400_IM_LDO3_UV_EINT_MASK 0x0004 /* IM_LDO3_UV_EINT */ 781#define WM8400_IM_LDO3_UV_EINT_SHIFT 2 /* IM_LDO3_UV_EINT */ 782#define WM8400_IM_LDO3_UV_EINT_WIDTH 1 /* IM_LDO3_UV_EINT */ 783#define WM8400_IM_LDO2_UV_EINT 0x0002 /* IM_LDO2_UV_EINT */ 784#define WM8400_IM_LDO2_UV_EINT_MASK 0x0002 /* IM_LDO2_UV_EINT */ 785#define WM8400_IM_LDO2_UV_EINT_SHIFT 1 /* IM_LDO2_UV_EINT */ 786#define WM8400_IM_LDO2_UV_EINT_WIDTH 1 /* IM_LDO2_UV_EINT */ 787#define WM8400_IM_LDO1_UV_EINT 0x0001 /* IM_LDO1_UV_EINT */ 788#define WM8400_IM_LDO1_UV_EINT_MASK 0x0001 /* IM_LDO1_UV_EINT */ 789#define WM8400_IM_LDO1_UV_EINT_SHIFT 0 /* IM_LDO1_UV_EINT */ 790#define WM8400_IM_LDO1_UV_EINT_WIDTH 1 /* IM_LDO1_UV_EINT */ 791 792/* 793 * R81 (0x51) - Interrupt Levels 794 */ 795#define WM8400_MICD_LVL 0x8000 /* MICD_LVL */ 796#define WM8400_MICD_LVL_MASK 0x8000 /* MICD_LVL */ 797#define WM8400_MICD_LVL_SHIFT 15 /* MICD_LVL */ 798#define WM8400_MICD_LVL_WIDTH 1 /* MICD_LVL */ 799#define WM8400_MICSCD_LVL 0x4000 /* MICSCD_LVL */ 800#define WM8400_MICSCD_LVL_MASK 0x4000 /* MICSCD_LVL */ 801#define WM8400_MICSCD_LVL_SHIFT 14 /* MICSCD_LVL */ 802#define WM8400_MICSCD_LVL_WIDTH 1 /* MICSCD_LVL */ 803#define WM8400_JDL_LVL 0x2000 /* JDL_LVL */ 804#define WM8400_JDL_LVL_MASK 0x2000 /* JDL_LVL */ 805#define WM8400_JDL_LVL_SHIFT 13 /* JDL_LVL */ 806#define WM8400_JDL_LVL_WIDTH 1 /* JDL_LVL */ 807#define WM8400_JDR_LVL 0x1000 /* JDR_LVL */ 808#define WM8400_JDR_LVL_MASK 0x1000 /* JDR_LVL */ 809#define WM8400_JDR_LVL_SHIFT 12 /* JDR_LVL */ 810#define WM8400_JDR_LVL_WIDTH 1 /* JDR_LVL */ 811#define WM8400_CODEC_SEQ_END_LVL 0x0800 /* CODEC_SEQ_END_LVL */ 812#define WM8400_CODEC_SEQ_END_LVL_MASK 0x0800 /* CODEC_SEQ_END_LVL */ 813#define WM8400_CODEC_SEQ_END_LVL_SHIFT 11 /* CODEC_SEQ_END_LVL */ 814#define WM8400_CODEC_SEQ_END_LVL_WIDTH 1 /* CODEC_SEQ_END_LVL */ 815#define WM8400_CDEL_TO_LVL 0x0400 /* CDEL_TO_LVL */ 816#define WM8400_CDEL_TO_LVL_MASK 0x0400 /* CDEL_TO_LVL */ 817#define WM8400_CDEL_TO_LVL_SHIFT 10 /* CDEL_TO_LVL */ 818#define WM8400_CDEL_TO_LVL_WIDTH 1 /* CDEL_TO_LVL */ 819#define WM8400_CHIP_GT150_LVL 0x0200 /* CHIP_GT150_LVL */ 820#define WM8400_CHIP_GT150_LVL_MASK 0x0200 /* CHIP_GT150_LVL */ 821#define WM8400_CHIP_GT150_LVL_SHIFT 9 /* CHIP_GT150_LVL */ 822#define WM8400_CHIP_GT150_LVL_WIDTH 1 /* CHIP_GT150_LVL */ 823#define WM8400_CHIP_GT115_LVL 0x0100 /* CHIP_GT115_LVL */ 824#define WM8400_CHIP_GT115_LVL_MASK 0x0100 /* CHIP_GT115_LVL */ 825#define WM8400_CHIP_GT115_LVL_SHIFT 8 /* CHIP_GT115_LVL */ 826#define WM8400_CHIP_GT115_LVL_WIDTH 1 /* CHIP_GT115_LVL */ 827#define WM8400_LINE_CMP_LVL 0x0080 /* LINE_CMP_LVL */ 828#define WM8400_LINE_CMP_LVL_MASK 0x0080 /* LINE_CMP_LVL */ 829#define WM8400_LINE_CMP_LVL_SHIFT 7 /* LINE_CMP_LVL */ 830#define WM8400_LINE_CMP_LVL_WIDTH 1 /* LINE_CMP_LVL */ 831#define WM8400_UVLO_LVL 0x0040 /* UVLO_LVL */ 832#define WM8400_UVLO_LVL_MASK 0x0040 /* UVLO_LVL */ 833#define WM8400_UVLO_LVL_SHIFT 6 /* UVLO_LVL */ 834#define WM8400_UVLO_LVL_WIDTH 1 /* UVLO_LVL */ 835#define WM8400_DC2_UV_LVL 0x0020 /* DC2_UV_LVL */ 836#define WM8400_DC2_UV_LVL_MASK 0x0020 /* DC2_UV_LVL */ 837#define WM8400_DC2_UV_LVL_SHIFT 5 /* DC2_UV_LVL */ 838#define WM8400_DC2_UV_LVL_WIDTH 1 /* DC2_UV_LVL */ 839#define WM8400_DC1_UV_LVL 0x0010 /* DC1_UV_LVL */ 840#define WM8400_DC1_UV_LVL_MASK 0x0010 /* DC1_UV_LVL */ 841#define WM8400_DC1_UV_LVL_SHIFT 4 /* DC1_UV_LVL */ 842#define WM8400_DC1_UV_LVL_WIDTH 1 /* DC1_UV_LVL */ 843#define WM8400_LDO4_UV_LVL 0x0008 /* LDO4_UV_LVL */ 844#define WM8400_LDO4_UV_LVL_MASK 0x0008 /* LDO4_UV_LVL */ 845#define WM8400_LDO4_UV_LVL_SHIFT 3 /* LDO4_UV_LVL */ 846#define WM8400_LDO4_UV_LVL_WIDTH 1 /* LDO4_UV_LVL */ 847#define WM8400_LDO3_UV_LVL 0x0004 /* LDO3_UV_LVL */ 848#define WM8400_LDO3_UV_LVL_MASK 0x0004 /* LDO3_UV_LVL */ 849#define WM8400_LDO3_UV_LVL_SHIFT 2 /* LDO3_UV_LVL */ 850#define WM8400_LDO3_UV_LVL_WIDTH 1 /* LDO3_UV_LVL */ 851#define WM8400_LDO2_UV_LVL 0x0002 /* LDO2_UV_LVL */ 852#define WM8400_LDO2_UV_LVL_MASK 0x0002 /* LDO2_UV_LVL */ 853#define WM8400_LDO2_UV_LVL_SHIFT 1 /* LDO2_UV_LVL */ 854#define WM8400_LDO2_UV_LVL_WIDTH 1 /* LDO2_UV_LVL */ 855#define WM8400_LDO1_UV_LVL 0x0001 /* LDO1_UV_LVL */ 856#define WM8400_LDO1_UV_LVL_MASK 0x0001 /* LDO1_UV_LVL */ 857#define WM8400_LDO1_UV_LVL_SHIFT 0 /* LDO1_UV_LVL */ 858#define WM8400_LDO1_UV_LVL_WIDTH 1 /* LDO1_UV_LVL */ 859 860/* 861 * R82 (0x52) - Shutdown Reason 862 */ 863#define WM8400_SDR_CHIP_SOFTSD 0x2000 /* SDR_CHIP_SOFTSD */ 864#define WM8400_SDR_CHIP_SOFTSD_MASK 0x2000 /* SDR_CHIP_SOFTSD */ 865#define WM8400_SDR_CHIP_SOFTSD_SHIFT 13 /* SDR_CHIP_SOFTSD */ 866#define WM8400_SDR_CHIP_SOFTSD_WIDTH 1 /* SDR_CHIP_SOFTSD */ 867#define WM8400_SDR_NPDN 0x0800 /* SDR_NPDN */ 868#define WM8400_SDR_NPDN_MASK 0x0800 /* SDR_NPDN */ 869#define WM8400_SDR_NPDN_SHIFT 11 /* SDR_NPDN */ 870#define WM8400_SDR_NPDN_WIDTH 1 /* SDR_NPDN */ 871#define WM8400_SDR_CHIP_GT150 0x0200 /* SDR_CHIP_GT150 */ 872#define WM8400_SDR_CHIP_GT150_MASK 0x0200 /* SDR_CHIP_GT150 */ 873#define WM8400_SDR_CHIP_GT150_SHIFT 9 /* SDR_CHIP_GT150 */ 874#define WM8400_SDR_CHIP_GT150_WIDTH 1 /* SDR_CHIP_GT150 */ 875#define WM8400_SDR_CHIP_GT115 0x0100 /* SDR_CHIP_GT115 */ 876#define WM8400_SDR_CHIP_GT115_MASK 0x0100 /* SDR_CHIP_GT115 */ 877#define WM8400_SDR_CHIP_GT115_SHIFT 8 /* SDR_CHIP_GT115 */ 878#define WM8400_SDR_CHIP_GT115_WIDTH 1 /* SDR_CHIP_GT115 */ 879#define WM8400_SDR_LINE_CMP 0x0080 /* SDR_LINE_CMP */ 880#define WM8400_SDR_LINE_CMP_MASK 0x0080 /* SDR_LINE_CMP */ 881#define WM8400_SDR_LINE_CMP_SHIFT 7 /* SDR_LINE_CMP */ 882#define WM8400_SDR_LINE_CMP_WIDTH 1 /* SDR_LINE_CMP */ 883#define WM8400_SDR_UVLO 0x0040 /* SDR_UVLO */ 884#define WM8400_SDR_UVLO_MASK 0x0040 /* SDR_UVLO */ 885#define WM8400_SDR_UVLO_SHIFT 6 /* SDR_UVLO */ 886#define WM8400_SDR_UVLO_WIDTH 1 /* SDR_UVLO */ 887#define WM8400_SDR_DC2_UV 0x0020 /* SDR_DC2_UV */ 888#define WM8400_SDR_DC2_UV_MASK 0x0020 /* SDR_DC2_UV */ 889#define WM8400_SDR_DC2_UV_SHIFT 5 /* SDR_DC2_UV */ 890#define WM8400_SDR_DC2_UV_WIDTH 1 /* SDR_DC2_UV */ 891#define WM8400_SDR_DC1_UV 0x0010 /* SDR_DC1_UV */ 892#define WM8400_SDR_DC1_UV_MASK 0x0010 /* SDR_DC1_UV */ 893#define WM8400_SDR_DC1_UV_SHIFT 4 /* SDR_DC1_UV */ 894#define WM8400_SDR_DC1_UV_WIDTH 1 /* SDR_DC1_UV */ 895#define WM8400_SDR_LDO4_UV 0x0008 /* SDR_LDO4_UV */ 896#define WM8400_SDR_LDO4_UV_MASK 0x0008 /* SDR_LDO4_UV */ 897#define WM8400_SDR_LDO4_UV_SHIFT 3 /* SDR_LDO4_UV */ 898#define WM8400_SDR_LDO4_UV_WIDTH 1 /* SDR_LDO4_UV */ 899#define WM8400_SDR_LDO3_UV 0x0004 /* SDR_LDO3_UV */ 900#define WM8400_SDR_LDO3_UV_MASK 0x0004 /* SDR_LDO3_UV */ 901#define WM8400_SDR_LDO3_UV_SHIFT 2 /* SDR_LDO3_UV */ 902#define WM8400_SDR_LDO3_UV_WIDTH 1 /* SDR_LDO3_UV */ 903#define WM8400_SDR_LDO2_UV 0x0002 /* SDR_LDO2_UV */ 904#define WM8400_SDR_LDO2_UV_MASK 0x0002 /* SDR_LDO2_UV */ 905#define WM8400_SDR_LDO2_UV_SHIFT 1 /* SDR_LDO2_UV */ 906#define WM8400_SDR_LDO2_UV_WIDTH 1 /* SDR_LDO2_UV */ 907#define WM8400_SDR_LDO1_UV 0x0001 /* SDR_LDO1_UV */ 908#define WM8400_SDR_LDO1_UV_MASK 0x0001 /* SDR_LDO1_UV */ 909#define WM8400_SDR_LDO1_UV_SHIFT 0 /* SDR_LDO1_UV */ 910#define WM8400_SDR_LDO1_UV_WIDTH 1 /* SDR_LDO1_UV */ 911 912/* 913 * R84 (0x54) - Line Circuits 914 */ 915#define WM8400_BG_LINE_COMP 0x8000 /* BG_LINE_COMP */ 916#define WM8400_BG_LINE_COMP_MASK 0x8000 /* BG_LINE_COMP */ 917#define WM8400_BG_LINE_COMP_SHIFT 15 /* BG_LINE_COMP */ 918#define WM8400_BG_LINE_COMP_WIDTH 1 /* BG_LINE_COMP */ 919#define WM8400_LINE_CMP_VTHI_MASK 0x00F0 /* LINE_CMP_VTHI - [7:4] */ 920#define WM8400_LINE_CMP_VTHI_SHIFT 4 /* LINE_CMP_VTHI - [7:4] */ 921#define WM8400_LINE_CMP_VTHI_WIDTH 4 /* LINE_CMP_VTHI - [7:4] */ 922#define WM8400_LINE_CMP_VTHD_MASK 0x000F /* LINE_CMP_VTHD - [3:0] */ 923#define WM8400_LINE_CMP_VTHD_SHIFT 0 /* LINE_CMP_VTHD - [3:0] */ 924#define WM8400_LINE_CMP_VTHD_WIDTH 4 /* LINE_CMP_VTHD - [3:0] */ 925 926u16 wm8400_reg_read(struct wm8400 *wm8400, u8 reg); 927int wm8400_block_read(struct wm8400 *wm8400, u8 reg, int count, u16 *data); 928 929static inline int wm8400_set_bits(struct wm8400 *wm8400, u8 reg, 930 u16 mask, u16 val) 931{ 932 return regmap_update_bits(wm8400->regmap, reg, mask, val); 933} 934 935#endif 936