aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/watchdog/orion_wdt.c27
1 files changed, 20 insertions, 7 deletions
diff --git a/drivers/watchdog/orion_wdt.c b/drivers/watchdog/orion_wdt.c
index afa38314fb18..75f623f5e6c3 100644
--- a/drivers/watchdog/orion_wdt.c
+++ b/drivers/watchdog/orion_wdt.c
@@ -262,10 +262,6 @@ static void __iomem *orion_wdt_ioremap_rstout(struct platform_device *pdev,
262 return devm_ioremap(&pdev->dev, res->start, 262 return devm_ioremap(&pdev->dev, res->start,
263 resource_size(res)); 263 resource_size(res));
264 264
265 /* This workaround works only for "orion-wdt", DT-enabled */
266 if (!of_device_is_compatible(pdev->dev.of_node, "marvell,orion-wdt"))
267 return NULL;
268
269 rstout = internal_regs + ORION_RSTOUT_MASK_OFFSET; 265 rstout = internal_regs + ORION_RSTOUT_MASK_OFFSET;
270 266
271 WARN(1, FW_BUG "falling back to harcoded RSTOUT reg %pa\n", &rstout); 267 WARN(1, FW_BUG "falling back to harcoded RSTOUT reg %pa\n", &rstout);
@@ -316,6 +312,7 @@ MODULE_DEVICE_TABLE(of, orion_wdt_of_match_table);
316static int orion_wdt_get_regs(struct platform_device *pdev, 312static int orion_wdt_get_regs(struct platform_device *pdev,
317 struct orion_watchdog *dev) 313 struct orion_watchdog *dev)
318{ 314{
315 struct device_node *node = pdev->dev.of_node;
319 struct resource *res; 316 struct resource *res;
320 317
321 res = platform_get_resource(pdev, IORESOURCE_MEM, 0); 318 res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
@@ -326,10 +323,26 @@ static int orion_wdt_get_regs(struct platform_device *pdev,
326 if (!dev->reg) 323 if (!dev->reg)
327 return -ENOMEM; 324 return -ENOMEM;
328 325
329 dev->rstout = orion_wdt_ioremap_rstout(pdev, res->start & 326 /* Each supported compatible has some RSTOUT register quirk */
330 INTERNAL_REGS_MASK); 327 if (of_device_is_compatible(node, "marvell,orion-wdt")) {
331 if (!dev->rstout) 328
329 dev->rstout = orion_wdt_ioremap_rstout(pdev, res->start &
330 INTERNAL_REGS_MASK);
331 if (!dev->rstout)
332 return -ENODEV;
333
334 } else if (of_device_is_compatible(node, "marvell,armada-370-wdt") ||
335 of_device_is_compatible(node, "marvell,armada-xp-wdt")) {
336
337 /* Dedicated RSTOUT register, can be requested. */
338 res = platform_get_resource(pdev, IORESOURCE_MEM, 1);
339 dev->rstout = devm_ioremap_resource(&pdev->dev, res);
340 if (IS_ERR(dev->rstout))
341 return PTR_ERR(dev->rstout);
342
343 } else {
332 return -ENODEV; 344 return -ENODEV;
345 }
333 346
334 return 0; 347 return 0;
335} 348}