staging: dgnc: audit goto's in dgnc_mgmt

TODO file requests fix up of error handling.

Audit dgnc_mgmt.c and fix all return paths to be uniform and inline
with kernel coding style.

Signed-off-by: Tobin C. Harding <me@tobin.cc>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
Tobin C. Harding 2017-03-07 20:57:02 +11:00 committed by Greg Kroah-Hartman
parent c8863b3ff7
commit 7029064dd1
1 changed files with 20 additions and 17 deletions

View File

@ -42,25 +42,25 @@ int dgnc_mgmt_open(struct inode *inode, struct file *file)
{ {
unsigned long flags; unsigned long flags;
unsigned int minor = iminor(inode); unsigned int minor = iminor(inode);
int rc = 0;
spin_lock_irqsave(&dgnc_global_lock, flags); spin_lock_irqsave(&dgnc_global_lock, flags);
/* mgmt device */ /* mgmt device */
if (minor < MAXMGMTDEVICES) { if (minor >= MAXMGMTDEVICES) {
/* Only allow 1 open at a time on mgmt device */ rc = -ENXIO;
if (dgnc_mgmt_in_use[minor]) { goto out;
spin_unlock_irqrestore(&dgnc_global_lock, flags);
return -EBUSY;
}
dgnc_mgmt_in_use[minor]++;
} else {
spin_unlock_irqrestore(&dgnc_global_lock, flags);
return -ENXIO;
} }
/* Only allow 1 open at a time on mgmt device */
if (dgnc_mgmt_in_use[minor]) {
rc = -EBUSY;
goto out;
}
dgnc_mgmt_in_use[minor]++;
out:
spin_unlock_irqrestore(&dgnc_global_lock, flags); spin_unlock_irqrestore(&dgnc_global_lock, flags);
return rc;
return 0;
} }
/* /*
@ -72,17 +72,20 @@ int dgnc_mgmt_close(struct inode *inode, struct file *file)
{ {
unsigned long flags; unsigned long flags;
unsigned int minor = iminor(inode); unsigned int minor = iminor(inode);
int rc = 0;
spin_lock_irqsave(&dgnc_global_lock, flags); spin_lock_irqsave(&dgnc_global_lock, flags);
/* mgmt device */ /* mgmt device */
if (minor < MAXMGMTDEVICES) { if (minor >= MAXMGMTDEVICES) {
if (dgnc_mgmt_in_use[minor]) rc = -ENXIO;
dgnc_mgmt_in_use[minor] = 0; goto out;
} }
spin_unlock_irqrestore(&dgnc_global_lock, flags); dgnc_mgmt_in_use[minor] = 0;
return 0; out:
spin_unlock_irqrestore(&dgnc_global_lock, flags);
return rc;
} }
/* /*