Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 39741
b: refs/heads/master
c: 12fda16
h: refs/heads/master
i:
  39739: 1507dbb
v: v3
  • Loading branch information
Jeff Garzik authored and Linus Torvalds committed Oct 17, 2006
1 parent bae147b commit ac93263
Show file tree
Hide file tree
Showing 3 changed files with 36 additions and 8 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 58ff407bee5a55f9c1188a3f9d70ffc79485183c
refs/heads/master: 12fda16814bba05a84a49a1da25a069d6c249758
26 changes: 21 additions & 5 deletions trunk/drivers/leds/led-class.c
Original file line number Diff line number Diff line change
Expand Up @@ -91,6 +91,8 @@ EXPORT_SYMBOL_GPL(led_classdev_resume);
*/
int led_classdev_register(struct device *parent, struct led_classdev *led_cdev)
{
int rc;

led_cdev->class_dev = class_device_create(leds_class, NULL, 0,
parent, "%s", led_cdev->name);
if (unlikely(IS_ERR(led_cdev->class_dev)))
Expand All @@ -99,8 +101,10 @@ int led_classdev_register(struct device *parent, struct led_classdev *led_cdev)
class_set_devdata(led_cdev->class_dev, led_cdev);

/* register the attributes */
class_device_create_file(led_cdev->class_dev,
&class_device_attr_brightness);
rc = class_device_create_file(led_cdev->class_dev,
&class_device_attr_brightness);
if (rc)
goto err_out;

/* add to the list of leds */
write_lock(&leds_list_lock);
Expand All @@ -110,16 +114,28 @@ int led_classdev_register(struct device *parent, struct led_classdev *led_cdev)
#ifdef CONFIG_LEDS_TRIGGERS
rwlock_init(&led_cdev->trigger_lock);

led_trigger_set_default(led_cdev);
rc = class_device_create_file(led_cdev->class_dev,
&class_device_attr_trigger);
if (rc)
goto err_out_led_list;

class_device_create_file(led_cdev->class_dev,
&class_device_attr_trigger);
led_trigger_set_default(led_cdev);
#endif

printk(KERN_INFO "Registered led device: %s\n",
led_cdev->class_dev->class_id);

return 0;

#ifdef CONFIG_LEDS_TRIGGERS
err_out_led_list:
class_device_remove_file(led_cdev->class_dev,
&class_device_attr_brightness);
list_del(&led_cdev->node);
#endif
err_out:
class_device_unregister(led_cdev->class_dev);
return rc;
}
EXPORT_SYMBOL_GPL(led_classdev_register);

Expand Down
16 changes: 14 additions & 2 deletions trunk/drivers/leds/ledtrig-timer.c
Original file line number Diff line number Diff line change
Expand Up @@ -123,6 +123,7 @@ static CLASS_DEVICE_ATTR(delay_off, 0644, led_delay_off_show,
static void timer_trig_activate(struct led_classdev *led_cdev)
{
struct timer_trig_data *timer_data;
int rc;

timer_data = kzalloc(sizeof(struct timer_trig_data), GFP_KERNEL);
if (!timer_data)
Expand All @@ -134,10 +135,21 @@ static void timer_trig_activate(struct led_classdev *led_cdev)
timer_data->timer.function = led_timer_function;
timer_data->timer.data = (unsigned long) led_cdev;

class_device_create_file(led_cdev->class_dev,
rc = class_device_create_file(led_cdev->class_dev,
&class_device_attr_delay_on);
class_device_create_file(led_cdev->class_dev,
if (rc) goto err_out;
rc = class_device_create_file(led_cdev->class_dev,
&class_device_attr_delay_off);
if (rc) goto err_out_delayon;

return;

err_out_delayon:
class_device_remove_file(led_cdev->class_dev,
&class_device_attr_delay_on);
err_out:
led_cdev->trigger_data = NULL;
kfree(timer_data);
}

static void timer_trig_deactivate(struct led_classdev *led_cdev)
Expand Down

0 comments on commit ac93263

Please sign in to comment.