Index: third_party/grpc/src/core/iomgr/socket_utils_linux.c |
diff --git a/third_party/tcmalloc/vendor/src/base/spinlock_win32-inl.h b/third_party/grpc/src/core/iomgr/socket_utils_linux.c |
similarity index 76% |
copy from third_party/tcmalloc/vendor/src/base/spinlock_win32-inl.h |
copy to third_party/grpc/src/core/iomgr/socket_utils_linux.c |
index 64decd267240a384c66e4cd556f70df8e8f33b54..a87625262b26d554044ea899f4aad6e155d51bdc 100644 |
--- a/third_party/tcmalloc/vendor/src/base/spinlock_win32-inl.h |
+++ b/third_party/grpc/src/core/iomgr/socket_utils_linux.c |
@@ -1,10 +1,12 @@ |
-/* Copyright (c) 2009, Google Inc. |
+/* |
+ * |
+ * Copyright 2015, Google Inc. |
* All rights reserved. |
- * |
+ * |
* Redistribution and use in source and binary forms, with or without |
* modification, are permitted provided that the following conditions are |
* met: |
- * |
+ * |
* * Redistributions of source code must retain the above copyright |
* notice, this list of conditions and the following disclaimer. |
* * Redistributions in binary form must reproduce the above |
@@ -14,7 +16,7 @@ |
* * Neither the name of Google Inc. nor the names of its |
* contributors may be used to endorse or promote products derived from |
* this software without specific prior written permission. |
- * |
+ * |
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |
@@ -27,27 +29,23 @@ |
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
* |
- * --- |
- * This file is a Win32-specific part of spinlock_internal.cc |
*/ |
+#include <grpc/support/port_platform.h> |
-#include <windows.h> |
+#ifdef GPR_LINUX_SOCKETUTILS |
-namespace base { |
-namespace internal { |
+#include "src/core/iomgr/socket_utils_posix.h" |
-void SpinLockDelay(volatile Atomic32 *w, int32 value, int loop) { |
- if (loop == 0) { |
- } else if (loop == 1) { |
- Sleep(0); |
- } else { |
- Sleep(base::internal::SuggestedDelayNS(loop) / 1000000); |
- } |
-} |
+#include <sys/types.h> |
+#include <sys/socket.h> |
-void SpinLockWake(volatile Atomic32 *w, bool all) { |
+int grpc_accept4(int sockfd, struct sockaddr *addr, socklen_t *addrlen, |
+ int nonblock, int cloexec) { |
+ int flags = 0; |
+ flags |= nonblock ? SOCK_NONBLOCK : 0; |
+ flags |= cloexec ? SOCK_CLOEXEC : 0; |
+ return accept4(sockfd, addr, addrlen, flags); |
} |
-} // namespace internal |
-} // namespace base |
+#endif |