162306a36Sopenharmony_ci/*
262306a36Sopenharmony_ci * This file is subject to the terms and conditions of the GNU General Public
362306a36Sopenharmony_ci * License.  See the file "COPYING" in the main directory of this archive
462306a36Sopenharmony_ci * for more details.
562306a36Sopenharmony_ci *
662306a36Sopenharmony_ci * Copyright (C) 2008 Florian Fainelli <florian@openwrt.org>
762306a36Sopenharmony_ci */
862306a36Sopenharmony_ci
962306a36Sopenharmony_ci#include <linux/init.h>
1062306a36Sopenharmony_ci#include <linux/kernel.h>
1162306a36Sopenharmony_ci#include <linux/platform_device.h>
1262306a36Sopenharmony_ci#include <linux/platform_data/bcm7038_wdt.h>
1362306a36Sopenharmony_ci#include <bcm63xx_cpu.h>
1462306a36Sopenharmony_ci
1562306a36Sopenharmony_cistatic struct resource wdt_resources[] = {
1662306a36Sopenharmony_ci	{
1762306a36Sopenharmony_ci		.start		= -1, /* filled at runtime */
1862306a36Sopenharmony_ci		.end		= -1, /* filled at runtime */
1962306a36Sopenharmony_ci		.flags		= IORESOURCE_MEM,
2062306a36Sopenharmony_ci	},
2162306a36Sopenharmony_ci};
2262306a36Sopenharmony_ci
2362306a36Sopenharmony_cistatic struct bcm7038_wdt_platform_data bcm63xx_wdt_pdata = {
2462306a36Sopenharmony_ci	.clk_name	= "periph",
2562306a36Sopenharmony_ci};
2662306a36Sopenharmony_ci
2762306a36Sopenharmony_cistatic struct platform_device bcm63xx_wdt_device = {
2862306a36Sopenharmony_ci	.name		= "bcm63xx-wdt",
2962306a36Sopenharmony_ci	.id		= -1,
3062306a36Sopenharmony_ci	.num_resources	= ARRAY_SIZE(wdt_resources),
3162306a36Sopenharmony_ci	.resource	= wdt_resources,
3262306a36Sopenharmony_ci	.dev		= {
3362306a36Sopenharmony_ci		.platform_data = &bcm63xx_wdt_pdata,
3462306a36Sopenharmony_ci	},
3562306a36Sopenharmony_ci};
3662306a36Sopenharmony_ci
3762306a36Sopenharmony_ciint __init bcm63xx_wdt_register(void)
3862306a36Sopenharmony_ci{
3962306a36Sopenharmony_ci	wdt_resources[0].start = bcm63xx_regset_address(RSET_WDT);
4062306a36Sopenharmony_ci	wdt_resources[0].end = wdt_resources[0].start;
4162306a36Sopenharmony_ci	wdt_resources[0].end += RSET_WDT_SIZE - 1;
4262306a36Sopenharmony_ci
4362306a36Sopenharmony_ci	return platform_device_register(&bcm63xx_wdt_device);
4462306a36Sopenharmony_ci}
4562306a36Sopenharmony_ciarch_initcall(bcm63xx_wdt_register);
46