diff options
| author | bunnei <bunneidev@gmail.com> | 2018-01-25 21:56:04 -0500 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2018-01-25 21:56:04 -0500 | 
| commit | 767ce8abc828e893973de9ec6b303cea31f7834f (patch) | |
| tree | 6209962cde074c9435999dbeda7af9f02b9d6da1 /src/core/hle | |
| parent | 748c0de539674dc8ca4a5a8aadd2a61b0eabe652 (diff) | |
| parent | 3258db29da499f88c0d85983272f30871c75a59f (diff) | |
Merge pull request #142 from bunnei/improve-time
time: Implement ISteadyClock::GetCurrentTimePoint
Diffstat (limited to 'src/core/hle')
| -rw-r--r-- | src/core/hle/service/time/time.cpp | 17 | ||||
| -rw-r--r-- | src/core/hle/service/time/time.h | 6 | 
2 files changed, 22 insertions, 1 deletions
| diff --git a/src/core/hle/service/time/time.cpp b/src/core/hle/service/time/time.cpp index 96ccee50d..5802f6f6c 100644 --- a/src/core/hle/service/time/time.cpp +++ b/src/core/hle/service/time/time.cpp @@ -4,6 +4,7 @@  #include <chrono>  #include "common/logging/log.h" +#include "core/core_timing.h"  #include "core/hle/ipc_helpers.h"  #include "core/hle/kernel/client_port.h"  #include "core/hle/kernel/client_session.h" @@ -45,7 +46,21 @@ private:  class ISteadyClock final : public ServiceFramework<ISteadyClock> {  public: -    ISteadyClock() : ServiceFramework("ISteadyClock") {} +    ISteadyClock() : ServiceFramework("ISteadyClock") { +        static const FunctionInfo functions[] = { +            {0, &ISteadyClock::GetCurrentTimePoint, "GetCurrentTimePoint"}, +        }; +        RegisterHandlers(functions); +    } + +private: +    void GetCurrentTimePoint(Kernel::HLERequestContext& ctx) { +        LOG_DEBUG(Service, "called"); +        SteadyClockTimePoint steady_clock_time_point{cyclesToMs(CoreTiming::GetTicks()) / 1000}; +        IPC::ResponseBuilder rb{ctx, (sizeof(SteadyClockTimePoint) / 4) + 2}; +        rb.Push(RESULT_SUCCESS); +        rb.PushRaw(steady_clock_time_point); +    }  };  class ITimeZoneService final : public ServiceFramework<ITimeZoneService> { diff --git a/src/core/hle/service/time/time.h b/src/core/hle/service/time/time.h index cd936a50c..1cbbadb21 100644 --- a/src/core/hle/service/time/time.h +++ b/src/core/hle/service/time/time.h @@ -40,6 +40,12 @@ struct SystemClockContext {  static_assert(sizeof(SystemClockContext) == 0x20,                "SystemClockContext structure has incorrect size"); +struct SteadyClockTimePoint { +    u64 value; +    INSERT_PADDING_WORDS(4); +}; +static_assert(sizeof(SteadyClockTimePoint) == 0x18, "SteadyClockTimePoint is incorrect size"); +  class Module final {  public:      class Interface : public ServiceFramework<Interface> { | 
