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