linux 内核printk使用记录

linux5.10 内核printk使用记录

打印函数名

// 使用, 对于pF 废弃了
printk("%s:  %ps\n", __func__, func);

// 内核函数位置:
// lib/vsprintf.c line:2214
/*
'[Ff]' %pf and %pF were obsoleted and later removed in favor of
 *	    %ps and %pS. Be careful when re-using these specifiers.
*/
static noinline_for_stack
char *pointer(const char *fmt, char *buf, char *end, void *ptr,
	      struct printf_spec spec)
{	
	switch (*fmt) {
	case 'S':
	case 's':
		ptr = dereference_symbol_descriptor(ptr);
		/* fall through */
		case 'B':
		return symbol_string(buf, end, ptr, spec, fmt);
	....
	}
}

在内核文档 Documentation/core-api/printk-formats.rst 中查看

Symbols/Function Pointers
-------------------------

::

	%pS	versatile_init+0x0/0x110
	%ps	versatile_init
	%pSR	versatile_init+0x9/0x110
		(with __builtin_extract_return_addr() translation)
	%pB	prev_fn_of_versatile_init+0x88/0x88


The ``S`` and ``s`` specifiers are used for printing a pointer in symbolic
format. They result in the symbol name with (S) or without (s)
offsets. If KALLSYMS are disabled then the symbol address is printed instead.

需要内核开启KALLSYMS, 查看编译选项

cat /boot/config-`uname -r` | grep CONFIG_KALLSYMS

linux下自带的nm分析工具,可以用来分析二进制文件、库文件、可执行文件中的符号表,返回二进制文件中各段的信息。
在这里插入图片描述
内核关闭随机化

cat /proc/sys/kernel/randomize_va_space
# 0: 关闭# 1: 半随机 # 2: 全随机
sudo sysctl -w kernel.randomize_va_space=0
其他方法
  • WARN_ON(condition) 在括号中的条件成立的时候,内核会抛出栈回溯,但是不会panic() , 可以作为一个调试技巧, 了解函数的调用关系
  • dump_stack() 函数,能够用来回溯打印调用栈信息。oops 时打印的栈回溯调用信息也是通过调用此函数来完成的
  • backtrace() 获取当前线程的调用堆栈
#include<stdio.h>
#include<execinfo.h>

void func1(){}

int main()
{
    void *func = func1; //注意这里必须转化为一个void *指针
    backtrace_symbols_fd(&func, 1, 1); 
    return 0;
}

在这里插入图片描述

参考

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值