Commit 2b68e77f authored by Mark A. Greer's avatar Mark A. Greer Committed by Kevin Hilman

davinci: Add watchdog base address flexibility

The watchdog code currently hardcodes the base address
of the timer its using.  To support new SoCs, make it
support timers at any address.  Use the soc_info structure
to do this.
Signed-off-by: default avatarMark A. Greer <mgreer@mvista.com>
Signed-off-by: default avatarKevin Hilman <khilman@deeprootsystems.com>
parent 7bd322ef
...@@ -224,8 +224,6 @@ void __init davinci_setup_mmc(int module, struct davinci_mmc_config *config) ...@@ -224,8 +224,6 @@ void __init davinci_setup_mmc(int module, struct davinci_mmc_config *config)
static struct resource wdt_resources[] = { static struct resource wdt_resources[] = {
{ {
.start = 0x01c21c00,
.end = 0x01c21fff,
.flags = IORESOURCE_MEM, .flags = IORESOURCE_MEM,
}, },
}; };
...@@ -239,6 +237,11 @@ static struct platform_device davinci_wdt_device = { ...@@ -239,6 +237,11 @@ static struct platform_device davinci_wdt_device = {
static void davinci_init_wdt(void) static void davinci_init_wdt(void)
{ {
struct davinci_soc_info *soc_info = davinci_get_soc_info();
wdt_resources[0].start = (resource_size_t)soc_info->wdt_base;
wdt_resources[0].end = (resource_size_t)soc_info->wdt_base + SZ_1K - 1;
platform_device_register(&davinci_wdt_device); platform_device_register(&davinci_wdt_device);
} }
......
...@@ -646,6 +646,7 @@ static struct davinci_soc_info davinci_soc_info_dm355 = { ...@@ -646,6 +646,7 @@ static struct davinci_soc_info davinci_soc_info_dm355 = {
.intc_irq_prios = dm355_default_priorities, .intc_irq_prios = dm355_default_priorities,
.intc_irq_num = DAVINCI_N_AINTC_IRQ, .intc_irq_num = DAVINCI_N_AINTC_IRQ,
.timer_info = &dm355_timer_info, .timer_info = &dm355_timer_info,
.wdt_base = IO_ADDRESS(DAVINCI_WDOG_BASE),
}; };
void __init dm355_init(void) void __init dm355_init(void)
......
...@@ -589,6 +589,7 @@ static struct davinci_soc_info davinci_soc_info_dm644x = { ...@@ -589,6 +589,7 @@ static struct davinci_soc_info davinci_soc_info_dm644x = {
.intc_irq_prios = dm644x_default_priorities, .intc_irq_prios = dm644x_default_priorities,
.intc_irq_num = DAVINCI_N_AINTC_IRQ, .intc_irq_num = DAVINCI_N_AINTC_IRQ,
.timer_info = &dm644x_timer_info, .timer_info = &dm644x_timer_info,
.wdt_base = IO_ADDRESS(DAVINCI_WDOG_BASE),
}; };
void __init dm644x_init(void) void __init dm644x_init(void)
......
...@@ -568,6 +568,7 @@ static struct davinci_soc_info davinci_soc_info_dm646x = { ...@@ -568,6 +568,7 @@ static struct davinci_soc_info davinci_soc_info_dm646x = {
.intc_irq_prios = dm646x_default_priorities, .intc_irq_prios = dm646x_default_priorities,
.intc_irq_num = DAVINCI_N_AINTC_IRQ, .intc_irq_num = DAVINCI_N_AINTC_IRQ,
.timer_info = &dm646x_timer_info, .timer_info = &dm646x_timer_info,
.wdt_base = IO_ADDRESS(DAVINCI_WDOG_BASE),
}; };
void __init dm646x_init(void) void __init dm646x_init(void)
......
...@@ -57,6 +57,7 @@ struct davinci_soc_info { ...@@ -57,6 +57,7 @@ struct davinci_soc_info {
u8 *intc_irq_prios; u8 *intc_irq_prios;
unsigned long intc_irq_num; unsigned long intc_irq_num;
struct davinci_timer_info *timer_info; struct davinci_timer_info *timer_info;
void __iomem *wdt_base;
}; };
extern struct davinci_soc_info *davinci_get_soc_info(void); extern struct davinci_soc_info *davinci_get_soc_info(void);
......
...@@ -13,6 +13,7 @@ ...@@ -13,6 +13,7 @@
#define DAVINCI_TIMER0_BASE (IO_PHYS + 0x21400) #define DAVINCI_TIMER0_BASE (IO_PHYS + 0x21400)
#define DAVINCI_TIMER1_BASE (IO_PHYS + 0x21800) #define DAVINCI_TIMER1_BASE (IO_PHYS + 0x21800)
#define DAVINCI_WDOG_BASE (IO_PHYS + 0x21C00)
enum { enum {
T0_BOT, T0_BOT,
......
...@@ -34,8 +34,6 @@ ...@@ -34,8 +34,6 @@
static struct clock_event_device clockevent_davinci; static struct clock_event_device clockevent_davinci;
static unsigned int davinci_clock_tick_rate; static unsigned int davinci_clock_tick_rate;
#define DAVINCI_WDOG_BASE (IO_PHYS + 0x21C00)
/* /*
* This driver configures the 2 64-bit count-up timers as 4 independent * This driver configures the 2 64-bit count-up timers as 4 independent
* 32-bit count-up timers used as follows: * 32-bit count-up timers used as follows:
...@@ -342,7 +340,8 @@ struct sys_timer davinci_timer = { ...@@ -342,7 +340,8 @@ struct sys_timer davinci_timer = {
/* reset board using watchdog timer */ /* reset board using watchdog timer */
void davinci_watchdog_reset(void) { void davinci_watchdog_reset(void) {
u32 tgcr, wdtcr; u32 tgcr, wdtcr;
void __iomem *base = IO_ADDRESS(DAVINCI_WDOG_BASE); struct davinci_soc_info *soc_info = davinci_get_soc_info();
void __iomem *base = soc_info->wdt_base;
struct device dev; struct device dev;
struct clk *wd_clk; struct clk *wd_clk;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment