Lines Matching defs:solo_dev

48 	struct solo_dev			*solo_dev;
53 static void solo_g723_config(struct solo_dev *solo_dev)
57 clk_div = (solo_dev->clock_mhz * 1000000)
60 solo_reg_write(solo_dev, SOLO_AUDIO_SAMPLE,
64 solo_reg_write(solo_dev, SOLO_AUDIO_FDMA_INTR,
67 | SOLO_AUDIO_FDMA_BASE(SOLO_G723_EXT_ADDR(solo_dev) >> 16));
69 solo_reg_write(solo_dev, SOLO_AUDIO_CONTROL,
76 void solo_g723_isr(struct solo_dev *solo_dev)
79 &solo_dev->snd_pcm->streams[SNDRV_PCM_STREAM_CAPTURE];
88 if (snd_pcm_substream_chip(ss) == solo_dev)
120 struct solo_dev *solo_dev = snd_pcm_substream_chip(ss);
127 solo_pcm->g723_buf = pci_alloc_consistent(solo_dev->pdev,
134 solo_pcm->solo_dev = solo_dev;
150 snd_pcm_substream_chip(ss) = solo_pcm->solo_dev;
151 pci_free_consistent(solo_pcm->solo_dev->pdev, G723_PERIOD_BYTES,
161 struct solo_dev *solo_dev = solo_pcm->solo_dev;
170 if (atomic_inc_return(&solo_dev->snd_users) == 1)
171 solo_irq_on(solo_dev, SOLO_IRQ_G723);
178 if (atomic_dec_return(&solo_dev->snd_users) == 0)
179 solo_irq_off(solo_dev, SOLO_IRQ_G723);
200 struct solo_dev *solo_dev = solo_pcm->solo_dev;
201 snd_pcm_uframes_t idx = solo_reg_read(solo_dev, SOLO_AUDIO_STA) & 0x1f;
211 struct solo_dev *solo_dev = solo_pcm->solo_dev;
217 err = solo_p2m_dma_t(solo_dev, 0, solo_pcm->g723_dma,
218 SOLO_G723_EXT_ADDR(solo_dev) +
238 struct solo_dev *solo_dev = solo_pcm->solo_dev;
244 err = solo_p2m_dma_t(solo_dev, 0, solo_pcm->g723_dma,
245 SOLO_G723_EXT_ADDR(solo_dev) +
284 struct solo_dev *solo_dev = snd_kcontrol_chip(kcontrol);
287 value->value.integer.value[0] = tw28_get_audio_gain(solo_dev, ch);
295 struct solo_dev *solo_dev = snd_kcontrol_chip(kcontrol);
299 old_val = tw28_get_audio_gain(solo_dev, ch);
303 tw28_set_audio_gain(solo_dev, ch, value->value.integer.value[0]);
316 static int solo_snd_pcm_init(struct solo_dev *solo_dev)
318 struct snd_card *card = solo_dev->snd_card;
324 ret = snd_pcm_new(card, card->driver, 0, 0, solo_dev->nr_chans,
332 snd_pcm_chip(pcm) = solo_dev;
346 solo_dev->snd_pcm = pcm;
351 int solo_g723_init(struct solo_dev *solo_dev)
359 atomic_set(&solo_dev->snd_users, 0);
362 sprintf(name, "Softlogic%d", solo_dev->vfd->num);
364 ret = snd_card_new(&solo_dev->pdev->dev,
366 &solo_dev->snd_card);
370 card = solo_dev->snd_card;
375 pci_name(solo_dev->pdev), solo_dev->pdev->irq);
377 ret = snd_device_new(card, SNDRV_DEV_LOWLEVEL, solo_dev, &ops);
384 kctl.count = solo_dev->nr_chans;
386 ret = snd_ctl_add(card, snd_ctl_new1(&kctl, solo_dev));
390 ret = solo_snd_pcm_init(solo_dev);
398 solo_g723_config(solo_dev);
400 dev_info(&solo_dev->pdev->dev, "Alsa sound card as %s\n", name);
409 void solo_g723_exit(struct solo_dev *solo_dev)
411 if (!solo_dev->snd_card)
414 solo_reg_write(solo_dev, SOLO_AUDIO_CONTROL, 0);
415 solo_irq_off(solo_dev, SOLO_IRQ_G723);
417 snd_card_free(solo_dev->snd_card);
418 solo_dev->snd_card = NULL;