Commit 27dd5548 authored by Ken Cox's avatar Ken Cox Committed by Greg Kroah-Hartman

Staging: unisys: uislib: Fix locking in info_proc_read_helper()

Make sure BusListLock is unlocked before returning.  If an error is encountered
early on in info_proc_read_helper() the function can return without unlocking.

Also changed the PROCLINE macro so that it doesn't include a goto statement.
Reported-by: default avatarDan Carpenter <dan.carpenter@oracle.com>
Signed-off-by: default avatarKen Cox <jkc@redhat.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent bed3b10d
...@@ -1622,13 +1622,8 @@ chipset_proc_write(struct file *file, const char __user *buffer, ...@@ -1622,13 +1622,8 @@ chipset_proc_write(struct file *file, const char __user *buffer,
return -EFAULT; return -EFAULT;
} }
#define PROCLINE(...) \ #define PLINE(...) uisutil_add_proc_line_ex(&tot, buff, \
do { \ buff_len, __VA_ARGS__)
if (uisutil_add_proc_line_ex(&tot, buff, \
buff_len, __VA_ARGS__) < 0) { \
goto err_done; \
} \
} while (0)
static int static int
info_proc_read_helper(char **buff, int *buff_len) info_proc_read_helper(char **buff, int *buff_len)
...@@ -1636,55 +1631,75 @@ info_proc_read_helper(char **buff, int *buff_len) ...@@ -1636,55 +1631,75 @@ info_proc_read_helper(char **buff, int *buff_len)
int i, tot = 0; int i, tot = 0;
struct bus_info *bus; struct bus_info *bus;
PROCLINE("\nBuses:\n"); if (PLINE("\nBuses:\n") < 0)
goto err_done;
read_lock(&BusListLock); read_lock(&BusListLock);
for (bus = BusListHead; bus; bus = bus->next) { for (bus = BusListHead; bus; bus = bus->next) {
PROCLINE(" bus=0x%p, busNo=%d, deviceCount=%d\n", if (PLINE(" bus=0x%p, busNo=%d, deviceCount=%d\n",
bus, bus->busNo, bus->deviceCount); bus, bus->busNo, bus->deviceCount) < 0)
goto err_done_unlock;
PROCLINE(" Devices:\n"); if (PLINE(" Devices:\n") < 0)
goto err_done_unlock;
for (i = 0; i < bus->deviceCount; i++) { for (i = 0; i < bus->deviceCount; i++) {
if (bus->device[i]) { if (bus->device[i]) {
PROCLINE(" busNo %d, device[%i]: 0x%p, chanptr=0x%p, swtch=0x%p\n", if (PLINE(" busNo %d, device[%i]: 0x%p, chanptr=0x%p, swtch=0x%p\n",
bus->busNo, i, bus->device[i], bus->busNo, i, bus->device[i],
bus->device[i]->chanptr, bus->device[i]->chanptr,
bus->device[i]->swtch); bus->device[i]->swtch) < 0)
PROCLINE(" first_busy_cnt=%llu, moved_to_tail_cnt=%llu, last_on_list_cnt=%llu\n", goto err_done_unlock;
if (PLINE(" first_busy_cnt=%llu, moved_to_tail_cnt=%llu, last_on_list_cnt=%llu\n",
bus->device[i]->first_busy_cnt, bus->device[i]->first_busy_cnt,
bus->device[i]->moved_to_tail_cnt, bus->device[i]->moved_to_tail_cnt,
bus->device[i]->last_on_list_cnt); bus->device[i]->last_on_list_cnt) < 0)
goto err_done_unlock;
} }
} }
} }
read_unlock(&BusListLock); read_unlock(&BusListLock);
PROCLINE("Malloc bytes in use: %d\n", atomic_read(&Malloc_BytesInUse)); if (PLINE("Malloc bytes in use: %d\n",
PROCLINE("Malloc buffers in use: %d\n", atomic_read(&Malloc_BytesInUse)) < 0)
atomic_read(&Malloc_BuffersInUse)); goto err_done;
PROCLINE("Malloc allocation failures: %d\n", if (PLINE("Malloc buffers in use: %d\n",
atomic_read(&Malloc_FailuresAlloc)); atomic_read(&Malloc_BuffersInUse)) < 0)
PROCLINE("Malloc free failures: %d\n", goto err_done;
atomic_read(&Malloc_FailuresFree)); if (PLINE("Malloc allocation failures: %d\n",
PROCLINE("Malloc total mallocs: %u (may overflow)\n", atomic_read(&Malloc_FailuresAlloc)) < 0)
(unsigned) atomic_read(&Malloc_TotalMallocs)); goto err_done;
PROCLINE("Malloc total frees: %u (may overflow)\n", if (PLINE("Malloc free failures: %d\n",
(unsigned) atomic_read(&Malloc_TotalFrees)); atomic_read(&Malloc_FailuresFree)) < 0)
PROCLINE("UisUtils_Registered_Services: %d\n", goto err_done;
atomic_read(&UisUtils_Registered_Services)); if (PLINE("Malloc total mallocs: %u (may overflow)\n",
(unsigned) atomic_read(&Malloc_TotalMallocs)) < 0)
PROCLINE("cycles_before_wait %llu wait_cycles:%llu\n", goto err_done;
cycles_before_wait, wait_cycles); if (PLINE("Malloc total frees: %u (may overflow)\n",
PROCLINE("tot_wakeup_cnt %llu:tot_wait_cnt %llu:tot_schedule_cnt %llu\n", (unsigned) atomic_read(&Malloc_TotalFrees)) < 0)
tot_wakeup_cnt, tot_wait_cnt, tot_schedule_cnt); goto err_done;
PROCLINE("en_smart_wakeup %d\n", en_smart_wakeup); if (PLINE("UisUtils_Registered_Services: %d\n",
PROCLINE("tot_moved_to_tail_cnt %llu\n", tot_moved_to_tail_cnt); atomic_read(&UisUtils_Registered_Services)) < 0)
goto err_done;
if (PLINE("cycles_before_wait %llu wait_cycles:%llu\n",
cycles_before_wait, wait_cycles) < 0)
goto err_done;
if (PLINE("tot_wakeup_cnt %llu:tot_wait_cnt %llu:tot_schedule_cnt %llu\n",
tot_wakeup_cnt, tot_wait_cnt, tot_schedule_cnt) < 0)
goto err_done;
if (PLINE("en_smart_wakeup %d\n", en_smart_wakeup) < 0)
goto err_done;
if (PLINE("tot_moved_to_tail_cnt %llu\n", tot_moved_to_tail_cnt) < 0)
goto err_done;
return tot; return tot;
err_done:
err_done_unlock:
read_unlock(&BusListLock);
err_done:
return -1; return -1;
} }
......
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