Lines Matching refs:led_cdev
31 trigger_relevant(struct led_classdev *led_cdev, struct led_trigger *trig) in trigger_relevant() argument
33 return !trig->trigger_type || trig->trigger_type == led_cdev->trigger_type; in trigger_relevant()
41 struct led_classdev *led_cdev = dev_get_drvdata(dev); in led_trigger_write() local
45 mutex_lock(&led_cdev->led_access); in led_trigger_write()
47 if (led_sysfs_is_disabled(led_cdev)) { in led_trigger_write()
53 led_trigger_remove(led_cdev); in led_trigger_write()
59 if (sysfs_streq(buf, trig->name) && trigger_relevant(led_cdev, trig)) { in led_trigger_write()
60 down_write(&led_cdev->trigger_lock); in led_trigger_write()
61 led_trigger_set(led_cdev, trig); in led_trigger_write()
62 up_write(&led_cdev->trigger_lock); in led_trigger_write()
73 mutex_unlock(&led_cdev->led_access); in led_trigger_write()
95 struct led_classdev *led_cdev) in led_trigger_format() argument
99 led_cdev->trigger ? "none" : "[none]"); in led_trigger_format()
104 if (!trigger_relevant(led_cdev, trig)) in led_trigger_format()
107 hit = led_cdev->trigger && !strcmp(led_cdev->trigger->name, trig->name); in led_trigger_format()
130 struct led_classdev *led_cdev = dev_get_drvdata(dev); in led_trigger_read() local
135 down_read(&led_cdev->trigger_lock); in led_trigger_read()
137 len = led_trigger_format(NULL, 0, led_cdev); in led_trigger_read()
140 up_read(&led_cdev->trigger_lock); in led_trigger_read()
144 len = led_trigger_format(data, len + 1, led_cdev); in led_trigger_read()
146 up_read(&led_cdev->trigger_lock); in led_trigger_read()
158 int led_trigger_set(struct led_classdev *led_cdev, struct led_trigger *trig) in led_trigger_set() argument
165 if (!led_cdev->trigger && !trig) in led_trigger_set()
172 if (led_cdev->trigger) { in led_trigger_set()
173 spin_lock(&led_cdev->trigger->leddev_list_lock); in led_trigger_set()
174 list_del_rcu(&led_cdev->trig_list); in led_trigger_set()
175 spin_unlock(&led_cdev->trigger->leddev_list_lock); in led_trigger_set()
180 cancel_work_sync(&led_cdev->set_brightness_work); in led_trigger_set()
181 led_stop_software_blink(led_cdev); in led_trigger_set()
182 if (led_cdev->trigger->deactivate) in led_trigger_set()
183 led_cdev->trigger->deactivate(led_cdev); in led_trigger_set()
184 device_remove_groups(led_cdev->dev, led_cdev->trigger->groups); in led_trigger_set()
185 led_cdev->trigger = NULL; in led_trigger_set()
186 led_cdev->trigger_data = NULL; in led_trigger_set()
187 led_cdev->activated = false; in led_trigger_set()
188 led_cdev->flags &= ~LED_INIT_DEFAULT_TRIGGER; in led_trigger_set()
189 led_set_brightness(led_cdev, LED_OFF); in led_trigger_set()
193 list_add_tail_rcu(&led_cdev->trig_list, &trig->led_cdevs); in led_trigger_set()
195 led_cdev->trigger = trig; in led_trigger_set()
198 ret = trig->activate(led_cdev); in led_trigger_set()
205 ret = device_add_groups(led_cdev->dev, trig->groups); in led_trigger_set()
207 dev_err(led_cdev->dev, "Failed to add trigger attributes\n"); in led_trigger_set()
215 if (kobject_uevent_env(&led_cdev->dev->kobj, KOBJ_CHANGE, envp)) in led_trigger_set()
216 dev_err(led_cdev->dev, in led_trigger_set()
226 trig->deactivate(led_cdev); in led_trigger_set()
229 spin_lock(&led_cdev->trigger->leddev_list_lock); in led_trigger_set()
230 list_del_rcu(&led_cdev->trig_list); in led_trigger_set()
231 spin_unlock(&led_cdev->trigger->leddev_list_lock); in led_trigger_set()
233 led_cdev->trigger = NULL; in led_trigger_set()
234 led_cdev->trigger_data = NULL; in led_trigger_set()
235 led_set_brightness(led_cdev, LED_OFF); in led_trigger_set()
242 void led_trigger_remove(struct led_classdev *led_cdev) in led_trigger_remove() argument
244 down_write(&led_cdev->trigger_lock); in led_trigger_remove()
245 led_trigger_set(led_cdev, NULL); in led_trigger_remove()
246 up_write(&led_cdev->trigger_lock); in led_trigger_remove()
250 void led_trigger_set_default(struct led_classdev *led_cdev) in led_trigger_set_default() argument
254 if (!led_cdev->default_trigger) in led_trigger_set_default()
258 down_write(&led_cdev->trigger_lock); in led_trigger_set_default()
260 if (!strcmp(led_cdev->default_trigger, trig->name) && in led_trigger_set_default()
261 trigger_relevant(led_cdev, trig)) { in led_trigger_set_default()
262 led_cdev->flags |= LED_INIT_DEFAULT_TRIGGER; in led_trigger_set_default()
263 led_trigger_set(led_cdev, trig); in led_trigger_set_default()
267 up_write(&led_cdev->trigger_lock); in led_trigger_set_default()
289 struct led_classdev *led_cdev; in led_trigger_register() local
311 list_for_each_entry(led_cdev, &leds_list, node) { in led_trigger_register()
312 down_write(&led_cdev->trigger_lock); in led_trigger_register()
313 if (!led_cdev->trigger && led_cdev->default_trigger && in led_trigger_register()
314 !strcmp(led_cdev->default_trigger, trig->name) && in led_trigger_register()
315 trigger_relevant(led_cdev, trig)) { in led_trigger_register()
316 led_cdev->flags |= LED_INIT_DEFAULT_TRIGGER; in led_trigger_register()
317 led_trigger_set(led_cdev, trig); in led_trigger_register()
319 up_write(&led_cdev->trigger_lock); in led_trigger_register()
329 struct led_classdev *led_cdev; in led_trigger_unregister() local
341 list_for_each_entry(led_cdev, &leds_list, node) { in led_trigger_unregister()
342 down_write(&led_cdev->trigger_lock); in led_trigger_unregister()
343 if (led_cdev->trigger == trig) in led_trigger_unregister()
344 led_trigger_set(led_cdev, NULL); in led_trigger_unregister()
345 up_write(&led_cdev->trigger_lock); in led_trigger_unregister()
384 struct led_classdev *led_cdev; in led_trigger_event() local
390 list_for_each_entry_rcu(led_cdev, &trig->led_cdevs, trig_list) in led_trigger_event()
391 led_set_brightness(led_cdev, brightness); in led_trigger_event()
402 struct led_classdev *led_cdev; in led_trigger_blink_setup() local
408 list_for_each_entry_rcu(led_cdev, &trig->led_cdevs, trig_list) { in led_trigger_blink_setup()
410 led_blink_set_oneshot(led_cdev, &delay_on, &delay_off, in led_trigger_blink_setup()
413 led_blink_set_nosleep(led_cdev, delay_on, delay_off); in led_trigger_blink_setup()