linux内核探索--基于proc实现内核和用户态通信

简介: 基于proc实现内核和用户态通信

目录

1、编写proc文件

2、编写配套的Makefile

3、测试


要求:实现一个proc文件,一个只读文件output,一个可写文件input;功能是:向input文件写入字符串后,可以从output文件中,读出input文件中反转后的字符串


1、编写proc文件

vim my_proc.c

#include <linux/module.h>
#include <linux/init.h>
#include <linux/kernel.h> 
#include <linux/proc_fs.h>
#include <linux/uaccess.h>
#include <linux/slab.h>
#define BUFSIZE  1024
static struct proc_dir_entry *input, *output;
static char *buf;
static unsigned int len;
void reverse(void)
{
  int i = 0;
  int j = len - 2;
  printk("in reverse = %u\n", len);
  while(i < j)
  {
    char c;
    c = buf[i];
    buf[i++] = buf[j];
    buf[j--] = c;
  }
}
static ssize_t mywrite(struct file *file, const char __user *ubuf,size_t count, loff_t *ppos) 
{
  if(count <= 0)
    return -EFAULT;
  printk("---start write---\n");
  len = count > BUFSIZE ? BUFSIZE : count;
  // kfree memory by kmalloc before
  if(buf != NULL)
    kfree(buf);
  buf = (char*)kmalloc(len+1, GFP_KERNEL);
  if(buf == NULL)
  {
    printk("kmalloc failure\n");
    return -EFAULT;
  }
  //memset(buf, 0, sizeof(buf));
  memset(buf, 0, len+1);
  if(copy_from_user(buf, ubuf, len))
    return -EFAULT;
  printk("writing :%s",buf);
  return len;
}
static ssize_t myread(struct file *file, char __user *ubuf,size_t count, loff_t *ppos) 
{
  if(*ppos > 0)
    return 0;
  printk("---start read---\n");
  printk("origin = %s\n", buf);
  reverse();
  printk("after = %s\n", buf);
  if(copy_to_user(ubuf, buf, len))
    return -EFAULT;
  *ppos = *ppos + len;
  return len;
}
static struct file_operations fo_input = 
{
  .owner = THIS_MODULE,
  .write = mywrite,
};
static struct file_operations fo_output = 
{
  .owner = THIS_MODULE,
  .read = myread,
};
static int proc_init(void)
{
  input=proc_create("input",0660,NULL,&fo_input);
  if(input == NULL)
    return -ENOMEM;
  output=proc_create("output",0660,NULL,&fo_output);
  if(output == NULL)
    return -ENOMEM;
  printk("input & ouput init success!\n");
  return 0;
}
static void proc_cleanup(void)
{
  proc_remove(input);
  proc_remove(output);
  printk("input & output cleanup\n");
}
module_init(proc_init);
module_exit(proc_cleanup);
MODULE_LICENSE("GPL");

image.gif

2、编写配套的Makefile

vim Makefile:

obj-m += my_proc.o
all:
  make -C /lib/modules/$(shell uname -r)/build M=$(PWD) modules
clean:
  make -C /lib/modules/$(shell uname -r)/build M=$(PWD) clean

image.gif

3、测试

make 编译一下

如下

make -C /lib/modules/4.18.11/build M=/home/zj/neihe/proc_module_making/my_proc clean

make[1]: 正在进入目录 `/usr/src/linux-4.18.11'

 CLEAN   /home/zj/neihe/proc_module_making/my_proc/.tmp_versions

 CLEAN   /home/zj/neihe/proc_module_making/my_proc/Module.symvers

make[1]:正在离开目录 `/usr/src/linux-4.18.11'

如果觉得文章对你有帮助,欢迎关注微信公众号:小牛呼噜噜

然后sudo su 切换的root用户下

ls /proc/

发现多了2个文件:input ,output

ehco "test" >> /proc/input

cat /proc/input

打印:tset

ps:dmesg

image.png

内核探索暂时先到这里,先告一段落= =

相关文章
|
2月前
|
安全 网络协议 Linux
深入理解Linux内核模块:加载机制、参数传递与实战开发
本文深入解析了Linux内核模块的加载机制、参数传递方式及实战开发技巧。内容涵盖模块基础概念、加载与卸载流程、生命周期管理、参数配置方法,并通过“Hello World”模块和字符设备驱动实例,带领读者逐步掌握模块开发技能。同时,介绍了调试手段、常见问题排查、开发规范及高级特性,如内核线程、模块间通信与性能优化策略。适合希望深入理解Linux内核机制、提升系统编程能力的技术人员阅读与实践。
232 1
|
2月前
|
Ubuntu Linux
Ubuntu 23.04 用上 Linux 6.2 内核,预计下放到 22.04 LTS 版本
Linux 6.2 带来了多项内容更新,修复了 AMD 锐龙处理器设备在启用 fTPM 后的运行卡顿问题,还增强了文件系统。
|
2月前
|
Ubuntu Linux
Ubuntu 23.10 现在由Linux内核6.3提供支持
如果你想在你的个人电脑上测试一下Ubuntu 23.10的最新开发快照,你可以从官方下载服务器下载最新的每日构建ISO。然而,请记住,这是一个预发布版本,所以不要在生产机器上使用或安装它。
|
2月前
|
监控 Ubuntu Linux
什么Linux,Linux内核及Linux操作系统
上面只是简单的介绍了一下Linux操作系统的几个核心组件,其实Linux的整体架构要复杂的多。单纯从Linux内核的角度,它要管理CPU、内存、网卡、硬盘和输入输出等设备,因此内核本身分为进程调度,内存管理,虚拟文件系统,网络接口等4个核心子系统。
209 0
|
2月前
|
Web App开发 缓存 Rust
|
2月前
|
Ubuntu 安全 Linux
Ubuntu 发行版更新 Linux 内核,修复 17 个安全漏洞
本地攻击者可以利用上述漏洞,攻击 Ubuntu 22.10、Ubuntu 22.04、Ubuntu 20.04 LTS 发行版,导致拒绝服务(系统崩溃)或执行任意代码。
|
存储 Linux
Linux的Proc文件系统详解
Linux系统上的/proc目录是一种文件系统,即proc文件系统。与其它常见的文件系统不同的是,/proc是一种伪文件系统(也即虚拟文件系 统),存储的是当前内核运行状态的一系列特殊文件,用户可以通过这些文件查看有关系统硬件及当前正在运行进程的信息,甚至可以通过更改其中某些文件来改变 内核的运行状态。
1122 0