2018-08-20 11:24:33 +01:00
|
|
|
/*
|
|
|
|
* ARM CMSDK APB watchdog emulation
|
|
|
|
*
|
|
|
|
* Copyright (c) 2018 Linaro Limited
|
|
|
|
* Written by Peter Maydell
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License version 2 or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* This is a model of the "APB watchdog" which is part of the Cortex-M
|
|
|
|
* System Design Kit (CMSDK) and documented in the Cortex-M System
|
|
|
|
* Design Kit Technical Reference Manual (ARM DDI0479C):
|
|
|
|
* https://developer.arm.com/products/system-design/system-design-kits/cortex-m-system-design-kit
|
|
|
|
*
|
|
|
|
* QEMU interface:
|
hw/watchdog/cmsdk-apb-watchdog: Add Clock input
As the first step in converting the CMSDK_APB_TIMER device to the
Clock framework, add a Clock input. For the moment we do nothing
with this clock; we will change the behaviour from using the
wdogclk-frq property to using the Clock once all the users of this
device have been converted to wire up the Clock.
This is a migration compatibility break for machines mps2-an385,
mps2-an386, mps2-an500, mps2-an511, mps2-an505, mps2-an521, musca-a,
musca-b1, lm3s811evb, lm3s6965evb.
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
Reviewed-by: Luc Michel <luc@lmichel.fr>
Tested-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
Message-id: 20210128114145.20536-10-peter.maydell@linaro.org
Message-id: 20210121190622.22000-10-peter.maydell@linaro.org
2021-01-28 11:41:29 +00:00
|
|
|
* + Clock input "WDOGCLK": clock for the watchdog's timer
|
2018-08-20 11:24:33 +01:00
|
|
|
* + sysbus MMIO region 0: the register bank
|
|
|
|
* + sysbus IRQ 0: watchdog interrupt
|
|
|
|
*
|
|
|
|
* In real hardware the watchdog's reset output is just a GPIO line
|
|
|
|
* which can then be masked by the board or treated as a simple interrupt.
|
|
|
|
* (For instance the IoTKit does this with the non-secure watchdog, so that
|
|
|
|
* secure code can control whether non-secure code can perform a system
|
|
|
|
* reset via its watchdog.) In QEMU, we just wire up the watchdog reset
|
|
|
|
* to watchdog_perform_action(), at least for the moment.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef CMSDK_APB_WATCHDOG_H
|
|
|
|
#define CMSDK_APB_WATCHDOG_H
|
|
|
|
|
|
|
|
#include "hw/sysbus.h"
|
|
|
|
#include "hw/ptimer.h"
|
hw/watchdog/cmsdk-apb-watchdog: Add Clock input
As the first step in converting the CMSDK_APB_TIMER device to the
Clock framework, add a Clock input. For the moment we do nothing
with this clock; we will change the behaviour from using the
wdogclk-frq property to using the Clock once all the users of this
device have been converted to wire up the Clock.
This is a migration compatibility break for machines mps2-an385,
mps2-an386, mps2-an500, mps2-an511, mps2-an505, mps2-an521, musca-a,
musca-b1, lm3s811evb, lm3s6965evb.
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
Reviewed-by: Luc Michel <luc@lmichel.fr>
Tested-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
Message-id: 20210128114145.20536-10-peter.maydell@linaro.org
Message-id: 20210121190622.22000-10-peter.maydell@linaro.org
2021-01-28 11:41:29 +00:00
|
|
|
#include "hw/clock.h"
|
2020-09-03 16:43:22 -04:00
|
|
|
#include "qom/object.h"
|
2018-08-20 11:24:33 +01:00
|
|
|
|
|
|
|
#define TYPE_CMSDK_APB_WATCHDOG "cmsdk-apb-watchdog"
|
2020-09-16 14:25:19 -04:00
|
|
|
OBJECT_DECLARE_SIMPLE_TYPE(CMSDKAPBWatchdog, CMSDK_APB_WATCHDOG)
|
2018-08-20 11:24:33 +01:00
|
|
|
|
2019-03-05 01:16:22 +02:00
|
|
|
/*
|
|
|
|
* This shares the same struct (and cast macro) as the base
|
|
|
|
* cmsdk-apb-watchdog device.
|
|
|
|
*/
|
|
|
|
#define TYPE_LUMINARY_WATCHDOG "luminary-watchdog"
|
|
|
|
|
2020-09-03 16:43:22 -04:00
|
|
|
struct CMSDKAPBWatchdog {
|
2018-08-20 11:24:33 +01:00
|
|
|
/*< private >*/
|
|
|
|
SysBusDevice parent_obj;
|
|
|
|
|
|
|
|
/*< public >*/
|
|
|
|
MemoryRegion iomem;
|
|
|
|
qemu_irq wdogint;
|
2019-03-05 01:16:22 +02:00
|
|
|
bool is_luminary;
|
2018-08-20 11:24:33 +01:00
|
|
|
struct ptimer_state *timer;
|
hw/watchdog/cmsdk-apb-watchdog: Add Clock input
As the first step in converting the CMSDK_APB_TIMER device to the
Clock framework, add a Clock input. For the moment we do nothing
with this clock; we will change the behaviour from using the
wdogclk-frq property to using the Clock once all the users of this
device have been converted to wire up the Clock.
This is a migration compatibility break for machines mps2-an385,
mps2-an386, mps2-an500, mps2-an511, mps2-an505, mps2-an521, musca-a,
musca-b1, lm3s811evb, lm3s6965evb.
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
Reviewed-by: Luc Michel <luc@lmichel.fr>
Tested-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
Message-id: 20210128114145.20536-10-peter.maydell@linaro.org
Message-id: 20210121190622.22000-10-peter.maydell@linaro.org
2021-01-28 11:41:29 +00:00
|
|
|
Clock *wdogclk;
|
2018-08-20 11:24:33 +01:00
|
|
|
|
|
|
|
uint32_t control;
|
|
|
|
uint32_t intstatus;
|
|
|
|
uint32_t lock;
|
|
|
|
uint32_t itcr;
|
|
|
|
uint32_t itop;
|
|
|
|
uint32_t resetstatus;
|
2019-03-05 01:16:22 +02:00
|
|
|
const uint32_t *id;
|
2020-09-03 16:43:22 -04:00
|
|
|
};
|
2018-08-20 11:24:33 +01:00
|
|
|
|
|
|
|
#endif
|