[PATCH u-boot v2 1/2] drivers: spi: Add support for disabling FMC_WDT2 for aspeed

Marc Olberding molberding at nvidia.com
Wed Dec 17 12:15:01 AEDT 2025


On Wed, Dec 17, 2025 at 09:53:33AM +1030, Andrew Jeffery wrote:
> On Tue, 2025-12-02 at 15:52 -0800, Marc Olberding wrote:
> > Adds support for disabling the ast2600 FMC_WDT2 through
> > a device tree entry in the fmc node.
> > Set `aspeed,watchdog-disable` in your device tree to have
> > the driver disable it.
> > 
> > Signed-off-by: Marc Olberding <molberding at nvidia.com>
> > ---
> >  drivers/spi/aspeed_spi.c | 19 +++++++++++++++----
> >  1 file changed, 15 insertions(+), 4 deletions(-)
> > 
> > diff --git a/drivers/spi/aspeed_spi.c b/drivers/spi/aspeed_spi.c
> > index 54520122f1c48c8b2052b4b1e47445a9b990d25e..de954e477aa15e6d1be042a2aee47f5a501178da 100644
> > --- a/drivers/spi/aspeed_spi.c
> > +++ b/drivers/spi/aspeed_spi.c
> > @@ -30,14 +30,16 @@ struct aspeed_spi_regs {
> >  					/* 0x30 .. 0x38 Segment Address */
> >  	u32 _reserved1[5];		/* .. */
> >  	u32 soft_rst_cmd_ctrl;	/* 0x50 Auto Soft-Reset Command Control */
> > -	u32 _reserved2[11];		/* .. */
> > +	u32 _reserved2[4];		/* .. */
> > +	u32 wdt2_ctrl;			/* 0x64 FMC_WDT2 control */
> > +	u32 _reserved3[6];		/* .. */
> 
> Ugh (passing commentary, not your fault).
> 
Yeah this sucks, if you have a better idea, let me know.

> >  	/*
> >  	 * Set safe default settings for each device. These will be
> >  	 * tuned after the SPI flash devices are probed.
> > @@ -1907,6 +1914,10 @@ static int aspeed_spi_probe(struct udevice *bus)
> >  	 * SPI controllers
> >  	 */
> >  	priv->is_fmc = dev_get_driver_data(bus);
> > +	if (device_is_compatible(bus, "aspeed,ast2600-fmc") &&
> > +	    dev_read_bool(bus, "aspeed,watchdog-disable"))
> > +		priv->disable_wdt = true;
> 
> We're not setting it to false, just declaring it above, which means if
> this branch isn't taken then its value is undefined.
> 
> Perhaps initialise it to false by default.

Ah, I figured that priv would've been callocd by the driver framework
before being passed to probe.
I'll change this to 
priv->disable_wdt = <boolean expression>

in the next rev. Thanks.

> > +
> 
> Unnecessary new-line?
> 
> >  
> >  	ret = aspeed_spi_controller_init(priv);
> >  	if (ret)
ack, will fix.

Thanks for the review.


More information about the openbmc mailing list