linux vm_area_struct,Linux内核编程:试图让vm_area_struct-> vm_start崩溃内核

这是在学校的作业,我需要使用系统调用确定系统上的进程大小.我的代码如下:

...

struct task_struct *p;

struct vm_area_struct *v;

struct mm_struct *m;

read_lock(&tasklist_lock);

for_each_process(p) {

printk("%ld\n", p->pid);

m = p->mm;

v = m->mmap;

long start = v->vm_start;

printk("vm_start is %ld\n", start);

}

read_unlock(&tasklist_lock);

...

当我运行调用此系统调用的用户级程序时,我得到的输出是:

1

vm_start是134512640

2

EIP:0073:[<0806e352>] CPU:0未受污染ESP:007b:0f7ecf04 EFLAGS:00010246未受污染

EAX:00000000 EBX:0fc587c0 ECX:081fbb58 EDX:00000000

ESI:bf88efe0 EDI:0f482284 EBP:0f7ecf10 DS:007b ES: 007b

081f9bc0:[<08069ae8>] show_regs + 0xb4/

0xb9 081f9bec:[<080587ac>] segv + 0x225/0x23d

081f9c8c:[<08058582>] segv_handler + 0x4f/0x54

081f9cac:[<08067453>] sig_handler_common_skas + 0xb7/0xd4

081f9cd4 :[<08064748>] sig_handler + 0x34/0×44

081f9cec:[<080648b5>] handle_signal + 0x4c/0x7a

081f9d0c:[<08066227>] hard_handler + 0xf/0×14

081f9d1c:[<00776420>] 0x776420

内核恐慌-不同步:内核于地址为0x0模式故障,IP 0x806e352

EIP:0073:[<400ea0f2>] CPU:0未污染ESP:007B:bf88ef9c EFLAGS:00000246不被污染

EAX:ffffffda EBX:00000000 ECX:bf88efc8 EDX:080483c8

ESI:00000000 EDI:bf88efe0 EBP:bf88f038 DS:007b ES:007b

081f9b28:[<08069ae8>] show_regs + 0xb4/

0xb9 081f9b54:[<08058a1a>] panic_exit + 0x25/0x3f

081f9b68:[<08084f54>] notifier_call_chain + 0x21/0x46

081f9b88:[<08084fef > ] __atomic_notifier_call_chain + 0×17/0x19

081f9ba4:[<08085006>] atomic_notifier_call_chain + 0×15/0×17

081f9bc0:[<0807039a>]恐慌+ 0×52/0xd8

081f9be0:[<080587ba>] SEGV + 0x233/0x23d

081f9c8c:[<08058582>] segv_handler + 0x4f/0x54

081f9cac:[<08067453>] sig_handler_common_skas + 0xb7/0xd4

081f9cd4:[<08064748>] sig_handler + 0x34/

0x44 081f9cec:[<080648b5>] handle_signal + 0x4c/0x7a

081f9d0c:[<08066227>] hard_handler + 0xf/0x14

081f9d1c:[<00776420>] 0x776420

第一个进程(pid = 1)给了我vm_start没有任何问题,但是当我尝试访问第二个进程时,内核崩溃了.任何人都可以告诉我什么是错的,也许还有如何解决它?非常感谢!

(抱歉格式不好......)

编辑:这是在uml环境中的Fedora 2.6内核中完成的.

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值