Nicolas Noble | b7ebd3b | 2014-11-26 16:33:03 -0800 | [diff] [blame] | 1 | /* |
| 2 | * |
Craig Tiller | 6169d5f | 2016-03-31 07:46:18 -0700 | [diff] [blame] | 3 | * Copyright 2015, Google Inc. |
Nicolas Noble | b7ebd3b | 2014-11-26 16:33:03 -0800 | [diff] [blame] | 4 | * 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 Tiller | acf0f07 | 2015-06-29 08:24:16 -0700 | [diff] [blame] | 34 | #include <grpc/support/port_platform.h> |
| 35 | |
Craig Tiller | 178edfa | 2016-02-17 20:54:46 -0800 | [diff] [blame] | 36 | #include <limits.h> |
Hongwei Wang | a3780a8 | 2015-07-17 15:27:18 -0700 | [diff] [blame] | 37 | #include <memory.h> |
| 38 | |
Nicolas Noble | b7ebd3b | 2014-11-26 16:33:03 -0800 | [diff] [blame] | 39 | #include <grpc/grpc.h> |
Hongwei Wang | a3780a8 | 2015-07-17 15:27:18 -0700 | [diff] [blame] | 40 | #include <grpc/support/alloc.h> |
Yuchen Zeng | 95e4c48 | 2016-04-15 10:38:24 -0700 | [diff] [blame] | 41 | #include <grpc/support/log.h> |
Craig Tiller | f3756c1 | 2015-07-01 17:21:01 -0700 | [diff] [blame] | 42 | #include <grpc/support/time.h> |
Craig Tiller | 9533d04 | 2016-03-25 17:11:06 -0700 | [diff] [blame] | 43 | #include "src/core/lib/channel/channel_stack.h" |
Craig Tiller | 9533d04 | 2016-03-25 17:11:06 -0700 | [diff] [blame] | 44 | #include "src/core/lib/channel/compress_filter.h" |
| 45 | #include "src/core/lib/channel/connected_channel.h" |
| 46 | #include "src/core/lib/channel/http_client_filter.h" |
| 47 | #include "src/core/lib/channel/http_server_filter.h" |
Craig Tiller | 9533d04 | 2016-03-25 17:11:06 -0700 | [diff] [blame] | 48 | #include "src/core/lib/debug/trace.h" |
Craig Tiller | 3ab2fe0 | 2016-04-11 20:11:18 -0700 | [diff] [blame] | 49 | #include "src/core/lib/http/parser.h" |
Craig Tiller | 9533d04 | 2016-03-25 17:11:06 -0700 | [diff] [blame] | 50 | #include "src/core/lib/iomgr/executor.h" |
| 51 | #include "src/core/lib/iomgr/iomgr.h" |
| 52 | #include "src/core/lib/profiling/timers.h" |
| 53 | #include "src/core/lib/surface/api_trace.h" |
| 54 | #include "src/core/lib/surface/call.h" |
| 55 | #include "src/core/lib/surface/channel_init.h" |
| 56 | #include "src/core/lib/surface/completion_queue.h" |
| 57 | #include "src/core/lib/surface/init.h" |
| 58 | #include "src/core/lib/surface/lame_client.h" |
| 59 | #include "src/core/lib/surface/server.h" |
| 60 | #include "src/core/lib/surface/surface_trace.h" |
Craig Tiller | 9533d04 | 2016-03-25 17:11:06 -0700 | [diff] [blame] | 61 | #include "src/core/lib/transport/connectivity_state.h" |
| 62 | #include "src/core/lib/transport/transport_impl.h" |
Nicolas Noble | b7ebd3b | 2014-11-26 16:33:03 -0800 | [diff] [blame] | 63 | |
Craig Tiller | 3113ef4 | 2016-03-29 09:03:14 -0700 | [diff] [blame] | 64 | /* (generated) built in registry of plugins */ |
| 65 | extern void grpc_register_built_in_plugins(void); |
| 66 | |
Hongwei Wang | 85ad685 | 2015-08-13 16:13:10 -0700 | [diff] [blame] | 67 | #define MAX_PLUGINS 128 |
| 68 | |
Craig Tiller | 8ace0bc | 2015-03-05 17:16:09 -0800 | [diff] [blame] | 69 | static gpr_once g_basic_init = GPR_ONCE_INIT; |
Craig Tiller | 35108f6 | 2015-02-17 11:24:15 -0800 | [diff] [blame] | 70 | static gpr_mu g_init_mu; |
| 71 | static int g_initializations; |
| 72 | |
Craig Tiller | 8ace0bc | 2015-03-05 17:16:09 -0800 | [diff] [blame] | 73 | static void do_basic_init(void) { |
Yuchen Zeng | 95e4c48 | 2016-04-15 10:38:24 -0700 | [diff] [blame] | 74 | gpr_log_verbosity_init(); |
Craig Tiller | 35108f6 | 2015-02-17 11:24:15 -0800 | [diff] [blame] | 75 | gpr_mu_init(&g_init_mu); |
Craig Tiller | 3113ef4 | 2016-03-29 09:03:14 -0700 | [diff] [blame] | 76 | grpc_register_built_in_plugins(); |
Craig Tiller | 35108f6 | 2015-02-17 11:24:15 -0800 | [diff] [blame] | 77 | g_initializations = 0; |
| 78 | } |
| 79 | |
Craig Tiller | 178edfa | 2016-02-17 20:54:46 -0800 | [diff] [blame] | 80 | static bool append_filter(grpc_channel_stack_builder *builder, void *arg) { |
vjpai | e7077b5 | 2016-03-21 20:58:44 -0700 | [diff] [blame] | 81 | return grpc_channel_stack_builder_append_filter( |
| 82 | builder, (const grpc_channel_filter *)arg, NULL, NULL); |
Craig Tiller | 178edfa | 2016-02-17 20:54:46 -0800 | [diff] [blame] | 83 | } |
| 84 | |
| 85 | static bool prepend_filter(grpc_channel_stack_builder *builder, void *arg) { |
vjpai | e7077b5 | 2016-03-21 20:58:44 -0700 | [diff] [blame] | 86 | return grpc_channel_stack_builder_prepend_filter( |
| 87 | builder, (const grpc_channel_filter *)arg, NULL, NULL); |
Craig Tiller | 178edfa | 2016-02-17 20:54:46 -0800 | [diff] [blame] | 88 | } |
| 89 | |
| 90 | static bool maybe_add_http_filter(grpc_channel_stack_builder *builder, |
| 91 | void *arg) { |
| 92 | grpc_transport *t = grpc_channel_stack_builder_get_transport(builder); |
| 93 | if (t && strstr(t->vtable->name, "http")) { |
vjpai | e7077b5 | 2016-03-21 20:58:44 -0700 | [diff] [blame] | 94 | return grpc_channel_stack_builder_prepend_filter( |
| 95 | builder, (const grpc_channel_filter *)arg, NULL, NULL); |
Craig Tiller | 178edfa | 2016-02-17 20:54:46 -0800 | [diff] [blame] | 96 | } |
| 97 | return true; |
| 98 | } |
| 99 | |
| 100 | static void register_builtin_channel_init() { |
Craig Tiller | f82ddc4 | 2016-04-05 17:15:07 -0700 | [diff] [blame] | 101 | grpc_channel_init_register_stage( |
| 102 | GRPC_CLIENT_CHANNEL, GRPC_CHANNEL_INIT_BUILTIN_PRIORITY, prepend_filter, |
| 103 | (void *)&grpc_compress_filter); |
| 104 | grpc_channel_init_register_stage( |
| 105 | GRPC_CLIENT_DIRECT_CHANNEL, GRPC_CHANNEL_INIT_BUILTIN_PRIORITY, |
| 106 | prepend_filter, (void *)&grpc_compress_filter); |
| 107 | grpc_channel_init_register_stage( |
| 108 | GRPC_SERVER_CHANNEL, GRPC_CHANNEL_INIT_BUILTIN_PRIORITY, prepend_filter, |
| 109 | (void *)&grpc_compress_filter); |
| 110 | grpc_channel_init_register_stage( |
| 111 | GRPC_CLIENT_SUBCHANNEL, GRPC_CHANNEL_INIT_BUILTIN_PRIORITY, |
| 112 | maybe_add_http_filter, (void *)&grpc_http_client_filter); |
| 113 | grpc_channel_init_register_stage(GRPC_CLIENT_SUBCHANNEL, |
| 114 | GRPC_CHANNEL_INIT_BUILTIN_PRIORITY, |
Craig Tiller | 178edfa | 2016-02-17 20:54:46 -0800 | [diff] [blame] | 115 | grpc_add_connected_filter, NULL); |
Craig Tiller | f82ddc4 | 2016-04-05 17:15:07 -0700 | [diff] [blame] | 116 | grpc_channel_init_register_stage( |
| 117 | GRPC_CLIENT_DIRECT_CHANNEL, GRPC_CHANNEL_INIT_BUILTIN_PRIORITY, |
| 118 | maybe_add_http_filter, (void *)&grpc_http_client_filter); |
| 119 | grpc_channel_init_register_stage(GRPC_CLIENT_DIRECT_CHANNEL, |
| 120 | GRPC_CHANNEL_INIT_BUILTIN_PRIORITY, |
Craig Tiller | de67626 | 2016-02-19 12:28:34 -0800 | [diff] [blame] | 121 | grpc_add_connected_filter, NULL); |
Craig Tiller | f82ddc4 | 2016-04-05 17:15:07 -0700 | [diff] [blame] | 122 | grpc_channel_init_register_stage( |
| 123 | GRPC_SERVER_CHANNEL, GRPC_CHANNEL_INIT_BUILTIN_PRIORITY, |
| 124 | maybe_add_http_filter, (void *)&grpc_http_server_filter); |
| 125 | grpc_channel_init_register_stage(GRPC_SERVER_CHANNEL, |
| 126 | GRPC_CHANNEL_INIT_BUILTIN_PRIORITY, |
Craig Tiller | 178edfa | 2016-02-17 20:54:46 -0800 | [diff] [blame] | 127 | grpc_add_connected_filter, NULL); |
Craig Tiller | f82ddc4 | 2016-04-05 17:15:07 -0700 | [diff] [blame] | 128 | grpc_channel_init_register_stage(GRPC_CLIENT_LAME_CHANNEL, |
| 129 | GRPC_CHANNEL_INIT_BUILTIN_PRIORITY, |
Craig Tiller | 178edfa | 2016-02-17 20:54:46 -0800 | [diff] [blame] | 130 | append_filter, (void *)&grpc_lame_filter); |
Craig Tiller | 8166732 | 2016-04-06 07:47:01 -0700 | [diff] [blame] | 131 | grpc_channel_init_register_stage(GRPC_SERVER_CHANNEL, INT_MAX, prepend_filter, |
| 132 | (void *)&grpc_server_top_filter); |
Craig Tiller | 178edfa | 2016-02-17 20:54:46 -0800 | [diff] [blame] | 133 | } |
| 134 | |
Hongwei Wang | a3780a8 | 2015-07-17 15:27:18 -0700 | [diff] [blame] | 135 | typedef struct grpc_plugin { |
| 136 | void (*init)(); |
Hongwei Wang | 85ad685 | 2015-08-13 16:13:10 -0700 | [diff] [blame] | 137 | void (*destroy)(); |
Hongwei Wang | a3780a8 | 2015-07-17 15:27:18 -0700 | [diff] [blame] | 138 | } grpc_plugin; |
| 139 | |
Hongwei Wang | 85ad685 | 2015-08-13 16:13:10 -0700 | [diff] [blame] | 140 | static grpc_plugin g_all_of_the_plugins[MAX_PLUGINS]; |
| 141 | static int g_number_of_plugins = 0; |
Hongwei Wang | a3780a8 | 2015-07-17 15:27:18 -0700 | [diff] [blame] | 142 | |
Hongwei Wang | 85ad685 | 2015-08-13 16:13:10 -0700 | [diff] [blame] | 143 | void grpc_register_plugin(void (*init)(void), void (*destroy)(void)) { |
Jan Tattermusch | 1b34aeb | 2015-12-17 10:37:10 -0800 | [diff] [blame] | 144 | GRPC_API_TRACE("grpc_register_plugin(init=%p, destroy=%p)", 2, |
Craig Tiller | 178edfa | 2016-02-17 20:54:46 -0800 | [diff] [blame] | 145 | ((void *)(intptr_t)init, (void *)(intptr_t)destroy)); |
Hongwei Wang | 85ad685 | 2015-08-13 16:13:10 -0700 | [diff] [blame] | 146 | GPR_ASSERT(g_number_of_plugins != MAX_PLUGINS); |
| 147 | g_all_of_the_plugins[g_number_of_plugins].init = init; |
| 148 | g_all_of_the_plugins[g_number_of_plugins].destroy = destroy; |
| 149 | g_number_of_plugins++; |
Hongwei Wang | ff6097a | 2015-08-12 17:48:56 -0700 | [diff] [blame] | 150 | } |
| 151 | |
Craig Tiller | 32946d3 | 2015-01-15 11:37:30 -0800 | [diff] [blame] | 152 | void grpc_init(void) { |
Hongwei Wang | 85ad685 | 2015-08-13 16:13:10 -0700 | [diff] [blame] | 153 | int i; |
Craig Tiller | 8ace0bc | 2015-03-05 17:16:09 -0800 | [diff] [blame] | 154 | gpr_once_init(&g_basic_init, do_basic_init); |
Craig Tiller | 35108f6 | 2015-02-17 11:24:15 -0800 | [diff] [blame] | 155 | |
| 156 | gpr_mu_lock(&g_init_mu); |
| 157 | if (++g_initializations == 1) { |
Craig Tiller | f3756c1 | 2015-07-01 17:21:01 -0700 | [diff] [blame] | 158 | gpr_time_init(); |
Craig Tiller | 0e72ede | 2015-11-19 07:48:53 -0800 | [diff] [blame] | 159 | grpc_mdctx_global_init(); |
Craig Tiller | 178edfa | 2016-02-17 20:54:46 -0800 | [diff] [blame] | 160 | grpc_channel_init_init(); |
Masood Malekghassemi | 76c3d74 | 2015-08-19 18:22:53 -0700 | [diff] [blame] | 161 | grpc_register_tracer("api", &grpc_api_trace); |
Craig Tiller | faa8480 | 2015-03-01 21:56:38 -0800 | [diff] [blame] | 162 | grpc_register_tracer("channel", &grpc_trace_channel); |
Craig Tiller | 1ada6ad | 2015-07-16 16:19:14 -0700 | [diff] [blame] | 163 | grpc_register_tracer("connectivity_state", &grpc_connectivity_state_trace); |
Craig Tiller | d78d164 | 2016-02-21 22:18:51 -0800 | [diff] [blame] | 164 | grpc_register_tracer("channel_stack_builder", |
| 165 | &grpc_trace_channel_stack_builder); |
Craig Tiller | 3ab2fe0 | 2016-04-11 20:11:18 -0700 | [diff] [blame] | 166 | grpc_register_tracer("http1", &grpc_http1_trace); |
Craig Tiller | faa8480 | 2015-03-01 21:56:38 -0800 | [diff] [blame] | 167 | grpc_security_pre_init(); |
Craig Tiller | 35108f6 | 2015-02-17 11:24:15 -0800 | [diff] [blame] | 168 | grpc_iomgr_init(); |
David Garcia Quintas | 4bc3463 | 2015-10-07 16:12:35 -0700 | [diff] [blame] | 169 | grpc_executor_init(); |
Craig Tiller | 9aadeb8 | 2015-04-15 11:01:08 -0700 | [diff] [blame] | 170 | grpc_tracer_init("GRPC_TRACE"); |
Craig Tiller | 0ba432d | 2015-10-09 16:57:11 -0700 | [diff] [blame] | 171 | gpr_timers_global_init(); |
Craig Tiller | c7e1a2a | 2015-11-02 14:17:32 -0800 | [diff] [blame] | 172 | grpc_cq_global_init(); |
Hongwei Wang | 85ad685 | 2015-08-13 16:13:10 -0700 | [diff] [blame] | 173 | for (i = 0; i < g_number_of_plugins; i++) { |
| 174 | if (g_all_of_the_plugins[i].init != NULL) { |
| 175 | g_all_of_the_plugins[i].init(); |
Hongwei Wang | 35d5a0f | 2015-07-24 11:14:23 -0700 | [diff] [blame] | 176 | } |
Hongwei Wang | a3780a8 | 2015-07-17 15:27:18 -0700 | [diff] [blame] | 177 | } |
Craig Tiller | 178edfa | 2016-02-17 20:54:46 -0800 | [diff] [blame] | 178 | /* register channel finalization AFTER all plugins, to ensure that it's run |
| 179 | * at the appropriate time */ |
| 180 | grpc_register_security_filters(); |
| 181 | register_builtin_channel_init(); |
| 182 | /* no more changes to channel init pipelines */ |
| 183 | grpc_channel_init_finalize(); |
Craig Tiller | 35108f6 | 2015-02-17 11:24:15 -0800 | [diff] [blame] | 184 | } |
| 185 | gpr_mu_unlock(&g_init_mu); |
Masood Malekghassemi | 76c3d74 | 2015-08-19 18:22:53 -0700 | [diff] [blame] | 186 | GRPC_API_TRACE("grpc_init(void)", 0, ()); |
Nicolas Noble | b7ebd3b | 2014-11-26 16:33:03 -0800 | [diff] [blame] | 187 | } |
| 188 | |
Craig Tiller | 32946d3 | 2015-01-15 11:37:30 -0800 | [diff] [blame] | 189 | void grpc_shutdown(void) { |
Hongwei Wang | 85ad685 | 2015-08-13 16:13:10 -0700 | [diff] [blame] | 190 | int i; |
Masood Malekghassemi | 76c3d74 | 2015-08-19 18:22:53 -0700 | [diff] [blame] | 191 | GRPC_API_TRACE("grpc_shutdown(void)", 0, ()); |
Craig Tiller | 35108f6 | 2015-02-17 11:24:15 -0800 | [diff] [blame] | 192 | gpr_mu_lock(&g_init_mu); |
| 193 | if (--g_initializations == 0) { |
David Garcia Quintas | 4bc3463 | 2015-10-07 16:12:35 -0700 | [diff] [blame] | 194 | grpc_executor_shutdown(); |
Craig Tiller | c7e1a2a | 2015-11-02 14:17:32 -0800 | [diff] [blame] | 195 | grpc_cq_global_shutdown(); |
| 196 | grpc_iomgr_shutdown(); |
Craig Tiller | 0ba432d | 2015-10-09 16:57:11 -0700 | [diff] [blame] | 197 | gpr_timers_global_destroy(); |
Craig Tiller | 2f300e2 | 2015-06-04 08:28:43 -0700 | [diff] [blame] | 198 | grpc_tracer_shutdown(); |
Craig Tiller | f82ddc4 | 2016-04-05 17:15:07 -0700 | [diff] [blame] | 199 | for (i = g_number_of_plugins; i >= 0; i--) { |
Hongwei Wang | 85ad685 | 2015-08-13 16:13:10 -0700 | [diff] [blame] | 200 | if (g_all_of_the_plugins[i].destroy != NULL) { |
| 201 | g_all_of_the_plugins[i].destroy(); |
Hongwei Wang | 35d5a0f | 2015-07-24 11:14:23 -0700 | [diff] [blame] | 202 | } |
Hongwei Wang | a3780a8 | 2015-07-17 15:27:18 -0700 | [diff] [blame] | 203 | } |
Craig Tiller | 0e72ede | 2015-11-19 07:48:53 -0800 | [diff] [blame] | 204 | grpc_mdctx_global_shutdown(); |
Craig Tiller | 35108f6 | 2015-02-17 11:24:15 -0800 | [diff] [blame] | 205 | } |
| 206 | gpr_mu_unlock(&g_init_mu); |
Nicolas Noble | b7ebd3b | 2014-11-26 16:33:03 -0800 | [diff] [blame] | 207 | } |
Craig Tiller | 60fd361 | 2015-03-05 16:24:22 -0800 | [diff] [blame] | 208 | |
| 209 | int grpc_is_initialized(void) { |
| 210 | int r; |
Craig Tiller | 8ace0bc | 2015-03-05 17:16:09 -0800 | [diff] [blame] | 211 | gpr_once_init(&g_basic_init, do_basic_init); |
Craig Tiller | 60fd361 | 2015-03-05 16:24:22 -0800 | [diff] [blame] | 212 | gpr_mu_lock(&g_init_mu); |
| 213 | r = g_initializations > 0; |
| 214 | gpr_mu_unlock(&g_init_mu); |
| 215 | return r; |
| 216 | } |