Date: Thu, 2 Dec 2010 10:39:44 +0000 (UTC) From: "Bjoern A. Zeeb" <bz@FreeBSD.org> To: cvs-src-old@freebsd.org Subject: cvs commit: src/sys/netinet6 in6.c nd6.c nd6_nbr.c Message-ID: <201012021039.oB2AdrAH093519@repoman.freebsd.org>
next in thread | raw e-mail | index | archive | help
bz 2010-12-02 10:39:44 UTC
FreeBSD src repository
Modified files: (Branch: RELENG_8)
sys/netinet6 in6.c nd6.c nd6_nbr.c
Log:
SVN rev 216118 on 2010-12-02 10:39:44Z by bz
MFC r216022:
Plug well observed races on la_hold entries with the callout handler.
Call the handler function with the lock held, return unlocked as we
might free the entry. Rework functions later in the call graph to be
either called with the lock held or, only if needed, unlocked.
Place asserts to document and tighten assumptions on various lle locking,
which were not always true before.
We call nd6_ns_output() unlocked and the assignment of ip6->ip6_src was
decentralized to minimize possible complexity introduced with the formerly
missing locking there. This also resulted in a push down of local
variable scopes into smaller blocks.
Reported by: many
Submitted by: Dmitrij Tejblum (tejblum yandex-team.ru) (original version)
Tested by: remko
PR: kern/148857
Approved by: re (kib)
Revision Changes Path
1.121.2.12 +3 -1 src/sys/netinet6/in6.c
1.123.2.14 +64 -38 src/sys/netinet6/nd6.c
1.69.2.5 +23 -19 src/sys/netinet6/nd6_nbr.c
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201012021039.oB2AdrAH093519>
