diff options
Diffstat (limited to 'net/socket.c')
| -rw-r--r-- | net/socket.c | 18 |
1 files changed, 8 insertions, 10 deletions
diff --git a/net/socket.c b/net/socket.c index 12a48d846223..484cc6953fc6 100644 --- a/net/socket.c +++ b/net/socket.c | |||
| @@ -2592,7 +2592,7 @@ void socket_seq_show(struct seq_file *seq) | |||
| 2592 | 2592 | ||
| 2593 | #ifdef CONFIG_COMPAT | 2593 | #ifdef CONFIG_COMPAT |
| 2594 | static int do_siocgstamp(struct net *net, struct socket *sock, | 2594 | static int do_siocgstamp(struct net *net, struct socket *sock, |
| 2595 | unsigned int cmd, struct compat_timeval __user *up) | 2595 | unsigned int cmd, void __user *up) |
| 2596 | { | 2596 | { |
| 2597 | mm_segment_t old_fs = get_fs(); | 2597 | mm_segment_t old_fs = get_fs(); |
| 2598 | struct timeval ktv; | 2598 | struct timeval ktv; |
| @@ -2601,15 +2601,14 @@ static int do_siocgstamp(struct net *net, struct socket *sock, | |||
| 2601 | set_fs(KERNEL_DS); | 2601 | set_fs(KERNEL_DS); |
| 2602 | err = sock_do_ioctl(net, sock, cmd, (unsigned long)&ktv); | 2602 | err = sock_do_ioctl(net, sock, cmd, (unsigned long)&ktv); |
| 2603 | set_fs(old_fs); | 2603 | set_fs(old_fs); |
| 2604 | if (!err) { | 2604 | if (!err) |
| 2605 | err = put_user(ktv.tv_sec, &up->tv_sec); | 2605 | err = compat_put_timeval(up, &ktv); |
| 2606 | err |= __put_user(ktv.tv_usec, &up->tv_usec); | 2606 | |
| 2607 | } | ||
| 2608 | return err; | 2607 | return err; |
| 2609 | } | 2608 | } |
| 2610 | 2609 | ||
| 2611 | static int do_siocgstampns(struct net *net, struct socket *sock, | 2610 | static int do_siocgstampns(struct net *net, struct socket *sock, |
| 2612 | unsigned int cmd, struct compat_timespec __user *up) | 2611 | unsigned int cmd, void __user *up) |
| 2613 | { | 2612 | { |
| 2614 | mm_segment_t old_fs = get_fs(); | 2613 | mm_segment_t old_fs = get_fs(); |
| 2615 | struct timespec kts; | 2614 | struct timespec kts; |
| @@ -2618,10 +2617,9 @@ static int do_siocgstampns(struct net *net, struct socket *sock, | |||
| 2618 | set_fs(KERNEL_DS); | 2617 | set_fs(KERNEL_DS); |
| 2619 | err = sock_do_ioctl(net, sock, cmd, (unsigned long)&kts); | 2618 | err = sock_do_ioctl(net, sock, cmd, (unsigned long)&kts); |
| 2620 | set_fs(old_fs); | 2619 | set_fs(old_fs); |
| 2621 | if (!err) { | 2620 | if (!err) |
| 2622 | err = put_user(kts.tv_sec, &up->tv_sec); | 2621 | err = compat_put_timespec(up, &kts); |
| 2623 | err |= __put_user(kts.tv_nsec, &up->tv_nsec); | 2622 | |
| 2624 | } | ||
| 2625 | return err; | 2623 | return err; |
| 2626 | } | 2624 | } |
| 2627 | 2625 | ||
