aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDavid S. Miller <davem@sunset.davemloft.net>2007-02-08 18:06:08 -0500
committerDavid S. Miller <davem@sunset.davemloft.net>2007-02-08 18:06:08 -0500
commit4387ff75f29412a234d394b0276c2b239d3d3844 (patch)
treeca338c8c4c1b0c51df8720b712f18871fc74fca8
parent23bb80d2158cf4421fe239d788fd53cafb151050 (diff)
[NET]: Fix net/socket.c warnings.
GCC (correctly) says: net/socket.c: In function ‘sys_sendto’: net/socket.c:1510: warning: ‘err’ may be used uninitialized in this function net/socket.c: In function ‘sys_recvfrom’: net/socket.c:1571: warning: ‘err’ may be used uninitialized in this function sock_from_file() either returns filp->private_data or it sets *err and returns NULL. Callers return "err" on NULL, but filp->private_data could be NULL. Some minor rearrangements of error handling in sys_sendto and sys_recvfrom solves the issue. Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r--net/socket.c12
1 files changed, 8 insertions, 4 deletions
diff --git a/net/socket.c b/net/socket.c
index fc74930f1443..5f374e1ff526 100644
--- a/net/socket.c
+++ b/net/socket.c
@@ -1514,8 +1514,9 @@ asmlinkage long sys_sendto(int fd, void __user *buff, size_t len,
1514 struct file *sock_file; 1514 struct file *sock_file;
1515 1515
1516 sock_file = fget_light(fd, &fput_needed); 1516 sock_file = fget_light(fd, &fput_needed);
1517 err = -EBADF;
1517 if (!sock_file) 1518 if (!sock_file)
1518 return -EBADF; 1519 goto out;
1519 1520
1520 sock = sock_from_file(sock_file, &err); 1521 sock = sock_from_file(sock_file, &err);
1521 if (!sock) 1522 if (!sock)
@@ -1542,6 +1543,7 @@ asmlinkage long sys_sendto(int fd, void __user *buff, size_t len,
1542 1543
1543out_put: 1544out_put:
1544 fput_light(sock_file, fput_needed); 1545 fput_light(sock_file, fput_needed);
1546out:
1545 return err; 1547 return err;
1546} 1548}
1547 1549
@@ -1573,12 +1575,13 @@ asmlinkage long sys_recvfrom(int fd, void __user *ubuf, size_t size,
1573 int fput_needed; 1575 int fput_needed;
1574 1576
1575 sock_file = fget_light(fd, &fput_needed); 1577 sock_file = fget_light(fd, &fput_needed);
1578 err = -EBADF;
1576 if (!sock_file) 1579 if (!sock_file)
1577 return -EBADF; 1580 goto out;
1578 1581
1579 sock = sock_from_file(sock_file, &err); 1582 sock = sock_from_file(sock_file, &err);
1580 if (!sock) 1583 if (!sock)
1581 goto out; 1584 goto out_put;
1582 1585
1583 msg.msg_control = NULL; 1586 msg.msg_control = NULL;
1584 msg.msg_controllen = 0; 1587 msg.msg_controllen = 0;
@@ -1597,8 +1600,9 @@ asmlinkage long sys_recvfrom(int fd, void __user *ubuf, size_t size,
1597 if (err2 < 0) 1600 if (err2 < 0)
1598 err = err2; 1601 err = err2;
1599 } 1602 }
1600out: 1603out_put:
1601 fput_light(sock_file, fput_needed); 1604 fput_light(sock_file, fput_needed);
1605out:
1602 return err; 1606 return err;
1603} 1607}
1604 1608