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_set_brightness(led_cdev, LED_OFF); in led_trigger_set()
192 list_add_tail_rcu(&led_cdev->trig_list, &trig->led_cdevs); in led_trigger_set()
194 led_cdev->trigger = trig; in led_trigger_set()
197 ret = trig->activate(led_cdev); in led_trigger_set()
204 ret = device_add_groups(led_cdev->dev, trig->groups); in led_trigger_set()
206 dev_err(led_cdev->dev, "Failed to add trigger attributes\n"); in led_trigger_set()
214 if (kobject_uevent_env(&led_cdev->dev->kobj, KOBJ_CHANGE, envp)) in led_trigger_set()
215 dev_err(led_cdev->dev, in led_trigger_set()
225 trig->deactivate(led_cdev); in led_trigger_set()
228 spin_lock(&led_cdev->trigger->leddev_list_lock); in led_trigger_set()
229 list_del_rcu(&led_cdev->trig_list); in led_trigger_set()
230 spin_unlock(&led_cdev->trigger->leddev_list_lock); in led_trigger_set()
232 led_cdev->trigger = NULL; in led_trigger_set()
233 led_cdev->trigger_data = NULL; in led_trigger_set()
234 led_set_brightness(led_cdev, LED_OFF); in led_trigger_set()
241 void led_trigger_remove(struct led_classdev *led_cdev) in led_trigger_remove() argument
243 down_write(&led_cdev->trigger_lock); in led_trigger_remove()
244 led_trigger_set(led_cdev, NULL); in led_trigger_remove()
245 up_write(&led_cdev->trigger_lock); in led_trigger_remove()
249 void led_trigger_set_default(struct led_classdev *led_cdev) in led_trigger_set_default() argument
253 if (!led_cdev->default_trigger) in led_trigger_set_default()
257 down_write(&led_cdev->trigger_lock); in led_trigger_set_default()
259 if (!strcmp(led_cdev->default_trigger, trig->name) && in led_trigger_set_default()
260 trigger_relevant(led_cdev, trig)) { in led_trigger_set_default()
261 led_cdev->flags |= LED_INIT_DEFAULT_TRIGGER; in led_trigger_set_default()
262 led_trigger_set(led_cdev, trig); in led_trigger_set_default()
266 up_write(&led_cdev->trigger_lock); in led_trigger_set_default()
288 struct led_classdev *led_cdev; in led_trigger_register() local
310 list_for_each_entry(led_cdev, &leds_list, node) { in led_trigger_register()
311 down_write(&led_cdev->trigger_lock); in led_trigger_register()
312 if (!led_cdev->trigger && led_cdev->default_trigger && in led_trigger_register()
313 !strcmp(led_cdev->default_trigger, trig->name) && in led_trigger_register()
314 trigger_relevant(led_cdev, trig)) { in led_trigger_register()
315 led_cdev->flags |= LED_INIT_DEFAULT_TRIGGER; in led_trigger_register()
316 led_trigger_set(led_cdev, trig); in led_trigger_register()
318 up_write(&led_cdev->trigger_lock); in led_trigger_register()
328 struct led_classdev *led_cdev; in led_trigger_unregister() local
340 list_for_each_entry(led_cdev, &leds_list, node) { in led_trigger_unregister()
341 down_write(&led_cdev->trigger_lock); in led_trigger_unregister()
342 if (led_cdev->trigger == trig) in led_trigger_unregister()
343 led_trigger_set(led_cdev, NULL); in led_trigger_unregister()
344 up_write(&led_cdev->trigger_lock); in led_trigger_unregister()
383 struct led_classdev *led_cdev; in led_trigger_event() local
389 list_for_each_entry_rcu(led_cdev, &trig->led_cdevs, trig_list) in led_trigger_event()
390 led_set_brightness(led_cdev, brightness); in led_trigger_event()
401 struct led_classdev *led_cdev; in led_trigger_blink_setup() local
407 list_for_each_entry_rcu(led_cdev, &trig->led_cdevs, trig_list) { in led_trigger_blink_setup()
409 led_blink_set_oneshot(led_cdev, delay_on, delay_off, in led_trigger_blink_setup()
412 led_blink_set(led_cdev, delay_on, delay_off); in led_trigger_blink_setup()