diff options
author | Eric Sandeen <sandeen@redhat.com> | 2008-07-25 04:45:27 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2008-07-25 13:53:26 -0400 |
commit | 585e93ae83b80c874bf4eb50a239027cef5db4af (patch) | |
tree | b4564c31f5f731f5491fa145fd9ff52c297b6101 | |
parent | 545e400619b24b6b17b7f1f1e838e9ff6d036949 (diff) |
find dynamic stack allocations in checkstack.pl
Currently, checkstack.pl only looks for fixed subtractions from the stack
pointer. However, things like this:
void function(int size)
{
char stackbuster[size << 2];
...
are certainly worth pointing out, I think.
This could perhaps be done more cleanly, and the following patch only
adds "dynamic" REs for x86 and x86_64, but it works:
0x00b0 crypto_cbc_decrypt_inplace [cbc]: Dynamic (%rax)
0x00ad crypto_pcbc_decrypt_inplace [pcbc]: Dynamic (%rax)
0x02f6 crypto_pcbc_encrypt_inplace [pcbc]: Dynamic (%rax)
0x036c _crypto_xcbc_digest_setkey [xcbc]: Dynamic (%rax)
...
(Inspired by Keith Owens' old stack-check script)
Signed-off-by: Eric Sandeen <sandeen@redhat.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
-rwxr-xr-x | scripts/checkstack.pl | 24 |
1 files changed, 23 insertions, 1 deletions
diff --git a/scripts/checkstack.pl b/scripts/checkstack.pl index 340ad6920511..358f96c75b43 100755 --- a/scripts/checkstack.pl +++ b/scripts/checkstack.pl | |||
@@ -26,8 +26,12 @@ | |||
26 | # $& (whole re) matches the complete objdump line with the stack growth | 26 | # $& (whole re) matches the complete objdump line with the stack growth |
27 | # $1 (first bracket) matches the size of the stack growth | 27 | # $1 (first bracket) matches the size of the stack growth |
28 | # | 28 | # |
29 | # $dre is similar, but for dynamic stack redutions: | ||
30 | # $& (whole re) matches the complete objdump line with the stack growth | ||
31 | # $1 (first bracket) matches the dynamic amount of the stack growth | ||
32 | # | ||
29 | # use anything else and feel the pain ;) | 33 | # use anything else and feel the pain ;) |
30 | my (@stack, $re, $x, $xs); | 34 | my (@stack, $re, $dre, $x, $xs); |
31 | { | 35 | { |
32 | my $arch = shift; | 36 | my $arch = shift; |
33 | if ($arch eq "") { | 37 | if ($arch eq "") { |
@@ -46,9 +50,11 @@ my (@stack, $re, $x, $xs); | |||
46 | } elsif ($arch =~ /^i[3456]86$/) { | 50 | } elsif ($arch =~ /^i[3456]86$/) { |
47 | #c0105234: 81 ec ac 05 00 00 sub $0x5ac,%esp | 51 | #c0105234: 81 ec ac 05 00 00 sub $0x5ac,%esp |
48 | $re = qr/^.*[as][du][db] \$(0x$x{1,8}),\%esp$/o; | 52 | $re = qr/^.*[as][du][db] \$(0x$x{1,8}),\%esp$/o; |
53 | $dre = qr/^.*[as][du][db] (%.*),\%esp$/o; | ||
49 | } elsif ($arch eq 'x86_64') { | 54 | } elsif ($arch eq 'x86_64') { |
50 | # 2f60: 48 81 ec e8 05 00 00 sub $0x5e8,%rsp | 55 | # 2f60: 48 81 ec e8 05 00 00 sub $0x5e8,%rsp |
51 | $re = qr/^.*[as][du][db] \$(0x$x{1,8}),\%rsp$/o; | 56 | $re = qr/^.*[as][du][db] \$(0x$x{1,8}),\%rsp$/o; |
57 | $dre = qr/^.*[as][du][db] (\%.*),\%rsp$/o; | ||
52 | } elsif ($arch eq 'ia64') { | 58 | } elsif ($arch eq 'ia64') { |
53 | #e0000000044011fc: 01 0f fc 8c adds r12=-384,r12 | 59 | #e0000000044011fc: 01 0f fc 8c adds r12=-384,r12 |
54 | $re = qr/.*adds.*r12=-(([0-9]{2}|[3-9])[0-9]{2}),r12/o; | 60 | $re = qr/.*adds.*r12=-(([0-9]{2}|[3-9])[0-9]{2}),r12/o; |
@@ -141,6 +147,22 @@ while (my $line = <STDIN>) { | |||
141 | next if ($size < 100); | 147 | next if ($size < 100); |
142 | push @stack, "$intro$size\n"; | 148 | push @stack, "$intro$size\n"; |
143 | } | 149 | } |
150 | elsif (defined $dre && $line =~ m/$dre/) { | ||
151 | my $size = "Dynamic ($1)"; | ||
152 | |||
153 | next if $line !~ m/^($xs*)/; | ||
154 | my $addr = $1; | ||
155 | $addr =~ s/ /0/g; | ||
156 | $addr = "0x$addr"; | ||
157 | |||
158 | my $intro = "$addr $func [$file]:"; | ||
159 | my $padlen = 56 - length($intro); | ||
160 | while ($padlen > 0) { | ||
161 | $intro .= ' '; | ||
162 | $padlen -= 8; | ||
163 | } | ||
164 | push @stack, "$intro$size\n"; | ||
165 | } | ||
144 | } | 166 | } |
145 | 167 | ||
146 | print sort bysize @stack; | 168 | print sort bysize @stack; |