Skip site navigation (1)Skip section navigation (2)
Date:      Fri, 28 Dec 2007 12:45:51 +0200
From:      Stefan Lambrev <stefan.lambrev@moneybookers.com>
To:        Attila Nagy <bra@fsn.hu>
Cc:        current@freebsd.org
Subject:   Re: rtfree: 0xc5caad98 has 2 refs
Message-ID:  <4774D3DF.90802@moneybookers.com>
In-Reply-To: <4774C7A4.5070303@fsn.hu>
References:  <4774C7A4.5070303@fsn.hu>

next in thread | previous in thread | raw e-mail | index | archive | help
Hi Attila,

Attila Nagy wrote:
> Hello,
>
> I have an i386 7.0-PRERELEASE #12: Thu Dec 27 17:46:49 CET 2007, with 
> an em and two fxp interfaces in an IPv4-only setup with some jails and 
> a pf route-to (if that counts) line.
>
> The machine itself runs some mail related stuff (postfix, cyrus, 
> openldap, etc) on a ZFS pool.
>
> The problem is with the default kernel I get tons of similar messages:
> Dec 27 12:38:40 artax kernel: rtfree: 0xc5caad98 has 1 refs
> Dec 27 12:39:03 artax last message repeated 24 times
> Dec 27 12:39:03 artax kernel: rtfree: 0xc5caad98 has 2 refs
> Dec 27 12:39:03 artax kernel: rtfree: 0xc5caad98 has 1 refs
> Dec 27 12:39:04 artax last message repeated 64 times
> Dec 27 12:39:04 artax kernel: rtfree: 0
> Dec 27 12:39:04 artax kernel: xc5caad98 has 1 refs
> Dec 27 12:39:04 artax kernel:
> Dec 27 12:39:04 artax kernel: rtfree: 0xc5caad98
> Dec 27 12:39:04 artax kernel: has 1 refs
> Dec 27 12:39:04 artax kernel:
> Dec 27 12:39:04 artax kernel: rtfree: 0xc5caad98 has 1 refs
> Dec 27 12:39:04 artax kernel:
> Dec 27 12:39:04 artax kernel: rtfree: 0xc5caad98 h
> Dec 27 12:39:04 artax kernel: s 1 refs
> Dec 27 12:39:04 artax kernel:
> Dec 27 12:39:04 artax kernel: rtfree
> Dec 27 12:39:04 artax kernel: 0xc5caad98 has 1 refs
>
> Besides these messages fill up the logs and are annoying, the machine 
> crashes minutes after it has been started.
> I found out that replacing rtfree() calls in the kernel to 
> RTFREE_LOCKED() not only makes the above messages disappear, but helps 
> the machine to survive and run for days.
Look at this: http://www.freebsd.org/cgi/query-pr.cgi?pr=117913
>
> The only places where there are plain rtfree calls are in the kernel 
> (and where I've replaced them to RTFREE_LOCKED):
> net/route.c
> netinet/if_ether.c
> netinet6/nd6_nbr.c
> netinet6/in6_ifattach.c
> netinet6/in6_gif.c
>
> Question: is the above approach right and if it is, do anyone care to 
> make this replacement?
>
> BTW, how could I find out what causes these?
If it's not a production server and/or you can afford downtime add 
kbd_backtrace() to rtfree (in src/sys/net/route.c)
and you will see what cause the problem in your case.





Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?4774D3DF.90802>