* [PATCH net-next v5 0/2] report TCP MD5 signing keys and addresses
@ 2017-08-31 16:59 Ivan Delalande
2017-08-31 16:59 ` [PATCH net-next v5 1/2] inet_diag: allow protocols to provide additional data Ivan Delalande
` (2 more replies)
0 siblings, 3 replies; 9+ messages in thread
From: Ivan Delalande @ 2017-08-31 16:59 UTC (permalink / raw)
To: David Miller; +Cc: Eric Dumazet, netdev, Ivan Delalande
Allow userspace to retrieve MD5 signature keys and addresses configured
on TCP sockets through inet_diag.
Thanks to Eric Dumazet and Stephen Hemminger for their useful
explanations and feedback.
v5: - memset the whole netlink payload after it has been nla_reserve-d
in tcp_diag_put_md5sig (a third memset had to be added for
tcpm_key so we might as well have just one for entire region).
- move the nla_total_size call from inet_sk_attr_size to the
idiag_get_aux_size defined by protocols as they could add multiple
netlink attributes,
- add check for net_admin in tcp_diag_get_aux_size.
v4: - add new struct tcp_diag_md5sig to report the data instead of
tcp_md5sig to avoid wasting 112 bytes on every tcpm_addr,
- memset tcpm_addr on IPv4 addresses to avoid leaks,
- style fix in inet_diag_dump_one_icsk.
v3: - rename inet_diag_*md5sig in tcp_diag.c to tcp_diag_* for
consistency,
- don't lock the socket in tcp_diag_put_md5sig,
- add checks on md5sig_count in tcp_diag_put_md5sig to not create
the netlink attribute if the list is empty, and to avoid overflows
or memory leaks if the list has changed in the meantime.
v2: - move changes to tcp_diag.c and extend inet_diag_handler to allow
protocols to provide additional data on INET_DIAG_INFO,
- lock socket before calling tcp_diag_put_md5sig.
I also have a patch for iproute2/ss to test this change, making it print
this new attribute. I'm planning to polish and send it if this series
gets applied.
Ivan Delalande (2):
inet_diag: allow protocols to provide additional data
tcp_diag: report TCP MD5 signing keys and addresses
include/linux/inet_diag.h | 7 +++
include/uapi/linux/inet_diag.h | 1 +
include/uapi/linux/tcp.h | 9 ++++
net/ipv4/inet_diag.c | 22 +++++++--
net/ipv4/tcp_diag.c | 109 ++++++++++++++++++++++++++++++++++++++---
5 files changed, 138 insertions(+), 10 deletions(-)
--
2.14.1
^ permalink raw reply [flat|nested] 9+ messages in thread* [PATCH net-next v5 1/2] inet_diag: allow protocols to provide additional data 2017-08-31 16:59 [PATCH net-next v5 0/2] report TCP MD5 signing keys and addresses Ivan Delalande @ 2017-08-31 16:59 ` Ivan Delalande 2017-09-01 2:57 ` Eric Dumazet 2017-08-31 16:59 ` [PATCH net-next v5 2/2] tcp_diag: report TCP MD5 signing keys and addresses Ivan Delalande 2017-09-02 1:38 ` [PATCH net-next v5 0/2] " David Miller 2 siblings, 1 reply; 9+ messages in thread From: Ivan Delalande @ 2017-08-31 16:59 UTC (permalink / raw) To: David Miller; +Cc: Eric Dumazet, netdev, Ivan Delalande Extend inet_diag_handler to allow individual protocols to report additional data on INET_DIAG_INFO through idiag_get_aux. The size can be dynamic and is computed by idiag_get_aux_size. Signed-off-by: Ivan Delalande <colona@arista.com> --- include/linux/inet_diag.h | 7 +++++++ net/ipv4/inet_diag.c | 22 ++++++++++++++++++---- 2 files changed, 25 insertions(+), 4 deletions(-) diff --git a/include/linux/inet_diag.h b/include/linux/inet_diag.h index 65da430e260f..ee251c585854 100644 --- a/include/linux/inet_diag.h +++ b/include/linux/inet_diag.h @@ -25,6 +25,13 @@ struct inet_diag_handler { struct inet_diag_msg *r, void *info); + int (*idiag_get_aux)(struct sock *sk, + bool net_admin, + struct sk_buff *skb); + + size_t (*idiag_get_aux_size)(struct sock *sk, + bool net_admin); + int (*destroy)(struct sk_buff *in_skb, const struct inet_diag_req_v2 *req); diff --git a/net/ipv4/inet_diag.c b/net/ipv4/inet_diag.c index 67325d5832d7..c9c35b61a027 100644 --- a/net/ipv4/inet_diag.c +++ b/net/ipv4/inet_diag.c @@ -93,8 +93,17 @@ void inet_diag_msg_common_fill(struct inet_diag_msg *r, struct sock *sk) } EXPORT_SYMBOL_GPL(inet_diag_msg_common_fill); -static size_t inet_sk_attr_size(void) +static size_t inet_sk_attr_size(struct sock *sk, + const struct inet_diag_req_v2 *req, + bool net_admin) { + const struct inet_diag_handler *handler; + size_t aux = 0; + + handler = inet_diag_table[req->sdiag_protocol]; + if (handler && handler->idiag_get_aux_size) + aux = handler->idiag_get_aux_size(sk, net_admin); + return nla_total_size(sizeof(struct tcp_info)) + nla_total_size(1) /* INET_DIAG_SHUTDOWN */ + nla_total_size(1) /* INET_DIAG_TOS */ @@ -105,6 +114,7 @@ static size_t inet_sk_attr_size(void) + nla_total_size(SK_MEMINFO_VARS * sizeof(u32)) + nla_total_size(TCP_CA_NAME_MAX) + nla_total_size(sizeof(struct tcpvegas_info)) + + aux + 64; } @@ -260,6 +270,10 @@ int inet_sk_diag_fill(struct sock *sk, struct inet_connection_sock *icsk, handler->idiag_get_info(sk, r, info); + if (ext & (1 << (INET_DIAG_INFO - 1)) && handler->idiag_get_aux) + if (handler->idiag_get_aux(sk, net_admin, skb) < 0) + goto errout; + if (sk->sk_state < TCP_TIME_WAIT) { union tcp_cc_info info; size_t sz = 0; @@ -449,6 +463,7 @@ int inet_diag_dump_one_icsk(struct inet_hashinfo *hashinfo, const struct nlmsghdr *nlh, const struct inet_diag_req_v2 *req) { + bool net_admin = netlink_net_capable(in_skb, CAP_NET_ADMIN); struct net *net = sock_net(in_skb->sk); struct sk_buff *rep; struct sock *sk; @@ -458,7 +473,7 @@ int inet_diag_dump_one_icsk(struct inet_hashinfo *hashinfo, if (IS_ERR(sk)) return PTR_ERR(sk); - rep = nlmsg_new(inet_sk_attr_size(), GFP_KERNEL); + rep = nlmsg_new(inet_sk_attr_size(sk, req, net_admin), GFP_KERNEL); if (!rep) { err = -ENOMEM; goto out; @@ -467,8 +482,7 @@ int inet_diag_dump_one_icsk(struct inet_hashinfo *hashinfo, err = sk_diag_fill(sk, rep, req, sk_user_ns(NETLINK_CB(in_skb).sk), NETLINK_CB(in_skb).portid, - nlh->nlmsg_seq, 0, nlh, - netlink_net_capable(in_skb, CAP_NET_ADMIN)); + nlh->nlmsg_seq, 0, nlh, net_admin); if (err < 0) { WARN_ON(err == -EMSGSIZE); nlmsg_free(rep); -- 2.14.1 ^ permalink raw reply related [flat|nested] 9+ messages in thread
* Re: [PATCH net-next v5 1/2] inet_diag: allow protocols to provide additional data 2017-08-31 16:59 ` [PATCH net-next v5 1/2] inet_diag: allow protocols to provide additional data Ivan Delalande @ 2017-09-01 2:57 ` Eric Dumazet 0 siblings, 0 replies; 9+ messages in thread From: Eric Dumazet @ 2017-09-01 2:57 UTC (permalink / raw) To: Ivan Delalande; +Cc: David Miller, netdev On Thu, 2017-08-31 at 09:59 -0700, Ivan Delalande wrote: > Extend inet_diag_handler to allow individual protocols to report > additional data on INET_DIAG_INFO through idiag_get_aux. The size > can be dynamic and is computed by idiag_get_aux_size. > > Signed-off-by: Ivan Delalande <colona@arista.com> > --- > include/linux/inet_diag.h | 7 +++++++ > net/ipv4/inet_diag.c | 22 ++++++++++++++++++---- > 2 files changed, 25 insertions(+), 4 deletions(-) Acked-by: Eric Dumazet <edumazet@google.com> ^ permalink raw reply [flat|nested] 9+ messages in thread
* [PATCH net-next v5 2/2] tcp_diag: report TCP MD5 signing keys and addresses 2017-08-31 16:59 [PATCH net-next v5 0/2] report TCP MD5 signing keys and addresses Ivan Delalande 2017-08-31 16:59 ` [PATCH net-next v5 1/2] inet_diag: allow protocols to provide additional data Ivan Delalande @ 2017-08-31 16:59 ` Ivan Delalande 2017-08-31 23:26 ` Sabrina Dubroca 2017-09-01 2:58 ` Eric Dumazet 2017-09-02 1:38 ` [PATCH net-next v5 0/2] " David Miller 2 siblings, 2 replies; 9+ messages in thread From: Ivan Delalande @ 2017-08-31 16:59 UTC (permalink / raw) To: David Miller; +Cc: Eric Dumazet, netdev, Ivan Delalande Report TCP MD5 (RFC2385) signing keys, addresses and address prefixes to processes with CAP_NET_ADMIN requesting INET_DIAG_INFO. Currently it is not possible to retrieve these from the kernel once they have been configured on sockets. Signed-off-by: Ivan Delalande <colona@arista.com> --- include/uapi/linux/inet_diag.h | 1 + include/uapi/linux/tcp.h | 9 ++++ net/ipv4/tcp_diag.c | 109 ++++++++++++++++++++++++++++++++++++++--- 3 files changed, 113 insertions(+), 6 deletions(-) diff --git a/include/uapi/linux/inet_diag.h b/include/uapi/linux/inet_diag.h index 678496897a68..f52ff62bfabe 100644 --- a/include/uapi/linux/inet_diag.h +++ b/include/uapi/linux/inet_diag.h @@ -143,6 +143,7 @@ enum { INET_DIAG_MARK, INET_DIAG_BBRINFO, INET_DIAG_CLASS_ID, + INET_DIAG_MD5SIG, __INET_DIAG_MAX, }; diff --git a/include/uapi/linux/tcp.h b/include/uapi/linux/tcp.h index 030e594bab45..15c25eccab2b 100644 --- a/include/uapi/linux/tcp.h +++ b/include/uapi/linux/tcp.h @@ -256,4 +256,13 @@ struct tcp_md5sig { __u8 tcpm_key[TCP_MD5SIG_MAXKEYLEN]; /* key (binary) */ }; +/* INET_DIAG_MD5SIG */ +struct tcp_diag_md5sig { + __u8 tcpm_family; + __u8 tcpm_prefixlen; + __u16 tcpm_keylen; + __be32 tcpm_addr[4]; + __u8 tcpm_key[TCP_MD5SIG_MAXKEYLEN]; +}; + #endif /* _UAPI_LINUX_TCP_H */ diff --git a/net/ipv4/tcp_diag.c b/net/ipv4/tcp_diag.c index a748c74aa8b7..abbf0edcf6c2 100644 --- a/net/ipv4/tcp_diag.c +++ b/net/ipv4/tcp_diag.c @@ -16,6 +16,7 @@ #include <linux/tcp.h> +#include <net/netlink.h> #include <net/tcp.h> static void tcp_diag_get_info(struct sock *sk, struct inet_diag_msg *r, @@ -36,6 +37,100 @@ static void tcp_diag_get_info(struct sock *sk, struct inet_diag_msg *r, tcp_get_info(sk, info); } +#ifdef CONFIG_TCP_MD5SIG +static void tcp_diag_md5sig_fill(struct tcp_diag_md5sig *info, + const struct tcp_md5sig_key *key) +{ + info->tcpm_family = key->family; + info->tcpm_prefixlen = key->prefixlen; + info->tcpm_keylen = key->keylen; + memcpy(info->tcpm_key, key->key, key->keylen); + + if (key->family == AF_INET) + info->tcpm_addr[0] = key->addr.a4.s_addr; + #if IS_ENABLED(CONFIG_IPV6) + else if (key->family == AF_INET6) + memcpy(&info->tcpm_addr, &key->addr.a6, + sizeof(info->tcpm_addr)); + #endif +} + +static int tcp_diag_put_md5sig(struct sk_buff *skb, + const struct tcp_md5sig_info *md5sig) +{ + const struct tcp_md5sig_key *key; + struct tcp_diag_md5sig *info; + struct nlattr *attr; + int md5sig_count = 0; + + hlist_for_each_entry_rcu(key, &md5sig->head, node) + md5sig_count++; + if (md5sig_count == 0) + return 0; + + attr = nla_reserve(skb, INET_DIAG_MD5SIG, + md5sig_count * sizeof(struct tcp_diag_md5sig)); + if (!attr) + return -EMSGSIZE; + + info = nla_data(attr); + memset(info, 0, md5sig_count * sizeof(struct tcp_diag_md5sig)); + hlist_for_each_entry_rcu(key, &md5sig->head, node) { + tcp_diag_md5sig_fill(info++, key); + if (--md5sig_count == 0) + break; + } + + return 0; +} +#endif + +static int tcp_diag_get_aux(struct sock *sk, bool net_admin, + struct sk_buff *skb) +{ +#ifdef CONFIG_TCP_MD5SIG + if (net_admin) { + struct tcp_md5sig_info *md5sig; + int err = 0; + + rcu_read_lock(); + md5sig = rcu_dereference(tcp_sk(sk)->md5sig_info); + if (md5sig) + err = tcp_diag_put_md5sig(skb, md5sig); + rcu_read_unlock(); + if (err < 0) + return err; + } +#endif + + return 0; +} + +static size_t tcp_diag_get_aux_size(struct sock *sk, bool net_admin) +{ + size_t size = 0; + +#ifdef CONFIG_TCP_MD5SIG + if (net_admin && sk_fullsock(sk)) { + const struct tcp_md5sig_info *md5sig; + const struct tcp_md5sig_key *key; + size_t md5sig_count = 0; + + rcu_read_lock(); + md5sig = rcu_dereference(tcp_sk(sk)->md5sig_info); + if (md5sig) { + hlist_for_each_entry_rcu(key, &md5sig->head, node) + md5sig_count++; + } + rcu_read_unlock(); + size += nla_total_size(md5sig_count * + sizeof(struct tcp_diag_md5sig)); + } +#endif + + return size; +} + static void tcp_diag_dump(struct sk_buff *skb, struct netlink_callback *cb, const struct inet_diag_req_v2 *r, struct nlattr *bc) { @@ -68,13 +163,15 @@ static int tcp_diag_destroy(struct sk_buff *in_skb, #endif static const struct inet_diag_handler tcp_diag_handler = { - .dump = tcp_diag_dump, - .dump_one = tcp_diag_dump_one, - .idiag_get_info = tcp_diag_get_info, - .idiag_type = IPPROTO_TCP, - .idiag_info_size = sizeof(struct tcp_info), + .dump = tcp_diag_dump, + .dump_one = tcp_diag_dump_one, + .idiag_get_info = tcp_diag_get_info, + .idiag_get_aux = tcp_diag_get_aux, + .idiag_get_aux_size = tcp_diag_get_aux_size, + .idiag_type = IPPROTO_TCP, + .idiag_info_size = sizeof(struct tcp_info), #ifdef CONFIG_INET_DIAG_DESTROY - .destroy = tcp_diag_destroy, + .destroy = tcp_diag_destroy, #endif }; -- 2.14.1 ^ permalink raw reply related [flat|nested] 9+ messages in thread
* Re: [PATCH net-next v5 2/2] tcp_diag: report TCP MD5 signing keys and addresses 2017-08-31 16:59 ` [PATCH net-next v5 2/2] tcp_diag: report TCP MD5 signing keys and addresses Ivan Delalande @ 2017-08-31 23:26 ` Sabrina Dubroca 2017-09-01 0:21 ` Ivan Delalande 2017-09-01 2:58 ` Eric Dumazet 1 sibling, 1 reply; 9+ messages in thread From: Sabrina Dubroca @ 2017-08-31 23:26 UTC (permalink / raw) To: Ivan Delalande; +Cc: David Miller, Eric Dumazet, netdev 2017-08-31, 09:59:39 -0700, Ivan Delalande wrote: > diff --git a/net/ipv4/tcp_diag.c b/net/ipv4/tcp_diag.c > index a748c74aa8b7..abbf0edcf6c2 100644 > --- a/net/ipv4/tcp_diag.c > +++ b/net/ipv4/tcp_diag.c [...] > +static int tcp_diag_get_aux(struct sock *sk, bool net_admin, > + struct sk_buff *skb) > +{ > +#ifdef CONFIG_TCP_MD5SIG > + if (net_admin) { In tcp_diag_get_aux_size() you put a check for sk_fullsock. I don't see anything preventing you from reaching this with a !fullsock? > + struct tcp_md5sig_info *md5sig; > + int err = 0; > + > + rcu_read_lock(); > + md5sig = rcu_dereference(tcp_sk(sk)->md5sig_info); > + if (md5sig) > + err = tcp_diag_put_md5sig(skb, md5sig); > + rcu_read_unlock(); > + if (err < 0) > + return err; > + } > +#endif > + > + return 0; > +} > + > +static size_t tcp_diag_get_aux_size(struct sock *sk, bool net_admin) > +{ > + size_t size = 0; > + > +#ifdef CONFIG_TCP_MD5SIG > + if (net_admin && sk_fullsock(sk)) { > + const struct tcp_md5sig_info *md5sig; > + const struct tcp_md5sig_key *key; > + size_t md5sig_count = 0; > + > + rcu_read_lock(); > + md5sig = rcu_dereference(tcp_sk(sk)->md5sig_info); > + if (md5sig) { > + hlist_for_each_entry_rcu(key, &md5sig->head, node) > + md5sig_count++; > + } > + rcu_read_unlock(); > + size += nla_total_size(md5sig_count * > + sizeof(struct tcp_diag_md5sig)); > + } > +#endif > + > + return size; > +} > + > static void tcp_diag_dump(struct sk_buff *skb, struct netlink_callback *cb, > const struct inet_diag_req_v2 *r, struct nlattr *bc) > { -- Sabrina ^ permalink raw reply [flat|nested] 9+ messages in thread
* Re: [PATCH net-next v5 2/2] tcp_diag: report TCP MD5 signing keys and addresses 2017-08-31 23:26 ` Sabrina Dubroca @ 2017-09-01 0:21 ` Ivan Delalande 2017-09-01 15:47 ` Sabrina Dubroca 0 siblings, 1 reply; 9+ messages in thread From: Ivan Delalande @ 2017-09-01 0:21 UTC (permalink / raw) To: Sabrina Dubroca; +Cc: David Miller, Eric Dumazet, netdev On Fri, Sep 01, 2017 at 01:26:33AM +0200, Sabrina Dubroca wrote: > 2017-08-31, 09:59:39 -0700, Ivan Delalande wrote: > > diff --git a/net/ipv4/tcp_diag.c b/net/ipv4/tcp_diag.c > > index a748c74aa8b7..abbf0edcf6c2 100644 > > --- a/net/ipv4/tcp_diag.c > > +++ b/net/ipv4/tcp_diag.c > [...] > > +static int tcp_diag_get_aux(struct sock *sk, bool net_admin, > > + struct sk_buff *skb) > > +{ > > +#ifdef CONFIG_TCP_MD5SIG > > + if (net_admin) { > > In tcp_diag_get_aux_size() you put a check for sk_fullsock. I don't > see anything preventing you from reaching this with a !fullsock? Currently handler->idiag_get_aux is only called from inet_sk_diag_fill which has a `BUG_ON(!sk_fullsock(sk));`, but I could add another explicit check in that function if you think it's more consistent. Actually, I wasn't sure when adding this idiag_get_aux in v2 if it should be called from inet_twsk_diag_fill, inet_req_diag_fill and inet_csk_diag_fill, or just the last one. I chose that simpler approach for now to avoid duplicating these state checks in the idiag_get_aux defined by protocols and because we didn't need for INET_DIAG_MD5SIG, but it shouldn't be too hard to change. Do you think this could be useful for other protocols or attributes? Thank you, -- Ivan Delalande Arista Networks ^ permalink raw reply [flat|nested] 9+ messages in thread
* Re: [PATCH net-next v5 2/2] tcp_diag: report TCP MD5 signing keys and addresses 2017-09-01 0:21 ` Ivan Delalande @ 2017-09-01 15:47 ` Sabrina Dubroca 0 siblings, 0 replies; 9+ messages in thread From: Sabrina Dubroca @ 2017-09-01 15:47 UTC (permalink / raw) To: Ivan Delalande; +Cc: David Miller, Eric Dumazet, netdev 2017-09-01, 02:21:18 +0200, Ivan Delalande wrote: > On Fri, Sep 01, 2017 at 01:26:33AM +0200, Sabrina Dubroca wrote: > > 2017-08-31, 09:59:39 -0700, Ivan Delalande wrote: > > > diff --git a/net/ipv4/tcp_diag.c b/net/ipv4/tcp_diag.c > > > index a748c74aa8b7..abbf0edcf6c2 100644 > > > --- a/net/ipv4/tcp_diag.c > > > +++ b/net/ipv4/tcp_diag.c > > [...] > > > +static int tcp_diag_get_aux(struct sock *sk, bool net_admin, > > > + struct sk_buff *skb) > > > +{ > > > +#ifdef CONFIG_TCP_MD5SIG > > > + if (net_admin) { > > > > In tcp_diag_get_aux_size() you put a check for sk_fullsock. I don't > > see anything preventing you from reaching this with a !fullsock? > > Currently handler->idiag_get_aux is only called from inet_sk_diag_fill > which has a `BUG_ON(!sk_fullsock(sk));`, but I could add another Oh, right, that's the part I was missing. Thanks. > explicit check in that function if you think it's more consistent. > > Actually, I wasn't sure when adding this idiag_get_aux in v2 if it > should be called from inet_twsk_diag_fill, inet_req_diag_fill and > inet_csk_diag_fill, or just the last one. I chose that simpler approach > for now to avoid duplicating these state checks in the idiag_get_aux > defined by protocols and because we didn't need for INET_DIAG_MD5SIG, > but it shouldn't be too hard to change. Do you think this could be > useful for other protocols or attributes? No opinion. It can be added later if necessary. -- Sabrina ^ permalink raw reply [flat|nested] 9+ messages in thread
* Re: [PATCH net-next v5 2/2] tcp_diag: report TCP MD5 signing keys and addresses 2017-08-31 16:59 ` [PATCH net-next v5 2/2] tcp_diag: report TCP MD5 signing keys and addresses Ivan Delalande 2017-08-31 23:26 ` Sabrina Dubroca @ 2017-09-01 2:58 ` Eric Dumazet 1 sibling, 0 replies; 9+ messages in thread From: Eric Dumazet @ 2017-09-01 2:58 UTC (permalink / raw) To: Ivan Delalande; +Cc: David Miller, netdev On Thu, 2017-08-31 at 09:59 -0700, Ivan Delalande wrote: > Report TCP MD5 (RFC2385) signing keys, addresses and address prefixes to > processes with CAP_NET_ADMIN requesting INET_DIAG_INFO. Currently it is > not possible to retrieve these from the kernel once they have been > configured on sockets. > > Signed-off-by: Ivan Delalande <colona@arista.com> > --- > include/uapi/linux/inet_diag.h | 1 + > include/uapi/linux/tcp.h | 9 ++++ > net/ipv4/tcp_diag.c | 109 ++++++++++++++++++++++++++++++++++++++--- > 3 files changed, 113 insertions(+), 6 deletions(-) Acked-by: Eric Dumazet <edumazet@google.com> ^ permalink raw reply [flat|nested] 9+ messages in thread
* Re: [PATCH net-next v5 0/2] report TCP MD5 signing keys and addresses 2017-08-31 16:59 [PATCH net-next v5 0/2] report TCP MD5 signing keys and addresses Ivan Delalande 2017-08-31 16:59 ` [PATCH net-next v5 1/2] inet_diag: allow protocols to provide additional data Ivan Delalande 2017-08-31 16:59 ` [PATCH net-next v5 2/2] tcp_diag: report TCP MD5 signing keys and addresses Ivan Delalande @ 2017-09-02 1:38 ` David Miller 2 siblings, 0 replies; 9+ messages in thread From: David Miller @ 2017-09-02 1:38 UTC (permalink / raw) To: colona; +Cc: eric.dumazet, netdev From: Ivan Delalande <colona@arista.com> Date: Thu, 31 Aug 2017 09:59:37 -0700 > Allow userspace to retrieve MD5 signature keys and addresses configured > on TCP sockets through inet_diag. ... Series applied to net-next, thanks. ^ permalink raw reply [flat|nested] 9+ messages in thread
end of thread, other threads:[~2017-09-02 1:39 UTC | newest] Thread overview: 9+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2017-08-31 16:59 [PATCH net-next v5 0/2] report TCP MD5 signing keys and addresses Ivan Delalande 2017-08-31 16:59 ` [PATCH net-next v5 1/2] inet_diag: allow protocols to provide additional data Ivan Delalande 2017-09-01 2:57 ` Eric Dumazet 2017-08-31 16:59 ` [PATCH net-next v5 2/2] tcp_diag: report TCP MD5 signing keys and addresses Ivan Delalande 2017-08-31 23:26 ` Sabrina Dubroca 2017-09-01 0:21 ` Ivan Delalande 2017-09-01 15:47 ` Sabrina Dubroca 2017-09-01 2:58 ` Eric Dumazet 2017-09-02 1:38 ` [PATCH net-next v5 0/2] " David Miller
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox