/** * snd_device_new - create an ALSA device component * @card: the card instance * @type: the device type, SNDRV_DEV_XXX * @device_data: the data pointer of this device * @ops: the operator table * * Creates a new device component for the given data pointer. * The device will be assigned to the card and managed together * by the card. * * The data pointer plays a role as the identifier, too, so the * pointer address must be unique and unchanged. * * Return: Zero if successful, or a negative error code on failure.
*/ int snd_device_new(struct snd_card *card, enum snd_device_type type, void *device_data, conststruct snd_device_ops *ops)
{ struct snd_device *dev; struct list_head *p;
list_for_each_entry(dev, &card->devices, list) if (dev->device_data == device_data) return dev;
return NULL;
}
/** * snd_device_disconnect - disconnect the device * @card: the card instance * @device_data: the data pointer to disconnect * * Turns the device into the disconnection state, invoking * dev_disconnect callback, if the device was already registered. * * Usually called from snd_card_disconnect(). * * Return: Zero if successful, or a negative error code on failure or if the * device not found.
*/ void snd_device_disconnect(struct snd_card *card, void *device_data)
{ struct snd_device *dev;
if (snd_BUG_ON(!card || !device_data)) return;
dev = look_for_dev(card, device_data); if (dev)
__snd_device_disconnect(dev); else
dev_dbg(card->dev, "device disconnect %p (from %pS), not found\n",
device_data, __builtin_return_address(0));
}
EXPORT_SYMBOL_GPL(snd_device_disconnect);
/** * snd_device_free - release the device from the card * @card: the card instance * @device_data: the data pointer to release * * Removes the device from the list on the card and invokes the * callbacks, dev_disconnect and dev_free, corresponding to the state. * Then release the device.
*/ void snd_device_free(struct snd_card *card, void *device_data)
{ struct snd_device *dev;
if (snd_BUG_ON(!card || !device_data)) return;
dev = look_for_dev(card, device_data); if (dev)
__snd_device_free(dev); else
dev_dbg(card->dev, "device free %p (from %pS), not found\n",
device_data, __builtin_return_address(0));
}
EXPORT_SYMBOL(snd_device_free);
staticint __snd_device_register(struct snd_device *dev)
{ if (dev->state == SNDRV_DEV_BUILD) { if (dev->ops->dev_register) { int err = dev->ops->dev_register(dev); if (err < 0) return err;
}
dev->state = SNDRV_DEV_REGISTERED;
} return 0;
}
/** * snd_device_register - register the device * @card: the card instance * @device_data: the data pointer to register * * Registers the device which was already created via * snd_device_new(). Usually this is called from snd_card_register(), * but it can be called later if any new devices are created after * invocation of snd_card_register(). * * Return: Zero if successful, or a negative error code on failure or if the * device not found.
*/ int snd_device_register(struct snd_card *card, void *device_data)
{ struct snd_device *dev;
if (snd_BUG_ON(!card || !device_data)) return -ENXIO;
dev = look_for_dev(card, device_data); if (dev) return __snd_device_register(dev);
snd_BUG(); return -ENXIO;
}
EXPORT_SYMBOL(snd_device_register);
/* * register all the devices on the card. * called from init.c
*/ int snd_device_register_all(struct snd_card *card)
{ struct snd_device *dev; int err;
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.