[PATCH][Resend] TIPC: Fix infinite loop in netlink handler

2007-06-23 Thread Florian Westphal
From: Florian Westphal [EMAIL PROTECTED]

The tipc netlink config handler uses the nlmsg_pid from the
request header as destination for its reply. If the application
initialized nlmsg_pid to 0, the reply is looped back to the kernel,
causing hangup. Fix: use nlmsg_pid of the skb that triggered the
request.

Signed-off-by: Florian Westphal [EMAIL PROTECTED]
---
I already sent this to netdev@ on the 19th, but the patch itself
was neither acked nor Nacked. This is a crash that can be
triggered trivially -- please fix this bug.

 net/tipc/netlink.c |2 +-
  1 files changed, 1 insertions(+), 1 deletions(-)

diff --git a/net/tipc/netlink.c b/net/tipc/netlink.c
index 4cdafa2..6a7f7b4 100644
--- a/net/tipc/netlink.c
+++ b/net/tipc/netlink.c
@@ -60,7 +60,7 @@ static int handle_cmd(struct sk_buff *skb, struct genl_info 
*info)
rep_nlh = nlmsg_hdr(rep_buf);
memcpy(rep_nlh, req_nlh, hdr_space);
rep_nlh-nlmsg_len = rep_buf-len;
-   genlmsg_unicast(rep_buf, req_nlh-nlmsg_pid);
+   genlmsg_unicast(rep_buf, NETLINK_CB(skb).pid);
}
 
return 0;
-
To unsubscribe from this list: send the line unsubscribe netdev in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html


Re: [PATCH][Resend] TIPC: Fix infinite loop in netlink handler

2007-06-23 Thread David Miller
From: Florian Westphal [EMAIL PROTECTED]
Date: Sat, 23 Jun 2007 20:25:46 +0200

 From: Florian Westphal [EMAIL PROTECTED]
 
 The tipc netlink config handler uses the nlmsg_pid from the
 request header as destination for its reply. If the application
 initialized nlmsg_pid to 0, the reply is looped back to the kernel,
 causing hangup. Fix: use nlmsg_pid of the skb that triggered the
 request.
 
 Signed-off-by: Florian Westphal [EMAIL PROTECTED]

I have this patch already, I'm just backlogged :-)

Please be patient.
-
To unsubscribe from this list: send the line unsubscribe netdev in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html