Linux嵌入式 -- 内核 - proc文件系统
1. 什么是proc文件系统?
实例:通过 /proc/meminfo,查询当前内存使用情况。
结论:proc文件系统是一种在用户态检查内核状态的机制。
2.Proc文件分类
特点
每个文件都规定了严格的权限可读?可写?哪个用户可读?哪个用户可写?
可以用文本编辑程序读取(more命令,cat命令,vi程序等等)
不仅可以有文件,还可以有子目录。
可以自己编写内核程序添加一个/proc目录下的文件。
文件的内容都是动态创建的,并不存在于磁盘上,存在内存中。
3. 功能函数
内核描述
struct proc_dir_entry{
{
。。 。。。。。。。。。。。。。。。。。
read_proc_t *read_proc;
write_proc_t *write_proc;
。。。。。。。。。。。。。。。。。。。
}
创建文件
struct proc_dir_entry* create_proc_entry (const char *name,mode_t mode,struct proc_dir_entry *parent)
功能:创建proc文件
参数:
name:要创建的文件名
mode:要创建的文件的属性 默认0755
parent:这个文件的父目录
创建目录
struct proc_dir_entry * proc_mkdir (const char *name,struct proc_dir_entry *parent)
功能:创建proc目录
参数:
name:要创建的目录名
parent:这个目录的父目录
删除目录/文件
void remove_proc_entry (const char *name,struct proc_dir_entry *parent)
功能:删除proc目录或文件
参数:
name:要删除的文件或目录名
parent:所在的父目录
读写 为了能让用户读写添加的proc文件,需要挂接上读写回调函数: read_proc 和 write_proc
读操作
int read_func (char *buffer,char**stat,off_t off,int count,int *peof,void *data)
参数:
buffer:把要返回给用户的信息写在buffer里,最大不超过PAGE_SIZE
stat:一般不使用
off:偏移量
count:用户要取的字节数
peof:读到文件尾时,需要把*peof置1
data:一般不使用
写操作
int write_func (struct file*file,const char *buffer,unsigned long count,void*data) //提供用户的写操作
参数:
file :该proc文件对应的file结构,一般忽略。
buffer :待写的数据所在的位置
count :待写数据的大小
data :一般不使用
4. 实现流程
实现一个proc文件的流程:
(1)调用create_proc_entry创建一个struct proc_dir_entry。
(2)对创建的struct proc_dir_entry进行赋值:read_proc,mode,owner,size,write_proc 等等。
5.实例一
#include<linux/kernel.h>
#include<linux/init.h>
#include<linux/proc_fs.h>
#define procfs_name "proctest" // /proc目录下创建的文件名 struct proc_dir_entry *Our_Proc_File; //结构体,create_proc_entry返回一个指针给他 int procfile_read(char *buffer, char **buffer_location, off_t offset, int buffer_length, int *eof, void *data ) //回调函数,对应写操作
{
int ret;
ret = sprintf(buffer, "HelloWorld!\n");
return ret;
} int proc_init()
{
Our_Proc_File = create_proc_entry(procfs_name, 0644, NULL);
if(Our_Proc_File == NULL)
{
remove_proc_entry(procfs_name, NULL);
printk(KERN_ALERT"Error: Could not init /proc/%s\n", procfs_name);
return -ENOMEM;
}
Our_Proc_File->read_proc = procfile_read; //回调函数
Our_Proc_File->mode = S_IFREG | S_IRUGO;
Our_Proc_File->uid = 0;
Our_Proc_File->gid = 0;
Our_Proc_File->size = 37;
printk("/proc/%s created \n", procfs_name);
return 0;
} void proc_exit()
{
remove_proc_entry(procfs_name, NULL);
printk(KERN_INFO"/proc/%s removed \n", procfs_name);
} module_init(proc_init);
module_exit(proc_exit);
5. 实例二 (由1修改为 能够 echo xxx > /proc/proctest)
#include<linux/kernel.h>
#include<linux/init.h>
#include<linux/proc_fs.h>
#include<linux/uaccess.h>
#define procfs_name "proctest" struct proc_dir_entry *Our_Proc_File;
static char msg[255]; //输入保存数组 int procfile_read(char *buffer, char **buffer_location, off_t offset, int buffer_length, int *eof, void *data )
{
//int ret;
//ret = sprintf(buffer, "HelloWorld!\n"); int len = strlen(msg);
if(offset >= len)
return 0;
if(buffer_length > len-offset)
buffer_length = len - offset;
memcpy(buffer+offset, msg+offset, buffer_length);
return offset+buffer_length;
} int procfile_write(struct file *file, const char __user *buffer, unsigned long count, void *data) //提供给用户输入信息,控制内核。
{
unsigned long count2 = count;
if(count2 >= sizeof(msg))
count2 = sizeof(msg)-1;
if(copy_from_user(msg, buffer, count2))
return -EFAULT;
msg[count2] = '\0';
return count;
} int proc_init()
{
Our_Proc_File = create_proc_entry(procfs_name, 0644, NULL);
if(Our_Proc_File == NULL)
{
remove_proc_entry(procfs_name, NULL);
printk(KERN_ALERT"Error: Could not init /proc/%s\n", procfs_name);
return -ENOMEM;
}
Our_Proc_File->read_proc = procfile_read;
Our_Proc_File->write_proc = procfile_write;
Our_Proc_File->mode = S_IFREG | S_IRUGO;
Our_Proc_File->uid = 0;
Our_Proc_File->gid = 0;
Our_Proc_File->size = 37;
printk("/proc/%s created \n", procfs_name);
return 0;
} void proc_exit()
{
remove_proc_entry(procfs_name, NULL);
printk(KERN_INFO"/proc/%s removed \n", procfs_name);
} module_init(proc_init);
module_exit(proc_exit);
echo xxxx > /proc/proctest
cat /proc/proctest
makefile
ifneq ($(KERNELRELEASE),) obj-m :=proc.o else KDIR := /lib/modules/3.5.0-17-generic/build
all:
make -C $(KDIR) M=$(PWD) modules
clean:
rm -f *.ok *.o *.mod.o *.mod.c *.symvers
endif
Linux嵌入式 -- 内核 - proc文件系统的更多相关文章
- 深入理解linux系统下proc文件系统内容
深入理解linux系统下proc文件系统内容 内容摘要:Linux系统上的/proc目录是一种文件系统,即proc文件系统. Linux系统上的/proc目录是一种文件系统,即proc文件系统.与其它 ...
- Linux嵌入式 -- 内核 (arm) & 文件系统
1. make distclean 2. 配置内核 ----> 生成 .config文件 make menuconfig ARCH=arm Makefile文件分析: 3. 编译内核 mak ...
- linux kernel (proc文件系统)参数
http://blog.csdn.net/guowake/article/details/3279796 Linux Proc文件系统,通过对Proc文件系统进行调整,达到性能优化的目的. 二./pr ...
- linux文件管理之proc文件系统
proc 文件系统 ==================================================================================== Linux ...
- Linux嵌入式 -- 内核简介(x86)
0. 嵌入式系统 以应用为中心,软硬件可裁剪,对功耗.对体积.对成本等都有严格要求的专用计算机系统. 1. linux体系结构 2. 为什么 划分为 用户空间 和 内核控件 ? 分两级,内核和应用 ...
- Linux嵌入式 -- 内核 - 系统调用
1. 系统调用 定义 Linux内核中设置了一组用于实现各种系统功能的子程序,称为系统调用.用户可以通过系统调用命令在自己的应用程序中调用它们. 系统调用和普通的函数调用非常相似,区别仅仅在于,系统调 ...
- Linux嵌入式 -- 内核 - 进程控制 和 调度
1. 进程四要素 1. 有一段程序供其执行.这段程序不一定是某个进程所专有,可以与其他进程共用. 2. 有进程专用的内核空间堆栈. 3. 在内核中有一个task_struct数据结构,即通常所说的&q ...
- Linux嵌入式 -- 内核 - 内核定时器
1. 度量时间差 时钟中断由系统的定时硬件以周期性的时间间隔产生,这个间隔(即频率)由内核根据HZ来确定,HZ是一个与体系结构无关的常数,可配置(50-1200),在X86平台,默认值为1000(每 ...
- Linux嵌入式 -- 内核 - 内核链表
1. linux内核链表 链表数据结构的定义: struct list_head { struct list_head *next, *prev; }; list_head结构包含两个指向li ...
随机推荐
- 获取字符串已utf-8表示的字节数
private static int utf8Length(String string) { /** Returns the number of bytes required to write thi ...
- knockoutJs在移动设备上有时无法更新控件值
最近在用cordova(phonegap)写一个移动app,表单比较复杂,用了knockoutJs作为前端的MVVM框架进行数据绑定. 但是发现有时候(其实是每次)如果最后在input中编辑一个值,然 ...
- 【转】mysql利用init-connect增加访问审计功能
mysql的连接首先都是要通过init-connect初始化,然后连接到实例. 我们利用这一点,通过在init-connect的时候记录下用户的thread_id,用户名和用户地址实现db的访问审计功 ...
- ios 避免两个button同一时候被点击
版权声明:本文为博主原创文章.未经博主同意不得转载. https://blog.csdn.net/superchaoxian/article/details/24631293 这个能够通过[btn ...
- 剑指offer 面试61题
面试61题: 题目:LL今天心情特别好,因为他去买了一副扑克牌,发现里面居然有2个大王,2个小王(一副牌原本是54张^_^)...他随机从中抽出了5张牌,想测测自己的手气,看看能不能抽到顺子,如果抽到 ...
- Python基础之socket编程(Day29)
一.客户端/服务器架构 1.硬件c/s架构(打印机) 2.软件c/s架构 互联网中处处是c/s架构 浏览的网页就是如此 C/S架构与socket的关系 socket就是为了完成c/s架构的开发 二.s ...
- hadoop本地运行与集群运行
开发环境: windows10+伪分布式(虚拟机组成的集群)+IDEA(不需要装插件) 介绍: 本地开发,本地debug,不需要启动集群,不需要在集群启动hdfs yarn 需要准备什么: 1/配置w ...
- 乐思启慧教学系列—Bootstrap布局规则
1外层变化,内层相应变化规则 col-md-6 col-md-4 外层6变成12,扩大了2倍,里面就得缩小2倍(除以2), 只有这样才能保持外部变化了,内部依然对齐 col-md-12 col-md- ...
- 模块调用,datetime,time,logging,递归,双层装饰器, json,pickle迭代器和生成器
一.python模块(导入,内置,自定义,开源) 1.模块简介 模块是一个包含所有你定义的函数和变量的文件,其后缀名是.py.模块可以被别的程序引入,以使用该模块中的函数等功能.这也是使用python ...
- 教你在Yii2.0框架中如何创建自定义小部件
本教程将帮助您创建自己的自定义小部件在 yii framework 2.0.部件是可重用的模块和用于视图. 创建一个小部件,需要继承 yii\base\Widget,覆盖重写 yii\base\Wid ...