diff options
author | Jason M. Bills <jason.m.bills@linux.intel.com> | 2021-01-27 22:47:14 +0300 |
---|---|---|
committer | Jason M. Bills <jason.m.bills@linux.intel.com> | 2021-01-28 02:23:52 +0300 |
commit | 7c5f8839ec3d71a2170b8f3514a16a67c69d1c7c (patch) | |
tree | 729dbf87ba33bf4d83b5d95496ce18f99a61ef03 /meta-openbmc-mods/meta-common/recipes-phosphor/datetime | |
parent | 98cc5cd6483975b64d80e8323f7f659dd1337d75 (diff) | |
download | openbmc-7c5f8839ec3d71a2170b8f3514a16a67c69d1c7c.tar.xz |
Update to internal 0.29
Signed-off-by: Jason M. Bills <jason.m.bills@linux.intel.com>
Diffstat (limited to 'meta-openbmc-mods/meta-common/recipes-phosphor/datetime')
-rw-r--r-- | meta-openbmc-mods/meta-common/recipes-phosphor/datetime/pch-time-sync/pch-time-sync.cpp | 35 |
1 files changed, 33 insertions, 2 deletions
diff --git a/meta-openbmc-mods/meta-common/recipes-phosphor/datetime/pch-time-sync/pch-time-sync.cpp b/meta-openbmc-mods/meta-common/recipes-phosphor/datetime/pch-time-sync/pch-time-sync.cpp index 3d0b7fd98..00e2b53fe 100644 --- a/meta-openbmc-mods/meta-common/recipes-phosphor/datetime/pch-time-sync/pch-time-sync.cpp +++ b/meta-openbmc-mods/meta-common/recipes-phosphor/datetime/pch-time-sync/pch-time-sync.cpp @@ -19,6 +19,7 @@ #include <boost/asio/steady_timer.hpp> #include <boost/date_time/posix_time/posix_time.hpp> #include <chrono> +#include <filesystem> #include <iostream> #include <phosphor-logging/log.hpp> #include <sdbusplus/asio/object_server.hpp> @@ -29,6 +30,7 @@ extern "C" { static constexpr uint32_t syncIntervalNormalMS = 60000; static constexpr uint32_t syncIntervalFastMS = (syncIntervalNormalMS / 2); +static constexpr uint32_t syncIntervalBootMS = 5000; static uint32_t syncIntervalMS = syncIntervalNormalMS; @@ -37,6 +39,7 @@ static constexpr uint8_t timeDiffAllowedSecond = 1; static uint8_t pchDevI2cBusNo = 0; static uint8_t pchDevI2cSlaveAddr = 0; static bool getPCHI2cAddrFlag = false; +static constexpr const char* clockFile = "/var/lib/systemd/timesync/clock"; static inline uint8_t bcd2Decimal(uint8_t hex) { uint8_t dec = ((hex & 0xF0) >> 4) * 10 + (hex & 0x0F); @@ -250,6 +253,26 @@ class PCHSync return true; } + bool updateClockFileTimestamp() + { + if (!std::filesystem::exists(clockFile)) + { + phosphor::logging::log<phosphor::logging::level::WARNING>( + "The systemd timestamp synchronization file doesn't exist: ", + phosphor::logging::entry("PATHNAME=%s", clockFile)); + return false; + } + int rc = utimensat(AT_FDCWD, clockFile, nullptr, 0); + if (rc) + { + phosphor::logging::log<phosphor::logging::level::ERR>( + "utimensat systemd timestamp synchronization file fail: ", + phosphor::logging::entry("PATHNAME=%s", clockFile), + phosphor::logging::entry("ERRCODE=%x", errno)); + return false; + } + return true; + } bool setSystemTime(uint32_t timeSeconds) { struct timespec sTime = {0}; @@ -305,12 +328,20 @@ class PCHSync phosphor::logging::entry("TIME=%s", dateString.c_str())); } + // During the boot time, systemd-timesyncd.service checks + // "/var/lib/systemd/timesync/clock" and updates the system time with + // the timestamp of the file + if (!updateClockFileTimestamp()) + { + return false; + } + return true; } void startSyncTimer(std::shared_ptr<sdbusplus::asio::connection>& conn) { - // retry 10 times (10 * 30 sec = 5min ) to get the pch timer + // retry 10 times (10 * 5s = 50s ) to get the pch timer // configuration. static uint8_t retrytimes = 10; if (!getPCHI2cAddrFlag) @@ -321,7 +352,7 @@ class PCHSync "Get pch timer configuration fail"); return; } - syncIntervalMS = syncIntervalFastMS; + syncIntervalMS = syncIntervalBootMS; getPCHTimerConfiguration(conn); retrytimes--; } |