Message ID | 1609935546-11722-3-git-send-email-argus.lin@mediatek.com (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
Series | Add mediatek MT6359 accdet driver | expand |
On Wed, Jan 06, 2021 at 08:19:06PM +0800, Argus Lin wrote: > MT6359 audio codec support accessory detect features, adds MT6359 > accdet driver to support plug detection and key detection. > --- > sound/soc/codecs/Kconfig | 7 + > sound/soc/codecs/Makefile | 2 + > sound/soc/codecs/mt6359-accdet.c | 1951 ++++++++++++++++++++++++++++++++++++++ > sound/soc/codecs/mt6359-accdet.h | 136 +++ > sound/soc/codecs/mt6359.h | 1863 +++++++++++++++++++++++++++++++++--- This driver is *huge*. Looking through the code it feels like there's a lot of things that are written with mostly duplicated code that differs only in data so you could shrink things down a lot by refactoring things to have one copy of the code and pass different data into it. > Enable support for the platform which uses MT6359 as > external codec device. > +config SND_SOC_MT6359_ACCDET Missing blank line here. > +++ b/sound/soc/codecs/mt6359-accdet.c > @@ -0,0 +1,1951 @@ > +// SPDX-License-Identifier: GPL-2.0 > +/* > + * Copyright (C) 2021 MediaTek Inc. Please make the entire comment a C++ one so things look more intentional. > +#include "mt6359-accdet.h" > +#include "mt6359.h" > +/* grobal variable definitions */ Spelling mistake and you need more blank lines here. > +#define REGISTER_VAL(x) ((x) - 1) > +#define HAS_CAP(_c, _x) \ > + ({typeof(_c)c = (_c); \ > + typeof(_x)x = (_x); \ > + (((c) & (x)) == (x)); }) These need namepsacing. > +static struct mt63xx_accdet_data *accdet; > + > +static struct head_dts_data accdet_dts; > +struct pwm_deb_settings *cust_pwm_deb; You'd need a *very* good reason to be using global data rather than storing anything in the device's driver data like most drivers. There's extensive use of global data here, and lots of raw pr_ prints rather than dev_ prints as well - this doesn't look like how a Linux driver is supposed to be written. > + > +const struct of_device_id mt6359_accdet_of_match[] = { > + { > + .compatible = "mediatek,mt6359-accdet", > + .data = &mt6359_accdet, Given that this is specific to a particular PMIC why does this need a compatible string? > +/* global function declaration */ > + > +static u64 mt6359_accdet_get_current_time(void) > +{ > + return sched_clock(); > +} It is probably best to remove this wrapper. > +static bool mt6359_accdet_timeout_ns(u64 start_time_ns, u64 timeout_time_ns) > +{ > + u64 cur_time = 0; > + u64 elapse_time = 0; > + > + /* get current tick, ns */ > + cur_time = mt6359_accdet_get_current_time(); > + if (cur_time < start_time_ns) { > + start_time_ns = cur_time; > + /* 400us */ > + timeout_time_ns = 400 * 1000; > + } > + elapse_time = cur_time - start_time_ns; > + > + /* check if timeout */ > + if (timeout_time_ns <= elapse_time) > + return false; > + > + return true; > +} There must be a generic implementation of this already surely? > +static unsigned int check_key(unsigned int v) > +{ This looks a lot like open coding of the functionality of the extcon adc_jack functionality. > +static void send_key_event(unsigned int keycode, unsigned int flag) > +{ > + int report = 0; > + > + switch (keycode) { > + case DW_KEY: > + if (flag != 0) > + report = SND_JACK_BTN_1; What does flag mean? At the very least it needs renaming. > +static void send_status_event(unsigned int cable_type, unsigned int status) > +{ > + int report = 0; This is one of those places that looks like it could be code with different data passed in. > + > + switch (cable_type) { > + case HEADSET_NO_MIC: > + if (status) > + report = SND_JACK_HEADPHONE; > + else > + report = 0; > + snd_soc_jack_report(&accdet->jack, report, SND_JACK_HEADPHONE); > + /* when plug 4-pole out, if both AB=3 AB=0 happen,3-pole plug > + * in will be incorrectly reported, then 3-pole plug-out is > + * reported,if no mantory 4-pole plug-out, icon would be > + * visible. > + */ > + if (status == 0) { > + report = 0; > + snd_soc_jack_report(&accdet->jack, report, SND_JACK_MICROPHONE); > + } > + pr_info("accdet HEADPHONE(3-pole) %s\n", > + status ? "PlugIn" : "PlugOut"); You shouldn't be spamming the logs for normal events like this. > + regmap_read(accdet->regmap, ACCDET_IRQ_ADDR, &val); > + while (val & ACCDET_IRQ_MASK_SFT && > + mt6359_accdet_timeout_ns(cur_time, ACCDET_TIME_OUT)) > + ; This is open coding regmap_read_poll_timeout(), this pattern is repeated in several places. > +static inline void clear_accdet_eint(unsigned int eintid) > +{ > + if ((eintid & PMIC_EINT0) == PMIC_EINT0) { The == part is redundant here, and again this is another place where it feels like there's duplicated code that should be using data. All this interrupt handling code is really extremely difficult to follow, there's *lots* of functions all open coding many individual register bits sometimes redundantly and it's very hard to follow what it's supposed to be doing. I can't help but think that in addition to making things data driven writing more linear code without these abstraction layers would help a lot with comprehensibility. > +static irqreturn_t mtk_accdet_irq_handler_thread(int irq, void *data) > +{ > + accdet_irq_handle(); > + > + return IRQ_HANDLED; > +} Why does this wrapper function exist - AFAICT it's just introducing a bug given that the called function is able to detect spurious interrupts but this unconditionally reports IRQ_HANDLED. > +int mt6359_accdet_init(struct snd_soc_component *component, > + struct snd_soc_card *card) > +{ > + int ret = 0; > + struct mt63xx_accdet_data *priv = > + snd_soc_card_get_drvdata(component->card); > + > + return ret; > +} > +EXPORT_SYMBOL_GPL(mt6359_accdet_init); This is a weird interface, what's going on here? > +int mt6359_accdet_set_drvdata(struct snd_soc_card *card) > +{ > + snd_soc_card_set_drvdata(card, accdet); > + > + return 0; > +} > +EXPORT_SYMBOL_GPL(mt6359_accdet_set_drvdata); This is setting off *massive* alarm bells in that it seems to try to claim the card level driver data for this specific driver, again what's going on here? > +module_init(mt6359_accdet_soc_init); > +module_exit(mt6359_accdet_soc_exit); module_platform_driver()
Dear maintainers: Can you reply to me if any opinion? thanks B.R. Argus On Wed, 2021-01-06 at 20:19 +0800, Argus Lin wrote: > MT6359 audio codec support accessory detect features, adds MT6359 > accdet driver to support plug detection and key detection. > > Signed-off-by: Argus Lin <argus.lin@mediatek.com> > --- > sound/soc/codecs/Kconfig | 7 + > sound/soc/codecs/Makefile | 2 + > sound/soc/codecs/mt6359-accdet.c | 1951 ++++++++++++++++++++++++++++++++++++++ > sound/soc/codecs/mt6359-accdet.h | 136 +++ > sound/soc/codecs/mt6359.h | 1863 +++++++++++++++++++++++++++++++++--- > 5 files changed, 3853 insertions(+), 106 deletions(-) > create mode 100644 sound/soc/codecs/mt6359-accdet.c > create mode 100644 sound/soc/codecs/mt6359-accdet.h > > diff --git a/sound/soc/codecs/Kconfig b/sound/soc/codecs/Kconfig > index ba4eb54..dbf3141 100644 > --- a/sound/soc/codecs/Kconfig > +++ b/sound/soc/codecs/Kconfig > @@ -1774,6 +1774,13 @@ config SND_SOC_MT6359 > help > Enable support for the platform which uses MT6359 as > external codec device. > +config SND_SOC_MT6359_ACCDET > + tristate "MediaTek MT6359 ACCDET driver" > + depends on MTK_PMIC_WRAP > + help > + ACCDET means Accessory Detection technology, MediaTek develop it > + for ASoC codec soc-jack detection mechanism. > + Select N if you don't have jack on board. > > config SND_SOC_MT6660 > tristate "Mediatek MT6660 Speaker Amplifier" > diff --git a/sound/soc/codecs/Makefile b/sound/soc/codecs/Makefile > index d277f03..f77d057 100644 > --- a/sound/soc/codecs/Makefile > +++ b/sound/soc/codecs/Makefile > @@ -133,6 +133,7 @@ snd-soc-msm8916-digital-objs := msm8916-wcd-digital.o > snd-soc-mt6351-objs := mt6351.o > snd-soc-mt6358-objs := mt6358.o > snd-soc-mt6359-objs := mt6359.o > +snd-soc-mt6359-accdet-objs := mt6359-accdet.o > snd-soc-mt6660-objs := mt6660.o > snd-soc-nau8315-objs := nau8315.o > snd-soc-nau8540-objs := nau8540.o > @@ -448,6 +449,7 @@ obj-$(CONFIG_SND_SOC_MSM8916_WCD_DIGITAL) +=snd-soc-msm8916-digital.o > obj-$(CONFIG_SND_SOC_MT6351) += snd-soc-mt6351.o > obj-$(CONFIG_SND_SOC_MT6358) += snd-soc-mt6358.o > obj-$(CONFIG_SND_SOC_MT6359) += snd-soc-mt6359.o > +obj-$(CONFIG_SND_SOC_MT6359_ACCDET) += mt6359-accdet.o > obj-$(CONFIG_SND_SOC_MT6660) += snd-soc-mt6660.o > obj-$(CONFIG_SND_SOC_NAU8315) += snd-soc-nau8315.o > obj-$(CONFIG_SND_SOC_NAU8540) += snd-soc-nau8540.o > diff --git a/sound/soc/codecs/mt6359-accdet.c b/sound/soc/codecs/mt6359-accdet.c > new file mode 100644 > index 0000000..ff90e4e > --- /dev/null > +++ b/sound/soc/codecs/mt6359-accdet.c > @@ -0,0 +1,1951 @@ > +// SPDX-License-Identifier: GPL-2.0 > +/* > + * Copyright (C) 2021 MediaTek Inc. > + * Author: Argus Lin <argus.lin@mediatek.com> > + */ > + > +#include <linux/of_gpio.h> > +#include <linux/of.h> > +#include <linux/of_irq.h> > +#include <linux/of_device.h> > +#include <linux/of_address.h> > +#include <linux/input.h> > +#include <linux/kthread.h> > +#include <linux/io.h> > +#include <linux/sched/clock.h> > +#include <linux/workqueue.h> > +#include <linux/timer.h> > +#include <linux/delay.h> > +#include <linux/module.h> > +#include <linux/platform_device.h> > +#include <linux/init.h> > +#include <linux/irqdomain.h> > +#include <linux/irq.h> > +#include <linux/regmap.h> > +#include <sound/soc.h> > +#include <sound/jack.h> > +#include <linux/mfd/mt6397/core.h> > +#include "mt6359-accdet.h" > +#include "mt6359.h" > +/* grobal variable definitions */ > +#define REGISTER_VAL(x) ((x) - 1) > +#define HAS_CAP(_c, _x) \ > + ({typeof(_c)c = (_c); \ > + typeof(_x)x = (_x); \ > + (((c) & (x)) == (x)); }) > +#define ACCDET_PMIC_EINT_IRQ BIT(0) > +#define ACCDET_AP_GPIO_EINT BIT(1) > + > +#define ACCDET_PMIC_EINT0 BIT(2) > +#define ACCDET_PMIC_EINT1 BIT(3) > +#define ACCDET_PMIC_BI_EINT BIT(4) > + > +#define ACCDET_PMIC_GPIO_TRIG_EINT BIT(5) > +#define ACCDET_PMIC_INVERTER_TRIG_EINT BIT(6) > +#define ACCDET_PMIC_RSV_EINT BIT(7) > + > +#define ACCDET_THREE_KEY BIT(8) > +#define ACCDET_FOUR_KEY BIT(9) > +#define ACCDET_TRI_KEY_CDD BIT(10) > +#define ACCDET_RSV_KEY BIT(11) > + > +#define ACCDET_ANALOG_FASTDISCHARGE BIT(12) > +#define ACCDET_DIGITAL_FASTDISCHARGE BIT(13) > +#define ACCDET_AD_FASTDISCHRAGE BIT(14) > + > +#define RET_LT_5K (-1) > +#define RET_GT_5K (0) > + > +/* Used to let accdet know if the pin has been fully plugged-in */ > +#define EINT_PLUG_OUT (0) > +#define EINT_PLUG_IN (1) > + > +struct mt63xx_accdet_data { > + struct snd_soc_jack jack; > + struct platform_device *pdev; > + struct device *dev; > + struct accdet_priv *data; > + atomic_t init_once; > + struct regmap *regmap; > + int accdet_irq; > + int accdet_eint0; > + int accdet_eint1; > + struct wakeup_source *wake_lock; > + struct wakeup_source *timer_lock; > + struct mutex res_lock; /* lock to protect flag */ > + bool eint_sync_flag; > + /* accdet FSM State & lock*/ > + unsigned int cur_eint_state; > + unsigned int eint0_state; > + unsigned int eint1_state; > + unsigned int accdet_status; > + unsigned int cable_type; > + unsigned int cur_key; > + unsigned int cali_voltage; > + int auxadc_offset; > + unsigned int eint_id; > + /* when caps include ACCDET_AP_GPIO_EINT */ > + struct pinctrl *pinctrl; > + struct pinctrl_state *pins_eint; > + unsigned int gpiopin; > + unsigned int gpio_hp_deb; > + unsigned int gpioirq; > + unsigned int accdet_eint_type; > + /* when MICBIAS_DISABLE_TIMER timeout, queue work: dis_micbias_work */ > + struct work_struct delay_init_work; > + struct workqueue_struct *delay_init_workqueue; > + struct work_struct dis_micbias_work; > + struct workqueue_struct *dis_micbias_workqueue; > + struct work_struct accdet_work; > + struct workqueue_struct *accdet_workqueue; > + /* when eint issued, queue work: eint_work */ > + struct work_struct eint_work; > + struct workqueue_struct *eint_workqueue; > +}; > + > +static struct mt63xx_accdet_data *accdet; > + > +static struct head_dts_data accdet_dts; > +struct pwm_deb_settings *cust_pwm_deb; > + > +struct accdet_priv { > + unsigned int caps; > +}; > + > +static struct accdet_priv mt6359_accdet[] = { > + { > + .caps = 0, > + }, > +}; > + > +const struct of_device_id mt6359_accdet_of_match[] = { > + { > + .compatible = "mediatek,mt6359-accdet", > + .data = &mt6359_accdet, > + }, { > + /* sentinel */ > + }, > +}; > + > +static struct platform_driver mt6359_accdet_driver; > +static const struct snd_soc_component_driver mt6359_accdet_soc_driver; > + > +#define ACCDET_INIT_WAIT_TIMER (10 * HZ) > +static struct timer_list accdet_init_timer; > +static void delay_init_timerhandler(struct timer_list *t); > +/* micbias_timer: disable micbias if no accdet irq after eint, > + * timeout: 6 seconds > + * timerHandler: dis_micbias_timerhandler() > + */ > +#define MICBIAS_DISABLE_TIMER (6 * HZ) > +static struct timer_list micbias_timer; > +static void dis_micbias_timerhandler(struct timer_list *t); > + > +static unsigned int button_press_debounce = 0x400; > +static unsigned int button_press_debounce_01 = 0x800; > + > +/* local function declaration */ > +static void accdet_init_once(void); > +static inline void accdet_init(void); > +static void accdet_init_debounce(void); > +static unsigned int adjust_eint_analog_setting(void); > +static unsigned int adjust_eint_setting(unsigned int eintsts); > +static void config_digital_init_by_mode(void); > +static void config_eint_init_by_mode(void); > +static unsigned int get_triggered_eint(void); > +static void recover_eint_analog_setting(void); > +static void recover_eint_digital_setting(void); > +static void recover_eint_setting(unsigned int eintsts); > +static void send_status_event(unsigned int cable_type, unsigned int status); > +static void accdet_set_debounce(int state, unsigned int debounce); > + > +/* global function declaration */ > + > +static u64 mt6359_accdet_get_current_time(void) > +{ > + return sched_clock(); > +} > + > +static bool mt6359_accdet_timeout_ns(u64 start_time_ns, u64 timeout_time_ns) > +{ > + u64 cur_time = 0; > + u64 elapse_time = 0; > + > + /* get current tick, ns */ > + cur_time = mt6359_accdet_get_current_time(); > + if (cur_time < start_time_ns) { > + start_time_ns = cur_time; > + /* 400us */ > + timeout_time_ns = 400 * 1000; > + } > + elapse_time = cur_time - start_time_ns; > + > + /* check if timeout */ > + if (timeout_time_ns <= elapse_time) > + return false; > + > + return true; > +} > + > +static unsigned int check_key(unsigned int v) > +{ > + if (HAS_CAP(accdet->data->caps, ACCDET_FOUR_KEY)) { > + if (v < accdet_dts.four_key.down && v >= accdet_dts.four_key.up) > + return DW_KEY; > + if (v < accdet_dts.four_key.up && v >= accdet_dts.four_key.voice) > + return UP_KEY; > + if (v < accdet_dts.four_key.voice && v >= accdet_dts.four_key.mid) > + return AS_KEY; > + if (v < accdet_dts.four_key.mid) > + return MD_KEY; > + } else { > + if (v < accdet_dts.three_key.down && v >= accdet_dts.three_key.up) > + return DW_KEY; > + if (v < accdet_dts.three_key.up && v >= accdet_dts.three_key.mid) > + return UP_KEY; > + if (v < accdet_dts.three_key.mid) > + return MD_KEY; > + } > + return NO_KEY; > +} > + > +static void send_key_event(unsigned int keycode, unsigned int flag) > +{ > + int report = 0; > + > + switch (keycode) { > + case DW_KEY: > + if (flag != 0) > + report = SND_JACK_BTN_1; > + snd_soc_jack_report(&accdet->jack, report, SND_JACK_BTN_1); > + break; > + case UP_KEY: > + if (flag != 0) > + report = SND_JACK_BTN_2; > + snd_soc_jack_report(&accdet->jack, report, SND_JACK_BTN_2); > + break; > + case MD_KEY: > + if (flag != 0) > + report = SND_JACK_BTN_0; > + snd_soc_jack_report(&accdet->jack, report, SND_JACK_BTN_0); > + break; > + case AS_KEY: > + if (flag != 0) > + report = SND_JACK_BTN_3; > + snd_soc_jack_report(&accdet->jack, report, SND_JACK_BTN_3); > + break; > + } > +} > + > +static void send_status_event(unsigned int cable_type, unsigned int status) > +{ > + int report = 0; > + > + switch (cable_type) { > + case HEADSET_NO_MIC: > + if (status) > + report = SND_JACK_HEADPHONE; > + else > + report = 0; > + snd_soc_jack_report(&accdet->jack, report, SND_JACK_HEADPHONE); > + /* when plug 4-pole out, if both AB=3 AB=0 happen,3-pole plug > + * in will be incorrectly reported, then 3-pole plug-out is > + * reported,if no mantory 4-pole plug-out, icon would be > + * visible. > + */ > + if (status == 0) { > + report = 0; > + snd_soc_jack_report(&accdet->jack, report, SND_JACK_MICROPHONE); > + } > + pr_info("accdet HEADPHONE(3-pole) %s\n", > + status ? "PlugIn" : "PlugOut"); > + break; > + case HEADSET_MIC: > + /* when plug 4-pole out, 3-pole plug out should also be > + * reported for slow plug-in case > + */ > + if (status == 0) { > + report = 0; > + snd_soc_jack_report(&accdet->jack, report, SND_JACK_HEADPHONE); > + } > + if (status) > + report = SND_JACK_MICROPHONE; > + else > + report = 0; > + > + snd_soc_jack_report(&accdet->jack, report, SND_JACK_MICROPHONE); > + pr_info("accdet MICROPHONE(4-pole) %s\n", > + status ? "PlugIn" : "PlugOut"); > + /* when press key for a long time then plug in > + * even recoginized as 4-pole > + * disable micbias timer still timeout after 6s > + * it check AB=00(because keep to press key) then disable > + * micbias, it will cause key no response > + */ > + del_timer_sync(&micbias_timer); > + break; > + case LINE_OUT_DEVICE: > + if (status) > + report = SND_JACK_LINEOUT; > + else > + report = 0; > + > + snd_soc_jack_report(&accdet->jack, report, SND_JACK_LINEOUT); > + pr_info("accdet LineOut %s\n", > + status ? "PlugIn" : "PlugOut"); > + break; > + default: > + pr_info("%s Invalid cableType\n", __func__); > + } > +} > + > +static void multi_key_detection(unsigned int cur_AB) > +{ > + if (cur_AB == ACCDET_STATE_AB_00) > + accdet->cur_key = check_key(accdet->cali_voltage); > + > + /* delay to wait eint been flaged in register. > + * or eint handler issued. accdet->cur_eint_state == PLUG_OUT > + */ > + usleep_range(10000, 12000); > + > + if (HAS_CAP(accdet->data->caps, ACCDET_AP_GPIO_EINT)) { > + if (accdet->cur_eint_state == EINT_PLUG_IN) > + send_key_event(accdet->cur_key, !cur_AB); > + else > + accdet->cur_key = NO_KEY; > + } else { > + bool irq_bit = false; > + unsigned int val = 0; > + > + regmap_read(accdet->regmap, ACCDET_IRQ_ADDR, &val); > + irq_bit = !(val & ACCDET_EINT_IRQ_B2_B3); > + /* send key when: > + * no eint is flaged in reg, and now eint PLUG_IN > + */ > + if (irq_bit && accdet->cur_eint_state == EINT_PLUG_IN) > + send_key_event(accdet->cur_key, !cur_AB); > + else > + accdet->cur_key = NO_KEY; > + } > + > + if (cur_AB) > + accdet->cur_key = NO_KEY; > +} > + > +static inline void clear_accdet_int(void) > +{ > + /* it is safe by using polling to adjust when to clear IRQ_CLR_BIT */ > + regmap_update_bits(accdet->regmap, ACCDET_IRQ_ADDR, > + BIT(ACCDET_IRQ_CLR_SFT), BIT(ACCDET_IRQ_CLR_SFT)); > +} > + > +static inline void clear_accdet_int_check(void) > +{ > + u64 cur_time = mt6359_accdet_get_current_time(); > + unsigned int val = 0; > + > + regmap_read(accdet->regmap, ACCDET_IRQ_ADDR, &val); > + while (val & ACCDET_IRQ_MASK_SFT && > + mt6359_accdet_timeout_ns(cur_time, ACCDET_TIME_OUT)) > + ; > + /* clear accdet int, modify for fix interrupt trigger twice error */ > + regmap_update_bits(accdet->regmap, ACCDET_IRQ_ADDR, > + BIT(ACCDET_IRQ_CLR_SFT), 0); > + regmap_update_bits(accdet->regmap, RG_INT_STATUS_ACCDET_ADDR, > + BIT(RG_INT_STATUS_ACCDET_SFT), > + BIT(RG_INT_STATUS_ACCDET_SFT)); > +} > + > +static inline void clear_accdet_eint(unsigned int eintid) > +{ > + if ((eintid & PMIC_EINT0) == PMIC_EINT0) { > + regmap_update_bits(accdet->regmap, ACCDET_IRQ_ADDR, > + BIT(ACCDET_EINT0_IRQ_CLR_SFT), > + BIT(ACCDET_EINT0_IRQ_CLR_SFT)); > + } > + if ((eintid & PMIC_EINT1) == PMIC_EINT1) { > + regmap_update_bits(accdet->regmap, ACCDET_IRQ_ADDR, > + BIT(ACCDET_EINT1_IRQ_CLR_SFT), > + BIT(ACCDET_EINT1_IRQ_CLR_SFT)); > + } > +} > + > +static inline void clear_accdet_eint_check(unsigned int eintid) > +{ > + u64 cur_time = mt6359_accdet_get_current_time(); > + unsigned int val = 0; > + > + regmap_read(accdet->regmap, ACCDET_IRQ_ADDR, &val); > + > + if ((eintid & PMIC_EINT0) == PMIC_EINT0) { > + while (val & ACCDET_EINT0_IRQ_MASK_SFT && > + mt6359_accdet_timeout_ns(cur_time, ACCDET_TIME_OUT)) > + ; > + regmap_update_bits(accdet->regmap, ACCDET_IRQ_ADDR, > + BIT(ACCDET_EINT0_IRQ_CLR_SFT), 0); > + regmap_update_bits(accdet->regmap, > + RG_INT_STATUS_ACCDET_ADDR, > + BIT(RG_INT_STATUS_ACCDET_EINT0_SFT), > + BIT(RG_INT_STATUS_ACCDET_EINT0_SFT)); > + } > + if ((eintid & PMIC_EINT1) == PMIC_EINT1) { > + while (val & ACCDET_EINT1_IRQ_MASK_SFT && > + mt6359_accdet_timeout_ns(cur_time, ACCDET_TIME_OUT)) > + ; > + regmap_update_bits(accdet->regmap, ACCDET_IRQ_ADDR, > + BIT(ACCDET_EINT1_IRQ_CLR_SFT), 0); > + regmap_update_bits(accdet->regmap, > + RG_INT_STATUS_ACCDET_ADDR, > + BIT(RG_INT_STATUS_ACCDET_EINT1_SFT), > + BIT(RG_INT_STATUS_ACCDET_EINT1_SFT)); > + } > +} > + > +static unsigned int adjust_eint_analog_setting(void) > +{ > + if (accdet_dts.eint_detect_mode == 0x3 || > + accdet_dts.eint_detect_mode == 0x4) { > + /* ESD switches off */ > + regmap_update_bits(accdet->regmap, > + RG_ACCDETSPARE_ADDR, 1 << 8, 0); > + } > + if (accdet_dts.eint_detect_mode == 0x4) { > + if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT0)) { > + /* enable RG_EINT0CONFIGACCDET */ > + regmap_update_bits(accdet->regmap, > + RG_EINT0CONFIGACCDET_ADDR, > + BIT(RG_EINT0CONFIGACCDET_SFT), > + BIT(RG_EINT0CONFIGACCDET_SFT)); > + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT1)) { > + /* enable RG_EINT1CONFIGACCDET */ > + regmap_update_bits(accdet->regmap, > + RG_EINT1CONFIGACCDET_ADDR, > + BIT(RG_EINT1CONFIGACCDET_SFT), > + BIT(RG_EINT1CONFIGACCDET_SFT)); > + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_BI_EINT)) { > + /* enable RG_EINT0CONFIGACCDET */ > + regmap_update_bits(accdet->regmap, > + RG_EINT0CONFIGACCDET_ADDR, > + BIT(RG_EINT0CONFIGACCDET_SFT), > + BIT(RG_EINT0CONFIGACCDET_SFT)); > + /* enable RG_EINT1CONFIGACCDET */ > + regmap_update_bits(accdet->regmap, > + RG_EINT1CONFIGACCDET_ADDR, > + BIT(RG_EINT1CONFIGACCDET_SFT), > + BIT(RG_EINT1CONFIGACCDET_SFT)); > + } > + if (accdet_dts.eint_use_ext_res == 0x3 || > + accdet_dts.eint_use_ext_res == 0x4) { > + /*select 500k, use internal resistor */ > + regmap_update_bits(accdet->regmap, > + RG_EINT0HIRENB_ADDR, > + BIT(RG_EINT0HIRENB_SFT), > + BIT(RG_EINT0HIRENB_SFT)); > + } > + } > + return 0; > +} > + > +static unsigned int adjust_eint_digital_setting(void) > +{ > + if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT0)) { > + /* disable inverter */ > + regmap_update_bits(accdet->regmap, > + ACCDET_EINT0_INVERTER_SW_EN_ADDR, > + BIT(ACCDET_EINT0_INVERTER_SW_EN_SFT), 0); > + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT1)) { > + /* disable inverter */ > + regmap_update_bits(accdet->regmap, > + ACCDET_EINT1_INVERTER_SW_EN_ADDR, > + BIT(ACCDET_EINT1_INVERTER_SW_EN_SFT), 0); > + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_BI_EINT)) { > + /* disable inverter */ > + regmap_update_bits(accdet->regmap, > + ACCDET_EINT0_INVERTER_SW_EN_ADDR, > + BIT(ACCDET_EINT0_INVERTER_SW_EN_SFT), 0); > + /* disable inverter */ > + regmap_update_bits(accdet->regmap, > + ACCDET_EINT1_INVERTER_SW_EN_ADDR, > + BIT(ACCDET_EINT1_INVERTER_SW_EN_SFT), 0); > + } > + > + if (accdet_dts.eint_detect_mode == 0x4) { > + if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT0)) { > + /* set DA stable signal */ > + regmap_update_bits(accdet->regmap, > + ACCDET_DA_STABLE_ADDR, > + BIT(ACCDET_EINT0_CEN_STABLE_SFT), 0); > + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT1)) { > + /* set DA stable signal */ > + regmap_update_bits(accdet->regmap, > + ACCDET_DA_STABLE_ADDR, > + BIT(ACCDET_EINT1_CEN_STABLE_SFT), 0); > + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_BI_EINT)) { > + /* set DA stable signal */ > + regmap_update_bits(accdet->regmap, > + ACCDET_DA_STABLE_ADDR, > + BIT(ACCDET_EINT0_CEN_STABLE_SFT), 0); > + /* set DA stable signal */ > + regmap_update_bits(accdet->regmap, > + ACCDET_DA_STABLE_ADDR, > + BIT(ACCDET_EINT1_CEN_STABLE_SFT), 0); > + } > + } > + return 0; > +} > + > +static unsigned int adjust_eint_setting(unsigned int eintsts) > +{ > + if (eintsts == M_PLUG_IN) { > + /* adjust digital setting */ > + adjust_eint_digital_setting(); > + /* adjust analog setting */ > + adjust_eint_analog_setting(); > + } else if (eintsts == M_PLUG_OUT) { > + /* set debounce to 1ms */ > + accdet_set_debounce(eint_state000, > + accdet_dts.pwm_deb.eint_debounce0); > + } else { > + pr_debug("should not be here %s()\n", __func__); > + } > + > + return 0; > +} > + > +static void recover_eint_analog_setting(void) > +{ > + if (accdet_dts.eint_detect_mode == 0x3 || > + accdet_dts.eint_detect_mode == 0x4) { > + /* ESD switches on */ > + regmap_update_bits(accdet->regmap, RG_ACCDETSPARE_ADDR, > + 1 << 8, 1 << 8); > + } > + if (accdet_dts.eint_detect_mode == 0x4) { > + if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT0)) { > + /* disable RG_EINT0CONFIGACCDET */ > + regmap_update_bits(accdet->regmap, > + RG_EINT0CONFIGACCDET_ADDR, > + BIT(RG_EINT0CONFIGACCDET_SFT), 0); > + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT1)) { > + /* disable RG_EINT1CONFIGACCDET */ > + regmap_update_bits(accdet->regmap, > + RG_EINT1CONFIGACCDET_ADDR, > + BIT(RG_EINT1CONFIGACCDET_SFT), 0); > + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_BI_EINT)) { > + /* disable RG_EINT0CONFIGACCDET */ > + regmap_update_bits(accdet->regmap, > + RG_EINT0CONFIGACCDET_ADDR, > + BIT(RG_EINT0CONFIGACCDET_SFT), 0); > + /* disable RG_EINT0CONFIGACCDET */ > + regmap_update_bits(accdet->regmap, > + RG_EINT1CONFIGACCDET_ADDR, > + BIT(RG_EINT1CONFIGACCDET_SFT), 0); > + } > + regmap_update_bits(accdet->regmap, RG_EINT0HIRENB_ADDR, > + BIT(RG_EINT0HIRENB_SFT), 0); > + } > +} > + > +static void recover_eint_digital_setting(void) > +{ > + if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT0)) { > + regmap_update_bits(accdet->regmap, > + ACCDET_EINT0_M_SW_EN_ADDR, > + BIT(ACCDET_EINT0_M_SW_EN_SFT), 0); > + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT1)) { > + regmap_update_bits(accdet->regmap, > + ACCDET_EINT1_M_SW_EN_ADDR, > + BIT(ACCDET_EINT1_M_SW_EN_SFT), 0); > + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_BI_EINT)) { > + regmap_update_bits(accdet->regmap, > + ACCDET_EINT0_M_SW_EN_ADDR, > + BIT(ACCDET_EINT0_M_SW_EN_SFT), 0); > + regmap_update_bits(accdet->regmap, > + ACCDET_EINT1_M_SW_EN_ADDR, > + BIT(ACCDET_EINT1_M_SW_EN_SFT), 0); > + } > + if (accdet_dts.eint_detect_mode == 0x4) { > + /* enable eint0cen */ > + if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT0)) { > + /* enable eint0cen */ > + regmap_update_bits(accdet->regmap, > + ACCDET_DA_STABLE_ADDR, > + BIT(ACCDET_EINT0_CEN_STABLE_SFT), > + BIT(ACCDET_EINT0_CEN_STABLE_SFT)); > + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT1)) { > + /* enable eint1cen */ > + regmap_update_bits(accdet->regmap, > + ACCDET_DA_STABLE_ADDR, > + BIT(ACCDET_EINT1_CEN_STABLE_SFT), > + BIT(ACCDET_EINT1_CEN_STABLE_SFT)); > + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_BI_EINT)) { > + /* enable eint0cen */ > + regmap_update_bits(accdet->regmap, > + ACCDET_DA_STABLE_ADDR, > + BIT(ACCDET_EINT0_CEN_STABLE_SFT), > + BIT(ACCDET_EINT0_CEN_STABLE_SFT)); > + /* enable eint1cen */ > + regmap_update_bits(accdet->regmap, > + ACCDET_DA_STABLE_ADDR, > + BIT(ACCDET_EINT1_CEN_STABLE_SFT), > + BIT(ACCDET_EINT1_CEN_STABLE_SFT)); > + } > + } > + > + if (accdet_dts.eint_detect_mode != 0x1) { > + if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT0)) { > + /* enable inverter */ > + regmap_update_bits(accdet->regmap, > + ACCDET_EINT0_INVERTER_SW_EN_ADDR, > + BIT(ACCDET_EINT0_INVERTER_SW_EN_SFT), > + BIT(ACCDET_EINT0_INVERTER_SW_EN_SFT)); > + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT1)) { > + /* enable inverter */ > + regmap_update_bits(accdet->regmap, > + ACCDET_EINT1_INVERTER_SW_EN_ADDR, > + BIT(ACCDET_EINT1_INVERTER_SW_EN_SFT), > + BIT(ACCDET_EINT1_INVERTER_SW_EN_SFT)); > + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_BI_EINT)) { > + /* enable inverter */ > + regmap_update_bits(accdet->regmap, > + ACCDET_EINT0_INVERTER_SW_EN_ADDR, > + BIT(ACCDET_EINT0_INVERTER_SW_EN_SFT), > + BIT(ACCDET_EINT0_INVERTER_SW_EN_SFT)); > + /* enable inverter */ > + regmap_update_bits(accdet->regmap, > + ACCDET_EINT1_INVERTER_SW_EN_ADDR, > + BIT(ACCDET_EINT1_INVERTER_SW_EN_SFT), > + BIT(ACCDET_EINT1_INVERTER_SW_EN_SFT)); > + } > + } > +} > + > +static void recover_eint_setting(unsigned int eintsts) > +{ > + if (eintsts == M_PLUG_OUT) { > + recover_eint_analog_setting(); > + recover_eint_digital_setting(); > + } > +} > + > +static unsigned int get_triggered_eint(void) > +{ > + unsigned int eint_ID = NO_PMIC_EINT; > + unsigned int irq_status = 0; > + > + regmap_read(accdet->regmap, ACCDET_IRQ_ADDR, &irq_status); > + > + if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT0)) { > + if ((irq_status & ACCDET_EINT0_IRQ_MASK_SFT) == > + ACCDET_EINT0_IRQ_MASK_SFT) > + eint_ID = PMIC_EINT0; > + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT1)) { > + if ((irq_status & ACCDET_EINT1_IRQ_MASK_SFT) == > + ACCDET_EINT1_IRQ_MASK_SFT) > + eint_ID = PMIC_EINT1; > + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_BI_EINT)) { > + if ((irq_status & ACCDET_EINT0_IRQ_MASK_SFT) == > + ACCDET_EINT0_IRQ_MASK_SFT) > + eint_ID |= PMIC_EINT0; > + if ((irq_status & ACCDET_EINT1_IRQ_MASK_SFT) == > + ACCDET_EINT1_IRQ_MASK_SFT) > + eint_ID |= PMIC_EINT1; > + } > + return eint_ID; > +} > + > +static inline void enable_accdet(unsigned int state_swctrl) > +{ > + /* enable ACCDET unit */ > + regmap_update_bits(accdet->regmap, ACCDET_SW_EN_ADDR, > + BIT(ACCDET_SW_EN_SFT), BIT(ACCDET_SW_EN_SFT)); > +} > + > +static inline void disable_accdet(void) > +{ > + clear_accdet_int(); > + usleep_range(200, 300); > + mutex_lock(&accdet->res_lock); > + clear_accdet_int_check(); > + mutex_unlock(&accdet->res_lock); > + > + /* recover accdet debounce0,3 */ > + accdet_set_debounce(accdet_state000, cust_pwm_deb->debounce0); > + accdet_set_debounce(accdet_state001, cust_pwm_deb->debounce1); > + accdet_set_debounce(accdet_state011, cust_pwm_deb->debounce3); > +} > + > +static inline void headset_plug_out(void) > +{ > + send_status_event(accdet->cable_type, 0); > + accdet->accdet_status = PLUG_OUT; > + accdet->cable_type = NO_DEVICE; > + > + if (accdet->cur_key != 0) { > + send_key_event(accdet->cur_key, 0); > + accdet->cur_key = 0; > + } > + pr_info("accdet %s, set cable_type = NO_DEVICE\n", __func__); > +} > + > +static void dis_micbias_timerhandler(struct timer_list *t) > +{ > + int ret = 0; > + > + ret = queue_work(accdet->dis_micbias_workqueue, > + &accdet->dis_micbias_work); > + if (!ret) > + pr_notice("Error: %s (%d)\n", __func__, ret); > +} > + > +static void dis_micbias_work_callback(struct work_struct *work) > +{ > + unsigned int cur_AB = 0, eint = 0; > + unsigned int val = 0; > + > + /* check EINT0 status, if plug out, > + * not need to disable accdet here > + */ > + regmap_read(accdet->regmap, ACCDET_EINT0_MEM_IN_ADDR, &val); > + eint = ((val >> ACCDET_EINT0_MEM_IN_SFT) & ACCDET_EINT0_MEM_IN_MASK); > + if (eint == M_PLUG_OUT) { > + pr_notice("%s Plug-out, no need disable micbias\n", __func__); > + return; > + } > + > + regmap_read(accdet->regmap, ACCDET_MEM_IN_ADDR, &val); > + cur_AB = (val >> ACCDET_STATE_MEM_IN_OFFSET) & ACCDET_STATE_AB_MASK; > + > + /* if 3pole disable accdet > + * if <20k + 4pole, disable accdet will disable accdet > + * plug out interrupt. The behavior will same as 3pole > + */ > + if (accdet->cable_type == HEADSET_NO_MIC || > + cur_AB == ACCDET_STATE_AB_00 || > + cur_AB == ACCDET_STATE_AB_11) { > + regmap_update_bits(accdet->regmap, ACCDET_SW_EN_ADDR, > + BIT(ACCDET_SW_EN_SFT), 0); > + disable_accdet(); > + } > +} > + > +static void eint_work_callback(struct work_struct *work) > +{ > + if (accdet->cur_eint_state == EINT_PLUG_IN) { > + /* disable vusb LP */ > + regmap_write(accdet->regmap, RG_LDO_VUSB_HW0_OP_EN_ADDR, 0x8000); > + > + mutex_lock(&accdet->res_lock); > + accdet->eint_sync_flag = true; > + mutex_unlock(&accdet->res_lock); > + __pm_wakeup_event(accdet->timer_lock, > + jiffies_to_msecs(7 * HZ)); > + > + accdet_init(); > + > + enable_accdet(0); > + } else { > + mutex_lock(&accdet->res_lock); > + accdet->eint_sync_flag = false; > + mutex_unlock(&accdet->res_lock); > + del_timer_sync(&micbias_timer); > + > + regmap_update_bits(accdet->regmap, ACCDET_SW_EN_ADDR, > + BIT(ACCDET_SW_EN_SFT), 0); > + disable_accdet(); > + headset_plug_out(); > + } > + > + if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT_IRQ)) > + recover_eint_setting(accdet->eint_id); > + else if (HAS_CAP(accdet->data->caps, ACCDET_AP_GPIO_EINT)) > + enable_irq(accdet->gpioirq); > +} > + > +static void accdet_set_debounce(int state, unsigned int debounce) > +{ > + switch (state) { > + case accdet_state000: > + /* set ACCDET debounce value = debounce/32 ms */ > + regmap_write(accdet->regmap, ACCDET_DEBOUNCE0_ADDR, debounce); > + break; > + case accdet_state001: > + regmap_write(accdet->regmap, ACCDET_DEBOUNCE1_ADDR, debounce); > + break; > + case accdet_state010: > + regmap_write(accdet->regmap, ACCDET_DEBOUNCE2_ADDR, debounce); > + break; > + case accdet_state011: > + regmap_write(accdet->regmap, ACCDET_DEBOUNCE3_ADDR, debounce); > + break; > + case accdet_auxadc: > + /* set auxadc debounce:0x42(2ms) */ > + regmap_write(accdet->regmap, > + ACCDET_CONNECT_AUXADC_TIME_DIG_ADDR, debounce); > + break; > + case eint_state000: > + regmap_update_bits(accdet->regmap, ACCDET_EINT_DEBOUNCE0_ADDR, > + 0xF << ACCDET_EINT_DEBOUNCE0_SFT, > + debounce << ACCDET_EINT_DEBOUNCE0_SFT); > + break; > + case eint_state001: > + regmap_update_bits(accdet->regmap, ACCDET_EINT_DEBOUNCE1_ADDR, > + 0xF << ACCDET_EINT_DEBOUNCE1_SFT, > + debounce << ACCDET_EINT_DEBOUNCE1_SFT); > + break; > + case eint_state010: > + regmap_update_bits(accdet->regmap, ACCDET_EINT_DEBOUNCE2_ADDR, > + 0xF << ACCDET_EINT_DEBOUNCE2_SFT, > + debounce << ACCDET_EINT_DEBOUNCE2_SFT); > + break; > + case eint_state011: > + regmap_update_bits(accdet->regmap, ACCDET_EINT_DEBOUNCE3_ADDR, > + 0xF << ACCDET_EINT_DEBOUNCE3_SFT, > + debounce << ACCDET_EINT_DEBOUNCE3_SFT); > + break; > + case eint_inverter_state000: > + regmap_write(accdet->regmap, ACCDET_EINT_INVERTER_DEBOUNCE_ADDR, > + debounce); > + break; > + default: > + pr_notice("Error: %s error state (%d)\n", __func__, state); > + break; > + } > +} > + > +static inline void check_cable_type(void) > +{ > + unsigned int cur_AB = 0; > + unsigned int val = 0; > + > + regmap_read(accdet->regmap, ACCDET_MEM_IN_ADDR, &val); > + > + cur_AB = (val >> ACCDET_STATE_MEM_IN_OFFSET) & ACCDET_STATE_AB_MASK; > + > + switch (accdet->accdet_status) { > + case PLUG_OUT: > + if (cur_AB == ACCDET_STATE_AB_00) { > + mutex_lock(&accdet->res_lock); > + if (accdet->eint_sync_flag) { > + accdet->cable_type = HEADSET_NO_MIC; > + accdet->accdet_status = HOOK_SWITCH; > + } else { > + pr_notice("accdet hp has been plug-out\n"); > + } > + mutex_unlock(&accdet->res_lock); > + /* for IOT HP */ > + accdet_set_debounce(eint_state011, > + accdet_dts.pwm_deb.eint_debounce3); > + } else if (cur_AB == ACCDET_STATE_AB_01) { > + mutex_lock(&accdet->res_lock); > + if (accdet->eint_sync_flag) { > + accdet->accdet_status = MIC_BIAS; > + accdet->cable_type = HEADSET_MIC; > + } else { > + pr_notice("accdet hp has been plug-out\n"); > + } > + mutex_unlock(&accdet->res_lock); > + /* adjust hook switch debounce time > + * for fast key press condition, avoid to miss key > + */ > + accdet_set_debounce(accdet_state000, > + button_press_debounce); > + > + /* adjust debounce1 to original 0x800(64ms), > + * to fix miss key issue when fast press double key. > + */ > + accdet_set_debounce(accdet_state001, > + button_press_debounce_01); > + accdet_set_debounce(eint_state011, 0x1); > + } else if (cur_AB == ACCDET_STATE_AB_11) { > + /* accdet PLUG_OUT state not change */ > + if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT_IRQ)) { > + mutex_lock(&accdet->res_lock); > + if (accdet->eint_sync_flag) { > + accdet->accdet_status = PLUG_OUT; > + accdet->cable_type = NO_DEVICE; > + } else { > + pr_notice("accdet hp been plug-out\n"); > + } > + mutex_unlock(&accdet->res_lock); > + } > + } else { > + pr_notice("accdet %s Invalid AB.\n", __func__); > + } > + break; > + case MIC_BIAS: > + if (cur_AB == ACCDET_STATE_AB_00) { > + mutex_lock(&accdet->res_lock); > + if (accdet->eint_sync_flag) { > + accdet->accdet_status = HOOK_SWITCH; > + multi_key_detection(cur_AB); > + } else { > + pr_notice("accdet hp has been plug-out\n"); > + } > + mutex_unlock(&accdet->res_lock); > + } else if (cur_AB == ACCDET_STATE_AB_01) { > + mutex_lock(&accdet->res_lock); > + if (accdet->eint_sync_flag) { > + accdet->accdet_status = MIC_BIAS; > + accdet->cable_type = HEADSET_MIC; > + /* accdet MIC_BIAS state not change */ > + } else { > + pr_notice("accdet hp has been plug-out\n"); > + } > + mutex_unlock(&accdet->res_lock); > + accdet_set_debounce(eint_state011, 0x1); > + } else if (cur_AB == ACCDET_STATE_AB_11) { > + /* accdet Don't send plug out in MIC_BIAS */ > + mutex_lock(&accdet->res_lock); > + if (accdet->eint_sync_flag) > + accdet->accdet_status = PLUG_OUT; > + else > + pr_notice("accdet hp has been plug-out\n"); > + mutex_unlock(&accdet->res_lock); > + } else { > + pr_notice("accdet %s Invalid AB.\n", __func__); > + } > + break; > + case HOOK_SWITCH: > + if (cur_AB == ACCDET_STATE_AB_00) { > + } else if (cur_AB == ACCDET_STATE_AB_01) { > + mutex_lock(&accdet->res_lock); > + if (accdet->eint_sync_flag) { > + multi_key_detection(cur_AB); > + accdet->accdet_status = MIC_BIAS; > + accdet->cable_type = HEADSET_MIC; > + } else { > + pr_notice("accdet hp has been plug-out\n"); > + } > + mutex_unlock(&accdet->res_lock); > + > + /* adjust debounce0 and debounce1 to fix miss key issue. > + */ > + accdet_set_debounce(accdet_state000, > + button_press_debounce); > + accdet_set_debounce(accdet_state001, > + button_press_debounce_01); > + /* for IOT HP */ > + accdet_set_debounce(eint_state011, 0x1); > + } else if (cur_AB == ACCDET_STATE_AB_11) { > + /* accdet Don't send plugout in HOOK_SWITCH */ > + mutex_lock(&accdet->res_lock); > + if (accdet->eint_sync_flag) > + accdet->accdet_status = PLUG_OUT; > + else > + pr_notice("accdet hp has been plug-out\n"); > + mutex_unlock(&accdet->res_lock); > + } else { > + pr_notice("accdet %s Invalid AB.\n", __func__); > + } > + break; > + case STAND_BY: > + /* accdet %s STANDBY state.Err!Do nothing */ > + break; > + default: > + /* accdet %s Error state.Do nothing */ > + break; > + } > +} > + > +static void accdet_work_callback(struct work_struct *work) > +{ > + unsigned int pre_cable_type = accdet->cable_type; > + > + __pm_stay_awake(accdet->wake_lock); > + check_cable_type(); > + > + mutex_lock(&accdet->res_lock); > + if (accdet->eint_sync_flag) { > + if (pre_cable_type != accdet->cable_type) > + send_status_event(accdet->cable_type, 1); > + } > + mutex_unlock(&accdet->res_lock); > + if (accdet->cable_type != NO_DEVICE) { > + /* enable vusb LP */ > + regmap_write(accdet->regmap, RG_LDO_VUSB_HW0_OP_EN_ADDR, 0x8005); > + } > + > + __pm_relax(accdet->wake_lock); > +} > + > +static void accdet_queue_work(void) > +{ > + int ret; > + > + if (accdet->accdet_status == MIC_BIAS) > + accdet->cali_voltage = 10; > + > + ret = queue_work(accdet->accdet_workqueue, &accdet->accdet_work); > + if (!ret) > + pr_notice("Error: %s (%d)\n", __func__, ret); > +} > + > +static int pmic_eint_queue_work(int eint) > +{ > + int ret = 0; > + > + if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT0)) { > + if (eint == PMIC_EINT0) { > + if (accdet->cur_eint_state == EINT_PLUG_IN) { > + accdet_set_debounce(accdet_state011, > + cust_pwm_deb->debounce3); > + accdet->cur_eint_state = EINT_PLUG_OUT; > + } else { > + if (accdet->eint_id != M_PLUG_OUT) { > + accdet->cur_eint_state = EINT_PLUG_IN; > + mod_timer(&micbias_timer, > + jiffies + MICBIAS_DISABLE_TIMER); > + } > + } > + ret = queue_work(accdet->eint_workqueue, > + &accdet->eint_work); > + } else { > + pr_notice("%s invalid EINT ID!\n", __func__); > + } > + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT1)) { > + if (eint == PMIC_EINT1) { > + if (accdet->cur_eint_state == EINT_PLUG_IN) { > + accdet_set_debounce(accdet_state011, > + cust_pwm_deb->debounce3); > + accdet->cur_eint_state = EINT_PLUG_OUT; > + } else { > + if (accdet->eint_id != M_PLUG_OUT) { > + accdet->cur_eint_state = EINT_PLUG_IN; > + mod_timer(&micbias_timer, > + jiffies + MICBIAS_DISABLE_TIMER); > + } > + } > + ret = queue_work(accdet->eint_workqueue, > + &accdet->eint_work); > + } else { > + pr_notice("%s invalid EINT ID!\n", __func__); > + } > + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_BI_EINT)) { > + if ((eint & PMIC_EINT0) == PMIC_EINT0) { > + if (accdet->eint0_state == EINT_PLUG_IN) { > + accdet_set_debounce(accdet_state011, > + cust_pwm_deb->debounce3); > + accdet->eint0_state = EINT_PLUG_OUT; > + } else { > + if (accdet->eint_id != M_PLUG_OUT) > + accdet->eint0_state = EINT_PLUG_IN; > + } > + } > + if ((eint & PMIC_EINT1) == PMIC_EINT1) { > + if (accdet->eint1_state == EINT_PLUG_IN) { > + accdet_set_debounce(accdet_state011, > + cust_pwm_deb->debounce3); > + accdet->eint1_state = EINT_PLUG_OUT; > + } else { > + if (accdet->eint_id != M_PLUG_OUT) > + accdet->eint1_state = EINT_PLUG_IN; > + } > + } > + > + /* bi_eint trigger issued current state, may */ > + if (accdet->cur_eint_state == EINT_PLUG_OUT) { > + accdet->cur_eint_state = > + accdet->eint0_state & accdet->eint1_state; > + if (accdet->cur_eint_state == EINT_PLUG_IN) { > + mod_timer(&micbias_timer, > + jiffies + MICBIAS_DISABLE_TIMER); > + ret = queue_work(accdet->eint_workqueue, > + &accdet->eint_work); > + } > + } else if (accdet->cur_eint_state == EINT_PLUG_IN) { > + if ((accdet->eint0_state | accdet->eint1_state) == EINT_PLUG_OUT) { > + clear_accdet_eint_check(PMIC_EINT0); > + clear_accdet_eint_check(PMIC_EINT1); > + } else if ((accdet->eint0_state & accdet->eint1_state) > + == EINT_PLUG_OUT) { > + accdet->cur_eint_state = EINT_PLUG_OUT; > + ret = queue_work(accdet->eint_workqueue, > + &accdet->eint_work); > + } > + } > + } > + return ret; > +} > + > +void accdet_irq_handle(void) > +{ > + unsigned int eint = 0; > + unsigned int irq_status = 0, acc_sts = 0, eint_sts = 0; > + unsigned int val = 0; > + > + eint = get_triggered_eint(); > + regmap_read(accdet->regmap, ACCDET_IRQ_ADDR, &irq_status); > + regmap_read(accdet->regmap, ACCDET_MEM_IN_ADDR, &acc_sts); > + regmap_read(accdet->regmap, ACCDET_EINT0_MEM_IN_ADDR, &eint_sts); > + > + if ((irq_status & ACCDET_IRQ_MASK_SFT) && eint == 0) { > + clear_accdet_int(); > + accdet_queue_work(); > + clear_accdet_int_check(); > + } else if (eint != NO_PMIC_EINT) { > + /* check EINT0 status */ > + regmap_read(accdet->regmap, ACCDET_EINT0_MEM_IN_ADDR, &val); > + accdet->eint_id = ((val >> ACCDET_EINT0_MEM_IN_SFT) & > + ACCDET_EINT0_MEM_IN_MASK); > + /* adjust eint digital/analog setting */ > + adjust_eint_setting(accdet->eint_id); > + clear_accdet_eint(eint); > + clear_accdet_eint_check(eint); > + pmic_eint_queue_work(eint); > + } else { > + pr_notice("%s no interrupt detected!\n", __func__); > + } > +} > + > +static irqreturn_t mtk_accdet_irq_handler_thread(int irq, void *data) > +{ > + accdet_irq_handle(); > + > + return IRQ_HANDLED; > +} > + > +static irqreturn_t ex_eint_handler(int irq, void *data) > +{ > + int ret = 0; > + > + if (accdet->cur_eint_state == EINT_PLUG_IN) { > + /* To trigger EINT when the headset was plugged in > + * We set the polarity back as we initialed. > + */ > + if (accdet->accdet_eint_type == IRQ_TYPE_LEVEL_HIGH) > + irq_set_irq_type(accdet->gpioirq, IRQ_TYPE_LEVEL_HIGH); > + else > + irq_set_irq_type(accdet->gpioirq, IRQ_TYPE_LEVEL_LOW); > + gpio_set_debounce(accdet->gpiopin, accdet->gpio_hp_deb); > + > + accdet->cur_eint_state = EINT_PLUG_OUT; > + } else { > + /* To trigger EINT when the headset was plugged out > + * We set the opposite polarity to what we initialed. > + */ > + if (accdet->accdet_eint_type == IRQ_TYPE_LEVEL_HIGH) > + irq_set_irq_type(accdet->gpioirq, IRQ_TYPE_LEVEL_LOW); > + else > + irq_set_irq_type(accdet->gpioirq, IRQ_TYPE_LEVEL_HIGH); > + > + gpio_set_debounce(accdet->gpiopin, > + accdet_dts.plugout_deb * 1000); > + > + accdet->cur_eint_state = EINT_PLUG_IN; > + > + mod_timer(&micbias_timer, > + jiffies + MICBIAS_DISABLE_TIMER); > + } > + > + disable_irq_nosync(accdet->gpioirq); > + ret = queue_work(accdet->eint_workqueue, &accdet->eint_work); > + return IRQ_HANDLED; > +} > + > +static inline int ext_eint_setup(struct platform_device *platform_device) > +{ > + int ret = 0; > + unsigned int ints[4] = { 0 }; > + struct device_node *node = NULL; > + struct pinctrl_state *pins_default = NULL; > + > + accdet->pinctrl = devm_pinctrl_get(&platform_device->dev); > + if (IS_ERR(accdet->pinctrl)) { > + ret = PTR_ERR(accdet->pinctrl); > + return ret; > + } > + > + pins_default = pinctrl_lookup_state(accdet->pinctrl, "default"); > + if (IS_ERR(pins_default)) > + ret = PTR_ERR(pins_default); > + > + accdet->pins_eint = pinctrl_lookup_state(accdet->pinctrl, > + "state_eint_as_int"); > + if (IS_ERR(accdet->pins_eint)) { > + ret = PTR_ERR(accdet->pins_eint); > + return ret; > + } > + pinctrl_select_state(accdet->pinctrl, accdet->pins_eint); > + > + node = of_find_matching_node(node, mt6359_accdet_of_match); > + if (!node) > + return -1; > + > + accdet->gpiopin = of_get_named_gpio(node, "deb-gpios", 0); > + ret = of_property_read_u32(node, "debounce", > + &accdet->gpio_hp_deb); > + if (ret < 0) > + return ret; > + > + gpio_set_debounce(accdet->gpiopin, accdet->gpio_hp_deb); > + > + accdet->gpioirq = irq_of_parse_and_map(node, 0); > + ret = of_property_read_u32_array(node, "interrupts", ints, > + ARRAY_SIZE(ints)); > + if (ret) > + return ret; > + > + accdet->accdet_eint_type = ints[1]; > + ret = request_irq(accdet->gpioirq, ex_eint_handler, IRQF_TRIGGER_NONE, > + "accdet-eint", NULL); > + if (ret) > + return ret; > + > + return 0; > +} > + > +static int mt6359_accdet_parse_dt(void) > +{ > + int ret = 0; > + struct device_node *node = NULL; > + int pwm_deb[15] = {0}; > + int three_key[4] = {0}; > + unsigned int tmp = 0; > + > + node = of_find_matching_node(node, mt6359_accdet_of_match); > + if (!node) { > + pr_notice("Error: %s can't find dts node\n", __func__); > + return -1; > + } > + > + ret = of_property_read_u32(node, "eint_use_ext_res", > + &accdet_dts.eint_use_ext_res); > + if (ret) { > + /* eint use internal resister */ > + accdet_dts.eint_use_ext_res = 0x0; > + } > + ret = of_property_read_u32(node, "eint_detect_mode", > + &accdet_dts.eint_detect_mode); > + if (ret) { > + /* eint detection mode equals to EINT HW Mode */ > + accdet_dts.eint_detect_mode = 0x4; > + } > + > + ret = of_property_read_u32(node, > + "accdet-mic-vol", &accdet_dts.mic_vol); > + if (ret) > + accdet_dts.mic_vol = 8; > + > + ret = of_property_read_u32(node, "accdet-plugout-debounce", > + &accdet_dts.plugout_deb); > + if (ret) > + accdet_dts.plugout_deb = 1; > + > + ret = of_property_read_u32(node, > + "accdet-mic-mode", &accdet_dts.mic_mode); > + if (ret) > + accdet_dts.mic_mode = 2; > + > + ret = of_property_read_u32_array(node, "headset-mode-setting", pwm_deb, > + ARRAY_SIZE(pwm_deb)); > + /* debounce8(auxadc debounce) is default, needn't get from dts */ > + if (!ret) > + memcpy(&accdet_dts.pwm_deb, pwm_deb, sizeof(pwm_deb)); > + > + cust_pwm_deb = &accdet_dts.pwm_deb; > + > + ret = of_property_read_u32(node, "headset-eint-level-pol", > + &accdet_dts.eint_pol); > + if (ret) > + accdet_dts.eint_pol = 8; > + > + ret = of_property_read_u32(node, "headset-use-ap-eint", &tmp); > + if (ret) > + tmp = 0; > + if (tmp == 0) > + accdet->data->caps |= ACCDET_PMIC_EINT_IRQ; > + else if (tmp == 1) > + accdet->data->caps |= ACCDET_AP_GPIO_EINT; > + > + ret = of_property_read_u32(node, "headset-eint-num", &tmp); > + if (ret) > + tmp = 0; > + if (tmp == 0) > + accdet->data->caps |= ACCDET_PMIC_EINT0; > + else if (tmp == 1) > + accdet->data->caps |= ACCDET_PMIC_EINT1; > + else if (tmp == 2) > + accdet->data->caps |= ACCDET_PMIC_BI_EINT; > + > + ret = of_property_read_u32(node, "headset-eint-trig-mode", &tmp); > + if (ret) > + tmp = 0; > + if (tmp == 0) > + accdet->data->caps |= ACCDET_PMIC_GPIO_TRIG_EINT; > + else if (tmp == 1) > + accdet->data->caps |= ACCDET_PMIC_INVERTER_TRIG_EINT; > + > + ret = of_property_read_u32(node, "headset-key-mode", &tmp); > + if (ret) > + tmp = 0; > + if (tmp == 0) > + accdet->data->caps |= ACCDET_THREE_KEY; > + else if (tmp == 1) > + accdet->data->caps |= ACCDET_FOUR_KEY; > + else if (tmp == 2) > + accdet->data->caps |= ACCDET_TRI_KEY_CDD; > + > + if (HAS_CAP(accdet->data->caps, ACCDET_FOUR_KEY)) { > + int four_key[5]; > + > + ret = of_property_read_u32_array(node, > + "headset-four-key-threshold", > + four_key, ARRAY_SIZE(four_key)); > + if (!ret) { > + memcpy(&accdet_dts.four_key, four_key + 1, > + sizeof(struct four_key_threshold)); > + } else { > + pr_notice("accdet no 4-key-thrsh dts, use efuse\n"); > + } > + } else { > + if (HAS_CAP(accdet->data->caps, ACCDET_THREE_KEY)) { > + ret = of_property_read_u32_array(node, > + "headset-three-key-threshold", > + three_key, ARRAY_SIZE(three_key)); > + } else { > + ret = of_property_read_u32_array(node, > + "headset-three-key-threshold-CDD", > + three_key, > + ARRAY_SIZE(three_key)); > + } > + if (!ret) > + memcpy(&accdet_dts.three_key, three_key + 1, > + sizeof(struct three_key_threshold)); > + } > + > + ret = of_property_read_u32(node, "eint_use_ext_res", > + &accdet_dts.eint_use_ext_res); > + if (ret) { > + /* eint use internal resister */ > + accdet_dts.eint_use_ext_res = 0x0; > + } > + pr_info("accdet caps=%x\n", accdet->data->caps); > + > + return 0; > +} > + > +static void config_digital_init_by_mode(void) > +{ > + /* enable eint cmpmem pwm */ > + regmap_write(accdet->regmap, ACCDET_EINT_CMPMEN_PWM_THRESH_ADDR, > + (accdet_dts.pwm_deb.eint_pwm_width << 4 | > + accdet_dts.pwm_deb.eint_pwm_thresh)); > + /* DA signal stable */ > + if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT0)) { > + regmap_write(accdet->regmap, ACCDET_DA_STABLE_ADDR, > + ACCDET_EINT0_STABLE_VAL); > + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT1)) { > + regmap_write(accdet->regmap, ACCDET_DA_STABLE_ADDR, > + ACCDET_EINT1_STABLE_VAL); > + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_BI_EINT)) { > + regmap_write(accdet->regmap, ACCDET_DA_STABLE_ADDR, > + ACCDET_EINT0_STABLE_VAL); > + regmap_write(accdet->regmap, ACCDET_DA_STABLE_ADDR, > + ACCDET_EINT1_STABLE_VAL); > + } > + /* after receive n+1 number, interrupt issued. now is 2 times */ > + regmap_update_bits(accdet->regmap, ACCDET_EINT_M_PLUG_IN_NUM_ADDR, > + BIT(ACCDET_EINT_M_PLUG_IN_NUM_SFT), > + BIT(ACCDET_EINT_M_PLUG_IN_NUM_SFT)); > + /* setting HW mode, enable digital fast discharge > + * if use EINT0 & EINT1 detection, please modify > + * ACCDET_HWMODE_EN_ADDR[2:1] > + */ > + regmap_write(accdet->regmap, ACCDET_HWMODE_EN_ADDR, 0x100); > + > + regmap_update_bits(accdet->regmap, ACCDET_EINT_M_DETECT_EN_ADDR, > + BIT(ACCDET_EINT_M_DETECT_EN_SFT), 0); > + > + /* enable PWM */ > + regmap_write(accdet->regmap, ACCDET_CMP_PWM_EN_ADDR, 0x67); > + /* enable inverter detection */ > + if (accdet_dts.eint_detect_mode == 0x1) { > + /* disable inverter detection */ > + if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT0)) { > + regmap_update_bits(accdet->regmap, > + ACCDET_EINT0_INVERTER_SW_EN_ADDR, > + BIT(ACCDET_EINT0_INVERTER_SW_EN_SFT), > + 0); > + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT1)) { > + regmap_update_bits(accdet->regmap, > + ACCDET_EINT1_INVERTER_SW_EN_ADDR, > + BIT(ACCDET_EINT1_INVERTER_SW_EN_SFT), > + 0); > + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_BI_EINT)) { > + regmap_update_bits(accdet->regmap, > + ACCDET_EINT0_INVERTER_SW_EN_ADDR, > + BIT(ACCDET_EINT0_INVERTER_SW_EN_SFT), > + 0); > + regmap_update_bits(accdet->regmap, > + ACCDET_EINT1_INVERTER_SW_EN_ADDR, > + BIT(ACCDET_EINT1_INVERTER_SW_EN_SFT), > + 0); > + } > + } else { > + if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT0)) { > + regmap_update_bits(accdet->regmap, > + ACCDET_EINT0_INVERTER_SW_EN_ADDR, > + BIT(ACCDET_EINT0_INVERTER_SW_EN_SFT), > + BIT(ACCDET_EINT0_INVERTER_SW_EN_SFT)); > + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT1)) { > + regmap_update_bits(accdet->regmap, > + ACCDET_EINT1_INVERTER_SW_EN_ADDR, > + BIT(ACCDET_EINT1_INVERTER_SW_EN_SFT), > + BIT(ACCDET_EINT1_INVERTER_SW_EN_SFT)); > + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_BI_EINT)) { > + regmap_update_bits(accdet->regmap, > + ACCDET_EINT0_INVERTER_SW_EN_ADDR, > + BIT(ACCDET_EINT0_INVERTER_SW_EN_SFT), > + BIT(ACCDET_EINT0_INVERTER_SW_EN_SFT)); > + regmap_update_bits(accdet->regmap, > + ACCDET_EINT1_INVERTER_SW_EN_ADDR, > + BIT(ACCDET_EINT1_INVERTER_SW_EN_SFT), > + BIT(ACCDET_EINT1_INVERTER_SW_EN_SFT)); > + } > + } > +} > + > +static void config_eint_init_by_mode(void) > +{ > + if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT0)) { > + regmap_update_bits(accdet->regmap, RG_EINT0EN_ADDR, > + BIT(RG_EINT0EN_SFT), BIT(RG_EINT0EN_SFT)); > + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT1)) { > + regmap_update_bits(accdet->regmap, RG_EINT1EN_ADDR, > + BIT(RG_EINT1EN_SFT), BIT(RG_EINT1EN_SFT)); > + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_BI_EINT)) { > + regmap_update_bits(accdet->regmap, RG_EINT0EN_ADDR, > + BIT(RG_EINT0EN_SFT), BIT(RG_EINT0EN_SFT)); > + regmap_update_bits(accdet->regmap, RG_EINT1EN_ADDR, > + BIT(RG_EINT1EN_SFT), BIT(RG_EINT1EN_SFT)); > + } > + /* ESD switches on */ > + regmap_update_bits(accdet->regmap, RG_ACCDETSPARE_ADDR, > + 1 << 8, 1 << 8); > + /* before playback, set NCP pull low before nagative voltage */ > + regmap_update_bits(accdet->regmap, RG_NCP_PDDIS_EN_ADDR, > + BIT(RG_NCP_PDDIS_EN_SFT), BIT(RG_NCP_PDDIS_EN_SFT)); > + > + if (accdet_dts.eint_detect_mode == 0x1 || > + accdet_dts.eint_detect_mode == 0x2 || > + accdet_dts.eint_detect_mode == 0x3) { > + if (accdet_dts.eint_use_ext_res == 0x1) { > + /* select VTH to 2v and 500k, use external resitance */ > + if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT0)) { > + /* disable RG_EINT0CONFIGACCDET */ > + regmap_update_bits(accdet->regmap, > + RG_EINT0CONFIGACCDET_ADDR, > + BIT(RG_EINT0CONFIGACCDET_SFT), > + 0); > + } else if (HAS_CAP(accdet->data->caps, > + ACCDET_PMIC_EINT1)) { > + /* disable RG_EINT1CONFIGACCDET */ > + regmap_update_bits(accdet->regmap, > + RG_EINT1CONFIGACCDET_ADDR, > + BIT(RG_EINT1CONFIGACCDET_SFT), > + 0); > + } else if (HAS_CAP(accdet->data->caps, > + ACCDET_PMIC_BI_EINT)) { > + /* disable RG_EINT0CONFIGACCDET */ > + regmap_update_bits(accdet->regmap, > + RG_EINT0CONFIGACCDET_ADDR, > + BIT(RG_EINT0CONFIGACCDET_SFT), > + 0); > + /* disable RG_EINT1CONFIGACCDET */ > + regmap_update_bits(accdet->regmap, > + RG_EINT1CONFIGACCDET_ADDR, > + BIT(RG_EINT1CONFIGACCDET_SFT), > + 0); > + } > + } else { > + /* select VTH to 2v and 500k, use internal resitance */ > + if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT0)) { > + /* enable RG_EINT0CONFIGACCDET */ > + regmap_update_bits(accdet->regmap, > + RG_EINT0CONFIGACCDET_ADDR, > + BIT(RG_EINT0CONFIGACCDET_SFT), > + BIT(RG_EINT0CONFIGACCDET_SFT)); > + } else if (HAS_CAP(accdet->data->caps, > + ACCDET_PMIC_EINT1)) { > + /* enable RG_EINT1CONFIGACCDET */ > + regmap_update_bits(accdet->regmap, > + RG_EINT1CONFIGACCDET_ADDR, > + BIT(RG_EINT1CONFIGACCDET_SFT), > + BIT(RG_EINT1CONFIGACCDET_SFT)); > + } else if (HAS_CAP(accdet->data->caps, > + ACCDET_PMIC_BI_EINT)) { > + /* enable RG_EINT0CONFIGACCDET */ > + regmap_update_bits(accdet->regmap, > + RG_EINT0CONFIGACCDET_ADDR, > + BIT(RG_EINT0CONFIGACCDET_SFT), > + BIT(RG_EINT0CONFIGACCDET_SFT)); > + /* enable RG_EINT1CONFIGACCDET */ > + regmap_update_bits(accdet->regmap, > + RG_EINT1CONFIGACCDET_ADDR, > + BIT(RG_EINT1CONFIGACCDET_SFT), > + BIT(RG_EINT1CONFIGACCDET_SFT)); > + } > + } > + } > + > + if (accdet_dts.eint_detect_mode != 0x1) { > + /* current detect set 0.25uA */ > + regmap_update_bits(accdet->regmap, RG_ACCDETSPARE_ADDR, > + 0x3 << RG_ACCDETSPARE_SFT, > + 0x3 << RG_ACCDETSPARE_SFT); > + } > +} > + > +static void accdet_init_once(void) > +{ > + unsigned int reg = 0; > + > + /* reset the accdet unit */ > + regmap_update_bits(accdet->regmap, RG_ACCDET_RST_ADDR, > + BIT(RG_ACCDET_RST_SFT), BIT(RG_ACCDET_RST_SFT)); > + regmap_update_bits(accdet->regmap, RG_ACCDET_RST_ADDR, > + BIT(RG_ACCDET_RST_SFT), 0); > + > + /* clear high micbias1 voltage setting */ > + regmap_update_bits(accdet->regmap, RG_AUDPWDBMICBIAS1_ADDR, > + 0x3 << RG_AUDMICBIAS1HVEN_SFT, 0); > + /* clear micbias1 voltage */ > + regmap_update_bits(accdet->regmap, RG_AUDPWDBMICBIAS1_ADDR, > + 0x7 << RG_AUDMICBIAS1VREF_SFT, 0); > + > + /* init pwm frequency, duty & rise/falling delay */ > + regmap_write(accdet->regmap, ACCDET_PWM_WIDTH_ADDR, > + REGISTER_VAL(cust_pwm_deb->pwm_width)); > + regmap_write(accdet->regmap, ACCDET_PWM_THRESH_ADDR, > + REGISTER_VAL(cust_pwm_deb->pwm_thresh)); > + regmap_write(accdet->regmap, ACCDET_RISE_DELAY_ADDR, > + (cust_pwm_deb->fall_delay << 15 | cust_pwm_deb->rise_delay)); > + > + /* config micbias voltage, micbias1 vref is only controlled by accdet > + * if we need 2.8V, config [12:13] > + */ > + regmap_read(accdet->regmap, RG_AUDPWDBMICBIAS1_ADDR, ®); > + if (accdet_dts.mic_vol <= 7) { > + /* micbias1 <= 2.7V */ > + regmap_write(accdet->regmap, RG_AUDPWDBMICBIAS1_ADDR, > + reg | (accdet_dts.mic_vol << RG_AUDMICBIAS1VREF_SFT) | > + RG_AUDMICBIAS1LOWPEN_MASK_SFT); > + } else if (accdet_dts.mic_vol == 8) { > + /* micbias1 = 2.8v */ > + regmap_write(accdet->regmap, RG_AUDPWDBMICBIAS1_ADDR, > + reg | (3 << RG_AUDMICBIAS1HVEN_SFT) | > + RG_AUDMICBIAS1LOWPEN_MASK_SFT); > + } else if (accdet_dts.mic_vol == 9) { > + /* micbias1 = 2.85v */ > + regmap_write(accdet->regmap, RG_AUDPWDBMICBIAS1_ADDR, > + reg | (1 << RG_AUDMICBIAS1HVEN_SFT) | > + RG_AUDMICBIAS1LOWPEN_MASK_SFT); > + } > + /* mic mode setting */ > + regmap_read(accdet->regmap, RG_AUDACCDETMICBIAS0PULLLOW_ADDR, ®); > + if (accdet_dts.mic_mode == HEADSET_MODE_1) { > + /* ACC mode*/ > + regmap_write(accdet->regmap, RG_AUDACCDETMICBIAS0PULLLOW_ADDR, > + reg | RG_ACCDET_MODE_ANA11_MODE1); > + /* enable analog fast discharge */ > + regmap_update_bits(accdet->regmap, RG_ANALOGFDEN_ADDR, > + BIT(RG_ANALOGFDEN_SFT), > + BIT(RG_ANALOGFDEN_SFT)); > + regmap_update_bits(accdet->regmap, RG_ACCDETSPARE_ADDR, > + 0x3 << 11, 0x3 << 11); > + } else if (accdet_dts.mic_mode == HEADSET_MODE_2) { > + /* DCC mode Low cost mode without internal bias*/ > + regmap_write(accdet->regmap, RG_AUDACCDETMICBIAS0PULLLOW_ADDR, > + reg | RG_ACCDET_MODE_ANA11_MODE2); > + /* enable analog fast discharge */ > + regmap_update_bits(accdet->regmap, RG_ANALOGFDEN_ADDR, > + 0x3 << RG_ANALOGFDEN_SFT, > + 0x3 << RG_ANALOGFDEN_SFT); > + } else if (accdet_dts.mic_mode == HEADSET_MODE_6) { > + /* DCC mode Low cost mode with internal bias, > + * bit8 = 1 to use internal bias > + */ > + regmap_write(accdet->regmap, RG_AUDACCDETMICBIAS0PULLLOW_ADDR, > + reg | RG_ACCDET_MODE_ANA11_MODE6); > + regmap_update_bits(accdet->regmap, RG_AUDPWDBMICBIAS1_ADDR, > + BIT(RG_AUDMICBIAS1DCSW1PEN_SFT), > + BIT(RG_AUDMICBIAS1DCSW1PEN_SFT)); > + /* enable analog fast discharge */ > + regmap_update_bits(accdet->regmap, RG_ANALOGFDEN_ADDR, > + 0x3 << RG_ANALOGFDEN_SFT, > + 0x3 << RG_ANALOGFDEN_SFT); > + } > + > + if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT_IRQ)) { > + config_eint_init_by_mode(); > + config_digital_init_by_mode(); > + } else if (HAS_CAP(accdet->data->caps, ACCDET_AP_GPIO_EINT)) { > + /* set pull low pads and DCC mode */ > + regmap_write(accdet->regmap, RG_AUDACCDETMICBIAS0PULLLOW_ADDR, > + 0x8F); > + /* disconnect configaccdet */ > + regmap_write(accdet->regmap, RG_EINT1CONFIGACCDET_ADDR, > + 0x0); > + /* disable eint comparator */ > + regmap_write(accdet->regmap, RG_EINT0CMPEN_ADDR, 0x0); > + /* enable PWM */ > + regmap_write(accdet->regmap, ACCDET_CMP_PWM_EN_ADDR, 0x7); > + /* enable accdet sw mode */ > + regmap_write(accdet->regmap, ACCDET_HWMODE_EN_ADDR, 0x0); > + /* set DA signal to stable */ > + regmap_write(accdet->regmap, ACCDET_DA_STABLE_ADDR, 0x1); > + /* disable eint/inverter/sw_en */ > + regmap_write(accdet->regmap, ACCDET_SW_EN_ADDR, 0x0); > + } > +} > + > +static void accdet_init_debounce(void) > +{ > + /* set debounce to 1ms */ > + accdet_set_debounce(eint_state000, accdet_dts.pwm_deb.eint_debounce0); > + /* set debounce to 128ms */ > + accdet_set_debounce(eint_state011, accdet_dts.pwm_deb.eint_debounce3); > +} > + > +static inline void accdet_init(void) > +{ > + /* set and clear initial bit every eint interrutp */ > + regmap_update_bits(accdet->regmap, ACCDET_SEQ_INIT_ADDR, > + BIT(ACCDET_SEQ_INIT_SFT), BIT(ACCDET_SEQ_INIT_SFT)); > + mdelay(2); > + regmap_update_bits(accdet->regmap, ACCDET_SEQ_INIT_ADDR, > + BIT(ACCDET_SEQ_INIT_SFT), 0); > + mdelay(1); > + /* init the debounce time (debounce/32768)sec */ > + accdet_set_debounce(accdet_state000, cust_pwm_deb->debounce0); > + accdet_set_debounce(accdet_state001, cust_pwm_deb->debounce1); > + accdet_set_debounce(accdet_state011, cust_pwm_deb->debounce3); > + /* auxadc:2ms */ > + accdet_set_debounce(accdet_auxadc, cust_pwm_deb->debounce4); > + accdet_set_debounce(eint_state001, accdet_dts.pwm_deb.eint_debounce1); > + accdet_set_debounce(eint_inverter_state000, > + accdet_dts.pwm_deb.eint_inverter_debounce); > +} > + > +/* late init for DC trim, and this API Will be called by audio */ > +void mt6359_accdet_late_init(unsigned long data) > +{ > + if (atomic_cmpxchg(&accdet->init_once, 1, 0)) { > + del_timer_sync(&accdet_init_timer); > + accdet_init(); > + accdet_init_debounce(); > + accdet_init_once(); > + } else { > + pr_info("%s fail\n", __func__); > + } > +} > +EXPORT_SYMBOL(mt6359_accdet_late_init); > + > +static void delay_init_work_callback(struct work_struct *work) > +{ > + accdet_init(); > + accdet_init_debounce(); > + accdet_init_once(); > +} > + > +static void delay_init_timerhandler(struct timer_list *t) > +{ > + int ret = 0; > + > + ret = queue_work(accdet->delay_init_workqueue, > + &accdet->delay_init_work); > + if (!ret) > + pr_err("Error: %s (%d)\n", __func__, ret); > +} > + > +int mt6359_accdet_init(struct snd_soc_component *component, > + struct snd_soc_card *card) > +{ > + int ret = 0; > + struct mt63xx_accdet_data *priv = > + snd_soc_card_get_drvdata(component->card); > + > + /* Enable Headset and 4 Buttons Jack detection */ > + ret = snd_soc_card_jack_new(card, > + "Headset Jack", > + SND_JACK_HEADSET | > + SND_JACK_LINEOUT | > + SND_JACK_MECHANICAL, > + &priv->jack, > + NULL, 0); > + if (ret) { > + dev_err(card->dev, "Can't new Headset Jack %x\n", ret); > + return ret; > + } > + > + accdet->jack.jack->input_dev->id.bustype = BUS_HOST; > + snd_jack_set_key(accdet->jack.jack, SND_JACK_BTN_0, KEY_PLAYPAUSE); > + snd_jack_set_key(accdet->jack.jack, SND_JACK_BTN_1, KEY_VOLUMEDOWN); > + snd_jack_set_key(accdet->jack.jack, SND_JACK_BTN_2, KEY_VOLUMEUP); > + snd_jack_set_key(accdet->jack.jack, SND_JACK_BTN_3, KEY_VOICECOMMAND); > + > + return ret; > +} > +EXPORT_SYMBOL_GPL(mt6359_accdet_init); > + > +int mt6359_accdet_set_drvdata(struct snd_soc_card *card) > +{ > + snd_soc_card_set_drvdata(card, accdet); > + > + return 0; > +} > +EXPORT_SYMBOL_GPL(mt6359_accdet_set_drvdata); > + > +static int mt6359_accdet_probe(struct platform_device *pdev) > +{ > + int ret = 0; > + struct resource *res; > + struct mt6397_chip *mt6397_chip = dev_get_drvdata(pdev->dev.parent); > + const struct of_device_id *of_id = > + of_match_device(mt6359_accdet_of_match, &pdev->dev); > + if (!of_id) { > + dev_err(&pdev->dev, "Error: No device match found\n"); > + return -ENODEV; > + } > + > + accdet = devm_kzalloc(&pdev->dev, sizeof(*accdet), GFP_KERNEL); > + if (!accdet) > + return -ENOMEM; > + > + accdet->data = (struct accdet_priv *)of_id->data; > + accdet->pdev = pdev; > + > + /* parse dts attributes */ > + ret = mt6359_accdet_parse_dt(); > + if (ret) { > + dev_err(&pdev->dev, "Error: Get dts data failed (%d)\n", ret); > + return ret; > + } > + /* init lock */ > + accdet->wake_lock = wakeup_source_register(NULL, "accdet_wake_lock"); > + if (!accdet->wake_lock) { > + dev_err(&pdev->dev, "Error: get accdet_wake_lock fail\n"); > + return -ENOMEM; > + } > + accdet->timer_lock = wakeup_source_register(NULL, "accdet_timer_lock"); > + if (!accdet->timer_lock) { > + dev_err(&pdev->dev, "Error: get accdet_timer_lock fail\n"); > + return -ENOMEM; > + } > + mutex_init(&accdet->res_lock); > + > + platform_set_drvdata(pdev, accdet); > + ret = devm_snd_soc_register_component(&pdev->dev, > + &mt6359_accdet_soc_driver, > + NULL, 0); > + if (ret) { > + dev_err(&pdev->dev, "Error: register component fail\n"); > + return ret; > + } > + res = platform_get_resource(pdev, IORESOURCE_MEM, 0); > + accdet->regmap = mt6397_chip->regmap; > + accdet->dev = &pdev->dev; > + accdet->auxadc_offset = 0; > + > + /* register pmic interrupt */ > + accdet->accdet_irq = platform_get_irq(pdev, 0); > + if (accdet->accdet_irq < 0) { > + dev_err(&pdev->dev, > + "Error: Get accdet irq failed (%d)\n", > + accdet->accdet_irq); > + return accdet->accdet_irq; > + } > + ret = devm_request_threaded_irq(&pdev->dev, accdet->accdet_irq, > + NULL, mtk_accdet_irq_handler_thread, > + IRQF_TRIGGER_HIGH | IRQF_ONESHOT, > + "ACCDET_IRQ", accdet); > + if (ret) { > + dev_err(&pdev->dev, > + "Error: Get thread irq request failed (%d) (%d)\n", > + accdet->accdet_irq, ret); > + return ret; > + } > + > + if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT0)) { > + accdet->accdet_eint0 = platform_get_irq(pdev, 1); > + if (accdet->accdet_eint0 < 0) { > + dev_err(&pdev->dev, > + "Error: Get eint0 irq failed (%d)\n", > + accdet->accdet_eint0); > + return accdet->accdet_eint0; > + } > + ret = devm_request_threaded_irq(&pdev->dev, > + accdet->accdet_eint0, > + NULL, mtk_accdet_irq_handler_thread, > + IRQF_TRIGGER_HIGH | IRQF_ONESHOT, > + "ACCDET_EINT0", accdet); > + if (ret) { > + dev_err(&pdev->dev, > + "Error: Get eint0 irq request failed (%d)\n", > + ret); > + return ret; > + } > + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT1)) { > + accdet->accdet_eint1 = platform_get_irq(pdev, 2); > + if (accdet->accdet_eint1 < 0) { > + dev_err(&pdev->dev, > + "Error: Get eint1 irq failed (%d)\n", > + accdet->accdet_eint1); > + return accdet->accdet_eint1; > + } > + ret = devm_request_threaded_irq(&pdev->dev, > + accdet->accdet_eint1, > + NULL, > + mtk_accdet_irq_handler_thread, > + IRQF_TRIGGER_HIGH | IRQF_ONESHOT, > + "ACCDET_EINT1", accdet); > + if (ret) { > + dev_err(&pdev->dev, > + "Error: Get eint1 irq request failed (%d)\n", > + ret); > + return ret; > + } > + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_BI_EINT)) { > + accdet->accdet_eint0 = platform_get_irq(pdev, 1); > + if (accdet->accdet_eint0 < 0) { > + dev_err(&pdev->dev, > + "Error: Get eint0 irq failed (%d)\n", > + accdet->accdet_eint0); > + return accdet->accdet_eint0; > + } > + ret = devm_request_threaded_irq(&pdev->dev, > + accdet->accdet_eint0, > + NULL, > + mtk_accdet_irq_handler_thread, > + IRQF_TRIGGER_HIGH | IRQF_ONESHOT, > + "ACCDET_EINT0", accdet); > + if (ret) { > + dev_err(&pdev->dev, > + "Error: Get eint0 irq request failed (%d)\n", > + ret); > + return ret; > + } > + accdet->accdet_eint1 = platform_get_irq(pdev, 2); > + if (accdet->accdet_eint1 < 0) { > + dev_err(&pdev->dev, > + "Error: Get eint1 irq failed (%d)\n", > + accdet->accdet_eint1); > + return accdet->accdet_eint1; > + } > + ret = devm_request_threaded_irq(&pdev->dev, > + accdet->accdet_eint1, > + NULL, > + mtk_accdet_irq_handler_thread, > + IRQF_TRIGGER_HIGH | IRQF_ONESHOT, > + "ACCDET_EINT1", accdet); > + if (ret) { > + dev_err(&pdev->dev, > + "Error: Get eint1 irq request failed (%d)\n", > + ret); > + return ret; > + } > + } > + > + /* setup timer */ > + timer_setup(&micbias_timer, dis_micbias_timerhandler, 0); > + micbias_timer.expires = jiffies + MICBIAS_DISABLE_TIMER; > + timer_setup(&accdet_init_timer, delay_init_timerhandler, 0); > + accdet_init_timer.expires = jiffies + ACCDET_INIT_WAIT_TIMER; > + > + /* Create workqueue */ > + accdet->delay_init_workqueue = > + create_singlethread_workqueue("delay_init"); > + INIT_WORK(&accdet->delay_init_work, delay_init_work_callback); > + if (!accdet->delay_init_workqueue) { > + dev_err(&pdev->dev, "Error: Create dinit workqueue failed\n"); > + ret = -1; > + goto err_delay_init_wq; > + } > + accdet->accdet_workqueue = create_singlethread_workqueue("accdet"); > + INIT_WORK(&accdet->accdet_work, accdet_work_callback); > + if (!accdet->accdet_workqueue) { > + dev_err(&pdev->dev, "Error: Create accdet workqueue failed\n"); > + ret = -1; > + goto err_accdet_wq; > + } > + > + accdet->dis_micbias_workqueue = > + create_singlethread_workqueue("dismicQueue"); > + INIT_WORK(&accdet->dis_micbias_work, dis_micbias_work_callback); > + if (!accdet->dis_micbias_workqueue) { > + dev_err(&pdev->dev, "Error: Create dismic workqueue failed\n"); > + ret = -1; > + goto err_dis_micbias_wq; > + } > + accdet->eint_workqueue = create_singlethread_workqueue("accdet_eint"); > + INIT_WORK(&accdet->eint_work, eint_work_callback); > + if (!accdet->eint_workqueue) { > + dev_err(&pdev->dev, "Error: Create eint workqueue failed\n"); > + ret = -1; > + goto err_eint_wq; > + } > + if (HAS_CAP(accdet->data->caps, ACCDET_AP_GPIO_EINT)) { > + accdet->accdet_eint_type = IRQ_TYPE_LEVEL_LOW; > + ret = ext_eint_setup(pdev); > + if (ret) > + destroy_workqueue(accdet->eint_workqueue); > + } > + > + atomic_set(&accdet->init_once, 1); > + mod_timer(&accdet_init_timer, (jiffies + ACCDET_INIT_WAIT_TIMER)); > + > + return 0; > + > +err_eint_wq: > + destroy_workqueue(accdet->dis_micbias_workqueue); > +err_dis_micbias_wq: > + destroy_workqueue(accdet->accdet_workqueue); > +err_accdet_wq: > + destroy_workqueue(accdet->delay_init_workqueue); > +err_delay_init_wq: > + pr_notice("%s error. now exit.!\n", __func__); > + return ret; > +} > + > +static int mt6359_accdet_remove(struct platform_device *pdev) > +{ > + destroy_workqueue(accdet->eint_workqueue); > + destroy_workqueue(accdet->dis_micbias_workqueue); > + destroy_workqueue(accdet->accdet_workqueue); > + destroy_workqueue(accdet->delay_init_workqueue); > + devm_kfree(&pdev->dev, accdet); > + return 0; > +} > + > +static struct platform_driver mt6359_accdet_driver = { > + .probe = mt6359_accdet_probe, > + .remove = mt6359_accdet_remove, > + .driver = { > + .name = "pmic-codec-accdet", > + .of_match_table = mt6359_accdet_of_match, > + }, > +}; > + > +static int __init mt6359_accdet_soc_init(void) > +{ > + int ret = 0; > + > + ret = platform_driver_register(&mt6359_accdet_driver); > + if (ret) > + return -ENODEV; > + return 0; > +} > + > +static void __exit mt6359_accdet_soc_exit(void) > +{ > + platform_driver_unregister(&mt6359_accdet_driver); > +} > +module_init(mt6359_accdet_soc_init); > +module_exit(mt6359_accdet_soc_exit); > + > +/* Module information */ > +MODULE_DESCRIPTION("MT6359 ALSA SoC accdet driver"); > +MODULE_AUTHOR("Argus Lin <argus.lin@mediatek.com>"); > +MODULE_LICENSE("GPL v2"); > diff --git a/sound/soc/codecs/mt6359-accdet.h b/sound/soc/codecs/mt6359-accdet.h > new file mode 100644 > index 0000000..d081d69 > --- /dev/null > +++ b/sound/soc/codecs/mt6359-accdet.h > @@ -0,0 +1,136 @@ > +/* SPDX-License-Identifier: GPL-2.0 */ > +/* > + * Copyright (C) 2021 MediaTek Inc. > + * Author: Argus Lin <argus.lin@mediatek.com> > + */ > + > +#ifndef _ACCDET_H_ > +#define _ACCDET_H_ > + > +#include <linux/ctype.h> > +#include <linux/string.h> > + > +#define ACCDET_DEVNAME "accdet" > +/* SW ENV define */ > +#define NO_KEY (0x0) > +#define UP_KEY (0x01) > +#define MD_KEY (0x02) > +#define DW_KEY (0x04) > +#define AS_KEY (0x08) > + > +#define HEADSET_MODE_1 (1) > +#define HEADSET_MODE_2 (2) > +#define HEADSET_MODE_6 (6) > + > +/* IOCTL */ > +#define ACCDET_IOC_MAGIC 'A' > +#define ACCDET_INIT _IO(ACCDET_IOC_MAGIC, 0) > +#define SET_CALL_STATE _IO(ACCDET_IOC_MAGIC, 1) > +#define GET_BUTTON_STATUS _IO(ACCDET_IOC_MAGIC, 2) > + > +/* 400us, Accdet irq clear timeout */ > +#define ACCDET_TIME_OUT 0x61A80 > + > +/* cable type recognized by accdet, and report to WiredAccessoryManager */ > +enum accdet_report_state { > + NO_DEVICE = 0, > + HEADSET_MIC = 1, > + HEADSET_NO_MIC = 2, > + HEADSET_FIVE_POLE = 3, > + LINE_OUT_DEVICE = 4, > +}; > + > +/* accdet status got from accdet FSM */ > +enum accdet_status { > + PLUG_OUT = 0, > + MIC_BIAS = 1, > + HOOK_SWITCH = 2, > + BI_MIC_BIAS = 3, > + LINE_OUT = 4, > + STAND_BY = 5 > +}; > + > +enum accdet_eint_ID { > + NO_PMIC_EINT = 0, > + PMIC_EINT0 = 1, > + PMIC_EINT1 = 2, > + PMIC_BIEINT = 3, > +}; > + > +/* EINT state when moisture enable */ > +enum eint_moisture_status { > + M_PLUG_IN = 0, > + M_WATER_IN = 1, > + M_HP_PLUG_IN = 2, > + M_PLUG_OUT = 3, > + M_NO_ACT = 4, > + M_UNKNOWN = 5, > +}; > + > +struct three_key_threshold { > + unsigned int mid; > + unsigned int up; > + unsigned int down; > +}; > + > +struct four_key_threshold { > + unsigned int mid; > + unsigned int voice; > + unsigned int up; > + unsigned int down; > +}; > + > +struct pwm_deb_settings { > + unsigned int pwm_width; > + unsigned int pwm_thresh; > + unsigned int fall_delay; > + unsigned int rise_delay; > + unsigned int debounce0; > + unsigned int debounce1; > + unsigned int debounce3; > + unsigned int debounce4; > + unsigned int eint_pwm_width; > + unsigned int eint_pwm_thresh; > + unsigned int eint_debounce0; > + unsigned int eint_debounce1; > + unsigned int eint_debounce2; > + unsigned int eint_debounce3; > + unsigned int eint_inverter_debounce; > + > +}; > + > +struct head_dts_data { > + unsigned int mic_vol; > + unsigned int mic_mode; > + unsigned int plugout_deb; > + unsigned int eint_pol; > + struct pwm_deb_settings pwm_deb; > + struct three_key_threshold three_key; > + struct four_key_threshold four_key; > + unsigned int moisture_detect_enable; > + unsigned int eint_detect_mode; > + unsigned int eint_use_ext_res; > + unsigned int moisture_detect_mode; > + unsigned int moisture_comp_vth; > + unsigned int moisture_comp_vref2; > + unsigned int moisture_use_ext_res; > +}; > + > +enum { > + accdet_state000 = 0, > + accdet_state001, > + accdet_state010, > + accdet_state011, > + accdet_auxadc, > + eint_state000, > + eint_state001, > + eint_state010, > + eint_state011, > + eint_inverter_state000, > +}; > + > +/* just be called by audio module for DC trim */ > +void mt6359_accdet_late_init(unsigned long data); > +int mt6359_accdet_init(struct snd_soc_component *component, struct snd_soc_card *card); > +int mt6359_accdet_set_drvdata(struct snd_soc_card *card); > +#endif > diff --git a/sound/soc/codecs/mt6359.h b/sound/soc/codecs/mt6359.h > index 35f806b..9f9a94a 100644 > --- a/sound/soc/codecs/mt6359.h > +++ b/sound/soc/codecs/mt6359.h > @@ -8,128 +8,1779 @@ > #define _MT6359_H_ > > /*************Register Bit Define*************/ > -#define PMIC_ACCDET_IRQ_SHIFT 0 > -#define PMIC_ACCDET_EINT0_IRQ_SHIFT 2 > -#define PMIC_ACCDET_EINT1_IRQ_SHIFT 3 > -#define PMIC_ACCDET_IRQ_CLR_SHIFT 8 > -#define PMIC_ACCDET_EINT0_IRQ_CLR_SHIFT 10 > -#define PMIC_ACCDET_EINT1_IRQ_CLR_SHIFT 11 > -#define PMIC_RG_INT_STATUS_ACCDET_SHIFT 5 > -#define PMIC_RG_INT_STATUS_ACCDET_EINT0_SHIFT 6 > -#define PMIC_RG_INT_STATUS_ACCDET_EINT1_SHIFT 7 > -#define PMIC_RG_EINT0CONFIGACCDET_SHIFT 11 > -#define PMIC_RG_EINT1CONFIGACCDET_SHIFT 0 > -#define PMIC_ACCDET_EINT0_INVERTER_SW_EN_SHIFT 6 > -#define PMIC_ACCDET_EINT1_INVERTER_SW_EN_SHIFT 8 > -#define PMIC_RG_MTEST_EN_SHIFT 8 > -#define PMIC_RG_MTEST_SEL_SHIFT 9 > -#define PMIC_ACCDET_EINT0_M_SW_EN_SHIFT 10 > -#define PMIC_ACCDET_EINT1_M_SW_EN_SHIFT 11 > -#define PMIC_ACCDET_EINT0_CEN_STABLE_SHIFT 5 > -#define PMIC_ACCDET_EINT1_CEN_STABLE_SHIFT 10 > -#define PMIC_ACCDET_DA_STABLE_SHIFT 0 > -#define PMIC_ACCDET_EINT0_EN_STABLE_SHIFT 1 > -#define PMIC_ACCDET_EINT0_CMPEN_STABLE_SHIFT 2 > -#define PMIC_ACCDET_EINT1_EN_STABLE_SHIFT 6 > -#define PMIC_ACCDET_EINT1_CMPEN_STABLE_SHIFT 7 > -#define PMIC_ACCDET_EINT_CTURBO_SEL_SHIFT 7 > -#define PMIC_ACCDET_EINT0_CTURBO_SW_SHIFT 7 > -#define PMIC_RG_EINTCOMPVTH_SHIFT 4 > -#define PMIC_RG_EINT0HIRENB_SHIFT 12 > -#define PMIC_RG_EINT0NOHYS_SHIFT 10 > -#define PMIC_ACCDET_SW_EN_SHIFT 0 > -#define PMIC_ACCDET_EINT0_MEM_IN_SHIFT 6 > -#define PMIC_ACCDET_MEM_IN_SHIFT 6 > -#define PMIC_ACCDET_EINT_DEBOUNCE0_SHIFT 0 > -#define PMIC_ACCDET_EINT_DEBOUNCE1_SHIFT 4 > -#define PMIC_ACCDET_EINT_DEBOUNCE2_SHIFT 8 > -#define PMIC_ACCDET_EINT_DEBOUNCE3_SHIFT 12 > -#define PMIC_RG_ACCDET2AUXSWEN_SHIFT 14 > -#define PMIC_AUDACCDETAUXADCSWCTRL_SEL_SHIFT 9 > -#define PMIC_AUDACCDETAUXADCSWCTRL_SW_SHIFT 10 > -#define PMIC_RG_EINT0CTURBO_SHIFT 5 > -#define PMIC_RG_EINT1CTURBO_SHIFT 13 > -#define PMIC_ACCDET_EINT_M_PLUG_IN_NUM_SHIFT 12 > -#define PMIC_ACCDET_EINT_M_DETECT_EN_SHIFT 12 > -#define PMIC_ACCDET_EINT0_SW_EN_SHIFT 2 > -#define PMIC_ACCDET_EINT1_SW_EN_SHIFT 4 > -#define PMIC_ACCDET_EINT_CMPMOUT_SEL_SHIFT 12 > -#define PMIC_ACCDET_EINT_CMPMEN_SEL_SHIFT 6 > -#define PMIC_RG_HPLOUTPUTSTBENH_VAUDP32_SHIFT 0 > -#define PMIC_RG_HPROUTPUTSTBENH_VAUDP32_SHIFT 4 > -#define PMIC_RG_EINT0EN_SHIFT 2 > -#define PMIC_RG_EINT1EN_SHIFT 10 > -#define PMIC_RG_NCP_PDDIS_EN_SHIFT 0 > -#define PMIC_RG_ACCDETSPARE_SHIFT 0 > -#define PMIC_RG_ACCDET_RST_SHIFT 1 > -#define PMIC_RG_AUDMICBIAS1HVEN_SHIFT 12 > -#define PMIC_RG_AUDMICBIAS1VREF_SHIFT 4 > -#define PMIC_RG_ANALOGFDEN_SHIFT 12 > -#define PMIC_RG_AUDMICBIAS1DCSW1PEN_SHIFT 8 > -#define PMIC_RG_AUDMICBIAS1LOWPEN_SHIFT 2 > -#define PMIC_ACCDET_SEQ_INIT_SHIFT 1 > -#define PMIC_RG_EINTCOMPVTH_MASK 0xf > -#define PMIC_ACCDET_EINT0_MEM_IN_MASK 0x3 > -#define PMIC_ACCDET_EINT_DEBOUNCE0_MASK 0xf > -#define PMIC_ACCDET_EINT_DEBOUNCE1_MASK 0xf > -#define PMIC_ACCDET_EINT_DEBOUNCE2_MASK 0xf > -#define PMIC_ACCDET_EINT_DEBOUNCE3_MASK 0xf > -#define PMIC_ACCDET_EINT0_IRQ_SHIFT 2 > -#define PMIC_ACCDET_EINT1_IRQ_SHIFT 3 > - > -/* AUDENC_ANA_CON16: */ > -#define RG_AUD_MICBIAS1_LOWP_EN BIT(PMIC_RG_AUDMICBIAS1LOWPEN_SHIFT) > - > +#define MT6359_TOP0_ID 0x0 > +#define MT6359_SMT_CON1 0x32 > +#define MT6359_DRV_CON2 0x3c > +#define MT6359_DRV_CON3 0x3e > +#define MT6359_DRV_CON4 0x40 > +#define MT6359_TOP_CKPDN_CON0 0x10c > +#define MT6359_TOP_CKPDN_CON0_SET 0x10e > +#define MT6359_TOP_CKPDN_CON0_CLR 0x110 > +#define MT6359_AUXADC_RQST0 0x1108 > +#define MT6359_AUXADC_CON10 0x11a0 > +#define MT6359_AUXADC_ACCDET 0x11ba > +#define MT6359_LDO_VUSB_OP_EN 0x1d0c > +#define MT6359_LDO_VUSB_OP_EN_SET 0x1d0e > +#define MT6359_LDO_VUSB_OP_EN_CLR 0x1d10 > +#define MT6359_AUD_TOP_CKPDN_CON0 0x230c > +#define MT6359_AUD_TOP_CKPDN_CON0_SET 0x230e > +#define MT6359_AUD_TOP_CKPDN_CON0_CLR 0x2310 > +#define MT6359_AUD_TOP_RST_CON0 0x2320 > +#define MT6359_AUD_TOP_RST_CON0_SET 0x2322 > +#define MT6359_AUD_TOP_RST_CON0_CLR 0x2324 > +#define MT6359_AUD_TOP_INT_CON0 0x2328 > +#define MT6359_AUD_TOP_INT_CON0_SET 0x232a > +#define MT6359_AUD_TOP_INT_CON0_CLR 0x232c > +#define MT6359_AUD_TOP_INT_MASK_CON0 0x232e > +#define MT6359_AUD_TOP_INT_MASK_CON0_SET 0x2330 > +#define MT6359_AUD_TOP_INT_MASK_CON0_CLR 0x2332 > +#define MT6359_AUD_TOP_INT_STATUS0 0x2334 > +#define MT6359_AFE_NCP_CFG2 0x24e2 > +#define MT6359_AUDENC_DSN_ID 0x2500 > +#define MT6359_AUDENC_DSN_REV0 0x2502 > +#define MT6359_AUDENC_DSN_DBI 0x2504 > +#define MT6359_AUDENC_DSN_FPI 0x2506 > +#define MT6359_AUDENC_ANA_CON0 0x2508 > +#define MT6359_AUDENC_ANA_CON1 0x250a > +#define MT6359_AUDENC_ANA_CON2 0x250c > +#define MT6359_AUDENC_ANA_CON3 0x250e > +#define MT6359_AUDENC_ANA_CON4 0x2510 > +#define MT6359_AUDENC_ANA_CON5 0x2512 > +#define MT6359_AUDENC_ANA_CON6 0x2514 > +#define MT6359_AUDENC_ANA_CON7 0x2516 > +#define MT6359_AUDENC_ANA_CON8 0x2518 > +#define MT6359_AUDENC_ANA_CON9 0x251a > +#define MT6359_AUDENC_ANA_CON10 0x251c > +#define MT6359_AUDENC_ANA_CON11 0x251e > +#define MT6359_AUDENC_ANA_CON12 0x2520 > +#define MT6359_AUDENC_ANA_CON13 0x2522 > +#define MT6359_AUDENC_ANA_CON14 0x2524 > +#define MT6359_AUDENC_ANA_CON15 0x2526 > +#define MT6359_AUDENC_ANA_CON16 0x2528 > +#define MT6359_AUDENC_ANA_CON17 0x252a > +#define MT6359_AUDENC_ANA_CON18 0x252c > +#define MT6359_AUDENC_ANA_CON19 0x252e > +#define MT6359_AUDENC_ANA_CON20 0x2530 > +#define MT6359_AUDENC_ANA_CON21 0x2532 > +#define MT6359_AUDENC_ANA_CON22 0x2534 > +#define MT6359_AUDENC_ANA_CON23 0x2536 > +#define MT6359_AUDDEC_DSN_ID 0x2580 > +#define MT6359_AUDDEC_DSN_REV0 0x2582 > +#define MT6359_AUDDEC_DSN_DBI 0x2584 > +#define MT6359_AUDDEC_DSN_FPI 0x2586 > +#define MT6359_AUDDEC_ANA_CON0 0x2588 > +#define MT6359_AUDDEC_ANA_CON1 0x258a > +#define MT6359_AUDDEC_ANA_CON2 0x258c > +#define MT6359_AUDDEC_ANA_CON3 0x258e > +#define MT6359_AUDDEC_ANA_CON4 0x2590 > +#define MT6359_AUDDEC_ANA_CON5 0x2592 > +#define MT6359_AUDDEC_ANA_CON6 0x2594 > +#define MT6359_AUDDEC_ANA_CON7 0x2596 > +#define MT6359_AUDDEC_ANA_CON8 0x2598 > +#define MT6359_AUDDEC_ANA_CON9 0x259a > +#define MT6359_AUDDEC_ANA_CON10 0x259c > +#define MT6359_AUDDEC_ANA_CON11 0x259e > +#define MT6359_AUDDEC_ANA_CON12 0x25a0 > +#define MT6359_AUDDEC_ANA_CON13 0x25a2 > +#define MT6359_AUDDEC_ANA_CON14 0x25a4 > +#define MT6359_ACCDET_DSN_DIG_ID 0x2680 > +#define MT6359_ACCDET_DSN_DIG_REV0 0x2682 > +#define MT6359_ACCDET_DSN_DBI 0x2684 > +#define MT6359_ACCDET_DSN_FPI 0x2686 > +#define MT6359_ACCDET_CON0 0x2688 > +#define MT6359_ACCDET_CON1 0x268a > +#define MT6359_ACCDET_CON2 0x268c > +#define MT6359_ACCDET_CON3 0x268e > +#define MT6359_ACCDET_CON4 0x2690 > +#define MT6359_ACCDET_CON5 0x2692 > +#define MT6359_ACCDET_CON6 0x2694 > +#define MT6359_ACCDET_CON7 0x2696 > +#define MT6359_ACCDET_CON8 0x2698 > +#define MT6359_ACCDET_CON9 0x269a > +#define MT6359_ACCDET_CON10 0x269c > +#define MT6359_ACCDET_CON11 0x269e > +#define MT6359_ACCDET_CON12 0x26a0 > +#define MT6359_ACCDET_CON13 0x26a2 > +#define MT6359_ACCDET_CON14 0x26a4 > +#define MT6359_ACCDET_CON15 0x26a6 > +#define MT6359_ACCDET_CON16 0x26a8 > +#define MT6359_ACCDET_CON17 0x26aa > +#define MT6359_ACCDET_CON18 0x26ac > +#define MT6359_ACCDET_CON19 0x26ae > +#define MT6359_ACCDET_CON20 0x26b0 > +#define MT6359_ACCDET_CON21 0x26b2 > +#define MT6359_ACCDET_CON22 0x26b4 > +#define MT6359_ACCDET_CON23 0x26b6 > +#define MT6359_ACCDET_CON24 0x26b8 > +#define MT6359_ACCDET_CON25 0x26ba > +#define MT6359_ACCDET_CON26 0x26bc > +#define MT6359_ACCDET_CON27 0x26be > +#define MT6359_ACCDET_CON28 0x26c0 > +#define MT6359_ACCDET_CON29 0x26c2 > +#define MT6359_ACCDET_CON30 0x26c4 > +#define MT6359_ACCDET_CON31 0x26c6 > +#define MT6359_ACCDET_CON32 0x26c8 > +#define MT6359_ACCDET_CON33 0x26ca > +#define MT6359_ACCDET_CON34 0x26cc > +#define MT6359_ACCDET_CON35 0x26ce > +#define MT6359_ACCDET_CON36 0x26d0 > +#define MT6359_ACCDET_CON37 0x26d2 > +#define MT6359_ACCDET_CON38 0x26d4 > +#define MT6359_ACCDET_CON39 0x26d6 > +#define MT6359_ACCDET_CON40 0x26d8 > + > +#define TOP0_ANA_ID_ADDR \ > + MT6359_TOP0_ID > +#define TOP0_ANA_ID_SFT 0 > +#define TOP0_ANA_ID_MASK 0xFF > +#define TOP0_ANA_ID_MASK_SFT (0xFF << 0) > +#define AUXADC_RQST_CH0_ADDR \ > + MT6359_AUXADC_RQST0 > +#define AUXADC_RQST_CH0_SFT 0 > +#define AUXADC_RQST_CH0_MASK 0x1 > +#define AUXADC_RQST_CH0_MASK_SFT (0x1 << 0) > +#define AUXADC_ACCDET_ANASWCTRL_EN_ADDR \ > + MT6359_AUXADC_CON15 > +#define AUXADC_ACCDET_ANASWCTRL_EN_SFT 6 > +#define AUXADC_ACCDET_ANASWCTRL_EN_MASK 0x1 > +#define AUXADC_ACCDET_ANASWCTRL_EN_MASK_SFT (0x1 << 6) > + > +#define AUXADC_ACCDET_AUTO_SPL_ADDR \ > + MT6359_AUXADC_ACCDET > +#define AUXADC_ACCDET_AUTO_SPL_SFT 0 > +#define AUXADC_ACCDET_AUTO_SPL_MASK 0x1 > +#define AUXADC_ACCDET_AUTO_SPL_MASK_SFT (0x1 << 0) > +#define AUXADC_ACCDET_AUTO_RQST_CLR_ADDR \ > + MT6359_AUXADC_ACCDET > +#define AUXADC_ACCDET_AUTO_RQST_CLR_SFT 1 > +#define AUXADC_ACCDET_AUTO_RQST_CLR_MASK 0x1 > +#define AUXADC_ACCDET_AUTO_RQST_CLR_MASK_SFT (0x1 << 1) > +#define AUXADC_ACCDET_DIG1_RSV0_ADDR \ > + MT6359_AUXADC_ACCDET > +#define AUXADC_ACCDET_DIG1_RSV0_SFT 2 > +#define AUXADC_ACCDET_DIG1_RSV0_MASK 0x3F > +#define AUXADC_ACCDET_DIG1_RSV0_MASK_SFT (0x3F << 2) > +#define AUXADC_ACCDET_DIG0_RSV0_ADDR \ > + MT6359_AUXADC_ACCDET > +#define AUXADC_ACCDET_DIG0_RSV0_SFT 8 > +#define AUXADC_ACCDET_DIG0_RSV0_MASK 0xFF > +#define AUXADC_ACCDET_DIG0_RSV0_MASK_SFT (0xFF << 8) > + > +#define RG_ACCDET_CK_PDN_ADDR \ > + MT6359_AUD_TOP_CKPDN_CON0 > +#define RG_ACCDET_CK_PDN_SFT 0 > +#define RG_ACCDET_CK_PDN_MASK 0x1 > +#define RG_ACCDET_CK_PDN_MASK_SFT (0x1 << 0) > + > +#define RG_ACCDET_RST_ADDR \ > + MT6359_AUD_TOP_RST_CON0 > +#define RG_ACCDET_RST_SFT 1 > +#define RG_ACCDET_RST_MASK 0x1 > +#define RG_ACCDET_RST_MASK_SFT (0x1 << 1) > +#define BANK_ACCDET_SWRST_ADDR \ > + MT6359_AUD_TOP_RST_BANK_CON0 > +#define BANK_ACCDET_SWRST_SFT 0 > +#define BANK_ACCDET_SWRST_MASK 0x1 > +#define BANK_ACCDET_SWRST_MASK_SFT (0x1 << 0) > + > +#define RG_INT_EN_ACCDET_ADDR \ > + MT6359_AUD_TOP_INT_CON0 > +#define RG_INT_EN_ACCDET_SFT 5 > +#define RG_INT_EN_ACCDET_MASK 0x1 > +#define RG_INT_EN_ACCDET_MASK_SFT (0x1 << 5) > +#define RG_INT_EN_ACCDET_EINT0_ADDR \ > + MT6359_AUD_TOP_INT_CON0 > +#define RG_INT_EN_ACCDET_EINT0_SFT 6 > +#define RG_INT_EN_ACCDET_EINT0_MASK 0x1 > +#define RG_INT_EN_ACCDET_EINT0_MASK_SFT (0x1 << 6) > +#define RG_INT_EN_ACCDET_EINT1_ADDR \ > + MT6359_AUD_TOP_INT_CON0 > +#define RG_INT_EN_ACCDET_EINT1_SFT 7 > +#define RG_INT_EN_ACCDET_EINT1_MASK 0x1 > +#define RG_INT_EN_ACCDET_EINT1_MASK_SFT (0x1 << 7) > + > +#define RG_INT_MASK_ACCDET_ADDR \ > + MT6359_AUD_TOP_INT_MASK_CON0 > +#define RG_INT_MASK_ACCDET_SFT 5 > +#define RG_INT_MASK_ACCDET_MASK 0x1 > +#define RG_INT_MASK_ACCDET_MASK_SFT (0x1 << 5) > +#define RG_INT_MASK_ACCDET_EINT0_ADDR \ > + MT6359_AUD_TOP_INT_MASK_CON0 > +#define RG_INT_MASK_ACCDET_EINT0_SFT 6 > +#define RG_INT_MASK_ACCDET_EINT0_MASK 0x1 > +#define RG_INT_MASK_ACCDET_EINT0_MASK_SFT (0x1 << 6) > +#define RG_INT_MASK_ACCDET_EINT1_ADDR \ > + MT6359_AUD_TOP_INT_MASK_CON0 > +#define RG_INT_MASK_ACCDET_EINT1_SFT 7 > +#define RG_INT_MASK_ACCDET_EINT1_MASK 0x1 > +#define RG_INT_MASK_ACCDET_EINT1_MASK_SFT (0x1 << 7) > + > +#define RG_INT_STATUS_ACCDET_ADDR \ > + MT6359_AUD_TOP_INT_STATUS0 > +#define RG_INT_STATUS_ACCDET_SFT 5 > +#define RG_INT_STATUS_ACCDET_MASK 0x1 > +#define RG_INT_STATUS_ACCDET_MASK_SFT (0x1 << 5) > +#define RG_INT_STATUS_ACCDET_EINT0_ADDR \ > + MT6359_AUD_TOP_INT_STATUS0 > +#define RG_INT_STATUS_ACCDET_EINT0_SFT 6 > +#define RG_INT_STATUS_ACCDET_EINT0_MASK 0x1 > +#define RG_INT_STATUS_ACCDET_EINT0_MASK_SFT (0x1 << 6) > +#define RG_INT_STATUS_ACCDET_EINT1_ADDR \ > + MT6359_AUD_TOP_INT_STATUS0 > +#define RG_INT_STATUS_ACCDET_EINT1_SFT 7 > +#define RG_INT_STATUS_ACCDET_EINT1_MASK 0x1 > +#define RG_INT_STATUS_ACCDET_EINT1_MASK_SFT (0x1 << 7) > + > +#define RG_INT_RAW_STATUS_ACCDET_ADDR \ > + MT6359_AUD_TOP_INT_RAW_STATUS0 > +#define RG_INT_RAW_STATUS_ACCDET_SFT 5 > +#define RG_INT_RAW_STATUS_ACCDET_MASK 0x1 > +#define RG_INT_RAW_STATUS_ACCDET_MASK_SFT (0x1 << 5) > +#define RG_INT_RAW_STATUS_ACCDET_EINT0_ADDR \ > + MT6359_AUD_TOP_INT_RAW_STATUS0 > +#define RG_INT_RAW_STATUS_ACCDET_EINT0_SFT 6 > +#define RG_INT_RAW_STATUS_ACCDET_EINT0_MASK 0x1 > +#define RG_INT_RAW_STATUS_ACCDET_EINT0_MASK_SFT (0x1 << 6) > +#define RG_INT_RAW_STATUS_ACCDET_EINT1_ADDR \ > + MT6359_AUD_TOP_INT_RAW_STATUS0 > +#define RG_INT_RAW_STATUS_ACCDET_EINT1_SFT 7 > +#define RG_INT_RAW_STATUS_ACCDET_EINT1_MASK 0x1 > +#define RG_INT_RAW_STATUS_ACCDET_EINT1_MASK_SFT (0x1 << 7) > + > +#define RG_AUDACCDETMICBIAS0PULLLOW_ADDR \ > + MT6359_AUDENC_ANA_CON18 > +#define RG_AUDACCDETMICBIAS0PULLLOW_SFT 0 > +#define RG_AUDACCDETMICBIAS0PULLLOW_MASK 0x1 > +#define RG_AUDACCDETMICBIAS0PULLLOW_MASK_SFT (0x1 << 0) > +#define RG_AUDACCDETMICBIAS1PULLLOW_ADDR \ > + MT6359_AUDENC_ANA_CON18 > +#define RG_AUDACCDETMICBIAS1PULLLOW_SFT 1 > +#define RG_AUDACCDETMICBIAS1PULLLOW_MASK 0x1 > +#define RG_AUDACCDETMICBIAS1PULLLOW_MASK_SFT (0x1 << 1) > +#define RG_AUDACCDETMICBIAS2PULLLOW_ADDR \ > + MT6359_AUDENC_ANA_CON18 > +#define RG_AUDACCDETMICBIAS2PULLLOW_SFT 2 > +#define RG_AUDACCDETMICBIAS2PULLLOW_MASK 0x1 > +#define RG_AUDACCDETMICBIAS2PULLLOW_MASK_SFT (0x1 << 2) > +#define RG_AUDACCDETVIN1PULLLOW_ADDR \ > + MT6359_AUDENC_ANA_CON18 > +#define RG_AUDACCDETVIN1PULLLOW_SFT 3 > +#define RG_AUDACCDETVIN1PULLLOW_MASK 0x1 > +#define RG_AUDACCDETVIN1PULLLOW_MASK_SFT (0x1 << 3) > +#define RG_AUDACCDETVTHACAL_ADDR \ > + MT6359_AUDENC_ANA_CON18 > +#define RG_AUDACCDETVTHACAL_SFT 4 > +#define RG_AUDACCDETVTHACAL_MASK 0x1 > +#define RG_AUDACCDETVTHACAL_MASK_SFT (0x1 << 4) > +#define RG_AUDACCDETVTHBCAL_ADDR \ > + MT6359_AUDENC_ANA_CON18 > +#define RG_AUDACCDETVTHBCAL_SFT 5 > +#define RG_AUDACCDETVTHBCAL_MASK 0x1 > +#define RG_AUDACCDETVTHBCAL_MASK_SFT (0x1 << 5) > +#define RG_AUDACCDETTVDET_ADDR \ > + MT6359_AUDENC_ANA_CON18 > +#define RG_AUDACCDETTVDET_SFT 6 > +#define RG_AUDACCDETTVDET_MASK 0x1 > +#define RG_AUDACCDETTVDET_MASK_SFT (0x1 << 6) > +#define RG_ACCDETSEL_ADDR \ > + MT6359_AUDENC_ANA_CON18 > +#define RG_ACCDETSEL_SFT 7 > +#define RG_ACCDETSEL_MASK 0x1 > +#define RG_ACCDETSEL_MASK_SFT (0x1 << 7) > + > +#define RG_AUDPWDBMICBIAS1_ADDR \ > + MT6359_AUDENC_ANA_CON16 > +#define RG_AUDPWDBMICBIAS1_SFT 0 > +#define RG_AUDPWDBMICBIAS1_MASK 0x1 > +#define RG_AUDPWDBMICBIAS1_MASK_SFT (0x1 << 0) > +#define RG_AUDMICBIAS1BYPASSEN_ADDR \ > + MT6359_AUDENC_ANA_CON16 > +#define RG_AUDMICBIAS1BYPASSEN_SFT 1 > +#define RG_AUDMICBIAS1BYPASSEN_MASK 0x1 > +#define RG_AUDMICBIAS1BYPASSEN_MASK_SFT (0x1 << 1) > +#define RG_AUDMICBIAS1LOWPEN_ADDR \ > + MT6359_AUDENC_ANA_CON16 > +#define RG_AUDMICBIAS1LOWPEN_SFT 2 > +#define RG_AUDMICBIAS1LOWPEN_MASK 0x1 > +#define RG_AUDMICBIAS1LOWPEN_MASK_SFT (0x1 << 2) > +#define RG_AUDMICBIAS1VREF_ADDR \ > + MT6359_AUDENC_ANA_CON16 > +#define RG_AUDMICBIAS1VREF_SFT 4 > +#define RG_AUDMICBIAS1VREF_MASK 0x7 > +#define RG_AUDMICBIAS1VREF_MASK_SFT (0x7 << 4) > +#define RG_AUDMICBIAS1DCSW1PEN_ADDR \ > + MT6359_AUDENC_ANA_CON16 > +#define RG_AUDMICBIAS1DCSW1PEN_SFT 8 > +#define RG_AUDMICBIAS1DCSW1PEN_MASK 0x1 > +#define RG_AUDMICBIAS1DCSW1PEN_MASK_SFT (0x1 << 8) > +#define RG_AUDMICBIAS1DCSW1NEN_ADDR \ > + MT6359_AUDENC_ANA_CON16 > +#define RG_AUDMICBIAS1DCSW1NEN_SFT 9 > +#define RG_AUDMICBIAS1DCSW1NEN_MASK 0x1 > +#define RG_AUDMICBIAS1DCSW1NEN_MASK_SFT (0x1 << 9) > +#define RG_BANDGAPGEN_ADDR \ > + MT6359_AUDENC_ANA_CON16 > +#define RG_BANDGAPGEN_SFT 10 > +#define RG_BANDGAPGEN_MASK 0x1 > +#define RG_BANDGAPGEN_MASK_SFT (0x1 << 10) > +#define RG_AUDMICBIAS1HVEN_ADDR \ > + MT6359_AUDENC_ANA_CON16 > +#define RG_AUDMICBIAS1HVEN_SFT 12 > +#define RG_AUDMICBIAS1HVEN_MASK 0x1 > +#define RG_AUDMICBIAS1HVEN_MASK_SFT (0x1 << 12) > +#define RG_AUDMICBIAS1HVVREF_ADDR \ > + MT6359_AUDENC_ANA_CON16 > +#define RG_AUDMICBIAS1HVVREF_SFT 13 > +#define RG_AUDMICBIAS1HVVREF_MASK 0x1 > +#define RG_AUDMICBIAS1HVVREF_MASK_SFT (0x1 << 13) > + > +#define RG_EINT0NOHYS_ADDR \ > + MT6359_AUDENC_ANA_CON18 > +#define RG_EINT0NOHYS_SFT 10 > +#define RG_EINT0NOHYS_MASK 0x1 > +#define RG_EINT0NOHYS_MASK_SFT (0x1 << 10) > +#define RG_EINT0CONFIGACCDET_ADDR \ > + MT6359_AUDENC_ANA_CON18 > +#define RG_EINT0CONFIGACCDET_SFT 11 > +#define RG_EINT0CONFIGACCDET_MASK 0x1 > +#define RG_EINT0CONFIGACCDET_MASK_SFT (0x1 << 11) > +#define RG_EINT0HIRENB_ADDR \ > + MT6359_AUDENC_ANA_CON18 > +#define RG_EINT0HIRENB_SFT 12 > +#define RG_EINT0HIRENB_MASK 0x1 > +#define RG_EINT0HIRENB_MASK_SFT (0x1 << 12) > +#define RG_ACCDET2AUXRESBYPASS_ADDR \ > + MT6359_AUDENC_ANA_CON18 > +#define RG_ACCDET2AUXRESBYPASS_SFT 13 > +#define RG_ACCDET2AUXRESBYPASS_MASK 0x1 > +#define RG_ACCDET2AUXRESBYPASS_MASK_SFT (0x1 << 13) > +#define RG_ACCDET2AUXSWEN_ADDR \ > + MT6359_AUDENC_ANA_CON18 > +#define RG_ACCDET2AUXSWEN_SFT 14 > +#define RG_ACCDET2AUXSWEN_MASK 0x1 > +#define RG_ACCDET2AUXSWEN_MASK_SFT (0x1 << 14) > +#define RG_AUDACCDETMICBIAS3PULLLOW_ADDR \ > + MT6359_AUDENC_ANA_CON18 > +#define RG_AUDACCDETMICBIAS3PULLLOW_SFT 15 > +#define RG_AUDACCDETMICBIAS3PULLLOW_MASK 0x1 > +#define RG_AUDACCDETMICBIAS3PULLLOW_MASK_SFT (0x1 << 15) > +#define RG_EINT1CONFIGACCDET_ADDR \ > + MT6359_AUDENC_ANA_CON19 > +#define RG_EINT1CONFIGACCDET_SFT 0 > +#define RG_EINT1CONFIGACCDET_MASK 0x1 > +#define RG_EINT1CONFIGACCDET_MASK_SFT (0x1 << 0) > +#define RG_EINT1HIRENB_ADDR \ > + MT6359_AUDENC_ANA_CON19 > +#define RG_EINT1HIRENB_SFT 1 > +#define RG_EINT1HIRENB_MASK 0x1 > +#define RG_EINT1HIRENB_MASK_SFT (0x1 << 1) > +#define RG_EINT1NOHYS_ADDR \ > + MT6359_AUDENC_ANA_CON19 > +#define RG_EINT1NOHYS_SFT 2 > +#define RG_EINT1NOHYS_MASK 0x1 > +#define RG_EINT1NOHYS_MASK_SFT (0x1 << 2) > +#define RG_EINTCOMPVTH_ADDR \ > + MT6359_AUDENC_ANA_CON19 > +#define RG_MTEST_EN_ADDR \ > + MT6359_AUDENC_ANA_CON19 > +#define RG_MTEST_EN_SFT 8 > +#define RG_MTEST_EN_MASK 0x1 > +#define RG_MTEST_EN_MASK_SFT (0x1 << 8) > +#define RG_MTEST_SEL_ADDR \ > + MT6359_AUDENC_ANA_CON19 > +#define RG_MTEST_SEL_SFT 9 > +#define RG_MTEST_SEL_MASK 0x1 > +#define RG_MTEST_SEL_MASK_SFT (0x1 << 9) > +#define RG_MTEST_CURRENT_ADDR \ > + MT6359_AUDENC_ANA_CON19 > +#define RG_MTEST_CURRENT_SFT 10 > +#define RG_MTEST_CURRENT_MASK 0x1 > +#define RG_MTEST_CURRENT_MASK_SFT (0x1 << 10) > +#define RG_ANALOGFDEN_ADDR \ > + MT6359_AUDENC_ANA_CON19 > +#define RG_ANALOGFDEN_SFT 12 > +#define RG_ANALOGFDEN_MASK 0x1 > +#define RG_ANALOGFDEN_MASK_SFT (0x1 << 12) > +#define RG_FDVIN1PPULLLOW_ADDR \ > + MT6359_AUDENC_ANA_CON19 > +#define RG_FDVIN1PPULLLOW_SFT 13 > +#define RG_FDVIN1PPULLLOW_MASK 0x1 > +#define RG_FDVIN1PPULLLOW_MASK_SFT (0x1 << 13) > +#define RG_FDEINT0TYPE_ADDR \ > + MT6359_AUDENC_ANA_CON19 > +#define RG_FDEINT0TYPE_SFT 14 > +#define RG_FDEINT0TYPE_MASK 0x1 > +#define RG_FDEINT0TYPE_MASK_SFT (0x1 << 14) > +#define RG_FDEINT1TYPE_ADDR \ > + MT6359_AUDENC_ANA_CON19 > +#define RG_FDEINT1TYPE_SFT 15 > +#define RG_FDEINT1TYPE_MASK 0x1 > +#define RG_FDEINT1TYPE_MASK_SFT (0x1 << 15) > +#define RG_EINT0CMPEN_ADDR \ > + MT6359_AUDENC_ANA_CON20 > +#define RG_EINT0CMPEN_SFT 0 > +#define RG_EINT0CMPEN_MASK 0x1 > +#define RG_EINT0CMPEN_MASK_SFT (0x1 << 0) > +#define RG_EINT0CMPMEN_ADDR \ > + MT6359_AUDENC_ANA_CON20 > +#define RG_EINT0CMPMEN_SFT 1 > +#define RG_EINT0CMPMEN_MASK 0x1 > +#define RG_EINT0CMPMEN_MASK_SFT (0x1 << 1) > +#define RG_EINT0EN_ADDR \ > + MT6359_AUDENC_ANA_CON20 > +#define RG_EINT0EN_SFT 2 > +#define RG_EINT0EN_MASK 0x1 > +#define RG_EINT0EN_MASK_SFT (0x1 << 2) > +#define RG_EINT0CEN_ADDR \ > + MT6359_AUDENC_ANA_CON20 > +#define RG_EINT0CEN_SFT 3 > +#define RG_EINT0CEN_MASK 0x1 > +#define RG_EINT0CEN_MASK_SFT (0x1 << 3) > +#define RG_EINT0INVEN_ADDR \ > + MT6359_AUDENC_ANA_CON20 > +#define RG_EINT0INVEN_SFT 4 > +#define RG_EINT0INVEN_MASK 0x1 > +#define RG_EINT0INVEN_MASK_SFT (0x1 << 4) > +#define RG_EINT0CTURBO_ADDR \ > + MT6359_AUDENC_ANA_CON20 > +#define RG_EINT0CTURBO_SFT 5 > +#define RG_EINT0CTURBO_MASK 0x7 > +#define RG_EINT0CTURBO_MASK_SFT (0x7 << 5) > +#define RG_EINT1CMPEN_ADDR \ > + MT6359_AUDENC_ANA_CON20 > +#define RG_EINT1CMPEN_SFT 8 > +#define RG_EINT1CMPEN_MASK 0x1 > +#define RG_EINT1CMPEN_MASK_SFT (0x1 << 8) > +#define RG_EINT1CMPMEN_ADDR \ > + MT6359_AUDENC_ANA_CON20 > +#define RG_EINT1CMPMEN_SFT 9 > +#define RG_EINT1CMPMEN_MASK 0x1 > +#define RG_EINT1CMPMEN_MASK_SFT (0x1 << 9) > +#define RG_EINT1EN_ADDR \ > + MT6359_AUDENC_ANA_CON20 > +#define RG_EINT1EN_SFT 10 > +#define RG_EINT1EN_MASK 0x1 > +#define RG_EINT1EN_MASK_SFT (0x1 << 10) > +#define RG_EINT1CEN_ADDR \ > + MT6359_AUDENC_ANA_CON20 > +#define RG_EINT1CEN_SFT 11 > +#define RG_EINT1CEN_MASK 0x1 > +#define RG_EINT1CEN_MASK_SFT (0x1 << 11) > +#define RG_EINT1INVEN_ADDR \ > + MT6359_AUDENC_ANA_CON20 > +#define RG_EINT1INVEN_SFT 12 > +#define RG_EINT1INVEN_MASK 0x1 > +#define RG_EINT1INVEN_MASK_SFT (0x1 << 12) > +#define RG_EINT1CTURBO_ADDR \ > + MT6359_AUDENC_ANA_CON20 > +#define RG_EINT1CTURBO_SFT 13 > +#define RG_EINT1CTURBO_MASK 0x7 > +#define RG_EINT1CTURBO_MASK_SFT (0x7 << 13) > +#define RG_ACCDETSPARE_ADDR \ > + MT6359_AUDENC_ANA_CON21 > + > +#define ACCDET_ANA_ID_ADDR \ > + MT6359_ACCDET_DSN_DIG_ID > +#define ACCDET_ANA_ID_SFT 0 > +#define ACCDET_ANA_ID_MASK 0xFF > +#define ACCDET_ANA_ID_MASK_SFT (0xFF << 0) > +#define ACCDET_DIG_ID_ADDR \ > + MT6359_ACCDET_DSN_DIG_ID > +#define ACCDET_DIG_ID_SFT 8 > +#define ACCDET_DIG_ID_MASK 0xFF > +#define ACCDET_DIG_ID_MASK_SFT (0xFF << 8) > +#define ACCDET_ANA_MINOR_REV_ADDR \ > + MT6359_ACCDET_DSN_DIG_REV0 > +#define ACCDET_ANA_MINOR_REV_SFT 0 > +#define ACCDET_ANA_MINOR_REV_MASK 0xF > +#define ACCDET_ANA_MINOR_REV_MASK_SFT (0xF << 0) > +#define ACCDET_ANA_MAJOR_REV_ADDR \ > + MT6359_ACCDET_DSN_DIG_REV0 > +#define ACCDET_ANA_MAJOR_REV_SFT 4 > +#define ACCDET_ANA_MAJOR_REV_MASK 0xF > +#define ACCDET_ANA_MAJOR_REV_MASK_SFT (0xF << 4) > +#define ACCDET_DIG_MINOR_REV_ADDR \ > + MT6359_ACCDET_DSN_DIG_REV0 > +#define ACCDET_DIG_MINOR_REV_SFT 8 > +#define ACCDET_DIG_MINOR_REV_MASK 0xF > +#define ACCDET_DIG_MINOR_REV_MASK_SFT (0xF << 8) > +#define ACCDET_DIG_MAJOR_REV_ADDR \ > + MT6359_ACCDET_DSN_DIG_REV0 > +#define ACCDET_DIG_MAJOR_REV_SFT 12 > +#define ACCDET_DIG_MAJOR_REV_MASK 0xF > +#define ACCDET_DIG_MAJOR_REV_MASK_SFT (0xF << 12) > +#define ACCDET_DSN_CBS_ADDR \ > + MT6359_ACCDET_DSN_DBI > +#define ACCDET_DSN_CBS_SFT 0 > +#define ACCDET_DSN_CBS_MASK 0x3 > +#define ACCDET_DSN_CBS_MASK_SFT (0x3 << 0) > +#define ACCDET_DSN_BIX_ADDR \ > + MT6359_ACCDET_DSN_DBI > +#define ACCDET_DSN_BIX_SFT 2 > +#define ACCDET_DSN_BIX_MASK 0x3 > +#define ACCDET_DSN_BIX_MASK_SFT (0x3 << 2) > +#define ACCDET_ESP_ADDR \ > + MT6359_ACCDET_DSN_DBI > +#define ACCDET_ESP_SFT 8 > +#define ACCDET_ESP_MASK 0xFF > +#define ACCDET_ESP_MASK_SFT (0xFF << 8) > +#define ACCDET_DSN_FPI_ADDR \ > + MT6359_ACCDET_DSN_FPI > +#define ACCDET_DSN_FPI_SFT 0 > +#define ACCDET_DSN_FPI_MASK 0xFF > +#define ACCDET_DSN_FPI_MASK_SFT (0xFF << 0) > +#define ACCDET_AUXADC_SEL_ADDR \ > + MT6359_ACCDET_CON0 > +#define ACCDET_AUXADC_SEL_SFT 0 > +#define ACCDET_AUXADC_SEL_MASK 0x1 > +#define ACCDET_AUXADC_SEL_MASK_SFT (0x1 << 0) > +#define ACCDET_AUXADC_SW_ADDR \ > + MT6359_ACCDET_CON0 > +#define ACCDET_AUXADC_SW_SFT 1 > +#define ACCDET_AUXADC_SW_MASK 0x1 > +#define ACCDET_AUXADC_SW_MASK_SFT (0x1 << 1) > +#define ACCDET_TEST_AUXADC_ADDR \ > + MT6359_ACCDET_CON0 > +#define ACCDET_TEST_AUXADC_SFT 2 > +#define ACCDET_TEST_AUXADC_MASK 0x1 > +#define ACCDET_TEST_AUXADC_MASK_SFT (0x1 << 2) > +#define ACCDET_AUXADC_ANASWCTRL_SEL_ADDR \ > + MT6359_ACCDET_CON0 > +#define ACCDET_AUXADC_ANASWCTRL_SEL_SFT 8 > +#define ACCDET_AUXADC_ANASWCTRL_SEL_MASK 0x1 > +#define ACCDET_AUXADC_ANASWCTRL_SEL_MASK_SFT (0x1 << 8) > +#define AUDACCDETAUXADCSWCTRL_SEL_ADDR \ > + MT6359_ACCDET_CON0 > +#define AUDACCDETAUXADCSWCTRL_SEL_SFT 9 > +#define AUDACCDETAUXADCSWCTRL_SEL_MASK 0x1 > +#define AUDACCDETAUXADCSWCTRL_SEL_MASK_SFT (0x1 << 9) > +#define AUDACCDETAUXADCSWCTRL_SW_ADDR \ > + MT6359_ACCDET_CON0 > +#define AUDACCDETAUXADCSWCTRL_SW_SFT 10 > +#define AUDACCDETAUXADCSWCTRL_SW_MASK 0x1 > +#define AUDACCDETAUXADCSWCTRL_SW_MASK_SFT (0x1 << 10) > +#define ACCDET_TEST_ANA_ADDR \ > + MT6359_ACCDET_CON0 > +#define ACCDET_TEST_ANA_SFT 11 > +#define ACCDET_TEST_ANA_MASK 0x1 > +#define ACCDET_TEST_ANA_MASK_SFT (0x1 << 11) > +#define RG_AUDACCDETRSV_ADDR \ > + MT6359_ACCDET_CON0 > +#define RG_AUDACCDETRSV_SFT 13 > +#define RG_AUDACCDETRSV_MASK 0x3 > +#define RG_AUDACCDETRSV_MASK_SFT (0x3 << 13) > +#define ACCDET_SW_EN_ADDR \ > + MT6359_ACCDET_CON1 > +#define ACCDET_SW_EN_SFT 0 > +#define ACCDET_SW_EN_MASK 0x1 > +#define ACCDET_SW_EN_MASK_SFT (0x1 << 0) > +#define ACCDET_SEQ_INIT_ADDR \ > + MT6359_ACCDET_CON1 > +#define ACCDET_SEQ_INIT_SFT 1 > +#define ACCDET_SEQ_INIT_MASK 0x1 > +#define ACCDET_SEQ_INIT_MASK_SFT (0x1 << 1) > +#define ACCDET_EINT0_SW_EN_ADDR \ > + MT6359_ACCDET_CON1 > +#define ACCDET_EINT0_SW_EN_SFT 2 > +#define ACCDET_EINT0_SW_EN_MASK 0x1 > +#define ACCDET_EINT0_SW_EN_MASK_SFT (0x1 << 2) > +#define ACCDET_EINT0_SEQ_INIT_ADDR \ > + MT6359_ACCDET_CON1 > +#define ACCDET_EINT0_SEQ_INIT_SFT 3 > +#define ACCDET_EINT0_SEQ_INIT_MASK 0x1 > +#define ACCDET_EINT0_SEQ_INIT_MASK_SFT (0x1 << 3) > +#define ACCDET_EINT1_SW_EN_ADDR \ > + MT6359_ACCDET_CON1 > +#define ACCDET_EINT1_SW_EN_SFT 4 > +#define ACCDET_EINT1_SW_EN_MASK 0x1 > +#define ACCDET_EINT1_SW_EN_MASK_SFT (0x1 << 4) > +#define ACCDET_EINT1_SEQ_INIT_ADDR \ > + MT6359_ACCDET_CON1 > +#define ACCDET_EINT1_SEQ_INIT_SFT 5 > +#define ACCDET_EINT1_SEQ_INIT_MASK 0x1 > +#define ACCDET_EINT1_SEQ_INIT_MASK_SFT (0x1 << 5) > +#define ACCDET_EINT0_INVERTER_SW_EN_ADDR \ > + MT6359_ACCDET_CON1 > +#define ACCDET_EINT0_INVERTER_SW_EN_SFT 6 > +#define ACCDET_EINT0_INVERTER_SW_EN_MASK 0x1 > +#define ACCDET_EINT0_INVERTER_SW_EN_MASK_SFT (0x1 << 6) > +#define ACCDET_EINT0_INVERTER_SEQ_INIT_ADDR \ > + MT6359_ACCDET_CON1 > +#define ACCDET_EINT0_INVERTER_SEQ_INIT_SFT 7 > +#define ACCDET_EINT0_INVERTER_SEQ_INIT_MASK 0x1 > +#define ACCDET_EINT0_INVERTER_SEQ_INIT_MASK_SFT (0x1 << 7) > +#define ACCDET_EINT1_INVERTER_SW_EN_ADDR \ > + MT6359_ACCDET_CON1 > +#define ACCDET_EINT1_INVERTER_SW_EN_SFT 8 > +#define ACCDET_EINT1_INVERTER_SW_EN_MASK 0x1 > +#define ACCDET_EINT1_INVERTER_SW_EN_MASK_SFT (0x1 << 8) > +#define ACCDET_EINT1_INVERTER_SEQ_INIT_ADDR \ > + MT6359_ACCDET_CON1 > +#define ACCDET_EINT1_INVERTER_SEQ_INIT_SFT 9 > +#define ACCDET_EINT1_INVERTER_SEQ_INIT_MASK 0x1 > +#define ACCDET_EINT1_INVERTER_SEQ_INIT_MASK_SFT (0x1 << 9) > +#define ACCDET_EINT0_M_SW_EN_ADDR \ > + MT6359_ACCDET_CON1 > +#define ACCDET_EINT0_M_SW_EN_SFT 10 > +#define ACCDET_EINT0_M_SW_EN_MASK 0x1 > +#define ACCDET_EINT0_M_SW_EN_MASK_SFT (0x1 << 10) > +#define ACCDET_EINT1_M_SW_EN_ADDR \ > + MT6359_ACCDET_CON1 > +#define ACCDET_EINT1_M_SW_EN_SFT 11 > +#define ACCDET_EINT1_M_SW_EN_MASK 0x1 > +#define ACCDET_EINT1_M_SW_EN_MASK_SFT (0x1 << 11) > +#define ACCDET_EINT_M_DETECT_EN_ADDR \ > + MT6359_ACCDET_CON1 > +#define ACCDET_EINT_M_DETECT_EN_SFT 12 > +#define ACCDET_EINT_M_DETECT_EN_MASK 0x1 > +#define ACCDET_EINT_M_DETECT_EN_MASK_SFT (0x1 << 12) > +#define ACCDET_CMP_PWM_EN_ADDR \ > + MT6359_ACCDET_CON2 > +#define ACCDET_CMP_PWM_EN_SFT 0 > +#define ACCDET_CMP_PWM_EN_MASK 0x1 > +#define ACCDET_CMP_PWM_EN_MASK_SFT (0x1 << 0) > +#define ACCDET_VTH_PWM_EN_ADDR \ > + MT6359_ACCDET_CON2 > +#define ACCDET_VTH_PWM_EN_SFT 1 > +#define ACCDET_VTH_PWM_EN_MASK 0x1 > +#define ACCDET_VTH_PWM_EN_MASK_SFT (0x1 << 1) > +#define ACCDET_MBIAS_PWM_EN_ADDR \ > + MT6359_ACCDET_CON2 > +#define ACCDET_MBIAS_PWM_EN_SFT 2 > +#define ACCDET_MBIAS_PWM_EN_MASK 0x1 > +#define ACCDET_MBIAS_PWM_EN_MASK_SFT (0x1 << 2) > +#define ACCDET_EINT_EN_PWM_EN_ADDR \ > + MT6359_ACCDET_CON2 > +#define ACCDET_EINT_EN_PWM_EN_SFT 3 > +#define ACCDET_EINT_EN_PWM_EN_MASK 0x1 > +#define ACCDET_EINT_EN_PWM_EN_MASK_SFT (0x1 << 3) > +#define ACCDET_EINT_CMPEN_PWM_EN_ADDR \ > + MT6359_ACCDET_CON2 > +#define ACCDET_EINT_CMPEN_PWM_EN_SFT 4 > +#define ACCDET_EINT_CMPEN_PWM_EN_MASK 0x1 > +#define ACCDET_EINT_CMPEN_PWM_EN_MASK_SFT (0x1 << 4) > +#define ACCDET_EINT_CMPMEN_PWM_EN_ADDR \ > + MT6359_ACCDET_CON2 > +#define ACCDET_EINT_CMPMEN_PWM_EN_SFT 5 > +#define ACCDET_EINT_CMPMEN_PWM_EN_MASK 0x1 > +#define ACCDET_EINT_CMPMEN_PWM_EN_MASK_SFT (0x1 << 5) > +#define ACCDET_EINT_CTURBO_PWM_EN_ADDR \ > + MT6359_ACCDET_CON2 > +#define ACCDET_EINT_CTURBO_PWM_EN_SFT 6 > +#define ACCDET_EINT_CTURBO_PWM_EN_MASK 0x1 > +#define ACCDET_EINT_CTURBO_PWM_EN_MASK_SFT (0x1 << 6) > +#define ACCDET_CMP_PWM_IDLE_ADDR \ > + MT6359_ACCDET_CON2 > +#define ACCDET_CMP_PWM_IDLE_SFT 8 > +#define ACCDET_CMP_PWM_IDLE_MASK 0x1 > +#define ACCDET_CMP_PWM_IDLE_MASK_SFT (0x1 << 8) > +#define ACCDET_VTH_PWM_IDLE_ADDR \ > + MT6359_ACCDET_CON2 > +#define ACCDET_VTH_PWM_IDLE_SFT 9 > +#define ACCDET_VTH_PWM_IDLE_MASK 0x1 > +#define ACCDET_VTH_PWM_IDLE_MASK_SFT (0x1 << 9) > +#define ACCDET_MBIAS_PWM_IDLE_ADDR \ > + MT6359_ACCDET_CON2 > +#define ACCDET_MBIAS_PWM_IDLE_SFT 10 > +#define ACCDET_MBIAS_PWM_IDLE_MASK 0x1 > +#define ACCDET_MBIAS_PWM_IDLE_MASK_SFT (0x1 << 10) > +#define ACCDET_EINT0_CMPEN_PWM_IDLE_ADDR \ > + MT6359_ACCDET_CON2 > +#define ACCDET_EINT0_CMPEN_PWM_IDLE_SFT 11 > +#define ACCDET_EINT0_CMPEN_PWM_IDLE_MASK 0x1 > +#define ACCDET_EINT0_CMPEN_PWM_IDLE_MASK_SFT (0x1 << 11) > +#define ACCDET_EINT1_CMPEN_PWM_IDLE_ADDR \ > + MT6359_ACCDET_CON2 > +#define ACCDET_EINT1_CMPEN_PWM_IDLE_SFT 12 > +#define ACCDET_EINT1_CMPEN_PWM_IDLE_MASK 0x1 > +#define ACCDET_EINT1_CMPEN_PWM_IDLE_MASK_SFT (0x1 << 12) > +#define ACCDET_PWM_EN_SW_ADDR \ > + MT6359_ACCDET_CON2 > +#define ACCDET_PWM_EN_SW_SFT 13 > +#define ACCDET_PWM_EN_SW_MASK 0x1 > +#define ACCDET_PWM_EN_SW_MASK_SFT (0x1 << 13) > +#define ACCDET_PWM_EN_SEL_ADDR \ > + MT6359_ACCDET_CON2 > +#define ACCDET_PWM_EN_SEL_SFT 14 > +#define ACCDET_PWM_EN_SEL_MASK 0x3 > +#define ACCDET_PWM_EN_SEL_MASK_SFT (0x3 << 14) > +#define ACCDET_PWM_WIDTH_ADDR \ > + MT6359_ACCDET_CON3 > +#define ACCDET_PWM_WIDTH_SFT 0 > +#define ACCDET_PWM_WIDTH_MASK 0xFFFF > +#define ACCDET_PWM_WIDTH_MASK_SFT (0xFFFF << 0) > +#define ACCDET_PWM_THRESH_ADDR \ > + MT6359_ACCDET_CON4 > +#define ACCDET_PWM_THRESH_SFT 0 > +#define ACCDET_PWM_THRESH_MASK 0xFFFF > +#define ACCDET_PWM_THRESH_MASK_SFT (0xFFFF << 0) > +#define ACCDET_RISE_DELAY_ADDR \ > + MT6359_ACCDET_CON5 > +#define ACCDET_RISE_DELAY_SFT 0 > +#define ACCDET_RISE_DELAY_MASK 0x7FFF > +#define ACCDET_RISE_DELAY_MASK_SFT (0x7FFF << 0) > +#define ACCDET_FALL_DELAY_ADDR \ > + MT6359_ACCDET_CON5 > +#define ACCDET_FALL_DELAY_SFT 15 > +#define ACCDET_FALL_DELAY_MASK 0x1 > +#define ACCDET_FALL_DELAY_MASK_SFT (0x1 << 15) > +#define ACCDET_EINT_CMPMEN_PWM_THRESH_ADDR \ > + MT6359_ACCDET_CON6 > +#define ACCDET_EINT_CMPMEN_PWM_THRESH_SFT 0 > +#define ACCDET_EINT_CMPMEN_PWM_THRESH_MASK 0x7 > +#define ACCDET_EINT_CMPMEN_PWM_THRESH_MASK_SFT (0x7 << 0) > +#define ACCDET_EINT_CMPMEN_PWM_WIDTH_ADDR \ > + MT6359_ACCDET_CON6 > +#define ACCDET_EINT_CMPMEN_PWM_WIDTH_SFT 4 > +#define ACCDET_EINT_CMPMEN_PWM_WIDTH_MASK 0x7 > +#define ACCDET_EINT_CMPMEN_PWM_WIDTH_MASK_SFT (0x7 << 4) > +#define ACCDET_EINT_EN_PWM_THRESH_ADDR \ > + MT6359_ACCDET_CON7 > +#define ACCDET_EINT_EN_PWM_THRESH_SFT 0 > +#define ACCDET_EINT_EN_PWM_THRESH_MASK 0x7 > +#define ACCDET_EINT_EN_PWM_THRESH_MASK_SFT (0x7 << 0) > +#define ACCDET_EINT_EN_PWM_WIDTH_ADDR \ > + MT6359_ACCDET_CON7 > +#define ACCDET_EINT_EN_PWM_WIDTH_SFT 4 > +#define ACCDET_EINT_EN_PWM_WIDTH_MASK 0x3 > +#define ACCDET_EINT_EN_PWM_WIDTH_MASK_SFT (0x3 << 4) > +#define ACCDET_EINT_CMPEN_PWM_THRESH_ADDR \ > + MT6359_ACCDET_CON7 > +#define ACCDET_EINT_CMPEN_PWM_THRESH_SFT 8 > +#define ACCDET_EINT_CMPEN_PWM_THRESH_MASK 0x7 > +#define ACCDET_EINT_CMPEN_PWM_THRESH_MASK_SFT (0x7 << 8) > +#define ACCDET_EINT_CMPEN_PWM_WIDTH_ADDR \ > + MT6359_ACCDET_CON7 > +#define ACCDET_EINT_CMPEN_PWM_WIDTH_SFT 12 > +#define ACCDET_EINT_CMPEN_PWM_WIDTH_MASK 0x3 > +#define ACCDET_EINT_CMPEN_PWM_WIDTH_MASK_SFT (0x3 << 12) > +#define ACCDET_DEBOUNCE0_ADDR \ > + MT6359_ACCDET_CON8 > +#define ACCDET_DEBOUNCE0_SFT 0 > +#define ACCDET_DEBOUNCE0_MASK 0xFFFF > +#define ACCDET_DEBOUNCE0_MASK_SFT (0xFFFF << 0) > +#define ACCDET_DEBOUNCE1_ADDR \ > + MT6359_ACCDET_CON9 > +#define ACCDET_DEBOUNCE1_SFT 0 > +#define ACCDET_DEBOUNCE1_MASK 0xFFFF > +#define ACCDET_DEBOUNCE1_MASK_SFT (0xFFFF << 0) > +#define ACCDET_DEBOUNCE2_ADDR \ > + MT6359_ACCDET_CON10 > +#define ACCDET_DEBOUNCE2_SFT 0 > +#define ACCDET_DEBOUNCE2_MASK 0xFFFF > +#define ACCDET_DEBOUNCE2_MASK_SFT (0xFFFF << 0) > +#define ACCDET_DEBOUNCE3_ADDR \ > + MT6359_ACCDET_CON11 > +#define ACCDET_DEBOUNCE3_SFT 0 > +#define ACCDET_DEBOUNCE3_MASK 0xFFFF > +#define ACCDET_DEBOUNCE3_MASK_SFT (0xFFFF << 0) > +#define ACCDET_CONNECT_AUXADC_TIME_DIG_ADDR \ > + MT6359_ACCDET_CON12 > +#define ACCDET_CONNECT_AUXADC_TIME_DIG_SFT 0 > +#define ACCDET_CONNECT_AUXADC_TIME_DIG_MASK 0xFFFF > +#define ACCDET_CONNECT_AUXADC_TIME_DIG_MASK_SFT (0xFFFF << 0) > +#define ACCDET_CONNECT_AUXADC_TIME_ANA_ADDR \ > + MT6359_ACCDET_CON13 > +#define ACCDET_CONNECT_AUXADC_TIME_ANA_SFT 0 > +#define ACCDET_CONNECT_AUXADC_TIME_ANA_MASK 0xFFFF > +#define ACCDET_CONNECT_AUXADC_TIME_ANA_MASK_SFT (0xFFFF << 0) > +#define ACCDET_EINT_DEBOUNCE0_ADDR \ > + MT6359_ACCDET_CON14 > +#define ACCDET_EINT_DEBOUNCE0_SFT 0 > +#define ACCDET_EINT_DEBOUNCE0_MASK 0xF > +#define ACCDET_EINT_DEBOUNCE0_MASK_SFT (0xF << 0) > +#define ACCDET_EINT_DEBOUNCE1_ADDR \ > + MT6359_ACCDET_CON14 > +#define ACCDET_EINT_DEBOUNCE1_SFT 4 > +#define ACCDET_EINT_DEBOUNCE1_MASK 0xF > +#define ACCDET_EINT_DEBOUNCE1_MASK_SFT (0xF << 4) > +#define ACCDET_EINT_DEBOUNCE2_ADDR \ > + MT6359_ACCDET_CON14 > +#define ACCDET_EINT_DEBOUNCE2_SFT 8 > +#define ACCDET_EINT_DEBOUNCE2_MASK 0xF > +#define ACCDET_EINT_DEBOUNCE2_MASK_SFT (0xF << 8) > +#define ACCDET_EINT_DEBOUNCE3_ADDR \ > + MT6359_ACCDET_CON14 > +#define ACCDET_EINT_DEBOUNCE3_SFT 12 > +#define ACCDET_EINT_DEBOUNCE3_MASK 0xF > +#define ACCDET_EINT_DEBOUNCE3_MASK_SFT (0xF << 12) > +#define ACCDET_EINT_INVERTER_DEBOUNCE_ADDR \ > + MT6359_ACCDET_CON15 > +#define ACCDET_EINT_INVERTER_DEBOUNCE_SFT 0 > +#define ACCDET_EINT_INVERTER_DEBOUNCE_MASK 0xF > +#define ACCDET_EINT_INVERTER_DEBOUNCE_MASK_SFT (0xF << 0) > +#define ACCDET_IVAL_CUR_IN_ADDR \ > + MT6359_ACCDET_CON16 > +#define ACCDET_IVAL_CUR_IN_SFT 0 > +#define ACCDET_IVAL_CUR_IN_MASK 0x3 > +#define ACCDET_IVAL_CUR_IN_MASK_SFT (0x3 << 0) > +#define ACCDET_IVAL_SAM_IN_ADDR \ > + MT6359_ACCDET_CON16 > +#define ACCDET_IVAL_SAM_IN_SFT 2 > +#define ACCDET_IVAL_SAM_IN_MASK 0x3 > +#define ACCDET_IVAL_SAM_IN_MASK_SFT (0x3 << 2) > +#define ACCDET_IVAL_MEM_IN_ADDR \ > + MT6359_ACCDET_CON16 > +#define ACCDET_IVAL_MEM_IN_SFT 4 > +#define ACCDET_IVAL_MEM_IN_MASK 0x3 > +#define ACCDET_IVAL_MEM_IN_MASK_SFT (0x3 << 4) > +#define ACCDET_EINT_IVAL_CUR_IN_ADDR \ > + MT6359_ACCDET_CON16 > +#define ACCDET_EINT_IVAL_CUR_IN_SFT 6 > +#define ACCDET_EINT_IVAL_CUR_IN_MASK 0x3 > +#define ACCDET_EINT_IVAL_CUR_IN_MASK_SFT (0x3 << 6) > +#define ACCDET_EINT_IVAL_SAM_IN_ADDR \ > + MT6359_ACCDET_CON16 > +#define ACCDET_EINT_IVAL_SAM_IN_SFT 8 > +#define ACCDET_EINT_IVAL_SAM_IN_MASK 0x3 > +#define ACCDET_EINT_IVAL_SAM_IN_MASK_SFT (0x3 << 8) > +#define ACCDET_EINT_IVAL_MEM_IN_ADDR \ > + MT6359_ACCDET_CON16 > +#define ACCDET_EINT_IVAL_MEM_IN_SFT 10 > +#define ACCDET_EINT_IVAL_MEM_IN_MASK 0x3 > +#define ACCDET_EINT_IVAL_MEM_IN_MASK_SFT (0x3 << 10) > +#define ACCDET_IVAL_SEL_ADDR \ > + MT6359_ACCDET_CON16 > +#define ACCDET_IVAL_SEL_SFT 12 > +#define ACCDET_IVAL_SEL_MASK 0x1 > +#define ACCDET_IVAL_SEL_MASK_SFT (0x1 << 12) > +#define ACCDET_EINT_IVAL_SEL_ADDR \ > + MT6359_ACCDET_CON16 > +#define ACCDET_EINT_IVAL_SEL_SFT 13 > +#define ACCDET_EINT_IVAL_SEL_MASK 0x1 > +#define ACCDET_EINT_IVAL_SEL_MASK_SFT (0x1 << 13) > +#define ACCDET_EINT_INVERTER_IVAL_CUR_IN_ADDR \ > + MT6359_ACCDET_CON17 > +#define ACCDET_EINT_INVERTER_IVAL_CUR_IN_SFT 0 > +#define ACCDET_EINT_INVERTER_IVAL_CUR_IN_MASK 0x1 > +#define ACCDET_EINT_INVERTER_IVAL_CUR_IN_MASK_SFT (0x1 << 0) > +#define ACCDET_EINT_INVERTER_IVAL_SAM_IN_ADDR \ > + MT6359_ACCDET_CON17 > +#define ACCDET_EINT_INVERTER_IVAL_SAM_IN_SFT 1 > +#define ACCDET_EINT_INVERTER_IVAL_SAM_IN_MASK 0x1 > +#define ACCDET_EINT_INVERTER_IVAL_SAM_IN_MASK_SFT (0x1 << 1) > +#define ACCDET_EINT_INVERTER_IVAL_MEM_IN_ADDR \ > + MT6359_ACCDET_CON17 > +#define ACCDET_EINT_INVERTER_IVAL_MEM_IN_SFT 2 > +#define ACCDET_EINT_INVERTER_IVAL_MEM_IN_MASK 0x1 > +#define ACCDET_EINT_INVERTER_IVAL_MEM_IN_MASK_SFT (0x1 << 2) > +#define ACCDET_EINT_INVERTER_IVAL_SEL_ADDR \ > + MT6359_ACCDET_CON17 > +#define ACCDET_EINT_INVERTER_IVAL_SEL_SFT 3 > +#define ACCDET_EINT_INVERTER_IVAL_SEL_MASK 0x1 > +#define ACCDET_EINT_INVERTER_IVAL_SEL_MASK_SFT (0x1 << 3) > +#define ACCDET_IRQ_ADDR \ > + MT6359_ACCDET_CON18 > +#define ACCDET_IRQ_SFT 0 > +#define ACCDET_IRQ_MASK 0x1 > +#define ACCDET_IRQ_MASK_SFT (0x1 << 0) > +#define ACCDET_EINT0_IRQ_ADDR \ > + MT6359_ACCDET_CON18 > +#define ACCDET_EINT0_IRQ_SFT 2 > +#define ACCDET_EINT0_IRQ_MASK 0x1 > +#define ACCDET_EINT0_IRQ_MASK_SFT (0x1 << 2) > +#define ACCDET_EINT1_IRQ_ADDR \ > + MT6359_ACCDET_CON18 > +#define ACCDET_EINT1_IRQ_SFT 3 > +#define ACCDET_EINT1_IRQ_MASK 0x1 > +#define ACCDET_EINT1_IRQ_MASK_SFT (0x1 << 3) > +#define ACCDET_EINT_IN_INVERSE_ADDR \ > + MT6359_ACCDET_CON18 > +#define ACCDET_EINT_IN_INVERSE_SFT 4 > +#define ACCDET_EINT_IN_INVERSE_MASK 0x1 > +#define ACCDET_EINT_IN_INVERSE_MASK_SFT (0x1 << 4) > +#define ACCDET_IRQ_CLR_ADDR \ > + MT6359_ACCDET_CON18 > +#define ACCDET_IRQ_CLR_SFT 8 > +#define ACCDET_IRQ_CLR_MASK 0x1 > +#define ACCDET_IRQ_CLR_MASK_SFT (0x1 << 8) > +#define ACCDET_EINT0_IRQ_CLR_ADDR \ > + MT6359_ACCDET_CON18 > +#define ACCDET_EINT0_IRQ_CLR_SFT 10 > +#define ACCDET_EINT0_IRQ_CLR_MASK 0x1 > +#define ACCDET_EINT0_IRQ_CLR_MASK_SFT (0x1 << 10) > +#define ACCDET_EINT1_IRQ_CLR_ADDR \ > + MT6359_ACCDET_CON18 > +#define ACCDET_EINT1_IRQ_CLR_SFT 11 > +#define ACCDET_EINT1_IRQ_CLR_MASK 0x1 > +#define ACCDET_EINT1_IRQ_CLR_MASK_SFT (0x1 << 11) > +#define ACCDET_EINT_M_PLUG_IN_NUM_ADDR \ > + MT6359_ACCDET_CON18 > +#define ACCDET_EINT_M_PLUG_IN_NUM_SFT 12 > +#define ACCDET_EINT_M_PLUG_IN_NUM_MASK 0x7 > +#define ACCDET_EINT_M_PLUG_IN_NUM_MASK_SFT (0x7 << 12) > +#define ACCDET_DA_STABLE_ADDR \ > + MT6359_ACCDET_CON19 > +#define ACCDET_DA_STABLE_SFT 0 > +#define ACCDET_DA_STABLE_MASK 0x1 > +#define ACCDET_DA_STABLE_MASK_SFT (0x1 << 0) > +#define ACCDET_EINT0_EN_STABLE_ADDR \ > + MT6359_ACCDET_CON19 > +#define ACCDET_EINT0_EN_STABLE_SFT 1 > +#define ACCDET_EINT0_EN_STABLE_MASK 0x1 > +#define ACCDET_EINT0_EN_STABLE_MASK_SFT (0x1 << 1) > +#define ACCDET_EINT0_CMPEN_STABLE_ADDR \ > + MT6359_ACCDET_CON19 > +#define ACCDET_EINT0_CMPEN_STABLE_SFT 2 > +#define ACCDET_EINT0_CMPEN_STABLE_MASK 0x1 > +#define ACCDET_EINT0_CMPEN_STABLE_MASK_SFT (0x1 << 2) > +#define ACCDET_EINT0_CMPMEN_STABLE_ADDR \ > + MT6359_ACCDET_CON19 > +#define ACCDET_EINT0_CMPMEN_STABLE_SFT 3 > +#define ACCDET_EINT0_CMPMEN_STABLE_MASK 0x1 > +#define ACCDET_EINT0_CMPMEN_STABLE_MASK_SFT (0x1 << 3) > +#define ACCDET_EINT0_CTURBO_STABLE_ADDR \ > + MT6359_ACCDET_CON19 > +#define ACCDET_EINT0_CTURBO_STABLE_SFT 4 > +#define ACCDET_EINT0_CTURBO_STABLE_MASK 0x1 > +#define ACCDET_EINT0_CTURBO_STABLE_MASK_SFT (0x1 << 4) > +#define ACCDET_EINT0_CEN_STABLE_ADDR \ > + MT6359_ACCDET_CON19 > +#define ACCDET_EINT0_CEN_STABLE_SFT 5 > +#define ACCDET_EINT0_CEN_STABLE_MASK 0x1 > +#define ACCDET_EINT0_CEN_STABLE_MASK_SFT (0x1 << 5) > +#define ACCDET_EINT1_EN_STABLE_ADDR \ > + MT6359_ACCDET_CON19 > +#define ACCDET_EINT1_EN_STABLE_SFT 6 > +#define ACCDET_EINT1_EN_STABLE_MASK 0x1 > +#define ACCDET_EINT1_EN_STABLE_MASK_SFT (0x1 << 6) > +#define ACCDET_EINT1_CMPEN_STABLE_ADDR \ > + MT6359_ACCDET_CON19 > +#define ACCDET_EINT1_CMPEN_STABLE_SFT 7 > +#define ACCDET_EINT1_CMPEN_STABLE_MASK 0x1 > +#define ACCDET_EINT1_CMPEN_STABLE_MASK_SFT (0x1 << 7) > +#define ACCDET_EINT1_CMPMEN_STABLE_ADDR \ > + MT6359_ACCDET_CON19 > +#define ACCDET_EINT1_CMPMEN_STABLE_SFT 8 > +#define ACCDET_EINT1_CMPMEN_STABLE_MASK 0x1 > +#define ACCDET_EINT1_CMPMEN_STABLE_MASK_SFT (0x1 << 8) > +#define ACCDET_EINT1_CTURBO_STABLE_ADDR \ > + MT6359_ACCDET_CON19 > +#define ACCDET_EINT1_CTURBO_STABLE_SFT 9 > +#define ACCDET_EINT1_CTURBO_STABLE_MASK 0x1 > +#define ACCDET_EINT1_CTURBO_STABLE_MASK_SFT (0x1 << 9) > +#define ACCDET_EINT1_CEN_STABLE_ADDR \ > + MT6359_ACCDET_CON19 > +#define ACCDET_EINT1_CEN_STABLE_SFT 10 > +#define ACCDET_EINT1_CEN_STABLE_MASK 0x1 > +#define ACCDET_EINT1_CEN_STABLE_MASK_SFT (0x1 << 10) > +#define ACCDET_HWMODE_EN_ADDR \ > + MT6359_ACCDET_CON20 > +#define ACCDET_HWMODE_EN_SFT 0 > +#define ACCDET_HWMODE_EN_MASK 0x1 > +#define ACCDET_HWMODE_EN_MASK_SFT (0x1 << 0) > +#define ACCDET_HWMODE_SEL_ADDR \ > + MT6359_ACCDET_CON20 > +#define ACCDET_HWMODE_SEL_SFT 1 > +#define ACCDET_HWMODE_SEL_MASK 0x3 > +#define ACCDET_HWMODE_SEL_MASK_SFT (0x3 << 1) > +#define ACCDET_PLUG_OUT_DETECT_ADDR \ > + MT6359_ACCDET_CON20 > +#define ACCDET_PLUG_OUT_DETECT_SFT 3 > +#define ACCDET_PLUG_OUT_DETECT_MASK 0x1 > +#define ACCDET_PLUG_OUT_DETECT_MASK_SFT (0x1 << 3) > +#define ACCDET_EINT0_REVERSE_ADDR \ > + MT6359_ACCDET_CON20 > +#define ACCDET_EINT0_REVERSE_SFT 4 > +#define ACCDET_EINT0_REVERSE_MASK 0x1 > +#define ACCDET_EINT0_REVERSE_MASK_SFT (0x1 << 4) > +#define ACCDET_EINT1_REVERSE_ADDR \ > + MT6359_ACCDET_CON20 > +#define ACCDET_EINT1_REVERSE_SFT 5 > +#define ACCDET_EINT1_REVERSE_MASK 0x1 > +#define ACCDET_EINT1_REVERSE_MASK_SFT (0x1 << 5) > +#define ACCDET_EINT_HWMODE_EN_ADDR \ > + MT6359_ACCDET_CON20 > +#define ACCDET_EINT_HWMODE_EN_SFT 8 > +#define ACCDET_EINT_HWMODE_EN_MASK 0x1 > +#define ACCDET_EINT_HWMODE_EN_MASK_SFT (0x1 << 8) > +#define ACCDET_EINT_PLUG_OUT_BYPASS_DEB_ADDR \ > + MT6359_ACCDET_CON20 > +#define ACCDET_EINT_PLUG_OUT_BYPASS_DEB_SFT 9 > +#define ACCDET_EINT_PLUG_OUT_BYPASS_DEB_MASK 0x1 > +#define ACCDET_EINT_PLUG_OUT_BYPASS_DEB_MASK_SFT (0x1 << 9) > +#define ACCDET_EINT_M_PLUG_IN_EN_ADDR \ > + MT6359_ACCDET_CON20 > +#define ACCDET_EINT_M_PLUG_IN_EN_SFT 10 > +#define ACCDET_EINT_M_PLUG_IN_EN_MASK 0x1 > +#define ACCDET_EINT_M_PLUG_IN_EN_MASK_SFT (0x1 << 10) > +#define ACCDET_EINT_M_HWMODE_EN_ADDR \ > + MT6359_ACCDET_CON20 > +#define ACCDET_EINT_M_HWMODE_EN_SFT 11 > +#define ACCDET_EINT_M_HWMODE_EN_MASK 0x1 > +#define ACCDET_EINT_M_HWMODE_EN_MASK_SFT (0x1 << 11) > +#define ACCDET_TEST_CMPEN_ADDR \ > + MT6359_ACCDET_CON21 > +#define ACCDET_TEST_CMPEN_SFT 0 > +#define ACCDET_TEST_CMPEN_MASK 0x1 > +#define ACCDET_TEST_CMPEN_MASK_SFT (0x1 << 0) > +#define ACCDET_TEST_VTHEN_ADDR \ > + MT6359_ACCDET_CON21 > +#define ACCDET_TEST_VTHEN_SFT 1 > +#define ACCDET_TEST_VTHEN_MASK 0x1 > +#define ACCDET_TEST_VTHEN_MASK_SFT (0x1 << 1) > +#define ACCDET_TEST_MBIASEN_ADDR \ > + MT6359_ACCDET_CON21 > +#define ACCDET_TEST_MBIASEN_SFT 2 > +#define ACCDET_TEST_MBIASEN_MASK 0x1 > +#define ACCDET_TEST_MBIASEN_MASK_SFT (0x1 << 2) > +#define ACCDET_EINT_TEST_EN_ADDR \ > + MT6359_ACCDET_CON21 > +#define ACCDET_EINT_TEST_EN_SFT 3 > +#define ACCDET_EINT_TEST_EN_MASK 0x1 > +#define ACCDET_EINT_TEST_EN_MASK_SFT (0x1 << 3) > +#define ACCDET_EINT_TEST_INVEN_ADDR \ > + MT6359_ACCDET_CON21 > +#define ACCDET_EINT_TEST_INVEN_SFT 4 > +#define ACCDET_EINT_TEST_INVEN_MASK 0x1 > +#define ACCDET_EINT_TEST_INVEN_MASK_SFT (0x1 << 4) > +#define ACCDET_EINT_TEST_CMPEN_ADDR \ > + MT6359_ACCDET_CON21 > +#define ACCDET_EINT_TEST_CMPEN_SFT 5 > +#define ACCDET_EINT_TEST_CMPEN_MASK 0x1 > +#define ACCDET_EINT_TEST_CMPEN_MASK_SFT (0x1 << 5) > +#define ACCDET_EINT_TEST_CMPMEN_ADDR \ > + MT6359_ACCDET_CON21 > +#define ACCDET_EINT_TEST_CMPMEN_SFT 6 > +#define ACCDET_EINT_TEST_CMPMEN_MASK 0x1 > +#define ACCDET_EINT_TEST_CMPMEN_MASK_SFT (0x1 << 6) > +#define ACCDET_EINT_TEST_CTURBO_ADDR \ > + MT6359_ACCDET_CON21 > +#define ACCDET_EINT_TEST_CTURBO_SFT 7 > +#define ACCDET_EINT_TEST_CTURBO_MASK 0x1 > +#define ACCDET_EINT_TEST_CTURBO_MASK_SFT (0x1 << 7) > +#define ACCDET_EINT_TEST_CEN_ADDR \ > + MT6359_ACCDET_CON21 > +#define ACCDET_EINT_TEST_CEN_SFT 8 > +#define ACCDET_EINT_TEST_CEN_MASK 0x1 > +#define ACCDET_EINT_TEST_CEN_MASK_SFT (0x1 << 8) > +#define ACCDET_TEST_B_ADDR \ > + MT6359_ACCDET_CON21 > +#define ACCDET_TEST_B_SFT 9 > +#define ACCDET_TEST_B_MASK 0x1 > +#define ACCDET_TEST_B_MASK_SFT (0x1 << 9) > +#define ACCDET_TEST_A_ADDR \ > + MT6359_ACCDET_CON21 > +#define ACCDET_TEST_A_SFT 10 > +#define ACCDET_TEST_A_MASK 0x1 > +#define ACCDET_TEST_A_MASK_SFT (0x1 << 10) > +#define ACCDET_EINT_TEST_CMPOUT_ADDR \ > + MT6359_ACCDET_CON21 > +#define ACCDET_EINT_TEST_CMPOUT_SFT 11 > +#define ACCDET_EINT_TEST_CMPOUT_MASK 0x1 > +#define ACCDET_EINT_TEST_CMPOUT_MASK_SFT (0x1 << 11) > +#define ACCDET_EINT_TEST_CMPMOUT_ADDR \ > + MT6359_ACCDET_CON21 > +#define ACCDET_EINT_TEST_CMPMOUT_SFT 12 > +#define ACCDET_EINT_TEST_CMPMOUT_MASK 0x1 > +#define ACCDET_EINT_TEST_CMPMOUT_MASK_SFT (0x1 << 12) > +#define ACCDET_EINT_TEST_INVOUT_ADDR \ > + MT6359_ACCDET_CON21 > +#define ACCDET_EINT_TEST_INVOUT_SFT 13 > +#define ACCDET_EINT_TEST_INVOUT_MASK 0x1 > +#define ACCDET_EINT_TEST_INVOUT_MASK_SFT (0x1 << 13) > +#define ACCDET_CMPEN_SEL_ADDR \ > + MT6359_ACCDET_CON22 > +#define ACCDET_CMPEN_SEL_SFT 0 > +#define ACCDET_CMPEN_SEL_MASK 0x1 > +#define ACCDET_CMPEN_SEL_MASK_SFT (0x1 << 0) > +#define ACCDET_VTHEN_SEL_ADDR \ > + MT6359_ACCDET_CON22 > +#define ACCDET_VTHEN_SEL_SFT 1 > +#define ACCDET_VTHEN_SEL_MASK 0x1 > +#define ACCDET_VTHEN_SEL_MASK_SFT (0x1 << 1) > +#define ACCDET_MBIASEN_SEL_ADDR \ > + MT6359_ACCDET_CON22 > +#define ACCDET_MBIASEN_SEL_SFT 2 > +#define ACCDET_MBIASEN_SEL_MASK 0x1 > +#define ACCDET_MBIASEN_SEL_MASK_SFT (0x1 << 2) > +#define ACCDET_EINT_EN_SEL_ADDR \ > + MT6359_ACCDET_CON22 > +#define ACCDET_EINT_EN_SEL_SFT 3 > +#define ACCDET_EINT_EN_SEL_MASK 0x1 > +#define ACCDET_EINT_EN_SEL_MASK_SFT (0x1 << 3) > +#define ACCDET_EINT_INVEN_SEL_ADDR \ > + MT6359_ACCDET_CON22 > +#define ACCDET_EINT_INVEN_SEL_SFT 4 > +#define ACCDET_EINT_INVEN_SEL_MASK 0x1 > +#define ACCDET_EINT_INVEN_SEL_MASK_SFT (0x1 << 4) > +#define ACCDET_EINT_CMPEN_SEL_ADDR \ > + MT6359_ACCDET_CON22 > +#define ACCDET_EINT_CMPEN_SEL_SFT 5 > +#define ACCDET_EINT_CMPEN_SEL_MASK 0x1 > +#define ACCDET_EINT_CMPEN_SEL_MASK_SFT (0x1 << 5) > +#define ACCDET_EINT_CMPMEN_SEL_ADDR \ > + MT6359_ACCDET_CON22 > +#define ACCDET_EINT_CMPMEN_SEL_SFT 6 > +#define ACCDET_EINT_CMPMEN_SEL_MASK 0x1 > +#define ACCDET_EINT_CMPMEN_SEL_MASK_SFT (0x1 << 6) > +#define ACCDET_EINT_CTURBO_SEL_ADDR \ > + MT6359_ACCDET_CON22 > +#define ACCDET_EINT_CTURBO_SEL_SFT 7 > +#define ACCDET_EINT_CTURBO_SEL_MASK 0x1 > +#define ACCDET_EINT_CTURBO_SEL_MASK_SFT (0x1 << 7) > +#define ACCDET_B_SEL_ADDR \ > + MT6359_ACCDET_CON22 > +#define ACCDET_B_SEL_SFT 9 > +#define ACCDET_B_SEL_MASK 0x1 > +#define ACCDET_B_SEL_MASK_SFT (0x1 << 9) > +#define ACCDET_A_SEL_ADDR \ > + MT6359_ACCDET_CON22 > +#define ACCDET_A_SEL_SFT 10 > +#define ACCDET_A_SEL_MASK 0x1 > +#define ACCDET_A_SEL_MASK_SFT (0x1 << 10) > +#define ACCDET_EINT_CMPOUT_SEL_ADDR \ > + MT6359_ACCDET_CON22 > +#define ACCDET_EINT_CMPOUT_SEL_SFT 11 > +#define ACCDET_EINT_CMPOUT_SEL_MASK 0x1 > +#define ACCDET_EINT_CMPOUT_SEL_MASK_SFT (0x1 << 11) > +#define ACCDET_EINT_CMPMOUT_SEL_ADDR \ > + MT6359_ACCDET_CON22 > +#define ACCDET_EINT_CMPMOUT_SEL_SFT 12 > +#define ACCDET_EINT_CMPMOUT_SEL_MASK 0x1 > +#define ACCDET_EINT_CMPMOUT_SEL_MASK_SFT (0x1 << 12) > +#define ACCDET_EINT_INVOUT_SEL_ADDR \ > + MT6359_ACCDET_CON22 > +#define ACCDET_EINT_INVOUT_SEL_SFT 13 > +#define ACCDET_EINT_INVOUT_SEL_MASK 0x1 > +#define ACCDET_EINT_INVOUT_SEL_MASK_SFT (0x1 << 13) > +#define ACCDET_CMPEN_SW_ADDR \ > + MT6359_ACCDET_CON23 > +#define ACCDET_CMPEN_SW_SFT 0 > +#define ACCDET_CMPEN_SW_MASK 0x1 > +#define ACCDET_CMPEN_SW_MASK_SFT (0x1 << 0) > +#define ACCDET_VTHEN_SW_ADDR \ > + MT6359_ACCDET_CON23 > +#define ACCDET_VTHEN_SW_SFT 1 > +#define ACCDET_VTHEN_SW_MASK 0x1 > +#define ACCDET_VTHEN_SW_MASK_SFT (0x1 << 1) > +#define ACCDET_MBIASEN_SW_ADDR \ > + MT6359_ACCDET_CON23 > +#define ACCDET_MBIASEN_SW_SFT 2 > +#define ACCDET_MBIASEN_SW_MASK 0x1 > +#define ACCDET_MBIASEN_SW_MASK_SFT (0x1 << 2) > +#define ACCDET_EINT0_EN_SW_ADDR \ > + MT6359_ACCDET_CON23 > +#define ACCDET_EINT0_EN_SW_SFT 3 > +#define ACCDET_EINT0_EN_SW_MASK 0x1 > +#define ACCDET_EINT0_EN_SW_MASK_SFT (0x1 << 3) > +#define ACCDET_EINT0_INVEN_SW_ADDR \ > + MT6359_ACCDET_CON23 > +#define ACCDET_EINT0_INVEN_SW_SFT 4 > +#define ACCDET_EINT0_INVEN_SW_MASK 0x1 > +#define ACCDET_EINT0_INVEN_SW_MASK_SFT (0x1 << 4) > +#define ACCDET_EINT0_CMPEN_SW_ADDR \ > + MT6359_ACCDET_CON23 > +#define ACCDET_EINT0_CMPEN_SW_SFT 5 > +#define ACCDET_EINT0_CMPEN_SW_MASK 0x1 > +#define ACCDET_EINT0_CMPEN_SW_MASK_SFT (0x1 << 5) > +#define ACCDET_EINT0_CMPMEN_SW_ADDR \ > + MT6359_ACCDET_CON23 > +#define ACCDET_EINT0_CMPMEN_SW_SFT 6 > +#define ACCDET_EINT0_CMPMEN_SW_MASK 0x1 > +#define ACCDET_EINT0_CMPMEN_SW_MASK_SFT (0x1 << 6) > +#define ACCDET_EINT0_CTURBO_SW_ADDR \ > + MT6359_ACCDET_CON23 > +#define ACCDET_EINT0_CTURBO_SW_SFT 7 > +#define ACCDET_EINT0_CTURBO_SW_MASK 0x1 > +#define ACCDET_EINT0_CTURBO_SW_MASK_SFT (0x1 << 7) > +#define ACCDET_EINT1_EN_SW_ADDR \ > + MT6359_ACCDET_CON23 > +#define ACCDET_EINT1_EN_SW_SFT 8 > +#define ACCDET_EINT1_EN_SW_MASK 0x1 > +#define ACCDET_EINT1_EN_SW_MASK_SFT (0x1 << 8) > +#define ACCDET_EINT1_INVEN_SW_ADDR \ > + MT6359_ACCDET_CON23 > +#define ACCDET_EINT1_INVEN_SW_SFT 9 > +#define ACCDET_EINT1_INVEN_SW_MASK 0x1 > +#define ACCDET_EINT1_INVEN_SW_MASK_SFT (0x1 << 9) > +#define ACCDET_EINT1_CMPEN_SW_ADDR \ > + MT6359_ACCDET_CON23 > +#define ACCDET_EINT1_CMPEN_SW_SFT 10 > +#define ACCDET_EINT1_CMPEN_SW_MASK 0x1 > +#define ACCDET_EINT1_CMPEN_SW_MASK_SFT (0x1 << 10) > +#define ACCDET_EINT1_CMPMEN_SW_ADDR \ > + MT6359_ACCDET_CON23 > +#define ACCDET_EINT1_CMPMEN_SW_SFT 11 > +#define ACCDET_EINT1_CMPMEN_SW_MASK 0x1 > +#define ACCDET_EINT1_CMPMEN_SW_MASK_SFT (0x1 << 11) > +#define ACCDET_EINT1_CTURBO_SW_ADDR \ > + MT6359_ACCDET_CON23 > +#define ACCDET_EINT1_CTURBO_SW_SFT 12 > +#define ACCDET_EINT1_CTURBO_SW_MASK 0x1 > +#define ACCDET_EINT1_CTURBO_SW_MASK_SFT (0x1 << 12) > +#define ACCDET_B_SW_ADDR \ > + MT6359_ACCDET_CON24 > +#define ACCDET_B_SW_SFT 0 > +#define ACCDET_B_SW_MASK 0x1 > +#define ACCDET_B_SW_MASK_SFT (0x1 << 0) > +#define ACCDET_A_SW_ADDR \ > + MT6359_ACCDET_CON24 > +#define ACCDET_A_SW_SFT 1 > +#define ACCDET_A_SW_MASK 0x1 > +#define ACCDET_A_SW_MASK_SFT (0x1 << 1) > +#define ACCDET_EINT0_CMPOUT_SW_ADDR \ > + MT6359_ACCDET_CON24 > +#define ACCDET_EINT0_CMPOUT_SW_SFT 2 > +#define ACCDET_EINT0_CMPOUT_SW_MASK 0x1 > +#define ACCDET_EINT0_CMPOUT_SW_MASK_SFT (0x1 << 2) > +#define ACCDET_EINT0_CMPMOUT_SW_ADDR \ > + MT6359_ACCDET_CON24 > +#define ACCDET_EINT0_CMPMOUT_SW_SFT 3 > +#define ACCDET_EINT0_CMPMOUT_SW_MASK 0x1 > +#define ACCDET_EINT0_CMPMOUT_SW_MASK_SFT (0x1 << 3) > +#define ACCDET_EINT0_INVOUT_SW_ADDR \ > + MT6359_ACCDET_CON24 > +#define ACCDET_EINT0_INVOUT_SW_SFT 4 > +#define ACCDET_EINT0_INVOUT_SW_MASK 0x1 > +#define ACCDET_EINT0_INVOUT_SW_MASK_SFT (0x1 << 4) > +#define ACCDET_EINT1_CMPOUT_SW_ADDR \ > + MT6359_ACCDET_CON24 > +#define ACCDET_EINT1_CMPOUT_SW_SFT 5 > +#define ACCDET_EINT1_CMPOUT_SW_MASK 0x1 > +#define ACCDET_EINT1_CMPOUT_SW_MASK_SFT (0x1 << 5) > +#define ACCDET_EINT1_CMPMOUT_SW_ADDR \ > + MT6359_ACCDET_CON24 > +#define ACCDET_EINT1_CMPMOUT_SW_SFT 6 > +#define ACCDET_EINT1_CMPMOUT_SW_MASK 0x1 > +#define ACCDET_EINT1_CMPMOUT_SW_MASK_SFT (0x1 << 6) > +#define ACCDET_EINT1_INVOUT_SW_ADDR \ > + MT6359_ACCDET_CON24 > +#define ACCDET_EINT1_INVOUT_SW_SFT 7 > +#define ACCDET_EINT1_INVOUT_SW_MASK 0x1 > +#define ACCDET_EINT1_INVOUT_SW_MASK_SFT (0x1 << 7) > +#define AD_AUDACCDETCMPOB_ADDR \ > + MT6359_ACCDET_CON25 > +#define AD_AUDACCDETCMPOB_SFT 0 > +#define AD_AUDACCDETCMPOB_MASK 0x1 > +#define AD_AUDACCDETCMPOB_MASK_SFT (0x1 << 0) > +#define AD_AUDACCDETCMPOA_ADDR \ > + MT6359_ACCDET_CON25 > +#define AD_AUDACCDETCMPOA_SFT 1 > +#define AD_AUDACCDETCMPOA_MASK 0x1 > +#define AD_AUDACCDETCMPOA_MASK_SFT (0x1 << 1) > +#define ACCDET_CUR_IN_ADDR \ > + MT6359_ACCDET_CON25 > +#define ACCDET_CUR_IN_SFT 2 > +#define ACCDET_CUR_IN_MASK 0x3 > +#define ACCDET_CUR_IN_MASK_SFT (0x3 << 2) > +#define ACCDET_SAM_IN_ADDR \ > + MT6359_ACCDET_CON25 > +#define ACCDET_SAM_IN_SFT 4 > +#define ACCDET_SAM_IN_MASK 0x3 > +#define ACCDET_SAM_IN_MASK_SFT (0x3 << 4) > +#define ACCDET_MEM_IN_ADDR \ > + MT6359_ACCDET_CON25 > +#define ACCDET_MEM_IN_SFT 6 > +#define ACCDET_MEM_IN_MASK 0x3 > +#define ACCDET_MEM_IN_MASK_SFT (0x3 << 6) > +#define ACCDET_STATE_ADDR \ > + MT6359_ACCDET_CON25 > +#define ACCDET_STATE_SFT 8 > +#define ACCDET_STATE_MASK 0x7 > +#define ACCDET_STATE_MASK_SFT (0x7 << 8) > +#define DA_AUDACCDETMBIASCLK_ADDR \ > + MT6359_ACCDET_CON25 > +#define DA_AUDACCDETMBIASCLK_SFT 12 > +#define DA_AUDACCDETMBIASCLK_MASK 0x1 > +#define DA_AUDACCDETMBIASCLK_MASK_SFT (0x1 << 12) > +#define DA_AUDACCDETVTHCLK_ADDR \ > + MT6359_ACCDET_CON25 > +#define DA_AUDACCDETVTHCLK_SFT 13 > +#define DA_AUDACCDETVTHCLK_MASK 0x1 > +#define DA_AUDACCDETVTHCLK_MASK_SFT (0x1 << 13) > +#define DA_AUDACCDETCMPCLK_ADDR \ > + MT6359_ACCDET_CON25 > +#define DA_AUDACCDETCMPCLK_SFT 14 > +#define DA_AUDACCDETCMPCLK_MASK 0x1 > +#define DA_AUDACCDETCMPCLK_MASK_SFT (0x1 << 14) > +#define DA_AUDACCDETAUXADCSWCTRL_ADDR \ > + MT6359_ACCDET_CON25 > +#define DA_AUDACCDETAUXADCSWCTRL_SFT 15 > +#define DA_AUDACCDETAUXADCSWCTRL_MASK 0x1 > +#define DA_AUDACCDETAUXADCSWCTRL_MASK_SFT (0x1 << 15) > +#define AD_EINT0CMPMOUT_ADDR \ > + MT6359_ACCDET_CON26 > +#define AD_EINT0CMPMOUT_SFT 0 > +#define AD_EINT0CMPMOUT_MASK 0x1 > +#define AD_EINT0CMPMOUT_MASK_SFT (0x1 << 0) > +#define AD_EINT0CMPOUT_ADDR \ > + MT6359_ACCDET_CON26 > +#define AD_EINT0CMPOUT_SFT 1 > +#define AD_EINT0CMPOUT_MASK 0x1 > +#define AD_EINT0CMPOUT_MASK_SFT (0x1 << 1) > +#define ACCDET_EINT0_CUR_IN_ADDR \ > + MT6359_ACCDET_CON26 > +#define ACCDET_EINT0_CUR_IN_SFT 2 > +#define ACCDET_EINT0_CUR_IN_MASK 0x3 > +#define ACCDET_EINT0_CUR_IN_MASK_SFT (0x3 << 2) > +#define ACCDET_EINT0_SAM_IN_ADDR \ > + MT6359_ACCDET_CON26 > +#define ACCDET_EINT0_SAM_IN_SFT 4 > +#define ACCDET_EINT0_SAM_IN_MASK 0x3 > +#define ACCDET_EINT0_SAM_IN_MASK_SFT (0x3 << 4) > +#define ACCDET_EINT0_MEM_IN_ADDR \ > + MT6359_ACCDET_CON26 > +#define ACCDET_EINT0_MEM_IN_SFT 6 > +#define ACCDET_EINT0_MEM_IN_MASK 0x3 > +#define ACCDET_EINT0_MEM_IN_MASK_SFT (0x3 << 6) > +#define ACCDET_EINT0_STATE_ADDR \ > + MT6359_ACCDET_CON26 > +#define ACCDET_EINT0_STATE_SFT 8 > +#define ACCDET_EINT0_STATE_MASK 0x7 > +#define ACCDET_EINT0_STATE_MASK_SFT (0x7 << 8) > +#define DA_EINT0CMPEN_ADDR \ > + MT6359_ACCDET_CON26 > +#define DA_EINT0CMPEN_SFT 13 > +#define DA_EINT0CMPEN_MASK 0x1 > +#define DA_EINT0CMPEN_MASK_SFT (0x1 << 13) > +#define DA_EINT0CMPMEN_ADDR \ > + MT6359_ACCDET_CON26 > +#define DA_EINT0CMPMEN_SFT 14 > +#define DA_EINT0CMPMEN_MASK 0x1 > +#define DA_EINT0CMPMEN_MASK_SFT (0x1 << 14) > +#define DA_EINT0CTURBO_ADDR \ > + MT6359_ACCDET_CON26 > +#define DA_EINT0CTURBO_SFT 15 > +#define DA_EINT0CTURBO_MASK 0x1 > +#define DA_EINT0CTURBO_MASK_SFT (0x1 << 15) > +#define AD_EINT1CMPMOUT_ADDR \ > + MT6359_ACCDET_CON27 > +#define AD_EINT1CMPMOUT_SFT 0 > +#define AD_EINT1CMPMOUT_MASK 0x1 > +#define AD_EINT1CMPMOUT_MASK_SFT (0x1 << 0) > +#define AD_EINT1CMPOUT_ADDR \ > + MT6359_ACCDET_CON27 > +#define AD_EINT1CMPOUT_SFT 1 > +#define AD_EINT1CMPOUT_MASK 0x1 > +#define AD_EINT1CMPOUT_MASK_SFT (0x1 << 1) > +#define ACCDET_EINT1_CUR_IN_ADDR \ > + MT6359_ACCDET_CON27 > +#define ACCDET_EINT1_CUR_IN_SFT 2 > +#define ACCDET_EINT1_CUR_IN_MASK 0x3 > +#define ACCDET_EINT1_CUR_IN_MASK_SFT (0x3 << 2) > +#define ACCDET_EINT1_SAM_IN_ADDR \ > + MT6359_ACCDET_CON27 > +#define ACCDET_EINT1_SAM_IN_SFT 4 > +#define ACCDET_EINT1_SAM_IN_MASK 0x3 > +#define ACCDET_EINT1_SAM_IN_MASK_SFT (0x3 << 4) > +#define ACCDET_EINT1_MEM_IN_ADDR \ > + MT6359_ACCDET_CON27 > +#define ACCDET_EINT1_MEM_IN_SFT 6 > +#define ACCDET_EINT1_MEM_IN_MASK 0x3 > +#define ACCDET_EINT1_MEM_IN_MASK_SFT (0x3 << 6) > +#define ACCDET_EINT1_STATE_ADDR \ > + MT6359_ACCDET_CON27 > +#define ACCDET_EINT1_STATE_SFT 8 > +#define ACCDET_EINT1_STATE_MASK 0x7 > +#define ACCDET_EINT1_STATE_MASK_SFT (0x7 << 8) > +#define DA_EINT1CMPEN_ADDR \ > + MT6359_ACCDET_CON27 > +#define DA_EINT1CMPEN_SFT 13 > +#define DA_EINT1CMPEN_MASK 0x1 > +#define DA_EINT1CMPEN_MASK_SFT (0x1 << 13) > +#define DA_EINT1CMPMEN_ADDR \ > + MT6359_ACCDET_CON27 > +#define DA_EINT1CMPMEN_SFT 14 > +#define DA_EINT1CMPMEN_MASK 0x1 > +#define DA_EINT1CMPMEN_MASK_SFT (0x1 << 14) > +#define DA_EINT1CTURBO_ADDR \ > + MT6359_ACCDET_CON27 > +#define DA_EINT1CTURBO_SFT 15 > +#define DA_EINT1CTURBO_MASK 0x1 > +#define DA_EINT1CTURBO_MASK_SFT (0x1 << 15) > +#define AD_EINT0INVOUT_ADDR \ > + MT6359_ACCDET_CON28 > +#define AD_EINT0INVOUT_SFT 0 > +#define AD_EINT0INVOUT_MASK 0x1 > +#define AD_EINT0INVOUT_MASK_SFT (0x1 << 0) > +#define ACCDET_EINT0_INVERTER_CUR_IN_ADDR \ > + MT6359_ACCDET_CON28 > +#define ACCDET_EINT0_INVERTER_CUR_IN_SFT 1 > +#define ACCDET_EINT0_INVERTER_CUR_IN_MASK 0x1 > +#define ACCDET_EINT0_INVERTER_CUR_IN_MASK_SFT (0x1 << 1) > +#define ACCDET_EINT0_INVERTER_SAM_IN_ADDR \ > + MT6359_ACCDET_CON28 > +#define ACCDET_EINT0_INVERTER_SAM_IN_SFT 2 > +#define ACCDET_EINT0_INVERTER_SAM_IN_MASK 0x1 > +#define ACCDET_EINT0_INVERTER_SAM_IN_MASK_SFT (0x1 << 2) > +#define ACCDET_EINT0_INVERTER_MEM_IN_ADDR \ > + MT6359_ACCDET_CON28 > +#define ACCDET_EINT0_INVERTER_MEM_IN_SFT 3 > +#define ACCDET_EINT0_INVERTER_MEM_IN_MASK 0x1 > +#define ACCDET_EINT0_INVERTER_MEM_IN_MASK_SFT (0x1 << 3) > +#define ACCDET_EINT0_INVERTER_STATE_ADDR \ > + MT6359_ACCDET_CON28 > +#define ACCDET_EINT0_INVERTER_STATE_SFT 8 > +#define ACCDET_EINT0_INVERTER_STATE_MASK 0x7 > +#define ACCDET_EINT0_INVERTER_STATE_MASK_SFT (0x7 << 8) > +#define DA_EINT0EN_ADDR \ > + MT6359_ACCDET_CON28 > +#define DA_EINT0EN_SFT 12 > +#define DA_EINT0EN_MASK 0x1 > +#define DA_EINT0EN_MASK_SFT (0x1 << 12) > +#define DA_EINT0INVEN_ADDR \ > + MT6359_ACCDET_CON28 > +#define DA_EINT0INVEN_SFT 13 > +#define DA_EINT0INVEN_MASK 0x1 > +#define DA_EINT0INVEN_MASK_SFT (0x1 << 13) > +#define DA_EINT0CEN_ADDR \ > + MT6359_ACCDET_CON28 > +#define DA_EINT0CEN_SFT 14 > +#define DA_EINT0CEN_MASK 0x1 > +#define DA_EINT0CEN_MASK_SFT (0x1 << 14) > +#define AD_EINT1INVOUT_ADDR \ > + MT6359_ACCDET_CON29 > +#define AD_EINT1INVOUT_SFT 0 > +#define AD_EINT1INVOUT_MASK 0x1 > +#define AD_EINT1INVOUT_MASK_SFT (0x1 << 0) > +#define ACCDET_EINT1_INVERTER_CUR_IN_ADDR \ > + MT6359_ACCDET_CON29 > +#define ACCDET_EINT1_INVERTER_CUR_IN_SFT 1 > +#define ACCDET_EINT1_INVERTER_CUR_IN_MASK 0x1 > +#define ACCDET_EINT1_INVERTER_CUR_IN_MASK_SFT (0x1 << 1) > +#define ACCDET_EINT1_INVERTER_SAM_IN_ADDR \ > + MT6359_ACCDET_CON29 > +#define ACCDET_EINT1_INVERTER_SAM_IN_SFT 2 > +#define ACCDET_EINT1_INVERTER_SAM_IN_MASK 0x1 > +#define ACCDET_EINT1_INVERTER_SAM_IN_MASK_SFT (0x1 << 2) > +#define ACCDET_EINT1_INVERTER_MEM_IN_ADDR \ > + MT6359_ACCDET_CON29 > +#define ACCDET_EINT1_INVERTER_MEM_IN_SFT 3 > +#define ACCDET_EINT1_INVERTER_MEM_IN_MASK 0x1 > +#define ACCDET_EINT1_INVERTER_MEM_IN_MASK_SFT (0x1 << 3) > +#define ACCDET_EINT1_INVERTER_STATE_ADDR \ > + MT6359_ACCDET_CON29 > +#define ACCDET_EINT1_INVERTER_STATE_SFT 8 > +#define ACCDET_EINT1_INVERTER_STATE_MASK 0x7 > +#define ACCDET_EINT1_INVERTER_STATE_MASK_SFT (0x7 << 8) > +#define DA_EINT1EN_ADDR \ > + MT6359_ACCDET_CON29 > +#define DA_EINT1EN_SFT 12 > +#define DA_EINT1EN_MASK 0x1 > +#define DA_EINT1EN_MASK_SFT (0x1 << 12) > +#define DA_EINT1INVEN_ADDR \ > + MT6359_ACCDET_CON29 > +#define DA_EINT1INVEN_SFT 13 > +#define DA_EINT1INVEN_MASK 0x1 > +#define DA_EINT1INVEN_MASK_SFT (0x1 << 13) > +#define DA_EINT1CEN_ADDR \ > + MT6359_ACCDET_CON29 > +#define DA_EINT1CEN_SFT 14 > +#define DA_EINT1CEN_MASK 0x1 > +#define DA_EINT1CEN_MASK_SFT (0x1 << 14) > +#define ACCDET_EN_ADDR \ > + MT6359_ACCDET_CON30 > +#define ACCDET_EN_SFT 0 > +#define ACCDET_EN_MASK 0x1 > +#define ACCDET_EN_MASK_SFT (0x1 << 0) > +#define ACCDET_EINT0_EN_ADDR \ > + MT6359_ACCDET_CON30 > +#define ACCDET_EINT0_EN_SFT 1 > +#define ACCDET_EINT0_EN_MASK 0x1 > +#define ACCDET_EINT0_EN_MASK_SFT (0x1 << 1) > +#define ACCDET_EINT1_EN_ADDR \ > + MT6359_ACCDET_CON30 > +#define ACCDET_EINT1_EN_SFT 2 > +#define ACCDET_EINT1_EN_MASK 0x1 > +#define ACCDET_EINT1_EN_MASK_SFT (0x1 << 2) > +#define ACCDET_EINT0_M_EN_ADDR \ > + MT6359_ACCDET_CON30 > +#define ACCDET_EINT0_M_EN_SFT 3 > +#define ACCDET_EINT0_M_EN_MASK 0x1 > +#define ACCDET_EINT0_M_EN_MASK_SFT (0x1 << 3) > +#define ACCDET_EINT0_DETECT_MOISTURE_ADDR \ > + MT6359_ACCDET_CON30 > +#define ACCDET_EINT0_DETECT_MOISTURE_SFT 4 > +#define ACCDET_EINT0_DETECT_MOISTURE_MASK 0x1 > +#define ACCDET_EINT0_DETECT_MOISTURE_MASK_SFT (0x1 << 4) > +#define ACCDET_EINT0_PLUG_IN_ADDR \ > + MT6359_ACCDET_CON30 > +#define ACCDET_EINT0_PLUG_IN_SFT 5 > +#define ACCDET_EINT0_PLUG_IN_MASK 0x1 > +#define ACCDET_EINT0_PLUG_IN_MASK_SFT (0x1 << 5) > +#define ACCDET_EINT0_M_PLUG_IN_ADDR \ > + MT6359_ACCDET_CON30 > +#define ACCDET_EINT0_M_PLUG_IN_SFT 6 > +#define ACCDET_EINT0_M_PLUG_IN_MASK 0x1 > +#define ACCDET_EINT0_M_PLUG_IN_MASK_SFT (0x1 << 6) > +#define ACCDET_EINT1_M_EN_ADDR \ > + MT6359_ACCDET_CON30 > +#define ACCDET_EINT1_M_EN_SFT 7 > +#define ACCDET_EINT1_M_EN_MASK 0x1 > +#define ACCDET_EINT1_M_EN_MASK_SFT (0x1 << 7) > +#define ACCDET_EINT1_DETECT_MOISTURE_ADDR \ > + MT6359_ACCDET_CON30 > +#define ACCDET_EINT1_DETECT_MOISTURE_SFT 8 > +#define ACCDET_EINT1_DETECT_MOISTURE_MASK 0x1 > +#define ACCDET_EINT1_DETECT_MOISTURE_MASK_SFT (0x1 << 8) > +#define ACCDET_EINT1_PLUG_IN_ADDR \ > + MT6359_ACCDET_CON30 > +#define ACCDET_EINT1_PLUG_IN_SFT 9 > +#define ACCDET_EINT1_PLUG_IN_MASK 0x1 > +#define ACCDET_EINT1_PLUG_IN_MASK_SFT (0x1 << 9) > +#define ACCDET_EINT1_M_PLUG_IN_ADDR \ > + MT6359_ACCDET_CON30 > +#define ACCDET_EINT1_M_PLUG_IN_SFT 10 > +#define ACCDET_EINT1_M_PLUG_IN_MASK 0x1 > +#define ACCDET_EINT1_M_PLUG_IN_MASK_SFT (0x1 << 10) > +#define ACCDET_CUR_DEB_ADDR \ > + MT6359_ACCDET_CON31 > +#define ACCDET_CUR_DEB_SFT 0 > +#define ACCDET_CUR_DEB_MASK 0xFFFF > +#define ACCDET_CUR_DEB_MASK_SFT (0xFFFF << 0) > +#define ACCDET_EINT0_CUR_DEB_ADDR \ > + MT6359_ACCDET_CON32 > +#define ACCDET_EINT0_CUR_DEB_SFT 0 > +#define ACCDET_EINT0_CUR_DEB_MASK 0x7FFF > +#define ACCDET_EINT0_CUR_DEB_MASK_SFT (0x7FFF << 0) > +#define ACCDET_EINT1_CUR_DEB_ADDR \ > + MT6359_ACCDET_CON33 > +#define ACCDET_EINT1_CUR_DEB_SFT 0 > +#define ACCDET_EINT1_CUR_DEB_MASK 0x7FFF > +#define ACCDET_EINT1_CUR_DEB_MASK_SFT (0x7FFF << 0) > +#define ACCDET_EINT0_INVERTER_CUR_DEB_ADDR \ > + MT6359_ACCDET_CON34 > +#define ACCDET_EINT0_INVERTER_CUR_DEB_SFT 0 > +#define ACCDET_EINT0_INVERTER_CUR_DEB_MASK 0x7FFF > +#define ACCDET_EINT0_INVERTER_CUR_DEB_MASK_SFT (0x7FFF << 0) > +#define ACCDET_EINT1_INVERTER_CUR_DEB_ADDR \ > + MT6359_ACCDET_CON35 > +#define ACCDET_EINT1_INVERTER_CUR_DEB_SFT 0 > +#define ACCDET_EINT1_INVERTER_CUR_DEB_MASK 0x7FFF > +#define ACCDET_EINT1_INVERTER_CUR_DEB_MASK_SFT (0x7FFF << 0) > +#define AD_AUDACCDETCMPOB_MON_ADDR \ > + MT6359_ACCDET_CON36 > +#define AD_AUDACCDETCMPOB_MON_SFT 0 > +#define AD_AUDACCDETCMPOB_MON_MASK 0x1 > +#define AD_AUDACCDETCMPOB_MON_MASK_SFT (0x1 << 0) > +#define AD_AUDACCDETCMPOA_MON_ADDR \ > + MT6359_ACCDET_CON36 > +#define AD_AUDACCDETCMPOA_MON_SFT 1 > +#define AD_AUDACCDETCMPOA_MON_MASK 0x1 > +#define AD_AUDACCDETCMPOA_MON_MASK_SFT (0x1 << 1) > +#define AD_EINT0CMPMOUT_MON_ADDR \ > + MT6359_ACCDET_CON36 > +#define AD_EINT0CMPMOUT_MON_SFT 2 > +#define AD_EINT0CMPMOUT_MON_MASK 0x1 > +#define AD_EINT0CMPMOUT_MON_MASK_SFT (0x1 << 2) > +#define AD_EINT0CMPOUT_MON_ADDR \ > + MT6359_ACCDET_CON36 > +#define AD_EINT0CMPOUT_MON_SFT 3 > +#define AD_EINT0CMPOUT_MON_MASK 0x1 > +#define AD_EINT0CMPOUT_MON_MASK_SFT (0x1 << 3) > +#define AD_EINT0INVOUT_MON_ADDR \ > + MT6359_ACCDET_CON36 > +#define AD_EINT0INVOUT_MON_SFT 4 > +#define AD_EINT0INVOUT_MON_MASK 0x1 > +#define AD_EINT0INVOUT_MON_MASK_SFT (0x1 << 4) > +#define AD_EINT1CMPMOUT_MON_ADDR \ > + MT6359_ACCDET_CON36 > +#define AD_EINT1CMPMOUT_MON_SFT 5 > +#define AD_EINT1CMPMOUT_MON_MASK 0x1 > +#define AD_EINT1CMPMOUT_MON_MASK_SFT (0x1 << 5) > +#define AD_EINT1CMPOUT_MON_ADDR \ > + MT6359_ACCDET_CON36 > +#define AD_EINT1CMPOUT_MON_SFT 6 > +#define AD_EINT1CMPOUT_MON_MASK 0x1 > +#define AD_EINT1CMPOUT_MON_MASK_SFT (0x1 << 6) > +#define AD_EINT1INVOUT_MON_ADDR \ > + MT6359_ACCDET_CON36 > +#define AD_EINT1INVOUT_MON_SFT 7 > +#define AD_EINT1INVOUT_MON_MASK 0x1 > +#define AD_EINT1INVOUT_MON_MASK_SFT (0x1 << 7) > +#define DA_AUDACCDETCMPCLK_MON_ADDR \ > + MT6359_ACCDET_CON37 > +#define DA_AUDACCDETCMPCLK_MON_SFT 0 > +#define DA_AUDACCDETCMPCLK_MON_MASK 0x1 > +#define DA_AUDACCDETCMPCLK_MON_MASK_SFT (0x1 << 0) > +#define DA_AUDACCDETVTHCLK_MON_ADDR \ > + MT6359_ACCDET_CON37 > +#define DA_AUDACCDETVTHCLK_MON_SFT 1 > +#define DA_AUDACCDETVTHCLK_MON_MASK 0x1 > +#define DA_AUDACCDETVTHCLK_MON_MASK_SFT (0x1 << 1) > +#define DA_AUDACCDETMBIASCLK_MON_ADDR \ > + MT6359_ACCDET_CON37 > +#define DA_AUDACCDETMBIASCLK_MON_SFT 2 > +#define DA_AUDACCDETMBIASCLK_MON_MASK 0x1 > +#define DA_AUDACCDETMBIASCLK_MON_MASK_SFT (0x1 << 2) > +#define DA_AUDACCDETAUXADCSWCTRL_MON_ADDR \ > + MT6359_ACCDET_CON37 > +#define DA_AUDACCDETAUXADCSWCTRL_MON_SFT 3 > +#define DA_AUDACCDETAUXADCSWCTRL_MON_MASK 0x1 > +#define DA_AUDACCDETAUXADCSWCTRL_MON_MASK_SFT (0x1 << 3) > +#define DA_EINT0CTURBO_MON_ADDR \ > + MT6359_ACCDET_CON38 > +#define DA_EINT0CTURBO_MON_SFT 0 > +#define DA_EINT0CTURBO_MON_MASK 0x1 > +#define DA_EINT0CTURBO_MON_MASK_SFT (0x1 << 0) > +#define DA_EINT0CMPMEN_MON_ADDR \ > + MT6359_ACCDET_CON38 > +#define DA_EINT0CMPMEN_MON_SFT 1 > +#define DA_EINT0CMPMEN_MON_MASK 0x1 > +#define DA_EINT0CMPMEN_MON_MASK_SFT (0x1 << 1) > +#define DA_EINT0CMPEN_MON_ADDR \ > + MT6359_ACCDET_CON38 > +#define DA_EINT0CMPEN_MON_SFT 2 > +#define DA_EINT0CMPEN_MON_MASK 0x1 > +#define DA_EINT0CMPEN_MON_MASK_SFT (0x1 << 2) > +#define DA_EINT0INVEN_MON_ADDR \ > + MT6359_ACCDET_CON38 > +#define DA_EINT0INVEN_MON_SFT 3 > +#define DA_EINT0INVEN_MON_MASK 0x1 > +#define DA_EINT0INVEN_MON_MASK_SFT (0x1 << 3) > +#define DA_EINT0CEN_MON_ADDR \ > + MT6359_ACCDET_CON38 > +#define DA_EINT0CEN_MON_SFT 4 > +#define DA_EINT0CEN_MON_MASK 0x1 > +#define DA_EINT0CEN_MON_MASK_SFT (0x1 << 4) > +#define DA_EINT0EN_MON_ADDR \ > + MT6359_ACCDET_CON38 > +#define DA_EINT0EN_MON_SFT 5 > +#define DA_EINT0EN_MON_MASK 0x1 > +#define DA_EINT0EN_MON_MASK_SFT (0x1 << 5) > +#define DA_EINT1CTURBO_MON_ADDR \ > + MT6359_ACCDET_CON38 > +#define DA_EINT1CTURBO_MON_SFT 8 > +#define DA_EINT1CTURBO_MON_MASK 0x1 > +#define DA_EINT1CTURBO_MON_MASK_SFT (0x1 << 8) > +#define DA_EINT1CMPMEN_MON_ADDR \ > + MT6359_ACCDET_CON38 > +#define DA_EINT1CMPMEN_MON_SFT 9 > +#define DA_EINT1CMPMEN_MON_MASK 0x1 > +#define DA_EINT1CMPMEN_MON_MASK_SFT (0x1 << 9) > +#define DA_EINT1CMPEN_MON_ADDR \ > + MT6359_ACCDET_CON38 > +#define DA_EINT1CMPEN_MON_SFT 10 > +#define DA_EINT1CMPEN_MON_MASK 0x1 > +#define DA_EINT1CMPEN_MON_MASK_SFT (0x1 << 10) > +#define DA_EINT1INVEN_MON_ADDR \ > + MT6359_ACCDET_CON38 > +#define DA_EINT1INVEN_MON_SFT 11 > +#define DA_EINT1INVEN_MON_MASK 0x1 > +#define DA_EINT1INVEN_MON_MASK_SFT (0x1 << 11) > +#define DA_EINT1CEN_MON_ADDR \ > + MT6359_ACCDET_CON38 > +#define DA_EINT1CEN_MON_SFT 12 > +#define DA_EINT1CEN_MON_MASK 0x1 > +#define DA_EINT1CEN_MON_MASK_SFT (0x1 << 12) > +#define DA_EINT1EN_MON_ADDR \ > + MT6359_ACCDET_CON38 > +#define DA_EINT1EN_MON_SFT 13 > +#define DA_EINT1EN_MON_MASK 0x1 > +#define DA_EINT1EN_MON_MASK_SFT (0x1 << 13) > +#define ACCDET_EINT0_M_PLUG_IN_COUNT_ADDR \ > + MT6359_ACCDET_CON39 > +#define ACCDET_EINT0_M_PLUG_IN_COUNT_SFT 0 > +#define ACCDET_EINT0_M_PLUG_IN_COUNT_MASK 0x7 > +#define ACCDET_EINT0_M_PLUG_IN_COUNT_MASK_SFT (0x7 << 0) > +#define ACCDET_EINT1_M_PLUG_IN_COUNT_ADDR \ > + MT6359_ACCDET_CON39 > +#define ACCDET_EINT1_M_PLUG_IN_COUNT_SFT 4 > +#define ACCDET_EINT1_M_PLUG_IN_COUNT_MASK 0x7 > +#define ACCDET_EINT1_M_PLUG_IN_COUNT_MASK_SFT (0x7 << 4) > +#define ACCDET_MON_FLAG_EN_ADDR \ > + MT6359_ACCDET_CON40 > +#define ACCDET_MON_FLAG_EN_SFT 0 > +#define ACCDET_MON_FLAG_EN_MASK 0x1 > +#define ACCDET_MON_FLAG_EN_MASK_SFT (0x1 << 0) > +#define ACCDET_MON_FLAG_SEL_ADDR \ > + MT6359_ACCDET_CON40 > +#define ACCDET_MON_FLAG_SEL_SFT 4 > +#define ACCDET_MON_FLAG_SEL_MASK 0xF > +#define ACCDET_MON_FLAG_SEL_MASK_SFT (0xF << 4) > + > +#define RG_AUDPWDBMICBIAS0_ADDR \ > + MT6359_AUDENC_ANA_CON15 > +#define RG_AUDPWDBMICBIAS0_SFT 0 > +#define RG_AUDPWDBMICBIAS0_MASK 0x1 > +#define RG_AUDPWDBMICBIAS0_MASK_SFT (0x1 << 0) > +#define RG_AUDPREAMPLON_ADDR \ > + MT6359_AUDENC_ANA_CON0 > +#define RG_AUDPREAMPLON_SFT 0 > +#define RG_AUDPREAMPLON_MASK 0x1 > +#define RG_AUDPREAMPLON_MASK_SFT (0x1 << 0) > +#define RG_CLKSQ_EN_ADDR \ > + MT6359_AUDENC_ANA_CON23 > +#define RG_CLKSQ_EN_SFT 0 > +#define RG_CLKSQ_EN_MASK 0x1 > +#define RG_CLKSQ_EN_MASK_SFT (0x1 << 0) > +#define RG_RTC32K_CK_PDN_ADDR \ > + MT6359_TOP_CKPDN_CON0 > +#define RG_RTC32K_CK_PDN_SFT 15 > +#define RG_RTC32K_CK_PDN_MASK 0x1 > +#define RG_RTC32K_CK_PDN_MASK_SFT (0x1 << 15) > +#define RG_HPLOUTPUTSTBENH_VAUDP32_ADDR \ > + MT6359_AUDDEC_ANA_CON2 > +#define RG_HPLOUTPUTSTBENH_VAUDP32_SFT 0 > +#define RG_HPLOUTPUTSTBENH_VAUDP32_MASK 0x7 > +#define RG_HPLOUTPUTSTBENH_VAUDP32_MASK_SFT (0x7 << 0) > +#define AUXADC_RQST_CH5_ADDR \ > + MT6359_AUXADC_RQST0 > +#define AUXADC_RQST_CH5_SFT 5 > +#define AUXADC_RQST_CH5_MASK 0x1 > +#define AUXADC_RQST_CH5_MASK_SFT (0x1 << 5) > +#define RG_LDO_VUSB_HW0_OP_EN_ADDR \ > + MT6359_LDO_VUSB_OP_EN > +#define RG_LDO_VUSB_HW0_OP_EN_SFT 0 > +#define RG_LDO_VUSB_HW0_OP_EN_MASK 0x1 > +#define RG_LDO_VUSB_HW0_OP_EN_MASK_SFT (0x1 << 0) > +#define RG_HPROUTPUTSTBENH_VAUDP32_ADDR \ > + MT6359_AUDDEC_ANA_CON2 > +#define RG_HPROUTPUTSTBENH_VAUDP32_SFT 4 > +#define RG_HPROUTPUTSTBENH_VAUDP32_MASK 0x7 > +#define RG_HPROUTPUTSTBENH_VAUDP32_MASK_SFT (0x7 << 4) > +#define RG_NCP_PDDIS_EN_ADDR \ > + MT6359_AFE_NCP_CFG2 > +#define RG_NCP_PDDIS_EN_SFT 0 > +#define RG_NCP_PDDIS_EN_MASK 0x1 > +#define RG_NCP_PDDIS_EN_MASK_SFT (0x1 << 0) > +#define RG_SCK32K_CK_PDN_ADDR \ > + MT6359_TOP_CKPDN_CON0 > +#define RG_SCK32K_CK_PDN_SFT 0 > +#define RG_SCK32K_CK_PDN_MASK 0x1 > +#define RG_SCK32K_CK_PDN_MASK_SFT (0x1 << 0) > /* AUDENC_ANA_CON18: */ > -#define RG_ACCDET_MODE_ANA11_MODE1 (0x000f) > -#define RG_ACCDET_MODE_ANA11_MODE2 (0x008f) > -#define RG_ACCDET_MODE_ANA11_MODE6 (0x008f) > +#define RG_ACCDET_MODE_ANA11_MODE1 (0x000F) > +#define RG_ACCDET_MODE_ANA11_MODE2 (0x008F) > +#define RG_ACCDET_MODE_ANA11_MODE6 (0x008F) > > /* AUXADC_ADC5: Auxadc CH5 read data */ > #define AUXADC_DATA_RDY_CH5 BIT(15) > #define AUXADC_DATA_PROCEED_CH5 BIT(15) > -#define AUXADC_DATA_MASK (0x0fff) > +#define AUXADC_DATA_MASK (0x0FFF) > > /* AUXADC_RQST0_SET: Auxadc CH5 request, relevant 0x07EC */ > #define AUXADC_RQST_CH5_SET BIT(5) > /* AUXADC_RQST0_CLR: Auxadc CH5 request, relevant 0x07EC */ > #define AUXADC_RQST_CH5_CLR BIT(5) > > -#define ACCDET_CALI_MASK0 (0xff) > -#define ACCDET_CALI_MASK1 (0xff << 8) > -#define ACCDET_CALI_MASK2 (0xff) > -#define ACCDET_CALI_MASK3 (0xff << 8) > -#define ACCDET_CALI_MASK4 (0xff) > - > -#define ACCDET_EINT1_IRQ_CLR_B11 BIT(PMIC_ACCDET_EINT1_IRQ_CLR_SHIFT) > -#define ACCDET_EINT0_IRQ_CLR_B10 BIT(PMIC_ACCDET_EINT0_IRQ_CLR_SHIFT) > -#define ACCDET_EINT_IRQ_CLR_B10_11 (0x03 << \ > - PMIC_ACCDET_EINT0_IRQ_CLR_SHIFT) > -#define ACCDET_IRQ_CLR_B8 BIT(PMIC_ACCDET_IRQ_CLR_SHIFT) > +#define ACCDET_CALI_MASK0 (0xFF) > +#define ACCDET_CALI_MASK1 (0xFF << 8) > +#define ACCDET_CALI_MASK2 (0xFF) > +#define ACCDET_CALI_MASK3 (0xFF << 8) > +#define ACCDET_CALI_MASK4 (0xFF) > > -#define ACCDET_EINT1_IRQ_B3 BIT(PMIC_ACCDET_EINT1_IRQ_SHIFT) > -#define ACCDET_EINT0_IRQ_B2 BIT(PMIC_ACCDET_EINT0_IRQ_SHIFT) > -#define ACCDET_EINT_IRQ_B2_B3 (0x03 << PMIC_ACCDET_EINT0_IRQ_SHIFT) > -#define ACCDET_IRQ_B0 BIT(PMIC_ACCDET_IRQ_SHIFT) > +#define ACCDET_EINT_IRQ_B2_B3 (0x03 << ACCDET_EINT0_IRQ_SFT) > > /* ACCDET_CON25: RO, accdet FSM state,etc.*/ > -#define ACCDET_STATE_MEM_IN_OFFSET (PMIC_ACCDET_MEM_IN_SHIFT) > -#define ACCDET_STATE_AB_MASK (0x03) > -#define ACCDET_STATE_AB_00 (0x00) > -#define ACCDET_STATE_AB_01 (0x01) > -#define ACCDET_STATE_AB_10 (0x02) > -#define ACCDET_STATE_AB_11 (0x03) > +#define ACCDET_STATE_MEM_IN_OFFSET (ACCDET_MEM_IN_SFT) > +#define ACCDET_STATE_AB_MASK (0x03) > +#define ACCDET_STATE_AB_00 (0x00) > +#define ACCDET_STATE_AB_01 (0x01) > +#define ACCDET_STATE_AB_10 (0x02) > +#define ACCDET_STATE_AB_11 (0x03) > > /* ACCDET_CON19 */ > -#define ACCDET_EINT0_STABLE_VAL ((1 << PMIC_ACCDET_DA_STABLE_SHIFT) | \ > - (1 << PMIC_ACCDET_EINT0_EN_STABLE_SHIFT) | \ > - (1 << PMIC_ACCDET_EINT0_CMPEN_STABLE_SHIFT) | \ > - (1 << PMIC_ACCDET_EINT0_CEN_STABLE_SHIFT)) > - > -#define ACCDET_EINT1_STABLE_VAL ((1 << PMIC_ACCDET_DA_STABLE_SHIFT) | \ > - (1 << PMIC_ACCDET_EINT1_EN_STABLE_SHIFT) | \ > - (1 << PMIC_ACCDET_EINT1_CMPEN_STABLE_SHIFT) | \ > - (1 << PMIC_ACCDET_EINT1_CEN_STABLE_SHIFT)) > +#define ACCDET_EINT0_STABLE_VAL ((ACCDET_DA_STABLE_SFT) | \ > + (ACCDET_EINT0_EN_STABLE_SFT) | \ > + (ACCDET_EINT0_CMPEN_STABLE_SFT) | \ > + (ACCDET_EINT0_CEN_STABLE_SFT)) > + > +#define ACCDET_EINT1_STABLE_VAL ((ACCDET_DA_STABLE_SFT) | \ > + (ACCDET_EINT1_EN_STABLE_SFT) | \ > + (ACCDET_EINT1_CMPEN_STABLE_SFT) | \ > + (ACCDET_EINT1_CEN_STABLE_SFT)) > > /* The following are used for mt6359.c */ > /* MT6359_DCXO_CW12 */ > -- > 1.8.1.1.dirty >
diff --git a/sound/soc/codecs/Kconfig b/sound/soc/codecs/Kconfig index ba4eb54..dbf3141 100644 --- a/sound/soc/codecs/Kconfig +++ b/sound/soc/codecs/Kconfig @@ -1774,6 +1774,13 @@ config SND_SOC_MT6359 help Enable support for the platform which uses MT6359 as external codec device. +config SND_SOC_MT6359_ACCDET + tristate "MediaTek MT6359 ACCDET driver" + depends on MTK_PMIC_WRAP + help + ACCDET means Accessory Detection technology, MediaTek develop it + for ASoC codec soc-jack detection mechanism. + Select N if you don't have jack on board. config SND_SOC_MT6660 tristate "Mediatek MT6660 Speaker Amplifier" diff --git a/sound/soc/codecs/Makefile b/sound/soc/codecs/Makefile index d277f03..f77d057 100644 --- a/sound/soc/codecs/Makefile +++ b/sound/soc/codecs/Makefile @@ -133,6 +133,7 @@ snd-soc-msm8916-digital-objs := msm8916-wcd-digital.o snd-soc-mt6351-objs := mt6351.o snd-soc-mt6358-objs := mt6358.o snd-soc-mt6359-objs := mt6359.o +snd-soc-mt6359-accdet-objs := mt6359-accdet.o snd-soc-mt6660-objs := mt6660.o snd-soc-nau8315-objs := nau8315.o snd-soc-nau8540-objs := nau8540.o @@ -448,6 +449,7 @@ obj-$(CONFIG_SND_SOC_MSM8916_WCD_DIGITAL) +=snd-soc-msm8916-digital.o obj-$(CONFIG_SND_SOC_MT6351) += snd-soc-mt6351.o obj-$(CONFIG_SND_SOC_MT6358) += snd-soc-mt6358.o obj-$(CONFIG_SND_SOC_MT6359) += snd-soc-mt6359.o +obj-$(CONFIG_SND_SOC_MT6359_ACCDET) += mt6359-accdet.o obj-$(CONFIG_SND_SOC_MT6660) += snd-soc-mt6660.o obj-$(CONFIG_SND_SOC_NAU8315) += snd-soc-nau8315.o obj-$(CONFIG_SND_SOC_NAU8540) += snd-soc-nau8540.o diff --git a/sound/soc/codecs/mt6359-accdet.c b/sound/soc/codecs/mt6359-accdet.c new file mode 100644 index 0000000..ff90e4e --- /dev/null +++ b/sound/soc/codecs/mt6359-accdet.c @@ -0,0 +1,1951 @@ +// SPDX-License-Identifier: GPL-2.0 +/* + * Copyright (C) 2021 MediaTek Inc. + * Author: Argus Lin <argus.lin@mediatek.com> + */ + +#include <linux/of_gpio.h> +#include <linux/of.h> +#include <linux/of_irq.h> +#include <linux/of_device.h> +#include <linux/of_address.h> +#include <linux/input.h> +#include <linux/kthread.h> +#include <linux/io.h> +#include <linux/sched/clock.h> +#include <linux/workqueue.h> +#include <linux/timer.h> +#include <linux/delay.h> +#include <linux/module.h> +#include <linux/platform_device.h> +#include <linux/init.h> +#include <linux/irqdomain.h> +#include <linux/irq.h> +#include <linux/regmap.h> +#include <sound/soc.h> +#include <sound/jack.h> +#include <linux/mfd/mt6397/core.h> +#include "mt6359-accdet.h" +#include "mt6359.h" +/* grobal variable definitions */ +#define REGISTER_VAL(x) ((x) - 1) +#define HAS_CAP(_c, _x) \ + ({typeof(_c)c = (_c); \ + typeof(_x)x = (_x); \ + (((c) & (x)) == (x)); }) +#define ACCDET_PMIC_EINT_IRQ BIT(0) +#define ACCDET_AP_GPIO_EINT BIT(1) + +#define ACCDET_PMIC_EINT0 BIT(2) +#define ACCDET_PMIC_EINT1 BIT(3) +#define ACCDET_PMIC_BI_EINT BIT(4) + +#define ACCDET_PMIC_GPIO_TRIG_EINT BIT(5) +#define ACCDET_PMIC_INVERTER_TRIG_EINT BIT(6) +#define ACCDET_PMIC_RSV_EINT BIT(7) + +#define ACCDET_THREE_KEY BIT(8) +#define ACCDET_FOUR_KEY BIT(9) +#define ACCDET_TRI_KEY_CDD BIT(10) +#define ACCDET_RSV_KEY BIT(11) + +#define ACCDET_ANALOG_FASTDISCHARGE BIT(12) +#define ACCDET_DIGITAL_FASTDISCHARGE BIT(13) +#define ACCDET_AD_FASTDISCHRAGE BIT(14) + +#define RET_LT_5K (-1) +#define RET_GT_5K (0) + +/* Used to let accdet know if the pin has been fully plugged-in */ +#define EINT_PLUG_OUT (0) +#define EINT_PLUG_IN (1) + +struct mt63xx_accdet_data { + struct snd_soc_jack jack; + struct platform_device *pdev; + struct device *dev; + struct accdet_priv *data; + atomic_t init_once; + struct regmap *regmap; + int accdet_irq; + int accdet_eint0; + int accdet_eint1; + struct wakeup_source *wake_lock; + struct wakeup_source *timer_lock; + struct mutex res_lock; /* lock to protect flag */ + bool eint_sync_flag; + /* accdet FSM State & lock*/ + unsigned int cur_eint_state; + unsigned int eint0_state; + unsigned int eint1_state; + unsigned int accdet_status; + unsigned int cable_type; + unsigned int cur_key; + unsigned int cali_voltage; + int auxadc_offset; + unsigned int eint_id; + /* when caps include ACCDET_AP_GPIO_EINT */ + struct pinctrl *pinctrl; + struct pinctrl_state *pins_eint; + unsigned int gpiopin; + unsigned int gpio_hp_deb; + unsigned int gpioirq; + unsigned int accdet_eint_type; + /* when MICBIAS_DISABLE_TIMER timeout, queue work: dis_micbias_work */ + struct work_struct delay_init_work; + struct workqueue_struct *delay_init_workqueue; + struct work_struct dis_micbias_work; + struct workqueue_struct *dis_micbias_workqueue; + struct work_struct accdet_work; + struct workqueue_struct *accdet_workqueue; + /* when eint issued, queue work: eint_work */ + struct work_struct eint_work; + struct workqueue_struct *eint_workqueue; +}; + +static struct mt63xx_accdet_data *accdet; + +static struct head_dts_data accdet_dts; +struct pwm_deb_settings *cust_pwm_deb; + +struct accdet_priv { + unsigned int caps; +}; + +static struct accdet_priv mt6359_accdet[] = { + { + .caps = 0, + }, +}; + +const struct of_device_id mt6359_accdet_of_match[] = { + { + .compatible = "mediatek,mt6359-accdet", + .data = &mt6359_accdet, + }, { + /* sentinel */ + }, +}; + +static struct platform_driver mt6359_accdet_driver; +static const struct snd_soc_component_driver mt6359_accdet_soc_driver; + +#define ACCDET_INIT_WAIT_TIMER (10 * HZ) +static struct timer_list accdet_init_timer; +static void delay_init_timerhandler(struct timer_list *t); +/* micbias_timer: disable micbias if no accdet irq after eint, + * timeout: 6 seconds + * timerHandler: dis_micbias_timerhandler() + */ +#define MICBIAS_DISABLE_TIMER (6 * HZ) +static struct timer_list micbias_timer; +static void dis_micbias_timerhandler(struct timer_list *t); + +static unsigned int button_press_debounce = 0x400; +static unsigned int button_press_debounce_01 = 0x800; + +/* local function declaration */ +static void accdet_init_once(void); +static inline void accdet_init(void); +static void accdet_init_debounce(void); +static unsigned int adjust_eint_analog_setting(void); +static unsigned int adjust_eint_setting(unsigned int eintsts); +static void config_digital_init_by_mode(void); +static void config_eint_init_by_mode(void); +static unsigned int get_triggered_eint(void); +static void recover_eint_analog_setting(void); +static void recover_eint_digital_setting(void); +static void recover_eint_setting(unsigned int eintsts); +static void send_status_event(unsigned int cable_type, unsigned int status); +static void accdet_set_debounce(int state, unsigned int debounce); + +/* global function declaration */ + +static u64 mt6359_accdet_get_current_time(void) +{ + return sched_clock(); +} + +static bool mt6359_accdet_timeout_ns(u64 start_time_ns, u64 timeout_time_ns) +{ + u64 cur_time = 0; + u64 elapse_time = 0; + + /* get current tick, ns */ + cur_time = mt6359_accdet_get_current_time(); + if (cur_time < start_time_ns) { + start_time_ns = cur_time; + /* 400us */ + timeout_time_ns = 400 * 1000; + } + elapse_time = cur_time - start_time_ns; + + /* check if timeout */ + if (timeout_time_ns <= elapse_time) + return false; + + return true; +} + +static unsigned int check_key(unsigned int v) +{ + if (HAS_CAP(accdet->data->caps, ACCDET_FOUR_KEY)) { + if (v < accdet_dts.four_key.down && v >= accdet_dts.four_key.up) + return DW_KEY; + if (v < accdet_dts.four_key.up && v >= accdet_dts.four_key.voice) + return UP_KEY; + if (v < accdet_dts.four_key.voice && v >= accdet_dts.four_key.mid) + return AS_KEY; + if (v < accdet_dts.four_key.mid) + return MD_KEY; + } else { + if (v < accdet_dts.three_key.down && v >= accdet_dts.three_key.up) + return DW_KEY; + if (v < accdet_dts.three_key.up && v >= accdet_dts.three_key.mid) + return UP_KEY; + if (v < accdet_dts.three_key.mid) + return MD_KEY; + } + return NO_KEY; +} + +static void send_key_event(unsigned int keycode, unsigned int flag) +{ + int report = 0; + + switch (keycode) { + case DW_KEY: + if (flag != 0) + report = SND_JACK_BTN_1; + snd_soc_jack_report(&accdet->jack, report, SND_JACK_BTN_1); + break; + case UP_KEY: + if (flag != 0) + report = SND_JACK_BTN_2; + snd_soc_jack_report(&accdet->jack, report, SND_JACK_BTN_2); + break; + case MD_KEY: + if (flag != 0) + report = SND_JACK_BTN_0; + snd_soc_jack_report(&accdet->jack, report, SND_JACK_BTN_0); + break; + case AS_KEY: + if (flag != 0) + report = SND_JACK_BTN_3; + snd_soc_jack_report(&accdet->jack, report, SND_JACK_BTN_3); + break; + } +} + +static void send_status_event(unsigned int cable_type, unsigned int status) +{ + int report = 0; + + switch (cable_type) { + case HEADSET_NO_MIC: + if (status) + report = SND_JACK_HEADPHONE; + else + report = 0; + snd_soc_jack_report(&accdet->jack, report, SND_JACK_HEADPHONE); + /* when plug 4-pole out, if both AB=3 AB=0 happen,3-pole plug + * in will be incorrectly reported, then 3-pole plug-out is + * reported,if no mantory 4-pole plug-out, icon would be + * visible. + */ + if (status == 0) { + report = 0; + snd_soc_jack_report(&accdet->jack, report, SND_JACK_MICROPHONE); + } + pr_info("accdet HEADPHONE(3-pole) %s\n", + status ? "PlugIn" : "PlugOut"); + break; + case HEADSET_MIC: + /* when plug 4-pole out, 3-pole plug out should also be + * reported for slow plug-in case + */ + if (status == 0) { + report = 0; + snd_soc_jack_report(&accdet->jack, report, SND_JACK_HEADPHONE); + } + if (status) + report = SND_JACK_MICROPHONE; + else + report = 0; + + snd_soc_jack_report(&accdet->jack, report, SND_JACK_MICROPHONE); + pr_info("accdet MICROPHONE(4-pole) %s\n", + status ? "PlugIn" : "PlugOut"); + /* when press key for a long time then plug in + * even recoginized as 4-pole + * disable micbias timer still timeout after 6s + * it check AB=00(because keep to press key) then disable + * micbias, it will cause key no response + */ + del_timer_sync(&micbias_timer); + break; + case LINE_OUT_DEVICE: + if (status) + report = SND_JACK_LINEOUT; + else + report = 0; + + snd_soc_jack_report(&accdet->jack, report, SND_JACK_LINEOUT); + pr_info("accdet LineOut %s\n", + status ? "PlugIn" : "PlugOut"); + break; + default: + pr_info("%s Invalid cableType\n", __func__); + } +} + +static void multi_key_detection(unsigned int cur_AB) +{ + if (cur_AB == ACCDET_STATE_AB_00) + accdet->cur_key = check_key(accdet->cali_voltage); + + /* delay to wait eint been flaged in register. + * or eint handler issued. accdet->cur_eint_state == PLUG_OUT + */ + usleep_range(10000, 12000); + + if (HAS_CAP(accdet->data->caps, ACCDET_AP_GPIO_EINT)) { + if (accdet->cur_eint_state == EINT_PLUG_IN) + send_key_event(accdet->cur_key, !cur_AB); + else + accdet->cur_key = NO_KEY; + } else { + bool irq_bit = false; + unsigned int val = 0; + + regmap_read(accdet->regmap, ACCDET_IRQ_ADDR, &val); + irq_bit = !(val & ACCDET_EINT_IRQ_B2_B3); + /* send key when: + * no eint is flaged in reg, and now eint PLUG_IN + */ + if (irq_bit && accdet->cur_eint_state == EINT_PLUG_IN) + send_key_event(accdet->cur_key, !cur_AB); + else + accdet->cur_key = NO_KEY; + } + + if (cur_AB) + accdet->cur_key = NO_KEY; +} + +static inline void clear_accdet_int(void) +{ + /* it is safe by using polling to adjust when to clear IRQ_CLR_BIT */ + regmap_update_bits(accdet->regmap, ACCDET_IRQ_ADDR, + BIT(ACCDET_IRQ_CLR_SFT), BIT(ACCDET_IRQ_CLR_SFT)); +} + +static inline void clear_accdet_int_check(void) +{ + u64 cur_time = mt6359_accdet_get_current_time(); + unsigned int val = 0; + + regmap_read(accdet->regmap, ACCDET_IRQ_ADDR, &val); + while (val & ACCDET_IRQ_MASK_SFT && + mt6359_accdet_timeout_ns(cur_time, ACCDET_TIME_OUT)) + ; + /* clear accdet int, modify for fix interrupt trigger twice error */ + regmap_update_bits(accdet->regmap, ACCDET_IRQ_ADDR, + BIT(ACCDET_IRQ_CLR_SFT), 0); + regmap_update_bits(accdet->regmap, RG_INT_STATUS_ACCDET_ADDR, + BIT(RG_INT_STATUS_ACCDET_SFT), + BIT(RG_INT_STATUS_ACCDET_SFT)); +} + +static inline void clear_accdet_eint(unsigned int eintid) +{ + if ((eintid & PMIC_EINT0) == PMIC_EINT0) { + regmap_update_bits(accdet->regmap, ACCDET_IRQ_ADDR, + BIT(ACCDET_EINT0_IRQ_CLR_SFT), + BIT(ACCDET_EINT0_IRQ_CLR_SFT)); + } + if ((eintid & PMIC_EINT1) == PMIC_EINT1) { + regmap_update_bits(accdet->regmap, ACCDET_IRQ_ADDR, + BIT(ACCDET_EINT1_IRQ_CLR_SFT), + BIT(ACCDET_EINT1_IRQ_CLR_SFT)); + } +} + +static inline void clear_accdet_eint_check(unsigned int eintid) +{ + u64 cur_time = mt6359_accdet_get_current_time(); + unsigned int val = 0; + + regmap_read(accdet->regmap, ACCDET_IRQ_ADDR, &val); + + if ((eintid & PMIC_EINT0) == PMIC_EINT0) { + while (val & ACCDET_EINT0_IRQ_MASK_SFT && + mt6359_accdet_timeout_ns(cur_time, ACCDET_TIME_OUT)) + ; + regmap_update_bits(accdet->regmap, ACCDET_IRQ_ADDR, + BIT(ACCDET_EINT0_IRQ_CLR_SFT), 0); + regmap_update_bits(accdet->regmap, + RG_INT_STATUS_ACCDET_ADDR, + BIT(RG_INT_STATUS_ACCDET_EINT0_SFT), + BIT(RG_INT_STATUS_ACCDET_EINT0_SFT)); + } + if ((eintid & PMIC_EINT1) == PMIC_EINT1) { + while (val & ACCDET_EINT1_IRQ_MASK_SFT && + mt6359_accdet_timeout_ns(cur_time, ACCDET_TIME_OUT)) + ; + regmap_update_bits(accdet->regmap, ACCDET_IRQ_ADDR, + BIT(ACCDET_EINT1_IRQ_CLR_SFT), 0); + regmap_update_bits(accdet->regmap, + RG_INT_STATUS_ACCDET_ADDR, + BIT(RG_INT_STATUS_ACCDET_EINT1_SFT), + BIT(RG_INT_STATUS_ACCDET_EINT1_SFT)); + } +} + +static unsigned int adjust_eint_analog_setting(void) +{ + if (accdet_dts.eint_detect_mode == 0x3 || + accdet_dts.eint_detect_mode == 0x4) { + /* ESD switches off */ + regmap_update_bits(accdet->regmap, + RG_ACCDETSPARE_ADDR, 1 << 8, 0); + } + if (accdet_dts.eint_detect_mode == 0x4) { + if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT0)) { + /* enable RG_EINT0CONFIGACCDET */ + regmap_update_bits(accdet->regmap, + RG_EINT0CONFIGACCDET_ADDR, + BIT(RG_EINT0CONFIGACCDET_SFT), + BIT(RG_EINT0CONFIGACCDET_SFT)); + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT1)) { + /* enable RG_EINT1CONFIGACCDET */ + regmap_update_bits(accdet->regmap, + RG_EINT1CONFIGACCDET_ADDR, + BIT(RG_EINT1CONFIGACCDET_SFT), + BIT(RG_EINT1CONFIGACCDET_SFT)); + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_BI_EINT)) { + /* enable RG_EINT0CONFIGACCDET */ + regmap_update_bits(accdet->regmap, + RG_EINT0CONFIGACCDET_ADDR, + BIT(RG_EINT0CONFIGACCDET_SFT), + BIT(RG_EINT0CONFIGACCDET_SFT)); + /* enable RG_EINT1CONFIGACCDET */ + regmap_update_bits(accdet->regmap, + RG_EINT1CONFIGACCDET_ADDR, + BIT(RG_EINT1CONFIGACCDET_SFT), + BIT(RG_EINT1CONFIGACCDET_SFT)); + } + if (accdet_dts.eint_use_ext_res == 0x3 || + accdet_dts.eint_use_ext_res == 0x4) { + /*select 500k, use internal resistor */ + regmap_update_bits(accdet->regmap, + RG_EINT0HIRENB_ADDR, + BIT(RG_EINT0HIRENB_SFT), + BIT(RG_EINT0HIRENB_SFT)); + } + } + return 0; +} + +static unsigned int adjust_eint_digital_setting(void) +{ + if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT0)) { + /* disable inverter */ + regmap_update_bits(accdet->regmap, + ACCDET_EINT0_INVERTER_SW_EN_ADDR, + BIT(ACCDET_EINT0_INVERTER_SW_EN_SFT), 0); + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT1)) { + /* disable inverter */ + regmap_update_bits(accdet->regmap, + ACCDET_EINT1_INVERTER_SW_EN_ADDR, + BIT(ACCDET_EINT1_INVERTER_SW_EN_SFT), 0); + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_BI_EINT)) { + /* disable inverter */ + regmap_update_bits(accdet->regmap, + ACCDET_EINT0_INVERTER_SW_EN_ADDR, + BIT(ACCDET_EINT0_INVERTER_SW_EN_SFT), 0); + /* disable inverter */ + regmap_update_bits(accdet->regmap, + ACCDET_EINT1_INVERTER_SW_EN_ADDR, + BIT(ACCDET_EINT1_INVERTER_SW_EN_SFT), 0); + } + + if (accdet_dts.eint_detect_mode == 0x4) { + if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT0)) { + /* set DA stable signal */ + regmap_update_bits(accdet->regmap, + ACCDET_DA_STABLE_ADDR, + BIT(ACCDET_EINT0_CEN_STABLE_SFT), 0); + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT1)) { + /* set DA stable signal */ + regmap_update_bits(accdet->regmap, + ACCDET_DA_STABLE_ADDR, + BIT(ACCDET_EINT1_CEN_STABLE_SFT), 0); + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_BI_EINT)) { + /* set DA stable signal */ + regmap_update_bits(accdet->regmap, + ACCDET_DA_STABLE_ADDR, + BIT(ACCDET_EINT0_CEN_STABLE_SFT), 0); + /* set DA stable signal */ + regmap_update_bits(accdet->regmap, + ACCDET_DA_STABLE_ADDR, + BIT(ACCDET_EINT1_CEN_STABLE_SFT), 0); + } + } + return 0; +} + +static unsigned int adjust_eint_setting(unsigned int eintsts) +{ + if (eintsts == M_PLUG_IN) { + /* adjust digital setting */ + adjust_eint_digital_setting(); + /* adjust analog setting */ + adjust_eint_analog_setting(); + } else if (eintsts == M_PLUG_OUT) { + /* set debounce to 1ms */ + accdet_set_debounce(eint_state000, + accdet_dts.pwm_deb.eint_debounce0); + } else { + pr_debug("should not be here %s()\n", __func__); + } + + return 0; +} + +static void recover_eint_analog_setting(void) +{ + if (accdet_dts.eint_detect_mode == 0x3 || + accdet_dts.eint_detect_mode == 0x4) { + /* ESD switches on */ + regmap_update_bits(accdet->regmap, RG_ACCDETSPARE_ADDR, + 1 << 8, 1 << 8); + } + if (accdet_dts.eint_detect_mode == 0x4) { + if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT0)) { + /* disable RG_EINT0CONFIGACCDET */ + regmap_update_bits(accdet->regmap, + RG_EINT0CONFIGACCDET_ADDR, + BIT(RG_EINT0CONFIGACCDET_SFT), 0); + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT1)) { + /* disable RG_EINT1CONFIGACCDET */ + regmap_update_bits(accdet->regmap, + RG_EINT1CONFIGACCDET_ADDR, + BIT(RG_EINT1CONFIGACCDET_SFT), 0); + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_BI_EINT)) { + /* disable RG_EINT0CONFIGACCDET */ + regmap_update_bits(accdet->regmap, + RG_EINT0CONFIGACCDET_ADDR, + BIT(RG_EINT0CONFIGACCDET_SFT), 0); + /* disable RG_EINT0CONFIGACCDET */ + regmap_update_bits(accdet->regmap, + RG_EINT1CONFIGACCDET_ADDR, + BIT(RG_EINT1CONFIGACCDET_SFT), 0); + } + regmap_update_bits(accdet->regmap, RG_EINT0HIRENB_ADDR, + BIT(RG_EINT0HIRENB_SFT), 0); + } +} + +static void recover_eint_digital_setting(void) +{ + if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT0)) { + regmap_update_bits(accdet->regmap, + ACCDET_EINT0_M_SW_EN_ADDR, + BIT(ACCDET_EINT0_M_SW_EN_SFT), 0); + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT1)) { + regmap_update_bits(accdet->regmap, + ACCDET_EINT1_M_SW_EN_ADDR, + BIT(ACCDET_EINT1_M_SW_EN_SFT), 0); + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_BI_EINT)) { + regmap_update_bits(accdet->regmap, + ACCDET_EINT0_M_SW_EN_ADDR, + BIT(ACCDET_EINT0_M_SW_EN_SFT), 0); + regmap_update_bits(accdet->regmap, + ACCDET_EINT1_M_SW_EN_ADDR, + BIT(ACCDET_EINT1_M_SW_EN_SFT), 0); + } + if (accdet_dts.eint_detect_mode == 0x4) { + /* enable eint0cen */ + if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT0)) { + /* enable eint0cen */ + regmap_update_bits(accdet->regmap, + ACCDET_DA_STABLE_ADDR, + BIT(ACCDET_EINT0_CEN_STABLE_SFT), + BIT(ACCDET_EINT0_CEN_STABLE_SFT)); + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT1)) { + /* enable eint1cen */ + regmap_update_bits(accdet->regmap, + ACCDET_DA_STABLE_ADDR, + BIT(ACCDET_EINT1_CEN_STABLE_SFT), + BIT(ACCDET_EINT1_CEN_STABLE_SFT)); + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_BI_EINT)) { + /* enable eint0cen */ + regmap_update_bits(accdet->regmap, + ACCDET_DA_STABLE_ADDR, + BIT(ACCDET_EINT0_CEN_STABLE_SFT), + BIT(ACCDET_EINT0_CEN_STABLE_SFT)); + /* enable eint1cen */ + regmap_update_bits(accdet->regmap, + ACCDET_DA_STABLE_ADDR, + BIT(ACCDET_EINT1_CEN_STABLE_SFT), + BIT(ACCDET_EINT1_CEN_STABLE_SFT)); + } + } + + if (accdet_dts.eint_detect_mode != 0x1) { + if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT0)) { + /* enable inverter */ + regmap_update_bits(accdet->regmap, + ACCDET_EINT0_INVERTER_SW_EN_ADDR, + BIT(ACCDET_EINT0_INVERTER_SW_EN_SFT), + BIT(ACCDET_EINT0_INVERTER_SW_EN_SFT)); + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT1)) { + /* enable inverter */ + regmap_update_bits(accdet->regmap, + ACCDET_EINT1_INVERTER_SW_EN_ADDR, + BIT(ACCDET_EINT1_INVERTER_SW_EN_SFT), + BIT(ACCDET_EINT1_INVERTER_SW_EN_SFT)); + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_BI_EINT)) { + /* enable inverter */ + regmap_update_bits(accdet->regmap, + ACCDET_EINT0_INVERTER_SW_EN_ADDR, + BIT(ACCDET_EINT0_INVERTER_SW_EN_SFT), + BIT(ACCDET_EINT0_INVERTER_SW_EN_SFT)); + /* enable inverter */ + regmap_update_bits(accdet->regmap, + ACCDET_EINT1_INVERTER_SW_EN_ADDR, + BIT(ACCDET_EINT1_INVERTER_SW_EN_SFT), + BIT(ACCDET_EINT1_INVERTER_SW_EN_SFT)); + } + } +} + +static void recover_eint_setting(unsigned int eintsts) +{ + if (eintsts == M_PLUG_OUT) { + recover_eint_analog_setting(); + recover_eint_digital_setting(); + } +} + +static unsigned int get_triggered_eint(void) +{ + unsigned int eint_ID = NO_PMIC_EINT; + unsigned int irq_status = 0; + + regmap_read(accdet->regmap, ACCDET_IRQ_ADDR, &irq_status); + + if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT0)) { + if ((irq_status & ACCDET_EINT0_IRQ_MASK_SFT) == + ACCDET_EINT0_IRQ_MASK_SFT) + eint_ID = PMIC_EINT0; + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT1)) { + if ((irq_status & ACCDET_EINT1_IRQ_MASK_SFT) == + ACCDET_EINT1_IRQ_MASK_SFT) + eint_ID = PMIC_EINT1; + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_BI_EINT)) { + if ((irq_status & ACCDET_EINT0_IRQ_MASK_SFT) == + ACCDET_EINT0_IRQ_MASK_SFT) + eint_ID |= PMIC_EINT0; + if ((irq_status & ACCDET_EINT1_IRQ_MASK_SFT) == + ACCDET_EINT1_IRQ_MASK_SFT) + eint_ID |= PMIC_EINT1; + } + return eint_ID; +} + +static inline void enable_accdet(unsigned int state_swctrl) +{ + /* enable ACCDET unit */ + regmap_update_bits(accdet->regmap, ACCDET_SW_EN_ADDR, + BIT(ACCDET_SW_EN_SFT), BIT(ACCDET_SW_EN_SFT)); +} + +static inline void disable_accdet(void) +{ + clear_accdet_int(); + usleep_range(200, 300); + mutex_lock(&accdet->res_lock); + clear_accdet_int_check(); + mutex_unlock(&accdet->res_lock); + + /* recover accdet debounce0,3 */ + accdet_set_debounce(accdet_state000, cust_pwm_deb->debounce0); + accdet_set_debounce(accdet_state001, cust_pwm_deb->debounce1); + accdet_set_debounce(accdet_state011, cust_pwm_deb->debounce3); +} + +static inline void headset_plug_out(void) +{ + send_status_event(accdet->cable_type, 0); + accdet->accdet_status = PLUG_OUT; + accdet->cable_type = NO_DEVICE; + + if (accdet->cur_key != 0) { + send_key_event(accdet->cur_key, 0); + accdet->cur_key = 0; + } + pr_info("accdet %s, set cable_type = NO_DEVICE\n", __func__); +} + +static void dis_micbias_timerhandler(struct timer_list *t) +{ + int ret = 0; + + ret = queue_work(accdet->dis_micbias_workqueue, + &accdet->dis_micbias_work); + if (!ret) + pr_notice("Error: %s (%d)\n", __func__, ret); +} + +static void dis_micbias_work_callback(struct work_struct *work) +{ + unsigned int cur_AB = 0, eint = 0; + unsigned int val = 0; + + /* check EINT0 status, if plug out, + * not need to disable accdet here + */ + regmap_read(accdet->regmap, ACCDET_EINT0_MEM_IN_ADDR, &val); + eint = ((val >> ACCDET_EINT0_MEM_IN_SFT) & ACCDET_EINT0_MEM_IN_MASK); + if (eint == M_PLUG_OUT) { + pr_notice("%s Plug-out, no need disable micbias\n", __func__); + return; + } + + regmap_read(accdet->regmap, ACCDET_MEM_IN_ADDR, &val); + cur_AB = (val >> ACCDET_STATE_MEM_IN_OFFSET) & ACCDET_STATE_AB_MASK; + + /* if 3pole disable accdet + * if <20k + 4pole, disable accdet will disable accdet + * plug out interrupt. The behavior will same as 3pole + */ + if (accdet->cable_type == HEADSET_NO_MIC || + cur_AB == ACCDET_STATE_AB_00 || + cur_AB == ACCDET_STATE_AB_11) { + regmap_update_bits(accdet->regmap, ACCDET_SW_EN_ADDR, + BIT(ACCDET_SW_EN_SFT), 0); + disable_accdet(); + } +} + +static void eint_work_callback(struct work_struct *work) +{ + if (accdet->cur_eint_state == EINT_PLUG_IN) { + /* disable vusb LP */ + regmap_write(accdet->regmap, RG_LDO_VUSB_HW0_OP_EN_ADDR, 0x8000); + + mutex_lock(&accdet->res_lock); + accdet->eint_sync_flag = true; + mutex_unlock(&accdet->res_lock); + __pm_wakeup_event(accdet->timer_lock, + jiffies_to_msecs(7 * HZ)); + + accdet_init(); + + enable_accdet(0); + } else { + mutex_lock(&accdet->res_lock); + accdet->eint_sync_flag = false; + mutex_unlock(&accdet->res_lock); + del_timer_sync(&micbias_timer); + + regmap_update_bits(accdet->regmap, ACCDET_SW_EN_ADDR, + BIT(ACCDET_SW_EN_SFT), 0); + disable_accdet(); + headset_plug_out(); + } + + if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT_IRQ)) + recover_eint_setting(accdet->eint_id); + else if (HAS_CAP(accdet->data->caps, ACCDET_AP_GPIO_EINT)) + enable_irq(accdet->gpioirq); +} + +static void accdet_set_debounce(int state, unsigned int debounce) +{ + switch (state) { + case accdet_state000: + /* set ACCDET debounce value = debounce/32 ms */ + regmap_write(accdet->regmap, ACCDET_DEBOUNCE0_ADDR, debounce); + break; + case accdet_state001: + regmap_write(accdet->regmap, ACCDET_DEBOUNCE1_ADDR, debounce); + break; + case accdet_state010: + regmap_write(accdet->regmap, ACCDET_DEBOUNCE2_ADDR, debounce); + break; + case accdet_state011: + regmap_write(accdet->regmap, ACCDET_DEBOUNCE3_ADDR, debounce); + break; + case accdet_auxadc: + /* set auxadc debounce:0x42(2ms) */ + regmap_write(accdet->regmap, + ACCDET_CONNECT_AUXADC_TIME_DIG_ADDR, debounce); + break; + case eint_state000: + regmap_update_bits(accdet->regmap, ACCDET_EINT_DEBOUNCE0_ADDR, + 0xF << ACCDET_EINT_DEBOUNCE0_SFT, + debounce << ACCDET_EINT_DEBOUNCE0_SFT); + break; + case eint_state001: + regmap_update_bits(accdet->regmap, ACCDET_EINT_DEBOUNCE1_ADDR, + 0xF << ACCDET_EINT_DEBOUNCE1_SFT, + debounce << ACCDET_EINT_DEBOUNCE1_SFT); + break; + case eint_state010: + regmap_update_bits(accdet->regmap, ACCDET_EINT_DEBOUNCE2_ADDR, + 0xF << ACCDET_EINT_DEBOUNCE2_SFT, + debounce << ACCDET_EINT_DEBOUNCE2_SFT); + break; + case eint_state011: + regmap_update_bits(accdet->regmap, ACCDET_EINT_DEBOUNCE3_ADDR, + 0xF << ACCDET_EINT_DEBOUNCE3_SFT, + debounce << ACCDET_EINT_DEBOUNCE3_SFT); + break; + case eint_inverter_state000: + regmap_write(accdet->regmap, ACCDET_EINT_INVERTER_DEBOUNCE_ADDR, + debounce); + break; + default: + pr_notice("Error: %s error state (%d)\n", __func__, state); + break; + } +} + +static inline void check_cable_type(void) +{ + unsigned int cur_AB = 0; + unsigned int val = 0; + + regmap_read(accdet->regmap, ACCDET_MEM_IN_ADDR, &val); + + cur_AB = (val >> ACCDET_STATE_MEM_IN_OFFSET) & ACCDET_STATE_AB_MASK; + + switch (accdet->accdet_status) { + case PLUG_OUT: + if (cur_AB == ACCDET_STATE_AB_00) { + mutex_lock(&accdet->res_lock); + if (accdet->eint_sync_flag) { + accdet->cable_type = HEADSET_NO_MIC; + accdet->accdet_status = HOOK_SWITCH; + } else { + pr_notice("accdet hp has been plug-out\n"); + } + mutex_unlock(&accdet->res_lock); + /* for IOT HP */ + accdet_set_debounce(eint_state011, + accdet_dts.pwm_deb.eint_debounce3); + } else if (cur_AB == ACCDET_STATE_AB_01) { + mutex_lock(&accdet->res_lock); + if (accdet->eint_sync_flag) { + accdet->accdet_status = MIC_BIAS; + accdet->cable_type = HEADSET_MIC; + } else { + pr_notice("accdet hp has been plug-out\n"); + } + mutex_unlock(&accdet->res_lock); + /* adjust hook switch debounce time + * for fast key press condition, avoid to miss key + */ + accdet_set_debounce(accdet_state000, + button_press_debounce); + + /* adjust debounce1 to original 0x800(64ms), + * to fix miss key issue when fast press double key. + */ + accdet_set_debounce(accdet_state001, + button_press_debounce_01); + accdet_set_debounce(eint_state011, 0x1); + } else if (cur_AB == ACCDET_STATE_AB_11) { + /* accdet PLUG_OUT state not change */ + if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT_IRQ)) { + mutex_lock(&accdet->res_lock); + if (accdet->eint_sync_flag) { + accdet->accdet_status = PLUG_OUT; + accdet->cable_type = NO_DEVICE; + } else { + pr_notice("accdet hp been plug-out\n"); + } + mutex_unlock(&accdet->res_lock); + } + } else { + pr_notice("accdet %s Invalid AB.\n", __func__); + } + break; + case MIC_BIAS: + if (cur_AB == ACCDET_STATE_AB_00) { + mutex_lock(&accdet->res_lock); + if (accdet->eint_sync_flag) { + accdet->accdet_status = HOOK_SWITCH; + multi_key_detection(cur_AB); + } else { + pr_notice("accdet hp has been plug-out\n"); + } + mutex_unlock(&accdet->res_lock); + } else if (cur_AB == ACCDET_STATE_AB_01) { + mutex_lock(&accdet->res_lock); + if (accdet->eint_sync_flag) { + accdet->accdet_status = MIC_BIAS; + accdet->cable_type = HEADSET_MIC; + /* accdet MIC_BIAS state not change */ + } else { + pr_notice("accdet hp has been plug-out\n"); + } + mutex_unlock(&accdet->res_lock); + accdet_set_debounce(eint_state011, 0x1); + } else if (cur_AB == ACCDET_STATE_AB_11) { + /* accdet Don't send plug out in MIC_BIAS */ + mutex_lock(&accdet->res_lock); + if (accdet->eint_sync_flag) + accdet->accdet_status = PLUG_OUT; + else + pr_notice("accdet hp has been plug-out\n"); + mutex_unlock(&accdet->res_lock); + } else { + pr_notice("accdet %s Invalid AB.\n", __func__); + } + break; + case HOOK_SWITCH: + if (cur_AB == ACCDET_STATE_AB_00) { + } else if (cur_AB == ACCDET_STATE_AB_01) { + mutex_lock(&accdet->res_lock); + if (accdet->eint_sync_flag) { + multi_key_detection(cur_AB); + accdet->accdet_status = MIC_BIAS; + accdet->cable_type = HEADSET_MIC; + } else { + pr_notice("accdet hp has been plug-out\n"); + } + mutex_unlock(&accdet->res_lock); + + /* adjust debounce0 and debounce1 to fix miss key issue. + */ + accdet_set_debounce(accdet_state000, + button_press_debounce); + accdet_set_debounce(accdet_state001, + button_press_debounce_01); + /* for IOT HP */ + accdet_set_debounce(eint_state011, 0x1); + } else if (cur_AB == ACCDET_STATE_AB_11) { + /* accdet Don't send plugout in HOOK_SWITCH */ + mutex_lock(&accdet->res_lock); + if (accdet->eint_sync_flag) + accdet->accdet_status = PLUG_OUT; + else + pr_notice("accdet hp has been plug-out\n"); + mutex_unlock(&accdet->res_lock); + } else { + pr_notice("accdet %s Invalid AB.\n", __func__); + } + break; + case STAND_BY: + /* accdet %s STANDBY state.Err!Do nothing */ + break; + default: + /* accdet %s Error state.Do nothing */ + break; + } +} + +static void accdet_work_callback(struct work_struct *work) +{ + unsigned int pre_cable_type = accdet->cable_type; + + __pm_stay_awake(accdet->wake_lock); + check_cable_type(); + + mutex_lock(&accdet->res_lock); + if (accdet->eint_sync_flag) { + if (pre_cable_type != accdet->cable_type) + send_status_event(accdet->cable_type, 1); + } + mutex_unlock(&accdet->res_lock); + if (accdet->cable_type != NO_DEVICE) { + /* enable vusb LP */ + regmap_write(accdet->regmap, RG_LDO_VUSB_HW0_OP_EN_ADDR, 0x8005); + } + + __pm_relax(accdet->wake_lock); +} + +static void accdet_queue_work(void) +{ + int ret; + + if (accdet->accdet_status == MIC_BIAS) + accdet->cali_voltage = 10; + + ret = queue_work(accdet->accdet_workqueue, &accdet->accdet_work); + if (!ret) + pr_notice("Error: %s (%d)\n", __func__, ret); +} + +static int pmic_eint_queue_work(int eint) +{ + int ret = 0; + + if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT0)) { + if (eint == PMIC_EINT0) { + if (accdet->cur_eint_state == EINT_PLUG_IN) { + accdet_set_debounce(accdet_state011, + cust_pwm_deb->debounce3); + accdet->cur_eint_state = EINT_PLUG_OUT; + } else { + if (accdet->eint_id != M_PLUG_OUT) { + accdet->cur_eint_state = EINT_PLUG_IN; + mod_timer(&micbias_timer, + jiffies + MICBIAS_DISABLE_TIMER); + } + } + ret = queue_work(accdet->eint_workqueue, + &accdet->eint_work); + } else { + pr_notice("%s invalid EINT ID!\n", __func__); + } + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT1)) { + if (eint == PMIC_EINT1) { + if (accdet->cur_eint_state == EINT_PLUG_IN) { + accdet_set_debounce(accdet_state011, + cust_pwm_deb->debounce3); + accdet->cur_eint_state = EINT_PLUG_OUT; + } else { + if (accdet->eint_id != M_PLUG_OUT) { + accdet->cur_eint_state = EINT_PLUG_IN; + mod_timer(&micbias_timer, + jiffies + MICBIAS_DISABLE_TIMER); + } + } + ret = queue_work(accdet->eint_workqueue, + &accdet->eint_work); + } else { + pr_notice("%s invalid EINT ID!\n", __func__); + } + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_BI_EINT)) { + if ((eint & PMIC_EINT0) == PMIC_EINT0) { + if (accdet->eint0_state == EINT_PLUG_IN) { + accdet_set_debounce(accdet_state011, + cust_pwm_deb->debounce3); + accdet->eint0_state = EINT_PLUG_OUT; + } else { + if (accdet->eint_id != M_PLUG_OUT) + accdet->eint0_state = EINT_PLUG_IN; + } + } + if ((eint & PMIC_EINT1) == PMIC_EINT1) { + if (accdet->eint1_state == EINT_PLUG_IN) { + accdet_set_debounce(accdet_state011, + cust_pwm_deb->debounce3); + accdet->eint1_state = EINT_PLUG_OUT; + } else { + if (accdet->eint_id != M_PLUG_OUT) + accdet->eint1_state = EINT_PLUG_IN; + } + } + + /* bi_eint trigger issued current state, may */ + if (accdet->cur_eint_state == EINT_PLUG_OUT) { + accdet->cur_eint_state = + accdet->eint0_state & accdet->eint1_state; + if (accdet->cur_eint_state == EINT_PLUG_IN) { + mod_timer(&micbias_timer, + jiffies + MICBIAS_DISABLE_TIMER); + ret = queue_work(accdet->eint_workqueue, + &accdet->eint_work); + } + } else if (accdet->cur_eint_state == EINT_PLUG_IN) { + if ((accdet->eint0_state | accdet->eint1_state) == EINT_PLUG_OUT) { + clear_accdet_eint_check(PMIC_EINT0); + clear_accdet_eint_check(PMIC_EINT1); + } else if ((accdet->eint0_state & accdet->eint1_state) + == EINT_PLUG_OUT) { + accdet->cur_eint_state = EINT_PLUG_OUT; + ret = queue_work(accdet->eint_workqueue, + &accdet->eint_work); + } + } + } + return ret; +} + +void accdet_irq_handle(void) +{ + unsigned int eint = 0; + unsigned int irq_status = 0, acc_sts = 0, eint_sts = 0; + unsigned int val = 0; + + eint = get_triggered_eint(); + regmap_read(accdet->regmap, ACCDET_IRQ_ADDR, &irq_status); + regmap_read(accdet->regmap, ACCDET_MEM_IN_ADDR, &acc_sts); + regmap_read(accdet->regmap, ACCDET_EINT0_MEM_IN_ADDR, &eint_sts); + + if ((irq_status & ACCDET_IRQ_MASK_SFT) && eint == 0) { + clear_accdet_int(); + accdet_queue_work(); + clear_accdet_int_check(); + } else if (eint != NO_PMIC_EINT) { + /* check EINT0 status */ + regmap_read(accdet->regmap, ACCDET_EINT0_MEM_IN_ADDR, &val); + accdet->eint_id = ((val >> ACCDET_EINT0_MEM_IN_SFT) & + ACCDET_EINT0_MEM_IN_MASK); + /* adjust eint digital/analog setting */ + adjust_eint_setting(accdet->eint_id); + clear_accdet_eint(eint); + clear_accdet_eint_check(eint); + pmic_eint_queue_work(eint); + } else { + pr_notice("%s no interrupt detected!\n", __func__); + } +} + +static irqreturn_t mtk_accdet_irq_handler_thread(int irq, void *data) +{ + accdet_irq_handle(); + + return IRQ_HANDLED; +} + +static irqreturn_t ex_eint_handler(int irq, void *data) +{ + int ret = 0; + + if (accdet->cur_eint_state == EINT_PLUG_IN) { + /* To trigger EINT when the headset was plugged in + * We set the polarity back as we initialed. + */ + if (accdet->accdet_eint_type == IRQ_TYPE_LEVEL_HIGH) + irq_set_irq_type(accdet->gpioirq, IRQ_TYPE_LEVEL_HIGH); + else + irq_set_irq_type(accdet->gpioirq, IRQ_TYPE_LEVEL_LOW); + gpio_set_debounce(accdet->gpiopin, accdet->gpio_hp_deb); + + accdet->cur_eint_state = EINT_PLUG_OUT; + } else { + /* To trigger EINT when the headset was plugged out + * We set the opposite polarity to what we initialed. + */ + if (accdet->accdet_eint_type == IRQ_TYPE_LEVEL_HIGH) + irq_set_irq_type(accdet->gpioirq, IRQ_TYPE_LEVEL_LOW); + else + irq_set_irq_type(accdet->gpioirq, IRQ_TYPE_LEVEL_HIGH); + + gpio_set_debounce(accdet->gpiopin, + accdet_dts.plugout_deb * 1000); + + accdet->cur_eint_state = EINT_PLUG_IN; + + mod_timer(&micbias_timer, + jiffies + MICBIAS_DISABLE_TIMER); + } + + disable_irq_nosync(accdet->gpioirq); + ret = queue_work(accdet->eint_workqueue, &accdet->eint_work); + return IRQ_HANDLED; +} + +static inline int ext_eint_setup(struct platform_device *platform_device) +{ + int ret = 0; + unsigned int ints[4] = { 0 }; + struct device_node *node = NULL; + struct pinctrl_state *pins_default = NULL; + + accdet->pinctrl = devm_pinctrl_get(&platform_device->dev); + if (IS_ERR(accdet->pinctrl)) { + ret = PTR_ERR(accdet->pinctrl); + return ret; + } + + pins_default = pinctrl_lookup_state(accdet->pinctrl, "default"); + if (IS_ERR(pins_default)) + ret = PTR_ERR(pins_default); + + accdet->pins_eint = pinctrl_lookup_state(accdet->pinctrl, + "state_eint_as_int"); + if (IS_ERR(accdet->pins_eint)) { + ret = PTR_ERR(accdet->pins_eint); + return ret; + } + pinctrl_select_state(accdet->pinctrl, accdet->pins_eint); + + node = of_find_matching_node(node, mt6359_accdet_of_match); + if (!node) + return -1; + + accdet->gpiopin = of_get_named_gpio(node, "deb-gpios", 0); + ret = of_property_read_u32(node, "debounce", + &accdet->gpio_hp_deb); + if (ret < 0) + return ret; + + gpio_set_debounce(accdet->gpiopin, accdet->gpio_hp_deb); + + accdet->gpioirq = irq_of_parse_and_map(node, 0); + ret = of_property_read_u32_array(node, "interrupts", ints, + ARRAY_SIZE(ints)); + if (ret) + return ret; + + accdet->accdet_eint_type = ints[1]; + ret = request_irq(accdet->gpioirq, ex_eint_handler, IRQF_TRIGGER_NONE, + "accdet-eint", NULL); + if (ret) + return ret; + + return 0; +} + +static int mt6359_accdet_parse_dt(void) +{ + int ret = 0; + struct device_node *node = NULL; + int pwm_deb[15] = {0}; + int three_key[4] = {0}; + unsigned int tmp = 0; + + node = of_find_matching_node(node, mt6359_accdet_of_match); + if (!node) { + pr_notice("Error: %s can't find dts node\n", __func__); + return -1; + } + + ret = of_property_read_u32(node, "eint_use_ext_res", + &accdet_dts.eint_use_ext_res); + if (ret) { + /* eint use internal resister */ + accdet_dts.eint_use_ext_res = 0x0; + } + ret = of_property_read_u32(node, "eint_detect_mode", + &accdet_dts.eint_detect_mode); + if (ret) { + /* eint detection mode equals to EINT HW Mode */ + accdet_dts.eint_detect_mode = 0x4; + } + + ret = of_property_read_u32(node, + "accdet-mic-vol", &accdet_dts.mic_vol); + if (ret) + accdet_dts.mic_vol = 8; + + ret = of_property_read_u32(node, "accdet-plugout-debounce", + &accdet_dts.plugout_deb); + if (ret) + accdet_dts.plugout_deb = 1; + + ret = of_property_read_u32(node, + "accdet-mic-mode", &accdet_dts.mic_mode); + if (ret) + accdet_dts.mic_mode = 2; + + ret = of_property_read_u32_array(node, "headset-mode-setting", pwm_deb, + ARRAY_SIZE(pwm_deb)); + /* debounce8(auxadc debounce) is default, needn't get from dts */ + if (!ret) + memcpy(&accdet_dts.pwm_deb, pwm_deb, sizeof(pwm_deb)); + + cust_pwm_deb = &accdet_dts.pwm_deb; + + ret = of_property_read_u32(node, "headset-eint-level-pol", + &accdet_dts.eint_pol); + if (ret) + accdet_dts.eint_pol = 8; + + ret = of_property_read_u32(node, "headset-use-ap-eint", &tmp); + if (ret) + tmp = 0; + if (tmp == 0) + accdet->data->caps |= ACCDET_PMIC_EINT_IRQ; + else if (tmp == 1) + accdet->data->caps |= ACCDET_AP_GPIO_EINT; + + ret = of_property_read_u32(node, "headset-eint-num", &tmp); + if (ret) + tmp = 0; + if (tmp == 0) + accdet->data->caps |= ACCDET_PMIC_EINT0; + else if (tmp == 1) + accdet->data->caps |= ACCDET_PMIC_EINT1; + else if (tmp == 2) + accdet->data->caps |= ACCDET_PMIC_BI_EINT; + + ret = of_property_read_u32(node, "headset-eint-trig-mode", &tmp); + if (ret) + tmp = 0; + if (tmp == 0) + accdet->data->caps |= ACCDET_PMIC_GPIO_TRIG_EINT; + else if (tmp == 1) + accdet->data->caps |= ACCDET_PMIC_INVERTER_TRIG_EINT; + + ret = of_property_read_u32(node, "headset-key-mode", &tmp); + if (ret) + tmp = 0; + if (tmp == 0) + accdet->data->caps |= ACCDET_THREE_KEY; + else if (tmp == 1) + accdet->data->caps |= ACCDET_FOUR_KEY; + else if (tmp == 2) + accdet->data->caps |= ACCDET_TRI_KEY_CDD; + + if (HAS_CAP(accdet->data->caps, ACCDET_FOUR_KEY)) { + int four_key[5]; + + ret = of_property_read_u32_array(node, + "headset-four-key-threshold", + four_key, ARRAY_SIZE(four_key)); + if (!ret) { + memcpy(&accdet_dts.four_key, four_key + 1, + sizeof(struct four_key_threshold)); + } else { + pr_notice("accdet no 4-key-thrsh dts, use efuse\n"); + } + } else { + if (HAS_CAP(accdet->data->caps, ACCDET_THREE_KEY)) { + ret = of_property_read_u32_array(node, + "headset-three-key-threshold", + three_key, ARRAY_SIZE(three_key)); + } else { + ret = of_property_read_u32_array(node, + "headset-three-key-threshold-CDD", + three_key, + ARRAY_SIZE(three_key)); + } + if (!ret) + memcpy(&accdet_dts.three_key, three_key + 1, + sizeof(struct three_key_threshold)); + } + + ret = of_property_read_u32(node, "eint_use_ext_res", + &accdet_dts.eint_use_ext_res); + if (ret) { + /* eint use internal resister */ + accdet_dts.eint_use_ext_res = 0x0; + } + pr_info("accdet caps=%x\n", accdet->data->caps); + + return 0; +} + +static void config_digital_init_by_mode(void) +{ + /* enable eint cmpmem pwm */ + regmap_write(accdet->regmap, ACCDET_EINT_CMPMEN_PWM_THRESH_ADDR, + (accdet_dts.pwm_deb.eint_pwm_width << 4 | + accdet_dts.pwm_deb.eint_pwm_thresh)); + /* DA signal stable */ + if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT0)) { + regmap_write(accdet->regmap, ACCDET_DA_STABLE_ADDR, + ACCDET_EINT0_STABLE_VAL); + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT1)) { + regmap_write(accdet->regmap, ACCDET_DA_STABLE_ADDR, + ACCDET_EINT1_STABLE_VAL); + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_BI_EINT)) { + regmap_write(accdet->regmap, ACCDET_DA_STABLE_ADDR, + ACCDET_EINT0_STABLE_VAL); + regmap_write(accdet->regmap, ACCDET_DA_STABLE_ADDR, + ACCDET_EINT1_STABLE_VAL); + } + /* after receive n+1 number, interrupt issued. now is 2 times */ + regmap_update_bits(accdet->regmap, ACCDET_EINT_M_PLUG_IN_NUM_ADDR, + BIT(ACCDET_EINT_M_PLUG_IN_NUM_SFT), + BIT(ACCDET_EINT_M_PLUG_IN_NUM_SFT)); + /* setting HW mode, enable digital fast discharge + * if use EINT0 & EINT1 detection, please modify + * ACCDET_HWMODE_EN_ADDR[2:1] + */ + regmap_write(accdet->regmap, ACCDET_HWMODE_EN_ADDR, 0x100); + + regmap_update_bits(accdet->regmap, ACCDET_EINT_M_DETECT_EN_ADDR, + BIT(ACCDET_EINT_M_DETECT_EN_SFT), 0); + + /* enable PWM */ + regmap_write(accdet->regmap, ACCDET_CMP_PWM_EN_ADDR, 0x67); + /* enable inverter detection */ + if (accdet_dts.eint_detect_mode == 0x1) { + /* disable inverter detection */ + if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT0)) { + regmap_update_bits(accdet->regmap, + ACCDET_EINT0_INVERTER_SW_EN_ADDR, + BIT(ACCDET_EINT0_INVERTER_SW_EN_SFT), + 0); + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT1)) { + regmap_update_bits(accdet->regmap, + ACCDET_EINT1_INVERTER_SW_EN_ADDR, + BIT(ACCDET_EINT1_INVERTER_SW_EN_SFT), + 0); + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_BI_EINT)) { + regmap_update_bits(accdet->regmap, + ACCDET_EINT0_INVERTER_SW_EN_ADDR, + BIT(ACCDET_EINT0_INVERTER_SW_EN_SFT), + 0); + regmap_update_bits(accdet->regmap, + ACCDET_EINT1_INVERTER_SW_EN_ADDR, + BIT(ACCDET_EINT1_INVERTER_SW_EN_SFT), + 0); + } + } else { + if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT0)) { + regmap_update_bits(accdet->regmap, + ACCDET_EINT0_INVERTER_SW_EN_ADDR, + BIT(ACCDET_EINT0_INVERTER_SW_EN_SFT), + BIT(ACCDET_EINT0_INVERTER_SW_EN_SFT)); + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT1)) { + regmap_update_bits(accdet->regmap, + ACCDET_EINT1_INVERTER_SW_EN_ADDR, + BIT(ACCDET_EINT1_INVERTER_SW_EN_SFT), + BIT(ACCDET_EINT1_INVERTER_SW_EN_SFT)); + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_BI_EINT)) { + regmap_update_bits(accdet->regmap, + ACCDET_EINT0_INVERTER_SW_EN_ADDR, + BIT(ACCDET_EINT0_INVERTER_SW_EN_SFT), + BIT(ACCDET_EINT0_INVERTER_SW_EN_SFT)); + regmap_update_bits(accdet->regmap, + ACCDET_EINT1_INVERTER_SW_EN_ADDR, + BIT(ACCDET_EINT1_INVERTER_SW_EN_SFT), + BIT(ACCDET_EINT1_INVERTER_SW_EN_SFT)); + } + } +} + +static void config_eint_init_by_mode(void) +{ + if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT0)) { + regmap_update_bits(accdet->regmap, RG_EINT0EN_ADDR, + BIT(RG_EINT0EN_SFT), BIT(RG_EINT0EN_SFT)); + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT1)) { + regmap_update_bits(accdet->regmap, RG_EINT1EN_ADDR, + BIT(RG_EINT1EN_SFT), BIT(RG_EINT1EN_SFT)); + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_BI_EINT)) { + regmap_update_bits(accdet->regmap, RG_EINT0EN_ADDR, + BIT(RG_EINT0EN_SFT), BIT(RG_EINT0EN_SFT)); + regmap_update_bits(accdet->regmap, RG_EINT1EN_ADDR, + BIT(RG_EINT1EN_SFT), BIT(RG_EINT1EN_SFT)); + } + /* ESD switches on */ + regmap_update_bits(accdet->regmap, RG_ACCDETSPARE_ADDR, + 1 << 8, 1 << 8); + /* before playback, set NCP pull low before nagative voltage */ + regmap_update_bits(accdet->regmap, RG_NCP_PDDIS_EN_ADDR, + BIT(RG_NCP_PDDIS_EN_SFT), BIT(RG_NCP_PDDIS_EN_SFT)); + + if (accdet_dts.eint_detect_mode == 0x1 || + accdet_dts.eint_detect_mode == 0x2 || + accdet_dts.eint_detect_mode == 0x3) { + if (accdet_dts.eint_use_ext_res == 0x1) { + /* select VTH to 2v and 500k, use external resitance */ + if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT0)) { + /* disable RG_EINT0CONFIGACCDET */ + regmap_update_bits(accdet->regmap, + RG_EINT0CONFIGACCDET_ADDR, + BIT(RG_EINT0CONFIGACCDET_SFT), + 0); + } else if (HAS_CAP(accdet->data->caps, + ACCDET_PMIC_EINT1)) { + /* disable RG_EINT1CONFIGACCDET */ + regmap_update_bits(accdet->regmap, + RG_EINT1CONFIGACCDET_ADDR, + BIT(RG_EINT1CONFIGACCDET_SFT), + 0); + } else if (HAS_CAP(accdet->data->caps, + ACCDET_PMIC_BI_EINT)) { + /* disable RG_EINT0CONFIGACCDET */ + regmap_update_bits(accdet->regmap, + RG_EINT0CONFIGACCDET_ADDR, + BIT(RG_EINT0CONFIGACCDET_SFT), + 0); + /* disable RG_EINT1CONFIGACCDET */ + regmap_update_bits(accdet->regmap, + RG_EINT1CONFIGACCDET_ADDR, + BIT(RG_EINT1CONFIGACCDET_SFT), + 0); + } + } else { + /* select VTH to 2v and 500k, use internal resitance */ + if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT0)) { + /* enable RG_EINT0CONFIGACCDET */ + regmap_update_bits(accdet->regmap, + RG_EINT0CONFIGACCDET_ADDR, + BIT(RG_EINT0CONFIGACCDET_SFT), + BIT(RG_EINT0CONFIGACCDET_SFT)); + } else if (HAS_CAP(accdet->data->caps, + ACCDET_PMIC_EINT1)) { + /* enable RG_EINT1CONFIGACCDET */ + regmap_update_bits(accdet->regmap, + RG_EINT1CONFIGACCDET_ADDR, + BIT(RG_EINT1CONFIGACCDET_SFT), + BIT(RG_EINT1CONFIGACCDET_SFT)); + } else if (HAS_CAP(accdet->data->caps, + ACCDET_PMIC_BI_EINT)) { + /* enable RG_EINT0CONFIGACCDET */ + regmap_update_bits(accdet->regmap, + RG_EINT0CONFIGACCDET_ADDR, + BIT(RG_EINT0CONFIGACCDET_SFT), + BIT(RG_EINT0CONFIGACCDET_SFT)); + /* enable RG_EINT1CONFIGACCDET */ + regmap_update_bits(accdet->regmap, + RG_EINT1CONFIGACCDET_ADDR, + BIT(RG_EINT1CONFIGACCDET_SFT), + BIT(RG_EINT1CONFIGACCDET_SFT)); + } + } + } + + if (accdet_dts.eint_detect_mode != 0x1) { + /* current detect set 0.25uA */ + regmap_update_bits(accdet->regmap, RG_ACCDETSPARE_ADDR, + 0x3 << RG_ACCDETSPARE_SFT, + 0x3 << RG_ACCDETSPARE_SFT); + } +} + +static void accdet_init_once(void) +{ + unsigned int reg = 0; + + /* reset the accdet unit */ + regmap_update_bits(accdet->regmap, RG_ACCDET_RST_ADDR, + BIT(RG_ACCDET_RST_SFT), BIT(RG_ACCDET_RST_SFT)); + regmap_update_bits(accdet->regmap, RG_ACCDET_RST_ADDR, + BIT(RG_ACCDET_RST_SFT), 0); + + /* clear high micbias1 voltage setting */ + regmap_update_bits(accdet->regmap, RG_AUDPWDBMICBIAS1_ADDR, + 0x3 << RG_AUDMICBIAS1HVEN_SFT, 0); + /* clear micbias1 voltage */ + regmap_update_bits(accdet->regmap, RG_AUDPWDBMICBIAS1_ADDR, + 0x7 << RG_AUDMICBIAS1VREF_SFT, 0); + + /* init pwm frequency, duty & rise/falling delay */ + regmap_write(accdet->regmap, ACCDET_PWM_WIDTH_ADDR, + REGISTER_VAL(cust_pwm_deb->pwm_width)); + regmap_write(accdet->regmap, ACCDET_PWM_THRESH_ADDR, + REGISTER_VAL(cust_pwm_deb->pwm_thresh)); + regmap_write(accdet->regmap, ACCDET_RISE_DELAY_ADDR, + (cust_pwm_deb->fall_delay << 15 | cust_pwm_deb->rise_delay)); + + /* config micbias voltage, micbias1 vref is only controlled by accdet + * if we need 2.8V, config [12:13] + */ + regmap_read(accdet->regmap, RG_AUDPWDBMICBIAS1_ADDR, ®); + if (accdet_dts.mic_vol <= 7) { + /* micbias1 <= 2.7V */ + regmap_write(accdet->regmap, RG_AUDPWDBMICBIAS1_ADDR, + reg | (accdet_dts.mic_vol << RG_AUDMICBIAS1VREF_SFT) | + RG_AUDMICBIAS1LOWPEN_MASK_SFT); + } else if (accdet_dts.mic_vol == 8) { + /* micbias1 = 2.8v */ + regmap_write(accdet->regmap, RG_AUDPWDBMICBIAS1_ADDR, + reg | (3 << RG_AUDMICBIAS1HVEN_SFT) | + RG_AUDMICBIAS1LOWPEN_MASK_SFT); + } else if (accdet_dts.mic_vol == 9) { + /* micbias1 = 2.85v */ + regmap_write(accdet->regmap, RG_AUDPWDBMICBIAS1_ADDR, + reg | (1 << RG_AUDMICBIAS1HVEN_SFT) | + RG_AUDMICBIAS1LOWPEN_MASK_SFT); + } + /* mic mode setting */ + regmap_read(accdet->regmap, RG_AUDACCDETMICBIAS0PULLLOW_ADDR, ®); + if (accdet_dts.mic_mode == HEADSET_MODE_1) { + /* ACC mode*/ + regmap_write(accdet->regmap, RG_AUDACCDETMICBIAS0PULLLOW_ADDR, + reg | RG_ACCDET_MODE_ANA11_MODE1); + /* enable analog fast discharge */ + regmap_update_bits(accdet->regmap, RG_ANALOGFDEN_ADDR, + BIT(RG_ANALOGFDEN_SFT), + BIT(RG_ANALOGFDEN_SFT)); + regmap_update_bits(accdet->regmap, RG_ACCDETSPARE_ADDR, + 0x3 << 11, 0x3 << 11); + } else if (accdet_dts.mic_mode == HEADSET_MODE_2) { + /* DCC mode Low cost mode without internal bias*/ + regmap_write(accdet->regmap, RG_AUDACCDETMICBIAS0PULLLOW_ADDR, + reg | RG_ACCDET_MODE_ANA11_MODE2); + /* enable analog fast discharge */ + regmap_update_bits(accdet->regmap, RG_ANALOGFDEN_ADDR, + 0x3 << RG_ANALOGFDEN_SFT, + 0x3 << RG_ANALOGFDEN_SFT); + } else if (accdet_dts.mic_mode == HEADSET_MODE_6) { + /* DCC mode Low cost mode with internal bias, + * bit8 = 1 to use internal bias + */ + regmap_write(accdet->regmap, RG_AUDACCDETMICBIAS0PULLLOW_ADDR, + reg | RG_ACCDET_MODE_ANA11_MODE6); + regmap_update_bits(accdet->regmap, RG_AUDPWDBMICBIAS1_ADDR, + BIT(RG_AUDMICBIAS1DCSW1PEN_SFT), + BIT(RG_AUDMICBIAS1DCSW1PEN_SFT)); + /* enable analog fast discharge */ + regmap_update_bits(accdet->regmap, RG_ANALOGFDEN_ADDR, + 0x3 << RG_ANALOGFDEN_SFT, + 0x3 << RG_ANALOGFDEN_SFT); + } + + if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT_IRQ)) { + config_eint_init_by_mode(); + config_digital_init_by_mode(); + } else if (HAS_CAP(accdet->data->caps, ACCDET_AP_GPIO_EINT)) { + /* set pull low pads and DCC mode */ + regmap_write(accdet->regmap, RG_AUDACCDETMICBIAS0PULLLOW_ADDR, + 0x8F); + /* disconnect configaccdet */ + regmap_write(accdet->regmap, RG_EINT1CONFIGACCDET_ADDR, + 0x0); + /* disable eint comparator */ + regmap_write(accdet->regmap, RG_EINT0CMPEN_ADDR, 0x0); + /* enable PWM */ + regmap_write(accdet->regmap, ACCDET_CMP_PWM_EN_ADDR, 0x7); + /* enable accdet sw mode */ + regmap_write(accdet->regmap, ACCDET_HWMODE_EN_ADDR, 0x0); + /* set DA signal to stable */ + regmap_write(accdet->regmap, ACCDET_DA_STABLE_ADDR, 0x1); + /* disable eint/inverter/sw_en */ + regmap_write(accdet->regmap, ACCDET_SW_EN_ADDR, 0x0); + } +} + +static void accdet_init_debounce(void) +{ + /* set debounce to 1ms */ + accdet_set_debounce(eint_state000, accdet_dts.pwm_deb.eint_debounce0); + /* set debounce to 128ms */ + accdet_set_debounce(eint_state011, accdet_dts.pwm_deb.eint_debounce3); +} + +static inline void accdet_init(void) +{ + /* set and clear initial bit every eint interrutp */ + regmap_update_bits(accdet->regmap, ACCDET_SEQ_INIT_ADDR, + BIT(ACCDET_SEQ_INIT_SFT), BIT(ACCDET_SEQ_INIT_SFT)); + mdelay(2); + regmap_update_bits(accdet->regmap, ACCDET_SEQ_INIT_ADDR, + BIT(ACCDET_SEQ_INIT_SFT), 0); + mdelay(1); + /* init the debounce time (debounce/32768)sec */ + accdet_set_debounce(accdet_state000, cust_pwm_deb->debounce0); + accdet_set_debounce(accdet_state001, cust_pwm_deb->debounce1); + accdet_set_debounce(accdet_state011, cust_pwm_deb->debounce3); + /* auxadc:2ms */ + accdet_set_debounce(accdet_auxadc, cust_pwm_deb->debounce4); + accdet_set_debounce(eint_state001, accdet_dts.pwm_deb.eint_debounce1); + accdet_set_debounce(eint_inverter_state000, + accdet_dts.pwm_deb.eint_inverter_debounce); +} + +/* late init for DC trim, and this API Will be called by audio */ +void mt6359_accdet_late_init(unsigned long data) +{ + if (atomic_cmpxchg(&accdet->init_once, 1, 0)) { + del_timer_sync(&accdet_init_timer); + accdet_init(); + accdet_init_debounce(); + accdet_init_once(); + } else { + pr_info("%s fail\n", __func__); + } +} +EXPORT_SYMBOL(mt6359_accdet_late_init); + +static void delay_init_work_callback(struct work_struct *work) +{ + accdet_init(); + accdet_init_debounce(); + accdet_init_once(); +} + +static void delay_init_timerhandler(struct timer_list *t) +{ + int ret = 0; + + ret = queue_work(accdet->delay_init_workqueue, + &accdet->delay_init_work); + if (!ret) + pr_err("Error: %s (%d)\n", __func__, ret); +} + +int mt6359_accdet_init(struct snd_soc_component *component, + struct snd_soc_card *card) +{ + int ret = 0; + struct mt63xx_accdet_data *priv = + snd_soc_card_get_drvdata(component->card); + + /* Enable Headset and 4 Buttons Jack detection */ + ret = snd_soc_card_jack_new(card, + "Headset Jack", + SND_JACK_HEADSET | + SND_JACK_LINEOUT | + SND_JACK_MECHANICAL, + &priv->jack, + NULL, 0); + if (ret) { + dev_err(card->dev, "Can't new Headset Jack %x\n", ret); + return ret; + } + + accdet->jack.jack->input_dev->id.bustype = BUS_HOST; + snd_jack_set_key(accdet->jack.jack, SND_JACK_BTN_0, KEY_PLAYPAUSE); + snd_jack_set_key(accdet->jack.jack, SND_JACK_BTN_1, KEY_VOLUMEDOWN); + snd_jack_set_key(accdet->jack.jack, SND_JACK_BTN_2, KEY_VOLUMEUP); + snd_jack_set_key(accdet->jack.jack, SND_JACK_BTN_3, KEY_VOICECOMMAND); + + return ret; +} +EXPORT_SYMBOL_GPL(mt6359_accdet_init); + +int mt6359_accdet_set_drvdata(struct snd_soc_card *card) +{ + snd_soc_card_set_drvdata(card, accdet); + + return 0; +} +EXPORT_SYMBOL_GPL(mt6359_accdet_set_drvdata); + +static int mt6359_accdet_probe(struct platform_device *pdev) +{ + int ret = 0; + struct resource *res; + struct mt6397_chip *mt6397_chip = dev_get_drvdata(pdev->dev.parent); + const struct of_device_id *of_id = + of_match_device(mt6359_accdet_of_match, &pdev->dev); + if (!of_id) { + dev_err(&pdev->dev, "Error: No device match found\n"); + return -ENODEV; + } + + accdet = devm_kzalloc(&pdev->dev, sizeof(*accdet), GFP_KERNEL); + if (!accdet) + return -ENOMEM; + + accdet->data = (struct accdet_priv *)of_id->data; + accdet->pdev = pdev; + + /* parse dts attributes */ + ret = mt6359_accdet_parse_dt(); + if (ret) { + dev_err(&pdev->dev, "Error: Get dts data failed (%d)\n", ret); + return ret; + } + /* init lock */ + accdet->wake_lock = wakeup_source_register(NULL, "accdet_wake_lock"); + if (!accdet->wake_lock) { + dev_err(&pdev->dev, "Error: get accdet_wake_lock fail\n"); + return -ENOMEM; + } + accdet->timer_lock = wakeup_source_register(NULL, "accdet_timer_lock"); + if (!accdet->timer_lock) { + dev_err(&pdev->dev, "Error: get accdet_timer_lock fail\n"); + return -ENOMEM; + } + mutex_init(&accdet->res_lock); + + platform_set_drvdata(pdev, accdet); + ret = devm_snd_soc_register_component(&pdev->dev, + &mt6359_accdet_soc_driver, + NULL, 0); + if (ret) { + dev_err(&pdev->dev, "Error: register component fail\n"); + return ret; + } + res = platform_get_resource(pdev, IORESOURCE_MEM, 0); + accdet->regmap = mt6397_chip->regmap; + accdet->dev = &pdev->dev; + accdet->auxadc_offset = 0; + + /* register pmic interrupt */ + accdet->accdet_irq = platform_get_irq(pdev, 0); + if (accdet->accdet_irq < 0) { + dev_err(&pdev->dev, + "Error: Get accdet irq failed (%d)\n", + accdet->accdet_irq); + return accdet->accdet_irq; + } + ret = devm_request_threaded_irq(&pdev->dev, accdet->accdet_irq, + NULL, mtk_accdet_irq_handler_thread, + IRQF_TRIGGER_HIGH | IRQF_ONESHOT, + "ACCDET_IRQ", accdet); + if (ret) { + dev_err(&pdev->dev, + "Error: Get thread irq request failed (%d) (%d)\n", + accdet->accdet_irq, ret); + return ret; + } + + if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT0)) { + accdet->accdet_eint0 = platform_get_irq(pdev, 1); + if (accdet->accdet_eint0 < 0) { + dev_err(&pdev->dev, + "Error: Get eint0 irq failed (%d)\n", + accdet->accdet_eint0); + return accdet->accdet_eint0; + } + ret = devm_request_threaded_irq(&pdev->dev, + accdet->accdet_eint0, + NULL, mtk_accdet_irq_handler_thread, + IRQF_TRIGGER_HIGH | IRQF_ONESHOT, + "ACCDET_EINT0", accdet); + if (ret) { + dev_err(&pdev->dev, + "Error: Get eint0 irq request failed (%d)\n", + ret); + return ret; + } + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_EINT1)) { + accdet->accdet_eint1 = platform_get_irq(pdev, 2); + if (accdet->accdet_eint1 < 0) { + dev_err(&pdev->dev, + "Error: Get eint1 irq failed (%d)\n", + accdet->accdet_eint1); + return accdet->accdet_eint1; + } + ret = devm_request_threaded_irq(&pdev->dev, + accdet->accdet_eint1, + NULL, + mtk_accdet_irq_handler_thread, + IRQF_TRIGGER_HIGH | IRQF_ONESHOT, + "ACCDET_EINT1", accdet); + if (ret) { + dev_err(&pdev->dev, + "Error: Get eint1 irq request failed (%d)\n", + ret); + return ret; + } + } else if (HAS_CAP(accdet->data->caps, ACCDET_PMIC_BI_EINT)) { + accdet->accdet_eint0 = platform_get_irq(pdev, 1); + if (accdet->accdet_eint0 < 0) { + dev_err(&pdev->dev, + "Error: Get eint0 irq failed (%d)\n", + accdet->accdet_eint0); + return accdet->accdet_eint0; + } + ret = devm_request_threaded_irq(&pdev->dev, + accdet->accdet_eint0, + NULL, + mtk_accdet_irq_handler_thread, + IRQF_TRIGGER_HIGH | IRQF_ONESHOT, + "ACCDET_EINT0", accdet); + if (ret) { + dev_err(&pdev->dev, + "Error: Get eint0 irq request failed (%d)\n", + ret); + return ret; + } + accdet->accdet_eint1 = platform_get_irq(pdev, 2); + if (accdet->accdet_eint1 < 0) { + dev_err(&pdev->dev, + "Error: Get eint1 irq failed (%d)\n", + accdet->accdet_eint1); + return accdet->accdet_eint1; + } + ret = devm_request_threaded_irq(&pdev->dev, + accdet->accdet_eint1, + NULL, + mtk_accdet_irq_handler_thread, + IRQF_TRIGGER_HIGH | IRQF_ONESHOT, + "ACCDET_EINT1", accdet); + if (ret) { + dev_err(&pdev->dev, + "Error: Get eint1 irq request failed (%d)\n", + ret); + return ret; + } + } + + /* setup timer */ + timer_setup(&micbias_timer, dis_micbias_timerhandler, 0); + micbias_timer.expires = jiffies + MICBIAS_DISABLE_TIMER; + timer_setup(&accdet_init_timer, delay_init_timerhandler, 0); + accdet_init_timer.expires = jiffies + ACCDET_INIT_WAIT_TIMER; + + /* Create workqueue */ + accdet->delay_init_workqueue = + create_singlethread_workqueue("delay_init"); + INIT_WORK(&accdet->delay_init_work, delay_init_work_callback); + if (!accdet->delay_init_workqueue) { + dev_err(&pdev->dev, "Error: Create dinit workqueue failed\n"); + ret = -1; + goto err_delay_init_wq; + } + accdet->accdet_workqueue = create_singlethread_workqueue("accdet"); + INIT_WORK(&accdet->accdet_work, accdet_work_callback); + if (!accdet->accdet_workqueue) { + dev_err(&pdev->dev, "Error: Create accdet workqueue failed\n"); + ret = -1; + goto err_accdet_wq; + } + + accdet->dis_micbias_workqueue = + create_singlethread_workqueue("dismicQueue"); + INIT_WORK(&accdet->dis_micbias_work, dis_micbias_work_callback); + if (!accdet->dis_micbias_workqueue) { + dev_err(&pdev->dev, "Error: Create dismic workqueue failed\n"); + ret = -1; + goto err_dis_micbias_wq; + } + accdet->eint_workqueue = create_singlethread_workqueue("accdet_eint"); + INIT_WORK(&accdet->eint_work, eint_work_callback); + if (!accdet->eint_workqueue) { + dev_err(&pdev->dev, "Error: Create eint workqueue failed\n"); + ret = -1; + goto err_eint_wq; + } + if (HAS_CAP(accdet->data->caps, ACCDET_AP_GPIO_EINT)) { + accdet->accdet_eint_type = IRQ_TYPE_LEVEL_LOW; + ret = ext_eint_setup(pdev); + if (ret) + destroy_workqueue(accdet->eint_workqueue); + } + + atomic_set(&accdet->init_once, 1); + mod_timer(&accdet_init_timer, (jiffies + ACCDET_INIT_WAIT_TIMER)); + + return 0; + +err_eint_wq: + destroy_workqueue(accdet->dis_micbias_workqueue); +err_dis_micbias_wq: + destroy_workqueue(accdet->accdet_workqueue); +err_accdet_wq: + destroy_workqueue(accdet->delay_init_workqueue); +err_delay_init_wq: + pr_notice("%s error. now exit.!\n", __func__); + return ret; +} + +static int mt6359_accdet_remove(struct platform_device *pdev) +{ + destroy_workqueue(accdet->eint_workqueue); + destroy_workqueue(accdet->dis_micbias_workqueue); + destroy_workqueue(accdet->accdet_workqueue); + destroy_workqueue(accdet->delay_init_workqueue); + devm_kfree(&pdev->dev, accdet); + return 0; +} + +static struct platform_driver mt6359_accdet_driver = { + .probe = mt6359_accdet_probe, + .remove = mt6359_accdet_remove, + .driver = { + .name = "pmic-codec-accdet", + .of_match_table = mt6359_accdet_of_match, + }, +}; + +static int __init mt6359_accdet_soc_init(void) +{ + int ret = 0; + + ret = platform_driver_register(&mt6359_accdet_driver); + if (ret) + return -ENODEV; + return 0; +} + +static void __exit mt6359_accdet_soc_exit(void) +{ + platform_driver_unregister(&mt6359_accdet_driver); +} +module_init(mt6359_accdet_soc_init); +module_exit(mt6359_accdet_soc_exit); + +/* Module information */ +MODULE_DESCRIPTION("MT6359 ALSA SoC accdet driver"); +MODULE_AUTHOR("Argus Lin <argus.lin@mediatek.com>"); +MODULE_LICENSE("GPL v2"); diff --git a/sound/soc/codecs/mt6359-accdet.h b/sound/soc/codecs/mt6359-accdet.h new file mode 100644 index 0000000..d081d69 --- /dev/null +++ b/sound/soc/codecs/mt6359-accdet.h @@ -0,0 +1,136 @@ +/* SPDX-License-Identifier: GPL-2.0 */ +/* + * Copyright (C) 2021 MediaTek Inc. + * Author: Argus Lin <argus.lin@mediatek.com> + */ + +#ifndef _ACCDET_H_ +#define _ACCDET_H_ + +#include <linux/ctype.h> +#include <linux/string.h> + +#define ACCDET_DEVNAME "accdet" +/* SW ENV define */ +#define NO_KEY (0x0) +#define UP_KEY (0x01) +#define MD_KEY (0x02) +#define DW_KEY (0x04) +#define AS_KEY (0x08) + +#define HEADSET_MODE_1 (1) +#define HEADSET_MODE_2 (2) +#define HEADSET_MODE_6 (6) + +/* IOCTL */ +#define ACCDET_IOC_MAGIC 'A' +#define ACCDET_INIT _IO(ACCDET_IOC_MAGIC, 0) +#define SET_CALL_STATE _IO(ACCDET_IOC_MAGIC, 1) +#define GET_BUTTON_STATUS _IO(ACCDET_IOC_MAGIC, 2) + +/* 400us, Accdet irq clear timeout */ +#define ACCDET_TIME_OUT 0x61A80 + +/* cable type recognized by accdet, and report to WiredAccessoryManager */ +enum accdet_report_state { + NO_DEVICE = 0, + HEADSET_MIC = 1, + HEADSET_NO_MIC = 2, + HEADSET_FIVE_POLE = 3, + LINE_OUT_DEVICE = 4, +}; + +/* accdet status got from accdet FSM */ +enum accdet_status { + PLUG_OUT = 0, + MIC_BIAS = 1, + HOOK_SWITCH = 2, + BI_MIC_BIAS = 3, + LINE_OUT = 4, + STAND_BY = 5 +}; + +enum accdet_eint_ID { + NO_PMIC_EINT = 0, + PMIC_EINT0 = 1, + PMIC_EINT1 = 2, + PMIC_BIEINT = 3, +}; + +/* EINT state when moisture enable */ +enum eint_moisture_status { + M_PLUG_IN = 0, + M_WATER_IN = 1, + M_HP_PLUG_IN = 2, + M_PLUG_OUT = 3, + M_NO_ACT = 4, + M_UNKNOWN = 5, +}; + +struct three_key_threshold { + unsigned int mid; + unsigned int up; + unsigned int down; +}; + +struct four_key_threshold { + unsigned int mid; + unsigned int voice; + unsigned int up; + unsigned int down; +}; + +struct pwm_deb_settings { + unsigned int pwm_width; + unsigned int pwm_thresh; + unsigned int fall_delay; + unsigned int rise_delay; + unsigned int debounce0; + unsigned int debounce1; + unsigned int debounce3; + unsigned int debounce4; + unsigned int eint_pwm_width; + unsigned int eint_pwm_thresh; + unsigned int eint_debounce0; + unsigned int eint_debounce1; + unsigned int eint_debounce2; + unsigned int eint_debounce3; + unsigned int eint_inverter_debounce; + +}; + +struct head_dts_data { + unsigned int mic_vol; + unsigned int mic_mode; + unsigned int plugout_deb; + unsigned int eint_pol; + struct pwm_deb_settings pwm_deb; + struct three_key_threshold three_key; + struct four_key_threshold four_key; + unsigned int moisture_detect_enable; + unsigned int eint_detect_mode; + unsigned int eint_use_ext_res; + unsigned int moisture_detect_mode; + unsigned int moisture_comp_vth; + unsigned int moisture_comp_vref2; + unsigned int moisture_use_ext_res; +}; + +enum { + accdet_state000 = 0, + accdet_state001, + accdet_state010, + accdet_state011, + accdet_auxadc, + eint_state000, + eint_state001, + eint_state010, + eint_state011, + eint_inverter_state000, +}; + +/* just be called by audio module for DC trim */ +void mt6359_accdet_late_init(unsigned long data); +int mt6359_accdet_init(struct snd_soc_component *component, struct snd_soc_card *card); +int mt6359_accdet_set_drvdata(struct snd_soc_card *card); +#endif diff --git a/sound/soc/codecs/mt6359.h b/sound/soc/codecs/mt6359.h index 35f806b..9f9a94a 100644 --- a/sound/soc/codecs/mt6359.h +++ b/sound/soc/codecs/mt6359.h @@ -8,128 +8,1779 @@ #define _MT6359_H_ /*************Register Bit Define*************/ -#define PMIC_ACCDET_IRQ_SHIFT 0 -#define PMIC_ACCDET_EINT0_IRQ_SHIFT 2 -#define PMIC_ACCDET_EINT1_IRQ_SHIFT 3 -#define PMIC_ACCDET_IRQ_CLR_SHIFT 8 -#define PMIC_ACCDET_EINT0_IRQ_CLR_SHIFT 10 -#define PMIC_ACCDET_EINT1_IRQ_CLR_SHIFT 11 -#define PMIC_RG_INT_STATUS_ACCDET_SHIFT 5 -#define PMIC_RG_INT_STATUS_ACCDET_EINT0_SHIFT 6 -#define PMIC_RG_INT_STATUS_ACCDET_EINT1_SHIFT 7 -#define PMIC_RG_EINT0CONFIGACCDET_SHIFT 11 -#define PMIC_RG_EINT1CONFIGACCDET_SHIFT 0 -#define PMIC_ACCDET_EINT0_INVERTER_SW_EN_SHIFT 6 -#define PMIC_ACCDET_EINT1_INVERTER_SW_EN_SHIFT 8 -#define PMIC_RG_MTEST_EN_SHIFT 8 -#define PMIC_RG_MTEST_SEL_SHIFT 9 -#define PMIC_ACCDET_EINT0_M_SW_EN_SHIFT 10 -#define PMIC_ACCDET_EINT1_M_SW_EN_SHIFT 11 -#define PMIC_ACCDET_EINT0_CEN_STABLE_SHIFT 5 -#define PMIC_ACCDET_EINT1_CEN_STABLE_SHIFT 10 -#define PMIC_ACCDET_DA_STABLE_SHIFT 0 -#define PMIC_ACCDET_EINT0_EN_STABLE_SHIFT 1 -#define PMIC_ACCDET_EINT0_CMPEN_STABLE_SHIFT 2 -#define PMIC_ACCDET_EINT1_EN_STABLE_SHIFT 6 -#define PMIC_ACCDET_EINT1_CMPEN_STABLE_SHIFT 7 -#define PMIC_ACCDET_EINT_CTURBO_SEL_SHIFT 7 -#define PMIC_ACCDET_EINT0_CTURBO_SW_SHIFT 7 -#define PMIC_RG_EINTCOMPVTH_SHIFT 4 -#define PMIC_RG_EINT0HIRENB_SHIFT 12 -#define PMIC_RG_EINT0NOHYS_SHIFT 10 -#define PMIC_ACCDET_SW_EN_SHIFT 0 -#define PMIC_ACCDET_EINT0_MEM_IN_SHIFT 6 -#define PMIC_ACCDET_MEM_IN_SHIFT 6 -#define PMIC_ACCDET_EINT_DEBOUNCE0_SHIFT 0 -#define PMIC_ACCDET_EINT_DEBOUNCE1_SHIFT 4 -#define PMIC_ACCDET_EINT_DEBOUNCE2_SHIFT 8 -#define PMIC_ACCDET_EINT_DEBOUNCE3_SHIFT 12 -#define PMIC_RG_ACCDET2AUXSWEN_SHIFT 14 -#define PMIC_AUDACCDETAUXADCSWCTRL_SEL_SHIFT 9 -#define PMIC_AUDACCDETAUXADCSWCTRL_SW_SHIFT 10 -#define PMIC_RG_EINT0CTURBO_SHIFT 5 -#define PMIC_RG_EINT1CTURBO_SHIFT 13 -#define PMIC_ACCDET_EINT_M_PLUG_IN_NUM_SHIFT 12 -#define PMIC_ACCDET_EINT_M_DETECT_EN_SHIFT 12 -#define PMIC_ACCDET_EINT0_SW_EN_SHIFT 2 -#define PMIC_ACCDET_EINT1_SW_EN_SHIFT 4 -#define PMIC_ACCDET_EINT_CMPMOUT_SEL_SHIFT 12 -#define PMIC_ACCDET_EINT_CMPMEN_SEL_SHIFT 6 -#define PMIC_RG_HPLOUTPUTSTBENH_VAUDP32_SHIFT 0 -#define PMIC_RG_HPROUTPUTSTBENH_VAUDP32_SHIFT 4 -#define PMIC_RG_EINT0EN_SHIFT 2 -#define PMIC_RG_EINT1EN_SHIFT 10 -#define PMIC_RG_NCP_PDDIS_EN_SHIFT 0 -#define PMIC_RG_ACCDETSPARE_SHIFT 0 -#define PMIC_RG_ACCDET_RST_SHIFT 1 -#define PMIC_RG_AUDMICBIAS1HVEN_SHIFT 12 -#define PMIC_RG_AUDMICBIAS1VREF_SHIFT 4 -#define PMIC_RG_ANALOGFDEN_SHIFT 12 -#define PMIC_RG_AUDMICBIAS1DCSW1PEN_SHIFT 8 -#define PMIC_RG_AUDMICBIAS1LOWPEN_SHIFT 2 -#define PMIC_ACCDET_SEQ_INIT_SHIFT 1 -#define PMIC_RG_EINTCOMPVTH_MASK 0xf -#define PMIC_ACCDET_EINT0_MEM_IN_MASK 0x3 -#define PMIC_ACCDET_EINT_DEBOUNCE0_MASK 0xf -#define PMIC_ACCDET_EINT_DEBOUNCE1_MASK 0xf -#define PMIC_ACCDET_EINT_DEBOUNCE2_MASK 0xf -#define PMIC_ACCDET_EINT_DEBOUNCE3_MASK 0xf -#define PMIC_ACCDET_EINT0_IRQ_SHIFT 2 -#define PMIC_ACCDET_EINT1_IRQ_SHIFT 3 - -/* AUDENC_ANA_CON16: */ -#define RG_AUD_MICBIAS1_LOWP_EN BIT(PMIC_RG_AUDMICBIAS1LOWPEN_SHIFT) - +#define MT6359_TOP0_ID 0x0 +#define MT6359_SMT_CON1 0x32 +#define MT6359_DRV_CON2 0x3c +#define MT6359_DRV_CON3 0x3e +#define MT6359_DRV_CON4 0x40 +#define MT6359_TOP_CKPDN_CON0 0x10c +#define MT6359_TOP_CKPDN_CON0_SET 0x10e +#define MT6359_TOP_CKPDN_CON0_CLR 0x110 +#define MT6359_AUXADC_RQST0 0x1108 +#define MT6359_AUXADC_CON10 0x11a0 +#define MT6359_AUXADC_ACCDET 0x11ba +#define MT6359_LDO_VUSB_OP_EN 0x1d0c +#define MT6359_LDO_VUSB_OP_EN_SET 0x1d0e +#define MT6359_LDO_VUSB_OP_EN_CLR 0x1d10 +#define MT6359_AUD_TOP_CKPDN_CON0 0x230c +#define MT6359_AUD_TOP_CKPDN_CON0_SET 0x230e +#define MT6359_AUD_TOP_CKPDN_CON0_CLR 0x2310 +#define MT6359_AUD_TOP_RST_CON0 0x2320 +#define MT6359_AUD_TOP_RST_CON0_SET 0x2322 +#define MT6359_AUD_TOP_RST_CON0_CLR 0x2324 +#define MT6359_AUD_TOP_INT_CON0 0x2328 +#define MT6359_AUD_TOP_INT_CON0_SET 0x232a +#define MT6359_AUD_TOP_INT_CON0_CLR 0x232c +#define MT6359_AUD_TOP_INT_MASK_CON0 0x232e +#define MT6359_AUD_TOP_INT_MASK_CON0_SET 0x2330 +#define MT6359_AUD_TOP_INT_MASK_CON0_CLR 0x2332 +#define MT6359_AUD_TOP_INT_STATUS0 0x2334 +#define MT6359_AFE_NCP_CFG2 0x24e2 +#define MT6359_AUDENC_DSN_ID 0x2500 +#define MT6359_AUDENC_DSN_REV0 0x2502 +#define MT6359_AUDENC_DSN_DBI 0x2504 +#define MT6359_AUDENC_DSN_FPI 0x2506 +#define MT6359_AUDENC_ANA_CON0 0x2508 +#define MT6359_AUDENC_ANA_CON1 0x250a +#define MT6359_AUDENC_ANA_CON2 0x250c +#define MT6359_AUDENC_ANA_CON3 0x250e +#define MT6359_AUDENC_ANA_CON4 0x2510 +#define MT6359_AUDENC_ANA_CON5 0x2512 +#define MT6359_AUDENC_ANA_CON6 0x2514 +#define MT6359_AUDENC_ANA_CON7 0x2516 +#define MT6359_AUDENC_ANA_CON8 0x2518 +#define MT6359_AUDENC_ANA_CON9 0x251a +#define MT6359_AUDENC_ANA_CON10 0x251c +#define MT6359_AUDENC_ANA_CON11 0x251e +#define MT6359_AUDENC_ANA_CON12 0x2520 +#define MT6359_AUDENC_ANA_CON13 0x2522 +#define MT6359_AUDENC_ANA_CON14 0x2524 +#define MT6359_AUDENC_ANA_CON15 0x2526 +#define MT6359_AUDENC_ANA_CON16 0x2528 +#define MT6359_AUDENC_ANA_CON17 0x252a +#define MT6359_AUDENC_ANA_CON18 0x252c +#define MT6359_AUDENC_ANA_CON19 0x252e +#define MT6359_AUDENC_ANA_CON20 0x2530 +#define MT6359_AUDENC_ANA_CON21 0x2532 +#define MT6359_AUDENC_ANA_CON22 0x2534 +#define MT6359_AUDENC_ANA_CON23 0x2536 +#define MT6359_AUDDEC_DSN_ID 0x2580 +#define MT6359_AUDDEC_DSN_REV0 0x2582 +#define MT6359_AUDDEC_DSN_DBI 0x2584 +#define MT6359_AUDDEC_DSN_FPI 0x2586 +#define MT6359_AUDDEC_ANA_CON0 0x2588 +#define MT6359_AUDDEC_ANA_CON1 0x258a +#define MT6359_AUDDEC_ANA_CON2 0x258c +#define MT6359_AUDDEC_ANA_CON3 0x258e +#define MT6359_AUDDEC_ANA_CON4 0x2590 +#define MT6359_AUDDEC_ANA_CON5 0x2592 +#define MT6359_AUDDEC_ANA_CON6 0x2594 +#define MT6359_AUDDEC_ANA_CON7 0x2596 +#define MT6359_AUDDEC_ANA_CON8 0x2598 +#define MT6359_AUDDEC_ANA_CON9 0x259a +#define MT6359_AUDDEC_ANA_CON10 0x259c +#define MT6359_AUDDEC_ANA_CON11 0x259e +#define MT6359_AUDDEC_ANA_CON12 0x25a0 +#define MT6359_AUDDEC_ANA_CON13 0x25a2 +#define MT6359_AUDDEC_ANA_CON14 0x25a4 +#define MT6359_ACCDET_DSN_DIG_ID 0x2680 +#define MT6359_ACCDET_DSN_DIG_REV0 0x2682 +#define MT6359_ACCDET_DSN_DBI 0x2684 +#define MT6359_ACCDET_DSN_FPI 0x2686 +#define MT6359_ACCDET_CON0 0x2688 +#define MT6359_ACCDET_CON1 0x268a +#define MT6359_ACCDET_CON2 0x268c +#define MT6359_ACCDET_CON3 0x268e +#define MT6359_ACCDET_CON4 0x2690 +#define MT6359_ACCDET_CON5 0x2692 +#define MT6359_ACCDET_CON6 0x2694 +#define MT6359_ACCDET_CON7 0x2696 +#define MT6359_ACCDET_CON8 0x2698 +#define MT6359_ACCDET_CON9 0x269a +#define MT6359_ACCDET_CON10 0x269c +#define MT6359_ACCDET_CON11 0x269e +#define MT6359_ACCDET_CON12 0x26a0 +#define MT6359_ACCDET_CON13 0x26a2 +#define MT6359_ACCDET_CON14 0x26a4 +#define MT6359_ACCDET_CON15 0x26a6 +#define MT6359_ACCDET_CON16 0x26a8 +#define MT6359_ACCDET_CON17 0x26aa +#define MT6359_ACCDET_CON18 0x26ac +#define MT6359_ACCDET_CON19 0x26ae +#define MT6359_ACCDET_CON20 0x26b0 +#define MT6359_ACCDET_CON21 0x26b2 +#define MT6359_ACCDET_CON22 0x26b4 +#define MT6359_ACCDET_CON23 0x26b6 +#define MT6359_ACCDET_CON24 0x26b8 +#define MT6359_ACCDET_CON25 0x26ba +#define MT6359_ACCDET_CON26 0x26bc +#define MT6359_ACCDET_CON27 0x26be +#define MT6359_ACCDET_CON28 0x26c0 +#define MT6359_ACCDET_CON29 0x26c2 +#define MT6359_ACCDET_CON30 0x26c4 +#define MT6359_ACCDET_CON31 0x26c6 +#define MT6359_ACCDET_CON32 0x26c8 +#define MT6359_ACCDET_CON33 0x26ca +#define MT6359_ACCDET_CON34 0x26cc +#define MT6359_ACCDET_CON35 0x26ce +#define MT6359_ACCDET_CON36 0x26d0 +#define MT6359_ACCDET_CON37 0x26d2 +#define MT6359_ACCDET_CON38 0x26d4 +#define MT6359_ACCDET_CON39 0x26d6 +#define MT6359_ACCDET_CON40 0x26d8 + +#define TOP0_ANA_ID_ADDR \ + MT6359_TOP0_ID +#define TOP0_ANA_ID_SFT 0 +#define TOP0_ANA_ID_MASK 0xFF +#define TOP0_ANA_ID_MASK_SFT (0xFF << 0) +#define AUXADC_RQST_CH0_ADDR \ + MT6359_AUXADC_RQST0 +#define AUXADC_RQST_CH0_SFT 0 +#define AUXADC_RQST_CH0_MASK 0x1 +#define AUXADC_RQST_CH0_MASK_SFT (0x1 << 0) +#define AUXADC_ACCDET_ANASWCTRL_EN_ADDR \ + MT6359_AUXADC_CON15 +#define AUXADC_ACCDET_ANASWCTRL_EN_SFT 6 +#define AUXADC_ACCDET_ANASWCTRL_EN_MASK 0x1 +#define AUXADC_ACCDET_ANASWCTRL_EN_MASK_SFT (0x1 << 6) + +#define AUXADC_ACCDET_AUTO_SPL_ADDR \ + MT6359_AUXADC_ACCDET +#define AUXADC_ACCDET_AUTO_SPL_SFT 0 +#define AUXADC_ACCDET_AUTO_SPL_MASK 0x1 +#define AUXADC_ACCDET_AUTO_SPL_MASK_SFT (0x1 << 0) +#define AUXADC_ACCDET_AUTO_RQST_CLR_ADDR \ + MT6359_AUXADC_ACCDET +#define AUXADC_ACCDET_AUTO_RQST_CLR_SFT 1 +#define AUXADC_ACCDET_AUTO_RQST_CLR_MASK 0x1 +#define AUXADC_ACCDET_AUTO_RQST_CLR_MASK_SFT (0x1 << 1) +#define AUXADC_ACCDET_DIG1_RSV0_ADDR \ + MT6359_AUXADC_ACCDET +#define AUXADC_ACCDET_DIG1_RSV0_SFT 2 +#define AUXADC_ACCDET_DIG1_RSV0_MASK 0x3F +#define AUXADC_ACCDET_DIG1_RSV0_MASK_SFT (0x3F << 2) +#define AUXADC_ACCDET_DIG0_RSV0_ADDR \ + MT6359_AUXADC_ACCDET +#define AUXADC_ACCDET_DIG0_RSV0_SFT 8 +#define AUXADC_ACCDET_DIG0_RSV0_MASK 0xFF +#define AUXADC_ACCDET_DIG0_RSV0_MASK_SFT (0xFF << 8) + +#define RG_ACCDET_CK_PDN_ADDR \ + MT6359_AUD_TOP_CKPDN_CON0 +#define RG_ACCDET_CK_PDN_SFT 0 +#define RG_ACCDET_CK_PDN_MASK 0x1 +#define RG_ACCDET_CK_PDN_MASK_SFT (0x1 << 0) + +#define RG_ACCDET_RST_ADDR \ + MT6359_AUD_TOP_RST_CON0 +#define RG_ACCDET_RST_SFT 1 +#define RG_ACCDET_RST_MASK 0x1 +#define RG_ACCDET_RST_MASK_SFT (0x1 << 1) +#define BANK_ACCDET_SWRST_ADDR \ + MT6359_AUD_TOP_RST_BANK_CON0 +#define BANK_ACCDET_SWRST_SFT 0 +#define BANK_ACCDET_SWRST_MASK 0x1 +#define BANK_ACCDET_SWRST_MASK_SFT (0x1 << 0) + +#define RG_INT_EN_ACCDET_ADDR \ + MT6359_AUD_TOP_INT_CON0 +#define RG_INT_EN_ACCDET_SFT 5 +#define RG_INT_EN_ACCDET_MASK 0x1 +#define RG_INT_EN_ACCDET_MASK_SFT (0x1 << 5) +#define RG_INT_EN_ACCDET_EINT0_ADDR \ + MT6359_AUD_TOP_INT_CON0 +#define RG_INT_EN_ACCDET_EINT0_SFT 6 +#define RG_INT_EN_ACCDET_EINT0_MASK 0x1 +#define RG_INT_EN_ACCDET_EINT0_MASK_SFT (0x1 << 6) +#define RG_INT_EN_ACCDET_EINT1_ADDR \ + MT6359_AUD_TOP_INT_CON0 +#define RG_INT_EN_ACCDET_EINT1_SFT 7 +#define RG_INT_EN_ACCDET_EINT1_MASK 0x1 +#define RG_INT_EN_ACCDET_EINT1_MASK_SFT (0x1 << 7) + +#define RG_INT_MASK_ACCDET_ADDR \ + MT6359_AUD_TOP_INT_MASK_CON0 +#define RG_INT_MASK_ACCDET_SFT 5 +#define RG_INT_MASK_ACCDET_MASK 0x1 +#define RG_INT_MASK_ACCDET_MASK_SFT (0x1 << 5) +#define RG_INT_MASK_ACCDET_EINT0_ADDR \ + MT6359_AUD_TOP_INT_MASK_CON0 +#define RG_INT_MASK_ACCDET_EINT0_SFT 6 +#define RG_INT_MASK_ACCDET_EINT0_MASK 0x1 +#define RG_INT_MASK_ACCDET_EINT0_MASK_SFT (0x1 << 6) +#define RG_INT_MASK_ACCDET_EINT1_ADDR \ + MT6359_AUD_TOP_INT_MASK_CON0 +#define RG_INT_MASK_ACCDET_EINT1_SFT 7 +#define RG_INT_MASK_ACCDET_EINT1_MASK 0x1 +#define RG_INT_MASK_ACCDET_EINT1_MASK_SFT (0x1 << 7) + +#define RG_INT_STATUS_ACCDET_ADDR \ + MT6359_AUD_TOP_INT_STATUS0 +#define RG_INT_STATUS_ACCDET_SFT 5 +#define RG_INT_STATUS_ACCDET_MASK 0x1 +#define RG_INT_STATUS_ACCDET_MASK_SFT (0x1 << 5) +#define RG_INT_STATUS_ACCDET_EINT0_ADDR \ + MT6359_AUD_TOP_INT_STATUS0 +#define RG_INT_STATUS_ACCDET_EINT0_SFT 6 +#define RG_INT_STATUS_ACCDET_EINT0_MASK 0x1 +#define RG_INT_STATUS_ACCDET_EINT0_MASK_SFT (0x1 << 6) +#define RG_INT_STATUS_ACCDET_EINT1_ADDR \ + MT6359_AUD_TOP_INT_STATUS0 +#define RG_INT_STATUS_ACCDET_EINT1_SFT 7 +#define RG_INT_STATUS_ACCDET_EINT1_MASK 0x1 +#define RG_INT_STATUS_ACCDET_EINT1_MASK_SFT (0x1 << 7) + +#define RG_INT_RAW_STATUS_ACCDET_ADDR \ + MT6359_AUD_TOP_INT_RAW_STATUS0 +#define RG_INT_RAW_STATUS_ACCDET_SFT 5 +#define RG_INT_RAW_STATUS_ACCDET_MASK 0x1 +#define RG_INT_RAW_STATUS_ACCDET_MASK_SFT (0x1 << 5) +#define RG_INT_RAW_STATUS_ACCDET_EINT0_ADDR \ + MT6359_AUD_TOP_INT_RAW_STATUS0 +#define RG_INT_RAW_STATUS_ACCDET_EINT0_SFT 6 +#define RG_INT_RAW_STATUS_ACCDET_EINT0_MASK 0x1 +#define RG_INT_RAW_STATUS_ACCDET_EINT0_MASK_SFT (0x1 << 6) +#define RG_INT_RAW_STATUS_ACCDET_EINT1_ADDR \ + MT6359_AUD_TOP_INT_RAW_STATUS0 +#define RG_INT_RAW_STATUS_ACCDET_EINT1_SFT 7 +#define RG_INT_RAW_STATUS_ACCDET_EINT1_MASK 0x1 +#define RG_INT_RAW_STATUS_ACCDET_EINT1_MASK_SFT (0x1 << 7) + +#define RG_AUDACCDETMICBIAS0PULLLOW_ADDR \ + MT6359_AUDENC_ANA_CON18 +#define RG_AUDACCDETMICBIAS0PULLLOW_SFT 0 +#define RG_AUDACCDETMICBIAS0PULLLOW_MASK 0x1 +#define RG_AUDACCDETMICBIAS0PULLLOW_MASK_SFT (0x1 << 0) +#define RG_AUDACCDETMICBIAS1PULLLOW_ADDR \ + MT6359_AUDENC_ANA_CON18 +#define RG_AUDACCDETMICBIAS1PULLLOW_SFT 1 +#define RG_AUDACCDETMICBIAS1PULLLOW_MASK 0x1 +#define RG_AUDACCDETMICBIAS1PULLLOW_MASK_SFT (0x1 << 1) +#define RG_AUDACCDETMICBIAS2PULLLOW_ADDR \ + MT6359_AUDENC_ANA_CON18 +#define RG_AUDACCDETMICBIAS2PULLLOW_SFT 2 +#define RG_AUDACCDETMICBIAS2PULLLOW_MASK 0x1 +#define RG_AUDACCDETMICBIAS2PULLLOW_MASK_SFT (0x1 << 2) +#define RG_AUDACCDETVIN1PULLLOW_ADDR \ + MT6359_AUDENC_ANA_CON18 +#define RG_AUDACCDETVIN1PULLLOW_SFT 3 +#define RG_AUDACCDETVIN1PULLLOW_MASK 0x1 +#define RG_AUDACCDETVIN1PULLLOW_MASK_SFT (0x1 << 3) +#define RG_AUDACCDETVTHACAL_ADDR \ + MT6359_AUDENC_ANA_CON18 +#define RG_AUDACCDETVTHACAL_SFT 4 +#define RG_AUDACCDETVTHACAL_MASK 0x1 +#define RG_AUDACCDETVTHACAL_MASK_SFT (0x1 << 4) +#define RG_AUDACCDETVTHBCAL_ADDR \ + MT6359_AUDENC_ANA_CON18 +#define RG_AUDACCDETVTHBCAL_SFT 5 +#define RG_AUDACCDETVTHBCAL_MASK 0x1 +#define RG_AUDACCDETVTHBCAL_MASK_SFT (0x1 << 5) +#define RG_AUDACCDETTVDET_ADDR \ + MT6359_AUDENC_ANA_CON18 +#define RG_AUDACCDETTVDET_SFT 6 +#define RG_AUDACCDETTVDET_MASK 0x1 +#define RG_AUDACCDETTVDET_MASK_SFT (0x1 << 6) +#define RG_ACCDETSEL_ADDR \ + MT6359_AUDENC_ANA_CON18 +#define RG_ACCDETSEL_SFT 7 +#define RG_ACCDETSEL_MASK 0x1 +#define RG_ACCDETSEL_MASK_SFT (0x1 << 7) + +#define RG_AUDPWDBMICBIAS1_ADDR \ + MT6359_AUDENC_ANA_CON16 +#define RG_AUDPWDBMICBIAS1_SFT 0 +#define RG_AUDPWDBMICBIAS1_MASK 0x1 +#define RG_AUDPWDBMICBIAS1_MASK_SFT (0x1 << 0) +#define RG_AUDMICBIAS1BYPASSEN_ADDR \ + MT6359_AUDENC_ANA_CON16 +#define RG_AUDMICBIAS1BYPASSEN_SFT 1 +#define RG_AUDMICBIAS1BYPASSEN_MASK 0x1 +#define RG_AUDMICBIAS1BYPASSEN_MASK_SFT (0x1 << 1) +#define RG_AUDMICBIAS1LOWPEN_ADDR \ + MT6359_AUDENC_ANA_CON16 +#define RG_AUDMICBIAS1LOWPEN_SFT 2 +#define RG_AUDMICBIAS1LOWPEN_MASK 0x1 +#define RG_AUDMICBIAS1LOWPEN_MASK_SFT (0x1 << 2) +#define RG_AUDMICBIAS1VREF_ADDR \ + MT6359_AUDENC_ANA_CON16 +#define RG_AUDMICBIAS1VREF_SFT 4 +#define RG_AUDMICBIAS1VREF_MASK 0x7 +#define RG_AUDMICBIAS1VREF_MASK_SFT (0x7 << 4) +#define RG_AUDMICBIAS1DCSW1PEN_ADDR \ + MT6359_AUDENC_ANA_CON16 +#define RG_AUDMICBIAS1DCSW1PEN_SFT 8 +#define RG_AUDMICBIAS1DCSW1PEN_MASK 0x1 +#define RG_AUDMICBIAS1DCSW1PEN_MASK_SFT (0x1 << 8) +#define RG_AUDMICBIAS1DCSW1NEN_ADDR \ + MT6359_AUDENC_ANA_CON16 +#define RG_AUDMICBIAS1DCSW1NEN_SFT 9 +#define RG_AUDMICBIAS1DCSW1NEN_MASK 0x1 +#define RG_AUDMICBIAS1DCSW1NEN_MASK_SFT (0x1 << 9) +#define RG_BANDGAPGEN_ADDR \ + MT6359_AUDENC_ANA_CON16 +#define RG_BANDGAPGEN_SFT 10 +#define RG_BANDGAPGEN_MASK 0x1 +#define RG_BANDGAPGEN_MASK_SFT (0x1 << 10) +#define RG_AUDMICBIAS1HVEN_ADDR \ + MT6359_AUDENC_ANA_CON16 +#define RG_AUDMICBIAS1HVEN_SFT 12 +#define RG_AUDMICBIAS1HVEN_MASK 0x1 +#define RG_AUDMICBIAS1HVEN_MASK_SFT (0x1 << 12) +#define RG_AUDMICBIAS1HVVREF_ADDR \ + MT6359_AUDENC_ANA_CON16 +#define RG_AUDMICBIAS1HVVREF_SFT 13 +#define RG_AUDMICBIAS1HVVREF_MASK 0x1 +#define RG_AUDMICBIAS1HVVREF_MASK_SFT (0x1 << 13) + +#define RG_EINT0NOHYS_ADDR \ + MT6359_AUDENC_ANA_CON18 +#define RG_EINT0NOHYS_SFT 10 +#define RG_EINT0NOHYS_MASK 0x1 +#define RG_EINT0NOHYS_MASK_SFT (0x1 << 10) +#define RG_EINT0CONFIGACCDET_ADDR \ + MT6359_AUDENC_ANA_CON18 +#define RG_EINT0CONFIGACCDET_SFT 11 +#define RG_EINT0CONFIGACCDET_MASK 0x1 +#define RG_EINT0CONFIGACCDET_MASK_SFT (0x1 << 11) +#define RG_EINT0HIRENB_ADDR \ + MT6359_AUDENC_ANA_CON18 +#define RG_EINT0HIRENB_SFT 12 +#define RG_EINT0HIRENB_MASK 0x1 +#define RG_EINT0HIRENB_MASK_SFT (0x1 << 12) +#define RG_ACCDET2AUXRESBYPASS_ADDR \ + MT6359_AUDENC_ANA_CON18 +#define RG_ACCDET2AUXRESBYPASS_SFT 13 +#define RG_ACCDET2AUXRESBYPASS_MASK 0x1 +#define RG_ACCDET2AUXRESBYPASS_MASK_SFT (0x1 << 13) +#define RG_ACCDET2AUXSWEN_ADDR \ + MT6359_AUDENC_ANA_CON18 +#define RG_ACCDET2AUXSWEN_SFT 14 +#define RG_ACCDET2AUXSWEN_MASK 0x1 +#define RG_ACCDET2AUXSWEN_MASK_SFT (0x1 << 14) +#define RG_AUDACCDETMICBIAS3PULLLOW_ADDR \ + MT6359_AUDENC_ANA_CON18 +#define RG_AUDACCDETMICBIAS3PULLLOW_SFT 15 +#define RG_AUDACCDETMICBIAS3PULLLOW_MASK 0x1 +#define RG_AUDACCDETMICBIAS3PULLLOW_MASK_SFT (0x1 << 15) +#define RG_EINT1CONFIGACCDET_ADDR \ + MT6359_AUDENC_ANA_CON19 +#define RG_EINT1CONFIGACCDET_SFT 0 +#define RG_EINT1CONFIGACCDET_MASK 0x1 +#define RG_EINT1CONFIGACCDET_MASK_SFT (0x1 << 0) +#define RG_EINT1HIRENB_ADDR \ + MT6359_AUDENC_ANA_CON19 +#define RG_EINT1HIRENB_SFT 1 +#define RG_EINT1HIRENB_MASK 0x1 +#define RG_EINT1HIRENB_MASK_SFT (0x1 << 1) +#define RG_EINT1NOHYS_ADDR \ + MT6359_AUDENC_ANA_CON19 +#define RG_EINT1NOHYS_SFT 2 +#define RG_EINT1NOHYS_MASK 0x1 +#define RG_EINT1NOHYS_MASK_SFT (0x1 << 2) +#define RG_EINTCOMPVTH_ADDR \ + MT6359_AUDENC_ANA_CON19 +#define RG_MTEST_EN_ADDR \ + MT6359_AUDENC_ANA_CON19 +#define RG_MTEST_EN_SFT 8 +#define RG_MTEST_EN_MASK 0x1 +#define RG_MTEST_EN_MASK_SFT (0x1 << 8) +#define RG_MTEST_SEL_ADDR \ + MT6359_AUDENC_ANA_CON19 +#define RG_MTEST_SEL_SFT 9 +#define RG_MTEST_SEL_MASK 0x1 +#define RG_MTEST_SEL_MASK_SFT (0x1 << 9) +#define RG_MTEST_CURRENT_ADDR \ + MT6359_AUDENC_ANA_CON19 +#define RG_MTEST_CURRENT_SFT 10 +#define RG_MTEST_CURRENT_MASK 0x1 +#define RG_MTEST_CURRENT_MASK_SFT (0x1 << 10) +#define RG_ANALOGFDEN_ADDR \ + MT6359_AUDENC_ANA_CON19 +#define RG_ANALOGFDEN_SFT 12 +#define RG_ANALOGFDEN_MASK 0x1 +#define RG_ANALOGFDEN_MASK_SFT (0x1 << 12) +#define RG_FDVIN1PPULLLOW_ADDR \ + MT6359_AUDENC_ANA_CON19 +#define RG_FDVIN1PPULLLOW_SFT 13 +#define RG_FDVIN1PPULLLOW_MASK 0x1 +#define RG_FDVIN1PPULLLOW_MASK_SFT (0x1 << 13) +#define RG_FDEINT0TYPE_ADDR \ + MT6359_AUDENC_ANA_CON19 +#define RG_FDEINT0TYPE_SFT 14 +#define RG_FDEINT0TYPE_MASK 0x1 +#define RG_FDEINT0TYPE_MASK_SFT (0x1 << 14) +#define RG_FDEINT1TYPE_ADDR \ + MT6359_AUDENC_ANA_CON19 +#define RG_FDEINT1TYPE_SFT 15 +#define RG_FDEINT1TYPE_MASK 0x1 +#define RG_FDEINT1TYPE_MASK_SFT (0x1 << 15) +#define RG_EINT0CMPEN_ADDR \ + MT6359_AUDENC_ANA_CON20 +#define RG_EINT0CMPEN_SFT 0 +#define RG_EINT0CMPEN_MASK 0x1 +#define RG_EINT0CMPEN_MASK_SFT (0x1 << 0) +#define RG_EINT0CMPMEN_ADDR \ + MT6359_AUDENC_ANA_CON20 +#define RG_EINT0CMPMEN_SFT 1 +#define RG_EINT0CMPMEN_MASK 0x1 +#define RG_EINT0CMPMEN_MASK_SFT (0x1 << 1) +#define RG_EINT0EN_ADDR \ + MT6359_AUDENC_ANA_CON20 +#define RG_EINT0EN_SFT 2 +#define RG_EINT0EN_MASK 0x1 +#define RG_EINT0EN_MASK_SFT (0x1 << 2) +#define RG_EINT0CEN_ADDR \ + MT6359_AUDENC_ANA_CON20 +#define RG_EINT0CEN_SFT 3 +#define RG_EINT0CEN_MASK 0x1 +#define RG_EINT0CEN_MASK_SFT (0x1 << 3) +#define RG_EINT0INVEN_ADDR \ + MT6359_AUDENC_ANA_CON20 +#define RG_EINT0INVEN_SFT 4 +#define RG_EINT0INVEN_MASK 0x1 +#define RG_EINT0INVEN_MASK_SFT (0x1 << 4) +#define RG_EINT0CTURBO_ADDR \ + MT6359_AUDENC_ANA_CON20 +#define RG_EINT0CTURBO_SFT 5 +#define RG_EINT0CTURBO_MASK 0x7 +#define RG_EINT0CTURBO_MASK_SFT (0x7 << 5) +#define RG_EINT1CMPEN_ADDR \ + MT6359_AUDENC_ANA_CON20 +#define RG_EINT1CMPEN_SFT 8 +#define RG_EINT1CMPEN_MASK 0x1 +#define RG_EINT1CMPEN_MASK_SFT (0x1 << 8) +#define RG_EINT1CMPMEN_ADDR \ + MT6359_AUDENC_ANA_CON20 +#define RG_EINT1CMPMEN_SFT 9 +#define RG_EINT1CMPMEN_MASK 0x1 +#define RG_EINT1CMPMEN_MASK_SFT (0x1 << 9) +#define RG_EINT1EN_ADDR \ + MT6359_AUDENC_ANA_CON20 +#define RG_EINT1EN_SFT 10 +#define RG_EINT1EN_MASK 0x1 +#define RG_EINT1EN_MASK_SFT (0x1 << 10) +#define RG_EINT1CEN_ADDR \ + MT6359_AUDENC_ANA_CON20 +#define RG_EINT1CEN_SFT 11 +#define RG_EINT1CEN_MASK 0x1 +#define RG_EINT1CEN_MASK_SFT (0x1 << 11) +#define RG_EINT1INVEN_ADDR \ + MT6359_AUDENC_ANA_CON20 +#define RG_EINT1INVEN_SFT 12 +#define RG_EINT1INVEN_MASK 0x1 +#define RG_EINT1INVEN_MASK_SFT (0x1 << 12) +#define RG_EINT1CTURBO_ADDR \ + MT6359_AUDENC_ANA_CON20 +#define RG_EINT1CTURBO_SFT 13 +#define RG_EINT1CTURBO_MASK 0x7 +#define RG_EINT1CTURBO_MASK_SFT (0x7 << 13) +#define RG_ACCDETSPARE_ADDR \ + MT6359_AUDENC_ANA_CON21 + +#define ACCDET_ANA_ID_ADDR \ + MT6359_ACCDET_DSN_DIG_ID +#define ACCDET_ANA_ID_SFT 0 +#define ACCDET_ANA_ID_MASK 0xFF +#define ACCDET_ANA_ID_MASK_SFT (0xFF << 0) +#define ACCDET_DIG_ID_ADDR \ + MT6359_ACCDET_DSN_DIG_ID +#define ACCDET_DIG_ID_SFT 8 +#define ACCDET_DIG_ID_MASK 0xFF +#define ACCDET_DIG_ID_MASK_SFT (0xFF << 8) +#define ACCDET_ANA_MINOR_REV_ADDR \ + MT6359_ACCDET_DSN_DIG_REV0 +#define ACCDET_ANA_MINOR_REV_SFT 0 +#define ACCDET_ANA_MINOR_REV_MASK 0xF +#define ACCDET_ANA_MINOR_REV_MASK_SFT (0xF << 0) +#define ACCDET_ANA_MAJOR_REV_ADDR \ + MT6359_ACCDET_DSN_DIG_REV0 +#define ACCDET_ANA_MAJOR_REV_SFT 4 +#define ACCDET_ANA_MAJOR_REV_MASK 0xF +#define ACCDET_ANA_MAJOR_REV_MASK_SFT (0xF << 4) +#define ACCDET_DIG_MINOR_REV_ADDR \ + MT6359_ACCDET_DSN_DIG_REV0 +#define ACCDET_DIG_MINOR_REV_SFT 8 +#define ACCDET_DIG_MINOR_REV_MASK 0xF +#define ACCDET_DIG_MINOR_REV_MASK_SFT (0xF << 8) +#define ACCDET_DIG_MAJOR_REV_ADDR \ + MT6359_ACCDET_DSN_DIG_REV0 +#define ACCDET_DIG_MAJOR_REV_SFT 12 +#define ACCDET_DIG_MAJOR_REV_MASK 0xF +#define ACCDET_DIG_MAJOR_REV_MASK_SFT (0xF << 12) +#define ACCDET_DSN_CBS_ADDR \ + MT6359_ACCDET_DSN_DBI +#define ACCDET_DSN_CBS_SFT 0 +#define ACCDET_DSN_CBS_MASK 0x3 +#define ACCDET_DSN_CBS_MASK_SFT (0x3 << 0) +#define ACCDET_DSN_BIX_ADDR \ + MT6359_ACCDET_DSN_DBI +#define ACCDET_DSN_BIX_SFT 2 +#define ACCDET_DSN_BIX_MASK 0x3 +#define ACCDET_DSN_BIX_MASK_SFT (0x3 << 2) +#define ACCDET_ESP_ADDR \ + MT6359_ACCDET_DSN_DBI +#define ACCDET_ESP_SFT 8 +#define ACCDET_ESP_MASK 0xFF +#define ACCDET_ESP_MASK_SFT (0xFF << 8) +#define ACCDET_DSN_FPI_ADDR \ + MT6359_ACCDET_DSN_FPI +#define ACCDET_DSN_FPI_SFT 0 +#define ACCDET_DSN_FPI_MASK 0xFF +#define ACCDET_DSN_FPI_MASK_SFT (0xFF << 0) +#define ACCDET_AUXADC_SEL_ADDR \ + MT6359_ACCDET_CON0 +#define ACCDET_AUXADC_SEL_SFT 0 +#define ACCDET_AUXADC_SEL_MASK 0x1 +#define ACCDET_AUXADC_SEL_MASK_SFT (0x1 << 0) +#define ACCDET_AUXADC_SW_ADDR \ + MT6359_ACCDET_CON0 +#define ACCDET_AUXADC_SW_SFT 1 +#define ACCDET_AUXADC_SW_MASK 0x1 +#define ACCDET_AUXADC_SW_MASK_SFT (0x1 << 1) +#define ACCDET_TEST_AUXADC_ADDR \ + MT6359_ACCDET_CON0 +#define ACCDET_TEST_AUXADC_SFT 2 +#define ACCDET_TEST_AUXADC_MASK 0x1 +#define ACCDET_TEST_AUXADC_MASK_SFT (0x1 << 2) +#define ACCDET_AUXADC_ANASWCTRL_SEL_ADDR \ + MT6359_ACCDET_CON0 +#define ACCDET_AUXADC_ANASWCTRL_SEL_SFT 8 +#define ACCDET_AUXADC_ANASWCTRL_SEL_MASK 0x1 +#define ACCDET_AUXADC_ANASWCTRL_SEL_MASK_SFT (0x1 << 8) +#define AUDACCDETAUXADCSWCTRL_SEL_ADDR \ + MT6359_ACCDET_CON0 +#define AUDACCDETAUXADCSWCTRL_SEL_SFT 9 +#define AUDACCDETAUXADCSWCTRL_SEL_MASK 0x1 +#define AUDACCDETAUXADCSWCTRL_SEL_MASK_SFT (0x1 << 9) +#define AUDACCDETAUXADCSWCTRL_SW_ADDR \ + MT6359_ACCDET_CON0 +#define AUDACCDETAUXADCSWCTRL_SW_SFT 10 +#define AUDACCDETAUXADCSWCTRL_SW_MASK 0x1 +#define AUDACCDETAUXADCSWCTRL_SW_MASK_SFT (0x1 << 10) +#define ACCDET_TEST_ANA_ADDR \ + MT6359_ACCDET_CON0 +#define ACCDET_TEST_ANA_SFT 11 +#define ACCDET_TEST_ANA_MASK 0x1 +#define ACCDET_TEST_ANA_MASK_SFT (0x1 << 11) +#define RG_AUDACCDETRSV_ADDR \ + MT6359_ACCDET_CON0 +#define RG_AUDACCDETRSV_SFT 13 +#define RG_AUDACCDETRSV_MASK 0x3 +#define RG_AUDACCDETRSV_MASK_SFT (0x3 << 13) +#define ACCDET_SW_EN_ADDR \ + MT6359_ACCDET_CON1 +#define ACCDET_SW_EN_SFT 0 +#define ACCDET_SW_EN_MASK 0x1 +#define ACCDET_SW_EN_MASK_SFT (0x1 << 0) +#define ACCDET_SEQ_INIT_ADDR \ + MT6359_ACCDET_CON1 +#define ACCDET_SEQ_INIT_SFT 1 +#define ACCDET_SEQ_INIT_MASK 0x1 +#define ACCDET_SEQ_INIT_MASK_SFT (0x1 << 1) +#define ACCDET_EINT0_SW_EN_ADDR \ + MT6359_ACCDET_CON1 +#define ACCDET_EINT0_SW_EN_SFT 2 +#define ACCDET_EINT0_SW_EN_MASK 0x1 +#define ACCDET_EINT0_SW_EN_MASK_SFT (0x1 << 2) +#define ACCDET_EINT0_SEQ_INIT_ADDR \ + MT6359_ACCDET_CON1 +#define ACCDET_EINT0_SEQ_INIT_SFT 3 +#define ACCDET_EINT0_SEQ_INIT_MASK 0x1 +#define ACCDET_EINT0_SEQ_INIT_MASK_SFT (0x1 << 3) +#define ACCDET_EINT1_SW_EN_ADDR \ + MT6359_ACCDET_CON1 +#define ACCDET_EINT1_SW_EN_SFT 4 +#define ACCDET_EINT1_SW_EN_MASK 0x1 +#define ACCDET_EINT1_SW_EN_MASK_SFT (0x1 << 4) +#define ACCDET_EINT1_SEQ_INIT_ADDR \ + MT6359_ACCDET_CON1 +#define ACCDET_EINT1_SEQ_INIT_SFT 5 +#define ACCDET_EINT1_SEQ_INIT_MASK 0x1 +#define ACCDET_EINT1_SEQ_INIT_MASK_SFT (0x1 << 5) +#define ACCDET_EINT0_INVERTER_SW_EN_ADDR \ + MT6359_ACCDET_CON1 +#define ACCDET_EINT0_INVERTER_SW_EN_SFT 6 +#define ACCDET_EINT0_INVERTER_SW_EN_MASK 0x1 +#define ACCDET_EINT0_INVERTER_SW_EN_MASK_SFT (0x1 << 6) +#define ACCDET_EINT0_INVERTER_SEQ_INIT_ADDR \ + MT6359_ACCDET_CON1 +#define ACCDET_EINT0_INVERTER_SEQ_INIT_SFT 7 +#define ACCDET_EINT0_INVERTER_SEQ_INIT_MASK 0x1 +#define ACCDET_EINT0_INVERTER_SEQ_INIT_MASK_SFT (0x1 << 7) +#define ACCDET_EINT1_INVERTER_SW_EN_ADDR \ + MT6359_ACCDET_CON1 +#define ACCDET_EINT1_INVERTER_SW_EN_SFT 8 +#define ACCDET_EINT1_INVERTER_SW_EN_MASK 0x1 +#define ACCDET_EINT1_INVERTER_SW_EN_MASK_SFT (0x1 << 8) +#define ACCDET_EINT1_INVERTER_SEQ_INIT_ADDR \ + MT6359_ACCDET_CON1 +#define ACCDET_EINT1_INVERTER_SEQ_INIT_SFT 9 +#define ACCDET_EINT1_INVERTER_SEQ_INIT_MASK 0x1 +#define ACCDET_EINT1_INVERTER_SEQ_INIT_MASK_SFT (0x1 << 9) +#define ACCDET_EINT0_M_SW_EN_ADDR \ + MT6359_ACCDET_CON1 +#define ACCDET_EINT0_M_SW_EN_SFT 10 +#define ACCDET_EINT0_M_SW_EN_MASK 0x1 +#define ACCDET_EINT0_M_SW_EN_MASK_SFT (0x1 << 10) +#define ACCDET_EINT1_M_SW_EN_ADDR \ + MT6359_ACCDET_CON1 +#define ACCDET_EINT1_M_SW_EN_SFT 11 +#define ACCDET_EINT1_M_SW_EN_MASK 0x1 +#define ACCDET_EINT1_M_SW_EN_MASK_SFT (0x1 << 11) +#define ACCDET_EINT_M_DETECT_EN_ADDR \ + MT6359_ACCDET_CON1 +#define ACCDET_EINT_M_DETECT_EN_SFT 12 +#define ACCDET_EINT_M_DETECT_EN_MASK 0x1 +#define ACCDET_EINT_M_DETECT_EN_MASK_SFT (0x1 << 12) +#define ACCDET_CMP_PWM_EN_ADDR \ + MT6359_ACCDET_CON2 +#define ACCDET_CMP_PWM_EN_SFT 0 +#define ACCDET_CMP_PWM_EN_MASK 0x1 +#define ACCDET_CMP_PWM_EN_MASK_SFT (0x1 << 0) +#define ACCDET_VTH_PWM_EN_ADDR \ + MT6359_ACCDET_CON2 +#define ACCDET_VTH_PWM_EN_SFT 1 +#define ACCDET_VTH_PWM_EN_MASK 0x1 +#define ACCDET_VTH_PWM_EN_MASK_SFT (0x1 << 1) +#define ACCDET_MBIAS_PWM_EN_ADDR \ + MT6359_ACCDET_CON2 +#define ACCDET_MBIAS_PWM_EN_SFT 2 +#define ACCDET_MBIAS_PWM_EN_MASK 0x1 +#define ACCDET_MBIAS_PWM_EN_MASK_SFT (0x1 << 2) +#define ACCDET_EINT_EN_PWM_EN_ADDR \ + MT6359_ACCDET_CON2 +#define ACCDET_EINT_EN_PWM_EN_SFT 3 +#define ACCDET_EINT_EN_PWM_EN_MASK 0x1 +#define ACCDET_EINT_EN_PWM_EN_MASK_SFT (0x1 << 3) +#define ACCDET_EINT_CMPEN_PWM_EN_ADDR \ + MT6359_ACCDET_CON2 +#define ACCDET_EINT_CMPEN_PWM_EN_SFT 4 +#define ACCDET_EINT_CMPEN_PWM_EN_MASK 0x1 +#define ACCDET_EINT_CMPEN_PWM_EN_MASK_SFT (0x1 << 4) +#define ACCDET_EINT_CMPMEN_PWM_EN_ADDR \ + MT6359_ACCDET_CON2 +#define ACCDET_EINT_CMPMEN_PWM_EN_SFT 5 +#define ACCDET_EINT_CMPMEN_PWM_EN_MASK 0x1 +#define ACCDET_EINT_CMPMEN_PWM_EN_MASK_SFT (0x1 << 5) +#define ACCDET_EINT_CTURBO_PWM_EN_ADDR \ + MT6359_ACCDET_CON2 +#define ACCDET_EINT_CTURBO_PWM_EN_SFT 6 +#define ACCDET_EINT_CTURBO_PWM_EN_MASK 0x1 +#define ACCDET_EINT_CTURBO_PWM_EN_MASK_SFT (0x1 << 6) +#define ACCDET_CMP_PWM_IDLE_ADDR \ + MT6359_ACCDET_CON2 +#define ACCDET_CMP_PWM_IDLE_SFT 8 +#define ACCDET_CMP_PWM_IDLE_MASK 0x1 +#define ACCDET_CMP_PWM_IDLE_MASK_SFT (0x1 << 8) +#define ACCDET_VTH_PWM_IDLE_ADDR \ + MT6359_ACCDET_CON2 +#define ACCDET_VTH_PWM_IDLE_SFT 9 +#define ACCDET_VTH_PWM_IDLE_MASK 0x1 +#define ACCDET_VTH_PWM_IDLE_MASK_SFT (0x1 << 9) +#define ACCDET_MBIAS_PWM_IDLE_ADDR \ + MT6359_ACCDET_CON2 +#define ACCDET_MBIAS_PWM_IDLE_SFT 10 +#define ACCDET_MBIAS_PWM_IDLE_MASK 0x1 +#define ACCDET_MBIAS_PWM_IDLE_MASK_SFT (0x1 << 10) +#define ACCDET_EINT0_CMPEN_PWM_IDLE_ADDR \ + MT6359_ACCDET_CON2 +#define ACCDET_EINT0_CMPEN_PWM_IDLE_SFT 11 +#define ACCDET_EINT0_CMPEN_PWM_IDLE_MASK 0x1 +#define ACCDET_EINT0_CMPEN_PWM_IDLE_MASK_SFT (0x1 << 11) +#define ACCDET_EINT1_CMPEN_PWM_IDLE_ADDR \ + MT6359_ACCDET_CON2 +#define ACCDET_EINT1_CMPEN_PWM_IDLE_SFT 12 +#define ACCDET_EINT1_CMPEN_PWM_IDLE_MASK 0x1 +#define ACCDET_EINT1_CMPEN_PWM_IDLE_MASK_SFT (0x1 << 12) +#define ACCDET_PWM_EN_SW_ADDR \ + MT6359_ACCDET_CON2 +#define ACCDET_PWM_EN_SW_SFT 13 +#define ACCDET_PWM_EN_SW_MASK 0x1 +#define ACCDET_PWM_EN_SW_MASK_SFT (0x1 << 13) +#define ACCDET_PWM_EN_SEL_ADDR \ + MT6359_ACCDET_CON2 +#define ACCDET_PWM_EN_SEL_SFT 14 +#define ACCDET_PWM_EN_SEL_MASK 0x3 +#define ACCDET_PWM_EN_SEL_MASK_SFT (0x3 << 14) +#define ACCDET_PWM_WIDTH_ADDR \ + MT6359_ACCDET_CON3 +#define ACCDET_PWM_WIDTH_SFT 0 +#define ACCDET_PWM_WIDTH_MASK 0xFFFF +#define ACCDET_PWM_WIDTH_MASK_SFT (0xFFFF << 0) +#define ACCDET_PWM_THRESH_ADDR \ + MT6359_ACCDET_CON4 +#define ACCDET_PWM_THRESH_SFT 0 +#define ACCDET_PWM_THRESH_MASK 0xFFFF +#define ACCDET_PWM_THRESH_MASK_SFT (0xFFFF << 0) +#define ACCDET_RISE_DELAY_ADDR \ + MT6359_ACCDET_CON5 +#define ACCDET_RISE_DELAY_SFT 0 +#define ACCDET_RISE_DELAY_MASK 0x7FFF +#define ACCDET_RISE_DELAY_MASK_SFT (0x7FFF << 0) +#define ACCDET_FALL_DELAY_ADDR \ + MT6359_ACCDET_CON5 +#define ACCDET_FALL_DELAY_SFT 15 +#define ACCDET_FALL_DELAY_MASK 0x1 +#define ACCDET_FALL_DELAY_MASK_SFT (0x1 << 15) +#define ACCDET_EINT_CMPMEN_PWM_THRESH_ADDR \ + MT6359_ACCDET_CON6 +#define ACCDET_EINT_CMPMEN_PWM_THRESH_SFT 0 +#define ACCDET_EINT_CMPMEN_PWM_THRESH_MASK 0x7 +#define ACCDET_EINT_CMPMEN_PWM_THRESH_MASK_SFT (0x7 << 0) +#define ACCDET_EINT_CMPMEN_PWM_WIDTH_ADDR \ + MT6359_ACCDET_CON6 +#define ACCDET_EINT_CMPMEN_PWM_WIDTH_SFT 4 +#define ACCDET_EINT_CMPMEN_PWM_WIDTH_MASK 0x7 +#define ACCDET_EINT_CMPMEN_PWM_WIDTH_MASK_SFT (0x7 << 4) +#define ACCDET_EINT_EN_PWM_THRESH_ADDR \ + MT6359_ACCDET_CON7 +#define ACCDET_EINT_EN_PWM_THRESH_SFT 0 +#define ACCDET_EINT_EN_PWM_THRESH_MASK 0x7 +#define ACCDET_EINT_EN_PWM_THRESH_MASK_SFT (0x7 << 0) +#define ACCDET_EINT_EN_PWM_WIDTH_ADDR \ + MT6359_ACCDET_CON7 +#define ACCDET_EINT_EN_PWM_WIDTH_SFT 4 +#define ACCDET_EINT_EN_PWM_WIDTH_MASK 0x3 +#define ACCDET_EINT_EN_PWM_WIDTH_MASK_SFT (0x3 << 4) +#define ACCDET_EINT_CMPEN_PWM_THRESH_ADDR \ + MT6359_ACCDET_CON7 +#define ACCDET_EINT_CMPEN_PWM_THRESH_SFT 8 +#define ACCDET_EINT_CMPEN_PWM_THRESH_MASK 0x7 +#define ACCDET_EINT_CMPEN_PWM_THRESH_MASK_SFT (0x7 << 8) +#define ACCDET_EINT_CMPEN_PWM_WIDTH_ADDR \ + MT6359_ACCDET_CON7 +#define ACCDET_EINT_CMPEN_PWM_WIDTH_SFT 12 +#define ACCDET_EINT_CMPEN_PWM_WIDTH_MASK 0x3 +#define ACCDET_EINT_CMPEN_PWM_WIDTH_MASK_SFT (0x3 << 12) +#define ACCDET_DEBOUNCE0_ADDR \ + MT6359_ACCDET_CON8 +#define ACCDET_DEBOUNCE0_SFT 0 +#define ACCDET_DEBOUNCE0_MASK 0xFFFF +#define ACCDET_DEBOUNCE0_MASK_SFT (0xFFFF << 0) +#define ACCDET_DEBOUNCE1_ADDR \ + MT6359_ACCDET_CON9 +#define ACCDET_DEBOUNCE1_SFT 0 +#define ACCDET_DEBOUNCE1_MASK 0xFFFF +#define ACCDET_DEBOUNCE1_MASK_SFT (0xFFFF << 0) +#define ACCDET_DEBOUNCE2_ADDR \ + MT6359_ACCDET_CON10 +#define ACCDET_DEBOUNCE2_SFT 0 +#define ACCDET_DEBOUNCE2_MASK 0xFFFF +#define ACCDET_DEBOUNCE2_MASK_SFT (0xFFFF << 0) +#define ACCDET_DEBOUNCE3_ADDR \ + MT6359_ACCDET_CON11 +#define ACCDET_DEBOUNCE3_SFT 0 +#define ACCDET_DEBOUNCE3_MASK 0xFFFF +#define ACCDET_DEBOUNCE3_MASK_SFT (0xFFFF << 0) +#define ACCDET_CONNECT_AUXADC_TIME_DIG_ADDR \ + MT6359_ACCDET_CON12 +#define ACCDET_CONNECT_AUXADC_TIME_DIG_SFT 0 +#define ACCDET_CONNECT_AUXADC_TIME_DIG_MASK 0xFFFF +#define ACCDET_CONNECT_AUXADC_TIME_DIG_MASK_SFT (0xFFFF << 0) +#define ACCDET_CONNECT_AUXADC_TIME_ANA_ADDR \ + MT6359_ACCDET_CON13 +#define ACCDET_CONNECT_AUXADC_TIME_ANA_SFT 0 +#define ACCDET_CONNECT_AUXADC_TIME_ANA_MASK 0xFFFF +#define ACCDET_CONNECT_AUXADC_TIME_ANA_MASK_SFT (0xFFFF << 0) +#define ACCDET_EINT_DEBOUNCE0_ADDR \ + MT6359_ACCDET_CON14 +#define ACCDET_EINT_DEBOUNCE0_SFT 0 +#define ACCDET_EINT_DEBOUNCE0_MASK 0xF +#define ACCDET_EINT_DEBOUNCE0_MASK_SFT (0xF << 0) +#define ACCDET_EINT_DEBOUNCE1_ADDR \ + MT6359_ACCDET_CON14 +#define ACCDET_EINT_DEBOUNCE1_SFT 4 +#define ACCDET_EINT_DEBOUNCE1_MASK 0xF +#define ACCDET_EINT_DEBOUNCE1_MASK_SFT (0xF << 4) +#define ACCDET_EINT_DEBOUNCE2_ADDR \ + MT6359_ACCDET_CON14 +#define ACCDET_EINT_DEBOUNCE2_SFT 8 +#define ACCDET_EINT_DEBOUNCE2_MASK 0xF +#define ACCDET_EINT_DEBOUNCE2_MASK_SFT (0xF << 8) +#define ACCDET_EINT_DEBOUNCE3_ADDR \ + MT6359_ACCDET_CON14 +#define ACCDET_EINT_DEBOUNCE3_SFT 12 +#define ACCDET_EINT_DEBOUNCE3_MASK 0xF +#define ACCDET_EINT_DEBOUNCE3_MASK_SFT (0xF << 12) +#define ACCDET_EINT_INVERTER_DEBOUNCE_ADDR \ + MT6359_ACCDET_CON15 +#define ACCDET_EINT_INVERTER_DEBOUNCE_SFT 0 +#define ACCDET_EINT_INVERTER_DEBOUNCE_MASK 0xF +#define ACCDET_EINT_INVERTER_DEBOUNCE_MASK_SFT (0xF << 0) +#define ACCDET_IVAL_CUR_IN_ADDR \ + MT6359_ACCDET_CON16 +#define ACCDET_IVAL_CUR_IN_SFT 0 +#define ACCDET_IVAL_CUR_IN_MASK 0x3 +#define ACCDET_IVAL_CUR_IN_MASK_SFT (0x3 << 0) +#define ACCDET_IVAL_SAM_IN_ADDR \ + MT6359_ACCDET_CON16 +#define ACCDET_IVAL_SAM_IN_SFT 2 +#define ACCDET_IVAL_SAM_IN_MASK 0x3 +#define ACCDET_IVAL_SAM_IN_MASK_SFT (0x3 << 2) +#define ACCDET_IVAL_MEM_IN_ADDR \ + MT6359_ACCDET_CON16 +#define ACCDET_IVAL_MEM_IN_SFT 4 +#define ACCDET_IVAL_MEM_IN_MASK 0x3 +#define ACCDET_IVAL_MEM_IN_MASK_SFT (0x3 << 4) +#define ACCDET_EINT_IVAL_CUR_IN_ADDR \ + MT6359_ACCDET_CON16 +#define ACCDET_EINT_IVAL_CUR_IN_SFT 6 +#define ACCDET_EINT_IVAL_CUR_IN_MASK 0x3 +#define ACCDET_EINT_IVAL_CUR_IN_MASK_SFT (0x3 << 6) +#define ACCDET_EINT_IVAL_SAM_IN_ADDR \ + MT6359_ACCDET_CON16 +#define ACCDET_EINT_IVAL_SAM_IN_SFT 8 +#define ACCDET_EINT_IVAL_SAM_IN_MASK 0x3 +#define ACCDET_EINT_IVAL_SAM_IN_MASK_SFT (0x3 << 8) +#define ACCDET_EINT_IVAL_MEM_IN_ADDR \ + MT6359_ACCDET_CON16 +#define ACCDET_EINT_IVAL_MEM_IN_SFT 10 +#define ACCDET_EINT_IVAL_MEM_IN_MASK 0x3 +#define ACCDET_EINT_IVAL_MEM_IN_MASK_SFT (0x3 << 10) +#define ACCDET_IVAL_SEL_ADDR \ + MT6359_ACCDET_CON16 +#define ACCDET_IVAL_SEL_SFT 12 +#define ACCDET_IVAL_SEL_MASK 0x1 +#define ACCDET_IVAL_SEL_MASK_SFT (0x1 << 12) +#define ACCDET_EINT_IVAL_SEL_ADDR \ + MT6359_ACCDET_CON16 +#define ACCDET_EINT_IVAL_SEL_SFT 13 +#define ACCDET_EINT_IVAL_SEL_MASK 0x1 +#define ACCDET_EINT_IVAL_SEL_MASK_SFT (0x1 << 13) +#define ACCDET_EINT_INVERTER_IVAL_CUR_IN_ADDR \ + MT6359_ACCDET_CON17 +#define ACCDET_EINT_INVERTER_IVAL_CUR_IN_SFT 0 +#define ACCDET_EINT_INVERTER_IVAL_CUR_IN_MASK 0x1 +#define ACCDET_EINT_INVERTER_IVAL_CUR_IN_MASK_SFT (0x1 << 0) +#define ACCDET_EINT_INVERTER_IVAL_SAM_IN_ADDR \ + MT6359_ACCDET_CON17 +#define ACCDET_EINT_INVERTER_IVAL_SAM_IN_SFT 1 +#define ACCDET_EINT_INVERTER_IVAL_SAM_IN_MASK 0x1 +#define ACCDET_EINT_INVERTER_IVAL_SAM_IN_MASK_SFT (0x1 << 1) +#define ACCDET_EINT_INVERTER_IVAL_MEM_IN_ADDR \ + MT6359_ACCDET_CON17 +#define ACCDET_EINT_INVERTER_IVAL_MEM_IN_SFT 2 +#define ACCDET_EINT_INVERTER_IVAL_MEM_IN_MASK 0x1 +#define ACCDET_EINT_INVERTER_IVAL_MEM_IN_MASK_SFT (0x1 << 2) +#define ACCDET_EINT_INVERTER_IVAL_SEL_ADDR \ + MT6359_ACCDET_CON17 +#define ACCDET_EINT_INVERTER_IVAL_SEL_SFT 3 +#define ACCDET_EINT_INVERTER_IVAL_SEL_MASK 0x1 +#define ACCDET_EINT_INVERTER_IVAL_SEL_MASK_SFT (0x1 << 3) +#define ACCDET_IRQ_ADDR \ + MT6359_ACCDET_CON18 +#define ACCDET_IRQ_SFT 0 +#define ACCDET_IRQ_MASK 0x1 +#define ACCDET_IRQ_MASK_SFT (0x1 << 0) +#define ACCDET_EINT0_IRQ_ADDR \ + MT6359_ACCDET_CON18 +#define ACCDET_EINT0_IRQ_SFT 2 +#define ACCDET_EINT0_IRQ_MASK 0x1 +#define ACCDET_EINT0_IRQ_MASK_SFT (0x1 << 2) +#define ACCDET_EINT1_IRQ_ADDR \ + MT6359_ACCDET_CON18 +#define ACCDET_EINT1_IRQ_SFT 3 +#define ACCDET_EINT1_IRQ_MASK 0x1 +#define ACCDET_EINT1_IRQ_MASK_SFT (0x1 << 3) +#define ACCDET_EINT_IN_INVERSE_ADDR \ + MT6359_ACCDET_CON18 +#define ACCDET_EINT_IN_INVERSE_SFT 4 +#define ACCDET_EINT_IN_INVERSE_MASK 0x1 +#define ACCDET_EINT_IN_INVERSE_MASK_SFT (0x1 << 4) +#define ACCDET_IRQ_CLR_ADDR \ + MT6359_ACCDET_CON18 +#define ACCDET_IRQ_CLR_SFT 8 +#define ACCDET_IRQ_CLR_MASK 0x1 +#define ACCDET_IRQ_CLR_MASK_SFT (0x1 << 8) +#define ACCDET_EINT0_IRQ_CLR_ADDR \ + MT6359_ACCDET_CON18 +#define ACCDET_EINT0_IRQ_CLR_SFT 10 +#define ACCDET_EINT0_IRQ_CLR_MASK 0x1 +#define ACCDET_EINT0_IRQ_CLR_MASK_SFT (0x1 << 10) +#define ACCDET_EINT1_IRQ_CLR_ADDR \ + MT6359_ACCDET_CON18 +#define ACCDET_EINT1_IRQ_CLR_SFT 11 +#define ACCDET_EINT1_IRQ_CLR_MASK 0x1 +#define ACCDET_EINT1_IRQ_CLR_MASK_SFT (0x1 << 11) +#define ACCDET_EINT_M_PLUG_IN_NUM_ADDR \ + MT6359_ACCDET_CON18 +#define ACCDET_EINT_M_PLUG_IN_NUM_SFT 12 +#define ACCDET_EINT_M_PLUG_IN_NUM_MASK 0x7 +#define ACCDET_EINT_M_PLUG_IN_NUM_MASK_SFT (0x7 << 12) +#define ACCDET_DA_STABLE_ADDR \ + MT6359_ACCDET_CON19 +#define ACCDET_DA_STABLE_SFT 0 +#define ACCDET_DA_STABLE_MASK 0x1 +#define ACCDET_DA_STABLE_MASK_SFT (0x1 << 0) +#define ACCDET_EINT0_EN_STABLE_ADDR \ + MT6359_ACCDET_CON19 +#define ACCDET_EINT0_EN_STABLE_SFT 1 +#define ACCDET_EINT0_EN_STABLE_MASK 0x1 +#define ACCDET_EINT0_EN_STABLE_MASK_SFT (0x1 << 1) +#define ACCDET_EINT0_CMPEN_STABLE_ADDR \ + MT6359_ACCDET_CON19 +#define ACCDET_EINT0_CMPEN_STABLE_SFT 2 +#define ACCDET_EINT0_CMPEN_STABLE_MASK 0x1 +#define ACCDET_EINT0_CMPEN_STABLE_MASK_SFT (0x1 << 2) +#define ACCDET_EINT0_CMPMEN_STABLE_ADDR \ + MT6359_ACCDET_CON19 +#define ACCDET_EINT0_CMPMEN_STABLE_SFT 3 +#define ACCDET_EINT0_CMPMEN_STABLE_MASK 0x1 +#define ACCDET_EINT0_CMPMEN_STABLE_MASK_SFT (0x1 << 3) +#define ACCDET_EINT0_CTURBO_STABLE_ADDR \ + MT6359_ACCDET_CON19 +#define ACCDET_EINT0_CTURBO_STABLE_SFT 4 +#define ACCDET_EINT0_CTURBO_STABLE_MASK 0x1 +#define ACCDET_EINT0_CTURBO_STABLE_MASK_SFT (0x1 << 4) +#define ACCDET_EINT0_CEN_STABLE_ADDR \ + MT6359_ACCDET_CON19 +#define ACCDET_EINT0_CEN_STABLE_SFT 5 +#define ACCDET_EINT0_CEN_STABLE_MASK 0x1 +#define ACCDET_EINT0_CEN_STABLE_MASK_SFT (0x1 << 5) +#define ACCDET_EINT1_EN_STABLE_ADDR \ + MT6359_ACCDET_CON19 +#define ACCDET_EINT1_EN_STABLE_SFT 6 +#define ACCDET_EINT1_EN_STABLE_MASK 0x1 +#define ACCDET_EINT1_EN_STABLE_MASK_SFT (0x1 << 6) +#define ACCDET_EINT1_CMPEN_STABLE_ADDR \ + MT6359_ACCDET_CON19 +#define ACCDET_EINT1_CMPEN_STABLE_SFT 7 +#define ACCDET_EINT1_CMPEN_STABLE_MASK 0x1 +#define ACCDET_EINT1_CMPEN_STABLE_MASK_SFT (0x1 << 7) +#define ACCDET_EINT1_CMPMEN_STABLE_ADDR \ + MT6359_ACCDET_CON19 +#define ACCDET_EINT1_CMPMEN_STABLE_SFT 8 +#define ACCDET_EINT1_CMPMEN_STABLE_MASK 0x1 +#define ACCDET_EINT1_CMPMEN_STABLE_MASK_SFT (0x1 << 8) +#define ACCDET_EINT1_CTURBO_STABLE_ADDR \ + MT6359_ACCDET_CON19 +#define ACCDET_EINT1_CTURBO_STABLE_SFT 9 +#define ACCDET_EINT1_CTURBO_STABLE_MASK 0x1 +#define ACCDET_EINT1_CTURBO_STABLE_MASK_SFT (0x1 << 9) +#define ACCDET_EINT1_CEN_STABLE_ADDR \ + MT6359_ACCDET_CON19 +#define ACCDET_EINT1_CEN_STABLE_SFT 10 +#define ACCDET_EINT1_CEN_STABLE_MASK 0x1 +#define ACCDET_EINT1_CEN_STABLE_MASK_SFT (0x1 << 10) +#define ACCDET_HWMODE_EN_ADDR \ + MT6359_ACCDET_CON20 +#define ACCDET_HWMODE_EN_SFT 0 +#define ACCDET_HWMODE_EN_MASK 0x1 +#define ACCDET_HWMODE_EN_MASK_SFT (0x1 << 0) +#define ACCDET_HWMODE_SEL_ADDR \ + MT6359_ACCDET_CON20 +#define ACCDET_HWMODE_SEL_SFT 1 +#define ACCDET_HWMODE_SEL_MASK 0x3 +#define ACCDET_HWMODE_SEL_MASK_SFT (0x3 << 1) +#define ACCDET_PLUG_OUT_DETECT_ADDR \ + MT6359_ACCDET_CON20 +#define ACCDET_PLUG_OUT_DETECT_SFT 3 +#define ACCDET_PLUG_OUT_DETECT_MASK 0x1 +#define ACCDET_PLUG_OUT_DETECT_MASK_SFT (0x1 << 3) +#define ACCDET_EINT0_REVERSE_ADDR \ + MT6359_ACCDET_CON20 +#define ACCDET_EINT0_REVERSE_SFT 4 +#define ACCDET_EINT0_REVERSE_MASK 0x1 +#define ACCDET_EINT0_REVERSE_MASK_SFT (0x1 << 4) +#define ACCDET_EINT1_REVERSE_ADDR \ + MT6359_ACCDET_CON20 +#define ACCDET_EINT1_REVERSE_SFT 5 +#define ACCDET_EINT1_REVERSE_MASK 0x1 +#define ACCDET_EINT1_REVERSE_MASK_SFT (0x1 << 5) +#define ACCDET_EINT_HWMODE_EN_ADDR \ + MT6359_ACCDET_CON20 +#define ACCDET_EINT_HWMODE_EN_SFT 8 +#define ACCDET_EINT_HWMODE_EN_MASK 0x1 +#define ACCDET_EINT_HWMODE_EN_MASK_SFT (0x1 << 8) +#define ACCDET_EINT_PLUG_OUT_BYPASS_DEB_ADDR \ + MT6359_ACCDET_CON20 +#define ACCDET_EINT_PLUG_OUT_BYPASS_DEB_SFT 9 +#define ACCDET_EINT_PLUG_OUT_BYPASS_DEB_MASK 0x1 +#define ACCDET_EINT_PLUG_OUT_BYPASS_DEB_MASK_SFT (0x1 << 9) +#define ACCDET_EINT_M_PLUG_IN_EN_ADDR \ + MT6359_ACCDET_CON20 +#define ACCDET_EINT_M_PLUG_IN_EN_SFT 10 +#define ACCDET_EINT_M_PLUG_IN_EN_MASK 0x1 +#define ACCDET_EINT_M_PLUG_IN_EN_MASK_SFT (0x1 << 10) +#define ACCDET_EINT_M_HWMODE_EN_ADDR \ + MT6359_ACCDET_CON20 +#define ACCDET_EINT_M_HWMODE_EN_SFT 11 +#define ACCDET_EINT_M_HWMODE_EN_MASK 0x1 +#define ACCDET_EINT_M_HWMODE_EN_MASK_SFT (0x1 << 11) +#define ACCDET_TEST_CMPEN_ADDR \ + MT6359_ACCDET_CON21 +#define ACCDET_TEST_CMPEN_SFT 0 +#define ACCDET_TEST_CMPEN_MASK 0x1 +#define ACCDET_TEST_CMPEN_MASK_SFT (0x1 << 0) +#define ACCDET_TEST_VTHEN_ADDR \ + MT6359_ACCDET_CON21 +#define ACCDET_TEST_VTHEN_SFT 1 +#define ACCDET_TEST_VTHEN_MASK 0x1 +#define ACCDET_TEST_VTHEN_MASK_SFT (0x1 << 1) +#define ACCDET_TEST_MBIASEN_ADDR \ + MT6359_ACCDET_CON21 +#define ACCDET_TEST_MBIASEN_SFT 2 +#define ACCDET_TEST_MBIASEN_MASK 0x1 +#define ACCDET_TEST_MBIASEN_MASK_SFT (0x1 << 2) +#define ACCDET_EINT_TEST_EN_ADDR \ + MT6359_ACCDET_CON21 +#define ACCDET_EINT_TEST_EN_SFT 3 +#define ACCDET_EINT_TEST_EN_MASK 0x1 +#define ACCDET_EINT_TEST_EN_MASK_SFT (0x1 << 3) +#define ACCDET_EINT_TEST_INVEN_ADDR \ + MT6359_ACCDET_CON21 +#define ACCDET_EINT_TEST_INVEN_SFT 4 +#define ACCDET_EINT_TEST_INVEN_MASK 0x1 +#define ACCDET_EINT_TEST_INVEN_MASK_SFT (0x1 << 4) +#define ACCDET_EINT_TEST_CMPEN_ADDR \ + MT6359_ACCDET_CON21 +#define ACCDET_EINT_TEST_CMPEN_SFT 5 +#define ACCDET_EINT_TEST_CMPEN_MASK 0x1 +#define ACCDET_EINT_TEST_CMPEN_MASK_SFT (0x1 << 5) +#define ACCDET_EINT_TEST_CMPMEN_ADDR \ + MT6359_ACCDET_CON21 +#define ACCDET_EINT_TEST_CMPMEN_SFT 6 +#define ACCDET_EINT_TEST_CMPMEN_MASK 0x1 +#define ACCDET_EINT_TEST_CMPMEN_MASK_SFT (0x1 << 6) +#define ACCDET_EINT_TEST_CTURBO_ADDR \ + MT6359_ACCDET_CON21 +#define ACCDET_EINT_TEST_CTURBO_SFT 7 +#define ACCDET_EINT_TEST_CTURBO_MASK 0x1 +#define ACCDET_EINT_TEST_CTURBO_MASK_SFT (0x1 << 7) +#define ACCDET_EINT_TEST_CEN_ADDR \ + MT6359_ACCDET_CON21 +#define ACCDET_EINT_TEST_CEN_SFT 8 +#define ACCDET_EINT_TEST_CEN_MASK 0x1 +#define ACCDET_EINT_TEST_CEN_MASK_SFT (0x1 << 8) +#define ACCDET_TEST_B_ADDR \ + MT6359_ACCDET_CON21 +#define ACCDET_TEST_B_SFT 9 +#define ACCDET_TEST_B_MASK 0x1 +#define ACCDET_TEST_B_MASK_SFT (0x1 << 9) +#define ACCDET_TEST_A_ADDR \ + MT6359_ACCDET_CON21 +#define ACCDET_TEST_A_SFT 10 +#define ACCDET_TEST_A_MASK 0x1 +#define ACCDET_TEST_A_MASK_SFT (0x1 << 10) +#define ACCDET_EINT_TEST_CMPOUT_ADDR \ + MT6359_ACCDET_CON21 +#define ACCDET_EINT_TEST_CMPOUT_SFT 11 +#define ACCDET_EINT_TEST_CMPOUT_MASK 0x1 +#define ACCDET_EINT_TEST_CMPOUT_MASK_SFT (0x1 << 11) +#define ACCDET_EINT_TEST_CMPMOUT_ADDR \ + MT6359_ACCDET_CON21 +#define ACCDET_EINT_TEST_CMPMOUT_SFT 12 +#define ACCDET_EINT_TEST_CMPMOUT_MASK 0x1 +#define ACCDET_EINT_TEST_CMPMOUT_MASK_SFT (0x1 << 12) +#define ACCDET_EINT_TEST_INVOUT_ADDR \ + MT6359_ACCDET_CON21 +#define ACCDET_EINT_TEST_INVOUT_SFT 13 +#define ACCDET_EINT_TEST_INVOUT_MASK 0x1 +#define ACCDET_EINT_TEST_INVOUT_MASK_SFT (0x1 << 13) +#define ACCDET_CMPEN_SEL_ADDR \ + MT6359_ACCDET_CON22 +#define ACCDET_CMPEN_SEL_SFT 0 +#define ACCDET_CMPEN_SEL_MASK 0x1 +#define ACCDET_CMPEN_SEL_MASK_SFT (0x1 << 0) +#define ACCDET_VTHEN_SEL_ADDR \ + MT6359_ACCDET_CON22 +#define ACCDET_VTHEN_SEL_SFT 1 +#define ACCDET_VTHEN_SEL_MASK 0x1 +#define ACCDET_VTHEN_SEL_MASK_SFT (0x1 << 1) +#define ACCDET_MBIASEN_SEL_ADDR \ + MT6359_ACCDET_CON22 +#define ACCDET_MBIASEN_SEL_SFT 2 +#define ACCDET_MBIASEN_SEL_MASK 0x1 +#define ACCDET_MBIASEN_SEL_MASK_SFT (0x1 << 2) +#define ACCDET_EINT_EN_SEL_ADDR \ + MT6359_ACCDET_CON22 +#define ACCDET_EINT_EN_SEL_SFT 3 +#define ACCDET_EINT_EN_SEL_MASK 0x1 +#define ACCDET_EINT_EN_SEL_MASK_SFT (0x1 << 3) +#define ACCDET_EINT_INVEN_SEL_ADDR \ + MT6359_ACCDET_CON22 +#define ACCDET_EINT_INVEN_SEL_SFT 4 +#define ACCDET_EINT_INVEN_SEL_MASK 0x1 +#define ACCDET_EINT_INVEN_SEL_MASK_SFT (0x1 << 4) +#define ACCDET_EINT_CMPEN_SEL_ADDR \ + MT6359_ACCDET_CON22 +#define ACCDET_EINT_CMPEN_SEL_SFT 5 +#define ACCDET_EINT_CMPEN_SEL_MASK 0x1 +#define ACCDET_EINT_CMPEN_SEL_MASK_SFT (0x1 << 5) +#define ACCDET_EINT_CMPMEN_SEL_ADDR \ + MT6359_ACCDET_CON22 +#define ACCDET_EINT_CMPMEN_SEL_SFT 6 +#define ACCDET_EINT_CMPMEN_SEL_MASK 0x1 +#define ACCDET_EINT_CMPMEN_SEL_MASK_SFT (0x1 << 6) +#define ACCDET_EINT_CTURBO_SEL_ADDR \ + MT6359_ACCDET_CON22 +#define ACCDET_EINT_CTURBO_SEL_SFT 7 +#define ACCDET_EINT_CTURBO_SEL_MASK 0x1 +#define ACCDET_EINT_CTURBO_SEL_MASK_SFT (0x1 << 7) +#define ACCDET_B_SEL_ADDR \ + MT6359_ACCDET_CON22 +#define ACCDET_B_SEL_SFT 9 +#define ACCDET_B_SEL_MASK 0x1 +#define ACCDET_B_SEL_MASK_SFT (0x1 << 9) +#define ACCDET_A_SEL_ADDR \ + MT6359_ACCDET_CON22 +#define ACCDET_A_SEL_SFT 10 +#define ACCDET_A_SEL_MASK 0x1 +#define ACCDET_A_SEL_MASK_SFT (0x1 << 10) +#define ACCDET_EINT_CMPOUT_SEL_ADDR \ + MT6359_ACCDET_CON22 +#define ACCDET_EINT_CMPOUT_SEL_SFT 11 +#define ACCDET_EINT_CMPOUT_SEL_MASK 0x1 +#define ACCDET_EINT_CMPOUT_SEL_MASK_SFT (0x1 << 11) +#define ACCDET_EINT_CMPMOUT_SEL_ADDR \ + MT6359_ACCDET_CON22 +#define ACCDET_EINT_CMPMOUT_SEL_SFT 12 +#define ACCDET_EINT_CMPMOUT_SEL_MASK 0x1 +#define ACCDET_EINT_CMPMOUT_SEL_MASK_SFT (0x1 << 12) +#define ACCDET_EINT_INVOUT_SEL_ADDR \ + MT6359_ACCDET_CON22 +#define ACCDET_EINT_INVOUT_SEL_SFT 13 +#define ACCDET_EINT_INVOUT_SEL_MASK 0x1 +#define ACCDET_EINT_INVOUT_SEL_MASK_SFT (0x1 << 13) +#define ACCDET_CMPEN_SW_ADDR \ + MT6359_ACCDET_CON23 +#define ACCDET_CMPEN_SW_SFT 0 +#define ACCDET_CMPEN_SW_MASK 0x1 +#define ACCDET_CMPEN_SW_MASK_SFT (0x1 << 0) +#define ACCDET_VTHEN_SW_ADDR \ + MT6359_ACCDET_CON23 +#define ACCDET_VTHEN_SW_SFT 1 +#define ACCDET_VTHEN_SW_MASK 0x1 +#define ACCDET_VTHEN_SW_MASK_SFT (0x1 << 1) +#define ACCDET_MBIASEN_SW_ADDR \ + MT6359_ACCDET_CON23 +#define ACCDET_MBIASEN_SW_SFT 2 +#define ACCDET_MBIASEN_SW_MASK 0x1 +#define ACCDET_MBIASEN_SW_MASK_SFT (0x1 << 2) +#define ACCDET_EINT0_EN_SW_ADDR \ + MT6359_ACCDET_CON23 +#define ACCDET_EINT0_EN_SW_SFT 3 +#define ACCDET_EINT0_EN_SW_MASK 0x1 +#define ACCDET_EINT0_EN_SW_MASK_SFT (0x1 << 3) +#define ACCDET_EINT0_INVEN_SW_ADDR \ + MT6359_ACCDET_CON23 +#define ACCDET_EINT0_INVEN_SW_SFT 4 +#define ACCDET_EINT0_INVEN_SW_MASK 0x1 +#define ACCDET_EINT0_INVEN_SW_MASK_SFT (0x1 << 4) +#define ACCDET_EINT0_CMPEN_SW_ADDR \ + MT6359_ACCDET_CON23 +#define ACCDET_EINT0_CMPEN_SW_SFT 5 +#define ACCDET_EINT0_CMPEN_SW_MASK 0x1 +#define ACCDET_EINT0_CMPEN_SW_MASK_SFT (0x1 << 5) +#define ACCDET_EINT0_CMPMEN_SW_ADDR \ + MT6359_ACCDET_CON23 +#define ACCDET_EINT0_CMPMEN_SW_SFT 6 +#define ACCDET_EINT0_CMPMEN_SW_MASK 0x1 +#define ACCDET_EINT0_CMPMEN_SW_MASK_SFT (0x1 << 6) +#define ACCDET_EINT0_CTURBO_SW_ADDR \ + MT6359_ACCDET_CON23 +#define ACCDET_EINT0_CTURBO_SW_SFT 7 +#define ACCDET_EINT0_CTURBO_SW_MASK 0x1 +#define ACCDET_EINT0_CTURBO_SW_MASK_SFT (0x1 << 7) +#define ACCDET_EINT1_EN_SW_ADDR \ + MT6359_ACCDET_CON23 +#define ACCDET_EINT1_EN_SW_SFT 8 +#define ACCDET_EINT1_EN_SW_MASK 0x1 +#define ACCDET_EINT1_EN_SW_MASK_SFT (0x1 << 8) +#define ACCDET_EINT1_INVEN_SW_ADDR \ + MT6359_ACCDET_CON23 +#define ACCDET_EINT1_INVEN_SW_SFT 9 +#define ACCDET_EINT1_INVEN_SW_MASK 0x1 +#define ACCDET_EINT1_INVEN_SW_MASK_SFT (0x1 << 9) +#define ACCDET_EINT1_CMPEN_SW_ADDR \ + MT6359_ACCDET_CON23 +#define ACCDET_EINT1_CMPEN_SW_SFT 10 +#define ACCDET_EINT1_CMPEN_SW_MASK 0x1 +#define ACCDET_EINT1_CMPEN_SW_MASK_SFT (0x1 << 10) +#define ACCDET_EINT1_CMPMEN_SW_ADDR \ + MT6359_ACCDET_CON23 +#define ACCDET_EINT1_CMPMEN_SW_SFT 11 +#define ACCDET_EINT1_CMPMEN_SW_MASK 0x1 +#define ACCDET_EINT1_CMPMEN_SW_MASK_SFT (0x1 << 11) +#define ACCDET_EINT1_CTURBO_SW_ADDR \ + MT6359_ACCDET_CON23 +#define ACCDET_EINT1_CTURBO_SW_SFT 12 +#define ACCDET_EINT1_CTURBO_SW_MASK 0x1 +#define ACCDET_EINT1_CTURBO_SW_MASK_SFT (0x1 << 12) +#define ACCDET_B_SW_ADDR \ + MT6359_ACCDET_CON24 +#define ACCDET_B_SW_SFT 0 +#define ACCDET_B_SW_MASK 0x1 +#define ACCDET_B_SW_MASK_SFT (0x1 << 0) +#define ACCDET_A_SW_ADDR \ + MT6359_ACCDET_CON24 +#define ACCDET_A_SW_SFT 1 +#define ACCDET_A_SW_MASK 0x1 +#define ACCDET_A_SW_MASK_SFT (0x1 << 1) +#define ACCDET_EINT0_CMPOUT_SW_ADDR \ + MT6359_ACCDET_CON24 +#define ACCDET_EINT0_CMPOUT_SW_SFT 2 +#define ACCDET_EINT0_CMPOUT_SW_MASK 0x1 +#define ACCDET_EINT0_CMPOUT_SW_MASK_SFT (0x1 << 2) +#define ACCDET_EINT0_CMPMOUT_SW_ADDR \ + MT6359_ACCDET_CON24 +#define ACCDET_EINT0_CMPMOUT_SW_SFT 3 +#define ACCDET_EINT0_CMPMOUT_SW_MASK 0x1 +#define ACCDET_EINT0_CMPMOUT_SW_MASK_SFT (0x1 << 3) +#define ACCDET_EINT0_INVOUT_SW_ADDR \ + MT6359_ACCDET_CON24 +#define ACCDET_EINT0_INVOUT_SW_SFT 4 +#define ACCDET_EINT0_INVOUT_SW_MASK 0x1 +#define ACCDET_EINT0_INVOUT_SW_MASK_SFT (0x1 << 4) +#define ACCDET_EINT1_CMPOUT_SW_ADDR \ + MT6359_ACCDET_CON24 +#define ACCDET_EINT1_CMPOUT_SW_SFT 5 +#define ACCDET_EINT1_CMPOUT_SW_MASK 0x1 +#define ACCDET_EINT1_CMPOUT_SW_MASK_SFT (0x1 << 5) +#define ACCDET_EINT1_CMPMOUT_SW_ADDR \ + MT6359_ACCDET_CON24 +#define ACCDET_EINT1_CMPMOUT_SW_SFT 6 +#define ACCDET_EINT1_CMPMOUT_SW_MASK 0x1 +#define ACCDET_EINT1_CMPMOUT_SW_MASK_SFT (0x1 << 6) +#define ACCDET_EINT1_INVOUT_SW_ADDR \ + MT6359_ACCDET_CON24 +#define ACCDET_EINT1_INVOUT_SW_SFT 7 +#define ACCDET_EINT1_INVOUT_SW_MASK 0x1 +#define ACCDET_EINT1_INVOUT_SW_MASK_SFT (0x1 << 7) +#define AD_AUDACCDETCMPOB_ADDR \ + MT6359_ACCDET_CON25 +#define AD_AUDACCDETCMPOB_SFT 0 +#define AD_AUDACCDETCMPOB_MASK 0x1 +#define AD_AUDACCDETCMPOB_MASK_SFT (0x1 << 0) +#define AD_AUDACCDETCMPOA_ADDR \ + MT6359_ACCDET_CON25 +#define AD_AUDACCDETCMPOA_SFT 1 +#define AD_AUDACCDETCMPOA_MASK 0x1 +#define AD_AUDACCDETCMPOA_MASK_SFT (0x1 << 1) +#define ACCDET_CUR_IN_ADDR \ + MT6359_ACCDET_CON25 +#define ACCDET_CUR_IN_SFT 2 +#define ACCDET_CUR_IN_MASK 0x3 +#define ACCDET_CUR_IN_MASK_SFT (0x3 << 2) +#define ACCDET_SAM_IN_ADDR \ + MT6359_ACCDET_CON25 +#define ACCDET_SAM_IN_SFT 4 +#define ACCDET_SAM_IN_MASK 0x3 +#define ACCDET_SAM_IN_MASK_SFT (0x3 << 4) +#define ACCDET_MEM_IN_ADDR \ + MT6359_ACCDET_CON25 +#define ACCDET_MEM_IN_SFT 6 +#define ACCDET_MEM_IN_MASK 0x3 +#define ACCDET_MEM_IN_MASK_SFT (0x3 << 6) +#define ACCDET_STATE_ADDR \ + MT6359_ACCDET_CON25 +#define ACCDET_STATE_SFT 8 +#define ACCDET_STATE_MASK 0x7 +#define ACCDET_STATE_MASK_SFT (0x7 << 8) +#define DA_AUDACCDETMBIASCLK_ADDR \ + MT6359_ACCDET_CON25 +#define DA_AUDACCDETMBIASCLK_SFT 12 +#define DA_AUDACCDETMBIASCLK_MASK 0x1 +#define DA_AUDACCDETMBIASCLK_MASK_SFT (0x1 << 12) +#define DA_AUDACCDETVTHCLK_ADDR \ + MT6359_ACCDET_CON25 +#define DA_AUDACCDETVTHCLK_SFT 13 +#define DA_AUDACCDETVTHCLK_MASK 0x1 +#define DA_AUDACCDETVTHCLK_MASK_SFT (0x1 << 13) +#define DA_AUDACCDETCMPCLK_ADDR \ + MT6359_ACCDET_CON25 +#define DA_AUDACCDETCMPCLK_SFT 14 +#define DA_AUDACCDETCMPCLK_MASK 0x1 +#define DA_AUDACCDETCMPCLK_MASK_SFT (0x1 << 14) +#define DA_AUDACCDETAUXADCSWCTRL_ADDR \ + MT6359_ACCDET_CON25 +#define DA_AUDACCDETAUXADCSWCTRL_SFT 15 +#define DA_AUDACCDETAUXADCSWCTRL_MASK 0x1 +#define DA_AUDACCDETAUXADCSWCTRL_MASK_SFT (0x1 << 15) +#define AD_EINT0CMPMOUT_ADDR \ + MT6359_ACCDET_CON26 +#define AD_EINT0CMPMOUT_SFT 0 +#define AD_EINT0CMPMOUT_MASK 0x1 +#define AD_EINT0CMPMOUT_MASK_SFT (0x1 << 0) +#define AD_EINT0CMPOUT_ADDR \ + MT6359_ACCDET_CON26 +#define AD_EINT0CMPOUT_SFT 1 +#define AD_EINT0CMPOUT_MASK 0x1 +#define AD_EINT0CMPOUT_MASK_SFT (0x1 << 1) +#define ACCDET_EINT0_CUR_IN_ADDR \ + MT6359_ACCDET_CON26 +#define ACCDET_EINT0_CUR_IN_SFT 2 +#define ACCDET_EINT0_CUR_IN_MASK 0x3 +#define ACCDET_EINT0_CUR_IN_MASK_SFT (0x3 << 2) +#define ACCDET_EINT0_SAM_IN_ADDR \ + MT6359_ACCDET_CON26 +#define ACCDET_EINT0_SAM_IN_SFT 4 +#define ACCDET_EINT0_SAM_IN_MASK 0x3 +#define ACCDET_EINT0_SAM_IN_MASK_SFT (0x3 << 4) +#define ACCDET_EINT0_MEM_IN_ADDR \ + MT6359_ACCDET_CON26 +#define ACCDET_EINT0_MEM_IN_SFT 6 +#define ACCDET_EINT0_MEM_IN_MASK 0x3 +#define ACCDET_EINT0_MEM_IN_MASK_SFT (0x3 << 6) +#define ACCDET_EINT0_STATE_ADDR \ + MT6359_ACCDET_CON26 +#define ACCDET_EINT0_STATE_SFT 8 +#define ACCDET_EINT0_STATE_MASK 0x7 +#define ACCDET_EINT0_STATE_MASK_SFT (0x7 << 8) +#define DA_EINT0CMPEN_ADDR \ + MT6359_ACCDET_CON26 +#define DA_EINT0CMPEN_SFT 13 +#define DA_EINT0CMPEN_MASK 0x1 +#define DA_EINT0CMPEN_MASK_SFT (0x1 << 13) +#define DA_EINT0CMPMEN_ADDR \ + MT6359_ACCDET_CON26 +#define DA_EINT0CMPMEN_SFT 14 +#define DA_EINT0CMPMEN_MASK 0x1 +#define DA_EINT0CMPMEN_MASK_SFT (0x1 << 14) +#define DA_EINT0CTURBO_ADDR \ + MT6359_ACCDET_CON26 +#define DA_EINT0CTURBO_SFT 15 +#define DA_EINT0CTURBO_MASK 0x1 +#define DA_EINT0CTURBO_MASK_SFT (0x1 << 15) +#define AD_EINT1CMPMOUT_ADDR \ + MT6359_ACCDET_CON27 +#define AD_EINT1CMPMOUT_SFT 0 +#define AD_EINT1CMPMOUT_MASK 0x1 +#define AD_EINT1CMPMOUT_MASK_SFT (0x1 << 0) +#define AD_EINT1CMPOUT_ADDR \ + MT6359_ACCDET_CON27 +#define AD_EINT1CMPOUT_SFT 1 +#define AD_EINT1CMPOUT_MASK 0x1 +#define AD_EINT1CMPOUT_MASK_SFT (0x1 << 1) +#define ACCDET_EINT1_CUR_IN_ADDR \ + MT6359_ACCDET_CON27 +#define ACCDET_EINT1_CUR_IN_SFT 2 +#define ACCDET_EINT1_CUR_IN_MASK 0x3 +#define ACCDET_EINT1_CUR_IN_MASK_SFT (0x3 << 2) +#define ACCDET_EINT1_SAM_IN_ADDR \ + MT6359_ACCDET_CON27 +#define ACCDET_EINT1_SAM_IN_SFT 4 +#define ACCDET_EINT1_SAM_IN_MASK 0x3 +#define ACCDET_EINT1_SAM_IN_MASK_SFT (0x3 << 4) +#define ACCDET_EINT1_MEM_IN_ADDR \ + MT6359_ACCDET_CON27 +#define ACCDET_EINT1_MEM_IN_SFT 6 +#define ACCDET_EINT1_MEM_IN_MASK 0x3 +#define ACCDET_EINT1_MEM_IN_MASK_SFT (0x3 << 6) +#define ACCDET_EINT1_STATE_ADDR \ + MT6359_ACCDET_CON27 +#define ACCDET_EINT1_STATE_SFT 8 +#define ACCDET_EINT1_STATE_MASK 0x7 +#define ACCDET_EINT1_STATE_MASK_SFT (0x7 << 8) +#define DA_EINT1CMPEN_ADDR \ + MT6359_ACCDET_CON27 +#define DA_EINT1CMPEN_SFT 13 +#define DA_EINT1CMPEN_MASK 0x1 +#define DA_EINT1CMPEN_MASK_SFT (0x1 << 13) +#define DA_EINT1CMPMEN_ADDR \ + MT6359_ACCDET_CON27 +#define DA_EINT1CMPMEN_SFT 14 +#define DA_EINT1CMPMEN_MASK 0x1 +#define DA_EINT1CMPMEN_MASK_SFT (0x1 << 14) +#define DA_EINT1CTURBO_ADDR \ + MT6359_ACCDET_CON27 +#define DA_EINT1CTURBO_SFT 15 +#define DA_EINT1CTURBO_MASK 0x1 +#define DA_EINT1CTURBO_MASK_SFT (0x1 << 15) +#define AD_EINT0INVOUT_ADDR \ + MT6359_ACCDET_CON28 +#define AD_EINT0INVOUT_SFT 0 +#define AD_EINT0INVOUT_MASK 0x1 +#define AD_EINT0INVOUT_MASK_SFT (0x1 << 0) +#define ACCDET_EINT0_INVERTER_CUR_IN_ADDR \ + MT6359_ACCDET_CON28 +#define ACCDET_EINT0_INVERTER_CUR_IN_SFT 1 +#define ACCDET_EINT0_INVERTER_CUR_IN_MASK 0x1 +#define ACCDET_EINT0_INVERTER_CUR_IN_MASK_SFT (0x1 << 1) +#define ACCDET_EINT0_INVERTER_SAM_IN_ADDR \ + MT6359_ACCDET_CON28 +#define ACCDET_EINT0_INVERTER_SAM_IN_SFT 2 +#define ACCDET_EINT0_INVERTER_SAM_IN_MASK 0x1 +#define ACCDET_EINT0_INVERTER_SAM_IN_MASK_SFT (0x1 << 2) +#define ACCDET_EINT0_INVERTER_MEM_IN_ADDR \ + MT6359_ACCDET_CON28 +#define ACCDET_EINT0_INVERTER_MEM_IN_SFT 3 +#define ACCDET_EINT0_INVERTER_MEM_IN_MASK 0x1 +#define ACCDET_EINT0_INVERTER_MEM_IN_MASK_SFT (0x1 << 3) +#define ACCDET_EINT0_INVERTER_STATE_ADDR \ + MT6359_ACCDET_CON28 +#define ACCDET_EINT0_INVERTER_STATE_SFT 8 +#define ACCDET_EINT0_INVERTER_STATE_MASK 0x7 +#define ACCDET_EINT0_INVERTER_STATE_MASK_SFT (0x7 << 8) +#define DA_EINT0EN_ADDR \ + MT6359_ACCDET_CON28 +#define DA_EINT0EN_SFT 12 +#define DA_EINT0EN_MASK 0x1 +#define DA_EINT0EN_MASK_SFT (0x1 << 12) +#define DA_EINT0INVEN_ADDR \ + MT6359_ACCDET_CON28 +#define DA_EINT0INVEN_SFT 13 +#define DA_EINT0INVEN_MASK 0x1 +#define DA_EINT0INVEN_MASK_SFT (0x1 << 13) +#define DA_EINT0CEN_ADDR \ + MT6359_ACCDET_CON28 +#define DA_EINT0CEN_SFT 14 +#define DA_EINT0CEN_MASK 0x1 +#define DA_EINT0CEN_MASK_SFT (0x1 << 14) +#define AD_EINT1INVOUT_ADDR \ + MT6359_ACCDET_CON29 +#define AD_EINT1INVOUT_SFT 0 +#define AD_EINT1INVOUT_MASK 0x1 +#define AD_EINT1INVOUT_MASK_SFT (0x1 << 0) +#define ACCDET_EINT1_INVERTER_CUR_IN_ADDR \ + MT6359_ACCDET_CON29 +#define ACCDET_EINT1_INVERTER_CUR_IN_SFT 1 +#define ACCDET_EINT1_INVERTER_CUR_IN_MASK 0x1 +#define ACCDET_EINT1_INVERTER_CUR_IN_MASK_SFT (0x1 << 1) +#define ACCDET_EINT1_INVERTER_SAM_IN_ADDR \ + MT6359_ACCDET_CON29 +#define ACCDET_EINT1_INVERTER_SAM_IN_SFT 2 +#define ACCDET_EINT1_INVERTER_SAM_IN_MASK 0x1 +#define ACCDET_EINT1_INVERTER_SAM_IN_MASK_SFT (0x1 << 2) +#define ACCDET_EINT1_INVERTER_MEM_IN_ADDR \ + MT6359_ACCDET_CON29 +#define ACCDET_EINT1_INVERTER_MEM_IN_SFT 3 +#define ACCDET_EINT1_INVERTER_MEM_IN_MASK 0x1 +#define ACCDET_EINT1_INVERTER_MEM_IN_MASK_SFT (0x1 << 3) +#define ACCDET_EINT1_INVERTER_STATE_ADDR \ + MT6359_ACCDET_CON29 +#define ACCDET_EINT1_INVERTER_STATE_SFT 8 +#define ACCDET_EINT1_INVERTER_STATE_MASK 0x7 +#define ACCDET_EINT1_INVERTER_STATE_MASK_SFT (0x7 << 8) +#define DA_EINT1EN_ADDR \ + MT6359_ACCDET_CON29 +#define DA_EINT1EN_SFT 12 +#define DA_EINT1EN_MASK 0x1 +#define DA_EINT1EN_MASK_SFT (0x1 << 12) +#define DA_EINT1INVEN_ADDR \ + MT6359_ACCDET_CON29 +#define DA_EINT1INVEN_SFT 13 +#define DA_EINT1INVEN_MASK 0x1 +#define DA_EINT1INVEN_MASK_SFT (0x1 << 13) +#define DA_EINT1CEN_ADDR \ + MT6359_ACCDET_CON29 +#define DA_EINT1CEN_SFT 14 +#define DA_EINT1CEN_MASK 0x1 +#define DA_EINT1CEN_MASK_SFT (0x1 << 14) +#define ACCDET_EN_ADDR \ + MT6359_ACCDET_CON30 +#define ACCDET_EN_SFT 0 +#define ACCDET_EN_MASK 0x1 +#define ACCDET_EN_MASK_SFT (0x1 << 0) +#define ACCDET_EINT0_EN_ADDR \ + MT6359_ACCDET_CON30 +#define ACCDET_EINT0_EN_SFT 1 +#define ACCDET_EINT0_EN_MASK 0x1 +#define ACCDET_EINT0_EN_MASK_SFT (0x1 << 1) +#define ACCDET_EINT1_EN_ADDR \ + MT6359_ACCDET_CON30 +#define ACCDET_EINT1_EN_SFT 2 +#define ACCDET_EINT1_EN_MASK 0x1 +#define ACCDET_EINT1_EN_MASK_SFT (0x1 << 2) +#define ACCDET_EINT0_M_EN_ADDR \ + MT6359_ACCDET_CON30 +#define ACCDET_EINT0_M_EN_SFT 3 +#define ACCDET_EINT0_M_EN_MASK 0x1 +#define ACCDET_EINT0_M_EN_MASK_SFT (0x1 << 3) +#define ACCDET_EINT0_DETECT_MOISTURE_ADDR \ + MT6359_ACCDET_CON30 +#define ACCDET_EINT0_DETECT_MOISTURE_SFT 4 +#define ACCDET_EINT0_DETECT_MOISTURE_MASK 0x1 +#define ACCDET_EINT0_DETECT_MOISTURE_MASK_SFT (0x1 << 4) +#define ACCDET_EINT0_PLUG_IN_ADDR \ + MT6359_ACCDET_CON30 +#define ACCDET_EINT0_PLUG_IN_SFT 5 +#define ACCDET_EINT0_PLUG_IN_MASK 0x1 +#define ACCDET_EINT0_PLUG_IN_MASK_SFT (0x1 << 5) +#define ACCDET_EINT0_M_PLUG_IN_ADDR \ + MT6359_ACCDET_CON30 +#define ACCDET_EINT0_M_PLUG_IN_SFT 6 +#define ACCDET_EINT0_M_PLUG_IN_MASK 0x1 +#define ACCDET_EINT0_M_PLUG_IN_MASK_SFT (0x1 << 6) +#define ACCDET_EINT1_M_EN_ADDR \ + MT6359_ACCDET_CON30 +#define ACCDET_EINT1_M_EN_SFT 7 +#define ACCDET_EINT1_M_EN_MASK 0x1 +#define ACCDET_EINT1_M_EN_MASK_SFT (0x1 << 7) +#define ACCDET_EINT1_DETECT_MOISTURE_ADDR \ + MT6359_ACCDET_CON30 +#define ACCDET_EINT1_DETECT_MOISTURE_SFT 8 +#define ACCDET_EINT1_DETECT_MOISTURE_MASK 0x1 +#define ACCDET_EINT1_DETECT_MOISTURE_MASK_SFT (0x1 << 8) +#define ACCDET_EINT1_PLUG_IN_ADDR \ + MT6359_ACCDET_CON30 +#define ACCDET_EINT1_PLUG_IN_SFT 9 +#define ACCDET_EINT1_PLUG_IN_MASK 0x1 +#define ACCDET_EINT1_PLUG_IN_MASK_SFT (0x1 << 9) +#define ACCDET_EINT1_M_PLUG_IN_ADDR \ + MT6359_ACCDET_CON30 +#define ACCDET_EINT1_M_PLUG_IN_SFT 10 +#define ACCDET_EINT1_M_PLUG_IN_MASK 0x1 +#define ACCDET_EINT1_M_PLUG_IN_MASK_SFT (0x1 << 10) +#define ACCDET_CUR_DEB_ADDR \ + MT6359_ACCDET_CON31 +#define ACCDET_CUR_DEB_SFT 0 +#define ACCDET_CUR_DEB_MASK 0xFFFF +#define ACCDET_CUR_DEB_MASK_SFT (0xFFFF << 0) +#define ACCDET_EINT0_CUR_DEB_ADDR \ + MT6359_ACCDET_CON32 +#define ACCDET_EINT0_CUR_DEB_SFT 0 +#define ACCDET_EINT0_CUR_DEB_MASK 0x7FFF +#define ACCDET_EINT0_CUR_DEB_MASK_SFT (0x7FFF << 0) +#define ACCDET_EINT1_CUR_DEB_ADDR \ + MT6359_ACCDET_CON33 +#define ACCDET_EINT1_CUR_DEB_SFT 0 +#define ACCDET_EINT1_CUR_DEB_MASK 0x7FFF +#define ACCDET_EINT1_CUR_DEB_MASK_SFT (0x7FFF << 0) +#define ACCDET_EINT0_INVERTER_CUR_DEB_ADDR \ + MT6359_ACCDET_CON34 +#define ACCDET_EINT0_INVERTER_CUR_DEB_SFT 0 +#define ACCDET_EINT0_INVERTER_CUR_DEB_MASK 0x7FFF +#define ACCDET_EINT0_INVERTER_CUR_DEB_MASK_SFT (0x7FFF << 0) +#define ACCDET_EINT1_INVERTER_CUR_DEB_ADDR \ + MT6359_ACCDET_CON35 +#define ACCDET_EINT1_INVERTER_CUR_DEB_SFT 0 +#define ACCDET_EINT1_INVERTER_CUR_DEB_MASK 0x7FFF +#define ACCDET_EINT1_INVERTER_CUR_DEB_MASK_SFT (0x7FFF << 0) +#define AD_AUDACCDETCMPOB_MON_ADDR \ + MT6359_ACCDET_CON36 +#define AD_AUDACCDETCMPOB_MON_SFT 0 +#define AD_AUDACCDETCMPOB_MON_MASK 0x1 +#define AD_AUDACCDETCMPOB_MON_MASK_SFT (0x1 << 0) +#define AD_AUDACCDETCMPOA_MON_ADDR \ + MT6359_ACCDET_CON36 +#define AD_AUDACCDETCMPOA_MON_SFT 1 +#define AD_AUDACCDETCMPOA_MON_MASK 0x1 +#define AD_AUDACCDETCMPOA_MON_MASK_SFT (0x1 << 1) +#define AD_EINT0CMPMOUT_MON_ADDR \ + MT6359_ACCDET_CON36 +#define AD_EINT0CMPMOUT_MON_SFT 2 +#define AD_EINT0CMPMOUT_MON_MASK 0x1 +#define AD_EINT0CMPMOUT_MON_MASK_SFT (0x1 << 2) +#define AD_EINT0CMPOUT_MON_ADDR \ + MT6359_ACCDET_CON36 +#define AD_EINT0CMPOUT_MON_SFT 3 +#define AD_EINT0CMPOUT_MON_MASK 0x1 +#define AD_EINT0CMPOUT_MON_MASK_SFT (0x1 << 3) +#define AD_EINT0INVOUT_MON_ADDR \ + MT6359_ACCDET_CON36 +#define AD_EINT0INVOUT_MON_SFT 4 +#define AD_EINT0INVOUT_MON_MASK 0x1 +#define AD_EINT0INVOUT_MON_MASK_SFT (0x1 << 4) +#define AD_EINT1CMPMOUT_MON_ADDR \ + MT6359_ACCDET_CON36 +#define AD_EINT1CMPMOUT_MON_SFT 5 +#define AD_EINT1CMPMOUT_MON_MASK 0x1 +#define AD_EINT1CMPMOUT_MON_MASK_SFT (0x1 << 5) +#define AD_EINT1CMPOUT_MON_ADDR \ + MT6359_ACCDET_CON36 +#define AD_EINT1CMPOUT_MON_SFT 6 +#define AD_EINT1CMPOUT_MON_MASK 0x1 +#define AD_EINT1CMPOUT_MON_MASK_SFT (0x1 << 6) +#define AD_EINT1INVOUT_MON_ADDR \ + MT6359_ACCDET_CON36 +#define AD_EINT1INVOUT_MON_SFT 7 +#define AD_EINT1INVOUT_MON_MASK 0x1 +#define AD_EINT1INVOUT_MON_MASK_SFT (0x1 << 7) +#define DA_AUDACCDETCMPCLK_MON_ADDR \ + MT6359_ACCDET_CON37 +#define DA_AUDACCDETCMPCLK_MON_SFT 0 +#define DA_AUDACCDETCMPCLK_MON_MASK 0x1 +#define DA_AUDACCDETCMPCLK_MON_MASK_SFT (0x1 << 0) +#define DA_AUDACCDETVTHCLK_MON_ADDR \ + MT6359_ACCDET_CON37 +#define DA_AUDACCDETVTHCLK_MON_SFT 1 +#define DA_AUDACCDETVTHCLK_MON_MASK 0x1 +#define DA_AUDACCDETVTHCLK_MON_MASK_SFT (0x1 << 1) +#define DA_AUDACCDETMBIASCLK_MON_ADDR \ + MT6359_ACCDET_CON37 +#define DA_AUDACCDETMBIASCLK_MON_SFT 2 +#define DA_AUDACCDETMBIASCLK_MON_MASK 0x1 +#define DA_AUDACCDETMBIASCLK_MON_MASK_SFT (0x1 << 2) +#define DA_AUDACCDETAUXADCSWCTRL_MON_ADDR \ + MT6359_ACCDET_CON37 +#define DA_AUDACCDETAUXADCSWCTRL_MON_SFT 3 +#define DA_AUDACCDETAUXADCSWCTRL_MON_MASK 0x1 +#define DA_AUDACCDETAUXADCSWCTRL_MON_MASK_SFT (0x1 << 3) +#define DA_EINT0CTURBO_MON_ADDR \ + MT6359_ACCDET_CON38 +#define DA_EINT0CTURBO_MON_SFT 0 +#define DA_EINT0CTURBO_MON_MASK 0x1 +#define DA_EINT0CTURBO_MON_MASK_SFT (0x1 << 0) +#define DA_EINT0CMPMEN_MON_ADDR \ + MT6359_ACCDET_CON38 +#define DA_EINT0CMPMEN_MON_SFT 1 +#define DA_EINT0CMPMEN_MON_MASK 0x1 +#define DA_EINT0CMPMEN_MON_MASK_SFT (0x1 << 1) +#define DA_EINT0CMPEN_MON_ADDR \ + MT6359_ACCDET_CON38 +#define DA_EINT0CMPEN_MON_SFT 2 +#define DA_EINT0CMPEN_MON_MASK 0x1 +#define DA_EINT0CMPEN_MON_MASK_SFT (0x1 << 2) +#define DA_EINT0INVEN_MON_ADDR \ + MT6359_ACCDET_CON38 +#define DA_EINT0INVEN_MON_SFT 3 +#define DA_EINT0INVEN_MON_MASK 0x1 +#define DA_EINT0INVEN_MON_MASK_SFT (0x1 << 3) +#define DA_EINT0CEN_MON_ADDR \ + MT6359_ACCDET_CON38 +#define DA_EINT0CEN_MON_SFT 4 +#define DA_EINT0CEN_MON_MASK 0x1 +#define DA_EINT0CEN_MON_MASK_SFT (0x1 << 4) +#define DA_EINT0EN_MON_ADDR \ + MT6359_ACCDET_CON38 +#define DA_EINT0EN_MON_SFT 5 +#define DA_EINT0EN_MON_MASK 0x1 +#define DA_EINT0EN_MON_MASK_SFT (0x1 << 5) +#define DA_EINT1CTURBO_MON_ADDR \ + MT6359_ACCDET_CON38 +#define DA_EINT1CTURBO_MON_SFT 8 +#define DA_EINT1CTURBO_MON_MASK 0x1 +#define DA_EINT1CTURBO_MON_MASK_SFT (0x1 << 8) +#define DA_EINT1CMPMEN_MON_ADDR \ + MT6359_ACCDET_CON38 +#define DA_EINT1CMPMEN_MON_SFT 9 +#define DA_EINT1CMPMEN_MON_MASK 0x1 +#define DA_EINT1CMPMEN_MON_MASK_SFT (0x1 << 9) +#define DA_EINT1CMPEN_MON_ADDR \ + MT6359_ACCDET_CON38 +#define DA_EINT1CMPEN_MON_SFT 10 +#define DA_EINT1CMPEN_MON_MASK 0x1 +#define DA_EINT1CMPEN_MON_MASK_SFT (0x1 << 10) +#define DA_EINT1INVEN_MON_ADDR \ + MT6359_ACCDET_CON38 +#define DA_EINT1INVEN_MON_SFT 11 +#define DA_EINT1INVEN_MON_MASK 0x1 +#define DA_EINT1INVEN_MON_MASK_SFT (0x1 << 11) +#define DA_EINT1CEN_MON_ADDR \ + MT6359_ACCDET_CON38 +#define DA_EINT1CEN_MON_SFT 12 +#define DA_EINT1CEN_MON_MASK 0x1 +#define DA_EINT1CEN_MON_MASK_SFT (0x1 << 12) +#define DA_EINT1EN_MON_ADDR \ + MT6359_ACCDET_CON38 +#define DA_EINT1EN_MON_SFT 13 +#define DA_EINT1EN_MON_MASK 0x1 +#define DA_EINT1EN_MON_MASK_SFT (0x1 << 13) +#define ACCDET_EINT0_M_PLUG_IN_COUNT_ADDR \ + MT6359_ACCDET_CON39 +#define ACCDET_EINT0_M_PLUG_IN_COUNT_SFT 0 +#define ACCDET_EINT0_M_PLUG_IN_COUNT_MASK 0x7 +#define ACCDET_EINT0_M_PLUG_IN_COUNT_MASK_SFT (0x7 << 0) +#define ACCDET_EINT1_M_PLUG_IN_COUNT_ADDR \ + MT6359_ACCDET_CON39 +#define ACCDET_EINT1_M_PLUG_IN_COUNT_SFT 4 +#define ACCDET_EINT1_M_PLUG_IN_COUNT_MASK 0x7 +#define ACCDET_EINT1_M_PLUG_IN_COUNT_MASK_SFT (0x7 << 4) +#define ACCDET_MON_FLAG_EN_ADDR \ + MT6359_ACCDET_CON40 +#define ACCDET_MON_FLAG_EN_SFT 0 +#define ACCDET_MON_FLAG_EN_MASK 0x1 +#define ACCDET_MON_FLAG_EN_MASK_SFT (0x1 << 0) +#define ACCDET_MON_FLAG_SEL_ADDR \ + MT6359_ACCDET_CON40 +#define ACCDET_MON_FLAG_SEL_SFT 4 +#define ACCDET_MON_FLAG_SEL_MASK 0xF +#define ACCDET_MON_FLAG_SEL_MASK_SFT (0xF << 4) + +#define RG_AUDPWDBMICBIAS0_ADDR \ + MT6359_AUDENC_ANA_CON15 +#define RG_AUDPWDBMICBIAS0_SFT 0 +#define RG_AUDPWDBMICBIAS0_MASK 0x1 +#define RG_AUDPWDBMICBIAS0_MASK_SFT (0x1 << 0) +#define RG_AUDPREAMPLON_ADDR \ + MT6359_AUDENC_ANA_CON0 +#define RG_AUDPREAMPLON_SFT 0 +#define RG_AUDPREAMPLON_MASK 0x1 +#define RG_AUDPREAMPLON_MASK_SFT (0x1 << 0) +#define RG_CLKSQ_EN_ADDR \ + MT6359_AUDENC_ANA_CON23 +#define RG_CLKSQ_EN_SFT 0 +#define RG_CLKSQ_EN_MASK 0x1 +#define RG_CLKSQ_EN_MASK_SFT (0x1 << 0) +#define RG_RTC32K_CK_PDN_ADDR \ + MT6359_TOP_CKPDN_CON0 +#define RG_RTC32K_CK_PDN_SFT 15 +#define RG_RTC32K_CK_PDN_MASK 0x1 +#define RG_RTC32K_CK_PDN_MASK_SFT (0x1 << 15) +#define RG_HPLOUTPUTSTBENH_VAUDP32_ADDR \ + MT6359_AUDDEC_ANA_CON2 +#define RG_HPLOUTPUTSTBENH_VAUDP32_SFT 0 +#define RG_HPLOUTPUTSTBENH_VAUDP32_MASK 0x7 +#define RG_HPLOUTPUTSTBENH_VAUDP32_MASK_SFT (0x7 << 0) +#define AUXADC_RQST_CH5_ADDR \ + MT6359_AUXADC_RQST0 +#define AUXADC_RQST_CH5_SFT 5 +#define AUXADC_RQST_CH5_MASK 0x1 +#define AUXADC_RQST_CH5_MASK_SFT (0x1 << 5) +#define RG_LDO_VUSB_HW0_OP_EN_ADDR \ + MT6359_LDO_VUSB_OP_EN +#define RG_LDO_VUSB_HW0_OP_EN_SFT 0 +#define RG_LDO_VUSB_HW0_OP_EN_MASK 0x1 +#define RG_LDO_VUSB_HW0_OP_EN_MASK_SFT (0x1 << 0) +#define RG_HPROUTPUTSTBENH_VAUDP32_ADDR \ + MT6359_AUDDEC_ANA_CON2 +#define RG_HPROUTPUTSTBENH_VAUDP32_SFT 4 +#define RG_HPROUTPUTSTBENH_VAUDP32_MASK 0x7 +#define RG_HPROUTPUTSTBENH_VAUDP32_MASK_SFT (0x7 << 4) +#define RG_NCP_PDDIS_EN_ADDR \ + MT6359_AFE_NCP_CFG2 +#define RG_NCP_PDDIS_EN_SFT 0 +#define RG_NCP_PDDIS_EN_MASK 0x1 +#define RG_NCP_PDDIS_EN_MASK_SFT (0x1 << 0) +#define RG_SCK32K_CK_PDN_ADDR \ + MT6359_TOP_CKPDN_CON0 +#define RG_SCK32K_CK_PDN_SFT 0 +#define RG_SCK32K_CK_PDN_MASK 0x1 +#define RG_SCK32K_CK_PDN_MASK_SFT (0x1 << 0) /* AUDENC_ANA_CON18: */ -#define RG_ACCDET_MODE_ANA11_MODE1 (0x000f) -#define RG_ACCDET_MODE_ANA11_MODE2 (0x008f) -#define RG_ACCDET_MODE_ANA11_MODE6 (0x008f) +#define RG_ACCDET_MODE_ANA11_MODE1 (0x000F) +#define RG_ACCDET_MODE_ANA11_MODE2 (0x008F) +#define RG_ACCDET_MODE_ANA11_MODE6 (0x008F) /* AUXADC_ADC5: Auxadc CH5 read data */ #define AUXADC_DATA_RDY_CH5 BIT(15) #define AUXADC_DATA_PROCEED_CH5 BIT(15) -#define AUXADC_DATA_MASK (0x0fff) +#define AUXADC_DATA_MASK (0x0FFF) /* AUXADC_RQST0_SET: Auxadc CH5 request, relevant 0x07EC */ #define AUXADC_RQST_CH5_SET BIT(5) /* AUXADC_RQST0_CLR: Auxadc CH5 request, relevant 0x07EC */ #define AUXADC_RQST_CH5_CLR BIT(5) -#define ACCDET_CALI_MASK0 (0xff) -#define ACCDET_CALI_MASK1 (0xff << 8) -#define ACCDET_CALI_MASK2 (0xff) -#define ACCDET_CALI_MASK3 (0xff << 8) -#define ACCDET_CALI_MASK4 (0xff) - -#define ACCDET_EINT1_IRQ_CLR_B11 BIT(PMIC_ACCDET_EINT1_IRQ_CLR_SHIFT) -#define ACCDET_EINT0_IRQ_CLR_B10 BIT(PMIC_ACCDET_EINT0_IRQ_CLR_SHIFT) -#define ACCDET_EINT_IRQ_CLR_B10_11 (0x03 << \ - PMIC_ACCDET_EINT0_IRQ_CLR_SHIFT) -#define ACCDET_IRQ_CLR_B8 BIT(PMIC_ACCDET_IRQ_CLR_SHIFT) +#define ACCDET_CALI_MASK0 (0xFF) +#define ACCDET_CALI_MASK1 (0xFF << 8) +#define ACCDET_CALI_MASK2 (0xFF) +#define ACCDET_CALI_MASK3 (0xFF << 8) +#define ACCDET_CALI_MASK4 (0xFF) -#define ACCDET_EINT1_IRQ_B3 BIT(PMIC_ACCDET_EINT1_IRQ_SHIFT) -#define ACCDET_EINT0_IRQ_B2 BIT(PMIC_ACCDET_EINT0_IRQ_SHIFT) -#define ACCDET_EINT_IRQ_B2_B3 (0x03 << PMIC_ACCDET_EINT0_IRQ_SHIFT) -#define ACCDET_IRQ_B0 BIT(PMIC_ACCDET_IRQ_SHIFT) +#define ACCDET_EINT_IRQ_B2_B3 (0x03 << ACCDET_EINT0_IRQ_SFT) /* ACCDET_CON25: RO, accdet FSM state,etc.*/ -#define ACCDET_STATE_MEM_IN_OFFSET (PMIC_ACCDET_MEM_IN_SHIFT) -#define ACCDET_STATE_AB_MASK (0x03) -#define ACCDET_STATE_AB_00 (0x00) -#define ACCDET_STATE_AB_01 (0x01) -#define ACCDET_STATE_AB_10 (0x02) -#define ACCDET_STATE_AB_11 (0x03) +#define ACCDET_STATE_MEM_IN_OFFSET (ACCDET_MEM_IN_SFT) +#define ACCDET_STATE_AB_MASK (0x03) +#define ACCDET_STATE_AB_00 (0x00) +#define ACCDET_STATE_AB_01 (0x01) +#define ACCDET_STATE_AB_10 (0x02) +#define ACCDET_STATE_AB_11 (0x03) /* ACCDET_CON19 */ -#define ACCDET_EINT0_STABLE_VAL ((1 << PMIC_ACCDET_DA_STABLE_SHIFT) | \ - (1 << PMIC_ACCDET_EINT0_EN_STABLE_SHIFT) | \ - (1 << PMIC_ACCDET_EINT0_CMPEN_STABLE_SHIFT) | \ - (1 << PMIC_ACCDET_EINT0_CEN_STABLE_SHIFT)) - -#define ACCDET_EINT1_STABLE_VAL ((1 << PMIC_ACCDET_DA_STABLE_SHIFT) | \ - (1 << PMIC_ACCDET_EINT1_EN_STABLE_SHIFT) | \ - (1 << PMIC_ACCDET_EINT1_CMPEN_STABLE_SHIFT) | \ - (1 << PMIC_ACCDET_EINT1_CEN_STABLE_SHIFT)) +#define ACCDET_EINT0_STABLE_VAL ((ACCDET_DA_STABLE_SFT) | \ + (ACCDET_EINT0_EN_STABLE_SFT) | \ + (ACCDET_EINT0_CMPEN_STABLE_SFT) | \ + (ACCDET_EINT0_CEN_STABLE_SFT)) + +#define ACCDET_EINT1_STABLE_VAL ((ACCDET_DA_STABLE_SFT) | \ + (ACCDET_EINT1_EN_STABLE_SFT) | \ + (ACCDET_EINT1_CMPEN_STABLE_SFT) | \ + (ACCDET_EINT1_CEN_STABLE_SFT)) /* The following are used for mt6359.c */ /* MT6359_DCXO_CW12 */
MT6359 audio codec support accessory detect features, adds MT6359 accdet driver to support plug detection and key detection. Signed-off-by: Argus Lin <argus.lin@mediatek.com> --- sound/soc/codecs/Kconfig | 7 + sound/soc/codecs/Makefile | 2 + sound/soc/codecs/mt6359-accdet.c | 1951 ++++++++++++++++++++++++++++++++++++++ sound/soc/codecs/mt6359-accdet.h | 136 +++ sound/soc/codecs/mt6359.h | 1863 +++++++++++++++++++++++++++++++++--- 5 files changed, 3853 insertions(+), 106 deletions(-) create mode 100644 sound/soc/codecs/mt6359-accdet.c create mode 100644 sound/soc/codecs/mt6359-accdet.h -- 1.8.1.1.dirty