kmillikin@chromium.org | c36ce6e | 2011-04-04 08:25:31 +0000 | [diff] [blame] | 1 | // Copyright 2011 the V8 project authors. All rights reserved. |
ager@chromium.org | bb29dc9 | 2009-03-24 13:25:23 +0000 | [diff] [blame] | 2 | // Redistribution and use in source and binary forms, with or without |
| 3 | // modification, are permitted provided that the following conditions are |
| 4 | // met: |
| 5 | // |
| 6 | // * Redistributions of source code must retain the above copyright |
| 7 | // notice, this list of conditions and the following disclaimer. |
| 8 | // * Redistributions in binary form must reproduce the above |
| 9 | // copyright notice, this list of conditions and the following |
| 10 | // disclaimer in the documentation and/or other materials provided |
| 11 | // with the distribution. |
| 12 | // * Neither the name of Google Inc. nor the names of its |
| 13 | // contributors may be used to endorse or promote products derived |
| 14 | // from this software without specific prior written permission. |
| 15 | // |
| 16 | // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
| 17 | // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
| 18 | // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |
| 19 | // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT |
| 20 | // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
| 21 | // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
| 22 | // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
| 23 | // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
| 24 | // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
| 25 | // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
| 26 | // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| 27 | |
| 28 | // Platform specific code for POSIX goes here. This is not a platform on its |
| 29 | // own but contains the parts which are the same across POSIX platforms Linux, |
sgjesse@chromium.org | ac6aa17 | 2009-12-04 12:29:05 +0000 | [diff] [blame] | 30 | // Mac OS, FreeBSD and OpenBSD. |
ager@chromium.org | bb29dc9 | 2009-03-24 13:25:23 +0000 | [diff] [blame] | 31 | |
| 32 | #include <unistd.h> |
| 33 | #include <errno.h> |
ager@chromium.org | 41826e7 | 2009-03-30 13:30:57 +0000 | [diff] [blame] | 34 | #include <time.h> |
ager@chromium.org | bb29dc9 | 2009-03-24 13:25:23 +0000 | [diff] [blame] | 35 | |
rossberg@chromium.org | 717967f | 2011-07-20 13:44:42 +0000 | [diff] [blame] | 36 | #include <sys/mman.h> |
ager@chromium.org | bb29dc9 | 2009-03-24 13:25:23 +0000 | [diff] [blame] | 37 | #include <sys/socket.h> |
ager@chromium.org | 41826e7 | 2009-03-30 13:30:57 +0000 | [diff] [blame] | 38 | #include <sys/resource.h> |
| 39 | #include <sys/time.h> |
ager@chromium.org | bb29dc9 | 2009-03-24 13:25:23 +0000 | [diff] [blame] | 40 | #include <sys/types.h> |
whesse@chromium.org | 030d38e | 2011-07-13 13:23:34 +0000 | [diff] [blame] | 41 | #include <sys/stat.h> |
ager@chromium.org | bb29dc9 | 2009-03-24 13:25:23 +0000 | [diff] [blame] | 42 | |
| 43 | #include <arpa/inet.h> |
| 44 | #include <netinet/in.h> |
| 45 | #include <netdb.h> |
| 46 | |
rossberg@chromium.org | 717967f | 2011-07-20 13:44:42 +0000 | [diff] [blame] | 47 | #undef MAP_TYPE |
| 48 | |
kasperl@chromium.org | e959c18 | 2009-07-27 08:59:04 +0000 | [diff] [blame] | 49 | #if defined(ANDROID) |
| 50 | #define LOG_TAG "v8" |
| 51 | #include <utils/Log.h> // LOG_PRI_VA |
| 52 | #endif |
| 53 | |
ager@chromium.org | bb29dc9 | 2009-03-24 13:25:23 +0000 | [diff] [blame] | 54 | #include "v8.h" |
| 55 | |
| 56 | #include "platform.h" |
| 57 | |
kasperl@chromium.org | 71affb5 | 2009-05-26 05:44:31 +0000 | [diff] [blame] | 58 | namespace v8 { |
| 59 | namespace internal { |
ager@chromium.org | bb29dc9 | 2009-03-24 13:25:23 +0000 | [diff] [blame] | 60 | |
lrn@chromium.org | ac2828d | 2011-06-23 06:29:21 +0000 | [diff] [blame] | 61 | |
| 62 | // Maximum size of the virtual memory. 0 means there is no artificial |
| 63 | // limit. |
| 64 | |
| 65 | intptr_t OS::MaxVirtualMemory() { |
| 66 | struct rlimit limit; |
| 67 | int result = getrlimit(RLIMIT_DATA, &limit); |
| 68 | if (result != 0) return 0; |
| 69 | return limit.rlim_cur; |
| 70 | } |
| 71 | |
| 72 | |
lrn@chromium.org | d4e9e22 | 2011-08-03 12:01:58 +0000 | [diff] [blame] | 73 | #ifndef __CYGWIN__ |
| 74 | // Get rid of writable permission on code allocations. |
| 75 | void OS::ProtectCode(void* address, const size_t size) { |
| 76 | mprotect(address, size, PROT_READ | PROT_EXEC); |
| 77 | } |
| 78 | |
| 79 | |
rossberg@chromium.org | 717967f | 2011-07-20 13:44:42 +0000 | [diff] [blame] | 80 | // Create guard pages. |
| 81 | void OS::Guard(void* address, const size_t size) { |
| 82 | mprotect(address, size, PROT_NONE); |
| 83 | } |
lrn@chromium.org | d4e9e22 | 2011-08-03 12:01:58 +0000 | [diff] [blame] | 84 | #endif // __CYGWIN__ |
rossberg@chromium.org | 717967f | 2011-07-20 13:44:42 +0000 | [diff] [blame] | 85 | |
| 86 | |
ager@chromium.org | 3811b43 | 2009-10-28 14:53:37 +0000 | [diff] [blame] | 87 | // ---------------------------------------------------------------------------- |
| 88 | // Math functions |
| 89 | |
| 90 | double modulo(double x, double y) { |
| 91 | return fmod(x, y); |
| 92 | } |
ager@chromium.org | bb29dc9 | 2009-03-24 13:25:23 +0000 | [diff] [blame] | 93 | |
sgjesse@chromium.org | ac6aa17 | 2009-12-04 12:29:05 +0000 | [diff] [blame] | 94 | |
| 95 | double OS::nan_value() { |
| 96 | // NAN from math.h is defined in C99 and not in POSIX. |
| 97 | return NAN; |
| 98 | } |
| 99 | |
| 100 | |
ager@chromium.org | bb29dc9 | 2009-03-24 13:25:23 +0000 | [diff] [blame] | 101 | // ---------------------------------------------------------------------------- |
ager@chromium.org | 41826e7 | 2009-03-30 13:30:57 +0000 | [diff] [blame] | 102 | // POSIX date/time support. |
| 103 | // |
| 104 | |
| 105 | int OS::GetUserTime(uint32_t* secs, uint32_t* usecs) { |
| 106 | struct rusage usage; |
| 107 | |
| 108 | if (getrusage(RUSAGE_SELF, &usage) < 0) return -1; |
| 109 | *secs = usage.ru_utime.tv_sec; |
| 110 | *usecs = usage.ru_utime.tv_usec; |
| 111 | return 0; |
| 112 | } |
| 113 | |
| 114 | |
| 115 | double OS::TimeCurrentMillis() { |
| 116 | struct timeval tv; |
| 117 | if (gettimeofday(&tv, NULL) < 0) return 0.0; |
| 118 | return (static_cast<double>(tv.tv_sec) * 1000) + |
| 119 | (static_cast<double>(tv.tv_usec) / 1000); |
| 120 | } |
| 121 | |
| 122 | |
| 123 | int64_t OS::Ticks() { |
| 124 | // gettimeofday has microsecond resolution. |
| 125 | struct timeval tv; |
| 126 | if (gettimeofday(&tv, NULL) < 0) |
| 127 | return 0; |
| 128 | return (static_cast<int64_t>(tv.tv_sec) * 1000000) + tv.tv_usec; |
| 129 | } |
| 130 | |
| 131 | |
ager@chromium.org | 41826e7 | 2009-03-30 13:30:57 +0000 | [diff] [blame] | 132 | double OS::DaylightSavingsOffset(double time) { |
sgjesse@chromium.org | b9d7da1 | 2009-08-05 08:38:10 +0000 | [diff] [blame] | 133 | if (isnan(time)) return nan_value(); |
ager@chromium.org | 41826e7 | 2009-03-30 13:30:57 +0000 | [diff] [blame] | 134 | time_t tv = static_cast<time_t>(floor(time/msPerSecond)); |
| 135 | struct tm* t = localtime(&tv); |
sgjesse@chromium.org | b9d7da1 | 2009-08-05 08:38:10 +0000 | [diff] [blame] | 136 | if (NULL == t) return nan_value(); |
ager@chromium.org | 41826e7 | 2009-03-30 13:30:57 +0000 | [diff] [blame] | 137 | return t->tm_isdst > 0 ? 3600 * msPerSecond : 0; |
| 138 | } |
| 139 | |
| 140 | |
ager@chromium.org | ea4f62e | 2010-08-16 16:28:43 +0000 | [diff] [blame] | 141 | int OS::GetLastError() { |
| 142 | return errno; |
| 143 | } |
| 144 | |
| 145 | |
ager@chromium.org | 41826e7 | 2009-03-30 13:30:57 +0000 | [diff] [blame] | 146 | // ---------------------------------------------------------------------------- |
| 147 | // POSIX stdio support. |
| 148 | // |
| 149 | |
| 150 | FILE* OS::FOpen(const char* path, const char* mode) { |
whesse@chromium.org | 030d38e | 2011-07-13 13:23:34 +0000 | [diff] [blame] | 151 | FILE* file = fopen(path, mode); |
| 152 | if (file == NULL) return NULL; |
| 153 | struct stat file_stat; |
| 154 | if (fstat(fileno(file), &file_stat) != 0) return NULL; |
| 155 | bool is_regular_file = ((file_stat.st_mode & S_IFREG) != 0); |
| 156 | if (is_regular_file) return file; |
| 157 | fclose(file); |
| 158 | return NULL; |
ager@chromium.org | 41826e7 | 2009-03-30 13:30:57 +0000 | [diff] [blame] | 159 | } |
| 160 | |
| 161 | |
vegorov@chromium.org | 0a4e901 | 2011-01-24 12:33:13 +0000 | [diff] [blame] | 162 | bool OS::Remove(const char* path) { |
| 163 | return (remove(path) == 0); |
| 164 | } |
| 165 | |
| 166 | |
whesse@chromium.org | 030d38e | 2011-07-13 13:23:34 +0000 | [diff] [blame] | 167 | FILE* OS::OpenTemporaryFile() { |
| 168 | return tmpfile(); |
| 169 | } |
| 170 | |
| 171 | |
sgjesse@chromium.org | ea88ce9 | 2011-03-23 11:19:56 +0000 | [diff] [blame] | 172 | const char* const OS::LogFileOpenMode = "w"; |
ager@chromium.org | 71daaf6 | 2009-04-01 07:22:49 +0000 | [diff] [blame] | 173 | |
| 174 | |
ager@chromium.org | 41826e7 | 2009-03-30 13:30:57 +0000 | [diff] [blame] | 175 | void OS::Print(const char* format, ...) { |
| 176 | va_list args; |
| 177 | va_start(args, format); |
| 178 | VPrint(format, args); |
| 179 | va_end(args); |
| 180 | } |
| 181 | |
| 182 | |
| 183 | void OS::VPrint(const char* format, va_list args) { |
ricow@chromium.org | badaffc | 2011-03-17 12:15:27 +0000 | [diff] [blame] | 184 | #if defined(ANDROID) && !defined(V8_ANDROID_LOG_STDOUT) |
kasperl@chromium.org | e959c18 | 2009-07-27 08:59:04 +0000 | [diff] [blame] | 185 | LOG_PRI_VA(ANDROID_LOG_INFO, LOG_TAG, format, args); |
| 186 | #else |
ager@chromium.org | 41826e7 | 2009-03-30 13:30:57 +0000 | [diff] [blame] | 187 | vprintf(format, args); |
kasperl@chromium.org | e959c18 | 2009-07-27 08:59:04 +0000 | [diff] [blame] | 188 | #endif |
ager@chromium.org | 41826e7 | 2009-03-30 13:30:57 +0000 | [diff] [blame] | 189 | } |
| 190 | |
| 191 | |
whesse@chromium.org | 023421e | 2010-12-21 12:19:12 +0000 | [diff] [blame] | 192 | void OS::FPrint(FILE* out, const char* format, ...) { |
| 193 | va_list args; |
| 194 | va_start(args, format); |
| 195 | VFPrint(out, format, args); |
| 196 | va_end(args); |
| 197 | } |
| 198 | |
| 199 | |
| 200 | void OS::VFPrint(FILE* out, const char* format, va_list args) { |
ricow@chromium.org | badaffc | 2011-03-17 12:15:27 +0000 | [diff] [blame] | 201 | #if defined(ANDROID) && !defined(V8_ANDROID_LOG_STDOUT) |
whesse@chromium.org | 023421e | 2010-12-21 12:19:12 +0000 | [diff] [blame] | 202 | LOG_PRI_VA(ANDROID_LOG_INFO, LOG_TAG, format, args); |
| 203 | #else |
| 204 | vfprintf(out, format, args); |
| 205 | #endif |
| 206 | } |
| 207 | |
| 208 | |
ager@chromium.org | 41826e7 | 2009-03-30 13:30:57 +0000 | [diff] [blame] | 209 | void OS::PrintError(const char* format, ...) { |
| 210 | va_list args; |
| 211 | va_start(args, format); |
| 212 | VPrintError(format, args); |
| 213 | va_end(args); |
| 214 | } |
| 215 | |
| 216 | |
| 217 | void OS::VPrintError(const char* format, va_list args) { |
ricow@chromium.org | badaffc | 2011-03-17 12:15:27 +0000 | [diff] [blame] | 218 | #if defined(ANDROID) && !defined(V8_ANDROID_LOG_STDOUT) |
kasperl@chromium.org | e959c18 | 2009-07-27 08:59:04 +0000 | [diff] [blame] | 219 | LOG_PRI_VA(ANDROID_LOG_ERROR, LOG_TAG, format, args); |
| 220 | #else |
ager@chromium.org | 41826e7 | 2009-03-30 13:30:57 +0000 | [diff] [blame] | 221 | vfprintf(stderr, format, args); |
kasperl@chromium.org | e959c18 | 2009-07-27 08:59:04 +0000 | [diff] [blame] | 222 | #endif |
ager@chromium.org | 41826e7 | 2009-03-30 13:30:57 +0000 | [diff] [blame] | 223 | } |
| 224 | |
| 225 | |
| 226 | int OS::SNPrintF(Vector<char> str, const char* format, ...) { |
| 227 | va_list args; |
| 228 | va_start(args, format); |
| 229 | int result = VSNPrintF(str, format, args); |
| 230 | va_end(args); |
| 231 | return result; |
| 232 | } |
| 233 | |
| 234 | |
| 235 | int OS::VSNPrintF(Vector<char> str, |
| 236 | const char* format, |
| 237 | va_list args) { |
| 238 | int n = vsnprintf(str.start(), str.length(), format, args); |
| 239 | if (n < 0 || n >= str.length()) { |
whesse@chromium.org | 023421e | 2010-12-21 12:19:12 +0000 | [diff] [blame] | 240 | // If the length is zero, the assignment fails. |
| 241 | if (str.length() > 0) |
| 242 | str[str.length() - 1] = '\0'; |
ager@chromium.org | 41826e7 | 2009-03-30 13:30:57 +0000 | [diff] [blame] | 243 | return -1; |
| 244 | } else { |
| 245 | return n; |
| 246 | } |
| 247 | } |
| 248 | |
| 249 | |
kmillikin@chromium.org | c36ce6e | 2011-04-04 08:25:31 +0000 | [diff] [blame] | 250 | #if defined(V8_TARGET_ARCH_IA32) |
| 251 | static OS::MemCopyFunction memcopy_function = NULL; |
| 252 | static Mutex* memcopy_function_mutex = OS::CreateMutex(); |
| 253 | // Defined in codegen-ia32.cc. |
| 254 | OS::MemCopyFunction CreateMemCopyFunction(); |
| 255 | |
| 256 | // Copy memory area to disjoint memory area. |
| 257 | void OS::MemCopy(void* dest, const void* src, size_t size) { |
| 258 | if (memcopy_function == NULL) { |
| 259 | ScopedLock lock(memcopy_function_mutex); |
| 260 | if (memcopy_function == NULL) { |
| 261 | OS::MemCopyFunction temp = CreateMemCopyFunction(); |
| 262 | MemoryBarrier(); |
| 263 | memcopy_function = temp; |
| 264 | } |
| 265 | } |
| 266 | // Note: here we rely on dependent reads being ordered. This is true |
| 267 | // on all architectures we currently support. |
| 268 | (*memcopy_function)(dest, src, size); |
| 269 | #ifdef DEBUG |
| 270 | CHECK_EQ(0, memcmp(dest, src, size)); |
| 271 | #endif |
| 272 | } |
| 273 | #endif // V8_TARGET_ARCH_IA32 |
| 274 | |
ager@chromium.org | 41826e7 | 2009-03-30 13:30:57 +0000 | [diff] [blame] | 275 | // ---------------------------------------------------------------------------- |
| 276 | // POSIX string support. |
| 277 | // |
| 278 | |
| 279 | char* OS::StrChr(char* str, int c) { |
| 280 | return strchr(str, c); |
| 281 | } |
| 282 | |
| 283 | |
| 284 | void OS::StrNCpy(Vector<char> dest, const char* src, size_t n) { |
| 285 | strncpy(dest.start(), src, n); |
| 286 | } |
| 287 | |
| 288 | |
| 289 | // ---------------------------------------------------------------------------- |
ager@chromium.org | bb29dc9 | 2009-03-24 13:25:23 +0000 | [diff] [blame] | 290 | // POSIX socket support. |
| 291 | // |
| 292 | |
| 293 | class POSIXSocket : public Socket { |
| 294 | public: |
| 295 | explicit POSIXSocket() { |
| 296 | // Create the socket. |
| 297 | socket_ = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP); |
whesse@chromium.org | 023421e | 2010-12-21 12:19:12 +0000 | [diff] [blame] | 298 | if (IsValid()) { |
| 299 | // Allow rapid reuse. |
| 300 | static const int kOn = 1; |
| 301 | int ret = setsockopt(socket_, SOL_SOCKET, SO_REUSEADDR, |
| 302 | &kOn, sizeof(kOn)); |
| 303 | ASSERT(ret == 0); |
| 304 | USE(ret); |
| 305 | } |
ager@chromium.org | bb29dc9 | 2009-03-24 13:25:23 +0000 | [diff] [blame] | 306 | } |
| 307 | explicit POSIXSocket(int socket): socket_(socket) { } |
| 308 | virtual ~POSIXSocket() { Shutdown(); } |
| 309 | |
| 310 | // Server initialization. |
| 311 | bool Bind(const int port); |
| 312 | bool Listen(int backlog) const; |
| 313 | Socket* Accept() const; |
| 314 | |
| 315 | // Client initialization. |
| 316 | bool Connect(const char* host, const char* port); |
| 317 | |
| 318 | // Shutdown socket for both read and write. |
| 319 | bool Shutdown(); |
| 320 | |
| 321 | // Data Transimission |
| 322 | int Send(const char* data, int len) const; |
| 323 | int Receive(char* data, int len) const; |
| 324 | |
| 325 | bool SetReuseAddress(bool reuse_address); |
| 326 | |
| 327 | bool IsValid() const { return socket_ != -1; } |
| 328 | |
| 329 | private: |
| 330 | int socket_; |
| 331 | }; |
| 332 | |
| 333 | |
| 334 | bool POSIXSocket::Bind(const int port) { |
| 335 | if (!IsValid()) { |
| 336 | return false; |
| 337 | } |
| 338 | |
| 339 | sockaddr_in addr; |
| 340 | memset(&addr, 0, sizeof(addr)); |
| 341 | addr.sin_family = AF_INET; |
| 342 | addr.sin_addr.s_addr = htonl(INADDR_LOOPBACK); |
| 343 | addr.sin_port = htons(port); |
| 344 | int status = bind(socket_, |
ager@chromium.org | ea4f62e | 2010-08-16 16:28:43 +0000 | [diff] [blame] | 345 | BitCast<struct sockaddr *>(&addr), |
ager@chromium.org | bb29dc9 | 2009-03-24 13:25:23 +0000 | [diff] [blame] | 346 | sizeof(addr)); |
| 347 | return status == 0; |
| 348 | } |
| 349 | |
| 350 | |
| 351 | bool POSIXSocket::Listen(int backlog) const { |
| 352 | if (!IsValid()) { |
| 353 | return false; |
| 354 | } |
| 355 | |
| 356 | int status = listen(socket_, backlog); |
| 357 | return status == 0; |
| 358 | } |
| 359 | |
| 360 | |
| 361 | Socket* POSIXSocket::Accept() const { |
| 362 | if (!IsValid()) { |
| 363 | return NULL; |
| 364 | } |
| 365 | |
| 366 | int socket = accept(socket_, NULL, NULL); |
| 367 | if (socket == -1) { |
| 368 | return NULL; |
| 369 | } else { |
| 370 | return new POSIXSocket(socket); |
| 371 | } |
| 372 | } |
| 373 | |
| 374 | |
| 375 | bool POSIXSocket::Connect(const char* host, const char* port) { |
| 376 | if (!IsValid()) { |
| 377 | return false; |
| 378 | } |
| 379 | |
| 380 | // Lookup host and port. |
| 381 | struct addrinfo *result = NULL; |
| 382 | struct addrinfo hints; |
| 383 | memset(&hints, 0, sizeof(addrinfo)); |
| 384 | hints.ai_family = AF_INET; |
| 385 | hints.ai_socktype = SOCK_STREAM; |
| 386 | hints.ai_protocol = IPPROTO_TCP; |
| 387 | int status = getaddrinfo(host, port, &hints, &result); |
| 388 | if (status != 0) { |
| 389 | return false; |
| 390 | } |
| 391 | |
| 392 | // Connect. |
| 393 | status = connect(socket_, result->ai_addr, result->ai_addrlen); |
| 394 | freeaddrinfo(result); |
| 395 | return status == 0; |
| 396 | } |
| 397 | |
| 398 | |
| 399 | bool POSIXSocket::Shutdown() { |
| 400 | if (IsValid()) { |
| 401 | // Shutdown socket for both read and write. |
| 402 | int status = shutdown(socket_, SHUT_RDWR); |
| 403 | close(socket_); |
| 404 | socket_ = -1; |
| 405 | return status == 0; |
| 406 | } |
| 407 | return true; |
| 408 | } |
| 409 | |
| 410 | |
| 411 | int POSIXSocket::Send(const char* data, int len) const { |
| 412 | int status = send(socket_, data, len, 0); |
| 413 | return status; |
| 414 | } |
| 415 | |
| 416 | |
| 417 | int POSIXSocket::Receive(char* data, int len) const { |
| 418 | int status = recv(socket_, data, len, 0); |
| 419 | return status; |
| 420 | } |
| 421 | |
| 422 | |
| 423 | bool POSIXSocket::SetReuseAddress(bool reuse_address) { |
| 424 | int on = reuse_address ? 1 : 0; |
| 425 | int status = setsockopt(socket_, SOL_SOCKET, SO_REUSEADDR, &on, sizeof(on)); |
| 426 | return status == 0; |
| 427 | } |
| 428 | |
| 429 | |
| 430 | bool Socket::Setup() { |
| 431 | // Nothing to do on POSIX. |
| 432 | return true; |
| 433 | } |
| 434 | |
| 435 | |
| 436 | int Socket::LastError() { |
| 437 | return errno; |
| 438 | } |
| 439 | |
| 440 | |
| 441 | uint16_t Socket::HToN(uint16_t value) { |
| 442 | return htons(value); |
| 443 | } |
| 444 | |
| 445 | |
| 446 | uint16_t Socket::NToH(uint16_t value) { |
| 447 | return ntohs(value); |
| 448 | } |
| 449 | |
| 450 | |
| 451 | uint32_t Socket::HToN(uint32_t value) { |
| 452 | return htonl(value); |
| 453 | } |
| 454 | |
| 455 | |
| 456 | uint32_t Socket::NToH(uint32_t value) { |
| 457 | return ntohl(value); |
| 458 | } |
| 459 | |
| 460 | |
| 461 | Socket* OS::CreateSocket() { |
| 462 | return new POSIXSocket(); |
| 463 | } |
| 464 | |
| 465 | |
| 466 | } } // namespace v8::internal |