Lines Matching refs:tscm

44 static int identify_model(struct snd_tscm *tscm)
46 struct fw_device *fw_dev = fw_parent_device(tscm->unit);
53 dev_err(&tscm->unit->device,
69 tscm->spec = &model_specs[i];
73 if (tscm->spec == NULL)
76 strcpy(tscm->card->driver, "FW-TASCAM");
77 strcpy(tscm->card->shortname, model);
78 strcpy(tscm->card->mixername, model);
79 snprintf(tscm->card->longname, sizeof(tscm->card->longname),
82 dev_name(&tscm->unit->device), 100 << fw_dev->max_speed);
89 struct snd_tscm *tscm = card->private_data;
91 snd_tscm_transaction_unregister(tscm);
92 snd_tscm_stream_destroy_duplex(tscm);
94 mutex_destroy(&tscm->mutex);
95 fw_unit_put(tscm->unit);
102 struct snd_tscm *tscm;
105 err = snd_card_new(&unit->device, -1, NULL, THIS_MODULE, sizeof(*tscm), &card);
110 tscm = card->private_data;
111 tscm->unit = fw_unit_get(unit);
112 dev_set_drvdata(&unit->device, tscm);
113 tscm->card = card;
115 mutex_init(&tscm->mutex);
116 spin_lock_init(&tscm->lock);
117 init_waitqueue_head(&tscm->hwdep_wait);
119 err = identify_model(tscm);
123 err = snd_tscm_transaction_register(tscm);
127 err = snd_tscm_stream_init_duplex(tscm);
131 snd_tscm_proc_init(tscm);
133 err = snd_tscm_create_pcm_devices(tscm);
137 err = snd_tscm_create_midi_devices(tscm);
141 err = snd_tscm_create_hwdep_device(tscm);
157 struct snd_tscm *tscm = dev_get_drvdata(&unit->device);
159 snd_tscm_transaction_reregister(tscm);
161 mutex_lock(&tscm->mutex);
162 snd_tscm_stream_update_duplex(tscm);
163 mutex_unlock(&tscm->mutex);
168 struct snd_tscm *tscm = dev_get_drvdata(&unit->device);
171 snd_card_free(tscm->card);