mirror of https://github.com/ARMmbed/mbed-os.git
watchdog: add WatchdogManager
Watchdog should be usable on it's own - kicking it via ticker. No Virtual involved. VirtualWatchdog as well - services should use this one to have multiple one in the system. There's WatchdogManager - basically internal class to manage ticker for Watchdog.pull/11023/head
parent
1c5097af49
commit
c97f95817c
|
@ -31,7 +31,7 @@ VirtualWatchdog::VirtualWatchdog(uint32_t timeout, const char *const str): _name
|
||||||
_max_timeout = timeout;
|
_max_timeout = timeout;
|
||||||
// start watchdog
|
// start watchdog
|
||||||
Watchdog& watchdog = Watchdog::get_instance();
|
Watchdog& watchdog = Watchdog::get_instance();
|
||||||
watchdog.start();
|
watchdog.start(&VirtualWatchdog::process, WatchdogManager::elapsed_ms);
|
||||||
}
|
}
|
||||||
|
|
||||||
VirtualWatchdog::~VirtualWatchdog()
|
VirtualWatchdog::~VirtualWatchdog()
|
||||||
|
@ -97,14 +97,14 @@ void VirtualWatchdog::remove_from_list()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void VirtualWatchdog::process(uint32_t elapsed_ms)
|
void VirtualWatchdog::process()
|
||||||
{
|
{
|
||||||
VirtualWatchdog *cur_ptr = _first;
|
VirtualWatchdog *cur_ptr = _first;
|
||||||
while (cur_ptr != NULL) {
|
while (cur_ptr != NULL) {
|
||||||
if (cur_ptr->_current_count > cur_ptr->_max_timeout) {
|
if (cur_ptr->_current_count > cur_ptr->_max_timeout) {
|
||||||
system_reset();
|
system_reset();
|
||||||
} else {
|
} else {
|
||||||
cur_ptr->_current_count += elapsed_ms;
|
cur_ptr->_current_count += WatchdogManager::elapsed_ms;
|
||||||
}
|
}
|
||||||
cur_ptr = cur_ptr->_next;
|
cur_ptr = cur_ptr->_next;
|
||||||
}
|
}
|
||||||
|
|
|
@ -25,6 +25,7 @@
|
||||||
#include "platform/mbed_critical.h"
|
#include "platform/mbed_critical.h"
|
||||||
#include "platform/mbed_power_mgmt.h"
|
#include "platform/mbed_power_mgmt.h"
|
||||||
#include "mbed_assert.h"
|
#include "mbed_assert.h"
|
||||||
|
#include "WatchdogManager.h"
|
||||||
|
|
||||||
namespace mbed {
|
namespace mbed {
|
||||||
|
|
||||||
|
@ -94,7 +95,7 @@ public:
|
||||||
*
|
*
|
||||||
* Otherwise, the system resets.
|
* Otherwise, the system resets.
|
||||||
*/
|
*/
|
||||||
static void process(uint32_t elapsed_ms);
|
static void process();
|
||||||
protected :
|
protected :
|
||||||
|
|
||||||
/** Use add_to_list to store the registered user in the list.
|
/** Use add_to_list to store the registered user in the list.
|
||||||
|
|
|
@ -16,24 +16,24 @@
|
||||||
*/
|
*/
|
||||||
#ifdef DEVICE_WATCHDOG
|
#ifdef DEVICE_WATCHDOG
|
||||||
|
|
||||||
#include "Watchdog.h"
|
#include "drivers/Watchdog.h"
|
||||||
|
#include "drivers/WatchdogManager.h"
|
||||||
|
|
||||||
#define MS_TO_US(x) ((x) * 1000) //macro to convert millisecond to microsecond
|
#define MS_TO_US(x) ((x) * 1000) //macro to convert millisecond to microsecond
|
||||||
|
|
||||||
namespace mbed {
|
namespace mbed {
|
||||||
|
|
||||||
static const uint32_t elapsed_ms = MBED_CONF_TARGET_WATCHDOG_TIMEOUT / 2;
|
Watchdog::Watchdog() : _running(false), _callback(NULL)
|
||||||
|
|
||||||
Watchdog::Watchdog() : _running(false)
|
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
~Watchdog::Watchdog()
|
Watchdog::~Watchdog()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Watchdog::start()
|
bool Watchdog::start(Callback<void()> func, uint32_t timeout)
|
||||||
{
|
{
|
||||||
|
_callback = func;
|
||||||
watchdog_status_t sts;
|
watchdog_status_t sts;
|
||||||
MBED_ASSERT(MBED_CONF_TARGET_WATCHDOG_TIMEOUT < get_max_timeout());
|
MBED_ASSERT(MBED_CONF_TARGET_WATCHDOG_TIMEOUT < get_max_timeout());
|
||||||
core_util_critical_section_enter();
|
core_util_critical_section_enter();
|
||||||
|
@ -49,8 +49,8 @@ bool Watchdog::start()
|
||||||
}
|
}
|
||||||
core_util_critical_section_exit();
|
core_util_critical_section_exit();
|
||||||
if (_running) {
|
if (_running) {
|
||||||
us_timestamp_t timeout = (MS_TO_US(((elapsed_ms <= 0) ? 1 : elapsed_ms)));
|
us_timestamp_t ticker_timeout = (MS_TO_US(((timeout <= 0) ? 1 : timeout)));
|
||||||
_ticker->attach_us(callback(&Watchdog::get_instance(), &Watchdog::kick), timeout);
|
WatchdogManager::attach(callback(this, &Watchdog::kick), ticker_timeout);
|
||||||
}
|
}
|
||||||
return _running;
|
return _running;
|
||||||
}
|
}
|
||||||
|
@ -66,8 +66,9 @@ bool Watchdog::stop()
|
||||||
if (sts != WATCHDOG_STATUS_OK) {
|
if (sts != WATCHDOG_STATUS_OK) {
|
||||||
msts = false;
|
msts = false;
|
||||||
} else {
|
} else {
|
||||||
_ticker->detach();
|
WatchdogManager::detach();
|
||||||
_running = false;
|
_running = false;
|
||||||
|
_callback = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
|
@ -82,6 +83,9 @@ void Watchdog::kick()
|
||||||
core_util_critical_section_enter();
|
core_util_critical_section_enter();
|
||||||
hal_watchdog_kick();
|
hal_watchdog_kick();
|
||||||
core_util_critical_section_exit();
|
core_util_critical_section_exit();
|
||||||
|
if (_callback) {
|
||||||
|
_callback();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -27,6 +27,7 @@
|
||||||
#include "platform/NonCopyable.h"
|
#include "platform/NonCopyable.h"
|
||||||
#include "platform/SingletonPtr.h"
|
#include "platform/SingletonPtr.h"
|
||||||
#include "drivers/LowPowerTicker.h"
|
#include "drivers/LowPowerTicker.h"
|
||||||
|
#include "drivers/WatchdogManager.h"
|
||||||
#include <cstdio>
|
#include <cstdio>
|
||||||
|
|
||||||
namespace mbed {
|
namespace mbed {
|
||||||
|
@ -69,7 +70,7 @@ public:
|
||||||
* successfully. assert if one of the input parameters is out of range for the current platform.
|
* successfully. assert if one of the input parameters is out of range for the current platform.
|
||||||
* false if watchdog timer was not started
|
* false if watchdog timer was not started
|
||||||
*/
|
*/
|
||||||
bool start();
|
bool start(Callback<void()> func = NULL, uint32_t timeout = WatchdogManager::elapsed_ms);
|
||||||
|
|
||||||
/** Stops the watchdog timer
|
/** Stops the watchdog timer
|
||||||
*
|
*
|
||||||
|
@ -104,22 +105,13 @@ public:
|
||||||
*/
|
*/
|
||||||
bool is_running() const;
|
bool is_running() const;
|
||||||
|
|
||||||
|
void kick();
|
||||||
private:
|
private:
|
||||||
Watchdog();
|
Watchdog();
|
||||||
~Watchdog();
|
~Watchdog();
|
||||||
|
|
||||||
void kick();
|
|
||||||
|
|
||||||
bool _running;
|
bool _running;
|
||||||
#if DEVICE_LPTICKER
|
Callback<void()> _callback;
|
||||||
/** Create singleton instance of LowPowerTicker for watchdog periodic call back of kick.
|
|
||||||
*/
|
|
||||||
SingletonPtr<LowPowerTicker> _ticker;
|
|
||||||
#else
|
|
||||||
/** Create singleton instance of Ticker for watchdog periodic call back of kick.
|
|
||||||
*/
|
|
||||||
SingletonPtr<Ticker> _ticker;
|
|
||||||
#endif
|
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace mbed
|
} // namespace mbed
|
||||||
|
|
|
@ -0,0 +1,46 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2018-2019 Arm Limited and affiliates.
|
||||||
|
* SPDX-License-Identifier: Apache-2.0
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
#ifdef DEVICE_WATCHDOG
|
||||||
|
|
||||||
|
#include "WatchdogManager.h"
|
||||||
|
|
||||||
|
namespace mbed {
|
||||||
|
|
||||||
|
#if DEVICE_LPTICKER
|
||||||
|
/** Create singleton instance of LowPowerTicker for watchdog periodic call back of kick.
|
||||||
|
*/
|
||||||
|
SingletonPtr<LowPowerTicker> _ticker;
|
||||||
|
#else
|
||||||
|
/** Create singleton instance of Ticker for watchdog periodic call back of kick.
|
||||||
|
*/
|
||||||
|
SingletonPtr<Ticker> _ticker;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
void WatchdogManager::attach(Callback<void()> func, us_timestamp_t timeout)
|
||||||
|
{
|
||||||
|
_ticker->attach_us(func, timeout);
|
||||||
|
}
|
||||||
|
|
||||||
|
void WatchdogManager::detach()
|
||||||
|
{
|
||||||
|
_ticker->detach();
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace mbed
|
||||||
|
|
||||||
|
|
||||||
|
#endif // DEVICE_WATCHDOG
|
|
@ -0,0 +1,53 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2019 Arm Limited and affiliates.
|
||||||
|
* SPDX-License-Identifier: Apache-2.0
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef MBED_WATCHDOG_MANAGER_H
|
||||||
|
#define MBED_WATCHDOG_MANAGER_H
|
||||||
|
|
||||||
|
#include "platform/SingletonPtr.h"
|
||||||
|
#include "drivers/LowPowerTicker.h"
|
||||||
|
#include "platform/Callback.h"
|
||||||
|
#include "hal/ticker_api.h"
|
||||||
|
|
||||||
|
#include <cstdio>
|
||||||
|
|
||||||
|
|
||||||
|
namespace mbed {
|
||||||
|
|
||||||
|
/** \addtogroup drivers */
|
||||||
|
|
||||||
|
class WatchdogManager {
|
||||||
|
public:
|
||||||
|
static void attach(Callback<void()> func, us_timestamp_t timeout);
|
||||||
|
static void detach();
|
||||||
|
// static uint32_t get_elapsed();
|
||||||
|
static const uint32_t elapsed_ms = MBED_CONF_TARGET_WATCHDOG_TIMEOUT / 2;
|
||||||
|
private:
|
||||||
|
#if DEVICE_LPTICKER
|
||||||
|
/** Create singleton instance of LowPowerTicker for watchdog periodic call back of kick.
|
||||||
|
*/
|
||||||
|
static SingletonPtr<LowPowerTicker> _ticker;
|
||||||
|
#else
|
||||||
|
/** Create singleton instance of Ticker for watchdog periodic call back of kick.
|
||||||
|
*/
|
||||||
|
static SingletonPtr<Ticker> _ticker;
|
||||||
|
#endif
|
||||||
|
};
|
||||||
|
|
||||||
|
} // namespace mbed
|
||||||
|
|
||||||
|
#endif // MBED_WATCHDOG_MANAGER_H
|
Loading…
Reference in New Issue