Home | History | Annotate | Download | only in grpc
      1 /*
      2  *
      3  * Copyright 2016 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_GRPC_POSIX_H
     20 #define GRPC_GRPC_POSIX_H
     21 
     22 #include <grpc/support/port_platform.h>
     23 
     24 #include <grpc/impl/codegen/grpc_types.h>
     25 
     26 #include <stddef.h>
     27 
     28 #ifdef __cplusplus
     29 extern "C" {
     30 #endif
     31 
     32 /*! \mainpage GRPC Core POSIX
     33  *
     34  * The GRPC Core POSIX library provides some POSIX-specific low-level
     35  * functionality on top of GRPC Core.
     36  */
     37 
     38 /** Create a client channel to 'target' using file descriptor 'fd'. The 'target'
     39     argument will be used to indicate the name for this channel. See the comment
     40     for grpc_insecure_channel_create for description of 'args' argument. */
     41 GRPCAPI grpc_channel* grpc_insecure_channel_create_from_fd(
     42     const char* target, int fd, const grpc_channel_args* args);
     43 
     44 /** Add the connected communication channel based on file descriptor 'fd' to the
     45     'server'. The 'fd' must be an open file descriptor corresponding to a
     46     connected socket. Events from the file descriptor may come on any of the
     47     server completion queues (i.e completion queues registered via the
     48     grpc_server_register_completion_queue API).
     49 
     50     The 'reserved' pointer MUST be NULL.
     51     */
     52 GRPCAPI void grpc_server_add_insecure_channel_from_fd(grpc_server* server,
     53                                                       void* reserved, int fd);
     54 
     55 /** GRPC Core POSIX library may internally use signals to optimize some work.
     56    The library uses (SIGRTMIN + 6) signal by default. Use this API to instruct
     57    the library to use a different signal i.e 'signum' instead.
     58    Note:
     59    - To prevent GRPC library from using any signals, pass a 'signum' of -1
     60    - This API is optional but if called, it MUST be called before grpc_init() */
     61 GRPCAPI void grpc_use_signal(int signum);
     62 
     63 #ifdef __cplusplus
     64 }
     65 #endif
     66 
     67 #endif /* GRPC_GRPC_POSIX_H */
     68