blob: 63d80a21252fc8e89e810b9479b675da18b36ad7 [file] [log] [blame]
David Reissea2cba82009-03-30 21:35:00 +00001/*
2 * Licensed to the Apache Software Foundation (ASF) under one
3 * or more contributor license agreements. See the NOTICE file
4 * distributed with this work for additional information
5 * regarding copyright ownership. The ASF licenses this file
6 * to you under the Apache License, Version 2.0 (the
7 * "License"); you may not use this file except in compliance
8 * with the License. You may obtain a copy of the License at
9 *
10 * http://www.apache.org/licenses/LICENSE-2.0
11 *
12 * Unless required by applicable law or agreed to in writing,
13 * software distributed under the License is distributed on an
14 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
15 * KIND, either express or implied. See the License for the
16 * specific language governing permissions and limitations
17 * under the License.
18 */
Mark Slee9f0c6512007-02-28 23:58:26 +000019
Mark Sleef5f2be42006-09-05 21:05:31 +000020#ifndef _THRIFT_CONCURRENCY_UTIL_H_
21#define _THRIFT_CONCURRENCY_UTIL_H_ 1
Marc Slemko0e53ccd2006-07-17 23:51:05 +000022
23#include <assert.h>
Marc Slemko03dedd92006-07-20 00:58:47 +000024#include <stddef.h>
David Reiss53f18f02008-07-11 00:45:29 +000025#include <stdint.h>
Marc Slemkoe6889de2006-08-12 00:32:53 +000026#include <time.h>
Roger Meier2fa9c312011-09-05 19:15:53 +000027
28#ifdef HAVE_SYS_TIME_H
Marc Slemkod42a2c22006-08-10 03:30:18 +000029#include <sys/time.h>
Roger Meier2fa9c312011-09-05 19:15:53 +000030#endif
Marc Slemko0e53ccd2006-07-17 23:51:05 +000031
Roger Meier7158d332013-06-29 12:48:05 +020032#include <thrift/transport/PlatformSocket.h>
33
T Jake Lucianib5e62212009-01-31 22:36:20 +000034namespace apache { namespace thrift { namespace concurrency {
Marc Slemko0e53ccd2006-07-17 23:51:05 +000035
Mark Sleef5f2be42006-09-05 21:05:31 +000036/**
37 * Utility methods
38 *
39 * This class contains basic utility methods for converting time formats,
40 * and other common platform-dependent concurrency operations.
41 * It should not be included in API headers for other concurrency library
42 * headers, since it will, by definition, pull in all sorts of horrid
David Reiss3bb5e052010-01-25 19:31:31 +000043 * platform dependent stuff. Rather it should be inluded directly in
Mark Sleef5f2be42006-09-05 21:05:31 +000044 * concurrency library implementation source.
45 *
Mark Sleef5f2be42006-09-05 21:05:31 +000046 * @version $Id:$
47 */
Marc Slemko0e53ccd2006-07-17 23:51:05 +000048class Util {
49
Mark Slee9b82d272007-05-23 05:16:07 +000050 static const int64_t NS_PER_S = 1000000000LL;
David Reiss631dcb42008-03-05 07:51:40 +000051 static const int64_t US_PER_S = 1000000LL;
Mark Slee9b82d272007-05-23 05:16:07 +000052 static const int64_t MS_PER_S = 1000LL;
David Reiss631dcb42008-03-05 07:51:40 +000053
54 static const int64_t NS_PER_MS = NS_PER_S / MS_PER_S;
David Reiss7a2065d2010-03-09 05:20:04 +000055 static const int64_t NS_PER_US = NS_PER_S / US_PER_S;
David Reiss631dcb42008-03-05 07:51:40 +000056 static const int64_t US_PER_MS = US_PER_S / MS_PER_S;
Marc Slemkoc7782972006-07-25 02:26:35 +000057
Marc Slemko0e53ccd2006-07-17 23:51:05 +000058 public:
59
Mark Sleef5f2be42006-09-05 21:05:31 +000060 /**
Carl Yeksigian7cb7fc82013-06-07 07:33:01 -040061 * Converts millisecond timestamp into a THRIFT_TIMESPEC struct
Mark Sleef5f2be42006-09-05 21:05:31 +000062 *
Carl Yeksigian7cb7fc82013-06-07 07:33:01 -040063 * @param struct THRIFT_TIMESPEC& result
Mark Sleef5f2be42006-09-05 21:05:31 +000064 * @param time or duration in milliseconds
65 */
Carl Yeksigian7cb7fc82013-06-07 07:33:01 -040066 static void toTimespec(struct THRIFT_TIMESPEC& result, int64_t value) {
David Reiss0c90f6f2008-02-06 22:18:40 +000067 result.tv_sec = value / MS_PER_S; // ms to s
Marc Slemkoc7782972006-07-25 02:26:35 +000068 result.tv_nsec = (value % MS_PER_S) * NS_PER_MS; // ms to ns
Marc Slemko0e53ccd2006-07-17 23:51:05 +000069 }
70
David Reiss631dcb42008-03-05 07:51:40 +000071 static void toTimeval(struct timeval& result, int64_t value) {
Roger Meier82525772012-11-16 00:38:27 +000072 result.tv_sec = static_cast<uint32_t>(value / MS_PER_S); // ms to s
73 result.tv_usec = static_cast<uint32_t>((value % MS_PER_S) * US_PER_MS); // ms to us
David Reiss631dcb42008-03-05 07:51:40 +000074 }
75
Roger Meier3b771a12010-11-17 22:11:26 +000076 static void toTicks(int64_t& result, int64_t secs, int64_t oldTicks,
Roger Meier7158d332013-06-29 12:48:05 +020077 int64_t oldTicksPerSec, int64_t newTicksPerSec) {
David Reiss7a2065d2010-03-09 05:20:04 +000078 result = secs * newTicksPerSec;
79 result += oldTicks * newTicksPerSec / oldTicksPerSec;
80
81 int64_t oldPerNew = oldTicksPerSec / newTicksPerSec;
82 if (oldPerNew && ((oldTicks % oldPerNew) >= (oldPerNew / 2))) {
83 ++result;
84 }
85 }
86 /**
Carl Yeksigian7cb7fc82013-06-07 07:33:01 -040087 * Converts struct THRIFT_TIMESPEC to arbitrary-sized ticks since epoch
David Reiss7a2065d2010-03-09 05:20:04 +000088 */
Roger Meier3b771a12010-11-17 22:11:26 +000089 static void toTicks(int64_t& result,
Roger Meier7158d332013-06-29 12:48:05 +020090 const struct THRIFT_TIMESPEC& value,
91 int64_t ticksPerSec) {
David Reiss7a2065d2010-03-09 05:20:04 +000092 return toTicks(result, value.tv_sec, value.tv_nsec, NS_PER_S, ticksPerSec);
93 }
94
95 /**
96 * Converts struct timeval to arbitrary-sized ticks since epoch
97 */
Roger Meier3b771a12010-11-17 22:11:26 +000098 static void toTicks(int64_t& result,
Roger Meier7158d332013-06-29 12:48:05 +020099 const struct timeval& value,
100 int64_t ticksPerSec) {
David Reiss7a2065d2010-03-09 05:20:04 +0000101 return toTicks(result, value.tv_sec, value.tv_usec, US_PER_S, ticksPerSec);
102 }
103
Mark Sleef5f2be42006-09-05 21:05:31 +0000104 /**
Carl Yeksigian7cb7fc82013-06-07 07:33:01 -0400105 * Converts struct THRIFT_TIMESPEC to milliseconds
Mark Sleef5f2be42006-09-05 21:05:31 +0000106 */
Roger Meier3b771a12010-11-17 22:11:26 +0000107 static void toMilliseconds(int64_t& result,
Roger Meier7158d332013-06-29 12:48:05 +0200108 const struct THRIFT_TIMESPEC& value) {
David Reiss7a2065d2010-03-09 05:20:04 +0000109 return toTicks(result, value, MS_PER_S);
David Reiss631dcb42008-03-05 07:51:40 +0000110 }
111
112 /**
113 * Converts struct timeval to milliseconds
114 */
Roger Meier3b771a12010-11-17 22:11:26 +0000115 static void toMilliseconds(int64_t& result,
Roger Meier7158d332013-06-29 12:48:05 +0200116 const struct timeval& value) {
David Reiss7a2065d2010-03-09 05:20:04 +0000117 return toTicks(result, value, MS_PER_S);
Marc Slemko0e53ccd2006-07-17 23:51:05 +0000118 }
119
Mark Sleef5f2be42006-09-05 21:05:31 +0000120 /**
Carl Yeksigian7cb7fc82013-06-07 07:33:01 -0400121 * Converts struct THRIFT_TIMESPEC to microseconds
David Reiss7a2065d2010-03-09 05:20:04 +0000122 */
Carl Yeksigian7cb7fc82013-06-07 07:33:01 -0400123 static void toUsec(int64_t& result, const struct THRIFT_TIMESPEC& value) {
David Reiss7a2065d2010-03-09 05:20:04 +0000124 return toTicks(result, value, US_PER_S);
125 }
126
127 /**
128 * Converts struct timeval to microseconds
129 */
Roger Meier3b771a12010-11-17 22:11:26 +0000130 static void toUsec(int64_t& result, const struct timeval& value) {
David Reiss7a2065d2010-03-09 05:20:04 +0000131 return toTicks(result, value, US_PER_S);
132 }
133
134 /**
135 * Get current time as a number of arbitrary-size ticks from epoch
136 */
Roger Meier3b771a12010-11-17 22:11:26 +0000137 static int64_t currentTimeTicks(int64_t ticksPerSec);
David Reiss7a2065d2010-03-09 05:20:04 +0000138
139 /**
Mark Sleef5f2be42006-09-05 21:05:31 +0000140 * Get current time as milliseconds from epoch
141 */
Roger Meier3b771a12010-11-17 22:11:26 +0000142 static int64_t currentTime() { return currentTimeTicks(MS_PER_S); }
David Reiss7a2065d2010-03-09 05:20:04 +0000143
144 /**
145 * Get current time as micros from epoch
146 */
Roger Meier3b771a12010-11-17 22:11:26 +0000147 static int64_t currentTimeUsec() { return currentTimeTicks(US_PER_S); }
Marc Slemko0e53ccd2006-07-17 23:51:05 +0000148};
149
T Jake Lucianib5e62212009-01-31 22:36:20 +0000150}}} // apache::thrift::concurrency
Marc Slemko0e53ccd2006-07-17 23:51:05 +0000151
Mark Sleef5f2be42006-09-05 21:05:31 +0000152#endif // #ifndef _THRIFT_CONCURRENCY_UTIL_H_