/proc 文件系统——提供一种驱动调试的利器

原创 2013年12月05日 16:11:47

     做了几年的Android驱动开发,最经常碰到的是出问题时,需要实时获取设备的状态,寄存器值,GPIO状态等。或者在开发一个新的设备驱动,由于前期HAL层的代码还没完成,那么通过proc文件系统提供一个调试接口,可以说即简单又便捷。这也一种和内核通信的方式。

    经常调试codec,就以提供一个调试codec的接口为例,来说明吧,既然是一种和内核的通信方式,计算机里面涉及到通信的时候,往往需要一个通信协议来协调通信双方,那么实现这个调试接口,首先也设计一个简单的协议吧。codec调试最多的是就是读写寄存器了,以下这个示例就提供一个读写寄存器的方法。

首先会在/proc 目录下创建一个子目录 codec,并在之目录下创建两个节点,结构如下:

/proc

   |-----codec

             |------reg_read

             |------reg_write

reg_read:用于读取寄存器的节点,例如:echo 0x05 > reg_read 往该节点写入一个数值,表示要读取寄存器,示例表示显示0x5寄存器的值

reg_write:用于写入寄存器的节点,例如:echo 0x05  0xff > reg_write 往该节点写入两个数值,表示往某个寄存器写入某个值,示例表示往0x5寄存器写入0xff

以下是代码实现:

#include <linux/proc_fs.h>

static struct proc_dir_entry *codec_dir;
#define BUFF_SIZE 64

static ssize_t proc_write_reg(struct file *file, const char *buffer,
								unsigned long length, void *data)
{
	char reg_str[BUFF_SIZE] = {0};
	unsigned int reg;
	unsigned int value;
	char *str_end;

	if (length > BUFF_SIZE - 1)
		length = BUFF_SIZE - 1;
	if (copy_from_user(reg_str, buffer, length))
		return -EINVAL;
	printk("%s\n", reg_str);
	reg_str[length] = '\0';

	reg = simple_strtoul(reg_str, &str_end, 16);
	printk("reg: %#x\n", reg);

	value = simple_strtoul(str_end + 1, NULL, 16);
	printk("value: %#x\n", value);
	WRITE_REG(reg, value);

	return length;
}

static ssize_t proc_read_reg(struct file *file, const char *buffer,
					unsigned long length, void * data)
{
	char reg_str[BUFF_SIZE] = {'0'};
	unsigned int reg;

	if (length > BUFF_SIZE - 1)
		length = BUFF_SIZE - 1;
	if (copy_from_user(reg_str, buffer, length))
		return -EINVAL;

	printk("%s\n", reg_str);
	reg_str[length] = '\0';
	reg = simple_strtoul(reg_str, NULL, 16);
	printk("reg(%#x):%#x", reg, READ_REG(reg));

	return length;
}

static void init_proc(void)
{
	struct proc_dir_entry *reg_read, *reg_write;

	codec_dir = proc_mkdir("codec", NULL);
	reg_read = create_proc_entry("reg_read", 0644, codec_dir);
	if (reg_read)
		reg_read->write_proc = proc_read_reg;

	reg_write = create_proc_entry("reg_write", 0644, codec_dir);
	if (reg_write)
		reg_write->write_proc = proc_write_reg;

}

static void remove_proc(void)
{
	remove_proc_entry("reg_read", codec_dir);
	remove_proc_entry("reg_write", codec_dir);
}


相关文章推荐

Linux RTC驱动分析(三)----sys和proc文件系统

rtc-sysfs.c这个部分主要是有关sysfs的操作。在rtc_device_register函数中,rtc_sysfs_add_device(rtc);完成sys的操作。 void rtc_s...

设备驱动之一 - proc文件系统接口

学习linux设备驱动,第四章;       关于proc文件系统接口编程参见       procfs读取信息实例:http://blog.csdn.net/iamonlyme/article/de...

【嵌入式Linux学习七步曲之第五篇 Linux内核及驱动编程】揭开Linux Proc文件系统的神秘面纱

声明:此文转载以下链接:嵌入式Linux学习之/proc伪文件系统(内核和内核模块向process发送信息机制的文件系统)                  揭开Linux Proc文件系统的神秘...

Linux /proc文件系统——CPU基本信息查看

/proc/cpuinfo /proc/stat /proc/cpuinfo一、基本概念CPU:中央处理器 CPU核心: 核心又成为内核,是CPU的重要组成部分。CPU所有的计算、接受/存储命令、处...

/proc——虚拟文件系统

/proc文件系统是一种内核和内核模块yong

LINUX系统监视——/proc文件系统(文件夹)

在Linux中有额外的机制可以为内核和内核模块将信息发送给进程 – /proc 文件系统。最初设计的目的是允许更方便的对进程信息进行访问(因此得名),现在它被每一个有有趣的东西报告的内核使用,例如 /...

五。内核代码调试方法——proc文件系统、seqfile文件系统

如有错误大家一定告诉我,一起学习了; ############## proc 文件系统 ################## 1、    mount -t proc none /proc    ...

/proc文件系统用于内核调试

一、/proc文件系统简介 Linux提供了一个特殊的文件系统——/proc,通过建立内核与进程之间发送信息的机制,使得可以在进程运行时动态地读写内核内部的数据结构、改变内核设置。与其他文件系统...

内核proc文件系统的代码

  • 2016年02月03日 13:52
  • 2KB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:/proc 文件系统——提供一种驱动调试的利器
举报原因:
原因补充:

(最多只允许输入30个字)