Message ID | 20240228-b4-pl011-v2-1-92129ba2e23a@outlook.com |
---|---|
State | Accepted |
Commit | 91febe80c9f2434170c6c2e866942c75372aed75 |
Delegated to: | Tom Rini |
Headers | show |
Series | [v2] serial: pl01x: set baudrate when probing | expand |
On Wed, Feb 28, 2024 at 06:57:52PM +0800, Yang Xiwen via B4 Relay wrote: > From: Yang Xiwen <forbidden405@outlook.com> > > It is found that when DM is enabled, only generic init function is > called in .probe(). Baudrate is never honored. Add a function call > to .setbrg() when probing so that we can update the baudrate of the > serial device. > > Signed-off-by: Yang Xiwen <forbidden405@outlook.com> Applied to u-boot/next, thanks!
diff --git a/drivers/serial/serial_pl01x.c b/drivers/serial/serial_pl01x.c index 428a4d210de5..f04c21e08264 100644 --- a/drivers/serial/serial_pl01x.c +++ b/drivers/serial/serial_pl01x.c @@ -290,6 +290,7 @@ int pl01x_serial_probe(struct udevice *dev) { struct pl01x_serial_plat *plat = dev_get_plat(dev); struct pl01x_priv *priv = dev_get_priv(dev); + int ret; #if CONFIG_IS_ENABLED(OF_PLATDATA) struct dtd_serial_pl01x *dtplat = &plat->dtplat; @@ -301,10 +302,14 @@ int pl01x_serial_probe(struct udevice *dev) #endif priv->type = plat->type; - if (!plat->skip_init) - return pl01x_generic_serial_init(priv->regs, priv->type); - else + if (!plat->skip_init) { + ret = pl01x_generic_serial_init(priv->regs, priv->type); + if (ret) + return ret; + return pl01x_serial_setbrg(dev, gd->baudrate); + } else { return 0; + } } int pl01x_serial_getc(struct udevice *dev)