blob: 1c0d13f96e2d3d2c726863cfabae6772e6c27141 [file] [log] [blame]
Nicolas Nobleb7ebd3b2014-11-26 16:33:03 -08001/*
2 *
Craig Tiller6169d5f2016-03-31 07:46:18 -07003 * Copyright 2015, Google Inc.
Nicolas Nobleb7ebd3b2014-11-26 16:33:03 -08004 * All rights reserved.
5 *
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions are
8 * met:
9 *
10 * * Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer.
12 * * Redistributions in binary form must reproduce the above
13 * copyright notice, this list of conditions and the following disclaimer
14 * in the documentation and/or other materials provided with the
15 * distribution.
16 * * Neither the name of Google Inc. nor the names of its
17 * contributors may be used to endorse or promote products derived from
18 * this software without specific prior written permission.
19 *
20 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
21 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
23 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
24 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
25 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
26 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
27 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
28 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
29 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
30 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31 *
32 */
33
Craig Tiller9a4dddd2016-03-25 17:08:13 -070034#ifndef GRPC_CORE_LIB_IOMGR_TCP_POSIX_H
35#define GRPC_CORE_LIB_IOMGR_TCP_POSIX_H
Nicolas Nobleb7ebd3b2014-11-26 16:33:03 -080036/*
37 Low level TCP "bottom half" implementation, for use by transports built on
38 top of a TCP connection.
39
40 Note that this file does not (yet) include APIs for creating the socket in
41 the first place.
42
43 All calls passing slice transfer ownership of a slice refcount unless
44 otherwise specified.
45*/
46
Craig Tiller9533d042016-03-25 17:11:06 -070047#include "src/core/lib/iomgr/endpoint.h"
Craig Tiller8a034482016-03-28 16:09:04 -070048#include "src/core/lib/iomgr/ev_posix.h"
Nicolas Nobleb7ebd3b2014-11-26 16:33:03 -080049
ctiller18b49ab2014-12-09 14:39:16 -080050#define GRPC_TCP_DEFAULT_READ_SLICE_SIZE 8192
Nicolas Nobleb7ebd3b2014-11-26 16:33:03 -080051
Craig Tillerfaa84802015-03-01 21:56:38 -080052extern int grpc_tcp_trace;
53
ctiller18b49ab2014-12-09 14:39:16 -080054/* Create a tcp endpoint given a file desciptor and a read slice size.
55 Takes ownership of fd. */
Craig Tiller20afa3d2016-10-17 14:52:14 -070056grpc_endpoint *grpc_tcp_create(grpc_fd *fd, grpc_resource_quota *resource_quota,
Craig Tillere34c2852016-09-23 09:43:32 -070057 size_t read_slice_size, const char *peer_string);
nnoble0c475f02014-12-05 15:37:39 -080058
Dan Born43a78032016-01-05 17:17:45 -080059/* Return the tcp endpoint's fd, or -1 if this is not available. Does not
60 release the fd.
61 Requires: ep must be a tcp endpoint.
62 */
63int grpc_tcp_fd(grpc_endpoint *ep);
64
yang-g5d850372015-12-01 10:32:28 -080065/* Destroy the tcp endpoint without closing its fd. *fd will be set and done
66 * will be called when the endpoint is destroyed.
67 * Requires: ep must be a tcp endpoint and fd must not be NULL. */
yang-gdc215932015-11-30 14:25:01 -080068void grpc_tcp_destroy_and_release_fd(grpc_exec_ctx *exec_ctx, grpc_endpoint *ep,
yang-g5d850372015-12-01 10:32:28 -080069 int *fd, grpc_closure *done);
yang-gdc215932015-11-30 14:25:01 -080070
Craig Tiller9a4dddd2016-03-25 17:08:13 -070071#endif /* GRPC_CORE_LIB_IOMGR_TCP_POSIX_H */