初探linux子系统集之led子系统(三)【转】
本文转载自:http://blog.csdn.net/eastmoon502136/article/details/37822837
世界杯结束了,德国战车夺得了大力神杯,阿根廷最终还是失败了。也许3年,5年,或者10年后,人们就不知道巴西世界杯的亚军是谁,但是总是会记得冠军是谁。就像什么考试,比赛,第一永远会被人们所记住,所以我们都想去追寻第一,渴望第一,在一次次的追寻中,成者为王败者为寇。而处在第一的位置,永远担心下面的会超越自己,从而活得很累,而第二永远想争取第一,也活得很累,有时候,想想,人一生当中,成功真的就那么重要吗?富有真的那么重要吗?采菊东篱下,悠然见南山不是也很有诗意吗?说了好多,还是继续写led子系统吧。
前面写了很多关于led子系统的相关知识,现在终于可以开始分析leds-gpio.c这个驱动了。
注册了platform驱动。
platform_driver_register(&gpio_led_driver);
platform总线就不多说了,在自己的平台下添加platform device就可以了。
当device和dirver匹配后,就会调用driver的probe函数,这里调用的是下面这个函数。
- static int __devinit gpio_led_probe(struct platform_device *pdev)
- {
- structgpio_led_platform_data *pdata = pdev->dev.platform_data;
- struct gpio_leds_priv*priv;
- int i, ret = 0;
- if (pdata &&pdata->num_leds) {
- priv =kzalloc(sizeof_gpio_leds_priv(pdata->num_leds),
- GFP_KERNEL);
- if (!priv)
- return-ENOMEM;
- priv->num_leds= pdata->num_leds;
- for (i = 0;i < priv->num_leds; i++) {
- ret= create_gpio_led(&pdata->leds[i],
- &priv->leds[i],
- &pdev->dev,pdata->gpio_blink_set);
- if(ret < 0) {
- /*On failure: unwind the led creations */
- for(i = i - 1; i >= 0; i--)
- delete_gpio_led(&priv->leds[i]);
- kfree(priv);
- returnret;
- }
- }
- } else {
- priv =gpio_leds_create_of(pdev);
- if (!priv)
- return-ENODEV;
- }
- platform_set_drvdata(pdev,priv);
- return 0;
- }
获取platform里的device的数据,然后create_gpio_led,这里可以注册很多歌led,具体的leds-gpio的platform数据可以参考
http://blog.csdn.net/eastmoon502136/article/details/37569789。
接着看一下create_gpio_led这个函数。
- static int __devinit create_gpio_led(const struct gpio_led*template,
- struct gpio_led_data*led_dat, struct device *parent,
- int (*blink_set)(unsigned,int, unsigned long *, unsigned long *))
- {
- int ret, state;
- led_dat->gpio = -1;
- /* skip leds thataren't available */
- if(!gpio_is_valid(template->gpio)) {
- printk(KERN_INFO"Skipping unavailable LED gpio %d (%s)\n",
- template->gpio,template->name);
- return 0;
- }
- ret =gpio_request(template->gpio, template->name);
- if (ret < 0)
- return ret;
- led_dat->cdev.name= template->name;
- led_dat->cdev.default_trigger= template->default_trigger;
- led_dat->gpio =template->gpio;
- led_dat->can_sleep= gpio_cansleep(template->gpio);
- led_dat->active_low= template->active_low;
- led_dat->blinking =0;
- if (blink_set) {
- led_dat->platform_gpio_blink_set= blink_set;
- led_dat->cdev.blink_set= gpio_blink_set;
- }
- led_dat->cdev.brightness_set= gpio_led_set;
- if(template->default_state == LEDS_GPIO_DEFSTATE_KEEP)
- state =!!gpio_get_value(led_dat->gpio) ^ led_dat->active_low;
- else
- state =(template->default_state == LEDS_GPIO_DEFSTATE_ON);
- led_dat->cdev.brightness= state ? LED_FULL : LED_OFF;
- if(!template->retain_state_suspended)
- led_dat->cdev.flags|= LED_CORE_SUSPENDRESUME;
- ret =gpio_direction_output(led_dat->gpio, led_dat->active_low ^ state);
- if (ret < 0)
- goto err;
- INIT_WORK(&led_dat->work,gpio_led_work);
- ret =led_classdev_register(parent, &led_dat->cdev);
- if (ret < 0)
- goto err;
- return 0;
- err:
- gpio_free(led_dat->gpio);
- return ret;
- }
- struct gpio_led_data {
- struct led_classdevcdev;
- unsigned gpio;
- struct work_structwork;
- u8 new_level;
- u8 can_sleep;
- u8 active_low;
- u8 blinking;
- int(*platform_gpio_blink_set)(unsigned gpio, int state,
- unsignedlong *delay_on, unsigned long *delay_off);
- };
申请gpio,以及对于一些变量和函数指针的赋值,最后注册led设备。
关于应用层的调用:
比如我们在platform设备中注册了
- Static struct gpio_led gpio_leds[] = {
- {
- .name=”my-led”,
- .default_trigger= “timer”,
- .gpio= 30,
- .active_low= 1,
- .default_state= LEDS_GPIO_DEFSTATE_OFF,
- }
- };
那么在/sys/class/leds/下会有my-led目录,在目录下面会创建两个文件delay_on和delay_off。
可以通过
echo 100 > /sys/class/leds/my-led/delay_on
echo 100 > /sys/class/leds/my-led/delay_off
来控制闪烁的时间。
cat /sys/class/leds/my-led/delay_on
cat /sys/class/leds/my-led/delay_off
来获取当前的delay_on和delay_off的值
对于led子系统就简单的介绍到这里了。
初探linux子系统集之led子系统(三)【转】的更多相关文章
- 初探linux子系统集之led子系统(三)
世界杯结束了,德国战车夺得了大力神杯,阿根廷最终还是失败了.也许3年,5年,或者10年后,人们就不知道巴西世界杯的亚军是谁,但是总是会记得冠军是谁.就像什么考试,比赛,第一永远会被人们所记住,所以我们 ...
- 初探linux子系统集之led子系统(一)
就像学编程第一个范例helloworld一样,学嵌入式,单片机.fpga之类的第一个范例就是点亮一盏灯.对于庞大的linux系统,当然可以编写一个字符设备驱动来实现我们需要的led灯,也可以直接利用g ...
- 初探linux子系统集之led子系统(一)【转】
本文转载自:http://blog.csdn.net/eastmoon502136/article/details/37569789 就像学编程第一个范例helloworld一样,学嵌入式,单片机.f ...
- 初探linux子系统集之led子系统(二)
巴西世界杯,德国7比1东道主,那个惨不忍睹啊,早上起来看新闻,第一眼看到7:1还以为点球也能踢成这样,后来想想,点球对多嘛6比1啊,接着就是各种新闻铺天盖地的来了.其实失败并没有什么,人生若是能够成功 ...
- 初探linux子系统集之led子系统(二)【转】
本文转载自:http://blog.csdn.net/eastmoon502136/article/details/37606487 巴西世界杯,德国7比1东道主,那个惨不忍睹啊,早上起来看新闻,第一 ...
- 初探linux子系统集之timer子系统(三)
因为现在的linux虽然还是可以使用低精度的timer,但是趋势是高精度hrtimer,所以上一篇试着翻译一下hrtimer的一些介绍,翻译的不是很好,看来英语还得好好学习啊,下面还是好好学习下lin ...
- 初探linux子系统集之timer子系统(一)
一般来说要让整个linux系统跑起来,那么一个必须的就是linux的时钟,也就是时间子系统了,这里正好工作需要,那么就研究下linux下的时间子系统了. linux内核必须完成两种主要的定时测量.一个 ...
- 初探linux子系统集之timer子系统(二)
想着博客中还没有翻译过一篇文章,虽然英文水平有限,但是借助google翻译慢慢地翻译出一篇文章也是不错的选择.那就来学习下hrtimer的文档吧,翻译的略搓,可以直接跳过这篇,这里仅作为学习的过程!^ ...
- 初探linux子系统集之i2c子系统(一)
I2c子系统在进公司来的时候就学习过了,可是那是还不是很熟悉linux中的i2c子系统,就没有细看.记得当初很想熟悉linux中的各种总线驱动,想专门写一个关于总线驱动的专集,后来发现好像就没有几个, ...
随机推荐
- bzoj3874&2832 [Ahoi2014]宅男计划 模拟退火,三分
[Ahoi2014&Jsoi2014]宅男计划 Time Limit: 1 Sec Memory Limit: 256 MBSubmit: 962 Solved: 371[Submit][ ...
- android开发里跳过的坑——camera调用setDisplayOrientation设置预览显示旋转无效
问题原因,在surfaceview没有设置给camera之前调用了,所以,这个方法一定要在camera.setPreviewDisplay(surfaceHolder)这个之后,启动相机预览之前调用.
- 【POJ1226】Substrings(后缀数组,二分)
题意: n<=10,len<=100 思路: 只有一个字符串的时候特判一下 #include<cstdio> #include<cstring> #include& ...
- 玩具装箱 BZOJ 1010
玩具装箱 [问题描述] P教授要去看奥运,但是他舍不下他的玩具,于是他决定把所有的玩具运到北京.他使用自己的压缩器进行压缩,其可以将任意物品变成一堆,再放到一种特殊的一维容器中.P教授有编号为1... ...
- Java面试题集(一)
作为一名java开发软件工程,一定要记住,基础非常重要,往往就是一些基础,很简单,但是你就是不知道实现原理,为什么使用,有没有自己去发现,对比,差异从而总结,有些东西看似简单,但是不一定你描述清楚,直 ...
- 并发编程辅助工具-java.util.concurrent
1. CountDownLatch 类似于计数器的功能,主要用于控制某个任务的执行先后顺序,可以控制某个任务在其他任务(可能是多线程的)执行完 之后,才会去执行. public static void ...
- 标准C程序设计七---20
Linux应用 编程深入 语言编程 标准C程序设计七---经典C11程序设计 以下内容为阅读: <标准C程序设计>(第7版) 作者 ...
- Python入门--2--继续学习
继续学习小甲鱼 一.python比较操作符 == :判断左边是否等于右边 != : 判断左边是否不能右边 二. if while判断语句 栗子: temp = input ("sha shu ...
- elasticsearch入门使用(四) 索引、安装IK分词器及增删改查数据
一.查看.创建索引 创建一个名字为user索引: curl -X PUT 'localhost:9200/stu' {"acknowledged":true,"shard ...
- P1551 亲戚 洛谷
https://www.luogu.org/problem/show?pid=1551 题目背景 若某个家族人员过于庞大,要判断两个是否是亲戚,确实还很不容易,现在给出某个亲戚关系图,求任意给出的两个 ...