netdev.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* speaking of stacks
@ 2008-03-31 13:15 jamal
  2008-04-03 21:18 ` David Miller
  0 siblings, 1 reply; 6+ messages in thread
From: jamal @ 2008-03-31 13:15 UTC (permalink / raw)
  To: netdev; +Cc: Joern Engel, David Miller, Herbert Xu


All this talk about stacks got me thirsty.
Heres something thats a mystery to me; probably very basic
when doing static check analysis (kernel make checkstack)

I have ipsec turned on in the linus git tree kernel and
net/xfrm/xfrm_user.c::xfrm_get_policy() shows up as one of
the top offenders. Eyeballing reveals that
struct xfrm_policy seems to be the offender 
in the else {} after if (p->index) in that function.
That seems understandable - once variable "tmp" is declared it goes
on the stack and it is freakin huge. 
However, checkstack only seems to catch it if i have the
line "memset(&tmp, 0, sizeof(struct xfrm_policy))". If i remove
that line - even though tmp is on the stack - checkstack doesnt catch
it.

What gives?

----
hadi@lilsol:~$ gcc -v
Using built-in specs.
Target: i486-linux-gnu
Configured with: ../src/configure -v --enable-languages=c,c
++,fortran,objc,obj-c++,treelang --prefix=/usr --enable-shared
--with-system-zlib --libexecdir=/usr/lib --without-included-gettext
--enable-threads=posix --enable-nls --program-suffix=-4.1
--enable-__cxa_atexit --enable-clocale=gnu --enable-libstdcxx-debug
--enable-mpfr --with-tune=i686 --enable-checking=release i486-linux-gnu
Thread model: posix
gcc version 4.1.2 20061115 (prerelease) (Debian 4.1.1-21)
-----

Not a gcc guru by far.
Anyone interested, I can send you the .o before and after commenting
for your perusal.

cheers,
jamal


^ permalink raw reply	[flat|nested] 6+ messages in thread

end of thread, other threads:[~2008-04-04 22:31 UTC | newest]

Thread overview: 6+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2008-03-31 13:15 speaking of stacks jamal
2008-04-03 21:18 ` David Miller
2008-04-04 12:24   ` jamal
2008-04-04 12:32     ` Paul Moore
2008-04-04 12:41       ` jamal
2008-04-04 22:31         ` Paul Moore

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).