In article <[email protected]>,
 <[email protected]> wrote:
>dmesg reports in loger intervals:
>
>nd6_storelladdr: something odd happens
>
>I do not know if this is the cause for the TIME_WAIT connections or a 
>consequence of TIME_WAIT connections.
>

Ok, I've been debugging memory initializations issues with link
layer sockets and ipv6 and I committed the following at HEAD which
fixes the problem for me:

Index: route.c
===================================================================
RCS file: /cvsroot/src/sys/net/route.c,v
retrieving revision 1.132
retrieving revision 1.134
diff -u -r1.132 -r1.134
--- route.c     6 Jun 2014 01:27:32 -0000       1.132
+++ route.c     2 Dec 2014 19:57:11 -0000       1.134
@@ -857,7 +841,7 @@
                sockaddr_free(rt->rt_gateway);
        KASSERT(rt->_rt_key != NULL);
        RT_DPRINTF("rt->_rt_key = %p\n", (void *)rt->_rt_key);
-       if ((rt->rt_gateway = sockaddr_dup(gate, M_NOWAIT)) == NULL)
+       if ((rt->rt_gateway = sockaddr_dup(gate, M_ZERO | M_NOWAIT)) == NULL)
                return ENOMEM;
        KASSERT(rt->_rt_key != NULL);
        RT_DPRINTF("rt->_rt_key = %p\n", (void *)rt->_rt_key);
@@ -1346,7 +1330,7 @@
 
        KASSERT(ro->_ro_rt == NULL);
 
-       if ((ro->ro_sa = sockaddr_dup(sa, M_NOWAIT)) == NULL) {
+       if ((ro->ro_sa = sockaddr_dup(sa, M_ZERO | M_NOWAIT)) == NULL) {
                rtcache_invariants(ro);
                return ENOMEM;
        }
@@ -1360,7 +1344,7 @@
        if (rt->rt_tag != tag) {
                if (rt->rt_tag != NULL)
                        sockaddr_free(rt->rt_tag);
-               rt->rt_tag = sockaddr_dup(tag, M_NOWAIT);
+               rt->rt_tag = sockaddr_dup(tag, M_ZERO | M_NOWAIT);
        }
        return rt->rt_tag; 
 }

Can you try this and see if you see the problem anymore?

Thanks,

christos

Reply via email to