diff options
| author | Linus Torvalds <torvalds@g5.osdl.org> | 2006-03-22 13:56:23 -0500 |
|---|---|---|
| committer | Linus Torvalds <torvalds@g5.osdl.org> | 2006-03-22 13:56:23 -0500 |
| commit | 36177ba655c238e33400cc2837a28720b62784bd (patch) | |
| tree | c285738397f0272f1e0e973c5e6a53b2e8da74b1 /net/compat.c | |
| parent | 2152f8536668a957ea3214735b4761e7b22ef7d8 (diff) | |
| parent | 056755f4d73d49b4adcbb8ecdaf75138cf166bd3 (diff) | |
Merge master.kernel.org:/pub/scm/linux/kernel/git/davem/net-2.6
* master.kernel.org:/pub/scm/linux/kernel/git/davem/net-2.6:
[TG3]: Bump driver version and reldate.
[TG3]: Skip phy power down on some devices
[TG3]: Fix SRAM access during tg3_init_one()
[X25]: dte facilities 32 64 ioctl conversion
[X25]: allow ITU-T DTE facilities for x25
[X25]: fix kernel error message 64 bit kernel
[X25]: ioctl conversion 32 bit user to 64 bit kernel
[NET]: socket timestamp 32 bit handler for 64 bit kernel
[NET]: allow 32 bit socket ioctl in 64 bit kernel
[BLUETOOTH]: Return negative error constant
Diffstat (limited to 'net/compat.c')
| -rw-r--r-- | net/compat.c | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/net/compat.c b/net/compat.c index 13177a1a4b39..8fd37cd7b501 100644 --- a/net/compat.c +++ b/net/compat.c | |||
| @@ -543,6 +543,25 @@ static int compat_sock_getsockopt(struct socket *sock, int level, int optname, | |||
| 543 | return sock_getsockopt(sock, level, optname, optval, optlen); | 543 | return sock_getsockopt(sock, level, optname, optval, optlen); |
| 544 | } | 544 | } |
| 545 | 545 | ||
| 546 | int compat_sock_get_timestamp(struct sock *sk, struct timeval __user *userstamp) | ||
| 547 | { | ||
| 548 | struct compat_timeval __user *ctv = | ||
| 549 | (struct compat_timeval __user*) userstamp; | ||
| 550 | int err = -ENOENT; | ||
| 551 | |||
| 552 | if (!sock_flag(sk, SOCK_TIMESTAMP)) | ||
| 553 | sock_enable_timestamp(sk); | ||
| 554 | if (sk->sk_stamp.tv_sec == -1) | ||
| 555 | return err; | ||
| 556 | if (sk->sk_stamp.tv_sec == 0) | ||
| 557 | do_gettimeofday(&sk->sk_stamp); | ||
| 558 | if (put_user(sk->sk_stamp.tv_sec, &ctv->tv_sec) || | ||
| 559 | put_user(sk->sk_stamp.tv_usec, &ctv->tv_usec)) | ||
| 560 | err = -EFAULT; | ||
| 561 | return err; | ||
| 562 | } | ||
| 563 | EXPORT_SYMBOL(compat_sock_get_timestamp); | ||
| 564 | |||
| 546 | asmlinkage long compat_sys_getsockopt(int fd, int level, int optname, | 565 | asmlinkage long compat_sys_getsockopt(int fd, int level, int optname, |
| 547 | char __user *optval, int __user *optlen) | 566 | char __user *optval, int __user *optlen) |
| 548 | { | 567 | { |
