Hello Guenter,
Thank you for your review!
On Thursday, March 02, 2017, Guenter Roeck wrote:
> > +/*
> > + * Renesas RZ/A Series WDT Driver
> > + *
> > + * Copyright (C) 2017 Renesas Electronics America, Inc.
> > + * Copyright (C) 2017 Chris Brandt
> > + *
> > + * This file is subject to the terms and conditions of the GNU
> > +General Public
> > + * License. See the file "COPYING" in the main directory of this
> > +archive
> > + * for more details.
> > + *
> > + *
>
> The above two lines are unnecessary.
OK.
#I'll assume you mean take out just the last sentence (2 lines), not both
sentences (all 3 lines).
> > +/* Watchdog Timer Registers */
> > +#define WTCSR 0
> > +#define WTCSR_MAGIC 0xA500
> > +#define WTSCR_WT (1<<6)
> > +#define WTSCR_TME (1<<5)
>
> BIT()
OK.
> > +#define WTSCR_CKS(i) i
>
> (i)
OK.
> > +#define WRCSR_CLEAR_WOVF 0xA500 /* special value */
>
> Please use
> #define SOMETHING<tab>value
> throughout and make sure value is aligned.
OK.
> > + rate = clk_get_rate(priv->clk);
> > + if (!rate)
> > + return -ENOENT;
> > +
> > + /* Assume slowest clock rate possible (CKS=7) */
> > + rate /= 16384;
> > +
>
> The rate check should probably be here to avoid situations where rate <
> 16384.
Do I need that if it's technically not possible to have a 'rate' less than
25MHz?
These watchdogs HW are always feed directly from the peripheral clock and there
is no such thing as a 16kHz peripheral block an any Renesas SoC.
> > + priv->wdev.info = &rza_wdt_ident,
> > + priv->wdev.ops = &rza_wdt_ops,
> > + priv->wdev.parent = &pdev->dev;
> > +
> > + /*
> > + * Since the max possible timeout of our 8-bit count register is
> less
> > + * than a second, we must use max_hw_heartbeat_ms.
> > + */
> > + priv->wdev.max_hw_heartbeat_ms = (1000 * U8_MAX)/rate;
>
> space before and after /
OK.
#Funny because checkpatch.pl said it didn't like a space on one side but
not the other, so I choose no spaces and it was happy. I'm way below 80
characters for that line so it doesn't matter to me.
> > + dev_info(&pdev->dev, "max hw timeout of %dms\n",
> > + priv->wdev.max_hw_heartbeat_ms);
>
> dev_dbg ?
OK.
#I guess we don't need to see that info on every boot.
> > +
> > + priv->wdev.min_timeout = 1;
> > + priv->wdev.timeout = DEFAULT_TIMEOUT;
> > +
>
> Add watchdog_init_timeout(&priv->wdev, 0, &pdev->dev); to optionally get
> the timeout from dt ?
OK. Good idea.
> > + platform_set_drvdata(pdev, priv);
> > + watchdog_set_drvdata(&priv->wdev, priv);
> > +
> > + ret = watchdog_register_device(&priv->wdev);
>
> devm_watchdog_register_device()
OK.
> > + if (ret < 0)
> > + return ret;
> > +
> > + return 0;
> > +}
> > +
> > +static int rza_wdt_remove(struct platform_device *pdev) {
> > + struct rza_wdt *priv = platform_get_drvdata(pdev);
> > +
> > + watchdog_unregister_device(&priv->wdev);
> > + iounmap(priv->base);
>
> iounmap is unnecessary (and wrong).
Anything mapped with devm_ioremap_resource() automatically gets unmapped
when the drive gets unloaded?
I didn't know that.
I'll wait till the end of the day to see if anyone finds anything else, and
then I'll send out a v5.
Chris