Linux-4.7.1添加自定义的系统调用的完整过程

参考的文章
//www.greatytc.com/p/b2d5fa8af581
https://blog.csdn.net/bboxhe/article/details/50011899#commentBox
https://medium.com/@ssreehari/implementing-a-system-call-in-linux-kernel-4-7-1-6f98250a8c38(最后一个可能因为DNS问题连不上)

下载与放置内核源代码

在清华开源镜像网站https://mirrors.tuna.tsinghua.edu.cn/kernel/v4.x/ 下载Linux内核源代码

下载橙色高亮的

将下载后的压缩包解压后的文件夹放入/usr/src/,在Ubuntu里解压可以用鼠标右键选择,然后sudo cp -r Linux-4.7.1 /usr/src/,为了后面的操作方便,可以创建软链接,以后就可以用Linux文件夹名访问Linux-4.7.1文件夹里的内容

sudo -i
cd /usr/src
ln -s Linux-4.7.1 Linux

后面所有的操作都在/usr/src/Linux文件夹里面,所有的操作都要在root用户下。

添加系统调用

1. 添加系统调用号

vim arch/x86/entry/syscalls/syscall_64.tbl,添加如下内容,前面的号码要在表里唯一(可能需要修改)。

327     64      hello                   sys_hello
328     64      listProc                sys_listProc

2. 定义系统调用函数

  • /usr/src/Linux/文件夹里创建两个文件hello和listProc,mkdir hello listProc
  • 在hello文件夹中创建三个文件Makefile, hello.c hello.h
  • 在Makefile文件添加如下内容后保存
ifneq ($(KERNELRELEASE),)
obj-y:=hello.o
else
KDIR := /lib/modules/4.7.1/  //这里可能要第一次编译后才会有对应内核版本的文件夹
PWD:=$(shell pwd)
all:
    make -C $(KDIR) M=$(PWD) modules
clean:
    rm -f *.ko *.o *.symvers *.cmd *.cmd.o
endif
  • 在hello.c文件添加如下内容后保存
#include<linux/kernel.h>
#include<linux/init.h>
#include<linux/sched.h>
#include<linux/syscalls.h>
#include<linux/linkage.h>
#include "hello.h"
asmlinkage long sys_hello(long __user n) {
    printk("Hello!This is a system call!\n");
    return n;
}
  • 在hello.h文件添加如下内容后保存
asmlinkage long sys_hello(long __user n);

另一个系统调用的添加步骤与输出一行语句的系统调用类似。

  • 在listProc文件夹中创建三个文件Makefile, listProc.c listProc.h
  • 在Makefile文件添加如下内容后保存
ifneq ($(KERNELRELEASE),)
obj-y:=listProc.o
else
KDIR := /lib/modules/4.7.1/  //这里可能要第一次编译后才会有对应内核版本的文件夹
PWD:=$(shell pwd)
all:
    make -C $(KDIR) M=$(PWD) modules
clean:
    rm -f *.ko *.o *.symvers *.cmd *.cmd.o
endif
#include<linux/kernel.h>
#include<linux/init.h>
#include<linux/sched.h>
#include<linux/syscalls.h>
#include<linux/linkage.h>
#include "listProc.h"
asmlinkage long sys_listProc(void) {
    struct task_struct *proces;
    for_each_process(proces) {
    printk(
      "Process: %s\n \
       PID_Number: %ld\n \
       Process State: %ld\n \
       Priority: %ld\n \
       RT_Priority: %ld\n \
       Static Priority: %ld\n \
       Normal Priority: %ld\n", \
       proces->comm, \
       (long)task_pid_nr(proces), \
       (long)proces->state, \
       (long)proces->prio, \
       (long)proces->rt_priority, \
       (long)proces->static_prio, \
       (long)proces->normal_prio \
    );
   if(proces->parent) 
      printk(
        "Parent process: %s, \
         PID_Number: %ld", \
         proces->parent->comm, \
         (long)task_pid_nr(proces->parent) \
      );
   printk("\n\n");
  }
  return 0;
}
  • 在listProc.h文件添加如下内容后保存
asmlinkage long sys_listProc(void);

3. 把自定义的系统调用加入Linux-4.7.1内核的编译

终端输入vim /usr/src/Linux/Makefile,找到下面这行
core-y += kernel/ certs/ mm/ fs/ ipc/ security/ crypto/ block/
将其改成
core-y += kernel/ certs/ mm/ fs/ ipc/ security/ crypto/ block/ hello/ lisrProc/
保存

4. 内核编译加速

下载ccache:sudo apt install ccache缓存编译的内容
vim /usr/src/Linux/Makefile,修改两处
HOSTCC = gcc改成HOSTCC = ccache gcc
CC = $(CROSS_COMPILE)gcc改成CC =ccache $(CROSS_COMPILE)gcc
保存

5. 编译内核并选择内核重启

按照下面的顺序输入,错了一步基本要重新开始,make menuconfigmake localmodconfig二选一进行,前者是图形化选择编译模块,后者是仅编译当前内核已加载的模块,后者会快很多很多。

sudo -i
cd /usr/src/Linux
make mrproper
make clean
make menuconfig //这个可以极快编译,但修改不了内核名字:make localmodconfig
make -j4 bzImage
make -j4 modules
make -j4 modules_install
make -j4 install
update-grub
reboot

几个注意事项:

  • 终端窗口要足够大,否则make menuconfig无法显示,会报错。
  • 在VMware虚拟机重启时,在输入reboot回车的同时,按住shift键直到开机,因为grub2不知道什么原因改了内核启动顺序却不按顺序启动。按住shift开机后选择4.7.1内核启动。

6. 验证系统调用

#include<stdio.h>
#include<signal.h>
#include<../unistd.h>
#include<linux/kernel.h>
#include<sys/syscall.h>
#include<sys/types.h>
int main(){
    long ret=0;
    ret=syscall(327,2);
    printf("ret = %ld\n",ret);
    ret=syscall(328);
    printf("ret = %ld\n",ret);
    return 0;
}

dmesg -C清空日志后,编译并运行上面的程序,再通过dmesg查看内核日志,可以检查系统调用是否成功。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 211,561评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,218评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,162评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,470评论 1 283
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,550评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,806评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,951评论 3 407
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,712评论 0 266
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,166评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,510评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,643评论 1 340
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,306评论 4 330
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,930评论 3 313
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,745评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,983评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,351评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,509评论 2 348