Function caller in linux kernel

前端 未结 4 1590
深忆病人
深忆病人 2021-01-30 03:26

Is there a way to get function caller in linux kernel? I know __func__ returns the function name which is executing. I am looking for the function whic

相关标签:
4条回答
  • 2021-01-30 04:03

    To get the caller function name, one can use the below printk command.

    printk("Caller is %pF\n", __builtin_return_address(0));

    0 讨论(0)
  • 2021-01-30 04:04

    You can also print the entire call stack contents by calling dump_stack().

    0 讨论(0)
  • 2021-01-30 04:06

    Whether or not frame pointers are needed depends on arch, IIRC. For x86, they are certainly desired to fully exploit these features. Also note that inlining can skew the accuracy of builtin_return_address for this very reason.

    If you just want a stack dump to see how some place was reached, better use the dump_stack() function than trying to fiddle around with builtin_return_address.

    0 讨论(0)
  • 2021-01-30 04:10

    You can get the caller with __builtin_return_address(0).

    The caller's caller is __builtin_return_address(1) and so on.

    It's a GCC extension, documented in the gcc manual: http://gcc.gnu.org/onlinedocs/gcc/Return-Address.html

    Edit: I should probably point out, that gets you the address of the caller. If you want the function name you can print it with %pS, eg:

    printk("Caller is %pS\n", __builtin_return_address(0));
    

    If you don't want to print it, you can use kallsyms_lookup() etc.

    0 讨论(0)
提交回复
热议问题