Lines Matching +full:0 +full:xf01

38 	if (ret < 0)  in rt700_index_write()
51 *value = 0; in rt700_index_read()
53 if (ret < 0) in rt700_index_read()
62 unsigned int btn_type = 0, val80, val81; in rt700_button_detect()
66 if (ret < 0) in rt700_button_detect()
69 if (ret < 0) in rt700_button_detect()
72 val80 &= 0x0381; in rt700_button_detect()
73 val81 &= 0xff00; in rt700_button_detect()
76 case 0x0200: in rt700_button_detect()
77 case 0x0100: in rt700_button_detect()
78 case 0x0080: in rt700_button_detect()
81 case 0x0001: in rt700_button_detect()
86 case 0x8000: in rt700_button_detect()
87 case 0x4000: in rt700_button_detect()
88 case 0x2000: in rt700_button_detect()
91 case 0x1000: in rt700_button_detect()
92 case 0x0800: in rt700_button_detect()
93 case 0x0400: in rt700_button_detect()
96 case 0x0200: in rt700_button_detect()
97 case 0x0100: in rt700_button_detect()
107 unsigned int buf, loop = 0; in rt700_headset_detect()
109 unsigned int jack_status = 0, reg; in rt700_headset_detect()
113 if (ret < 0) in rt700_headset_detect()
117 (buf & RT700_COMBOJACK_AUTO_DET_STATUS) == 0) { in rt700_headset_detect()
123 if (ret < 0) in rt700_headset_detect()
128 if ((jack_status & (1 << 31)) == 0) in rt700_headset_detect()
141 return 0; in rt700_headset_detect()
159 int btn_type = 0, ret; in rt700_jack_detect_handler()
160 unsigned int jack_status = 0, reg; in rt700_jack_detect_handler()
170 if (ret < 0) in rt700_jack_detect_handler()
176 if (rt700->jack_type == 0) { in rt700_jack_detect_handler()
178 if (ret < 0) in rt700_jack_detect_handler()
188 rt700->jack_type = 0; in rt700_jack_detect_handler()
192 "in %s, jack_type=0x%x\n", __func__, rt700->jack_type); in rt700_jack_detect_handler()
194 "in %s, btn_type=0x%x\n", __func__, btn_type); in rt700_jack_detect_handler()
222 int btn_type = 0, ret; in rt700_btn_check_handler()
223 unsigned int jack_status = 0, reg; in rt700_btn_check_handler()
227 if (ret < 0) in rt700_btn_check_handler()
237 rt700->jack_type = 0; in rt700_btn_check_handler()
242 if (ret < 0) in rt700_btn_check_handler()
245 if ((reg & 0xf0) == 0xf0) in rt700_btn_check_handler()
246 btn_type = 0; in rt700_btn_check_handler()
249 "%s, btn_type=0x%x\n", __func__, btn_type); in rt700_btn_check_handler()
285 RT700_SET_MIC2_UNSOLICITED_ENABLE, 0x82); in rt700_jack_init()
287 RT700_SET_HP_UNSOLICITED_ENABLE, 0x81); in rt700_jack_init()
289 RT700_SET_INLINE_UNSOLICITED_ENABLE, 0x83); in rt700_jack_init()
290 rt700_index_write(rt700->regmap, 0x10, 0x2420); in rt700_jack_init()
291 rt700_index_write(rt700->regmap, 0x19, 0x2e11); in rt700_jack_init()
299 RT700_SET_MIC2_UNSOLICITED_ENABLE, 0x00); in rt700_jack_init()
301 RT700_SET_HP_UNSOLICITED_ENABLE, 0x00); in rt700_jack_init()
303 RT700_SET_INLINE_UNSOLICITED_ENABLE, 0x00); in rt700_jack_init()
324 return 0; in rt700_set_jack_detect()
329 return 0; in rt700_set_jack_detect()
341 val_h |= 0x20; in rt700_get_gain()
364 val_h = 0x80; in rt700_set_amp_gain_put()
366 val_h = 0x0; in rt700_set_amp_gain_put()
373 val_ll = (mc->max - ucontrol->value.integer.value[0]) << 7; in rt700_set_amp_gain_put()
375 read_ll = read_ll & 0x7f; in rt700_set_amp_gain_put()
379 val_ll = ((ucontrol->value.integer.value[0]) & 0x7f); in rt700_set_amp_gain_put()
383 read_ll = read_ll & 0x80; in rt700_set_amp_gain_put()
396 read_rl = read_rl & 0x7f; in rt700_set_amp_gain_put()
400 val_lr = ((ucontrol->value.integer.value[1]) & 0x7f); in rt700_set_amp_gain_put()
404 read_rl = read_rl & 0x80; in rt700_set_amp_gain_put()
408 for (i = 0; i < 3; i++) { /* retry 3 times at most */ in rt700_set_amp_gain_put()
429 val_h = 0x80; in rt700_set_amp_gain_put()
431 val_h = 0x0; in rt700_set_amp_gain_put()
442 return 0; in rt700_set_amp_gain_put()
458 val_h = 0x80; in rt700_set_amp_gain_get()
460 val_h = 0x0; in rt700_set_amp_gain_get()
466 read_ll = !((read_ll & 0x80) >> RT700_MUTE_SFT); in rt700_set_amp_gain_get()
467 read_rl = !((read_rl & 0x80) >> RT700_MUTE_SFT); in rt700_set_amp_gain_get()
470 read_ll = read_ll & 0x7f; in rt700_set_amp_gain_get()
471 read_rl = read_rl & 0x7f; in rt700_set_amp_gain_get()
473 ucontrol->value.integer.value[0] = read_ll; in rt700_set_amp_gain_get()
476 return 0; in rt700_set_amp_gain_get()
479 static const DECLARE_TLV_DB_SCALE(out_vol_tlv, -6525, 75, 0);
480 static const DECLARE_TLV_DB_SCALE(in_vol_tlv, -1725, 75, 0);
481 static const DECLARE_TLV_DB_SCALE(mic_vol_tlv, 0, 1000, 0);
486 RT700_DIR_OUT_SFT, 0x57, 0,
498 RT700_DIR_IN_SFT, 0x3f, 0,
502 RT700_DIR_IN_SFT, 0x3f, 0,
506 RT700_DIR_IN_SFT, 3, 0,
516 unsigned int reg, val = 0, nid; in rt700_mux_get()
528 /* vid = 0xf01 */ in rt700_mux_get()
531 if (ret < 0) in rt700_mux_get()
534 ucontrol->value.enumerated.item[0] = val; in rt700_mux_get()
536 return 0; in rt700_mux_get()
549 unsigned int val, val2 = 0, change, reg, nid; in rt700_mux_put()
552 if (item[0] >= e->items) in rt700_mux_put()
564 /* Verb ID = 0x701h */ in rt700_mux_put()
565 val = snd_soc_enum_item_to_val(e, item[0]) << e->shift_l; in rt700_mux_put()
569 if (ret < 0) in rt700_mux_put()
573 change = 0; in rt700_mux_put()
583 item[0], e, NULL); in rt700_mux_put()
596 rt700_adc22_enum, SND_SOC_NOPM, 0, adc_mux_text);
599 rt700_adc23_enum, SND_SOC_NOPM, 0, adc_mux_text);
615 rt700_hp_enum, SND_SOC_NOPM, 0, out_mux_text);
631 RT700_SET_STREAMID_DAC1, 0x10); in rt700_dac_front_event()
635 RT700_SET_STREAMID_DAC1, 0x00); in rt700_dac_front_event()
638 return 0; in rt700_dac_front_event()
651 RT700_SET_STREAMID_DAC2, 0x10); in rt700_dac_surround_event()
655 RT700_SET_STREAMID_DAC2, 0x00); in rt700_dac_surround_event()
658 return 0; in rt700_dac_surround_event()
671 RT700_SET_STREAMID_ADC1, 0x10); in rt700_adc_09_event()
675 RT700_SET_STREAMID_ADC1, 0x00); in rt700_adc_09_event()
678 return 0; in rt700_adc_09_event()
691 RT700_SET_STREAMID_ADC2, 0x10); in rt700_adc_08_event()
695 RT700_SET_STREAMID_ADC2, 0x00); in rt700_adc_08_event()
698 return 0; in rt700_adc_08_event()
707 unsigned int val_h = (1 << RT700_DIR_OUT_SFT) | (0x3 << 4); in rt700_hpo_mux_event()
712 val_l = 0x00; in rt700_hpo_mux_event()
723 return 0; in rt700_hpo_mux_event()
732 unsigned int val_h = (1 << RT700_DIR_OUT_SFT) | (0x3 << 4); in rt700_spk_pga_event()
737 val_l = 0x00; in rt700_spk_pga_event()
747 return 0; in rt700_spk_pga_event()
758 SND_SOC_DAPM_DAC_E("DAC Front", NULL, SND_SOC_NOPM, 0, 0,
761 SND_SOC_DAPM_DAC_E("DAC Surround", NULL, SND_SOC_NOPM, 0, 0,
764 SND_SOC_DAPM_MUX_E("HPO Mux", SND_SOC_NOPM, 0, 0, &rt700_hp_mux,
767 SND_SOC_DAPM_PGA_E("SPK PGA", SND_SOC_NOPM, 0, 0, NULL, 0,
770 SND_SOC_DAPM_ADC_E("ADC 09", NULL, SND_SOC_NOPM, 0, 0,
773 SND_SOC_DAPM_ADC_E("ADC 08", NULL, SND_SOC_NOPM, 0, 0,
776 SND_SOC_DAPM_MUX("ADC 22 Mux", SND_SOC_NOPM, 0, 0,
778 SND_SOC_DAPM_MUX("ADC 23 Mux", SND_SOC_NOPM, 0, 0,
780 SND_SOC_DAPM_AIF_IN("DP1RX", "DP1 Playback", 0, SND_SOC_NOPM, 0, 0),
781 SND_SOC_DAPM_AIF_IN("DP3RX", "DP3 Playback", 0, SND_SOC_NOPM, 0, 0),
782 SND_SOC_DAPM_AIF_OUT("DP2TX", "DP2 Capture", 0, SND_SOC_NOPM, 0, 0),
783 SND_SOC_DAPM_AIF_OUT("DP4TX", "DP4 Capture", 0, SND_SOC_NOPM, 0, 0),
814 return 0; in rt700_probe()
843 return 0; in rt700_set_bias_level()
864 return 0; in rt700_set_sdw_stream()
878 return 0; in rt700_set_sdw_stream()
902 unsigned int val = 0; in rt700_pcm_hw_params()
951 /* bit 3:0 Number of Channel */ in rt700_pcm_hw_params()
964 val |= (0x1 << 4); in rt700_pcm_hw_params()
967 val |= (0x2 << 4); in rt700_pcm_hw_params()
970 val |= (0x3 << 4); in rt700_pcm_hw_params()
973 val |= (0x4 << 4); in rt700_pcm_hw_params()
998 return 0; in rt700_pcm_hw_free()
1070 value = 0x0; in rt700_clock_config()
1073 value = 0x1; in rt700_clock_config()
1076 value = 0x2; in rt700_clock_config()
1079 value = 0x3; in rt700_clock_config()
1082 value = 0x4; in rt700_clock_config()
1085 value = 0x5; in rt700_clock_config()
1091 regmap_write(rt700->regmap, 0xe0, value); in rt700_clock_config()
1092 regmap_write(rt700->regmap, 0xf0, value); in rt700_clock_config()
1096 return 0; in rt700_clock_config()
1137 return 0; in rt700_io_init()
1164 regmap_write(rt700->regmap, 0xff01, 0x0000); in rt700_io_init()
1165 regmap_write(rt700->regmap, 0x7520, 0x001a); in rt700_io_init()
1166 regmap_write(rt700->regmap, 0x7420, 0xc003); in rt700_io_init()
1171 regmap_write(rt700->regmap, RT700_SET_PIN_HP, 0x40); in rt700_io_init()
1172 regmap_write(rt700->regmap, RT700_SET_PIN_SPK, 0x40); in rt700_io_init()
1174 regmap_write(rt700->regmap, RT700_SET_PIN_DMIC1, 0x20); in rt700_io_init()
1175 regmap_write(rt700->regmap, RT700_SET_PIN_DMIC2, 0x20); in rt700_io_init()
1176 regmap_write(rt700->regmap, RT700_SET_PIN_MIC2, 0x20); in rt700_io_init()
1179 regmap_write(rt700->regmap, 0x4f12, 0x91); in rt700_io_init()
1180 regmap_write(rt700->regmap, 0x4e12, 0xd6); in rt700_io_init()
1181 regmap_write(rt700->regmap, 0x4d12, 0x11); in rt700_io_init()
1182 regmap_write(rt700->regmap, 0x4c12, 0x20); in rt700_io_init()
1183 regmap_write(rt700->regmap, 0x4f13, 0x91); in rt700_io_init()
1184 regmap_write(rt700->regmap, 0x4e13, 0xd6); in rt700_io_init()
1185 regmap_write(rt700->regmap, 0x4d13, 0x11); in rt700_io_init()
1186 regmap_write(rt700->regmap, 0x4c13, 0x21); in rt700_io_init()
1188 regmap_write(rt700->regmap, 0x4f19, 0x02); in rt700_io_init()
1189 regmap_write(rt700->regmap, 0x4e19, 0xa1); in rt700_io_init()
1190 regmap_write(rt700->regmap, 0x4d19, 0x90); in rt700_io_init()
1191 regmap_write(rt700->regmap, 0x4c19, 0x80); in rt700_io_init()
1194 regmap_write(rt700->regmap, 0x371b, 0x40); in rt700_io_init()
1195 regmap_write(rt700->regmap, 0x731b, 0xb0); in rt700_io_init()
1196 regmap_write(rt700->regmap, 0x839b, 0x00); in rt700_io_init()
1199 rt700_index_write(rt700->regmap, 0x4a, 0x201b); in rt700_io_init()
1200 rt700_index_write(rt700->regmap, 0x45, 0x5089); in rt700_io_init()
1201 rt700_index_write(rt700->regmap, 0x6b, 0x5064); in rt700_io_init()
1202 rt700_index_write(rt700->regmap, 0x48, 0xd249); in rt700_io_init()
1235 return 0; in rt700_io_init()