On Wed, Jan 12, 2022 at 12:12:58AM +0400, Alexey Sheplyakov wrote: > On Tue, Jan 11, 2022 at 08:30:28PM +0200, Andy Shevchenko wrote: > > On Tue, Jan 11, 2022 at 05:28:47PM +0400, asheplyakov@xxxxxxxxxx wrote: > > > Refuse to change the clock rate if clk_round_rate() returns > > > a rate which is way too off (i.e. by more than 1/16 from the one > > > necessary for a given baud rate). In particular this happens if > > > the requested rate is below the minimum supported by the clock. > > > > > > Fixes the UART console on BE-M1000 SoC. Without this patch the > > > console gets garbled immediately after loading the driver. > > > dw8250_set_termios tries to configure the baud rate (115200), > > > and calls clk_round_rate to figure out the supported rate closest > > > to 1843200 Hz (which is 115200 * 16). However the (SoC-specific) > > > clock driver returns 4705882 Hz. This frequency is way too off, > > > hence after setting it the console gets garbled. > > > > So, the root cause is to understand _why_ the clock provider is uncapable > > to fulfil the request. Any investigation has been conducted? > > Yes. On BE-M1000 SoC Linux has no direct control over (most) clocks. > The registers of CMU (clock management unit) are accessible only from > the secure world, therefore clocks are managed by the firmware (ARM-TF). > Linux' driver is a shim which calls into the firmware. And that > 4705882 Hz is exactly what is returned by firmware. > > > - if (rate > 0) { > > > + if (rate > 0 && rate >= baud * 15 && rate <= baud * 17) { > > > > It doesn't fell like a correct fix. > > What is the correct way to check if the rate returned by clk_round_rate > makes sense for the (new) baud rate? See, clk_round_rate is supposed to > give a supported rate which is closest to the requested one. Usually it > appears to be "close enough" to the requested rate (or an error), however > (as far as I understand) there is no a formal requirement (and it's up > to the driver to decide how close is "close enough"). > > Or should we just hope that the clock provider does the right thing? Does this hardware even work? I mean is it possible to change baud rate? To me the proper solution sounds like the driver on this hardware should not use CCF approach, i.e. use only DLAB for baud rate and fixed rate clock of the bus or so. -- With Best Regards, Andy Shevchenko