leds/leds-pca9532.c: sleeping function called in .brightness_set()

From: Guennadi Liakhovetski
Date: Mon Nov 24 2008 - 04:51:56 EST


Hi,

this seems to explicitly violate the API as documented in
include/linux/leds.h:

/* Set LED brightness level */
/* Must not sleep, use a workqueue if needed */
void (*brightness_set)(struct led_classdev *led_cdev,
enum led_brightness brightness);

and also contradicts some other drivers, e.g., pca955x, which do use a
workqueue as suggested: leds-pca9532.c::pca9532_set_brightness uses a
mutex for locking and calls i2c_smbus functions directly. Needs to be
fixed (if it hasn't been fixed yet), probably, also vor 2.6.27-stable.

Thanks
Guennadi
---
Guennadi Liakhovetski, Ph.D.

DENX Software Engineering GmbH, MD: Wolfgang Denk & Detlev Zundel
HRB 165235 Munich, Office: Kirchenstr.5, D-82194 Groebenzell, Germany
Phone: +49-8142-66989-0 Fax: +49-8142-66989-80 Email: office@xxxxxxx
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/