Android 中用内核模块实现系统调用(Implement system call by kernel module in Android)

给学生设计实验,要在ANDROID中实现一个系统调用,不停的调试烧写太费时间,所以想到了用内核模块来实现系统调用,方法如下:

在System.map中找到sys_call_table的地址,然后后用如下代码直接进行系统调用:

#include<linux/kernel.h>
#include<linux/module.h>
#include<linux/sched.h>
#include<asm/uaccess.h>
#include<linux/compiler.h>
#include<linux/linkage.h>
#include<linux/types.h>
#include<linux/unistd.h>

#define __NR_memboundary 378
#define SYS_CALL_TB 0xc000e5a8 //sys_call_table地址

unsigned long *sys_call_table = (unsigned long*)SYS_CALL_TB;

asmlinkage long sys_memboundary(void){
        printk(KERN_ALERT"===============The syscall print out!!!!\n");
        return 0;
}

int __init init_addsyscall(void)
{
//      sys_call_table = (unsigned long *)sys_call_table_address;
        sys_call_table[__NR_memboundary] = (unsigned long)sys_memboundary;
        printk("@@@@@@@System call module loaded\n");
        return 0;
}

void __exit exit_addsyscall(void)
{
        printk("@@@@@@@System call unlodaded\n");
}

module_init(init_addsyscall);
module_exit(exit_addsyscall);
MODULE_LICENSE("GPL");
~                        


Android 中用内核模块实现系统调用(Implement system call by kernel module in Android),,5-wow.com

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。