Commit f9a6bb84 authored by Takashi Iwai's avatar Takashi Iwai

ALSA: seq: Fix assignment in if condition

There are lots of places doing assignments in if condition in ALSA
sequencer core, which is a bad coding style that may confuse readers
and occasionally lead to bugs.

This patch is merely for coding-style fixes, no functional changes.

Link: https://lore.kernel.org/r/20210608140540.17885-57-tiwai@suse.deSigned-off-by: default avatarTakashi Iwai <tiwai@suse.de>
parent 51c816fd
...@@ -67,13 +67,16 @@ static int __init alsa_seq_oss_init(void) ...@@ -67,13 +67,16 @@ static int __init alsa_seq_oss_init(void)
{ {
int rc; int rc;
if ((rc = register_device()) < 0) rc = register_device();
if (rc < 0)
goto error; goto error;
if ((rc = register_proc()) < 0) { rc = register_proc();
if (rc < 0) {
unregister_device(); unregister_device();
goto error; goto error;
} }
if ((rc = snd_seq_oss_create_client()) < 0) { rc = snd_seq_oss_create_client();
if (rc < 0) {
unregister_proc(); unregister_proc();
unregister_device(); unregister_device();
goto error; goto error;
...@@ -133,7 +136,8 @@ odev_release(struct inode *inode, struct file *file) ...@@ -133,7 +136,8 @@ odev_release(struct inode *inode, struct file *file)
{ {
struct seq_oss_devinfo *dp; struct seq_oss_devinfo *dp;
if ((dp = file->private_data) == NULL) dp = file->private_data;
if (!dp)
return 0; return 0;
mutex_lock(&register_mutex); mutex_lock(&register_mutex);
...@@ -226,16 +230,18 @@ register_device(void) ...@@ -226,16 +230,18 @@ register_device(void)
int rc; int rc;
mutex_lock(&register_mutex); mutex_lock(&register_mutex);
if ((rc = snd_register_oss_device(SNDRV_OSS_DEVICE_TYPE_SEQUENCER, rc = snd_register_oss_device(SNDRV_OSS_DEVICE_TYPE_SEQUENCER,
NULL, 0, NULL, 0,
&seq_oss_f_ops, NULL)) < 0) { &seq_oss_f_ops, NULL);
if (rc < 0) {
pr_err("ALSA: seq_oss: can't register device seq\n"); pr_err("ALSA: seq_oss: can't register device seq\n");
mutex_unlock(&register_mutex); mutex_unlock(&register_mutex);
return rc; return rc;
} }
if ((rc = snd_register_oss_device(SNDRV_OSS_DEVICE_TYPE_MUSIC, rc = snd_register_oss_device(SNDRV_OSS_DEVICE_TYPE_MUSIC,
NULL, 0, NULL, 0,
&seq_oss_f_ops, NULL)) < 0) { &seq_oss_f_ops, NULL);
if (rc < 0) {
pr_err("ALSA: seq_oss: can't register device music\n"); pr_err("ALSA: seq_oss: can't register device music\n");
snd_unregister_oss_device(SNDRV_OSS_DEVICE_TYPE_SEQUENCER, NULL, 0); snd_unregister_oss_device(SNDRV_OSS_DEVICE_TYPE_SEQUENCER, NULL, 0);
mutex_unlock(&register_mutex); mutex_unlock(&register_mutex);
......
...@@ -95,7 +95,8 @@ snd_seq_oss_create_client(void) ...@@ -95,7 +95,8 @@ snd_seq_oss_create_client(void)
port->kernel = &port_callback; port->kernel = &port_callback;
call_ctl(SNDRV_SEQ_IOCTL_CREATE_PORT, port); call_ctl(SNDRV_SEQ_IOCTL_CREATE_PORT, port);
if ((system_port = port->addr.port) >= 0) { system_port = port->addr.port;
if (system_port >= 0) {
struct snd_seq_port_subscribe subs; struct snd_seq_port_subscribe subs;
memset(&subs, 0, sizeof(subs)); memset(&subs, 0, sizeof(subs));
...@@ -354,7 +355,8 @@ alloc_seq_queue(struct seq_oss_devinfo *dp) ...@@ -354,7 +355,8 @@ alloc_seq_queue(struct seq_oss_devinfo *dp)
qinfo.owner = system_client; qinfo.owner = system_client;
qinfo.locked = 1; qinfo.locked = 1;
strcpy(qinfo.name, "OSS Sequencer Emulation"); strcpy(qinfo.name, "OSS Sequencer Emulation");
if ((rc = call_ctl(SNDRV_SEQ_IOCTL_CREATE_QUEUE, &qinfo)) < 0) rc = call_ctl(SNDRV_SEQ_IOCTL_CREATE_QUEUE, &qinfo);
if (rc < 0)
return rc; return rc;
dp->queue = qinfo.queue; dp->queue = qinfo.queue;
return 0; return 0;
...@@ -485,7 +487,8 @@ snd_seq_oss_system_info_read(struct snd_info_buffer *buf) ...@@ -485,7 +487,8 @@ snd_seq_oss_system_info_read(struct snd_info_buffer *buf)
snd_iprintf(buf, "\nNumber of applications: %d\n", num_clients); snd_iprintf(buf, "\nNumber of applications: %d\n", num_clients);
for (i = 0; i < num_clients; i++) { for (i = 0; i < num_clients; i++) {
snd_iprintf(buf, "\nApplication %d: ", i); snd_iprintf(buf, "\nApplication %d: ", i);
if ((dp = client_table[i]) == NULL) { dp = client_table[i];
if (!dp) {
snd_iprintf(buf, "*empty*\n"); snd_iprintf(buf, "*empty*\n");
continue; continue;
} }
......
...@@ -152,7 +152,8 @@ snd_seq_oss_midi_check_new_port(struct snd_seq_port_info *pinfo) ...@@ -152,7 +152,8 @@ snd_seq_oss_midi_check_new_port(struct snd_seq_port_info *pinfo)
/* /*
* look for the identical slot * look for the identical slot
*/ */
if ((mdev = find_slot(pinfo->addr.client, pinfo->addr.port)) != NULL) { mdev = find_slot(pinfo->addr.client, pinfo->addr.port);
if (mdev) {
/* already exists */ /* already exists */
snd_use_lock_free(&mdev->use_lock); snd_use_lock_free(&mdev->use_lock);
return 0; return 0;
...@@ -218,7 +219,8 @@ snd_seq_oss_midi_check_exit_port(int client, int port) ...@@ -218,7 +219,8 @@ snd_seq_oss_midi_check_exit_port(int client, int port)
unsigned long flags; unsigned long flags;
int index; int index;
if ((mdev = find_slot(client, port)) != NULL) { mdev = find_slot(client, port);
if (mdev) {
spin_lock_irqsave(&register_lock, flags); spin_lock_irqsave(&register_lock, flags);
midi_devs[mdev->seq_device] = NULL; midi_devs[mdev->seq_device] = NULL;
spin_unlock_irqrestore(&register_lock, flags); spin_unlock_irqrestore(&register_lock, flags);
...@@ -250,7 +252,8 @@ snd_seq_oss_midi_clear_all(void) ...@@ -250,7 +252,8 @@ snd_seq_oss_midi_clear_all(void)
spin_lock_irqsave(&register_lock, flags); spin_lock_irqsave(&register_lock, flags);
for (i = 0; i < max_midi_devs; i++) { for (i = 0; i < max_midi_devs; i++) {
if ((mdev = midi_devs[i]) != NULL) { mdev = midi_devs[i];
if (mdev) {
snd_midi_event_free(mdev->coder); snd_midi_event_free(mdev->coder);
kfree(mdev); kfree(mdev);
midi_devs[i] = NULL; midi_devs[i] = NULL;
...@@ -318,7 +321,8 @@ snd_seq_oss_midi_open(struct seq_oss_devinfo *dp, int dev, int fmode) ...@@ -318,7 +321,8 @@ snd_seq_oss_midi_open(struct seq_oss_devinfo *dp, int dev, int fmode)
struct seq_oss_midi *mdev; struct seq_oss_midi *mdev;
struct snd_seq_port_subscribe subs; struct snd_seq_port_subscribe subs;
if ((mdev = get_mididev(dp, dev)) == NULL) mdev = get_mididev(dp, dev);
if (!mdev)
return -ENODEV; return -ENODEV;
/* already used? */ /* already used? */
...@@ -384,7 +388,8 @@ snd_seq_oss_midi_close(struct seq_oss_devinfo *dp, int dev) ...@@ -384,7 +388,8 @@ snd_seq_oss_midi_close(struct seq_oss_devinfo *dp, int dev)
struct seq_oss_midi *mdev; struct seq_oss_midi *mdev;
struct snd_seq_port_subscribe subs; struct snd_seq_port_subscribe subs;
if ((mdev = get_mididev(dp, dev)) == NULL) mdev = get_mididev(dp, dev);
if (!mdev)
return -ENODEV; return -ENODEV;
if (! mdev->opened || mdev->devinfo != dp) { if (! mdev->opened || mdev->devinfo != dp) {
snd_use_lock_free(&mdev->use_lock); snd_use_lock_free(&mdev->use_lock);
...@@ -421,7 +426,8 @@ snd_seq_oss_midi_filemode(struct seq_oss_devinfo *dp, int dev) ...@@ -421,7 +426,8 @@ snd_seq_oss_midi_filemode(struct seq_oss_devinfo *dp, int dev)
struct seq_oss_midi *mdev; struct seq_oss_midi *mdev;
int mode; int mode;
if ((mdev = get_mididev(dp, dev)) == NULL) mdev = get_mididev(dp, dev);
if (!mdev)
return 0; return 0;
mode = 0; mode = 0;
...@@ -443,7 +449,8 @@ snd_seq_oss_midi_reset(struct seq_oss_devinfo *dp, int dev) ...@@ -443,7 +449,8 @@ snd_seq_oss_midi_reset(struct seq_oss_devinfo *dp, int dev)
{ {
struct seq_oss_midi *mdev; struct seq_oss_midi *mdev;
if ((mdev = get_mididev(dp, dev)) == NULL) mdev = get_mididev(dp, dev);
if (!mdev)
return; return;
if (! mdev->opened) { if (! mdev->opened) {
snd_use_lock_free(&mdev->use_lock); snd_use_lock_free(&mdev->use_lock);
...@@ -491,7 +498,8 @@ snd_seq_oss_midi_get_addr(struct seq_oss_devinfo *dp, int dev, struct snd_seq_ad ...@@ -491,7 +498,8 @@ snd_seq_oss_midi_get_addr(struct seq_oss_devinfo *dp, int dev, struct snd_seq_ad
{ {
struct seq_oss_midi *mdev; struct seq_oss_midi *mdev;
if ((mdev = get_mididev(dp, dev)) == NULL) mdev = get_mididev(dp, dev);
if (!mdev)
return; return;
addr->client = mdev->client; addr->client = mdev->client;
addr->port = mdev->port; addr->port = mdev->port;
...@@ -511,7 +519,8 @@ snd_seq_oss_midi_input(struct snd_seq_event *ev, int direct, void *private_data) ...@@ -511,7 +519,8 @@ snd_seq_oss_midi_input(struct snd_seq_event *ev, int direct, void *private_data)
if (dp->readq == NULL) if (dp->readq == NULL)
return 0; return 0;
if ((mdev = find_slot(ev->source.client, ev->source.port)) == NULL) mdev = find_slot(ev->source.client, ev->source.port);
if (!mdev)
return 0; return 0;
if (! (mdev->opened & PERM_READ)) { if (! (mdev->opened & PERM_READ)) {
snd_use_lock_free(&mdev->use_lock); snd_use_lock_free(&mdev->use_lock);
...@@ -623,7 +632,8 @@ snd_seq_oss_midi_putc(struct seq_oss_devinfo *dp, int dev, unsigned char c, stru ...@@ -623,7 +632,8 @@ snd_seq_oss_midi_putc(struct seq_oss_devinfo *dp, int dev, unsigned char c, stru
{ {
struct seq_oss_midi *mdev; struct seq_oss_midi *mdev;
if ((mdev = get_mididev(dp, dev)) == NULL) mdev = get_mididev(dp, dev);
if (!mdev)
return -ENODEV; return -ENODEV;
if (snd_midi_event_encode_byte(mdev->coder, c, ev)) { if (snd_midi_event_encode_byte(mdev->coder, c, ev)) {
snd_seq_oss_fill_addr(dp, ev, mdev->client, mdev->port); snd_seq_oss_fill_addr(dp, ev, mdev->client, mdev->port);
...@@ -642,7 +652,8 @@ snd_seq_oss_midi_make_info(struct seq_oss_devinfo *dp, int dev, struct midi_info ...@@ -642,7 +652,8 @@ snd_seq_oss_midi_make_info(struct seq_oss_devinfo *dp, int dev, struct midi_info
{ {
struct seq_oss_midi *mdev; struct seq_oss_midi *mdev;
if ((mdev = get_mididev(dp, dev)) == NULL) mdev = get_mididev(dp, dev);
if (!mdev)
return -ENXIO; return -ENXIO;
inf->device = dev; inf->device = dev;
inf->dev_type = 0; /* FIXME: ?? */ inf->dev_type = 0; /* FIXME: ?? */
......
...@@ -132,7 +132,8 @@ snd_seq_oss_write(struct seq_oss_devinfo *dp, const char __user *buf, int count, ...@@ -132,7 +132,8 @@ snd_seq_oss_write(struct seq_oss_devinfo *dp, const char __user *buf, int count,
} }
/* insert queue */ /* insert queue */
if ((err = insert_queue(dp, &rec, opt)) < 0) err = insert_queue(dp, &rec, opt);
if (err < 0)
break; break;
result += ev_size; result += ev_size;
......
...@@ -451,7 +451,8 @@ snd_seq_oss_synth_load_patch(struct seq_oss_devinfo *dp, int dev, int fmt, ...@@ -451,7 +451,8 @@ snd_seq_oss_synth_load_patch(struct seq_oss_devinfo *dp, int dev, int fmt,
if (info->is_midi) if (info->is_midi)
return 0; return 0;
if ((rec = get_synthdev(dp, dev)) == NULL) rec = get_synthdev(dp, dev);
if (!rec)
return -ENXIO; return -ENXIO;
if (rec->oper.load_patch == NULL) if (rec->oper.load_patch == NULL)
...@@ -569,7 +570,8 @@ snd_seq_oss_synth_ioctl(struct seq_oss_devinfo *dp, int dev, unsigned int cmd, u ...@@ -569,7 +570,8 @@ snd_seq_oss_synth_ioctl(struct seq_oss_devinfo *dp, int dev, unsigned int cmd, u
info = get_synthinfo_nospec(dp, dev); info = get_synthinfo_nospec(dp, dev);
if (!info || info->is_midi) if (!info || info->is_midi)
return -ENXIO; return -ENXIO;
if ((rec = get_synthdev(dp, dev)) == NULL) rec = get_synthdev(dp, dev);
if (!rec)
return -ENXIO; return -ENXIO;
if (rec->oper.ioctl == NULL) if (rec->oper.ioctl == NULL)
rc = -ENXIO; rc = -ENXIO;
...@@ -619,7 +621,8 @@ snd_seq_oss_synth_make_info(struct seq_oss_devinfo *dp, int dev, struct synth_in ...@@ -619,7 +621,8 @@ snd_seq_oss_synth_make_info(struct seq_oss_devinfo *dp, int dev, struct synth_in
inf->device = dev; inf->device = dev;
strscpy(inf->name, minf.name, sizeof(inf->name)); strscpy(inf->name, minf.name, sizeof(inf->name));
} else { } else {
if ((rec = get_synthdev(dp, dev)) == NULL) rec = get_synthdev(dp, dev);
if (!rec)
return -ENXIO; return -ENXIO;
inf->synth_type = rec->synth_type; inf->synth_type = rec->synth_type;
inf->synth_subtype = rec->synth_subtype; inf->synth_subtype = rec->synth_subtype;
......
...@@ -27,7 +27,8 @@ snd_seq_oss_writeq_new(struct seq_oss_devinfo *dp, int maxlen) ...@@ -27,7 +27,8 @@ snd_seq_oss_writeq_new(struct seq_oss_devinfo *dp, int maxlen)
struct seq_oss_writeq *q; struct seq_oss_writeq *q;
struct snd_seq_client_pool pool; struct snd_seq_client_pool pool;
if ((q = kzalloc(sizeof(*q), GFP_KERNEL)) == NULL) q = kzalloc(sizeof(*q), GFP_KERNEL);
if (!q)
return NULL; return NULL;
q->dp = dp; q->dp = dp;
q->maxlen = maxlen; q->maxlen = maxlen;
......
...@@ -416,7 +416,10 @@ static ssize_t snd_seq_read(struct file *file, char __user *buf, size_t count, ...@@ -416,7 +416,10 @@ static ssize_t snd_seq_read(struct file *file, char __user *buf, size_t count,
if (snd_BUG_ON(!client)) if (snd_BUG_ON(!client))
return -ENXIO; return -ENXIO;
if (!client->accept_input || (fifo = client->data.user.fifo) == NULL) if (!client->accept_input)
return -ENXIO;
fifo = client->data.user.fifo;
if (!fifo)
return -ENXIO; return -ENXIO;
if (atomic_read(&fifo->overflow) > 0) { if (atomic_read(&fifo->overflow) > 0) {
...@@ -435,9 +438,9 @@ static ssize_t snd_seq_read(struct file *file, char __user *buf, size_t count, ...@@ -435,9 +438,9 @@ static ssize_t snd_seq_read(struct file *file, char __user *buf, size_t count,
int nonblock; int nonblock;
nonblock = (file->f_flags & O_NONBLOCK) || result > 0; nonblock = (file->f_flags & O_NONBLOCK) || result > 0;
if ((err = snd_seq_fifo_cell_out(fifo, &cell, nonblock)) < 0) { err = snd_seq_fifo_cell_out(fifo, &cell, nonblock);
if (err < 0)
break; break;
}
if (snd_seq_ev_is_variable(&cell->event)) { if (snd_seq_ev_is_variable(&cell->event)) {
struct snd_seq_event tmpev; struct snd_seq_event tmpev;
tmpev = cell->event; tmpev = cell->event;
...@@ -970,7 +973,8 @@ static int snd_seq_client_enqueue_event(struct snd_seq_client *client, ...@@ -970,7 +973,8 @@ static int snd_seq_client_enqueue_event(struct snd_seq_client *client,
return err; return err;
/* we got a cell. enqueue it. */ /* we got a cell. enqueue it. */
if ((err = snd_seq_enqueue_event(cell, atomic, hop)) < 0) { err = snd_seq_enqueue_event(cell, atomic, hop);
if (err < 0) {
snd_seq_cell_free(cell); snd_seq_cell_free(cell);
return err; return err;
} }
...@@ -1312,7 +1316,8 @@ static int snd_seq_ioctl_create_port(struct snd_seq_client *client, void *arg) ...@@ -1312,7 +1316,8 @@ static int snd_seq_ioctl_create_port(struct snd_seq_client *client, void *arg)
return -EINVAL; return -EINVAL;
} }
if (client->type == KERNEL_CLIENT) { if (client->type == KERNEL_CLIENT) {
if ((callback = info->kernel) != NULL) { callback = info->kernel;
if (callback) {
if (callback->owner) if (callback->owner)
port->owner = callback->owner; port->owner = callback->owner;
port->private_data = callback->private_data; port->private_data = callback->private_data;
...@@ -1466,13 +1471,17 @@ static int snd_seq_ioctl_subscribe_port(struct snd_seq_client *client, ...@@ -1466,13 +1471,17 @@ static int snd_seq_ioctl_subscribe_port(struct snd_seq_client *client,
struct snd_seq_client *receiver = NULL, *sender = NULL; struct snd_seq_client *receiver = NULL, *sender = NULL;
struct snd_seq_client_port *sport = NULL, *dport = NULL; struct snd_seq_client_port *sport = NULL, *dport = NULL;
if ((receiver = snd_seq_client_use_ptr(subs->dest.client)) == NULL) receiver = snd_seq_client_use_ptr(subs->dest.client);
if (!receiver)
goto __end; goto __end;
if ((sender = snd_seq_client_use_ptr(subs->sender.client)) == NULL) sender = snd_seq_client_use_ptr(subs->sender.client);
if (!sender)
goto __end; goto __end;
if ((sport = snd_seq_port_use_ptr(sender, subs->sender.port)) == NULL) sport = snd_seq_port_use_ptr(sender, subs->sender.port);
if (!sport)
goto __end; goto __end;
if ((dport = snd_seq_port_use_ptr(receiver, subs->dest.port)) == NULL) dport = snd_seq_port_use_ptr(receiver, subs->dest.port);
if (!dport)
goto __end; goto __end;
result = check_subscription_permission(client, sport, dport, subs); result = check_subscription_permission(client, sport, dport, subs);
...@@ -1508,13 +1517,17 @@ static int snd_seq_ioctl_unsubscribe_port(struct snd_seq_client *client, ...@@ -1508,13 +1517,17 @@ static int snd_seq_ioctl_unsubscribe_port(struct snd_seq_client *client,
struct snd_seq_client *receiver = NULL, *sender = NULL; struct snd_seq_client *receiver = NULL, *sender = NULL;
struct snd_seq_client_port *sport = NULL, *dport = NULL; struct snd_seq_client_port *sport = NULL, *dport = NULL;
if ((receiver = snd_seq_client_use_ptr(subs->dest.client)) == NULL) receiver = snd_seq_client_use_ptr(subs->dest.client);
if (!receiver)
goto __end; goto __end;
if ((sender = snd_seq_client_use_ptr(subs->sender.client)) == NULL) sender = snd_seq_client_use_ptr(subs->sender.client);
if (!sender)
goto __end; goto __end;
if ((sport = snd_seq_port_use_ptr(sender, subs->sender.port)) == NULL) sport = snd_seq_port_use_ptr(sender, subs->sender.port);
if (!sport)
goto __end; goto __end;
if ((dport = snd_seq_port_use_ptr(receiver, subs->dest.port)) == NULL) dport = snd_seq_port_use_ptr(receiver, subs->dest.port);
if (!dport)
goto __end; goto __end;
result = check_subscription_permission(client, sport, dport, subs); result = check_subscription_permission(client, sport, dport, subs);
...@@ -1926,9 +1939,11 @@ static int snd_seq_ioctl_get_subscription(struct snd_seq_client *client, ...@@ -1926,9 +1939,11 @@ static int snd_seq_ioctl_get_subscription(struct snd_seq_client *client,
struct snd_seq_client_port *sport = NULL; struct snd_seq_client_port *sport = NULL;
result = -EINVAL; result = -EINVAL;
if ((sender = snd_seq_client_use_ptr(subs->sender.client)) == NULL) sender = snd_seq_client_use_ptr(subs->sender.client);
if (!sender)
goto __end; goto __end;
if ((sport = snd_seq_port_use_ptr(sender, subs->sender.port)) == NULL) sport = snd_seq_port_use_ptr(sender, subs->sender.port);
if (!sport)
goto __end; goto __end;
result = snd_seq_port_get_subscription(&sport->c_src, &subs->dest, result = snd_seq_port_get_subscription(&sport->c_src, &subs->dest,
subs); subs);
...@@ -1955,9 +1970,11 @@ static int snd_seq_ioctl_query_subs(struct snd_seq_client *client, void *arg) ...@@ -1955,9 +1970,11 @@ static int snd_seq_ioctl_query_subs(struct snd_seq_client *client, void *arg)
struct list_head *p; struct list_head *p;
int i; int i;
if ((cptr = snd_seq_client_use_ptr(subs->root.client)) == NULL) cptr = snd_seq_client_use_ptr(subs->root.client);
if (!cptr)
goto __end; goto __end;
if ((port = snd_seq_port_use_ptr(cptr, subs->root.port)) == NULL) port = snd_seq_port_use_ptr(cptr, subs->root.port);
if (!port)
goto __end; goto __end;
switch (subs->type) { switch (subs->type) {
......
...@@ -109,7 +109,8 @@ create_port(int idx, int type) ...@@ -109,7 +109,8 @@ create_port(int idx, int type)
struct snd_seq_port_callback pcb; struct snd_seq_port_callback pcb;
struct snd_seq_dummy_port *rec; struct snd_seq_dummy_port *rec;
if ((rec = kzalloc(sizeof(*rec), GFP_KERNEL)) == NULL) rec = kzalloc(sizeof(*rec), GFP_KERNEL);
if (!rec)
return NULL; return NULL;
rec->client = my_client; rec->client = my_client;
......
...@@ -143,7 +143,8 @@ static struct snd_seq_event_cell *fifo_cell_out(struct snd_seq_fifo *f) ...@@ -143,7 +143,8 @@ static struct snd_seq_event_cell *fifo_cell_out(struct snd_seq_fifo *f)
{ {
struct snd_seq_event_cell *cell; struct snd_seq_event_cell *cell;
if ((cell = f->head) != NULL) { cell = f->head;
if (cell) {
f->head = cell->next; f->head = cell->next;
/* reset tail if this was the last element */ /* reset tail if this was the last element */
......
...@@ -69,7 +69,8 @@ int snd_seq_dump_var_event(const struct snd_seq_event *event, ...@@ -69,7 +69,8 @@ int snd_seq_dump_var_event(const struct snd_seq_event *event,
int len, err; int len, err;
struct snd_seq_event_cell *cell; struct snd_seq_event_cell *cell;
if ((len = get_var_len(event)) <= 0) len = get_var_len(event);
if (len <= 0)
return len; return len;
if (event->data.ext.len & SNDRV_SEQ_EXT_USRPTR) { if (event->data.ext.len & SNDRV_SEQ_EXT_USRPTR) {
...@@ -133,7 +134,8 @@ int snd_seq_expand_var_event(const struct snd_seq_event *event, int count, char ...@@ -133,7 +134,8 @@ int snd_seq_expand_var_event(const struct snd_seq_event *event, int count, char
int len, newlen; int len, newlen;
int err; int err;
if ((len = get_var_len(event)) < 0) len = get_var_len(event);
if (len < 0)
return len; return len;
newlen = len; newlen = len;
if (size_aligned > 0) if (size_aligned > 0)
......
...@@ -101,7 +101,8 @@ static int dump_midi(struct snd_rawmidi_substream *substream, const char *buf, i ...@@ -101,7 +101,8 @@ static int dump_midi(struct snd_rawmidi_substream *substream, const char *buf, i
if (snd_BUG_ON(!substream || !buf)) if (snd_BUG_ON(!substream || !buf))
return -EINVAL; return -EINVAL;
runtime = substream->runtime; runtime = substream->runtime;
if ((tmp = runtime->avail) < count) { tmp = runtime->avail;
if (tmp < count) {
if (printk_ratelimit()) if (printk_ratelimit())
pr_err("ALSA: seq_midi: MIDI output buffer overrun\n"); pr_err("ALSA: seq_midi: MIDI output buffer overrun\n");
return -ENOMEM; return -ENOMEM;
...@@ -167,10 +168,11 @@ static int midisynth_subscribe(void *private_data, struct snd_seq_port_subscribe ...@@ -167,10 +168,11 @@ static int midisynth_subscribe(void *private_data, struct snd_seq_port_subscribe
struct snd_rawmidi_params params; struct snd_rawmidi_params params;
/* open midi port */ /* open midi port */
if ((err = snd_rawmidi_kernel_open(msynth->card, msynth->device, err = snd_rawmidi_kernel_open(msynth->card, msynth->device,
msynth->subdevice, msynth->subdevice,
SNDRV_RAWMIDI_LFLG_INPUT, SNDRV_RAWMIDI_LFLG_INPUT,
&msynth->input_rfile)) < 0) { &msynth->input_rfile);
if (err < 0) {
pr_debug("ALSA: seq_midi: midi input open failed!!!\n"); pr_debug("ALSA: seq_midi: midi input open failed!!!\n");
return err; return err;
} }
...@@ -178,7 +180,8 @@ static int midisynth_subscribe(void *private_data, struct snd_seq_port_subscribe ...@@ -178,7 +180,8 @@ static int midisynth_subscribe(void *private_data, struct snd_seq_port_subscribe
memset(&params, 0, sizeof(params)); memset(&params, 0, sizeof(params));
params.avail_min = 1; params.avail_min = 1;
params.buffer_size = input_buffer_size; params.buffer_size = input_buffer_size;
if ((err = snd_rawmidi_input_params(msynth->input_rfile.input, &params)) < 0) { err = snd_rawmidi_input_params(msynth->input_rfile.input, &params);
if (err < 0) {
snd_rawmidi_kernel_release(&msynth->input_rfile); snd_rawmidi_kernel_release(&msynth->input_rfile);
return err; return err;
} }
...@@ -209,10 +212,11 @@ static int midisynth_use(void *private_data, struct snd_seq_port_subscribe *info ...@@ -209,10 +212,11 @@ static int midisynth_use(void *private_data, struct snd_seq_port_subscribe *info
struct snd_rawmidi_params params; struct snd_rawmidi_params params;
/* open midi port */ /* open midi port */
if ((err = snd_rawmidi_kernel_open(msynth->card, msynth->device, err = snd_rawmidi_kernel_open(msynth->card, msynth->device,
msynth->subdevice, msynth->subdevice,
SNDRV_RAWMIDI_LFLG_OUTPUT, SNDRV_RAWMIDI_LFLG_OUTPUT,
&msynth->output_rfile)) < 0) { &msynth->output_rfile);
if (err < 0) {
pr_debug("ALSA: seq_midi: midi output open failed!!!\n"); pr_debug("ALSA: seq_midi: midi output open failed!!!\n");
return err; return err;
} }
...@@ -220,7 +224,8 @@ static int midisynth_use(void *private_data, struct snd_seq_port_subscribe *info ...@@ -220,7 +224,8 @@ static int midisynth_use(void *private_data, struct snd_seq_port_subscribe *info
params.avail_min = 1; params.avail_min = 1;
params.buffer_size = output_buffer_size; params.buffer_size = output_buffer_size;
params.no_active_sensing = 1; params.no_active_sensing = 1;
if ((err = snd_rawmidi_output_params(msynth->output_rfile.output, &params)) < 0) { err = snd_rawmidi_output_params(msynth->output_rfile.output, &params);
if (err < 0) {
snd_rawmidi_kernel_release(&msynth->output_rfile); snd_rawmidi_kernel_release(&msynth->output_rfile);
return err; return err;
} }
......
...@@ -222,7 +222,8 @@ struct snd_seq_queue *snd_seq_queue_find_name(char *name) ...@@ -222,7 +222,8 @@ struct snd_seq_queue *snd_seq_queue_find_name(char *name)
struct snd_seq_queue *q; struct snd_seq_queue *q;
for (i = 0; i < SNDRV_SEQ_MAX_QUEUES; i++) { for (i = 0; i < SNDRV_SEQ_MAX_QUEUES; i++) {
if ((q = queueptr(i)) != NULL) { q = queueptr(i);
if (q) {
if (strncmp(q->name, name, sizeof(q->name)) == 0) if (strncmp(q->name, name, sizeof(q->name)) == 0)
return q; return q;
queuefree(q); queuefree(q);
...@@ -432,7 +433,8 @@ int snd_seq_queue_timer_open(int queueid) ...@@ -432,7 +433,8 @@ int snd_seq_queue_timer_open(int queueid)
if (queue == NULL) if (queue == NULL)
return -EINVAL; return -EINVAL;
tmr = queue->timer; tmr = queue->timer;
if ((result = snd_seq_timer_open(queue)) < 0) { result = snd_seq_timer_open(queue);
if (result < 0) {
snd_seq_timer_defaults(tmr); snd_seq_timer_defaults(tmr);
result = snd_seq_timer_open(queue); result = snd_seq_timer_open(queue);
} }
...@@ -548,7 +550,8 @@ void snd_seq_queue_client_leave(int client) ...@@ -548,7 +550,8 @@ void snd_seq_queue_client_leave(int client)
/* delete own queues from queue list */ /* delete own queues from queue list */
for (i = 0; i < SNDRV_SEQ_MAX_QUEUES; i++) { for (i = 0; i < SNDRV_SEQ_MAX_QUEUES; i++) {
if ((q = queue_list_remove(i, client)) != NULL) q = queue_list_remove(i, client);
if (q)
queue_delete(q); queue_delete(q);
} }
...@@ -556,7 +559,8 @@ void snd_seq_queue_client_leave(int client) ...@@ -556,7 +559,8 @@ void snd_seq_queue_client_leave(int client)
* they are not owned by this client * they are not owned by this client
*/ */
for (i = 0; i < SNDRV_SEQ_MAX_QUEUES; i++) { for (i = 0; i < SNDRV_SEQ_MAX_QUEUES; i++) {
if ((q = queueptr(i)) == NULL) q = queueptr(i);
if (!q)
continue; continue;
if (test_bit(client, q->clients_bitmap)) { if (test_bit(client, q->clients_bitmap)) {
snd_seq_prioq_leave(q->tickq, client, 0); snd_seq_prioq_leave(q->tickq, client, 0);
...@@ -578,7 +582,8 @@ void snd_seq_queue_client_leave_cells(int client) ...@@ -578,7 +582,8 @@ void snd_seq_queue_client_leave_cells(int client)
struct snd_seq_queue *q; struct snd_seq_queue *q;
for (i = 0; i < SNDRV_SEQ_MAX_QUEUES; i++) { for (i = 0; i < SNDRV_SEQ_MAX_QUEUES; i++) {
if ((q = queueptr(i)) == NULL) q = queueptr(i);
if (!q)
continue; continue;
snd_seq_prioq_leave(q->tickq, client, 0); snd_seq_prioq_leave(q->tickq, client, 0);
snd_seq_prioq_leave(q->timeq, client, 0); snd_seq_prioq_leave(q->timeq, client, 0);
...@@ -593,7 +598,8 @@ void snd_seq_queue_remove_cells(int client, struct snd_seq_remove_events *info) ...@@ -593,7 +598,8 @@ void snd_seq_queue_remove_cells(int client, struct snd_seq_remove_events *info)
struct snd_seq_queue *q; struct snd_seq_queue *q;
for (i = 0; i < SNDRV_SEQ_MAX_QUEUES; i++) { for (i = 0; i < SNDRV_SEQ_MAX_QUEUES; i++) {
if ((q = queueptr(i)) == NULL) q = queueptr(i);
if (!q)
continue; continue;
if (test_bit(client, q->clients_bitmap) && if (test_bit(client, q->clients_bitmap) &&
(! (info->remove_mode & SNDRV_SEQ_REMOVE_DEST) || (! (info->remove_mode & SNDRV_SEQ_REMOVE_DEST) ||
...@@ -724,7 +730,8 @@ void snd_seq_info_queues_read(struct snd_info_entry *entry, ...@@ -724,7 +730,8 @@ void snd_seq_info_queues_read(struct snd_info_entry *entry,
int owner; int owner;
for (i = 0; i < SNDRV_SEQ_MAX_QUEUES; i++) { for (i = 0; i < SNDRV_SEQ_MAX_QUEUES; i++) {
if ((q = queueptr(i)) == NULL) q = queueptr(i);
if (!q)
continue; continue;
tmr = q->timer; tmr = q->timer;
......
...@@ -482,10 +482,11 @@ int snd_virmidi_new(struct snd_card *card, int device, struct snd_rawmidi **rrmi ...@@ -482,10 +482,11 @@ int snd_virmidi_new(struct snd_card *card, int device, struct snd_rawmidi **rrmi
int err; int err;
*rrmidi = NULL; *rrmidi = NULL;
if ((err = snd_rawmidi_new(card, "VirMidi", device, err = snd_rawmidi_new(card, "VirMidi", device,
16, /* may be configurable */ 16, /* may be configurable */
16, /* may be configurable */ 16, /* may be configurable */
&rmidi)) < 0) &rmidi);
if (err < 0)
return err; return err;
strcpy(rmidi->name, rmidi->id); strcpy(rmidi->name, rmidi->id);
rdev = kzalloc(sizeof(*rdev), GFP_KERNEL); rdev = kzalloc(sizeof(*rdev), GFP_KERNEL);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment