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
Martin Kojtal 2019-06-27 17:11:30 +01:00
parent 1c5097af49
commit c97f95817c
6 changed files with 121 additions and 25 deletions

View File

@ -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;
} }

View File

@ -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.

View File

@ -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();
}
} }

View File

@ -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

View File

@ -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

53
drivers/WatchdogManager.h Normal file
View File

@ -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