> So... To me it's still slightly unclear when should one write a PWM > driver and when a LED driver. But I would say that as the TLC591xx > outputs a PWM signal, it should be a PWM driver. Then the different > users of this PWM signal could be made on top of that (LED, backlight, GPO). > > What would be the technical drawbacks with having the TLC591xx driver as > a PWM, instead of LED? Hi Tomi We have been through this once, but the big technical drawback is that this hardware cannot do what the Linux Kernel defines as PWM. It cannot correctly implement the PMW call: int pwm_config(struct pwm_device *pwm, int duty_ns, int period_ns); This hardware has a fixed period, since it is clocked at 97-kHz. So you cannot set the period. The duty is also somewhat restrictive, in that it only allows 1/256 increments of the 97Khz. This hardware does however perfectly fit the LED API: enum led_brightness { LED_OFF = 0, LED_HALF = 127, LED_FULL = 255, }; void (*brightness_set)(struct led_classdev *led_cdev, enum led_brightness brightness); So we can model it perfectly as an LED driver, or badly as a PWM driver. Andrew -- To unsubscribe from this list: send the line "unsubscribe devicetree" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html