OLD | NEW |
1 // Copyright 2013 the V8 project authors. All rights reserved. | 1 // Copyright 2013 the V8 project authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 // Platform-specific code for QNX goes here. For the POSIX-compatible | 5 // Platform-specific code for QNX goes here. For the POSIX-compatible |
6 // parts the implementation is in platform-posix.cc. | 6 // parts the implementation is in platform-posix.cc. |
7 | 7 |
8 #include <backtrace.h> | 8 #include <backtrace.h> |
9 #include <pthread.h> | 9 #include <pthread.h> |
10 #include <semaphore.h> | 10 #include <semaphore.h> |
(...skipping 70 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
81 #endif | 81 #endif |
82 #undef GCC_VERSION | 82 #undef GCC_VERSION |
83 } | 83 } |
84 | 84 |
85 #endif // __arm__ | 85 #endif // __arm__ |
86 | 86 |
87 | 87 |
88 const char* OS::LocalTimezone(double time, TimezoneCache* cache) { | 88 const char* OS::LocalTimezone(double time, TimezoneCache* cache) { |
89 if (std::isnan(time)) return ""; | 89 if (std::isnan(time)) return ""; |
90 time_t tv = static_cast<time_t>(std::floor(time/msPerSecond)); | 90 time_t tv = static_cast<time_t>(std::floor(time/msPerSecond)); |
91 struct tm* t = localtime(&tv); // NOLINT(runtime/threadsafe_fn) | 91 struct tm tm; |
| 92 struct tm* t = localtime_r(&tv, &tm); |
92 if (NULL == t) return ""; | 93 if (NULL == t) return ""; |
93 return t->tm_zone; | 94 return t->tm_zone; |
94 } | 95 } |
95 | 96 |
96 | 97 |
97 double OS::LocalTimeOffset(TimezoneCache* cache) { | 98 double OS::LocalTimeOffset(TimezoneCache* cache) { |
98 time_t tv = time(NULL); | 99 time_t tv = time(NULL); |
99 struct tm* t = localtime(&tv); // NOLINT(runtime/threadsafe_fn) | 100 struct tm tm; |
| 101 struct tm* t = localtime_r(&tv, &tm); |
100 // tm_gmtoff includes any daylight savings offset, so subtract it. | 102 // tm_gmtoff includes any daylight savings offset, so subtract it. |
101 return static_cast<double>(t->tm_gmtoff * msPerSecond - | 103 return static_cast<double>(t->tm_gmtoff * msPerSecond - |
102 (t->tm_isdst > 0 ? 3600 * msPerSecond : 0)); | 104 (t->tm_isdst > 0 ? 3600 * msPerSecond : 0)); |
103 } | 105 } |
104 | 106 |
105 | 107 |
106 void* OS::Allocate(const size_t requested, | 108 void* OS::Allocate(const size_t requested, |
107 size_t* allocated, | 109 size_t* allocated, |
108 bool is_executable) { | 110 bool is_executable) { |
109 const size_t msize = RoundUp(requested, AllocateAlignment()); | 111 const size_t msize = RoundUp(requested, AllocateAlignment()); |
(...skipping 197 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
307 return munmap(base, size) == 0; | 309 return munmap(base, size) == 0; |
308 } | 310 } |
309 | 311 |
310 | 312 |
311 bool VirtualMemory::HasLazyCommits() { | 313 bool VirtualMemory::HasLazyCommits() { |
312 return false; | 314 return false; |
313 } | 315 } |
314 | 316 |
315 } // namespace base | 317 } // namespace base |
316 } // namespace v8 | 318 } // namespace v8 |
OLD | NEW |