为Tiny4412设备驱动在proc目录下添加一个可读版本信息的文件

http://blog.csdn.net/morixinguan/article/details/77808088

上节,我们明白了proc文件系统的作用,接下来我们在友善之臂已经写好的led驱动的基础上,在proc目录下创建一个文件夹,然后加入led驱动的版本信息读取。

我们在init函数的最后加入:

//定义proc文件系统节点
struct proc_dir_entry *dev_dir , *dev_version;
//创建一个目录
dev_dir = proc_mkdir("Tiny4412_leds", NULL);
//创建一个文件
dev_version = create_proc_entry("version", S_IRUGO, dev_dir);
//调用读版本的函数
dev_version->read_proc = proc_read_version ;

然后编写获取版本信息的读函数:

#define VERSION_LEN 20
char Tiny4412_LED_version[VERSION_LEN] = "20170908\n";
int proc_read_version(char *page, char **start, off_t off, int count, int *eof,                  void *data)
{
	int len ;
	len = sprintf(page,Tiny4412_LED_version); //将字符串写入page,相当于copy到用户层
	return len ;
}

大功告成!!

接下来编译完成,将kenel刷入开发板后卡机,用adb shell进入可以看到如下:

修改的源码:

#include <linux/kernel.h>
#include <linux/module.h>
#include <linux/miscdevice.h>
#include <linux/fs.h>
#include <linux/types.h>
#include <linux/moduleparam.h>
#include <linux/slab.h>
#include <linux/ioctl.h>
#include <linux/cdev.h>
#include <linux/delay.h>

#include <linux/gpio.h>
#include <mach/gpio.h>
#include <plat/gpio-cfg.h>

//添加必要的头文件
#include <linux/proc_fs.h>
#include <linux/uaccess.h>

#define DEVICE_NAME "leds"

static int led_gpios[] = {
	EXYNOS4212_GPM4(0),
	EXYNOS4212_GPM4(1),
	EXYNOS4212_GPM4(2),
	EXYNOS4212_GPM4(3),
};

#define LED_NUM		ARRAY_SIZE(led_gpios)

static long tiny4412_leds_ioctl(struct file *filp, unsigned int cmd,
		unsigned long arg)
{
	switch(cmd) {
		case 0:
		case 1:
			if (arg > LED_NUM) {
				return -EINVAL;
			}

			gpio_set_value(led_gpios[arg], !cmd);
			//printk(DEVICE_NAME": %d %d\n", arg, cmd);
			break;

		default:
			return -EINVAL;
	}

	return 0;
}

static struct file_operations tiny4412_led_dev_fops = {
	.owner			= THIS_MODULE,
	.unlocked_ioctl	= tiny4412_leds_ioctl,
};

static struct miscdevice tiny4412_led_dev = {
	.minor			= MISC_DYNAMIC_MINOR,
	.name			= DEVICE_NAME,
	.fops			= &tiny4412_led_dev_fops,
};

#define VERSION_LEN 20
char Tiny4412_LED_version[VERSION_LEN] = "20170908\n";
int proc_read_version(char *page, char **start, off_t off, int count, int *eof,                  void *data)
{
	int len ;
	len = sprintf(page,Tiny4412_LED_version);
	return len ;
}

static int __init tiny4412_led_dev_init(void) {
	int ret;
	int i;

	for (i = 0; i < LED_NUM; i++) {
		ret = gpio_request(led_gpios[i], "LED");
		if (ret) {
			printk("%s: request GPIO %d for LED failed, ret = %d\n", DEVICE_NAME,
					led_gpios[i], ret);
			return ret;
		}

		s3c_gpio_cfgpin(led_gpios[i], S3C_GPIO_OUTPUT);
		gpio_set_value(led_gpios[i], 1);
	}
	//杂类设备
	ret = misc_register(&tiny4412_led_dev);
	//定义proc文件系统节点
	struct proc_dir_entry *dev_dir , *dev_version;
	//创建一个目录
	dev_dir = proc_mkdir("Tiny4412_leds", NULL);
	//创建一个文件
	dev_version = create_proc_entry("version", S_IRUGO, dev_dir);
	//调用读版本的函数
	dev_version->read_proc = proc_read_version ;
	printk(DEVICE_NAME"\tinitialized\n");
	return ret;
}

static void __exit tiny4412_led_dev_exit(void) {
	int i;

	for (i = 0; i < LED_NUM; i++) {
		gpio_free(led_gpios[i]);
	}

	misc_deregister(&tiny4412_led_dev);
}

module_init(tiny4412_led_dev_init);
module_exit(tiny4412_led_dev_exit);

MODULE_LICENSE("GPL");
MODULE_AUTHOR("FriendlyARM Inc & Y.X.YANG modify");
时间: 2024-09-04 07:35:00

为Tiny4412设备驱动在proc目录下添加一个可读版本信息的文件的相关文章

android system-安卓系统编译时,system目录下添加一个文件,为何生成的system.img为什么不包含该文件?

问题描述 安卓系统编译时,system目录下添加一个文件,为何生成的system.img为什么不包含该文件? 安卓系统编译时,在system路径下添加了一些文件,但是编译生成的system.img为什么不包含这些文件? 解决方案 http://www.linuxidc.com/Linux/2014-06/103521.htm

Linux中/proc目录下文件

  /proc文件系统下的多种文件提供的系统信息不是针对某个特定进程的,而是能够在整个系统范围的上下文中使用.可以使用的文件随系统配置的变化而变化.命令procinfo能够显示基于其中某些文件的多种系统信息.以下详细描述/proc下的文件. /proc/cmdline文件 这个文件给出了内核启动的命令行.它和用于进程的cmdline项非常相似. 示例: [root@localhost proc]# cat cmdline ro root=LABEL=/ rhgb quiet ----------

Linux中/proc目录下文件有什么用

/proc文件系统下的多种文件提供的系统信息不是针对某个特定进程的,而是能够在整个系统范围的上下文中使用.可以 使用的文件随系统配置的变化而变化.命令procinfo能够显示基于其中某些文件的多种系统信息.以下详细描述/proc下的 文件. -------------------------------------------------------------------------------- /proc/cmdline文件 这个文件给出了内核启动的命令行.它和用于进程的cmdline项非

源码-如何在安卓boot分区目录下添加文件?

问题描述 如何在安卓boot分区目录下添加文件? 我现在按照一个教程做安卓的verified boot,其中有一步是要在boot分区根目录下添加一个文件, 原文 "include it in the root of your boot image under the verity_key filename", 安卓aosp官方的原文 "add an RSA-2048 key to the /boot partition at /verity_key" 这里具体不知道

eclipse修改发布路径到tomcat root目录下遇到一个问题 急!在线等。。

问题描述 我修改了以下几处地方后,项目能够发布到tomcat目录下,但是包含在项目名称的文件夹下面,我想要实现的效果是把项目文件直接发布到root目录下而不是root目录下的项目名称下这样设置后实现了这样的效果(webapp下出现项目名称的文件夹)但是!!!!我想要实现的是如下的效果(root下面直接是要发布的文件) 解决方案 解决方案二:发布到哪里不是一样的?Path是"/"好像访问就不用输入工程名路径的解决方案三:其实把项目打包成war文件丢到webapps里面然后重启tomcat

小女子求教::怎样引用不同目录下的一个自定义类

问题描述 各位大虾晚上好:我今晚碰到了一个问题,就是怎样引用不同目录下的一个自定义类,我自定义了一个通用数据操作类:dataoperate.cs,一开始,放到了主文件目录下,统一目录下的文件把他实例化的时候没有问题,但是,把他放到我程序里编自定义的一个文件夹app_code下的时候,就报错说是没有引用,必须把他放到app_code外才可以编译通过,这是怎么回事啊?如何解决?谢谢 解决方案 解决方案二:放在App_Code是正确的.注意一下名称空间解决方案三:顶楼上解决方案四:你的开发工具应该是0

tomcat 6.0.18 work目录下 未保存jsp对应的servelt java文件

问题描述 tomcat 6.0.18 work目录下 未保存jsp对应的servelt java文件 而只有其class文件这个是什么原因呢或者需要怎样配置呢 谢谢! 问题补充:我是直接在myeclipse里的 servers View 里直接选择该工程部署到tomcat服务器里也就相当于直接放在 其webappps目录下的 解决方案 那这个就有点奇怪了.这样试试:你把项目直接拷贝到tomcat的webappps目录下,然后清除缓存,启动tomcat,看能否正常生成文件,如果还是不行,你再拷贝另

wince6 0-想要在wince6.0下添加一个软关机的功能,就像xp一样

问题描述 想要在wince6.0下添加一个软关机的功能,就像xp一样 请教诸位大神,小弟用vs2005编译一个intel_X86芯片上的wince6.0系统,本身系统只有一个suspend功能,我就想添加一个关机的功能,今天看了一点电源管理方面的知识,想用直接调用setsystempowerstate()函数,但是没啥效果,求各位大神给个思路或步骤啥地,明天争取做出来,跪谢啊...... 解决方案 wince中实现关机功能 http://blog.csdn.net/ymzhou117/artic

android如何在当前app的目录下创建一个文件

package com.example.listfile; import java.io.File; import java.io.IOException; import android.app.Activity; import android.content.Context; import android.widget.TextView; import android.os.Bundle; import android.os.Process; public class MainActivity