From: Marc Kleine-Budde <mkl@pengutronix.de>
To: Juergen Beisert <jbe@pengutronix.de>
Cc: barebox@lists.infradead.org
Subject: Re: [PATCH 2/2] Add two architectures which can detect the reset source
Date: Wed, 20 Jun 2012 16:59:46 +0200 [thread overview]
Message-ID: <4FE1E562.7050706@pengutronix.de> (raw)
In-Reply-To: <1340202731-30831-3-git-send-email-jbe@pengutronix.de>
[-- Attachment #1.1: Type: text/plain, Size: 6286 bytes --]
On 06/20/2012 04:32 PM, Juergen Beisert wrote:
> These are examples how to provide the reset source. Not really tested on
> the corresponding hardware yet.
>
> Signed-off-by: Juergen Beisert <jbe@pengutronix.de>
> ---
> arch/arm/mach-imx/Makefile | 1 +
> arch/arm/mach-imx/reset_source.c | 59 ++++++++++++++++++++++++++++++++++
> arch/arm/mach-samsung/Makefile | 1 +
> arch/arm/mach-samsung/reset_source.c | 56 ++++++++++++++++++++++++++++++++
> 4 files changed, 117 insertions(+)
> create mode 100644 arch/arm/mach-imx/reset_source.c
> create mode 100644 arch/arm/mach-samsung/reset_source.c
>
> diff --git a/arch/arm/mach-imx/Makefile b/arch/arm/mach-imx/Makefile
> index 03e2421..7da8cec 100644
> --- a/arch/arm/mach-imx/Makefile
> +++ b/arch/arm/mach-imx/Makefile
> @@ -1,4 +1,5 @@
> obj-y += clocksource.o gpio.o
> +obj-$(CONFIG_GLOBALVAR) += reset_source.o
> obj-$(CONFIG_ARCH_IMX1) += speed-imx1.o imx1.o iomux-v1.o
> obj-$(CONFIG_ARCH_IMX25) += speed-imx25.o imx25.o iomux-v3.o
> obj-$(CONFIG_ARCH_IMX21) += speed-imx21.o imx21.o iomux-v1.o
> diff --git a/arch/arm/mach-imx/reset_source.c b/arch/arm/mach-imx/reset_source.c
> new file mode 100644
> index 0000000..79e5337
> --- /dev/null
> +++ b/arch/arm/mach-imx/reset_source.c
> @@ -0,0 +1,59 @@
> +/*
> + * (C) Copyright 2012 Juergen Beisert - <kernel@pengutronix.de>
> + *
> + * This program is free software; you can redistribute it and/or
> + * modify it under the terms of the GNU General Public License as
> + * published by the Free Software Foundation; either version 2 of
> + * the License, or (at your option) any later version.
> + *
> + * This program is distributed in the hope that it will be useful,
> + * but WITHOUT ANY WARRANTY; without even the implied warranty of
> + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
> + * GNU General Public License for more details.
> + */
> +
> +#include <common.h>
> +#include <init.h>
> +#include <io.h>
> +#include <reset_source.h>
> +#include <mach/imx-regs.h>
> +
> +#ifdef CONFIG_ARCH_IMX1
> +# define WDOG_WRSR 0x08
> +# define WDOG_WRSR_TOUT (1 << 0)
> +/* let the compiler sort out useless code on this arch */
> +# define WDOG_WRSR_SFTW 0
> +# define WDOG_WRSR_EXT 0
> +# define WDOG_WRSR_PWR 0
> +#else
> +# define WDOG_WRSR 0x04
> +# define WDOG_WRSR_SFTW (1 << 0)
> +# define WDOG_WRSR_TOUT (1 << 1)
> +# define WDOG_WRSR_EXT (1 << 2)
> +# define WDOG_WRSR_PWR (1 << 3)
> +#endif
> +
> +static int imx_detect_reset_source(void)
> +{
> + u16 reg = readw(IMX_WDT_BASE + WDOG_WRSR);
> +
> + if (reg & WDOG_WRSR_PWR) {
> + set_reset_source(RESET_POR);
> + return 0;
> + }
> +
> + if (reg & (WDOG_WRSR_EXT | WDOG_WRSR_SFTW)) {
> + set_reset_source(RESET_RST);
> + return 0;
> + }
> +
> + if (reg & WDOG_WRSR_TOUT) {
> + set_reset_source(RESET_WDG);
> + return 0;
> + }
> +
> + /* else keep the default 'unknown' state */
> + return 0;
> +}
> +
> +device_initcall(imx_detect_reset_source);
> diff --git a/arch/arm/mach-samsung/Makefile b/arch/arm/mach-samsung/Makefile
> index d7344c8..74799c5 100644
> --- a/arch/arm/mach-samsung/Makefile
> +++ b/arch/arm/mach-samsung/Makefile
> @@ -1,4 +1,5 @@
> obj-y += s3c-timer.o generic.o
> +obj-$(CONFIG_GLOBALVAR) += reset_source.o
> obj-lowlevel-$(CONFIG_ARCH_S3C24xx) += lowlevel-s3c24x0.o
> obj-lowlevel-$(CONFIG_ARCH_S5PCxx) += lowlevel-s5pcxx.o
> obj-$(CONFIG_ARCH_S3C24xx) += gpio-s3c24x0.o s3c24xx-clocks.o mem-s3c24x0.o
> diff --git a/arch/arm/mach-samsung/reset_source.c b/arch/arm/mach-samsung/reset_source.c
> new file mode 100644
> index 0000000..2456e3f
> --- /dev/null
> +++ b/arch/arm/mach-samsung/reset_source.c
> @@ -0,0 +1,56 @@
> +/*
> + * (C) Copyright 2012 Juergen Beisert - <kernel@pengutronix.de>
> + *
> + * This program is free software; you can redistribute it and/or
> + * modify it under the terms of the GNU General Public License as
> + * published by the Free Software Foundation; either version 2 of
> + * the License, or (at your option) any later version.
> + *
> + * This program is distributed in the hope that it will be useful,
> + * but WITHOUT ANY WARRANTY; without even the implied warranty of
> + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
> + * GNU General Public License for more details.
> + */
> +
> +#include <common.h>
> +#include <init.h>
> +#include <io.h>
> +#include <reset_source.h>
> +#include <mach/s3c-iomap.h>
> +
> +/* S3C2440 relevant */
> +#define S3C2440_GSTATUS2 0xb4
> +# define S3C2440_GSTATUS2_PWRST (1 << 0)
> +# define S3C2440_GSTATUS2_SLEEPRST (1 << 1)
> +# define S3C2440_GSTATUS2_WDRST (1 << 2)
> +
> +static int s3c_detect_reset_source(void)
> +{
> + u32 reg = readl(S3C_GPIO_BASE + S3C2440_GSTATUS2);
> +
> + if (reg & S3C2440_GSTATUS2_PWRST) {
> + set_reset_source(RESET_POR);
> + writel(S3C2440_GSTATUS2_PWRST,
> + S3C_GPIO_BASE + S3C2440_GSTATUS2);
> + return 0;
> + }
> +
> + if (reg & S3C2440_GSTATUS2_SLEEPRST) {
> + set_reset_source(RESET_WKE);
> + writel(S3C2440_GSTATUS2_SLEEPRST,
> + S3C_GPIO_BASE + S3C2440_GSTATUS2);
> + return 0;
> + }
> +
> + if (reg & S3C2440_GSTATUS2_WDRST) {
> + set_reset_source(RESET_WDG);
> + writel(S3C2440_GSTATUS2_WDRST,
> + S3C_GPIO_BASE + S3C2440_GSTATUS2);
> + return 0;
> + }
That "writel(S3C2440_GSTATUS2_WDRST...)" is the same in each line, isn't it?
What about this:
if (reg & S3C2440_GSTATUS2_PWRST)
set_reset_source(RESET_POR);
else if (...)
else if (..)
else
return 0;
writel(S3C2440_GSTATUS2_WDRST,
S3C_GPIO_BASE +S3C2440_GSTATUS2);
return 0;
}
(If you convert the imx into "if else if" the function will be a
shorter, because you don't need any return 0 and "{ }")
> +
> + /* else keep the default 'unknown' state */
> + return 0;
> +}
> +
> +device_initcall(s3c_detect_reset_source);
Marc
--
Pengutronix e.K. | Marc Kleine-Budde |
Industrial Linux Solutions | Phone: +49-231-2826-924 |
Vertretung West/Dortmund | Fax: +49-5121-206917-5555 |
Amtsgericht Hildesheim, HRA 2686 | http://www.pengutronix.de |
[-- Attachment #1.2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 262 bytes --]
[-- Attachment #2: Type: text/plain, Size: 149 bytes --]
_______________________________________________
barebox mailing list
barebox@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/barebox
next prev parent reply other threads:[~2012-06-20 14:59 UTC|newest]
Thread overview: 19+ messages / expand[flat|nested] mbox.gz Atom feed top
2012-06-20 14:32 [PATCH] Enable a way to provide the reason for "being here" Juergen Beisert
2012-06-20 14:32 ` [PATCH 1/2] " Juergen Beisert
2012-06-20 14:53 ` Marc Kleine-Budde
2012-06-20 15:08 ` Juergen Beisert
2012-06-20 18:50 ` Uwe Kleine-König
2012-06-20 19:09 ` Juergen Beisert
2012-06-20 19:27 ` Uwe Kleine-König
2012-06-20 19:59 ` Juergen Beisert
2012-06-20 20:09 ` Uwe Kleine-König
2012-06-20 20:57 ` Juergen Beisert
2012-06-20 14:32 ` [PATCH 2/2] Add two architectures which can detect the reset source Juergen Beisert
2012-06-20 14:59 ` Marc Kleine-Budde [this message]
2012-06-20 15:05 ` Juergen Beisert
2012-06-20 15:09 ` Marc Kleine-Budde
-- strict thread matches above, loose matches on Subject: below --
2012-06-21 9:16 [PATCHv2] Enable a way to provide the reason for "being here" Juergen Beisert
2012-06-21 9:16 ` [PATCH 2/2] Add two architectures which can detect the reset source Juergen Beisert
2012-06-21 18:27 ` Sascha Hauer
2012-06-21 19:01 ` Juergen Beisert
2012-06-21 19:03 ` Sascha Hauer
2012-06-21 21:50 ` Roberto Nibali
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=4FE1E562.7050706@pengutronix.de \
--to=mkl@pengutronix.de \
--cc=barebox@lists.infradead.org \
--cc=jbe@pengutronix.de \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.