• Home
  • Raw
  • Download

Lines Matching refs:chip

110 ad1889_readw(struct snd_ad1889 *chip, unsigned reg)  in ad1889_readw()  argument
112 return readw(chip->iobase + reg); in ad1889_readw()
116 ad1889_writew(struct snd_ad1889 *chip, unsigned reg, u16 val) in ad1889_writew() argument
118 writew(val, chip->iobase + reg); in ad1889_writew()
122 ad1889_readl(struct snd_ad1889 *chip, unsigned reg) in ad1889_readl() argument
124 return readl(chip->iobase + reg); in ad1889_readl()
128 ad1889_writel(struct snd_ad1889 *chip, unsigned reg, u32 val) in ad1889_writel() argument
130 writel(val, chip->iobase + reg); in ad1889_writel()
134 ad1889_unmute(struct snd_ad1889 *chip) in ad1889_unmute() argument
137 st = ad1889_readw(chip, AD_DS_WADA) & in ad1889_unmute()
139 ad1889_writew(chip, AD_DS_WADA, st); in ad1889_unmute()
140 ad1889_readw(chip, AD_DS_WADA); in ad1889_unmute()
144 ad1889_mute(struct snd_ad1889 *chip) in ad1889_mute() argument
147 st = ad1889_readw(chip, AD_DS_WADA) | AD_DS_WADA_RWAM | AD_DS_WADA_LWAM; in ad1889_mute()
148 ad1889_writew(chip, AD_DS_WADA, st); in ad1889_mute()
149 ad1889_readw(chip, AD_DS_WADA); in ad1889_mute()
153 ad1889_load_adc_buffer_address(struct snd_ad1889 *chip, u32 address) in ad1889_load_adc_buffer_address() argument
155 ad1889_writel(chip, AD_DMA_ADCBA, address); in ad1889_load_adc_buffer_address()
156 ad1889_writel(chip, AD_DMA_ADCCA, address); in ad1889_load_adc_buffer_address()
160 ad1889_load_adc_buffer_count(struct snd_ad1889 *chip, u32 count) in ad1889_load_adc_buffer_count() argument
162 ad1889_writel(chip, AD_DMA_ADCBC, count); in ad1889_load_adc_buffer_count()
163 ad1889_writel(chip, AD_DMA_ADCCC, count); in ad1889_load_adc_buffer_count()
167 ad1889_load_adc_interrupt_count(struct snd_ad1889 *chip, u32 count) in ad1889_load_adc_interrupt_count() argument
169 ad1889_writel(chip, AD_DMA_ADCIB, count); in ad1889_load_adc_interrupt_count()
170 ad1889_writel(chip, AD_DMA_ADCIC, count); in ad1889_load_adc_interrupt_count()
174 ad1889_load_wave_buffer_address(struct snd_ad1889 *chip, u32 address) in ad1889_load_wave_buffer_address() argument
176 ad1889_writel(chip, AD_DMA_WAVBA, address); in ad1889_load_wave_buffer_address()
177 ad1889_writel(chip, AD_DMA_WAVCA, address); in ad1889_load_wave_buffer_address()
181 ad1889_load_wave_buffer_count(struct snd_ad1889 *chip, u32 count) in ad1889_load_wave_buffer_count() argument
183 ad1889_writel(chip, AD_DMA_WAVBC, count); in ad1889_load_wave_buffer_count()
184 ad1889_writel(chip, AD_DMA_WAVCC, count); in ad1889_load_wave_buffer_count()
188 ad1889_load_wave_interrupt_count(struct snd_ad1889 *chip, u32 count) in ad1889_load_wave_interrupt_count() argument
190 ad1889_writel(chip, AD_DMA_WAVIB, count); in ad1889_load_wave_interrupt_count()
191 ad1889_writel(chip, AD_DMA_WAVIC, count); in ad1889_load_wave_interrupt_count()
195 ad1889_channel_reset(struct snd_ad1889 *chip, unsigned int channel) in ad1889_channel_reset() argument
201 reg = ad1889_readw(chip, AD_DS_WSMC) & ~AD_DS_WSMC_WAEN; in ad1889_channel_reset()
202 ad1889_writew(chip, AD_DS_WSMC, reg); in ad1889_channel_reset()
203 chip->wave.reg = reg; in ad1889_channel_reset()
206 reg = ad1889_readw(chip, AD_DMA_WAV); in ad1889_channel_reset()
209 ad1889_writew(chip, AD_DMA_WAV, reg); in ad1889_channel_reset()
212 ad1889_load_wave_buffer_address(chip, 0x0); in ad1889_channel_reset()
213 ad1889_load_wave_buffer_count(chip, 0x0); in ad1889_channel_reset()
214 ad1889_load_wave_interrupt_count(chip, 0x0); in ad1889_channel_reset()
217 ad1889_readw(chip, AD_DMA_WAV); in ad1889_channel_reset()
222 reg = ad1889_readw(chip, AD_DS_RAMC) & ~AD_DS_RAMC_ADEN; in ad1889_channel_reset()
223 ad1889_writew(chip, AD_DS_RAMC, reg); in ad1889_channel_reset()
224 chip->ramc.reg = reg; in ad1889_channel_reset()
226 reg = ad1889_readw(chip, AD_DMA_ADC); in ad1889_channel_reset()
229 ad1889_writew(chip, AD_DMA_ADC, reg); in ad1889_channel_reset()
231 ad1889_load_adc_buffer_address(chip, 0x0); in ad1889_channel_reset()
232 ad1889_load_adc_buffer_count(chip, 0x0); in ad1889_channel_reset()
233 ad1889_load_adc_interrupt_count(chip, 0x0); in ad1889_channel_reset()
236 ad1889_readw(chip, AD_DMA_ADC); in ad1889_channel_reset()
243 struct snd_ad1889 *chip = ac97->private_data; in snd_ad1889_ac97_read() local
244 return ad1889_readw(chip, AD_AC97_BASE + reg); in snd_ad1889_ac97_read()
250 struct snd_ad1889 *chip = ac97->private_data; in snd_ad1889_ac97_write() local
251 ad1889_writew(chip, AD_AC97_BASE + reg, val); in snd_ad1889_ac97_write()
255 snd_ad1889_ac97_ready(struct snd_ad1889 *chip) in snd_ad1889_ac97_ready() argument
259 while (!(ad1889_readw(chip, AD_AC97_ACIC) & AD_AC97_ACIC_ACRDY) in snd_ad1889_ac97_ready()
263 dev_err(chip->card->dev, "[%s] Link is not ready.\n", in snd_ad1889_ac97_ready()
267 dev_dbg(chip->card->dev, "[%s] ready after %d ms\n", __func__, 400 - retry); in snd_ad1889_ac97_ready()
323 struct snd_ad1889 *chip = snd_pcm_substream_chip(ss); in snd_ad1889_playback_open() local
326 chip->psubs = ss; in snd_ad1889_playback_open()
335 struct snd_ad1889 *chip = snd_pcm_substream_chip(ss); in snd_ad1889_capture_open() local
338 chip->csubs = ss; in snd_ad1889_capture_open()
347 struct snd_ad1889 *chip = snd_pcm_substream_chip(ss); in snd_ad1889_playback_close() local
348 chip->psubs = NULL; in snd_ad1889_playback_close()
355 struct snd_ad1889 *chip = snd_pcm_substream_chip(ss); in snd_ad1889_capture_close() local
356 chip->csubs = NULL; in snd_ad1889_capture_close()
363 struct snd_ad1889 *chip = snd_pcm_substream_chip(ss); in snd_ad1889_playback_prepare() local
369 ad1889_channel_reset(chip, AD_CHAN_WAV); in snd_ad1889_playback_prepare()
371 reg = ad1889_readw(chip, AD_DS_WSMC); in snd_ad1889_playback_prepare()
383 spin_lock_irq(&chip->lock); in snd_ad1889_playback_prepare()
385 chip->wave.size = size; in snd_ad1889_playback_prepare()
386 chip->wave.reg = reg; in snd_ad1889_playback_prepare()
387 chip->wave.addr = rt->dma_addr; in snd_ad1889_playback_prepare()
389 ad1889_writew(chip, AD_DS_WSMC, chip->wave.reg); in snd_ad1889_playback_prepare()
392 ad1889_writew(chip, AD_DS_WAS, rt->rate); in snd_ad1889_playback_prepare()
395 ad1889_load_wave_buffer_address(chip, chip->wave.addr); in snd_ad1889_playback_prepare()
396 ad1889_load_wave_buffer_count(chip, size); in snd_ad1889_playback_prepare()
397 ad1889_load_wave_interrupt_count(chip, count); in snd_ad1889_playback_prepare()
400 ad1889_readw(chip, AD_DS_WSMC); in snd_ad1889_playback_prepare()
402 spin_unlock_irq(&chip->lock); in snd_ad1889_playback_prepare()
404 dev_dbg(chip->card->dev, in snd_ad1889_playback_prepare()
406 chip->wave.addr, count, size, reg, rt->rate); in snd_ad1889_playback_prepare()
413 struct snd_ad1889 *chip = snd_pcm_substream_chip(ss); in snd_ad1889_capture_prepare() local
419 ad1889_channel_reset(chip, AD_CHAN_ADC); in snd_ad1889_capture_prepare()
421 reg = ad1889_readw(chip, AD_DS_RAMC); in snd_ad1889_capture_prepare()
433 spin_lock_irq(&chip->lock); in snd_ad1889_capture_prepare()
435 chip->ramc.size = size; in snd_ad1889_capture_prepare()
436 chip->ramc.reg = reg; in snd_ad1889_capture_prepare()
437 chip->ramc.addr = rt->dma_addr; in snd_ad1889_capture_prepare()
439 ad1889_writew(chip, AD_DS_RAMC, chip->ramc.reg); in snd_ad1889_capture_prepare()
442 ad1889_load_adc_buffer_address(chip, chip->ramc.addr); in snd_ad1889_capture_prepare()
443 ad1889_load_adc_buffer_count(chip, size); in snd_ad1889_capture_prepare()
444 ad1889_load_adc_interrupt_count(chip, count); in snd_ad1889_capture_prepare()
447 ad1889_readw(chip, AD_DS_RAMC); in snd_ad1889_capture_prepare()
449 spin_unlock_irq(&chip->lock); in snd_ad1889_capture_prepare()
451 dev_dbg(chip->card->dev, in snd_ad1889_capture_prepare()
453 chip->ramc.addr, count, size, reg, rt->rate); in snd_ad1889_capture_prepare()
465 struct snd_ad1889 *chip = snd_pcm_substream_chip(ss); in snd_ad1889_playback_trigger() local
467 wsmc = ad1889_readw(chip, AD_DS_WSMC); in snd_ad1889_playback_trigger()
472 ad1889_writew(chip, AD_DMA_WAV, AD_DMA_LOOP | AD_DMA_IM_CNT); in snd_ad1889_playback_trigger()
475 ad1889_writel(chip, AD_DMA_CHSS, AD_DMA_CHSS_WAVS); in snd_ad1889_playback_trigger()
476 ad1889_unmute(chip); in snd_ad1889_playback_trigger()
479 ad1889_mute(chip); in snd_ad1889_playback_trigger()
487 chip->wave.reg = wsmc; in snd_ad1889_playback_trigger()
488 ad1889_writew(chip, AD_DS_WSMC, wsmc); in snd_ad1889_playback_trigger()
489 ad1889_readw(chip, AD_DS_WSMC); /* flush */ in snd_ad1889_playback_trigger()
493 ad1889_channel_reset(chip, AD_CHAN_WAV); in snd_ad1889_playback_trigger()
506 struct snd_ad1889 *chip = snd_pcm_substream_chip(ss); in snd_ad1889_capture_trigger() local
508 ramc = ad1889_readw(chip, AD_DS_RAMC); in snd_ad1889_capture_trigger()
513 ad1889_writew(chip, AD_DMA_ADC, AD_DMA_LOOP | AD_DMA_IM_CNT); in snd_ad1889_capture_trigger()
516 ad1889_writel(chip, AD_DMA_CHSS, AD_DMA_CHSS_ADCS); in snd_ad1889_capture_trigger()
525 chip->ramc.reg = ramc; in snd_ad1889_capture_trigger()
526 ad1889_writew(chip, AD_DS_RAMC, ramc); in snd_ad1889_capture_trigger()
527 ad1889_readw(chip, AD_DS_RAMC); /* flush */ in snd_ad1889_capture_trigger()
531 ad1889_channel_reset(chip, AD_CHAN_ADC); in snd_ad1889_capture_trigger()
541 struct snd_ad1889 *chip = snd_pcm_substream_chip(ss); in snd_ad1889_playback_pointer() local
543 if (unlikely(!(chip->wave.reg & AD_DS_WSMC_WAEN))) in snd_ad1889_playback_pointer()
546 ptr = ad1889_readl(chip, AD_DMA_WAVCA); in snd_ad1889_playback_pointer()
547 ptr -= chip->wave.addr; in snd_ad1889_playback_pointer()
549 if (snd_BUG_ON(ptr >= chip->wave.size)) in snd_ad1889_playback_pointer()
560 struct snd_ad1889 *chip = snd_pcm_substream_chip(ss); in snd_ad1889_capture_pointer() local
562 if (unlikely(!(chip->ramc.reg & AD_DS_RAMC_ADEN))) in snd_ad1889_capture_pointer()
565 ptr = ad1889_readl(chip, AD_DMA_ADCCA); in snd_ad1889_capture_pointer()
566 ptr -= chip->ramc.addr; in snd_ad1889_capture_pointer()
568 if (snd_BUG_ON(ptr >= chip->ramc.size)) in snd_ad1889_capture_pointer()
600 struct snd_ad1889 *chip = dev_id; in snd_ad1889_interrupt() local
602 st = ad1889_readl(chip, AD_DMA_DISR); in snd_ad1889_interrupt()
605 ad1889_writel(chip, AD_DMA_DISR, st); in snd_ad1889_interrupt()
613 dev_dbg(chip->card->dev, in snd_ad1889_interrupt()
616 if ((st & AD_DMA_DISR_WAVI) && chip->psubs) in snd_ad1889_interrupt()
617 snd_pcm_period_elapsed(chip->psubs); in snd_ad1889_interrupt()
618 if ((st & AD_DMA_DISR_ADCI) && chip->csubs) in snd_ad1889_interrupt()
619 snd_pcm_period_elapsed(chip->csubs); in snd_ad1889_interrupt()
625 snd_ad1889_pcm_init(struct snd_ad1889 *chip, int device) in snd_ad1889_pcm_init() argument
630 err = snd_pcm_new(chip->card, chip->card->driver, device, 1, 1, &pcm); in snd_ad1889_pcm_init()
639 pcm->private_data = chip; in snd_ad1889_pcm_init()
641 strcpy(pcm->name, chip->card->shortname); in snd_ad1889_pcm_init()
643 chip->pcm = pcm; in snd_ad1889_pcm_init()
644 chip->psubs = NULL; in snd_ad1889_pcm_init()
645 chip->csubs = NULL; in snd_ad1889_pcm_init()
648 snd_dma_pci_data(chip->pci), in snd_ad1889_pcm_init()
653 dev_err(chip->card->dev, "buffer allocation error: %d\n", err); in snd_ad1889_pcm_init()
663 struct snd_ad1889 *chip = entry->private_data; in snd_ad1889_proc_read() local
667 reg = ad1889_readw(chip, AD_DS_WSMC); in snd_ad1889_proc_read()
695 reg = ad1889_readw(chip, AD_DS_RAMC); in snd_ad1889_proc_read()
726 reg = ad1889_readw(chip, AD_DS_WADA); in snd_ad1889_proc_read()
730 reg = ad1889_readw(chip, AD_DS_WADA); in snd_ad1889_proc_read()
735 reg = ad1889_readw(chip, AD_DS_WAS); in snd_ad1889_proc_read()
737 reg = ad1889_readw(chip, AD_DS_RES); in snd_ad1889_proc_read()
742 snd_ad1889_proc_init(struct snd_ad1889 *chip) in snd_ad1889_proc_init() argument
746 if (!snd_card_proc_new(chip->card, chip->card->driver, &entry)) in snd_ad1889_proc_init()
747 snd_info_set_text_ops(entry, chip, snd_ad1889_proc_read); in snd_ad1889_proc_init()
762 snd_ad1889_ac97_xinit(struct snd_ad1889 *chip) in snd_ad1889_ac97_xinit() argument
766 reg = ad1889_readw(chip, AD_AC97_ACIC); in snd_ad1889_ac97_xinit()
768 ad1889_writew(chip, AD_AC97_ACIC, reg); in snd_ad1889_ac97_xinit()
769 ad1889_readw(chip, AD_AC97_ACIC); /* flush posted write */ in snd_ad1889_ac97_xinit()
773 ad1889_writew(chip, AD_AC97_ACIC, reg); in snd_ad1889_ac97_xinit()
775 snd_ad1889_ac97_ready(chip); in snd_ad1889_ac97_xinit()
778 reg = ad1889_readw(chip, AD_AC97_ACIC); in snd_ad1889_ac97_xinit()
780 ad1889_writew(chip, AD_AC97_ACIC, reg); in snd_ad1889_ac97_xinit()
781 ad1889_readw(chip, AD_AC97_ACIC); /* flush posted write */ in snd_ad1889_ac97_xinit()
788 struct snd_ad1889 *chip = bus->private_data; in snd_ad1889_ac97_bus_free() local
789 chip->ac97_bus = NULL; in snd_ad1889_ac97_bus_free()
795 struct snd_ad1889 *chip = ac97->private_data; in snd_ad1889_ac97_free() local
796 chip->ac97 = NULL; in snd_ad1889_ac97_free()
800 snd_ad1889_ac97_init(struct snd_ad1889 *chip, const char *quirk_override) in snd_ad1889_ac97_init() argument
810 snd_ad1889_ac97_xinit(chip); in snd_ad1889_ac97_init()
812 err = snd_ac97_bus(chip->card, 0, &ops, chip, &chip->ac97_bus); in snd_ad1889_ac97_init()
816 chip->ac97_bus->private_free = snd_ad1889_ac97_bus_free; in snd_ad1889_ac97_init()
819 ac97.private_data = chip; in snd_ad1889_ac97_init()
821 ac97.pci = chip->pci; in snd_ad1889_ac97_init()
823 err = snd_ac97_mixer(chip->ac97_bus, &ac97, &chip->ac97); in snd_ad1889_ac97_init()
827 snd_ac97_tune_hardware(chip->ac97, ac97_quirks, quirk_override); in snd_ad1889_ac97_init()
833 snd_ad1889_free(struct snd_ad1889 *chip) in snd_ad1889_free() argument
835 if (chip->irq < 0) in snd_ad1889_free()
838 spin_lock_irq(&chip->lock); in snd_ad1889_free()
840 ad1889_mute(chip); in snd_ad1889_free()
843 ad1889_channel_reset(chip, AD_CHAN_WAV | AD_CHAN_ADC); in snd_ad1889_free()
846 ad1889_writel(chip, AD_DMA_DISR, AD_DMA_DISR_PTAI | AD_DMA_DISR_PMAI); in snd_ad1889_free()
847 ad1889_readl(chip, AD_DMA_DISR); /* flush, dammit! */ in snd_ad1889_free()
849 spin_unlock_irq(&chip->lock); in snd_ad1889_free()
851 if (chip->irq >= 0) in snd_ad1889_free()
852 free_irq(chip->irq, chip); in snd_ad1889_free()
855 iounmap(chip->iobase); in snd_ad1889_free()
856 pci_release_regions(chip->pci); in snd_ad1889_free()
857 pci_disable_device(chip->pci); in snd_ad1889_free()
858 kfree(chip); in snd_ad1889_free()
865 struct snd_ad1889 *chip = device->device_data; in snd_ad1889_dev_free() local
866 return snd_ad1889_free(chip); in snd_ad1889_dev_free()
870 snd_ad1889_init(struct snd_ad1889 *chip) in snd_ad1889_init() argument
872 ad1889_writew(chip, AD_DS_CCS, AD_DS_CCS_CLKEN); /* turn on clock */ in snd_ad1889_init()
873 ad1889_readw(chip, AD_DS_CCS); /* flush posted write */ in snd_ad1889_init()
878 ad1889_writel(chip, AD_DMA_DISR, AD_DMA_DISR_PMAE | AD_DMA_DISR_PTAE); in snd_ad1889_init()
890 struct snd_ad1889 *chip; in snd_ad1889_create() local
909 if ((chip = kzalloc(sizeof(*chip), GFP_KERNEL)) == NULL) { in snd_ad1889_create()
914 chip->card = card; in snd_ad1889_create()
915 card->private_data = chip; in snd_ad1889_create()
916 chip->pci = pci; in snd_ad1889_create()
917 chip->irq = -1; in snd_ad1889_create()
923 chip->bar = pci_resource_start(pci, 0); in snd_ad1889_create()
924 chip->iobase = pci_ioremap_bar(pci, 0); in snd_ad1889_create()
925 if (chip->iobase == NULL) { in snd_ad1889_create()
933 spin_lock_init(&chip->lock); /* only now can we call ad1889_free */ in snd_ad1889_create()
936 IRQF_SHARED, KBUILD_MODNAME, chip)) { in snd_ad1889_create()
938 snd_ad1889_free(chip); in snd_ad1889_create()
942 chip->irq = pci->irq; in snd_ad1889_create()
943 synchronize_irq(chip->irq); in snd_ad1889_create()
946 if ((err = snd_ad1889_init(chip)) < 0) { in snd_ad1889_create()
947 snd_ad1889_free(chip); in snd_ad1889_create()
951 if ((err = snd_device_new(card, SNDRV_DEV_LOWLEVEL, chip, &ops)) < 0) { in snd_ad1889_create()
952 snd_ad1889_free(chip); in snd_ad1889_create()
956 *rchip = chip; in snd_ad1889_create()
961 kfree(chip); in snd_ad1889_create()
974 struct snd_ad1889 *chip; in snd_ad1889_probe() local
995 err = snd_ad1889_create(card, pci, &chip); in snd_ad1889_probe()
1001 card->shortname, chip->bar, chip->irq); in snd_ad1889_probe()
1005 err = snd_ad1889_ac97_init(chip, ac97_quirk[devno]); in snd_ad1889_probe()
1009 err = snd_ad1889_pcm_init(chip, 0); in snd_ad1889_probe()
1014 snd_ad1889_proc_init(chip); in snd_ad1889_probe()