Lines Matching refs:wm8962
95 struct wm8962_priv *wm8962 = container_of(nb, struct wm8962_priv, \
98 regcache_mark_dirty(wm8962->regmap); \
1439 static int wm8962_reset(struct wm8962_priv *wm8962) in wm8962_reset() argument
1443 ret = regmap_write(wm8962->regmap, WM8962_SOFTWARE_RESET, 0x6243); in wm8962_reset()
1447 return regmap_write(wm8962->regmap, WM8962_PLL_SOFTWARE_RESET, 0); in wm8962_reset()
1474 struct wm8962_priv *wm8962 = snd_soc_component_get_drvdata(component); in wm8962_dsp2_write_config() local
1476 return regcache_sync_region(wm8962->regmap, in wm8962_dsp2_write_config()
1505 struct wm8962_priv *wm8962 = snd_soc_component_get_drvdata(component); in wm8962_dsp2_start() local
1511 wm8962_dsp2_set_enable(component, wm8962->dsp2_ena); in wm8962_dsp2_start()
1548 struct wm8962_priv *wm8962 = snd_soc_component_get_drvdata(component); in wm8962_dsp2_ena_get() local
1550 ucontrol->value.integer.value[0] = !!(wm8962->dsp2_ena & 1 << shift); in wm8962_dsp2_ena_get()
1560 struct wm8962_priv *wm8962 = snd_soc_component_get_drvdata(component); in wm8962_dsp2_ena_put() local
1561 int old = wm8962->dsp2_ena; in wm8962_dsp2_ena_put()
1566 mutex_lock(&wm8962->dsp2_ena_lock); in wm8962_dsp2_ena_put()
1569 wm8962->dsp2_ena |= 1 << shift; in wm8962_dsp2_ena_put()
1571 wm8962->dsp2_ena &= ~(1 << shift); in wm8962_dsp2_ena_put()
1573 if (wm8962->dsp2_ena == old) in wm8962_dsp2_ena_put()
1579 if (wm8962->dsp2_ena) in wm8962_dsp2_ena_put()
1580 wm8962_dsp2_set_enable(component, wm8962->dsp2_ena); in wm8962_dsp2_ena_put()
1586 mutex_unlock(&wm8962->dsp2_ena_lock); in wm8962_dsp2_ena_put()
1991 struct wm8962_priv *wm8962 = snd_soc_component_get_drvdata(component); in dsp2_event() local
1995 if (wm8962->dsp2_ena) in dsp2_event()
2000 if (wm8962->dsp2_ena) in dsp2_event()
2356 struct wm8962_priv *wm8962 = snd_soc_component_get_drvdata(component); in wm8962_add_widgets() local
2357 struct wm8962_pdata *pdata = &wm8962->pdata; in wm8962_add_widgets()
2405 struct wm8962_priv *wm8962 = snd_soc_component_get_drvdata(component); in wm8962_configure_bclk() local
2411 if (!wm8962->sysclk_rate) { in wm8962_configure_bclk()
2416 if (!wm8962->bclk || !wm8962->lrclk) { in wm8962_configure_bclk()
2422 if (sysclk_rates[i] == wm8962->sysclk_rate / wm8962->lrclk) { in wm8962_configure_bclk()
2430 wm8962->sysclk_rate / wm8962->lrclk); in wm8962_configure_bclk()
2461 dspclk = wm8962->sysclk_rate; in wm8962_configure_bclk()
2464 dspclk = wm8962->sysclk_rate / 2; in wm8962_configure_bclk()
2467 dspclk = wm8962->sysclk_rate / 4; in wm8962_configure_bclk()
2471 dspclk = wm8962->sysclk_rate; in wm8962_configure_bclk()
2474 dev_dbg(component->dev, "DSPCLK is %dHz, BCLK %d\n", dspclk, wm8962->bclk); in wm8962_configure_bclk()
2481 if (dspclk / bclk_divs[i] == wm8962->bclk) { in wm8962_configure_bclk()
2483 bclk_divs[i], wm8962->bclk); in wm8962_configure_bclk()
2490 dspclk / wm8962->bclk); in wm8962_configure_bclk()
2494 aif2 |= wm8962->bclk / wm8962->lrclk; in wm8962_configure_bclk()
2496 wm8962->bclk / wm8962->lrclk, wm8962->lrclk); in wm8962_configure_bclk()
2557 struct wm8962_priv *wm8962 = snd_soc_component_get_drvdata(component); in wm8962_hw_params() local
2562 wm8962->bclk = snd_soc_params_to_bclk(params); in wm8962_hw_params()
2564 wm8962->bclk *= 2; in wm8962_hw_params()
2566 wm8962->lrclk = params_rate(params); in wm8962_hw_params()
2569 if (sr_vals[i].rate == wm8962->lrclk) { in wm8962_hw_params()
2575 dev_err(component->dev, "Unsupported rate %dHz\n", wm8962->lrclk); in wm8962_hw_params()
2579 if (wm8962->lrclk % 8000 == 0) in wm8962_hw_params()
2605 wm8962->bclk, wm8962->lrclk); in wm8962_hw_params()
2617 struct wm8962_priv *wm8962 = snd_soc_component_get_drvdata(component); in wm8962_set_dai_sysclk() local
2622 wm8962->sysclk = WM8962_SYSCLK_MCLK; in wm8962_set_dai_sysclk()
2626 wm8962->sysclk = WM8962_SYSCLK_FLL; in wm8962_set_dai_sysclk()
2636 wm8962->sysclk_rate = freq; in wm8962_set_dai_sysclk()
2813 struct wm8962_priv *wm8962 = snd_soc_component_get_drvdata(component); in wm8962_set_fll() local
2820 if (source == wm8962->fll_src && Fref == wm8962->fll_fref && in wm8962_set_fll()
2821 Fout == wm8962->fll_fout) in wm8962_set_fll()
2827 wm8962->fll_fref = 0; in wm8962_set_fll()
2828 wm8962->fll_fout = 0; in wm8962_set_fll()
2881 reinit_completion(&wm8962->fll_lock); in wm8962_set_fll()
2899 if (wm8962->irq) in wm8962_set_fll()
2904 timeout = wait_for_completion_timeout(&wm8962->fll_lock, in wm8962_set_fll()
2907 if (timeout == 0 && wm8962->irq) { in wm8962_set_fll()
2915 wm8962->fll_fref = Fref; in wm8962_set_fll()
2916 wm8962->fll_fout = Fout; in wm8962_set_fll()
2917 wm8962->fll_src = source; in wm8962_set_fll()
2981 struct wm8962_priv *wm8962 = container_of(work, in wm8962_mic_work() local
2984 struct snd_soc_component *component = wm8962->component; in wm8962_mic_work()
3001 snd_soc_jack_report(wm8962->jack, status, in wm8962_mic_work()
3012 struct wm8962_priv *wm8962 = dev_get_drvdata(dev); in wm8962_irq() local
3024 ret = regmap_read(wm8962->regmap, WM8962_INTERRUPT_STATUS_2_MASK, in wm8962_irq()
3033 ret = regmap_read(wm8962->regmap, WM8962_INTERRUPT_STATUS_2, &active); in wm8962_irq()
3048 ret = regmap_write(wm8962->regmap, WM8962_INTERRUPT_STATUS_2, active); in wm8962_irq()
3054 complete(&wm8962->fll_lock); in wm8962_irq()
3063 ret = regmap_read(wm8962->regmap, in wm8962_irq()
3091 &wm8962->mic_work, in wm8962_irq()
3115 struct wm8962_priv *wm8962 = snd_soc_component_get_drvdata(component); in wm8962_mic_detect() local
3119 wm8962->jack = jack; in wm8962_mic_detect()
3134 snd_soc_jack_report(wm8962->jack, 0, in wm8962_mic_detect()
3159 struct wm8962_priv *wm8962 = in wm8962_beep_work() local
3161 struct snd_soc_component *component = wm8962->component; in wm8962_beep_work()
3167 if (wm8962->beep_rate) { in wm8962_beep_work()
3169 if (abs(wm8962->beep_rate - beep_rates[i]) < in wm8962_beep_work()
3170 abs(wm8962->beep_rate - beep_rates[best])) in wm8962_beep_work()
3175 beep_rates[best], wm8962->beep_rate); in wm8962_beep_work()
3198 struct wm8962_priv *wm8962 = snd_soc_component_get_drvdata(component); in wm8962_beep_event() local
3213 wm8962->beep_rate = hz; in wm8962_beep_event()
3214 schedule_work(&wm8962->beep_work); in wm8962_beep_event()
3222 struct wm8962_priv *wm8962 = dev_get_drvdata(dev); in wm8962_beep_set() local
3230 input_event(wm8962->beep, EV_SND, SND_TONE, time); in wm8962_beep_set()
3239 struct wm8962_priv *wm8962 = snd_soc_component_get_drvdata(component); in wm8962_init_beep() local
3242 wm8962->beep = devm_input_allocate_device(component->dev); in wm8962_init_beep()
3243 if (!wm8962->beep) { in wm8962_init_beep()
3248 INIT_WORK(&wm8962->beep_work, wm8962_beep_work); in wm8962_init_beep()
3249 wm8962->beep_rate = 0; in wm8962_init_beep()
3251 wm8962->beep->name = "WM8962 Beep Generator"; in wm8962_init_beep()
3252 wm8962->beep->phys = dev_name(component->dev); in wm8962_init_beep()
3253 wm8962->beep->id.bustype = BUS_I2C; in wm8962_init_beep()
3255 wm8962->beep->evbit[0] = BIT_MASK(EV_SND); in wm8962_init_beep()
3256 wm8962->beep->sndbit[0] = BIT_MASK(SND_BELL) | BIT_MASK(SND_TONE); in wm8962_init_beep()
3257 wm8962->beep->event = wm8962_beep_event; in wm8962_init_beep()
3258 wm8962->beep->dev.parent = component->dev; in wm8962_init_beep()
3259 input_set_drvdata(wm8962->beep, component); in wm8962_init_beep()
3261 ret = input_register_device(wm8962->beep); in wm8962_init_beep()
3263 wm8962->beep = NULL; in wm8962_init_beep()
3276 struct wm8962_priv *wm8962 = snd_soc_component_get_drvdata(component); in wm8962_free_beep() local
3279 cancel_work_sync(&wm8962->beep_work); in wm8962_free_beep()
3280 wm8962->beep = NULL; in wm8962_free_beep()
3285 static void wm8962_set_gpio_mode(struct wm8962_priv *wm8962, int gpio) in wm8962_set_gpio_mode() argument
3306 regmap_update_bits(wm8962->regmap, WM8962_ANALOGUE_CLOCKING1, in wm8962_set_gpio_mode()
3313 struct wm8962_priv *wm8962 = gpiochip_get_data(chip); in wm8962_gpio_request() local
3329 wm8962_set_gpio_mode(wm8962, offset + 1); in wm8962_gpio_request()
3336 struct wm8962_priv *wm8962 = gpiochip_get_data(chip); in wm8962_gpio_set() local
3337 struct snd_soc_component *component = wm8962->component; in wm8962_gpio_set()
3346 struct wm8962_priv *wm8962 = gpiochip_get_data(chip); in wm8962_gpio_direction_out() local
3347 struct snd_soc_component *component = wm8962->component; in wm8962_gpio_direction_out()
3372 struct wm8962_priv *wm8962 = snd_soc_component_get_drvdata(component); in wm8962_init_gpio() local
3373 struct wm8962_pdata *pdata = &wm8962->pdata; in wm8962_init_gpio()
3376 wm8962->gpio_chip = wm8962_template_chip; in wm8962_init_gpio()
3377 wm8962->gpio_chip.ngpio = WM8962_MAX_GPIO; in wm8962_init_gpio()
3378 wm8962->gpio_chip.parent = component->dev; in wm8962_init_gpio()
3381 wm8962->gpio_chip.base = pdata->gpio_base; in wm8962_init_gpio()
3383 wm8962->gpio_chip.base = -1; in wm8962_init_gpio()
3385 ret = gpiochip_add_data(&wm8962->gpio_chip, wm8962); in wm8962_init_gpio()
3392 struct wm8962_priv *wm8962 = snd_soc_component_get_drvdata(component); in wm8962_free_gpio() local
3394 gpiochip_remove(&wm8962->gpio_chip); in wm8962_free_gpio()
3410 struct wm8962_priv *wm8962 = snd_soc_component_get_drvdata(component); in wm8962_probe() local
3414 wm8962->component = component; in wm8962_probe()
3416 wm8962->disable_nb[0].notifier_call = wm8962_regulator_event_0; in wm8962_probe()
3417 wm8962->disable_nb[1].notifier_call = wm8962_regulator_event_1; in wm8962_probe()
3418 wm8962->disable_nb[2].notifier_call = wm8962_regulator_event_2; in wm8962_probe()
3419 wm8962->disable_nb[3].notifier_call = wm8962_regulator_event_3; in wm8962_probe()
3420 wm8962->disable_nb[4].notifier_call = wm8962_regulator_event_4; in wm8962_probe()
3421 wm8962->disable_nb[5].notifier_call = wm8962_regulator_event_5; in wm8962_probe()
3422 wm8962->disable_nb[6].notifier_call = wm8962_regulator_event_6; in wm8962_probe()
3423 wm8962->disable_nb[7].notifier_call = wm8962_regulator_event_7; in wm8962_probe()
3426 for (i = 0; i < ARRAY_SIZE(wm8962->supplies); i++) { in wm8962_probe()
3428 wm8962->supplies[i].consumer, in wm8962_probe()
3429 &wm8962->disable_nb[i]); in wm8962_probe()
3476 struct wm8962_priv *wm8962 = snd_soc_component_get_drvdata(component); in wm8962_remove() local
3478 cancel_delayed_work_sync(&wm8962->mic_work); in wm8962_remove()
3547 struct wm8962_priv *wm8962; in wm8962_i2c_probe() local
3551 wm8962 = devm_kzalloc(&i2c->dev, sizeof(*wm8962), GFP_KERNEL); in wm8962_i2c_probe()
3552 if (wm8962 == NULL) in wm8962_i2c_probe()
3555 mutex_init(&wm8962->dsp2_ena_lock); in wm8962_i2c_probe()
3557 i2c_set_clientdata(i2c, wm8962); in wm8962_i2c_probe()
3559 INIT_DELAYED_WORK(&wm8962->mic_work, wm8962_mic_work); in wm8962_i2c_probe()
3560 init_completion(&wm8962->fll_lock); in wm8962_i2c_probe()
3561 wm8962->irq = i2c->irq; in wm8962_i2c_probe()
3565 memcpy(&wm8962->pdata, pdata, sizeof(struct wm8962_pdata)); in wm8962_i2c_probe()
3567 ret = wm8962_set_pdata_from_of(i2c, &wm8962->pdata); in wm8962_i2c_probe()
3573 if (IS_ERR(wm8962->pdata.mclk)) { in wm8962_i2c_probe()
3575 if (PTR_ERR(wm8962->pdata.mclk) == -EPROBE_DEFER) in wm8962_i2c_probe()
3577 wm8962->pdata.mclk = NULL; in wm8962_i2c_probe()
3580 for (i = 0; i < ARRAY_SIZE(wm8962->supplies); i++) in wm8962_i2c_probe()
3581 wm8962->supplies[i].supply = wm8962_supply_names[i]; in wm8962_i2c_probe()
3583 ret = devm_regulator_bulk_get(&i2c->dev, ARRAY_SIZE(wm8962->supplies), in wm8962_i2c_probe()
3584 wm8962->supplies); in wm8962_i2c_probe()
3590 ret = regulator_bulk_enable(ARRAY_SIZE(wm8962->supplies), in wm8962_i2c_probe()
3591 wm8962->supplies); in wm8962_i2c_probe()
3597 wm8962->regmap = devm_regmap_init_i2c(i2c, &wm8962_regmap); in wm8962_i2c_probe()
3598 if (IS_ERR(wm8962->regmap)) { in wm8962_i2c_probe()
3599 ret = PTR_ERR(wm8962->regmap); in wm8962_i2c_probe()
3609 regcache_cache_bypass(wm8962->regmap, true); in wm8962_i2c_probe()
3611 ret = regmap_read(wm8962->regmap, WM8962_SOFTWARE_RESET, ®); in wm8962_i2c_probe()
3623 ret = regmap_read(wm8962->regmap, WM8962_RIGHT_INPUT_VOLUME, ®); in wm8962_i2c_probe()
3635 regcache_cache_bypass(wm8962->regmap, false); in wm8962_i2c_probe()
3637 ret = wm8962_reset(wm8962); in wm8962_i2c_probe()
3646 regmap_update_bits(wm8962->regmap, WM8962_CLOCKING2, in wm8962_i2c_probe()
3650 regmap_update_bits(wm8962->regmap, WM8962_CLOCKING2, in wm8962_i2c_probe()
3654 regmap_update_bits(wm8962->regmap, WM8962_PLL2, in wm8962_i2c_probe()
3659 for (i = 0; i < ARRAY_SIZE(wm8962->pdata.gpio_init); i++) in wm8962_i2c_probe()
3660 if (wm8962->pdata.gpio_init[i]) { in wm8962_i2c_probe()
3661 wm8962_set_gpio_mode(wm8962, i + 1); in wm8962_i2c_probe()
3662 regmap_write(wm8962->regmap, 0x200 + i, in wm8962_i2c_probe()
3663 wm8962->pdata.gpio_init[i] & 0xffff); in wm8962_i2c_probe()
3668 if (wm8962->pdata.spk_mono) in wm8962_i2c_probe()
3669 regmap_update_bits(wm8962->regmap, WM8962_CLASS_D_CONTROL_2, in wm8962_i2c_probe()
3674 if (wm8962->pdata.mic_cfg) in wm8962_i2c_probe()
3675 regmap_update_bits(wm8962->regmap, WM8962_ADDITIONAL_CONTROL_4, in wm8962_i2c_probe()
3680 wm8962->pdata.mic_cfg); in wm8962_i2c_probe()
3683 regmap_update_bits(wm8962->regmap, WM8962_LEFT_INPUT_VOLUME, in wm8962_i2c_probe()
3685 regmap_update_bits(wm8962->regmap, WM8962_RIGHT_INPUT_VOLUME, in wm8962_i2c_probe()
3687 regmap_update_bits(wm8962->regmap, WM8962_LEFT_ADC_VOLUME, in wm8962_i2c_probe()
3689 regmap_update_bits(wm8962->regmap, WM8962_RIGHT_ADC_VOLUME, in wm8962_i2c_probe()
3691 regmap_update_bits(wm8962->regmap, WM8962_LEFT_DAC_VOLUME, in wm8962_i2c_probe()
3693 regmap_update_bits(wm8962->regmap, WM8962_RIGHT_DAC_VOLUME, in wm8962_i2c_probe()
3695 regmap_update_bits(wm8962->regmap, WM8962_SPKOUTL_VOLUME, in wm8962_i2c_probe()
3697 regmap_update_bits(wm8962->regmap, WM8962_SPKOUTR_VOLUME, in wm8962_i2c_probe()
3699 regmap_update_bits(wm8962->regmap, WM8962_HPOUTL_VOLUME, in wm8962_i2c_probe()
3701 regmap_update_bits(wm8962->regmap, WM8962_HPOUTR_VOLUME, in wm8962_i2c_probe()
3705 regmap_update_bits(wm8962->regmap, WM8962_EQ1, in wm8962_i2c_probe()
3709 regmap_update_bits(wm8962->regmap, WM8962_IRQ_DEBOUNCE, in wm8962_i2c_probe()
3714 if (wm8962->pdata.in4_dc_measure) { in wm8962_i2c_probe()
3715 ret = regmap_register_patch(wm8962->regmap, in wm8962_i2c_probe()
3724 if (wm8962->irq) { in wm8962_i2c_probe()
3725 if (wm8962->pdata.irq_active_low) { in wm8962_i2c_probe()
3733 regmap_update_bits(wm8962->regmap, WM8962_INTERRUPT_CONTROL, in wm8962_i2c_probe()
3736 ret = devm_request_threaded_irq(&i2c->dev, wm8962->irq, NULL, in wm8962_i2c_probe()
3742 wm8962->irq, ret); in wm8962_i2c_probe()
3743 wm8962->irq = 0; in wm8962_i2c_probe()
3747 regmap_update_bits(wm8962->regmap, in wm8962_i2c_probe()
3763 regcache_cache_only(wm8962->regmap, true); in wm8962_i2c_probe()
3766 regulator_bulk_disable(ARRAY_SIZE(wm8962->supplies), wm8962->supplies); in wm8962_i2c_probe()
3773 regulator_bulk_disable(ARRAY_SIZE(wm8962->supplies), wm8962->supplies); in wm8962_i2c_probe()
3787 struct wm8962_priv *wm8962 = dev_get_drvdata(dev); in wm8962_runtime_resume() local
3790 ret = clk_prepare_enable(wm8962->pdata.mclk); in wm8962_runtime_resume()
3796 ret = regulator_bulk_enable(ARRAY_SIZE(wm8962->supplies), in wm8962_runtime_resume()
3797 wm8962->supplies); in wm8962_runtime_resume()
3803 regcache_cache_only(wm8962->regmap, false); in wm8962_runtime_resume()
3805 wm8962_reset(wm8962); in wm8962_runtime_resume()
3807 regcache_mark_dirty(wm8962->regmap); in wm8962_runtime_resume()
3812 regmap_write_bits(wm8962->regmap, WM8962_CLOCKING2, in wm8962_runtime_resume()
3816 regmap_update_bits(wm8962->regmap, WM8962_CLOCKING2, in wm8962_runtime_resume()
3820 regmap_update_bits(wm8962->regmap, WM8962_PLL2, in wm8962_runtime_resume()
3824 regcache_sync(wm8962->regmap); in wm8962_runtime_resume()
3826 regmap_update_bits(wm8962->regmap, WM8962_ANTI_POP, in wm8962_runtime_resume()
3831 regmap_update_bits(wm8962->regmap, WM8962_PWR_MGMT_1, in wm8962_runtime_resume()
3840 clk_disable_unprepare(wm8962->pdata.mclk); in wm8962_runtime_resume()
3846 struct wm8962_priv *wm8962 = dev_get_drvdata(dev); in wm8962_runtime_suspend() local
3848 regmap_update_bits(wm8962->regmap, WM8962_PWR_MGMT_1, in wm8962_runtime_suspend()
3851 regmap_update_bits(wm8962->regmap, WM8962_ANTI_POP, in wm8962_runtime_suspend()
3855 regcache_cache_only(wm8962->regmap, true); in wm8962_runtime_suspend()
3857 regulator_bulk_disable(ARRAY_SIZE(wm8962->supplies), in wm8962_runtime_suspend()
3858 wm8962->supplies); in wm8962_runtime_suspend()
3860 clk_disable_unprepare(wm8962->pdata.mclk); in wm8962_runtime_suspend()