Re: [PATCH v3 1/3] net: rework SIOCGSTAMP ioctl handling

2019-04-17 Thread Willem de Bruijn
On Wed, Apr 17, 2019 at 4:54 PM Arnd Bergmann  wrote:
>
> The SIOCGSTAMP/SIOCGSTAMPNS ioctl commands are implemented by many
> socket protocol handlers, and all of those end up calling the same
> sock_get_timestamp()/sock_get_timestampns() helper functions, which
> results in a lot of duplicate code.
>
> With the introduction of 64-bit time_t on 32-bit architectures, this
> gets worse, as we then need four different ioctl commands in each
> socket protocol implementation.
>
> To simplify that, let's add a new .gettstamp() operation in
> struct proto_ops, and move ioctl implementation into the common
> sock_ioctl()/compat_sock_ioctl_trans() functions that these all go
> through.
>
> We can reuse the sock_get_timestamp() implementation, but generalize
> it so it can deal with both native and compat mode, as well as
> timeval and timespec structures.
>
> Acked-by: Stefan Schmidt 
> Acked-by: Neil Horman 
> Acked-by: Marc Kleine-Budde 
> Link: 
> https://lore.kernel.org/lkml/CAK8P3a038aDQQotzua_QtKGhq8O9n+rdiz2=wdcp82ys8eu...@mail.gmail.com/
> Signed-off-by: Arnd Bergmann 

Acked-by: Willem de Bruijn 


[PATCH v3 1/3] net: rework SIOCGSTAMP ioctl handling

2019-04-17 Thread Arnd Bergmann
The SIOCGSTAMP/SIOCGSTAMPNS ioctl commands are implemented by many
socket protocol handlers, and all of those end up calling the same
sock_get_timestamp()/sock_get_timestampns() helper functions, which
results in a lot of duplicate code.

With the introduction of 64-bit time_t on 32-bit architectures, this
gets worse, as we then need four different ioctl commands in each
socket protocol implementation.

To simplify that, let's add a new .gettstamp() operation in
struct proto_ops, and move ioctl implementation into the common
sock_ioctl()/compat_sock_ioctl_trans() functions that these all go
through.

We can reuse the sock_get_timestamp() implementation, but generalize
it so it can deal with both native and compat mode, as well as
timeval and timespec structures.

Acked-by: Stefan Schmidt 
Acked-by: Neil Horman 
Acked-by: Marc Kleine-Budde 
Link: 
https://lore.kernel.org/lkml/CAK8P3a038aDQQotzua_QtKGhq8O9n+rdiz2=wdcp82ys8eu...@mail.gmail.com/
Signed-off-by: Arnd Bergmann 
---
v3: add back sock_read_timestamp() that was accidentally dropped
v2: reworked to not break sparc64 support
---
 include/linux/net.h  |  2 ++
 include/net/compat.h |  3 --
 include/net/sock.h   |  4 +--
 net/appletalk/ddp.c  |  7 +
 net/atm/ioctl.c  | 16 --
 net/atm/pvc.c|  1 +
 net/atm/svc.c|  1 +
 net/ax25/af_ax25.c   |  9 +-
 net/bluetooth/af_bluetooth.c |  8 -
 net/bluetooth/l2cap_sock.c   |  1 +
 net/bluetooth/rfcomm/sock.c  |  1 +
 net/bluetooth/sco.c  |  1 +
 net/can/af_can.c |  6 
 net/can/bcm.c|  1 +
 net/can/raw.c|  1 +
 net/compat.c | 57 
 net/core/sock.c  | 51 +---
 net/dccp/ipv4.c  |  1 +
 net/dccp/ipv6.c  |  1 +
 net/ieee802154/socket.c  |  6 ++--
 net/ipv4/af_inet.c   |  9 ++
 net/ipv6/af_inet6.c  |  8 ++---
 net/ipv6/raw.c   |  1 +
 net/l2tp/l2tp_ip.c   |  1 +
 net/l2tp/l2tp_ip6.c  |  1 +
 net/netrom/af_netrom.c   | 14 +
 net/packet/af_packet.c   |  7 ++---
 net/qrtr/qrtr.c  |  4 +--
 net/rose/af_rose.c   |  7 +
 net/sctp/ipv6.c  |  1 +
 net/sctp/protocol.c  |  1 +
 net/socket.c | 48 +-
 net/x25/af_x25.c | 27 +
 33 files changed, 75 insertions(+), 232 deletions(-)

diff --git a/include/linux/net.h b/include/linux/net.h
index c606c72311d0..50bf5206ead6 100644
--- a/include/linux/net.h
+++ b/include/linux/net.h
@@ -161,6 +161,8 @@ struct proto_ops {
int (*compat_ioctl) (struct socket *sock, unsigned int cmd,
  unsigned long arg);
 #endif
+   int (*gettstamp) (struct socket *sock, void __user 
*userstamp,
+ bool timeval, bool time32);
int (*listen)(struct socket *sock, int len);
int (*shutdown)  (struct socket *sock, int flags);
int (*setsockopt)(struct socket *sock, int level,
diff --git a/include/net/compat.h b/include/net/compat.h
index 4c6d75612b6c..f277653c7e17 100644
--- a/include/net/compat.h
+++ b/include/net/compat.h
@@ -30,9 +30,6 @@ struct compat_cmsghdr {
compat_int_tcmsg_type;
 };
 
-int compat_sock_get_timestamp(struct sock *, struct timeval __user *);
-int compat_sock_get_timestampns(struct sock *, struct timespec __user *);
-
 #else /* defined(CONFIG_COMPAT) */
 /*
  * To avoid compiler warnings:
diff --git a/include/net/sock.h b/include/net/sock.h
index 8de5ee258b93..d1fe105dcf42 100644
--- a/include/net/sock.h
+++ b/include/net/sock.h
@@ -1607,6 +1607,8 @@ int sock_setsockopt(struct socket *sock, int level, int 
op,
 
 int sock_getsockopt(struct socket *sock, int level, int op,
char __user *optval, int __user *optlen);
+int sock_gettstamp(struct socket *sock, void __user *userstamp,
+  bool timeval, bool time32);
 struct sk_buff *sock_alloc_send_skb(struct sock *sk, unsigned long size,
int noblock, int *errcode);
 struct sk_buff *sock_alloc_send_pskb(struct sock *sk, unsigned long header_len,
@@ -2493,8 +2495,6 @@ static inline bool sk_listener(const struct sock *sk)
 }
 
 void sock_enable_timestamp(struct sock *sk, int flag);
-int sock_get_timestamp(struct sock *, struct timeval __user *);
-int sock_get_timestampns(struct sock *, struct timespec __user *);
 int sock_recv_errqueue(struct sock *sk, struct msghdr *msg, int len, int level,
   int type);
 
diff --git a/net/appletalk/ddp.c b/net/appletalk/ddp.c
index 709d2542f729..e2511027d19b 100644
--- a/net/appletalk/ddp.c
+++ b/net/appletalk/ddp.c
@@ -1806,12 +1806,6 @@ static int atalk_ioctl(struct socket *sock, unsigned int 
cmd,