Lines Matching refs:ak4114
14 #include <sound/ak4114.h>
25 static void ak4114_init_regs(struct ak4114 *chip);
27 static void reg_write(struct ak4114 *ak4114, unsigned char reg, unsigned char val)
29 ak4114->write(ak4114->private_data, reg, val);
31 ak4114->regmap[reg] = val;
33 ak4114->txcsb[reg-AK4114_REG_TXCSB0] = val;
36 static inline unsigned char reg_read(struct ak4114 *ak4114, unsigned char reg)
38 return ak4114->read(ak4114->private_data, reg);
42 static void reg_dump(struct ak4114 *ak4114)
48 printk(KERN_DEBUG "reg[%02x] = %02x (%02x)\n", i, reg_read(ak4114, i), i < ARRAY_SIZE(ak4114->regmap) ? ak4114->regmap[i] : 0);
52 static void snd_ak4114_free(struct ak4114 *chip)
61 struct ak4114 *chip = device->device_data;
69 void *private_data, struct ak4114 **r_ak4114)
71 struct ak4114 *chip;
114 void snd_ak4114_reg_write(struct ak4114 *chip, unsigned char reg, unsigned char mask, unsigned char val)
124 static void ak4114_init_regs(struct ak4114 *chip)
142 void snd_ak4114_reinit(struct ak4114 *chip)
182 struct ak4114 *chip = snd_kcontrol_chip(kcontrol);
197 struct ak4114 *chip = snd_kcontrol_chip(kcontrol);
219 struct ak4114 *chip = snd_kcontrol_chip(kcontrol);
235 struct ak4114 *chip = snd_kcontrol_chip(kcontrol);
246 struct ak4114 *chip = snd_kcontrol_chip(kcontrol);
257 struct ak4114 *chip = snd_kcontrol_chip(kcontrol);
291 struct ak4114 *chip = snd_kcontrol_chip(kcontrol);
313 struct ak4114 *chip = snd_kcontrol_chip(kcontrol);
443 struct ak4114 *ak4114 = entry->private_data;
445 /* all ak4114 registers 0x00 - 0x1f */
447 val = reg_read(ak4114, reg);
452 static void snd_ak4114_proc_init(struct ak4114 *ak4114)
454 snd_card_ro_proc_new(ak4114->card, "ak4114", ak4114,
458 int snd_ak4114_build(struct ak4114 *ak4114,
468 ak4114->playback_substream = ply_substream;
469 ak4114->capture_substream = cap_substream;
471 kctl = snd_ctl_new1(&snd_ak4114_iec958_controls[idx], ak4114);
477 ak4114->kctls[idx] = NULL;
486 err = snd_ctl_add(ak4114->card, kctl);
489 ak4114->kctls[idx] = kctl;
491 snd_ak4114_proc_init(ak4114);
493 schedule_delayed_work(&ak4114->work, HZ / 10);
499 static void ak4114_notify(struct ak4114 *ak4114,
503 if (!ak4114->kctls[0])
507 snd_ctl_notify(ak4114->card, SNDRV_CTL_EVENT_MASK_VALUE,
508 &ak4114->kctls[0]->id);
510 snd_ctl_notify(ak4114->card, SNDRV_CTL_EVENT_MASK_VALUE,
511 &ak4114->kctls[1]->id);
513 snd_ctl_notify(ak4114->card, SNDRV_CTL_EVENT_MASK_VALUE,
514 &ak4114->kctls[2]->id);
516 snd_ctl_notify(ak4114->card, SNDRV_CTL_EVENT_MASK_VALUE,
517 &ak4114->kctls[3]->id);
521 snd_ctl_notify(ak4114->card, SNDRV_CTL_EVENT_MASK_VALUE,
522 &ak4114->kctls[4]->id);
525 snd_ctl_notify(ak4114->card, SNDRV_CTL_EVENT_MASK_VALUE,
526 &ak4114->kctls[9]->id);
528 snd_ctl_notify(ak4114->card, SNDRV_CTL_EVENT_MASK_VALUE,
529 &ak4114->kctls[10]->id);
532 snd_ctl_notify(ak4114->card, SNDRV_CTL_EVENT_MASK_VALUE,
533 &ak4114->kctls[11]->id);
535 snd_ctl_notify(ak4114->card, SNDRV_CTL_EVENT_MASK_VALUE,
536 &ak4114->kctls[12]->id);
538 snd_ctl_notify(ak4114->card, SNDRV_CTL_EVENT_MASK_VALUE,
539 &ak4114->kctls[13]->id);
541 snd_ctl_notify(ak4114->card, SNDRV_CTL_EVENT_MASK_VALUE,
542 &ak4114->kctls[14]->id);
545 int snd_ak4114_external_rate(struct ak4114 *ak4114)
549 rcs1 = reg_read(ak4114, AK4114_REG_RCS1);
554 int snd_ak4114_check_rate_and_errors(struct ak4114 *ak4114, unsigned int flags)
556 struct snd_pcm_runtime *runtime = ak4114->capture_substream ? ak4114->capture_substream->runtime : NULL;
562 rcs1 = reg_read(ak4114, AK4114_REG_RCS1);
565 rcs0 = reg_read(ak4114, AK4114_REG_RCS0);
566 spin_lock_irqsave(&ak4114->lock, _flags);
568 ak4114->errors[AK4114_PARITY_ERRORS]++;
570 ak4114->errors[AK4114_V_BIT_ERRORS]++;
572 ak4114->errors[AK4114_CCRC_ERRORS]++;
574 ak4114->errors[AK4114_QCRC_ERRORS]++;
575 c0 = (ak4114->rcs0 & (AK4114_QINT | AK4114_CINT | AK4114_PEM | AK4114_AUDION | AK4114_AUTO | AK4114_UNLCK)) ^
577 c1 = (ak4114->rcs1 & 0xf0) ^ (rcs1 & 0xf0);
578 ak4114->rcs0 = rcs0 & ~(AK4114_QINT | AK4114_CINT);
579 ak4114->rcs1 = rcs1;
580 spin_unlock_irqrestore(&ak4114->lock, _flags);
582 ak4114_notify(ak4114, rcs0, rcs1, c0, c1);
583 if (ak4114->change_callback && (c0 | c1) != 0)
584 ak4114->change_callback(ak4114, c0, c1);
590 snd_pcm_stream_lock_irqsave(ak4114->capture_substream, _flags);
591 if (snd_pcm_running(ak4114->capture_substream)) {
593 snd_pcm_stop(ak4114->capture_substream, SNDRV_PCM_STATE_DRAINING);
596 snd_pcm_stream_unlock_irqrestore(ak4114->capture_substream, _flags);
604 struct ak4114 *chip = container_of(work, struct ak4114, work.work);
613 void snd_ak4114_suspend(struct ak4114 *chip)
620 void snd_ak4114_resume(struct ak4114 *chip)