OLD | NEW |
1 // Copyright 2006-2008 the V8 project authors. All rights reserved. | 1 // Copyright 2006-2008 the V8 project authors. All rights reserved. |
2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without |
3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are |
4 // met: | 4 // met: |
5 // | 5 // |
6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright |
7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. |
8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above |
9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following |
10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided |
(...skipping 63 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
74 // Seed the random number generator. | 74 // Seed the random number generator. |
75 // Convert the current time to a 64-bit integer first, before converting it | 75 // Convert the current time to a 64-bit integer first, before converting it |
76 // to an unsigned. Going directly can cause an overflow and the seed to be | 76 // to an unsigned. Going directly can cause an overflow and the seed to be |
77 // set to all ones. The seed will be identical for different instances that | 77 // set to all ones. The seed will be identical for different instances that |
78 // call this setup code within the same millisecond. | 78 // call this setup code within the same millisecond. |
79 uint64_t seed = static_cast<uint64_t>(TimeCurrentMillis()); | 79 uint64_t seed = static_cast<uint64_t>(TimeCurrentMillis()); |
80 srandom(static_cast<unsigned int>(seed)); | 80 srandom(static_cast<unsigned int>(seed)); |
81 } | 81 } |
82 | 82 |
83 | 83 |
84 int OS::GetUserTime(uint32_t* secs, uint32_t* usecs) { | |
85 struct rusage usage; | |
86 | |
87 if (getrusage(RUSAGE_SELF, &usage) < 0) return -1; | |
88 *secs = usage.ru_utime.tv_sec; | |
89 *usecs = usage.ru_utime.tv_usec; | |
90 return 0; | |
91 } | |
92 | |
93 | |
94 double OS::TimeCurrentMillis() { | |
95 struct timeval tv; | |
96 if (gettimeofday(&tv, NULL) < 0) return 0.0; | |
97 return (static_cast<double>(tv.tv_sec) * 1000) + | |
98 (static_cast<double>(tv.tv_usec) / 1000); | |
99 } | |
100 | |
101 | |
102 int64_t OS::Ticks() { | |
103 // Linux's gettimeofday has microsecond resolution. | |
104 struct timeval tv; | |
105 if (gettimeofday(&tv, NULL) < 0) | |
106 return 0; | |
107 return (static_cast<int64_t>(tv.tv_sec) * 1000000) + tv.tv_usec; | |
108 } | |
109 | |
110 | |
111 char* OS::LocalTimezone(double time) { | |
112 time_t tv = static_cast<time_t>(floor(time/msPerSecond)); | |
113 struct tm* t = localtime(&tv); | |
114 return const_cast<char*>(t->tm_zone); | |
115 } | |
116 | |
117 | |
118 double OS::DaylightSavingsOffset(double time) { | |
119 time_t tv = static_cast<time_t>(floor(time/msPerSecond)); | |
120 struct tm* t = localtime(&tv); | |
121 return t->tm_isdst > 0 ? 3600 * msPerSecond : 0; | |
122 } | |
123 | |
124 | |
125 double OS::LocalTimeOffset() { | |
126 time_t tv = time(NULL); | |
127 struct tm* t = localtime(&tv); | |
128 // tm_gmtoff includes any daylight savings offset, so subtract it. | |
129 return static_cast<double>(t->tm_gmtoff * msPerSecond - | |
130 (t->tm_isdst > 0 ? 3600 * msPerSecond : 0)); | |
131 } | |
132 | |
133 | |
134 FILE* OS::FOpen(const char* path, const char* mode) { | 84 FILE* OS::FOpen(const char* path, const char* mode) { |
135 return fopen(path, mode); | 85 return fopen(path, mode); |
136 } | 86 } |
137 | 87 |
138 | 88 |
139 void OS::Print(const char* format, ...) { | 89 void OS::Print(const char* format, ...) { |
140 va_list args; | 90 va_list args; |
141 va_start(args, format); | 91 va_start(args, format); |
142 VPrint(format, args); | 92 VPrint(format, args); |
143 va_end(args); | 93 va_end(args); |
(...skipping 595 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
739 } | 689 } |
740 | 690 |
741 // This sampler is no longer the active sampler. | 691 // This sampler is no longer the active sampler. |
742 active_sampler_ = NULL; | 692 active_sampler_ = NULL; |
743 active_ = false; | 693 active_ = false; |
744 } | 694 } |
745 | 695 |
746 #endif // ENABLE_LOGGING_AND_PROFILING | 696 #endif // ENABLE_LOGGING_AND_PROFILING |
747 | 697 |
748 } } // namespace v8::internal | 698 } } // namespace v8::internal |
OLD | NEW |