ts3a227e
static void ts3a227e_jack_report(struct ts3a227e *ts3a227e)
if (!ts3a227e->jack)
if (ts3a227e->plugged)
if (ts3a227e->mic_present)
if (ts3a227e->buttons_held & (1 << i))
snd_soc_jack_report(ts3a227e->jack, report, TS3A227E_JACK_MASK);
static void ts3a227e_new_jack_state(struct ts3a227e *ts3a227e, unsigned acc_reg)
ts3a227e->plugged = plugged;
if (mic_present != ts3a227e->mic_present) {
ts3a227e->mic_present = mic_present;
ts3a227e->buttons_held = 0;
regmap_update_bits(ts3a227e->regmap,
struct ts3a227e *ts3a227e = (struct ts3a227e *)data;
struct regmap *regmap = ts3a227e->regmap;
struct device *dev = ts3a227e->dev;
ts3a227e_new_jack_state(ts3a227e, acc_reg);
ts3a227e->buttons_held |= (1 << i);
ts3a227e->buttons_held &= ~(1 << i);
ts3a227e_jack_report(ts3a227e);
struct ts3a227e *ts3a227e = snd_soc_component_get_drvdata(component);
ts3a227e->jack = jack;
ts3a227e_jack_report(ts3a227e);
static int ts3a227e_parse_device_property(struct ts3a227e *ts3a227e,
regmap_update_bits(ts3a227e->regmap, TS3A227E_REG_SETTING_3,
regmap_update_bits(ts3a227e->regmap, TS3A227E_REG_SETTING_1,
struct ts3a227e *ts3a227e;
ts3a227e = devm_kzalloc(&i2c->dev, sizeof(*ts3a227e), GFP_KERNEL);
if (ts3a227e == NULL)
i2c_set_clientdata(i2c, ts3a227e);
ts3a227e->dev = dev;
ts3a227e->irq = i2c->irq;
ts3a227e->regmap = devm_regmap_init_i2c(i2c, &ts3a227e_regmap_config);
if (IS_ERR(ts3a227e->regmap))
return PTR_ERR(ts3a227e->regmap);
ret = ts3a227e_parse_device_property(ts3a227e, dev);
"TS3A227E", ts3a227e);
regmap_update_bits(ts3a227e->regmap, TS3A227E_REG_INTERRUPT_DISABLE,
regmap_read(ts3a227e->regmap, TS3A227E_REG_ACCESSORY_STATUS, &acc_reg);
ts3a227e_new_jack_state(ts3a227e, acc_reg);
ts3a227e_jack_report(ts3a227e);
struct ts3a227e *ts3a227e = dev_get_drvdata(dev);
dev_dbg(ts3a227e->dev, "suspend disable irq\n");
disable_irq(ts3a227e->irq);
struct ts3a227e *ts3a227e = dev_get_drvdata(dev);
dev_dbg(ts3a227e->dev, "resume enable irq\n");
enable_irq(ts3a227e->irq);