Lines Matching defs:aw_dev

27 static void aw88261_dev_set_volume(struct aw_device *aw_dev, unsigned int value)
29 struct aw_volume_desc *vol_desc = &aw_dev->volume_desc;
36 regmap_read(aw_dev->regmap, AW88261_SYSCTRL2_REG, &reg_value);
40 dev_dbg(aw_dev->dev, "value 0x%x , real_value:0x%x", value, real_value);
42 regmap_write(aw_dev->regmap, AW88261_SYSCTRL2_REG, real_value);
45 static void aw88261_dev_fade_in(struct aw_device *aw_dev)
47 struct aw_volume_desc *desc = &aw_dev->volume_desc;
49 int fade_step = aw_dev->fade_step;
52 if (fade_step == 0 || aw_dev->fade_in_time == 0) {
53 aw88261_dev_set_volume(aw_dev, fade_in_vol);
58 aw88261_dev_set_volume(aw_dev, i);
59 usleep_range(aw_dev->fade_in_time,
60 aw_dev->fade_in_time + 10);
64 aw88261_dev_set_volume(aw_dev, fade_in_vol);
67 static void aw88261_dev_fade_out(struct aw_device *aw_dev)
69 struct aw_volume_desc *desc = &aw_dev->volume_desc;
70 int fade_step = aw_dev->fade_step;
73 if (fade_step == 0 || aw_dev->fade_out_time == 0) {
74 aw88261_dev_set_volume(aw_dev, AW88261_MUTE_VOL);
79 aw88261_dev_set_volume(aw_dev, i);
80 usleep_range(aw_dev->fade_out_time, aw_dev->fade_out_time + 10);
84 aw88261_dev_set_volume(aw_dev, AW88261_MUTE_VOL);
85 usleep_range(aw_dev->fade_out_time, aw_dev->fade_out_time + 10);
89 static void aw88261_dev_i2s_tx_enable(struct aw_device *aw_dev, bool flag)
92 regmap_update_bits(aw_dev->regmap, AW88261_I2SCFG1_REG,
95 regmap_update_bits(aw_dev->regmap, AW88261_I2SCFG1_REG,
99 static void aw88261_dev_pwd(struct aw_device *aw_dev, bool pwd)
102 regmap_update_bits(aw_dev->regmap, AW88261_SYSCTRL_REG,
105 regmap_update_bits(aw_dev->regmap, AW88261_SYSCTRL_REG,
109 static void aw88261_dev_amppd(struct aw_device *aw_dev, bool amppd)
112 regmap_update_bits(aw_dev->regmap, AW88261_SYSCTRL_REG,
115 regmap_update_bits(aw_dev->regmap, AW88261_SYSCTRL_REG,
119 static void aw88261_dev_mute(struct aw_device *aw_dev, bool is_mute)
122 aw88261_dev_fade_out(aw_dev);
123 regmap_update_bits(aw_dev->regmap, AW88261_SYSCTRL_REG,
126 regmap_update_bits(aw_dev->regmap, AW88261_SYSCTRL_REG,
128 aw88261_dev_fade_in(aw_dev);
132 static void aw88261_dev_clear_int_status(struct aw_device *aw_dev)
137 regmap_read(aw_dev->regmap, AW88261_SYSINT_REG, &int_status);
139 regmap_read(aw_dev->regmap, AW88261_SYSINT_REG, &int_status);
141 dev_dbg(aw_dev->dev, "read interrupt reg = 0x%04x", int_status);
144 static int aw88261_dev_get_iis_status(struct aw_device *aw_dev)
149 ret = regmap_read(aw_dev->regmap, AW88261_SYSST_REG, &reg_val);
153 dev_err(aw_dev->dev, "check pll lock fail,reg_val:0x%04x", reg_val);
160 static int aw88261_dev_check_mode1_pll(struct aw_device *aw_dev)
165 ret = aw88261_dev_get_iis_status(aw_dev);
167 dev_err(aw_dev->dev, "mode1 iis signal check error");
177 static int aw88261_dev_check_mode2_pll(struct aw_device *aw_dev)
182 ret = regmap_read(aw_dev->regmap, AW88261_PLLCTRL1_REG, &reg_val);
188 dev_dbg(aw_dev->dev, "CCO_MUX is already divider");
193 ret = regmap_update_bits(aw_dev->regmap, AW88261_PLLCTRL1_REG,
199 ret = aw88261_dev_get_iis_status(aw_dev);
201 dev_err(aw_dev->dev, "mode2 iis signal check error");
209 ret = regmap_update_bits(aw_dev->regmap, AW88261_PLLCTRL1_REG,
214 ret = aw88261_dev_check_mode1_pll(aw_dev);
216 dev_err(aw_dev->dev, "mode2 switch to mode1, iis signal check error");
227 static int aw88261_dev_check_syspll(struct aw_device *aw_dev)
231 ret = aw88261_dev_check_mode1_pll(aw_dev);
233 dev_dbg(aw_dev->dev, "mode1 check iis failed try switch to mode2 check");
234 ret = aw88261_dev_check_mode2_pll(aw_dev);
236 dev_err(aw_dev->dev, "mode2 check iis failed");
244 static int aw88261_dev_check_sysst(struct aw_device *aw_dev)
251 ret = regmap_read(aw_dev->regmap, AW88261_SYSST_REG, &reg_val);
258 dev_err(aw_dev->dev, "check sysst fail, reg_val=0x%04x, check:0x%x",
269 static void aw88261_dev_uls_hmute(struct aw_device *aw_dev, bool uls_hmute)
272 regmap_update_bits(aw_dev->regmap, AW88261_SYSCTRL_REG,
276 regmap_update_bits(aw_dev->regmap, AW88261_SYSCTRL_REG,
307 static int aw88261_dev_get_icalk(struct aw_device *aw_dev, int16_t *icalk)
313 ret = regmap_read(aw_dev->regmap, AW88261_EFRH4_REG, &reg_val);
319 ret = regmap_read(aw_dev->regmap, AW88261_EFRL4_REG, &reg_val);
335 static int aw88261_dev_get_vcalk(struct aw_device *aw_dev, int16_t *vcalk)
341 ret = regmap_read(aw_dev->regmap, AW88261_EFRH3_REG, &reg_val);
347 ret = regmap_read(aw_dev->regmap, AW88261_EFRL3_REG, &reg_val);
362 static int aw88261_dev_set_vcalb(struct aw_device *aw_dev)
369 ret = aw88261_dev_get_icalk(aw_dev, &icalk_val);
373 ret = aw88261_dev_get_vcalk(aw_dev, &vcalk_val);
385 dev_dbg(aw_dev->dev, "icalk=%d, vcalk=%d, vcalb=%d, reg_val=0x%04x",
387 ret = regmap_write(aw_dev->regmap, AW88261_VSNTM1_REG, reg_val);
395 struct aw_device *aw_dev = aw88261->aw_pa;
396 struct aw_volume_desc *vol_desc = &aw_dev->volume_desc;
404 dev_err(aw_dev->dev, "reg data is null or len is 0");
412 dev_err(aw_dev->dev, "data len:%d unsupported", data_len);
422 ret = regmap_read(aw_dev->regmap, reg_addr, &read_val);
454 aw_dev->volume_desc.init_volume =
461 ret = regmap_write(aw_dev->regmap, reg_addr, reg_val);
466 ret = aw88261_dev_set_vcalb(aw_dev);
470 if (aw_dev->prof_cur != aw_dev->prof_index)
474 aw88261_dev_set_volume(aw_dev, vol_desc->mute_volume);
479 static int aw88261_dev_get_prof_name(struct aw_device *aw_dev, int index, char **prof_name)
481 struct aw_prof_info *prof_info = &aw_dev->prof_info;
484 if ((index >= aw_dev->prof_info.count) || (index < 0)) {
485 dev_err(aw_dev->dev, "index[%d] overflow count[%d]",
486 index, aw_dev->prof_info.count);
490 prof_desc = &aw_dev->prof_info.prof_desc[index];
497 static int aw88261_dev_get_prof_data(struct aw_device *aw_dev, int index,
500 if ((index >= aw_dev->prof_info.count) || (index < 0)) {
501 dev_err(aw_dev->dev, "%s: index[%d] overflow count[%d]\n",
502 __func__, index, aw_dev->prof_info.count);
506 *prof_desc = &aw_dev->prof_info.prof_desc[index];
513 struct aw_device *aw_dev = aw88261->aw_pa;
519 ret = aw88261_dev_get_prof_name(aw_dev, aw_dev->prof_index, &prof_name);
521 dev_err(aw_dev->dev, "get prof name failed");
525 dev_dbg(aw_dev->dev, "start update %s", prof_name);
527 ret = aw88261_dev_get_prof_data(aw_dev, aw_dev->prof_index, &prof_index_desc);
536 dev_err(aw_dev->dev, "update reg failed");
540 aw_dev->prof_cur = aw_dev->prof_index;
547 struct aw_device *aw_dev = aw88261->aw_pa;
550 if (aw_dev->status == AW88261_DEV_PW_ON) {
551 dev_info(aw_dev->dev, "already power on");
556 aw88261_dev_pwd(aw_dev, false);
559 ret = aw88261_dev_check_syspll(aw_dev);
561 dev_err(aw_dev->dev, "pll check failed cannot start");
566 aw88261_dev_amppd(aw_dev, false);
570 ret = aw88261_dev_check_sysst(aw_dev);
572 dev_err(aw_dev->dev, "sysst check failed");
577 aw88261_dev_i2s_tx_enable(aw_dev, true);
580 aw88261_dev_amppd(aw_dev, true);
585 aw88261_dev_uls_hmute(aw_dev, false);
589 aw88261_dev_mute(aw_dev, false);
592 aw88261_dev_clear_int_status(aw_dev);
593 aw_dev->status = AW88261_DEV_PW_ON;
598 aw88261_dev_i2s_tx_enable(aw_dev, false);
599 aw88261_dev_clear_int_status(aw_dev);
600 aw88261_dev_amppd(aw_dev, true);
602 aw88261_dev_pwd(aw_dev, true);
603 aw_dev->status = AW88261_DEV_PW_OFF;
608 static int aw88261_dev_stop(struct aw_device *aw_dev)
610 if (aw_dev->status == AW88261_DEV_PW_OFF) {
611 dev_info(aw_dev->dev, "already power off");
615 aw_dev->status = AW88261_DEV_PW_OFF;
618 aw88261_dev_clear_int_status(aw_dev);
620 aw88261_dev_uls_hmute(aw_dev, true);
622 aw88261_dev_mute(aw_dev, true);
625 aw88261_dev_i2s_tx_enable(aw_dev, false);
629 aw88261_dev_amppd(aw_dev, true);
632 aw88261_dev_pwd(aw_dev, true);
639 struct aw_device *aw_dev = aw88261->aw_pa;
643 ret = regmap_write(aw_dev->regmap,
652 if (aw_dev->prof_cur != aw_dev->prof_index) {
661 aw_dev->prof_cur = aw_dev->prof_index;
739 struct aw_device *aw_dev = aw88261->aw_pa;
741 ucontrol->value.integer.value[0] = aw_dev->fade_in_time;
753 struct aw_device *aw_dev = aw88261->aw_pa;
761 if (time != aw_dev->fade_in_time) {
762 aw_dev->fade_in_time = time;
774 struct aw_device *aw_dev = aw88261->aw_pa;
776 ucontrol->value.integer.value[0] = aw_dev->fade_out_time;
788 struct aw_device *aw_dev = aw88261->aw_pa;
795 if (time != aw_dev->fade_out_time) {
796 aw_dev->fade_out_time = time;
803 static int aw88261_dev_set_profile_index(struct aw_device *aw_dev, int index)
806 if ((index >= aw_dev->prof_info.count) || (index < 0))
809 if (aw_dev->prof_index == index)
812 aw_dev->prof_index = index;
1047 struct aw_device *aw_dev = aw88261->aw_pa;
1050 ret = aw88395_dev_cfg_load(aw_dev, aw_cfg);
1052 dev_err(aw_dev->dev, "aw_dev acf parse failed");
1056 ret = regmap_write(aw_dev->regmap, AW88261_ID_REG, AW88261_SOFT_RESET_VALUE);
1060 aw_dev->fade_in_time = AW88261_500_US;
1061 aw_dev->fade_out_time = AW88261_500_US;
1062 aw_dev->prof_cur = AW88261_INIT_PROFILE;
1063 aw_dev->prof_index = AW88261_INIT_PROFILE;
1067 dev_err(aw_dev->dev, "fw update failed ret = %d\n", ret);
1073 dev_err(aw_dev->dev, "aw88261_frcset_check ret = %d\n", ret);
1077 aw88261_dev_clear_int_status(aw_dev);
1079 aw88261_dev_uls_hmute(aw_dev, true);
1081 aw88261_dev_mute(aw_dev, true);
1083 aw88261_dev_i2s_tx_enable(aw_dev, false);
1087 aw88261_dev_amppd(aw_dev, true);
1089 aw88261_dev_pwd(aw_dev, true);
1179 struct aw_device *aw_dev = aw88261->aw_pa;
1180 struct device_node *np = aw_dev->dev->of_node;
1186 aw_dev->channel = channel_value;
1191 struct aw_device *aw_dev;
1208 aw_dev = devm_kzalloc(&i2c->dev, sizeof(*aw_dev), GFP_KERNEL);
1209 if (!aw_dev)
1212 (*aw88261)->aw_pa = aw_dev;
1213 aw_dev->i2c = i2c;
1214 aw_dev->regmap = regmap;
1215 aw_dev->dev = &i2c->dev;
1216 aw_dev->chip_id = AW88261_CHIP_ID;
1217 aw_dev->acf = NULL;
1218 aw_dev->prof_info.prof_desc = NULL;
1219 aw_dev->prof_info.count = 0;
1220 aw_dev->prof_info.prof_type = AW88395_DEV_NONE_TYPE_ID;
1221 aw_dev->channel = 0;
1222 aw_dev->fw_status = AW88261_DEV_FW_FAILED;
1223 aw_dev->fade_step = AW88261_VOLUME_STEP_DB;
1224 aw_dev->volume_desc.ctl_volume = AW88261_VOL_DEFAULT_VALUE;
1225 aw_dev->volume_desc.mute_volume = AW88261_MUTE_VOL;