led-class.c
来自「linux 内核源代码」· C语言 代码 · 共 183 行
C
183 行
/* * LED Class Core * * Copyright (C) 2005 John Lenz <lenz@cs.wisc.edu> * Copyright (C) 2005-2007 Richard Purdie <rpurdie@openedhand.com> * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License version 2 as * published by the Free Software Foundation. */#include <linux/module.h>#include <linux/kernel.h>#include <linux/init.h>#include <linux/list.h>#include <linux/spinlock.h>#include <linux/device.h>#include <linux/sysdev.h>#include <linux/timer.h>#include <linux/err.h>#include <linux/ctype.h>#include <linux/leds.h>#include "leds.h"static struct class *leds_class;static ssize_t led_brightness_show(struct device *dev, struct device_attribute *attr, char *buf){ struct led_classdev *led_cdev = dev_get_drvdata(dev); ssize_t ret = 0; /* no lock needed for this */ sprintf(buf, "%u\n", led_cdev->brightness); ret = strlen(buf) + 1; return ret;}static ssize_t led_brightness_store(struct device *dev, struct device_attribute *attr, const char *buf, size_t size){ struct led_classdev *led_cdev = dev_get_drvdata(dev); ssize_t ret = -EINVAL; char *after; unsigned long state = simple_strtoul(buf, &after, 10); size_t count = after - buf; if (*after && isspace(*after)) count++; if (count == size) { ret = count; led_set_brightness(led_cdev, state); } return ret;}static DEVICE_ATTR(brightness, 0644, led_brightness_show, led_brightness_store);#ifdef CONFIG_LEDS_TRIGGERSstatic DEVICE_ATTR(trigger, 0644, led_trigger_show, led_trigger_store);#endif/** * led_classdev_suspend - suspend an led_classdev. * @led_cdev: the led_classdev to suspend. */void led_classdev_suspend(struct led_classdev *led_cdev){ led_cdev->flags |= LED_SUSPENDED; led_cdev->brightness_set(led_cdev, 0);}EXPORT_SYMBOL_GPL(led_classdev_suspend);/** * led_classdev_resume - resume an led_classdev. * @led_cdev: the led_classdev to resume. */void led_classdev_resume(struct led_classdev *led_cdev){ led_cdev->brightness_set(led_cdev, led_cdev->brightness); led_cdev->flags &= ~LED_SUSPENDED;}EXPORT_SYMBOL_GPL(led_classdev_resume);/** * led_classdev_register - register a new object of led_classdev class. * @dev: The device to register. * @led_cdev: the led_classdev structure for this device. */int led_classdev_register(struct device *parent, struct led_classdev *led_cdev){ int rc; led_cdev->dev = device_create(leds_class, parent, 0, "%s", led_cdev->name); if (unlikely(IS_ERR(led_cdev->dev))) return PTR_ERR(led_cdev->dev); dev_set_drvdata(led_cdev->dev, led_cdev); /* register the attributes */ rc = device_create_file(led_cdev->dev, &dev_attr_brightness); if (rc) goto err_out; /* add to the list of leds */ down_write(&leds_list_lock); list_add_tail(&led_cdev->node, &leds_list); up_write(&leds_list_lock);#ifdef CONFIG_LEDS_TRIGGERS init_rwsem(&led_cdev->trigger_lock); rc = device_create_file(led_cdev->dev, &dev_attr_trigger); if (rc) goto err_out_led_list; led_trigger_set_default(led_cdev);#endif printk(KERN_INFO "Registered led device: %s\n", led_cdev->name); return 0;#ifdef CONFIG_LEDS_TRIGGERSerr_out_led_list: device_remove_file(led_cdev->dev, &dev_attr_brightness); list_del(&led_cdev->node);#endiferr_out: device_unregister(led_cdev->dev); return rc;}EXPORT_SYMBOL_GPL(led_classdev_register);/** * led_classdev_unregister - unregisters a object of led_properties class. * @led_cdev: the led device to unregister * * Unregisters a previously registered via led_classdev_register object. */void led_classdev_unregister(struct led_classdev *led_cdev){ device_remove_file(led_cdev->dev, &dev_attr_brightness);#ifdef CONFIG_LEDS_TRIGGERS device_remove_file(led_cdev->dev, &dev_attr_trigger); down_write(&led_cdev->trigger_lock); if (led_cdev->trigger) led_trigger_set(led_cdev, NULL); up_write(&led_cdev->trigger_lock);#endif device_unregister(led_cdev->dev); down_write(&leds_list_lock); list_del(&led_cdev->node); up_write(&leds_list_lock);}EXPORT_SYMBOL_GPL(led_classdev_unregister);static int __init leds_init(void){ leds_class = class_create(THIS_MODULE, "leds"); if (IS_ERR(leds_class)) return PTR_ERR(leds_class); return 0;}static void __exit leds_exit(void){ class_destroy(leds_class);}subsys_initcall(leds_init);module_exit(leds_exit);MODULE_AUTHOR("John Lenz, Richard Purdie");MODULE_LICENSE("GPL");MODULE_DESCRIPTION("LED Class Interface");
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?