• Home
  • Raw
  • Download

Lines Matching refs:chip

18 static int lola_init_pin(struct lola *chip, struct lola_pin *pin,  in lola_init_pin()  argument
25 err = lola_read_param(chip, nid, LOLA_PAR_AUDIO_WIDGET_CAP, &val); in lola_init_pin()
27 dev_err(chip->card->dev, "Can't read wcaps for 0x%x\n", nid); in lola_init_pin()
38 dev_err(chip->card->dev, "Invalid wcaps 0x%x for 0x%x\n", val, nid); in lola_init_pin()
48 err = lola_read_param(chip, nid, LOLA_PAR_AMP_OUT_CAP, &val); in lola_init_pin()
50 err = lola_read_param(chip, nid, LOLA_PAR_AMP_IN_CAP, &val); in lola_init_pin()
52 dev_err(chip->card->dev, "Can't read AMP-caps for 0x%x\n", nid); in lola_init_pin()
66 err = lola_codec_read(chip, nid, LOLA_VERB_GET_MAX_LEVEL, 0, 0, &val, in lola_init_pin()
69 dev_err(chip->card->dev, "Can't get MAX_LEVEL 0x%x\n", nid); in lola_init_pin()
81 int lola_init_pins(struct lola *chip, int dir, int *nidp) in lola_init_pins() argument
85 for (i = 0; i < chip->pin[dir].num_pins; i++, nid++) { in lola_init_pins()
86 err = lola_init_pin(chip, &chip->pin[dir].pins[i], dir, nid); in lola_init_pins()
89 if (chip->pin[dir].pins[i].is_analog) in lola_init_pins()
90 chip->pin[dir].num_analog_pins++; in lola_init_pins()
96 void lola_free_mixer(struct lola *chip) in lola_free_mixer() argument
98 vfree(chip->mixer.array_saved); in lola_free_mixer()
101 int lola_init_mixer_widget(struct lola *chip, int nid) in lola_init_mixer_widget() argument
106 err = lola_read_param(chip, nid, LOLA_PAR_AUDIO_WIDGET_CAP, &val); in lola_init_mixer_widget()
108 dev_err(chip->card->dev, "Can't read wcaps for 0x%x\n", nid); in lola_init_mixer_widget()
113 dev_dbg(chip->card->dev, "No valid mixer widget\n"); in lola_init_mixer_widget()
117 chip->mixer.nid = nid; in lola_init_mixer_widget()
118 chip->mixer.caps = val; in lola_init_mixer_widget()
119 chip->mixer.array = (struct lola_mixer_array __iomem *) in lola_init_mixer_widget()
120 (chip->bar[BAR1].remap_addr + LOLA_BAR1_SOURCE_GAIN_ENABLE); in lola_init_mixer_widget()
123 chip->mixer.array_saved = vmalloc(sizeof(struct lola_mixer_array)); in lola_init_mixer_widget()
126 chip->mixer.src_stream_outs = chip->pcm[PLAY].num_streams; in lola_init_mixer_widget()
127 chip->mixer.src_phys_ins = chip->pin[CAPT].num_pins; in lola_init_mixer_widget()
130 chip->mixer.dest_stream_ins = chip->pcm[CAPT].num_streams; in lola_init_mixer_widget()
131 chip->mixer.dest_phys_outs = chip->pin[PLAY].num_pins; in lola_init_mixer_widget()
136 chip->mixer.src_stream_out_ofs = chip->mixer.src_phys_ins + in lola_init_mixer_widget()
138 chip->mixer.dest_phys_out_ofs = chip->mixer.dest_stream_ins + in lola_init_mixer_widget()
189 if (chip->mixer.src_stream_out_ofs > MAX_AUDIO_INOUT_COUNT || in lola_init_mixer_widget()
190 chip->mixer.dest_phys_out_ofs > MAX_STREAM_IN_COUNT) { in lola_init_mixer_widget()
191 dev_err(chip->card->dev, "Invalid mixer widget size\n"); in lola_init_mixer_widget()
195 chip->mixer.src_mask = ((1U << chip->mixer.src_phys_ins) - 1) | in lola_init_mixer_widget()
196 (((1U << chip->mixer.src_stream_outs) - 1) in lola_init_mixer_widget()
197 << chip->mixer.src_stream_out_ofs); in lola_init_mixer_widget()
198 chip->mixer.dest_mask = ((1U << chip->mixer.dest_stream_ins) - 1) | in lola_init_mixer_widget()
199 (((1U << chip->mixer.dest_phys_outs) - 1) in lola_init_mixer_widget()
200 << chip->mixer.dest_phys_out_ofs); in lola_init_mixer_widget()
202 dev_dbg(chip->card->dev, "Mixer src_mask=%x, dest_mask=%x\n", in lola_init_mixer_widget()
203 chip->mixer.src_mask, chip->mixer.dest_mask); in lola_init_mixer_widget()
208 static int lola_mixer_set_src_gain(struct lola *chip, unsigned int id, in lola_mixer_set_src_gain() argument
213 if (!(chip->mixer.src_mask & (1 << id))) in lola_mixer_set_src_gain()
215 oldval = val = readl(&chip->mixer.array->src_gain_enable); in lola_mixer_set_src_gain()
222 (gain == readw(&chip->mixer.array->src_gain[id]))) in lola_mixer_set_src_gain()
225 dev_dbg(chip->card->dev, in lola_mixer_set_src_gain()
228 writew(gain, &chip->mixer.array->src_gain[id]); in lola_mixer_set_src_gain()
229 writel(val, &chip->mixer.array->src_gain_enable); in lola_mixer_set_src_gain()
230 lola_codec_flush(chip); in lola_mixer_set_src_gain()
232 return lola_codec_write(chip, chip->mixer.nid, in lola_mixer_set_src_gain()
237 static int lola_mixer_set_src_gains(struct lola *chip, unsigned int mask,
242 if ((chip->mixer.src_mask & mask) != mask)
246 writew(*gains, &chip->mixer.array->src_gain[i]);
250 writel(mask, &chip->mixer.array->src_gain_enable);
251 lola_codec_flush(chip);
252 if (chip->mixer.caps & LOLA_PEAK_METER_CAN_AGC_MASK) {
254 return lola_codec_write(chip, chip->mixer.nid,
260 lola_codec_write(chip, chip->mixer.nid,
268 static int lola_mixer_set_mapping_gain(struct lola *chip, in lola_mixer_set_mapping_gain() argument
274 if (!(chip->mixer.src_mask & (1 << src)) || in lola_mixer_set_mapping_gain()
275 !(chip->mixer.dest_mask & (1 << dest))) in lola_mixer_set_mapping_gain()
278 writew(gain, &chip->mixer.array->dest_mix_gain[dest][src]); in lola_mixer_set_mapping_gain()
279 val = readl(&chip->mixer.array->dest_mix_gain_enable[dest]); in lola_mixer_set_mapping_gain()
284 writel(val, &chip->mixer.array->dest_mix_gain_enable[dest]); in lola_mixer_set_mapping_gain()
285 lola_codec_flush(chip); in lola_mixer_set_mapping_gain()
286 return lola_codec_write(chip, chip->mixer.nid, LOLA_VERB_SET_MIX_GAIN, in lola_mixer_set_mapping_gain()
291 static int lola_mixer_set_dest_gains(struct lola *chip, unsigned int id,
296 if (!(chip->mixer.dest_mask & (1 << id)) ||
297 (chip->mixer.src_mask & mask) != mask)
301 writew(*gains, &chip->mixer.array->dest_mix_gain[id][i]);
305 writel(mask, &chip->mixer.array->dest_mix_gain_enable[id]);
306 lola_codec_flush(chip);
308 return lola_codec_write(chip, chip->mixer.nid,
316 static int set_analog_volume(struct lola *chip, int dir,
320 int lola_setup_all_analog_gains(struct lola *chip, int dir, bool mute) in lola_setup_all_analog_gains() argument
325 pin = chip->pin[dir].pins; in lola_setup_all_analog_gains()
326 max_idx = chip->pin[dir].num_pins; in lola_setup_all_analog_gains()
331 set_analog_volume(chip, dir, idx, val, false); in lola_setup_all_analog_gains()
334 return lola_codec_flush(chip); in lola_setup_all_analog_gains()
337 void lola_save_mixer(struct lola *chip) in lola_save_mixer() argument
340 if (chip->mixer.array_saved) { in lola_save_mixer()
342 memcpy_fromio(chip->mixer.array_saved, chip->mixer.array, in lola_save_mixer()
343 sizeof(*chip->mixer.array)); in lola_save_mixer()
345 lola_setup_all_analog_gains(chip, PLAY, true); /* output mute */ in lola_save_mixer()
348 void lola_restore_mixer(struct lola *chip) in lola_restore_mixer() argument
353 if (chip->mixer.array_saved) { in lola_restore_mixer()
355 memcpy_toio(chip->mixer.array, chip->mixer.array_saved, in lola_restore_mixer()
356 sizeof(*chip->mixer.array)); in lola_restore_mixer()
360 for (i = 0; i < chip->mixer.src_phys_ins; i++) in lola_restore_mixer()
361 lola_codec_write(chip, chip->mixer.nid, in lola_restore_mixer()
364 for (i = 0; i < chip->mixer.src_stream_outs; i++) in lola_restore_mixer()
365 lola_codec_write(chip, chip->mixer.nid, in lola_restore_mixer()
367 chip->mixer.src_stream_out_ofs + i, 0); in lola_restore_mixer()
368 for (i = 0; i < chip->mixer.dest_stream_ins; i++) in lola_restore_mixer()
369 lola_codec_write(chip, chip->mixer.nid, in lola_restore_mixer()
372 for (i = 0; i < chip->mixer.dest_phys_outs; i++) in lola_restore_mixer()
373 lola_codec_write(chip, chip->mixer.nid, in lola_restore_mixer()
375 chip->mixer.dest_phys_out_ofs + i, 0); in lola_restore_mixer()
376 lola_codec_flush(chip); in lola_restore_mixer()
383 static int set_analog_volume(struct lola *chip, int dir, in set_analog_volume() argument
390 if (idx >= chip->pin[dir].num_pins) in set_analog_volume()
392 pin = &chip->pin[dir].pins[idx]; in set_analog_volume()
398 lola_codec_flush(chip); in set_analog_volume()
399 dev_dbg(chip->card->dev, in set_analog_volume()
402 err = lola_codec_write(chip, pin->nid, in set_analog_volume()
411 int lola_set_src_config(struct lola *chip, unsigned int src_mask, bool update) in lola_set_src_config() argument
418 if ((chip->input_src_caps_mask & src_mask) != src_mask) in lola_set_src_config()
421 for (n = 0; n < chip->pin[CAPT].num_pins; n += 2) { in lola_set_src_config()
424 if (!(chip->input_src_caps_mask & mask)) in lola_set_src_config()
429 src_state = (chip->input_src_mask & mask) != 0; in lola_set_src_config()
433 err = lola_codec_write(chip, chip->pcm[CAPT].streams[n].nid, in lola_set_src_config()
441 ret = lola_codec_flush(chip); in lola_set_src_config()
443 chip->input_src_mask = src_mask; in lola_set_src_config()
449 static int init_mixer_values(struct lola *chip) in init_mixer_values() argument
454 lola_set_src_config(chip, (1 << chip->pin[CAPT].num_pins) - 1, false); in init_mixer_values()
457 memset_io(chip->mixer.array, 0, sizeof(*chip->mixer.array)); in init_mixer_values()
459 for (i = 0; i < chip->mixer.dest_stream_ins; i++) in init_mixer_values()
460 lola_codec_write(chip, chip->mixer.nid, in init_mixer_values()
464 for (i = 0; i < chip->mixer.dest_phys_outs; i++) in init_mixer_values()
465 lola_codec_write(chip, chip->mixer.nid, in init_mixer_values()
467 chip->mixer.dest_phys_out_ofs + i, 0); in init_mixer_values()
470 for (i = 0; i < chip->mixer.src_phys_ins; i++) in init_mixer_values()
471 lola_mixer_set_src_gain(chip, i, 336, true); /* 0dB */ in init_mixer_values()
474 for (i = 0; i < chip->mixer.src_stream_outs; i++) in init_mixer_values()
475 lola_mixer_set_src_gain(chip, in init_mixer_values()
476 i + chip->mixer.src_stream_out_ofs, in init_mixer_values()
479 for (i = 0; i < chip->mixer.dest_stream_ins; i++) { in init_mixer_values()
480 int src = i % chip->mixer.src_phys_ins; in init_mixer_values()
481 lola_mixer_set_mapping_gain(chip, src, i, 336, true); in init_mixer_values()
487 for (i = 0; i < chip->mixer.src_stream_outs; i++) { in init_mixer_values()
488 int src = chip->mixer.src_stream_out_ofs + i; in init_mixer_values()
489 int dst = chip->mixer.dest_phys_out_ofs + in init_mixer_values()
490 i % chip->mixer.dest_phys_outs; in init_mixer_values()
491 lola_mixer_set_mapping_gain(chip, src, dst, 336, true); in init_mixer_values()
502 struct lola *chip = snd_kcontrol_chip(kcontrol); in lola_analog_vol_info() local
506 uinfo->count = chip->pin[dir].num_pins; in lola_analog_vol_info()
508 uinfo->value.integer.max = chip->pin[dir].pins[0].amp_num_steps; in lola_analog_vol_info()
515 struct lola *chip = snd_kcontrol_chip(kcontrol); in lola_analog_vol_get() local
519 for (i = 0; i < chip->pin[dir].num_pins; i++) in lola_analog_vol_get()
521 chip->pin[dir].pins[i].cur_gain_step; in lola_analog_vol_get()
528 struct lola *chip = snd_kcontrol_chip(kcontrol); in lola_analog_vol_put() local
532 for (i = 0; i < chip->pin[dir].num_pins; i++) { in lola_analog_vol_put()
533 err = set_analog_volume(chip, dir, i, in lola_analog_vol_put()
545 struct lola *chip = snd_kcontrol_chip(kcontrol); in lola_analog_vol_tlv() local
552 pin = &chip->pin[dir].pins[0]; in lola_analog_vol_tlv()
581 static int create_analog_mixer(struct lola *chip, int dir, char *name) in create_analog_mixer() argument
583 if (!chip->pin[dir].num_pins) in create_analog_mixer()
586 if (chip->pin[dir].num_pins != chip->pin[dir].num_analog_pins) in create_analog_mixer()
590 return snd_ctl_add(chip->card, in create_analog_mixer()
591 snd_ctl_new1(&lola_analog_mixer, chip)); in create_analog_mixer()
600 struct lola *chip = snd_kcontrol_chip(kcontrol); in lola_input_src_info() local
603 uinfo->count = chip->pin[CAPT].num_pins; in lola_input_src_info()
612 struct lola *chip = snd_kcontrol_chip(kcontrol); in lola_input_src_get() local
615 for (i = 0; i < chip->pin[CAPT].num_pins; i++) in lola_input_src_get()
617 !!(chip->input_src_mask & (1 << i)); in lola_input_src_get()
624 struct lola *chip = snd_kcontrol_chip(kcontrol); in lola_input_src_put() local
629 for (i = 0; i < chip->pin[CAPT].num_pins; i++) in lola_input_src_put()
632 return lola_set_src_config(chip, mask, true); in lola_input_src_put()
647 static int create_input_src_mixer(struct lola *chip) in create_input_src_mixer() argument
649 if (!chip->input_src_caps_mask) in create_input_src_mixer()
652 return snd_ctl_add(chip->card, in create_input_src_mixer()
653 snd_ctl_new1(&lola_input_src_mixer, chip)); in create_input_src_mixer()
674 struct lola *chip = snd_kcontrol_chip(kcontrol); in lola_src_gain_get() local
679 mask = readl(&chip->mixer.array->src_gain_enable); in lola_src_gain_get()
683 if (!(chip->mixer.src_mask & (1 << idx))) in lola_src_gain_get()
686 val = readw(&chip->mixer.array->src_gain[idx]) + 1; in lola_src_gain_get()
697 struct lola *chip = snd_kcontrol_chip(kcontrol); in lola_src_gain_put() local
707 err = lola_mixer_set_src_gain(chip, idx, val, !!val); in lola_src_gain_put()
727 static int create_src_gain_mixer(struct lola *chip, in create_src_gain_mixer() argument
732 return snd_ctl_add(chip->card, in create_src_gain_mixer()
733 snd_ctl_new1(&lola_src_gain_mixer, chip)); in create_src_gain_mixer()
755 struct lola *chip = snd_kcontrol_chip(kcontrol);
762 mask = readl(&chip->mixer.array->dest_mix_gain_enable[dst]);
766 if (!(chip->mixer.src_mask & (1 << src)))
769 val = readw(&chip->mixer.array->dest_mix_gain[dst][src]) + 1;
780 struct lola *chip = snd_kcontrol_chip(kcontrol);
799 return lola_mixer_set_dest_gains(chip, dst, mask, gains);
814 static int create_dest_gain_mixer(struct lola *chip,
822 return snd_ctl_add(chip->card,
823 snd_ctl_new1(&lola_dest_gain_mixer, chip));
829 int lola_create_mixer(struct lola *chip) in lola_create_mixer() argument
833 err = create_analog_mixer(chip, PLAY, "Analog Playback Volume"); in lola_create_mixer()
836 err = create_analog_mixer(chip, CAPT, "Analog Capture Volume"); in lola_create_mixer()
839 err = create_input_src_mixer(chip); in lola_create_mixer()
842 err = create_src_gain_mixer(chip, chip->mixer.src_phys_ins, 0, in lola_create_mixer()
846 err = create_src_gain_mixer(chip, chip->mixer.src_stream_outs, in lola_create_mixer()
847 chip->mixer.src_stream_out_ofs, in lola_create_mixer()
853 err = create_dest_gain_mixer(chip, in lola_create_mixer()
854 chip->mixer.src_phys_ins, 0, in lola_create_mixer()
855 chip->mixer.dest_stream_ins, 0, in lola_create_mixer()
859 err = create_dest_gain_mixer(chip, in lola_create_mixer()
860 chip->mixer.src_stream_outs, in lola_create_mixer()
861 chip->mixer.src_stream_out_ofs, in lola_create_mixer()
862 chip->mixer.dest_stream_ins, 0, in lola_create_mixer()
866 err = create_dest_gain_mixer(chip, in lola_create_mixer()
867 chip->mixer.src_phys_ins, 0, in lola_create_mixer()
868 chip->mixer.dest_phys_outs, in lola_create_mixer()
869 chip->mixer.dest_phys_out_ofs, in lola_create_mixer()
873 err = create_dest_gain_mixer(chip, in lola_create_mixer()
874 chip->mixer.src_stream_outs, in lola_create_mixer()
875 chip->mixer.src_stream_out_ofs, in lola_create_mixer()
876 chip->mixer.dest_phys_outs, in lola_create_mixer()
877 chip->mixer.dest_phys_out_ofs, in lola_create_mixer()
882 return init_mixer_values(chip); in lola_create_mixer()