Lines Matching defs:aw88399

3 // aw88399.c --  ALSA SoC AW88399 codec support
18 #include "aw88399.h"
232 static int aw88399_dev_get_icalk(struct aw88399 *aw88399, int16_t *icalk)
235 struct aw_device *aw_dev = aw88399->aw_pa;
249 if (aw88399->check_val == AW_EF_AND_CHECK)
261 static int aw88399_dev_get_vcalk(struct aw88399 *aw88399, int16_t *vcalk)
264 struct aw_device *aw_dev = aw88399->aw_pa;
280 if (aw88399->check_val == AW_EF_AND_CHECK)
292 static int aw88399_dev_get_internal_vcalk(struct aw88399 *aw88399, int16_t *vcalk)
295 struct aw_device *aw_dev = aw88399->aw_pa;
309 if (aw88399->check_val == AW_EF_AND_CHECK)
324 static int aw_dev_set_vcalb(struct aw88399 *aw88399)
326 struct aw_device *aw_dev = aw88399->aw_pa;
339 ret = aw88399_dev_get_icalk(aw88399, &icalk);
349 ret = aw88399_dev_get_vcalk(aw88399, &vcalk);
352 ical_k / vcal_k * aw88399->vcalb_init_val;
355 ret = aw88399_dev_get_internal_vcalk(aw88399, &vcalk);
359 vcal_k * aw88399->vcalb_init_val;
495 static int aw_dev_hw_crc_check(struct aw88399 *aw88399)
497 struct aw_device *aw_dev = aw88399->aw_pa;
517 ret = regmap_write(aw_dev->regmap, AW88399_CRCCTRL_REG, aw88399->crc_init_val);
669 static void aw88399_dev_set_dither(struct aw88399 *aw88399, bool dither)
671 struct aw_device *aw_dev = aw88399->aw_pa;
681 static int aw88399_dev_start(struct aw88399 *aw88399)
683 struct aw_device *aw_dev = aw88399->aw_pa;
691 aw88399_dev_set_dither(aw88399, false);
715 ret = aw_dev_hw_crc_check(aw88399);
721 aw_dev_set_vcalb(aw88399);
736 if (aw88399->dither_st == AW88399_DITHER_EN_ENABLE_VALUE)
737 aw88399_dev_set_dither(aw88399, true);
909 static int aw_dev_update_reg_container(struct aw88399 *aw88399,
912 struct aw_device *aw_dev = aw88399->aw_pa;
932 aw88399->vcalb_init_val = reg_val;
961 aw88399->check_val = AW_EF_OR_CHECK;
963 aw88399->check_val = AW_EF_AND_CHECK;
965 aw88399->dither_st = reg_val & (~AW88399_DITHER_EN_MASK);
969 aw88399->crc_init_val = reg_val;
989 static int aw_dev_reg_update(struct aw88399 *aw88399,
995 dev_err(aw88399->aw_pa->dev, "reg data is null or len is 0");
999 ret = aw_dev_update_reg_container(aw88399, data, len);
1001 dev_err(aw88399->aw_pa->dev, "reg update failed");
1038 static int aw88399_dev_fw_update(struct aw88399 *aw88399, bool up_dsp_fw_en, bool force_up_en)
1040 struct aw_device *aw_dev = aw88399->aw_pa;
1069 ret = aw_dev_reg_update(aw88399, sec_desc[AW88395_DATA_TYPE_REG].data,
1118 static void aw88399_start_pa(struct aw88399 *aw88399)
1123 ret = aw88399_dev_start(aw88399);
1125 dev_err(aw88399->aw_pa->dev, "aw88399 device start failed. retry = %d", i);
1126 ret = aw88399_dev_fw_update(aw88399, AW88399_DSP_FW_UPDATE_ON, true);
1128 dev_err(aw88399->aw_pa->dev, "fw update failed");
1132 dev_dbg(aw88399->aw_pa->dev, "start success\n");
1140 struct aw88399 *aw88399 =
1141 container_of(work, struct aw88399, start_work.work);
1143 mutex_lock(&aw88399->lock);
1144 aw88399_start_pa(aw88399);
1145 mutex_unlock(&aw88399->lock);
1148 static void aw88399_start(struct aw88399 *aw88399, bool sync_start)
1152 if (aw88399->aw_pa->fw_status != AW88399_DEV_FW_OK)
1155 if (aw88399->aw_pa->status == AW88399_DEV_PW_ON)
1158 ret = aw88399_dev_fw_update(aw88399, AW88399_DSP_FW_UPDATE_OFF, true);
1160 dev_err(aw88399->aw_pa->dev, "fw update failed.");
1165 aw88399_start_pa(aw88399);
1168 &aw88399->start_work,
1226 .name = "aw88399-aif",
1533 static int aw_cali_svc_dev_cali_re(struct aw88399 *aw88399)
1535 struct aw_device *aw_dev = aw88399->aw_pa;
1571 struct aw88399 *aw88399 = snd_soc_component_get_drvdata(component);
1572 struct aw_device *aw_dev = aw88399->aw_pa;
1583 struct aw88399 *aw88399 = snd_soc_component_get_drvdata(component);
1586 struct aw_device *aw_dev = aw88399->aw_pa;
1606 struct aw88399 *aw88399 = snd_soc_component_get_drvdata(component);
1607 struct aw_device *aw_dev = aw88399->aw_pa;
1618 struct aw88399 *aw88399 = snd_soc_component_get_drvdata(component);
1621 struct aw_device *aw_dev = aw88399->aw_pa;
1656 struct aw88399 *aw88399 = snd_soc_component_get_drvdata(codec);
1663 count = aw88399->aw_pa->prof_info.count;
1676 ret = aw88399_dev_get_prof_name(aw88399->aw_pa, count, &prof_name);
1691 struct aw88399 *aw88399 = snd_soc_component_get_drvdata(codec);
1693 ucontrol->value.integer.value[0] = aw88399->aw_pa->prof_index;
1702 struct aw88399 *aw88399 = snd_soc_component_get_drvdata(codec);
1705 mutex_lock(&aw88399->lock);
1706 ret = aw88399_dev_set_profile_index(aw88399->aw_pa, ucontrol->value.integer.value[0]);
1709 mutex_unlock(&aw88399->lock);
1713 if (aw88399->aw_pa->status) {
1714 aw88399_stop(aw88399->aw_pa);
1715 aw88399_start(aw88399, AW88399_SYNC_START);
1718 mutex_unlock(&aw88399->lock);
1727 struct aw88399 *aw88399 = snd_soc_component_get_drvdata(codec);
1728 struct aw_volume_desc *vol_desc = &aw88399->aw_pa->volume_desc;
1739 struct aw88399 *aw88399 = snd_soc_component_get_drvdata(codec);
1740 struct aw_volume_desc *vol_desc = &aw88399->aw_pa->volume_desc;
1751 aw_dev_set_volume(aw88399->aw_pa, vol_desc->ctl_volume);
1763 struct aw88399 *aw88399 = snd_soc_component_get_drvdata(codec);
1765 ucontrol->value.integer.value[0] = aw88399->aw_pa->fade_step;
1774 struct aw88399 *aw88399 = snd_soc_component_get_drvdata(codec);
1783 if (aw88399->aw_pa->fade_step != value) {
1784 aw88399->aw_pa->fade_step = value;
1795 struct aw88399 *aw88399 = snd_soc_component_get_drvdata(codec);
1796 struct aw_device *aw_dev = aw88399->aw_pa;
1807 struct aw88399 *aw88399 = snd_soc_component_get_drvdata(codec);
1810 struct aw_device *aw_dev = aw88399->aw_pa;
1829 struct aw88399 *aw88399 = snd_soc_component_get_drvdata(codec);
1830 struct aw_device *aw_dev = aw88399->aw_pa;
1841 struct aw88399 *aw88399 = snd_soc_component_get_drvdata(codec);
1842 struct aw_device *aw_dev = aw88399->aw_pa;
1863 struct aw88399 *aw88399 = snd_soc_component_get_drvdata(codec);
1864 struct aw_device *aw_dev = aw88399->aw_pa;
1867 aw_cali_svc_dev_cali_re(aw88399);
1872 static int aw88399_dev_init(struct aw88399 *aw88399, struct aw_container *aw_cfg)
1874 struct aw_device *aw_dev = aw88399->aw_pa;
1887 ret = aw88399_dev_fw_update(aw88399, AW88399_FORCE_UPDATE_ON, AW88399_DSP_FW_UPDATE_ON);
1910 static int aw88399_request_firmware_file(struct aw88399 *aw88399)
1915 aw88399->aw_pa->fw_status = AW88399_DEV_FW_FAILED;
1917 ret = request_firmware(&cont, AW88399_ACF_FILE, aw88399->aw_pa->dev);
1919 dev_err(aw88399->aw_pa->dev, "request [%s] failed!", AW88399_ACF_FILE);
1923 dev_dbg(aw88399->aw_pa->dev, "loaded %s - size: %zu\n",
1926 aw88399->aw_cfg = devm_kzalloc(aw88399->aw_pa->dev,
1927 struct_size(aw88399->aw_cfg, data, cont->size), GFP_KERNEL);
1928 if (!aw88399->aw_cfg) {
1932 aw88399->aw_cfg->len = (int)cont->size;
1933 memcpy(aw88399->aw_cfg->data, cont->data, cont->size);
1936 ret = aw88395_dev_load_acf_check(aw88399->aw_pa, aw88399->aw_cfg);
1938 dev_err(aw88399->aw_pa->dev, "load [%s] failed!", AW88399_ACF_FILE);
1942 mutex_lock(&aw88399->lock);
1944 ret = aw88399_dev_init(aw88399, aw88399->aw_cfg);
1946 dev_err(aw88399->aw_pa->dev, "dev init failed");
1947 mutex_unlock(&aw88399->lock);
1976 struct aw88399 *aw88399 = snd_soc_component_get_drvdata(component);
1978 mutex_lock(&aw88399->lock);
1981 aw88399_start(aw88399, AW88399_ASYNC_START);
1984 aw88399_stop(aw88399->aw_pa);
1989 mutex_unlock(&aw88399->lock);
2013 struct aw88399 *aw88399 = snd_soc_component_get_drvdata(component);
2016 INIT_DELAYED_WORK(&aw88399->start_work, aw88399_startup_work);
2018 ret = aw88399_request_firmware_file(aw88399);
2020 dev_err(aw88399->aw_pa->dev, "%s failed\n", __func__);
2027 struct aw88399 *aw88399 = snd_soc_component_get_drvdata(aw_codec);
2029 cancel_delayed_work_sync(&aw88399->start_work);
2043 static void aw88399_hw_reset(struct aw88399 *aw88399)
2045 if (aw88399->reset_gpio) {
2046 gpiod_set_value_cansleep(aw88399->reset_gpio, 1);
2048 gpiod_set_value_cansleep(aw88399->reset_gpio, 0);
2050 gpiod_set_value_cansleep(aw88399->reset_gpio, 1);
2064 static int aw88399_init(struct aw88399 *aw88399, struct i2c_client *i2c, struct regmap *regmap)
2084 aw88399->aw_pa = aw_dev;
2109 struct aw88399 *aw88399;
2115 aw88399 = devm_kzalloc(&i2c->dev, sizeof(*aw88399), GFP_KERNEL);
2116 if (!aw88399)
2119 mutex_init(&aw88399->lock);
2121 i2c_set_clientdata(i2c, aw88399);
2123 aw88399->reset_gpio = devm_gpiod_get_optional(&i2c->dev, "reset", GPIOD_OUT_LOW);
2124 if (IS_ERR(aw88399->reset_gpio))
2125 return dev_err_probe(&i2c->dev, PTR_ERR(aw88399->reset_gpio),
2127 aw88399_hw_reset(aw88399);
2129 aw88399->regmap = devm_regmap_init_i2c(i2c, &aw88399_remap_config);
2130 if (IS_ERR(aw88399->regmap))
2131 return dev_err_probe(&i2c->dev, PTR_ERR(aw88399->regmap),
2135 ret = aw88399_init(aw88399, i2c, aw88399->regmap);
2143 dev_err(&i2c->dev, "failed to register aw88399: %d", ret);