Re: [PATCH v3 2/2] watchdog: Add Watchdog Timer driver for RZ/G2L

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi Biju,

On Tue, Nov 30, 2021 at 10:59 AM Biju Das <biju.das.jz@xxxxxxxxxxxxxx> wrote:
> > Subject: Re: [PATCH v3 2/2] watchdog: Add Watchdog Timer driver for RZ/G2L
> > On 11/22/21 3:35 AM, Biju Das wrote:
> > > Add Watchdog Timer driver for RZ/G2L SoC.
> > >
> > > WDT IP block supports normal watchdog timer function and reset request
> > > function due to CPU parity error.
> > >
> > > This driver currently supports normal watchdog timer function and
> > > later will add support for reset request function due to CPU parity
> > > error.
> > >
> > > Signed-off-by: Biju Das <biju.das.jz@xxxxxxxxxxxxxx>
> > > Reviewed-by: Guenter Roeck <linux@xxxxxxxxxxxx>

> > > --- /dev/null
> > > +++ b/drivers/watchdog/rzg2l_wdt.c
> > > @@ -0,0 +1,255 @@
> > > +// SPDX-License-Identifier: GPL-2.0
> > > +/*
> > > + * Renesas RZ/G2L WDT Watchdog Driver
> > > + *
> > > + * Copyright (C) 2021 Renesas Electronics Corporation  */ #include
> > > +<linux/bitops.h> #include <linux/clk.h> #include <linux/delay.h>
> > > +#include <linux/io.h> #include <linux/kernel.h> #include
> > > +<linux/module.h> #include <linux/of.h> #include
> > > +<linux/platform_device.h> #include <linux/pm_runtime.h> #include
> > > +<linux/reset.h> #include <linux/watchdog.h>
> > > +
> > > +#define WDTCNT             0x00
> > > +#define WDTSET             0x04
> > > +#define WDTTIM             0x08
> > > +#define WDTINT             0x0C
> > > +#define WDTCNT_WDTEN       BIT(0)
> > > +#define WDTINT_INTDISP     BIT(0)
> > > +
> > > +#define WDT_DEFAULT_TIMEOUT                60U
> > > +
> > > +/* Setting period time register only 12 bit set in WDTSET[31:20] */
> > > +#define WDTSET_COUNTER_MASK                (0xFFF00000)
> > > +#define WDTSET_COUNTER_VAL(f)              ((f) << 20)
> > > +
> > > +#define F2CYCLE_NSEC(f)                    (1000000000 / (f))
> > > +#define WDT_CYCLE_MSEC(f, wdttime) ((1024 * 1024 * (((u64)wdttime)
> > + 1)) / \
> > > +                                    ((f) / 1000000))
> >
> > This macro generates a 64 bit divide operation - as noticed by 0-day - and
> > will have to be rewritten.
> >
>
> OK, will rewrite like below to make the ARCH=m68k compiler happy
>
> -#define F2CYCLE_NSEC(f)                        (1000000000 / (f))
> -#define WDT_CYCLE_MSEC(f, wdttime)     ((1024 * 1024 * (((u64)wdttime) + 1)) / \
> -                                        ((f) / 1000000))
> +#define F2CYCLE_NSEC(f)                (1000000000 / (f))
> +#define WDT_CYCLE_MSEC_CONST           (1024 * 1024 * (u64)1000000)

1000000ULL (casts are evil ;-)

>
> +static u32 rzg2l_wdt_get_cycle_msec(u32 cycle, u32 wdttime)

cycle == priv->osc_clk_rate, i.e. unsigned long?

> +{
> +       /* timer_cycle = clk_cycle *1024 *1024 * (WDTTIME + 1) */

Comment not needed if you get rid of WDT_CYCLE_MSEC_CONST?

> +       u64 timer_cycle_ms = WDT_CYCLE_MSEC_CONST * (wdttime + 1);
> +       do_div(timer_cycle_ms, cycle);

div64_ul()?

> +
> +       return timer_cycle_ms;
> +}

Gr{oetje,eeting}s,

                        Geert

--
Geert Uytterhoeven -- There's lots of Linux beyond ia32 -- geert@xxxxxxxxxxxxxx

In personal conversations with technical people, I call myself a hacker. But
when I'm talking to journalists I just say "programmer" or something like that.
                                -- Linus Torvalds



[Index of Archives]     [Linux ARM Kernel]     [Linux ARM]     [Linux Omap]     [Fedora ARM]     [IETF Annouce]     [Security]     [Bugtraq]     [Linux]     [Linux OMAP]     [Linux MIPS]     [eCos]     [Asterisk Internet PBX]     [Linux API]

  Powered by Linux