Symbol: aw88166
sound/soc/codecs/aw88166.c
1000
aw88166->crc_init_val = reg_val;
sound/soc/codecs/aw88166.c
1018
static int aw_dev_reg_update(struct aw88166 *aw88166,
sound/soc/codecs/aw88166.c
1024
dev_err(aw88166->aw_pa->dev, "reg data is null or len is 0\n");
sound/soc/codecs/aw88166.c
1028
ret = aw_dev_update_reg_container(aw88166, data, len);
sound/soc/codecs/aw88166.c
1030
dev_err(aw88166->aw_pa->dev, "reg update failed\n");
sound/soc/codecs/aw88166.c
1067
static int aw88166_dev_fw_update(struct aw88166 *aw88166, bool up_dsp_fw_en, bool force_up_en)
sound/soc/codecs/aw88166.c
1069
struct aw_device *aw_dev = aw88166->aw_pa;
sound/soc/codecs/aw88166.c
1098
ret = aw_dev_reg_update(aw88166, sec_desc[AW88395_DATA_TYPE_REG].data,
sound/soc/codecs/aw88166.c
1118
aw_dev_backup_sec_recovery(aw88166);
sound/soc/codecs/aw88166.c
1138
aw_dev_backup_sec_record(aw88166);
sound/soc/codecs/aw88166.c
1151
static void aw88166_start_pa(struct aw88166 *aw88166)
sound/soc/codecs/aw88166.c
1156
ret = aw88166_dev_start(aw88166);
sound/soc/codecs/aw88166.c
1158
dev_err(aw88166->aw_pa->dev, "aw88166 device start failed. retry = %d", i);
sound/soc/codecs/aw88166.c
1159
ret = aw88166_dev_fw_update(aw88166, AW88166_DSP_FW_UPDATE_ON, true);
sound/soc/codecs/aw88166.c
1161
dev_err(aw88166->aw_pa->dev, "fw update failed");
sound/soc/codecs/aw88166.c
1165
dev_dbg(aw88166->aw_pa->dev, "start success\n");
sound/soc/codecs/aw88166.c
1173
struct aw88166 *aw88166 =
sound/soc/codecs/aw88166.c
1174
container_of(work, struct aw88166, start_work.work);
sound/soc/codecs/aw88166.c
1176
mutex_lock(&aw88166->lock);
sound/soc/codecs/aw88166.c
1177
aw88166_start_pa(aw88166);
sound/soc/codecs/aw88166.c
1178
mutex_unlock(&aw88166->lock);
sound/soc/codecs/aw88166.c
1181
static void aw88166_start(struct aw88166 *aw88166, bool sync_start)
sound/soc/codecs/aw88166.c
1185
if (aw88166->aw_pa->fw_status != AW88166_DEV_FW_OK)
sound/soc/codecs/aw88166.c
1188
if (aw88166->aw_pa->status == AW88166_DEV_PW_ON)
sound/soc/codecs/aw88166.c
1191
ret = aw88166_dev_fw_update(aw88166, AW88166_DSP_FW_UPDATE_OFF, aw88166->phase_sync);
sound/soc/codecs/aw88166.c
1193
dev_err(aw88166->aw_pa->dev, "fw update failed\n");
sound/soc/codecs/aw88166.c
1198
aw88166_start_pa(aw88166);
sound/soc/codecs/aw88166.c
1201
&aw88166->start_work,
sound/soc/codecs/aw88166.c
1282
struct aw88166 *aw88166 = snd_soc_component_get_drvdata(component);
sound/soc/codecs/aw88166.c
1283
struct aw_device *aw_dev = aw88166->aw_pa;
sound/soc/codecs/aw88166.c
1294
struct aw88166 *aw88166 = snd_soc_component_get_drvdata(component);
sound/soc/codecs/aw88166.c
1297
struct aw_device *aw_dev = aw88166->aw_pa;
sound/soc/codecs/aw88166.c
1317
struct aw88166 *aw88166 = snd_soc_component_get_drvdata(component);
sound/soc/codecs/aw88166.c
1318
struct aw_device *aw_dev = aw88166->aw_pa;
sound/soc/codecs/aw88166.c
1329
struct aw88166 *aw88166 = snd_soc_component_get_drvdata(component);
sound/soc/codecs/aw88166.c
1332
struct aw_device *aw_dev = aw88166->aw_pa;
sound/soc/codecs/aw88166.c
1367
struct aw88166 *aw88166 = snd_soc_component_get_drvdata(codec);
sound/soc/codecs/aw88166.c
1374
count = aw88166->aw_pa->prof_info.count;
sound/soc/codecs/aw88166.c
1387
ret = aw88166_dev_get_prof_name(aw88166->aw_pa, count, &prof_name);
sound/soc/codecs/aw88166.c
1402
struct aw88166 *aw88166 = snd_soc_component_get_drvdata(codec);
sound/soc/codecs/aw88166.c
1404
ucontrol->value.integer.value[0] = aw88166->aw_pa->prof_index;
sound/soc/codecs/aw88166.c
1413
struct aw88166 *aw88166 = snd_soc_component_get_drvdata(codec);
sound/soc/codecs/aw88166.c
1416
mutex_lock(&aw88166->lock);
sound/soc/codecs/aw88166.c
1417
ret = aw88166_dev_set_profile_index(aw88166->aw_pa, ucontrol->value.integer.value[0]);
sound/soc/codecs/aw88166.c
1420
mutex_unlock(&aw88166->lock);
sound/soc/codecs/aw88166.c
1424
if (aw88166->aw_pa->status) {
sound/soc/codecs/aw88166.c
1425
aw88166_stop(aw88166->aw_pa);
sound/soc/codecs/aw88166.c
1426
aw88166_start(aw88166, AW88166_SYNC_START);
sound/soc/codecs/aw88166.c
1429
mutex_unlock(&aw88166->lock);
sound/soc/codecs/aw88166.c
1438
struct aw88166 *aw88166 = snd_soc_component_get_drvdata(codec);
sound/soc/codecs/aw88166.c
1439
struct aw_volume_desc *vol_desc = &aw88166->aw_pa->volume_desc;
sound/soc/codecs/aw88166.c
1450
struct aw88166 *aw88166 = snd_soc_component_get_drvdata(codec);
sound/soc/codecs/aw88166.c
1451
struct aw_volume_desc *vol_desc = &aw88166->aw_pa->volume_desc;
sound/soc/codecs/aw88166.c
1462
aw_dev_set_volume(aw88166->aw_pa, vol_desc->ctl_volume);
sound/soc/codecs/aw88166.c
1474
struct aw88166 *aw88166 = snd_soc_component_get_drvdata(codec);
sound/soc/codecs/aw88166.c
1476
ucontrol->value.integer.value[0] = aw88166->aw_pa->fade_step;
sound/soc/codecs/aw88166.c
1485
struct aw88166 *aw88166 = snd_soc_component_get_drvdata(codec);
sound/soc/codecs/aw88166.c
1494
if (aw88166->aw_pa->fade_step != value) {
sound/soc/codecs/aw88166.c
1495
aw88166->aw_pa->fade_step = value;
sound/soc/codecs/aw88166.c
1506
struct aw88166 *aw88166 = snd_soc_component_get_drvdata(codec);
sound/soc/codecs/aw88166.c
1507
struct aw_device *aw_dev = aw88166->aw_pa;
sound/soc/codecs/aw88166.c
1518
struct aw88166 *aw88166 = snd_soc_component_get_drvdata(codec);
sound/soc/codecs/aw88166.c
1521
struct aw_device *aw_dev = aw88166->aw_pa;
sound/soc/codecs/aw88166.c
1536
static int aw88166_dev_init(struct aw88166 *aw88166, struct aw_container *aw_cfg)
sound/soc/codecs/aw88166.c
1538
struct aw_device *aw_dev = aw88166->aw_pa;
sound/soc/codecs/aw88166.c
1551
ret = aw88166_dev_fw_update(aw88166, AW88166_FORCE_UPDATE_ON, AW88166_DSP_FW_UPDATE_ON);
sound/soc/codecs/aw88166.c
1574
static int aw88166_request_firmware_file(struct aw88166 *aw88166)
sound/soc/codecs/aw88166.c
1579
aw88166->aw_pa->fw_status = AW88166_DEV_FW_FAILED;
sound/soc/codecs/aw88166.c
1581
ret = request_firmware(&cont, AW88166_ACF_FILE, aw88166->aw_pa->dev);
sound/soc/codecs/aw88166.c
1583
dev_err(aw88166->aw_pa->dev, "request [%s] failed!\n", AW88166_ACF_FILE);
sound/soc/codecs/aw88166.c
1587
dev_dbg(aw88166->aw_pa->dev, "loaded %s - size: %zu\n",
sound/soc/codecs/aw88166.c
1590
aw88166->aw_cfg = devm_kzalloc(aw88166->aw_pa->dev,
sound/soc/codecs/aw88166.c
1591
struct_size(aw88166->aw_cfg, data, cont->size), GFP_KERNEL);
sound/soc/codecs/aw88166.c
1592
if (!aw88166->aw_cfg) {
sound/soc/codecs/aw88166.c
1596
aw88166->aw_cfg->len = (int)cont->size;
sound/soc/codecs/aw88166.c
1597
memcpy(aw88166->aw_cfg->data, cont->data, cont->size);
sound/soc/codecs/aw88166.c
1600
ret = aw88395_dev_load_acf_check(aw88166->aw_pa, aw88166->aw_cfg);
sound/soc/codecs/aw88166.c
1602
dev_err(aw88166->aw_pa->dev, "load [%s] failed!\n", AW88166_ACF_FILE);
sound/soc/codecs/aw88166.c
1606
mutex_lock(&aw88166->lock);
sound/soc/codecs/aw88166.c
1608
ret = aw88166_dev_init(aw88166, aw88166->aw_cfg);
sound/soc/codecs/aw88166.c
1610
dev_err(aw88166->aw_pa->dev, "dev init failed\n");
sound/soc/codecs/aw88166.c
1611
mutex_unlock(&aw88166->lock);
sound/soc/codecs/aw88166.c
1636
struct aw88166 *aw88166 = snd_soc_component_get_drvdata(component);
sound/soc/codecs/aw88166.c
1638
mutex_lock(&aw88166->lock);
sound/soc/codecs/aw88166.c
1641
aw88166_start(aw88166, AW88166_ASYNC_START);
sound/soc/codecs/aw88166.c
1644
aw88166_stop(aw88166->aw_pa);
sound/soc/codecs/aw88166.c
1649
mutex_unlock(&aw88166->lock);
sound/soc/codecs/aw88166.c
1673
struct aw88166 *aw88166 = snd_soc_component_get_drvdata(component);
sound/soc/codecs/aw88166.c
1676
INIT_DELAYED_WORK(&aw88166->start_work, aw88166_startup_work);
sound/soc/codecs/aw88166.c
1678
ret = aw88166_request_firmware_file(aw88166);
sound/soc/codecs/aw88166.c
1680
dev_err(aw88166->aw_pa->dev, "%s failed\n", __func__);
sound/soc/codecs/aw88166.c
1687
struct aw88166 *aw88166 = snd_soc_component_get_drvdata(aw_codec);
sound/soc/codecs/aw88166.c
1689
cancel_delayed_work_sync(&aw88166->start_work);
sound/soc/codecs/aw88166.c
1703
static void aw88166_hw_reset(struct aw88166 *aw88166)
sound/soc/codecs/aw88166.c
1705
if (aw88166->reset_gpio) {
sound/soc/codecs/aw88166.c
1706
gpiod_set_value_cansleep(aw88166->reset_gpio, 1);
sound/soc/codecs/aw88166.c
1708
gpiod_set_value_cansleep(aw88166->reset_gpio, 0);
sound/soc/codecs/aw88166.c
1713
static void aw88166_parse_channel_dt(struct aw88166 *aw88166)
sound/soc/codecs/aw88166.c
1715
struct aw_device *aw_dev = aw88166->aw_pa;
sound/soc/codecs/aw88166.c
1721
aw88166->phase_sync = of_property_read_bool(np, "awinic,sync-flag");
sound/soc/codecs/aw88166.c
1724
static int aw88166_init(struct aw88166 *aw88166, struct i2c_client *i2c, struct regmap *regmap)
sound/soc/codecs/aw88166.c
1739
aw88166->aw_pa = aw_dev;
sound/soc/codecs/aw88166.c
1757
aw88166_parse_channel_dt(aw88166);
sound/soc/codecs/aw88166.c
1764
struct aw88166 *aw88166;
sound/soc/codecs/aw88166.c
1770
aw88166 = devm_kzalloc(&i2c->dev, sizeof(*aw88166), GFP_KERNEL);
sound/soc/codecs/aw88166.c
1771
if (!aw88166)
sound/soc/codecs/aw88166.c
1774
mutex_init(&aw88166->lock);
sound/soc/codecs/aw88166.c
1776
i2c_set_clientdata(i2c, aw88166);
sound/soc/codecs/aw88166.c
1778
aw88166->reset_gpio = devm_gpiod_get_optional(&i2c->dev, "reset", GPIOD_OUT_LOW);
sound/soc/codecs/aw88166.c
1779
if (IS_ERR(aw88166->reset_gpio))
sound/soc/codecs/aw88166.c
1780
return dev_err_probe(&i2c->dev, PTR_ERR(aw88166->reset_gpio),
sound/soc/codecs/aw88166.c
1782
aw88166_hw_reset(aw88166);
sound/soc/codecs/aw88166.c
1784
aw88166->regmap = devm_regmap_init_i2c(i2c, &aw88166_remap_config);
sound/soc/codecs/aw88166.c
1785
if (IS_ERR(aw88166->regmap))
sound/soc/codecs/aw88166.c
1786
return dev_err_probe(&i2c->dev, PTR_ERR(aw88166->regmap),
sound/soc/codecs/aw88166.c
1790
ret = aw88166_init(aw88166, i2c, aw88166->regmap);
sound/soc/codecs/aw88166.c
247
static int aw88166_dev_get_icalk(struct aw88166 *aw88166, int16_t *icalk)
sound/soc/codecs/aw88166.c
249
struct aw_device *aw_dev = aw88166->aw_pa;
sound/soc/codecs/aw88166.c
269
if (aw88166->check_val == AW_EF_AND_CHECK)
sound/soc/codecs/aw88166.c
281
static int aw88166_dev_get_vcalk(struct aw88166 *aw88166, int16_t *vcalk)
sound/soc/codecs/aw88166.c
283
struct aw_device *aw_dev = aw88166->aw_pa;
sound/soc/codecs/aw88166.c
303
if (aw88166->check_val == AW_EF_AND_CHECK)
sound/soc/codecs/aw88166.c
315
static int aw88166_dev_set_vcalb(struct aw88166 *aw88166)
sound/soc/codecs/aw88166.c
317
struct aw_device *aw_dev = aw88166->aw_pa;
sound/soc/codecs/aw88166.c
323
ret = aw88166_dev_get_icalk(aw88166, &icalk);
sound/soc/codecs/aw88166.c
330
ret = aw88166_dev_get_vcalk(aw88166, &vcalk);
sound/soc/codecs/aw88166.c
338
AW88166_ISCAL_FACTOR * ical_k / vcal_k * aw88166->vcalb_init_val;
sound/soc/codecs/aw88166.c
348
static int aw_dev_init_vcalb_update(struct aw88166 *aw88166, int flag)
sound/soc/codecs/aw88166.c
350
struct aw_device *aw_dev = aw88166->aw_pa;
sound/soc/codecs/aw88166.c
355
ret = regmap_write(aw_dev->regmap, AW88166_DSPVCALB_REG, aw88166->vcalb_init_val);
sound/soc/codecs/aw88166.c
358
ret = regmap_read(aw_dev->regmap, AW88166_DSPVCALB_REG, &aw88166->vcalb_init_val);
sound/soc/codecs/aw88166.c
369
static int aw_dev_init_re_update(struct aw88166 *aw88166, int flag)
sound/soc/codecs/aw88166.c
371
struct aw_device *aw_dev = aw88166->aw_pa;
sound/soc/codecs/aw88166.c
377
ret = regmap_write(aw_dev->regmap, AW88166_ACR1_REG, aw88166->re_init_val >> 16);
sound/soc/codecs/aw88166.c
381
(uint16_t)aw88166->re_init_val);
sound/soc/codecs/aw88166.c
392
aw88166->re_init_val = (re_temp_h << 16) + re_temp_l;
sound/soc/codecs/aw88166.c
403
static void aw_dev_backup_sec_record(struct aw88166 *aw88166)
sound/soc/codecs/aw88166.c
405
aw_dev_init_vcalb_update(aw88166, AW88166_RECORD_SEC_DATA);
sound/soc/codecs/aw88166.c
406
aw_dev_init_re_update(aw88166, AW88166_RECOVERY_SEC_DATA);
sound/soc/codecs/aw88166.c
409
static void aw_dev_backup_sec_recovery(struct aw88166 *aw88166)
sound/soc/codecs/aw88166.c
411
aw_dev_init_vcalb_update(aw88166, AW88166_RECOVERY_SEC_DATA);
sound/soc/codecs/aw88166.c
412
aw_dev_init_re_update(aw88166, AW88166_RECOVERY_SEC_DATA);
sound/soc/codecs/aw88166.c
533
static int aw_dev_hw_crc_check(struct aw88166 *aw88166)
sound/soc/codecs/aw88166.c
535
struct aw_device *aw_dev = aw88166->aw_pa;
sound/soc/codecs/aw88166.c
555
ret = regmap_write(aw_dev->regmap, AW88166_CRCCTRL_REG, aw88166->crc_init_val);
sound/soc/codecs/aw88166.c
707
static void aw88166_dev_set_dither(struct aw88166 *aw88166, bool dither)
sound/soc/codecs/aw88166.c
709
struct aw_device *aw_dev = aw88166->aw_pa;
sound/soc/codecs/aw88166.c
719
static int aw88166_dev_start(struct aw88166 *aw88166)
sound/soc/codecs/aw88166.c
721
struct aw_device *aw_dev = aw88166->aw_pa;
sound/soc/codecs/aw88166.c
729
aw88166_dev_set_dither(aw88166, false);
sound/soc/codecs/aw88166.c
753
aw_dev_backup_sec_recovery(aw88166);
sound/soc/codecs/aw88166.c
754
ret = aw_dev_hw_crc_check(aw88166);
sound/soc/codecs/aw88166.c
760
aw88166_dev_set_vcalb(aw88166);
sound/soc/codecs/aw88166.c
774
if (aw88166->dither_st == AW88166_DITHER_EN_ENABLE_VALUE)
sound/soc/codecs/aw88166.c
775
aw88166_dev_set_dither(aw88166, true);
sound/soc/codecs/aw88166.c
930
static int aw_dev_update_reg_container(struct aw88166 *aw88166,
sound/soc/codecs/aw88166.c
933
struct aw_device *aw_dev = aw88166->aw_pa;
sound/soc/codecs/aw88166.c
953
aw88166->vcalb_init_val = reg_val;
sound/soc/codecs/aw88166.c
982
aw88166->check_val = AW_EF_OR_CHECK;
sound/soc/codecs/aw88166.c
984
aw88166->check_val = AW_EF_AND_CHECK;
sound/soc/codecs/aw88166.c
986
aw88166->dither_st = reg_val & (~AW88166_DITHER_EN_MASK);
sound/soc/codecs/aw88166.c
990
aw88166->re_init_val |= (uint32_t)reg_val << 16;
sound/soc/codecs/aw88166.c
995
aw88166->re_init_val |= (uint32_t)reg_val;