1 // 2 // 3 // Copyright 2015 gRPC authors. 4 // 5 // Licensed under the Apache License, Version 2.0 (the "License"); 6 // you may not use this file except in compliance with the License. 7 // You may obtain a copy of the License at 8 // 9 // http://www.apache.org/licenses/LICENSE-2.0 10 // 11 // Unless required by applicable law or agreed to in writing, software 12 // distributed under the License is distributed on an "AS IS" BASIS, 13 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 14 // See the License for the specific language governing permissions and 15 // limitations under the License. 16 // 17 // 18 19 #ifndef GRPC_SRC_CORE_LIB_IOMGR_TCP_POSIX_H 20 #define GRPC_SRC_CORE_LIB_IOMGR_TCP_POSIX_H 21 // 22 // Low level TCP "bottom half" implementation, for use by transports built on 23 // top of a TCP connection. 24 25 // Note that this file does not (yet) include APIs for creating the socket in 26 // the first place. 27 28 // All calls passing slice transfer ownership of a slice refcount unless 29 // otherwise specified. 30 // 31 32 #include <grpc/support/port_platform.h> 33 34 #include "src/core/lib/debug/trace.h" 35 #include "src/core/lib/iomgr/buffer_list.h" 36 #include "src/core/lib/iomgr/endpoint.h" 37 #include "src/core/lib/iomgr/ev_posix.h" 38 #include "src/core/lib/iomgr/port.h" 39 #include "src/core/lib/iomgr/socket_utils_posix.h" 40 41 extern grpc_core::TraceFlag grpc_tcp_trace; 42 43 /// Create a tcp endpoint given a file desciptor and a read slice size. 44 /// Takes ownership of \a fd. Takes ownership of the \a slice_allocator. 45 grpc_endpoint* grpc_tcp_create(grpc_fd* fd, 46 const grpc_core::PosixTcpOptions& options, 47 absl::string_view peer_string); 48 49 /// Return the tcp endpoint's fd, or -1 if this is not available. Does not 50 /// release the fd. Requires: \a ep must be a tcp endpoint. 51 int grpc_tcp_fd(grpc_endpoint* ep); 52 53 /// Destroy the tcp endpoint without closing its fd. *fd will be set and done 54 /// will be called when the endpoint is destroyed. Requires: \a ep must be a tcp 55 /// endpoint and fd must not be NULL. 56 void grpc_tcp_destroy_and_release_fd(grpc_endpoint* ep, int* fd, 57 grpc_closure* done); 58 59 #ifdef GRPC_POSIX_SOCKET_TCP 60 61 void grpc_tcp_posix_init(); 62 63 void grpc_tcp_posix_shutdown(); 64 65 #endif // GRPC_POSIX_SOCKET_TCP 66 67 #endif // GRPC_SRC_CORE_LIB_IOMGR_TCP_POSIX_H 68