获取内核函数地址的方法

本文详细介绍了在Linux系统中获取内核函数sys_open地址的不同途径,包括从System.map、使用nm命令、/proc/kallsyms文件以及通过kallsyms_lookup_name函数,后者的使用需内核支持CONFIG_KALLSYMS。
摘要由CSDN通过智能技术生成

本文以获取内核函数 sys_open()的地址为例。
   1)从System.map文件中直接得到地址
      $ grep "sys_open" System.map
   
   2) 使用 nm 命令
      $ nm vmlinux | grep "sys_open"
   
   3) 从 /proc/kallsyms 文件获得地址
      $ cat /proc/kallsyms | grep "sys_open"
   
   4) 使用 kallsyms_lookup_name() 函数
      是在kernel/kallsyms.c文件中定义的,要使用它必须启用CONFIG_KALLSYMS编译内核。
      kallsyms_lookup_name()接受一个字符串格式内核函数名,返回那个内核函数的地址。
        kallsyms_lookup_name("sys_open");

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值