开发者

Any method to get the stack size of all functions in a file or a project in C language?

开发者 https://www.devze.com 2023-03-29 04:50 出处:网络
I want to get all function开发者_运维技巧s whose stack size is bigger than the assigned size, is there any easy method to suggest?

I want to get all function开发者_运维技巧s whose stack size is bigger than the assigned size, is there any easy method to suggest?

Get the .obj file, disassemble it, and then analyze the output file?


You can look at the assembly dump for each function. In gcc, you use the -S option.

Let's say you are interested in the function foo. Then, gcc mangles the function name to _foo. If you take a peek at the assembly, you should see, near the top of the function, an instruction to move the stack pointer. For example, in OSX you have something like:

_foo:
    ...
    movq %rsp, %rbp
    ...
    subq $48, %rsp

That number, $48, is the stack size.

Alternatively, you can look for the equivalent command using nm to find the address where the function starts, ndisasm to give you a human readable dump, and then scanning for the where the stack pointer is moved.


Outside of embedded computing, infinite recursion is much more likely culprit in stack overflow than any particular call.

That being said, in the first approximation, look for locally-allocated arrays:

void foo() {
    ...
    char buffer[1024] = "";
    ...
}

Also, don't forget alloca() call - it dynamically allocates space on the stack the same way malloc() allocates it on the heap.

0

精彩评论

暂无评论...
验证码 换一张
取 消