blob: ecb303ae18f89a7063e9ae4b140eef67c7330a45 [file] [log] [blame]
danilchapb1ac2032015-11-26 09:01:10 -08001/*
2* Copyright (c) 2015 The WebRTC project authors. All Rights Reserved.
3*
4* Use of this source code is governed by a BSD-style license
5* that can be found in the LICENSE file in the root of the source
6* tree. An additional intellectual property rights grant can be found
7* in the file PATENTS. All contributing project authors may
8* be found in the AUTHORS file in the root of the source tree.
9*/
10#ifndef WEBRTC_SYSTEM_WRAPPERS_INCLUDE_NTP_TIME_H_
11#define WEBRTC_SYSTEM_WRAPPERS_INCLUDE_NTP_TIME_H_
12
pbosc7c26a02017-01-02 08:42:32 -080013#include <stdint.h>
14
danilchapb1ac2032015-11-26 09:01:10 -080015namespace webrtc {
16
17class NtpTime {
18 public:
19 NtpTime() : seconds_(0), fractions_(0) {}
danilchapb1ac2032015-11-26 09:01:10 -080020 NtpTime(uint32_t seconds, uint32_t fractions)
21 : seconds_(seconds), fractions_(fractions) {}
22
23 NtpTime(const NtpTime&) = default;
24 NtpTime& operator=(const NtpTime&) = default;
25
danilchapb1ac2032015-11-26 09:01:10 -080026 void Set(uint32_t seconds, uint32_t fractions) {
27 seconds_ = seconds;
28 fractions_ = fractions;
29 }
30 void Reset() {
31 seconds_ = 0;
32 fractions_ = 0;
33 }
34
danilchap37953762017-02-09 11:15:25 -080035 int64_t ToMs() const {
36 static constexpr double kNtpFracPerMs = 4.294967296E6; // 2^32 / 1000.
37 const double frac_ms = static_cast<double>(fractions_) / kNtpFracPerMs;
38 return 1000 * static_cast<int64_t>(seconds_) +
39 static_cast<int64_t>(frac_ms + 0.5);
40 }
danilchapb1ac2032015-11-26 09:01:10 -080041 // NTP standard (RFC1305, section 3.1) explicitly state value 0/0 is invalid.
42 bool Valid() const { return !(seconds_ == 0 && fractions_ == 0); }
43
44 uint32_t seconds() const { return seconds_; }
45 uint32_t fractions() const { return fractions_; }
46
47 private:
48 uint32_t seconds_;
49 uint32_t fractions_;
50};
51
52inline bool operator==(const NtpTime& n1, const NtpTime& n2) {
53 return n1.seconds() == n2.seconds() && n1.fractions() == n2.fractions();
54}
55inline bool operator!=(const NtpTime& n1, const NtpTime& n2) {
56 return !(n1 == n2);
57}
58
59} // namespace webrtc
60#endif // WEBRTC_SYSTEM_WRAPPERS_INCLUDE_NTP_TIME_H_