1

我正在尝试编写一个必须从进程中读取 vm 区域地址的 LKM。我正在使用 pid_task() 来获取指向 task_struct 的指针,但是当我尝试使用它来获取 vmarea 的起始地址时出现编译错误。

struct task_struct *ts;
ts = pid_task(find_vpid(pid_t)pid,PIDTYPE_PID);
printk(KERN_INFO "%lu",ts->mm->mmap->start);

我收到错误“错误:取消引用指向不完整类型的指针”

我是一个 Linux 菜鸟,在 LKM 中完全是菜鸟。

我会很感激任何帮助。

谢谢你们

4

1 回答 1

0

我用以下代码对我的内核源代码树(2.6.35)进行了测试,编译正常:

struct task_struct *ts;
pid_t pid;

ts = pid_task(find_vpid(pid),PIDTYPE_PID);
printk(KERN_INFO "%lu",ts->mm->mmap->vm_start);

您可以尝试在内核源代码树中使用上述代码吗?我想也许你必须包含所有需要的头文件,例如:

#include <asm/uaccess.h>
#include <linux/errno.h>
#include <linux/time.h>
#include <linux/proc_fs.h>
#include <linux/stat.h>
#include <linux/init.h>
#include <linux/capability.h>
#include <linux/file.h>
#include <linux/fdtable.h>
#include <linux/string.h>
#include <linux/namei.h>
#include <linux/mnt_namespace.h>
#include <linux/mm.h>
#include <linux/swap.h>
#include <linux/rcupdate.h>
#include <linux/kallsyms.h>
#include <linux/stacktrace.h>
#include <linux/resource.h>
#include <linux/module.h>
#include <linux/mount.h>
#include <linux/security.h>
#include <linux/ptrace.h>
#include <linux/tracehook.h>
#include <linux/cgroup.h>
#include <linux/cpuset.h>
#include <linux/audit.h>
#include <linux/poll.h>
#include <linux/nsproxy.h>
#include <linux/oom.h>
#include <linux/elf.h>
#include <linux/pid_namespace.h>
#include <linux/fs_struct.h>

其他:

编译成功后,判断指针是否为NULL。

于 2013-03-13T04:32:31.493 回答