Lei YU | 2f9c0cc | 2017-01-20 14:02:03 +0800 | [diff] [blame] | 1 | #pragma once |
| 2 | |
Lei YU | 1cd4248 | 2018-07-24 10:40:59 +0800 | [diff] [blame^] | 3 | #include "config.h" |
Lei YU | 415b964 | 2017-02-09 11:37:26 +0800 | [diff] [blame] | 4 | #include "property_change_listener.hpp" |
| 5 | |
Lei YU | 2f9c0cc | 2017-01-20 14:02:03 +0800 | [diff] [blame] | 6 | #include <sdbusplus/bus.hpp> |
| 7 | #include <xyz/openbmc_project/Time/EpochTime/server.hpp> |
| 8 | |
| 9 | #include <chrono> |
| 10 | |
| 11 | namespace phosphor |
| 12 | { |
| 13 | namespace time |
| 14 | { |
| 15 | |
| 16 | /** @class EpochBase |
| 17 | * @brief Base class for OpenBMC EpochTime implementation. |
| 18 | * @details A base class that implements xyz.openbmc_project.Time.EpochTime |
| 19 | * DBus API for epoch time. |
| 20 | */ |
| 21 | class EpochBase : public sdbusplus::server::object::object < |
Lei YU | 415b964 | 2017-02-09 11:37:26 +0800 | [diff] [blame] | 22 | sdbusplus::xyz::openbmc_project::Time::server::EpochTime >, |
| 23 | public PropertyChangeListner |
Lei YU | 2f9c0cc | 2017-01-20 14:02:03 +0800 | [diff] [blame] | 24 | { |
| 25 | public: |
| 26 | friend class TestEpochBase; |
| 27 | |
Lei YU | 2f9c0cc | 2017-01-20 14:02:03 +0800 | [diff] [blame] | 28 | EpochBase(sdbusplus::bus::bus& bus, |
| 29 | const char* objPath); |
| 30 | |
Lei YU | 415b964 | 2017-02-09 11:37:26 +0800 | [diff] [blame] | 31 | /** @brief Notified on time mode changed */ |
| 32 | void onModeChanged(Mode mode) override; |
| 33 | |
| 34 | /** @brief Notified on time owner changed */ |
| 35 | void onOwnerChanged(Owner owner) override; |
| 36 | |
Lei YU | 2f9c0cc | 2017-01-20 14:02:03 +0800 | [diff] [blame] | 37 | protected: |
| 38 | /** @brief Persistent sdbusplus DBus connection */ |
| 39 | sdbusplus::bus::bus& bus; |
| 40 | |
| 41 | /** @brief The current time mode */ |
Lei YU | 1cd4248 | 2018-07-24 10:40:59 +0800 | [diff] [blame^] | 42 | Mode timeMode = DEFAULT_TIME_MODE; |
Lei YU | 2f9c0cc | 2017-01-20 14:02:03 +0800 | [diff] [blame] | 43 | |
| 44 | /** @brief The current time owner */ |
Lei YU | 1cd4248 | 2018-07-24 10:40:59 +0800 | [diff] [blame^] | 45 | Owner timeOwner = DEFAULT_TIME_OWNER; |
Lei YU | 2f9c0cc | 2017-01-20 14:02:03 +0800 | [diff] [blame] | 46 | |
| 47 | /** @brief Set current time to system |
| 48 | * |
| 49 | * This function set the time to system by invoking systemd |
| 50 | * org.freedesktop.timedate1's SetTime method. |
| 51 | * |
| 52 | * @param[in] timeOfDayUsec - Microseconds since UTC |
Lei YU | fa02488 | 2017-11-09 10:49:26 +0800 | [diff] [blame] | 53 | * |
| 54 | * @return true or false to indicate if it sets time successfully |
Lei YU | 2f9c0cc | 2017-01-20 14:02:03 +0800 | [diff] [blame] | 55 | */ |
Lei YU | fa02488 | 2017-11-09 10:49:26 +0800 | [diff] [blame] | 56 | bool setTime(const std::chrono::microseconds& timeOfDayUsec); |
Lei YU | 2f9c0cc | 2017-01-20 14:02:03 +0800 | [diff] [blame] | 57 | |
| 58 | /** @brief Get current time |
| 59 | * |
| 60 | * @return Microseconds since UTC |
| 61 | */ |
| 62 | std::chrono::microseconds getTime() const; |
Lei YU | 2f9c0cc | 2017-01-20 14:02:03 +0800 | [diff] [blame] | 63 | }; |
| 64 | |
| 65 | } // namespace time |
| 66 | } // namespace phosphor |