Lines Matching refs:solo_dev
57 struct solo_dev *solo_dev; member
62 static void solo_g723_config(struct solo_dev *solo_dev) in solo_g723_config() argument
66 clk_div = (solo_dev->clock_mhz * 1000000) in solo_g723_config()
69 solo_reg_write(solo_dev, SOLO_AUDIO_SAMPLE, in solo_g723_config()
73 solo_reg_write(solo_dev, SOLO_AUDIO_FDMA_INTR, in solo_g723_config()
76 | SOLO_AUDIO_FDMA_BASE(SOLO_G723_EXT_ADDR(solo_dev) >> 16)); in solo_g723_config()
78 solo_reg_write(solo_dev, SOLO_AUDIO_CONTROL, in solo_g723_config()
85 void solo_g723_isr(struct solo_dev *solo_dev) in solo_g723_isr() argument
88 &solo_dev->snd_pcm->streams[SNDRV_PCM_STREAM_CAPTURE]; in solo_g723_isr()
97 if (snd_pcm_substream_chip(ss) == solo_dev) in solo_g723_isr()
140 struct solo_dev *solo_dev = snd_pcm_substream_chip(ss); in snd_solo_pcm_open() local
147 solo_pcm->g723_buf = pci_alloc_consistent(solo_dev->pdev, in snd_solo_pcm_open()
154 solo_pcm->solo_dev = solo_dev; in snd_solo_pcm_open()
170 snd_pcm_substream_chip(ss) = solo_pcm->solo_dev; in snd_solo_pcm_close()
171 pci_free_consistent(solo_pcm->solo_dev->pdev, G723_PERIOD_BYTES, in snd_solo_pcm_close()
181 struct solo_dev *solo_dev = solo_pcm->solo_dev; in snd_solo_pcm_trigger() local
190 if (atomic_inc_return(&solo_dev->snd_users) == 1) in snd_solo_pcm_trigger()
191 solo_irq_on(solo_dev, SOLO_IRQ_G723); in snd_solo_pcm_trigger()
198 if (atomic_dec_return(&solo_dev->snd_users) == 0) in snd_solo_pcm_trigger()
199 solo_irq_off(solo_dev, SOLO_IRQ_G723); in snd_solo_pcm_trigger()
220 struct solo_dev *solo_dev = solo_pcm->solo_dev; in snd_solo_pcm_pointer() local
221 snd_pcm_uframes_t idx = solo_reg_read(solo_dev, SOLO_AUDIO_STA) & 0x1f; in snd_solo_pcm_pointer()
231 struct solo_dev *solo_dev = solo_pcm->solo_dev; in snd_solo_pcm_copy() local
237 err = solo_p2m_dma_t(solo_dev, 0, solo_pcm->g723_dma, in snd_solo_pcm_copy()
238 SOLO_G723_EXT_ADDR(solo_dev) + in snd_solo_pcm_copy()
282 struct solo_dev *solo_dev = snd_kcontrol_chip(kcontrol); in snd_solo_capture_volume_get() local
285 value->value.integer.value[0] = tw28_get_audio_gain(solo_dev, ch); in snd_solo_capture_volume_get()
293 struct solo_dev *solo_dev = snd_kcontrol_chip(kcontrol); in snd_solo_capture_volume_put() local
297 old_val = tw28_get_audio_gain(solo_dev, ch); in snd_solo_capture_volume_put()
301 tw28_set_audio_gain(solo_dev, ch, value->value.integer.value[0]); in snd_solo_capture_volume_put()
314 static int solo_snd_pcm_init(struct solo_dev *solo_dev) in solo_snd_pcm_init() argument
316 struct snd_card *card = solo_dev->snd_card; in solo_snd_pcm_init()
322 ret = snd_pcm_new(card, card->driver, 0, 0, solo_dev->nr_chans, in solo_snd_pcm_init()
330 snd_pcm_chip(pcm) = solo_dev; in solo_snd_pcm_init()
346 solo_dev->snd_pcm = pcm; in solo_snd_pcm_init()
351 int solo_g723_init(struct solo_dev *solo_dev) in solo_g723_init() argument
359 atomic_set(&solo_dev->snd_users, 0); in solo_g723_init()
362 sprintf(name, "Softlogic%d", solo_dev->vfd->num); in solo_g723_init()
364 ret = snd_card_new(&solo_dev->pdev->dev, in solo_g723_init()
366 &solo_dev->snd_card); in solo_g723_init()
370 card = solo_dev->snd_card; in solo_g723_init()
375 pci_name(solo_dev->pdev), solo_dev->pdev->irq); in solo_g723_init()
377 ret = snd_device_new(card, SNDRV_DEV_LOWLEVEL, solo_dev, &ops); in solo_g723_init()
384 kctl.count = solo_dev->nr_chans; in solo_g723_init()
386 ret = snd_ctl_add(card, snd_ctl_new1(&kctl, solo_dev)); in solo_g723_init()
390 ret = solo_snd_pcm_init(solo_dev); in solo_g723_init()
398 solo_g723_config(solo_dev); in solo_g723_init()
400 dev_info(&solo_dev->pdev->dev, "Alsa sound card as %s\n", name); in solo_g723_init()
409 void solo_g723_exit(struct solo_dev *solo_dev) in solo_g723_exit() argument
411 if (!solo_dev->snd_card) in solo_g723_exit()
414 solo_reg_write(solo_dev, SOLO_AUDIO_CONTROL, 0); in solo_g723_exit()
415 solo_irq_off(solo_dev, SOLO_IRQ_G723); in solo_g723_exit()
417 snd_card_free(solo_dev->snd_card); in solo_g723_exit()
418 solo_dev->snd_card = NULL; in solo_g723_exit()