Hello, On Mon, Apr 29, 2019 at 06:28:47PM +0200, Thierry Reding wrote: > On Mon, Apr 29, 2019 at 03:11:27PM +0200, Uwe Kleine-König wrote: > > On Mon, Apr 29, 2019 at 01:18:55PM +0200, Thierry Reding wrote: > > > On Mon, Apr 29, 2019 at 08:56:13AM +0200, Uwe Kleine-König wrote: > > > > There are currently no rules how the driver should behave for example if > > > > the consumer requests > > > > > > > > .duty_cycle = 10, .period = 50 > > > > > > > > and the hardware can only implement multiples of 3 for both values. The > > > > obvious candidates are: > > > > > > > > - .duty_cycle = 9, .period = 51 (round nearest for both) > > > > - .duty_cycle = 12, .period = 51 (round up) > > > > - .duty_cycle = 9, .period = 48 (round down) > > > > - .duty_cycle = 9, .period = 45 (round duty_cycle and keep proportion) > > > > - return error (which code?) > > > > > > > > And there are some other variants (e.g. round duty_cycle to nearest and > > > > period in the same direction) that might be sensible. > > > > > > The problem is that probably all of the above are valid, though maybe > > > not for all cases. The choice of algorithm probably depends on both the > > > PWM driver and the consumer, so I don't think fixing things to one such > > > algorithm is going to improve anything. > > > > But if you have pwm_round_state (which implements rounding down for > > example) you could easily implement a helper that rounds nearest or up. > > If however each driver rounds the way it prefers coming up with a helper > > for rounding up is considerably harder. > > pwm_round_state() is fundamentally racy. What if, for example, you have > two consumers racing to set two PWMs provided by the same controller. If > you have some dependency between the two PWMs (perhaps they need to > share the same divider or something like that), then between the time > where pwm_round_state() returns and pwm_apply_state() is called, the > results of the pwm_round_state() may no longer be valid. Yes, that's somewhat right. That is a problem that all approaches have that allow to determine the result of a given request without actually applying it. (Same for clk_round_rate() for example.) I think that it won't be possible to map all use cases without such an approach however. But the effect of the race can be minimised if I calculate a good PWM state (which might not be optimal because of the race) and then use pwm_apply_state_exact(). Having said that, we already have a very similar problem today. Each driver that does clk_get_rate without installing a notifier for frequency changes might suffer from unexpected results if another clk consumer changes the given clk. > > > > Also it should be possible to know the result before actually > > > > configuring the hardware. Otherwise things might already go wrong > > > > because the driver implements a setting that is too far from the > > > > requested configuration. > > > > > > I agree. > > > > > > Perhaps somebody with more experience with pwm-regulator can chime in > > > here, but it sounds to me like if you really want to accurately output a > > > voltage, you may want to hand-tune the duty-cycle/period pairs that are > > > used for pwm-regulator. > > > > This might be more ugly than needed because then you have to setup the > > table in dependance of the used PWM. > > Well, that's what you have to do anyway. I mean, you can't write one > voltage table that works for one device and then expect it to work for > every other device. DT by definition is a board-level definition. We're talking about different things here. I want that if you assembled the same type of pwm-regulator to an imx machine and a rockchip machine the representation of this regulator in the respective device trees would look identical (apart from the handle to the PWM). Of course this doesn't work for two different types of regulators. The datasheet of the regulator for sure is also agnostic to the actual PWM driving the input and provides a generic table or formula. > > Looking at the pwm-regulator code I > > think the binding is badly worded. The "Duty-Cycle" parameter is used as > > second parameter to pwm_set_relative_duty_cycle (with scale = 100). So > > with the regulator defined in the Voltage Table Example of > > Documentation/devicetree/bindings/regulator/pwm-regulator.txt you'd have > > to configure > > > > .duty_cycle = 2534, .period = 8448 > > > > to get 1.056 V. > > Hm... indeed. Requiring the duty-cycle to be in percent is not a good > idea. That's going to lead to rounding one way or another. > > > > > Note that my considerations are not only about pwm-regulators. > > > > Also in general I prefer a suitable and well reviewed algorithm (if > > possible) over a requirement to provide a hand-tuned table of values in > > a machine-specific device tree. > > I agree that an algorithm is usually better, but if you can't create an > algorithm that works, it's usually better to have a hand-coded fallback > rather than have no working system at all. We're in agreement here. And as there are cases where a suitable algorithm exists, we need some support in the PWM API to actually implement these. pwm_round_state is the best I'm aware of as it is powerful enough to map all requirements I currently think necessary and still it is not too hard to implement the needed callback for the device drivers. > > > According to the device tree bindings there's > > > already support for a voltage table mode where an exact duty-cycle to > > > output voltage correspondence is defined. This is as opposed to the > > > continuous voltage mode where the duty cycle is linearly interpolated > > > based on the requested output voltage. > > > > > > pwm-regulator in voltage table mode could run in "strict" mode with zero > > > deviation allowed, on the assumption that duty-cycle values were hand- > > > picked to give the desired results. For continuous voltage mode it > > > probably doesn't matter all that much, since very exact results can't be > > > guaranteed anyway. > > > > I don't understand the last sentence? Why is it impossible to get exact > > results in continuous voltage mode? > > I didn't say it was impossible. I said it can't be guaranteed. There may > very well be combinations of drivers and consumers where the results > will be accurate, but there may very well be other combinations where > the results won't be. So if you don't know the exact combination, you > can't be sure that the result will be accurate. Either I don't understand what you intend to say, or I fail to see its relevance here. If the device tree specifies a PWM regulator with continuous voltage mode the right thing to do with a request for a certain voltage is to exactly calculate the needed PWM setting with the parameters provided and rely on the PWM driver to implement what it promises. If the PWM driver is buggy or the device tree representation is inaccurate, well there is nothing the PWM framework or the pwm-regulator driver can do about it. Best regards Uwe -- Pengutronix e.K. | Uwe Kleine-König | Industrial Linux Solutions | http://www.pengutronix.de/ | _______________________________________________ Linux-rockchip mailing list Linux-rockchip@xxxxxxxxxxxxxxxxxxx http://lists.infradead.org/mailman/listinfo/linux-rockchip