mirror of https://github.com/ARMmbed/mbed-os.git
Add HighResClock and LowPowerClock
parent
4575ad3f23
commit
b9aa69a376
|
@ -0,0 +1,80 @@
|
||||||
|
/* mbed Microcontroller Library
|
||||||
|
* Copyright (c) 2006-2019 ARM Limited
|
||||||
|
* 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_HIGHRESCLOCK_H
|
||||||
|
#define MBED_HIGHRESCLOCK_H
|
||||||
|
|
||||||
|
#include <chrono>
|
||||||
|
#include "hal/us_ticker_api.h"
|
||||||
|
#include "platform/mbed_power_mgmt.h"
|
||||||
|
|
||||||
|
namespace mbed {
|
||||||
|
/**
|
||||||
|
* \defgroup drivers_HighResClock HighResClock class
|
||||||
|
* \ingroup drivers-public-api-ticker
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A C++11 Clock representing the HAL us_ticker.
|
||||||
|
*
|
||||||
|
* The high resolution clock will pause whenever deep sleep is entered.
|
||||||
|
*
|
||||||
|
* Lock and unlock methods are provided to control deep sleep to keep the
|
||||||
|
* clock running. LowPowerClock provides the same methods as dummies to support
|
||||||
|
* generic code that works with either clock.
|
||||||
|
*
|
||||||
|
* Locks and unlocks are passed to the deep sleep manager, so are reference counted.
|
||||||
|
*
|
||||||
|
* The lock and unlock methods mean this is a C++11 BasicLockable class,
|
||||||
|
* so scoped_lock<HighResClock> or unique_lock<HighResClock> could be used to
|
||||||
|
* manage ownership and guarantee balanced unlocking.
|
||||||
|
*
|
||||||
|
* @note To avoid the need to worry about locking, consider using the Timer, Ticker or
|
||||||
|
* Timeout classes, which lock automatically and only whenever they are active
|
||||||
|
*/
|
||||||
|
class HighResClock {
|
||||||
|
public:
|
||||||
|
/* duration is C++11 standard microseconds, so representation will be 64-bit signed integer */
|
||||||
|
using duration = std::chrono::microseconds;
|
||||||
|
using rep = duration::rep;
|
||||||
|
using period = duration::period;
|
||||||
|
using time_point = std::chrono::time_point<HighResClock>;
|
||||||
|
static const bool is_steady = false;
|
||||||
|
|
||||||
|
/** Read the current time */
|
||||||
|
static time_point now()
|
||||||
|
{
|
||||||
|
return time_point{duration{ticker_read_us(get_us_ticker_data())}};
|
||||||
|
}
|
||||||
|
|
||||||
|
/** Lock the clock to ensure it stays running */
|
||||||
|
static void lock()
|
||||||
|
{
|
||||||
|
sleep_manager_lock_deep_sleep();
|
||||||
|
}
|
||||||
|
|
||||||
|
/** Unlock the clock, allowing it to stop during power saving */
|
||||||
|
static void unlock()
|
||||||
|
{
|
||||||
|
sleep_manager_unlock_deep_sleep();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
/** @}*/
|
||||||
|
|
||||||
|
}
|
||||||
|
#endif /* MBED_HIGHRESCLOCK_H */
|
|
@ -0,0 +1,66 @@
|
||||||
|
/* mbed Microcontroller Library
|
||||||
|
* Copyright (c) 2006-2019 ARM Limited
|
||||||
|
* 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_LOWPOWERCLOCK_H
|
||||||
|
#define MBED_LOWPOWERCLOCK_H
|
||||||
|
|
||||||
|
#include <chrono>
|
||||||
|
#include "hal/lp_ticker_api.h"
|
||||||
|
|
||||||
|
namespace mbed {
|
||||||
|
/**
|
||||||
|
* \defgroup drivers_LowPowerClock LowPowerClock class
|
||||||
|
* \ingroup drivers-public-api-ticker
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A C++11 Clock representing the HAL lp_ticker.
|
||||||
|
*
|
||||||
|
* Dummy lock/unlock methods are provided to have the same generic API
|
||||||
|
* as UnlockedHighPowerClock. No action is required as the lp_ticker
|
||||||
|
* runs continuously.
|
||||||
|
*/
|
||||||
|
class LowPowerClock {
|
||||||
|
public:
|
||||||
|
/* duration is C++11 standard microseconds, so representation will be 64-bit signed integer */
|
||||||
|
using duration = std::chrono::microseconds;
|
||||||
|
using rep = duration::rep;
|
||||||
|
using period = duration::period;
|
||||||
|
using time_point = std::chrono::time_point<LowPowerClock>;
|
||||||
|
static const bool is_steady = true;
|
||||||
|
|
||||||
|
/** Read the current time */
|
||||||
|
static time_point now()
|
||||||
|
{
|
||||||
|
return time_point{duration{ticker_read_us(get_lp_ticker_data())}};
|
||||||
|
}
|
||||||
|
|
||||||
|
/** Lock the clock to ensure it stays running; dummy for API compatibility with HighResClock */
|
||||||
|
static void lock()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
/** Unlock the clock, allowing it to stop during power saving; dummy for API compatibility with HighResClock */
|
||||||
|
static void unlock()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
/** @}*/
|
||||||
|
|
||||||
|
}
|
||||||
|
#endif /* MBED_LOWPOWERCLOCK_H */
|
2
mbed.h
2
mbed.h
|
@ -76,9 +76,11 @@
|
||||||
|
|
||||||
// mbed Internal components
|
// mbed Internal components
|
||||||
#include "drivers/ResetReason.h"
|
#include "drivers/ResetReason.h"
|
||||||
|
#include "drivers/HighResClock.h"
|
||||||
#include "drivers/Timer.h"
|
#include "drivers/Timer.h"
|
||||||
#include "drivers/Ticker.h"
|
#include "drivers/Ticker.h"
|
||||||
#include "drivers/Timeout.h"
|
#include "drivers/Timeout.h"
|
||||||
|
#include "drivers/LowPowerClock.h"
|
||||||
#include "drivers/LowPowerTimeout.h"
|
#include "drivers/LowPowerTimeout.h"
|
||||||
#include "drivers/LowPowerTicker.h"
|
#include "drivers/LowPowerTicker.h"
|
||||||
#include "drivers/LowPowerTimer.h"
|
#include "drivers/LowPowerTimer.h"
|
||||||
|
|
Loading…
Reference in New Issue