mirror of
https://github.com/u-boot/u-boot.git
synced 2025-04-20 11:55:03 +00:00
ti: wdt: common: Make the wdt IP defines common for the TI platform
Signed-off-by: Lukasz Majewski <lukma@denx.de> Reviewed-by: Tom Rini <trini@konsulko.com>
This commit is contained in:
parent
04735a8fc4
commit
d7ebbe9dc4
3 changed files with 63 additions and 47 deletions
|
@ -66,29 +66,9 @@
|
||||||
#define PRM_RSTCTRL_RESET 0x01
|
#define PRM_RSTCTRL_RESET 0x01
|
||||||
#define PRM_RSTST_WARM_RESET_MASK 0x232
|
#define PRM_RSTST_WARM_RESET_MASK 0x232
|
||||||
|
|
||||||
/*
|
|
||||||
* Watchdog:
|
|
||||||
* Using the prescaler, the OMAP watchdog could go for many
|
|
||||||
* months before firing. These limits work without scaling,
|
|
||||||
* with the 60 second default assumed by most tools and docs.
|
|
||||||
*/
|
|
||||||
#define TIMER_MARGIN_MAX (24 * 60 * 60) /* 1 day */
|
|
||||||
#define TIMER_MARGIN_DEFAULT 60 /* 60 secs */
|
|
||||||
#define TIMER_MARGIN_MIN 1
|
|
||||||
|
|
||||||
#define PTV 0 /* prescale */
|
|
||||||
#define GET_WLDR_VAL(secs) (0xffffffff - ((secs) * (32768/(1<<PTV))) + 1)
|
|
||||||
#define WDT_WWPS_PEND_WCLR BIT(0)
|
|
||||||
#define WDT_WWPS_PEND_WLDR BIT(2)
|
|
||||||
#define WDT_WWPS_PEND_WTGR BIT(3)
|
|
||||||
#define WDT_WWPS_PEND_WSPR BIT(4)
|
|
||||||
|
|
||||||
#define WDT_WCLR_PRE BIT(5)
|
|
||||||
#define WDT_WCLR_PTV_OFF 2
|
|
||||||
|
|
||||||
#ifndef __KERNEL_STRICT_NAMES
|
#ifndef __KERNEL_STRICT_NAMES
|
||||||
#ifndef __ASSEMBLY__
|
#ifndef __ASSEMBLY__
|
||||||
|
#include <asm/ti-common/omap_wdt.h>
|
||||||
|
|
||||||
#ifndef CONFIG_AM43XX
|
#ifndef CONFIG_AM43XX
|
||||||
/* Encapsulating core pll registers */
|
/* Encapsulating core pll registers */
|
||||||
|
@ -422,32 +402,6 @@ struct cm_rtc {
|
||||||
unsigned int clkstctrl; /* offset 0x4 */
|
unsigned int clkstctrl; /* offset 0x4 */
|
||||||
};
|
};
|
||||||
|
|
||||||
/* Watchdog timer registers */
|
|
||||||
struct wd_timer {
|
|
||||||
unsigned int resv1[4];
|
|
||||||
unsigned int wdtwdsc; /* offset 0x010 */
|
|
||||||
unsigned int wdtwdst; /* offset 0x014 */
|
|
||||||
unsigned int wdtwisr; /* offset 0x018 */
|
|
||||||
unsigned int wdtwier; /* offset 0x01C */
|
|
||||||
unsigned int wdtwwer; /* offset 0x020 */
|
|
||||||
unsigned int wdtwclr; /* offset 0x024 */
|
|
||||||
unsigned int wdtwcrr; /* offset 0x028 */
|
|
||||||
unsigned int wdtwldr; /* offset 0x02C */
|
|
||||||
unsigned int wdtwtgr; /* offset 0x030 */
|
|
||||||
unsigned int wdtwwps; /* offset 0x034 */
|
|
||||||
unsigned int resv2[3];
|
|
||||||
unsigned int wdtwdly; /* offset 0x044 */
|
|
||||||
unsigned int wdtwspr; /* offset 0x048 */
|
|
||||||
unsigned int resv3[1];
|
|
||||||
unsigned int wdtwqeoi; /* offset 0x050 */
|
|
||||||
unsigned int wdtwqstar; /* offset 0x054 */
|
|
||||||
unsigned int wdtwqsta; /* offset 0x058 */
|
|
||||||
unsigned int wdtwqens; /* offset 0x05C */
|
|
||||||
unsigned int wdtwqenc; /* offset 0x060 */
|
|
||||||
unsigned int resv4[39];
|
|
||||||
unsigned int wdt_unfr; /* offset 0x100 */
|
|
||||||
};
|
|
||||||
|
|
||||||
/* Timer 32 bit registers */
|
/* Timer 32 bit registers */
|
||||||
struct gptimer {
|
struct gptimer {
|
||||||
unsigned int tidr; /* offset 0x00 */
|
unsigned int tidr; /* offset 0x00 */
|
||||||
|
|
|
@ -18,6 +18,8 @@
|
||||||
|
|
||||||
#ifndef __KERNEL_STRICT_NAMES
|
#ifndef __KERNEL_STRICT_NAMES
|
||||||
#ifndef __ASSEMBLY__
|
#ifndef __ASSEMBLY__
|
||||||
|
#include <asm/ti-common/omap_wdt.h>
|
||||||
|
|
||||||
struct gptimer {
|
struct gptimer {
|
||||||
u32 tidr; /* 0x00 r */
|
u32 tidr; /* 0x00 r */
|
||||||
u8 res1[0xc];
|
u8 res1[0xc];
|
||||||
|
|
60
arch/arm/include/asm/ti-common/omap_wdt.h
Normal file
60
arch/arm/include/asm/ti-common/omap_wdt.h
Normal file
|
@ -0,0 +1,60 @@
|
||||||
|
/*
|
||||||
|
* omap_wdt.h
|
||||||
|
*
|
||||||
|
* OMAP Watchdog header file
|
||||||
|
*
|
||||||
|
* Copyright (C) 2011, Texas Instruments, Incorporated - http://www.ti.com/
|
||||||
|
*
|
||||||
|
* SPDX-License-Identifier: GPL-2.0+
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __OMAP_WDT_H__
|
||||||
|
#define __OMAP_WDT_H__
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Watchdog:
|
||||||
|
* Using the prescaler, the OMAP watchdog could go for many
|
||||||
|
* months before firing. These limits work without scaling,
|
||||||
|
* with the 60 second default assumed by most tools and docs.
|
||||||
|
*/
|
||||||
|
#define TIMER_MARGIN_MAX (24 * 60 * 60) /* 1 day */
|
||||||
|
#define TIMER_MARGIN_DEFAULT 60 /* 60 secs */
|
||||||
|
#define TIMER_MARGIN_MIN 1
|
||||||
|
|
||||||
|
#define PTV 0 /* prescale */
|
||||||
|
#define GET_WLDR_VAL(secs) (0xffffffff - ((secs) * (32768/(1<<PTV))) + 1)
|
||||||
|
#define WDT_WWPS_PEND_WCLR BIT(0)
|
||||||
|
#define WDT_WWPS_PEND_WLDR BIT(2)
|
||||||
|
#define WDT_WWPS_PEND_WTGR BIT(3)
|
||||||
|
#define WDT_WWPS_PEND_WSPR BIT(4)
|
||||||
|
|
||||||
|
#define WDT_WCLR_PRE BIT(5)
|
||||||
|
#define WDT_WCLR_PTV_OFF 2
|
||||||
|
|
||||||
|
/* Watchdog timer registers */
|
||||||
|
struct wd_timer {
|
||||||
|
unsigned int resv1[4];
|
||||||
|
unsigned int wdtwdsc; /* offset 0x010 */
|
||||||
|
unsigned int wdtwdst; /* offset 0x014 */
|
||||||
|
unsigned int wdtwisr; /* offset 0x018 */
|
||||||
|
unsigned int wdtwier; /* offset 0x01C */
|
||||||
|
unsigned int wdtwwer; /* offset 0x020 */
|
||||||
|
unsigned int wdtwclr; /* offset 0x024 */
|
||||||
|
unsigned int wdtwcrr; /* offset 0x028 */
|
||||||
|
unsigned int wdtwldr; /* offset 0x02C */
|
||||||
|
unsigned int wdtwtgr; /* offset 0x030 */
|
||||||
|
unsigned int wdtwwps; /* offset 0x034 */
|
||||||
|
unsigned int resv2[3];
|
||||||
|
unsigned int wdtwdly; /* offset 0x044 */
|
||||||
|
unsigned int wdtwspr; /* offset 0x048 */
|
||||||
|
unsigned int resv3[1];
|
||||||
|
unsigned int wdtwqeoi; /* offset 0x050 */
|
||||||
|
unsigned int wdtwqstar; /* offset 0x054 */
|
||||||
|
unsigned int wdtwqsta; /* offset 0x058 */
|
||||||
|
unsigned int wdtwqens; /* offset 0x05C */
|
||||||
|
unsigned int wdtwqenc; /* offset 0x060 */
|
||||||
|
unsigned int resv4[39];
|
||||||
|
unsigned int wdt_unfr; /* offset 0x100 */
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif /* __OMAP_WDT_H__ */
|
Loading…
Add table
Reference in a new issue