aw88399
dev_err(aw88399->aw_pa->dev, "reg update failed");
static int aw88399_dev_fw_update(struct aw88399 *aw88399, bool up_dsp_fw_en, bool force_up_en)
struct aw_device *aw_dev = aw88399->aw_pa;
ret = aw_dev_reg_update(aw88399, sec_desc[AW88395_DATA_TYPE_REG].data,
static void aw88399_start_pa(struct aw88399 *aw88399)
ret = aw88399_dev_start(aw88399);
dev_err(aw88399->aw_pa->dev, "aw88399 device start failed. retry = %d", i);
ret = aw88399_dev_fw_update(aw88399, AW88399_DSP_FW_UPDATE_ON, true);
dev_err(aw88399->aw_pa->dev, "fw update failed");
dev_dbg(aw88399->aw_pa->dev, "start success\n");
struct aw88399 *aw88399 =
container_of(work, struct aw88399, start_work.work);
mutex_lock(&aw88399->lock);
aw88399_start_pa(aw88399);
mutex_unlock(&aw88399->lock);
static void aw88399_start(struct aw88399 *aw88399, bool sync_start)
if (aw88399->aw_pa->fw_status != AW88399_DEV_FW_OK)
if (aw88399->aw_pa->status == AW88399_DEV_PW_ON)
ret = aw88399_dev_fw_update(aw88399, AW88399_DSP_FW_UPDATE_OFF, true);
dev_err(aw88399->aw_pa->dev, "fw update failed.");
aw88399_start_pa(aw88399);
&aw88399->start_work,
static int aw_cali_svc_dev_cali_re(struct aw88399 *aw88399)
struct aw_device *aw_dev = aw88399->aw_pa;
struct aw88399 *aw88399 = snd_soc_component_get_drvdata(component);
struct aw_device *aw_dev = aw88399->aw_pa;
struct aw88399 *aw88399 = snd_soc_component_get_drvdata(component);
struct aw_device *aw_dev = aw88399->aw_pa;
struct aw88399 *aw88399 = snd_soc_component_get_drvdata(component);
struct aw_device *aw_dev = aw88399->aw_pa;
struct aw88399 *aw88399 = snd_soc_component_get_drvdata(component);
struct aw_device *aw_dev = aw88399->aw_pa;
struct aw88399 *aw88399 = snd_soc_component_get_drvdata(codec);
count = aw88399->aw_pa->prof_info.count;
ret = aw88399_dev_get_prof_name(aw88399->aw_pa, count, &prof_name);
struct aw88399 *aw88399 = snd_soc_component_get_drvdata(codec);
ucontrol->value.integer.value[0] = aw88399->aw_pa->prof_index;
struct aw88399 *aw88399 = snd_soc_component_get_drvdata(codec);
mutex_lock(&aw88399->lock);
ret = aw88399_dev_set_profile_index(aw88399->aw_pa, ucontrol->value.integer.value[0]);
mutex_unlock(&aw88399->lock);
if (aw88399->aw_pa->status) {
aw88399_stop(aw88399->aw_pa);
aw88399_start(aw88399, AW88399_SYNC_START);
mutex_unlock(&aw88399->lock);
struct aw88399 *aw88399 = snd_soc_component_get_drvdata(codec);
struct aw_volume_desc *vol_desc = &aw88399->aw_pa->volume_desc;
struct aw88399 *aw88399 = snd_soc_component_get_drvdata(codec);
struct aw_volume_desc *vol_desc = &aw88399->aw_pa->volume_desc;
aw_dev_set_volume(aw88399->aw_pa, vol_desc->ctl_volume);
struct aw88399 *aw88399 = snd_soc_component_get_drvdata(codec);
ucontrol->value.integer.value[0] = aw88399->aw_pa->fade_step;
struct aw88399 *aw88399 = snd_soc_component_get_drvdata(codec);
if (aw88399->aw_pa->fade_step != value) {
aw88399->aw_pa->fade_step = value;
struct aw88399 *aw88399 = snd_soc_component_get_drvdata(codec);
struct aw_device *aw_dev = aw88399->aw_pa;
struct aw88399 *aw88399 = snd_soc_component_get_drvdata(codec);
struct aw_device *aw_dev = aw88399->aw_pa;
struct aw88399 *aw88399 = snd_soc_component_get_drvdata(codec);
struct aw_device *aw_dev = aw88399->aw_pa;
struct aw88399 *aw88399 = snd_soc_component_get_drvdata(codec);
struct aw_device *aw_dev = aw88399->aw_pa;
struct aw88399 *aw88399 = snd_soc_component_get_drvdata(codec);
struct aw_device *aw_dev = aw88399->aw_pa;
aw_cali_svc_dev_cali_re(aw88399);
static int aw88399_dev_init(struct aw88399 *aw88399, struct aw_container *aw_cfg)
struct aw_device *aw_dev = aw88399->aw_pa;
ret = aw88399_dev_fw_update(aw88399, AW88399_FORCE_UPDATE_ON, AW88399_DSP_FW_UPDATE_ON);
static int aw88399_request_firmware_file(struct aw88399 *aw88399)
aw88399->aw_pa->fw_status = AW88399_DEV_FW_FAILED;
ret = request_firmware(&cont, AW88399_ACF_FILE, aw88399->aw_pa->dev);
dev_err(aw88399->aw_pa->dev, "request [%s] failed!", AW88399_ACF_FILE);
dev_dbg(aw88399->aw_pa->dev, "loaded %s - size: %zu\n",
aw88399->aw_cfg = devm_kzalloc(aw88399->aw_pa->dev,
struct_size(aw88399->aw_cfg, data, cont->size), GFP_KERNEL);
if (!aw88399->aw_cfg) {
aw88399->aw_cfg->len = (int)cont->size;
memcpy(aw88399->aw_cfg->data, cont->data, cont->size);
ret = aw88395_dev_load_acf_check(aw88399->aw_pa, aw88399->aw_cfg);
dev_err(aw88399->aw_pa->dev, "load [%s] failed!", AW88399_ACF_FILE);
mutex_lock(&aw88399->lock);
ret = aw88399_dev_init(aw88399, aw88399->aw_cfg);
dev_err(aw88399->aw_pa->dev, "dev init failed");
mutex_unlock(&aw88399->lock);
struct aw88399 *aw88399 = snd_soc_component_get_drvdata(component);
mutex_lock(&aw88399->lock);
aw88399_start(aw88399, AW88399_ASYNC_START);
aw88399_stop(aw88399->aw_pa);
mutex_unlock(&aw88399->lock);
struct aw88399 *aw88399 = snd_soc_component_get_drvdata(component);
INIT_DELAYED_WORK(&aw88399->start_work, aw88399_startup_work);
ret = aw88399_request_firmware_file(aw88399);
dev_err(aw88399->aw_pa->dev, "%s failed\n", __func__);
struct aw88399 *aw88399 = snd_soc_component_get_drvdata(aw_codec);
cancel_delayed_work_sync(&aw88399->start_work);
static void aw88399_hw_reset(struct aw88399 *aw88399)
if (aw88399->reset_gpio) {
gpiod_set_value_cansleep(aw88399->reset_gpio, 1);
gpiod_set_value_cansleep(aw88399->reset_gpio, 0);
gpiod_set_value_cansleep(aw88399->reset_gpio, 1);
static int aw88399_init(struct aw88399 *aw88399, struct i2c_client *i2c, struct regmap *regmap)
aw88399->aw_pa = aw_dev;
struct aw88399 *aw88399;
aw88399 = devm_kzalloc(&i2c->dev, sizeof(*aw88399), GFP_KERNEL);
if (!aw88399)
mutex_init(&aw88399->lock);
i2c_set_clientdata(i2c, aw88399);
aw88399->reset_gpio = devm_gpiod_get_optional(&i2c->dev, "reset", GPIOD_OUT_LOW);
if (IS_ERR(aw88399->reset_gpio))
return dev_err_probe(&i2c->dev, PTR_ERR(aw88399->reset_gpio),
aw88399_hw_reset(aw88399);
aw88399->regmap = devm_regmap_init_i2c(i2c, &aw88399_remap_config);
if (IS_ERR(aw88399->regmap))
return dev_err_probe(&i2c->dev, PTR_ERR(aw88399->regmap),
ret = aw88399_init(aw88399, i2c, aw88399->regmap);
static int aw88399_dev_get_icalk(struct aw88399 *aw88399, int16_t *icalk)
struct aw_device *aw_dev = aw88399->aw_pa;
if (aw88399->check_val == AW_EF_AND_CHECK)
static int aw88399_dev_get_vcalk(struct aw88399 *aw88399, int16_t *vcalk)
struct aw_device *aw_dev = aw88399->aw_pa;
if (aw88399->check_val == AW_EF_AND_CHECK)
static int aw88399_dev_get_internal_vcalk(struct aw88399 *aw88399, int16_t *vcalk)
struct aw_device *aw_dev = aw88399->aw_pa;
if (aw88399->check_val == AW_EF_AND_CHECK)
static int aw_dev_set_vcalb(struct aw88399 *aw88399)
struct aw_device *aw_dev = aw88399->aw_pa;
ret = aw88399_dev_get_icalk(aw88399, &icalk);
ret = aw88399_dev_get_vcalk(aw88399, &vcalk);
ical_k / vcal_k * aw88399->vcalb_init_val;
ret = aw88399_dev_get_internal_vcalk(aw88399, &vcalk);
vcal_k * aw88399->vcalb_init_val;
static int aw_dev_hw_crc_check(struct aw88399 *aw88399)
struct aw_device *aw_dev = aw88399->aw_pa;
ret = regmap_write(aw_dev->regmap, AW88399_CRCCTRL_REG, aw88399->crc_init_val);
static void aw88399_dev_set_dither(struct aw88399 *aw88399, bool dither)
struct aw_device *aw_dev = aw88399->aw_pa;
static int aw88399_dev_start(struct aw88399 *aw88399)
struct aw_device *aw_dev = aw88399->aw_pa;
aw88399_dev_set_dither(aw88399, false);
ret = aw_dev_hw_crc_check(aw88399);
aw_dev_set_vcalb(aw88399);
if (aw88399->dither_st == AW88399_DITHER_EN_ENABLE_VALUE)
aw88399_dev_set_dither(aw88399, true);
static int aw_dev_update_reg_container(struct aw88399 *aw88399,
struct aw_device *aw_dev = aw88399->aw_pa;
aw88399->vcalb_init_val = reg_val;
aw88399->check_val = AW_EF_OR_CHECK;
aw88399->check_val = AW_EF_AND_CHECK;
aw88399->dither_st = reg_val & (~AW88399_DITHER_EN_MASK);
aw88399->crc_init_val = reg_val;
static int aw_dev_reg_update(struct aw88399 *aw88399,
dev_err(aw88399->aw_pa->dev, "reg data is null or len is 0");
ret = aw_dev_update_reg_container(aw88399, data, len);