初探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子系统(一)【转】
本文转载自:http://blog.csdn.net/eastmoon502136/article/details/37569789 就像学编程第一个范例helloworld一样,学嵌入式,单片机.f ...
- Linux下的LED子系统
最简单的led驱动就是从端口输出0或1来关闭或点亮灯.而我们这里讲的led子系统,主要是对led事件进行了分装和优化,这里我们主要讲的是可以实现跨平台的led驱动.不管你是使用三星的平台,还是Atme ...
- Linux内核LED子系统、请务必看
前言 LED子系统你要是说很难嘛,但是它就是控制一些简单的GPIO口,但是你要是说它很简单嘛,但是我也不见得一个初学者很快就能掌握,你如果是刚入门这部分的话,我觉得你还是要去仔细研究下这些驱动.前两天 ...
- LINUX系统子系统DEMON,【linux】led子系统
目录 前言 led子系统 led子系统实战-系统调用-ARM平台 前言 接下来记录的是 led子系统 目前不涉及驱动源码 linux子系统 在 Linux 系统中 绝大多数硬件设备都有非常成熟的驱动框 ...
- 基于PM8916 MPP创建一个Linux led子系统
基于PM8916 MPP创建一个Linuxled子系统 首先,从kernel文件系统层面上创建sys文件系统节点/sys/class/leds/button-backlight/brightness的 ...
- LINUX IIO子系统分析之一 IIO子系统概述
从本章开始,我们进行IIO子系统专栏的分析文档,本次IIO子系统专栏分析文档大概包含如下几章: 一. IIO子系统概述 二.IIO子系统相关数据结构分析 三.iio trigger 介绍 四.iio ...
- linux驱动系列学习之i2c子系统(四)
一.i2c子系统简介 1. i2c总线 i2c总线因为只用SCL.SDA两根线就实现了设备之间的数据互传,极大的简化PCB布线,因此,2c总线在EEPROM.小型LCD等设备中应用极光.i2c的相关时 ...
- Linux中断(interrupt)子系统之四:驱动程序接口层 中断通用逻辑层
在本系列文章的第一篇:Linux中断(interrupt)子系统之一:中断系统基本原理,我把通用中断子系统分为了4个层次,其中的驱动程序接口层和中断通用逻辑层的界限实际上不是很明确,因为中断通用逻辑层 ...
- linux iio 设备驱动,Linux设备驱动之IIO子系统——IIO框架数据读取,linuxiio
Linux设备驱动之IIO子系统--IIO框架数据读取,linuxiio IIO DATA ACCESS IIO数据获取 只有两种方法可以使用IIO框架访问数据; 通过sysf通道进行一次性捕获,或通 ...
- linux内核添加spi驱动,Linux内核驱动之spi子系统spi协议.docx
Linux内核驱动之spi子系统spi协议 概况 SPI接口是摩托罗拉首先提出的全双工三线同步串行外围接口SCK,MOSI,MISO,采用主从模式(Master Slave)架构:支持多slave模式 ...
最新文章
- Linux 启动mysql
- 再译《A *路径搜索入门》之二
- 前端学习(479):html简介
- PASCAL不仅仅是语言
- 陷阱计算机音乐谱大全,陷阱 原版C调-王北车-和弦谱-《弹吧》官网tan8.com-和弦谱大全,学吉他,秀吉他...
- 【Python】pyCryptodome模块实现AES加密、解密
- .rpt文件内容读取java_Java 中读取文件内容的 n 中方式
- 入行数据科学,仅需6步
- Java的I/O总结
- jQuery、Ajax,DataTable数据如何转换成Json格式
- 静态HTML网页设计作品——食品餐饮行业网站模板(10页) HTML+CSS+JavaScript 学生DW网页设计作业成品 美食生鲜零食网页设计
- Unity之Touch触摸屏单指、多指触碰
- java发送QQ邮件详细步骤
- Unity 游戏多语言解决方案和字体错误解决方法的想法
- 【python】parser.add_argument后面为什么要加-和--?
- 往数据库里添加date(时间)类型的数据
- cygwin 安装 ffplay
- iOS精品资源汇总(持续更新)
- PDF如何编辑修改,怎么编辑PDF文字与图片
- 【vbers】ibv_get_async_event()