123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175 |
- /*
- * Arizona MFD internals
- *
- * Copyright 2012 Wolfson Microelectronics plc
- *
- * Author: Mark Brown <broonie@opensource.wolfsonmicro.com>
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License version 2 as
- * published by the Free Software Foundation.
- */
- #ifndef _WM_ARIZONA_CORE_H
- #define _WM_ARIZONA_CORE_H
- #include <linux/interrupt.h>
- #include <linux/regmap.h>
- #include <linux/regulator/consumer.h>
- #include <linux/mfd/arizona/pdata.h>
- #define ARIZONA_MAX_CORE_SUPPLIES 2
- enum arizona_type {
- WM5102 = 1,
- WM5110 = 2,
- WM8997 = 3,
- WM8280 = 4,
- WM8998 = 5,
- WM1814 = 6,
- };
- #define ARIZONA_IRQ_GP1 0
- #define ARIZONA_IRQ_GP2 1
- #define ARIZONA_IRQ_GP3 2
- #define ARIZONA_IRQ_GP4 3
- #define ARIZONA_IRQ_GP5_FALL 4
- #define ARIZONA_IRQ_GP5_RISE 5
- #define ARIZONA_IRQ_JD_FALL 6
- #define ARIZONA_IRQ_JD_RISE 7
- #define ARIZONA_IRQ_DSP1_RAM_RDY 8
- #define ARIZONA_IRQ_DSP2_RAM_RDY 9
- #define ARIZONA_IRQ_DSP3_RAM_RDY 10
- #define ARIZONA_IRQ_DSP4_RAM_RDY 11
- #define ARIZONA_IRQ_DSP_IRQ1 12
- #define ARIZONA_IRQ_DSP_IRQ2 13
- #define ARIZONA_IRQ_DSP_IRQ3 14
- #define ARIZONA_IRQ_DSP_IRQ4 15
- #define ARIZONA_IRQ_DSP_IRQ5 16
- #define ARIZONA_IRQ_DSP_IRQ6 17
- #define ARIZONA_IRQ_DSP_IRQ7 18
- #define ARIZONA_IRQ_DSP_IRQ8 19
- #define ARIZONA_IRQ_SPK_OVERHEAT_WARN 20
- #define ARIZONA_IRQ_SPK_OVERHEAT 21
- #define ARIZONA_IRQ_MICDET 22
- #define ARIZONA_IRQ_HPDET 23
- #define ARIZONA_IRQ_WSEQ_DONE 24
- #define ARIZONA_IRQ_DRC2_SIG_DET 25
- #define ARIZONA_IRQ_DRC1_SIG_DET 26
- #define ARIZONA_IRQ_ASRC2_LOCK 27
- #define ARIZONA_IRQ_ASRC1_LOCK 28
- #define ARIZONA_IRQ_UNDERCLOCKED 29
- #define ARIZONA_IRQ_OVERCLOCKED 30
- #define ARIZONA_IRQ_FLL2_LOCK 31
- #define ARIZONA_IRQ_FLL1_LOCK 32
- #define ARIZONA_IRQ_CLKGEN_ERR 33
- #define ARIZONA_IRQ_CLKGEN_ERR_ASYNC 34
- #define ARIZONA_IRQ_ASRC_CFG_ERR 35
- #define ARIZONA_IRQ_AIF3_ERR 36
- #define ARIZONA_IRQ_AIF2_ERR 37
- #define ARIZONA_IRQ_AIF1_ERR 38
- #define ARIZONA_IRQ_CTRLIF_ERR 39
- #define ARIZONA_IRQ_MIXER_DROPPED_SAMPLES 40
- #define ARIZONA_IRQ_ASYNC_CLK_ENA_LOW 41
- #define ARIZONA_IRQ_SYSCLK_ENA_LOW 42
- #define ARIZONA_IRQ_ISRC1_CFG_ERR 43
- #define ARIZONA_IRQ_ISRC2_CFG_ERR 44
- #define ARIZONA_IRQ_BOOT_DONE 45
- #define ARIZONA_IRQ_DCS_DAC_DONE 46
- #define ARIZONA_IRQ_DCS_HP_DONE 47
- #define ARIZONA_IRQ_FLL2_CLOCK_OK 48
- #define ARIZONA_IRQ_FLL1_CLOCK_OK 49
- #define ARIZONA_IRQ_MICD_CLAMP_RISE 50
- #define ARIZONA_IRQ_MICD_CLAMP_FALL 51
- #define ARIZONA_IRQ_HP3R_DONE 52
- #define ARIZONA_IRQ_HP3L_DONE 53
- #define ARIZONA_IRQ_HP2R_DONE 54
- #define ARIZONA_IRQ_HP2L_DONE 55
- #define ARIZONA_IRQ_HP1R_DONE 56
- #define ARIZONA_IRQ_HP1L_DONE 57
- #define ARIZONA_IRQ_ISRC3_CFG_ERR 58
- #define ARIZONA_IRQ_DSP_SHARED_WR_COLL 59
- #define ARIZONA_IRQ_SPK_SHUTDOWN 60
- #define ARIZONA_IRQ_SPK1R_SHORT 61
- #define ARIZONA_IRQ_SPK1L_SHORT 62
- #define ARIZONA_IRQ_HP3R_SC_NEG 63
- #define ARIZONA_IRQ_HP3R_SC_POS 64
- #define ARIZONA_IRQ_HP3L_SC_NEG 65
- #define ARIZONA_IRQ_HP3L_SC_POS 66
- #define ARIZONA_IRQ_HP2R_SC_NEG 67
- #define ARIZONA_IRQ_HP2R_SC_POS 68
- #define ARIZONA_IRQ_HP2L_SC_NEG 69
- #define ARIZONA_IRQ_HP2L_SC_POS 70
- #define ARIZONA_IRQ_HP1R_SC_NEG 71
- #define ARIZONA_IRQ_HP1R_SC_POS 72
- #define ARIZONA_IRQ_HP1L_SC_NEG 73
- #define ARIZONA_IRQ_HP1L_SC_POS 74
- #define ARIZONA_NUM_IRQ 75
- struct snd_soc_dapm_context;
- struct arizona {
- struct regmap *regmap;
- struct device *dev;
- enum arizona_type type;
- unsigned int rev;
- int num_core_supplies;
- struct regulator_bulk_data core_supplies[ARIZONA_MAX_CORE_SUPPLIES];
- struct regulator *dcvdd;
- bool has_fully_powered_off;
- struct arizona_pdata pdata;
- unsigned int external_dcvdd:1;
- int irq;
- struct irq_domain *virq;
- struct regmap_irq_chip_data *aod_irq_chip;
- struct regmap_irq_chip_data *irq_chip;
- bool hpdet_clamp;
- unsigned int hp_ena;
- struct mutex clk_lock;
- int clk32k_ref;
- bool ctrlif_error;
- struct snd_soc_dapm_context *dapm;
- int tdm_width[ARIZONA_MAX_AIF];
- int tdm_slots[ARIZONA_MAX_AIF];
- uint16_t dac_comp_coeff;
- uint8_t dac_comp_enabled;
- struct mutex dac_comp_lock;
- };
- int arizona_clk32k_enable(struct arizona *arizona);
- int arizona_clk32k_disable(struct arizona *arizona);
- int arizona_request_irq(struct arizona *arizona, int irq, char *name,
- irq_handler_t handler, void *data);
- void arizona_free_irq(struct arizona *arizona, int irq, void *data);
- int arizona_set_irq_wake(struct arizona *arizona, int irq, int on);
- #ifdef CONFIG_MFD_WM5102
- int wm5102_patch(struct arizona *arizona);
- #else
- static inline int wm5102_patch(struct arizona *arizona)
- {
- return 0;
- }
- #endif
- int wm5110_patch(struct arizona *arizona);
- int wm8997_patch(struct arizona *arizona);
- int wm8998_patch(struct arizona *arizona);
- extern int arizona_of_get_named_gpio(struct arizona *arizona, const char *prop,
- bool mandatory);
- #endif
|