grpc 1.44.0.pre2 → 1.46.3

Sign up to get free protection for your applications and to get access to all the features.

Potentially problematic release.


This version of grpc might be problematic. Click here for more details.

Files changed (1167) hide show
  1. checksums.yaml +4 -4
  2. data/Makefile +311 -191
  3. data/include/grpc/event_engine/event_engine.h +2 -2
  4. data/include/grpc/grpc.h +40 -14
  5. data/include/grpc/grpc_posix.h +20 -19
  6. data/include/grpc/grpc_security.h +26 -50
  7. data/include/grpc/impl/codegen/grpc_types.h +18 -21
  8. data/include/grpc/impl/codegen/port_platform.h +2 -2
  9. data/include/grpc/impl/codegen/slice.h +4 -1
  10. data/include/grpc/slice.h +0 -11
  11. data/src/core/ext/filters/channel_idle/channel_idle_filter.cc +309 -0
  12. data/src/core/ext/filters/channel_idle/channel_idle_filter.h +122 -0
  13. data/src/core/ext/filters/{client_idle → channel_idle}/idle_filter_state.cc +1 -1
  14. data/src/core/ext/filters/{client_idle → channel_idle}/idle_filter_state.h +5 -5
  15. data/src/core/ext/filters/client_channel/backend_metric.cc +3 -3
  16. data/src/core/ext/filters/client_channel/backup_poller.cc +12 -8
  17. data/src/core/ext/filters/client_channel/channel_connectivity.cc +5 -5
  18. data/src/core/ext/filters/client_channel/client_channel.cc +242 -153
  19. data/src/core/ext/filters/client_channel/client_channel.h +32 -29
  20. data/src/core/ext/filters/client_channel/client_channel_plugin.cc +5 -11
  21. data/src/core/ext/filters/client_channel/connector.h +1 -1
  22. data/src/core/ext/filters/client_channel/dynamic_filters.cc +1 -2
  23. data/src/core/ext/filters/client_channel/dynamic_filters.h +1 -1
  24. data/src/core/ext/filters/client_channel/global_subchannel_pool.cc +2 -22
  25. data/src/core/ext/filters/client_channel/global_subchannel_pool.h +3 -15
  26. data/src/core/ext/filters/client_channel/health/health_check_client.cc +124 -582
  27. data/src/core/ext/filters/client_channel/health/health_check_client.h +24 -160
  28. data/src/core/ext/filters/client_channel/http_connect_handshaker.cc +9 -12
  29. data/src/core/ext/filters/client_channel/http_proxy.cc +88 -110
  30. data/src/core/ext/filters/client_channel/http_proxy.h +17 -0
  31. data/src/core/ext/filters/client_channel/lb_policy/grpclb/client_load_reporting_filter.cc +1 -0
  32. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb.cc +68 -47
  33. data/src/core/ext/filters/client_channel/lb_policy/grpclb/load_balancer_api.cc +15 -15
  34. data/src/core/ext/filters/client_channel/lb_policy/grpclb/load_balancer_api.h +4 -4
  35. data/src/core/ext/filters/client_channel/lb_policy/pick_first/pick_first.cc +7 -3
  36. data/src/core/ext/filters/client_channel/lb_policy/priority/priority.cc +193 -148
  37. data/src/core/ext/filters/client_channel/lb_policy/ring_hash/ring_hash.cc +2 -6
  38. data/src/core/ext/filters/client_channel/lb_policy/rls/rls.cc +120 -92
  39. data/src/core/ext/filters/client_channel/lb_policy/weighted_target/weighted_target.cc +88 -59
  40. data/src/core/ext/filters/client_channel/lb_policy/xds/cds.cc +60 -52
  41. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_impl.cc +51 -24
  42. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_manager.cc +16 -8
  43. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_resolver.cc +245 -293
  44. data/src/core/ext/filters/client_channel/resolver/binder/binder_resolver.cc +7 -13
  45. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/dns_resolver_ares.cc +126 -278
  46. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.cc +18 -19
  47. data/src/core/ext/filters/client_channel/resolver/dns/native/dns_resolver.cc +62 -234
  48. data/src/core/ext/filters/client_channel/resolver/fake/fake_resolver.cc +8 -7
  49. data/src/core/ext/filters/client_channel/resolver/google_c2p/google_c2p_resolver.cc +82 -57
  50. data/src/core/ext/filters/client_channel/resolver/polling_resolver.cc +201 -0
  51. data/src/core/ext/filters/client_channel/resolver/polling_resolver.h +106 -0
  52. data/src/core/ext/filters/client_channel/resolver/sockaddr/sockaddr_resolver.cc +35 -34
  53. data/src/core/ext/filters/client_channel/resolver/xds/xds_resolver.cc +135 -89
  54. data/src/core/ext/filters/client_channel/resolver_result_parsing.cc +7 -10
  55. data/src/core/ext/filters/client_channel/resolver_result_parsing.h +11 -5
  56. data/src/core/ext/filters/client_channel/retry_filter.cc +236 -127
  57. data/src/core/ext/filters/client_channel/retry_service_config.cc +15 -17
  58. data/src/core/ext/filters/client_channel/retry_service_config.h +17 -11
  59. data/src/core/ext/filters/client_channel/retry_throttle.cc +9 -23
  60. data/src/core/ext/filters/client_channel/retry_throttle.h +11 -5
  61. data/src/core/ext/filters/client_channel/service_config_channel_arg_filter.cc +7 -6
  62. data/src/core/ext/filters/client_channel/subchannel.cc +38 -41
  63. data/src/core/ext/filters/client_channel/subchannel.h +5 -4
  64. data/src/core/ext/filters/client_channel/subchannel_stream_client.cc +544 -0
  65. data/src/core/ext/filters/client_channel/subchannel_stream_client.h +214 -0
  66. data/src/core/ext/filters/deadline/deadline_filter.cc +15 -14
  67. data/src/core/ext/filters/deadline/deadline_filter.h +3 -2
  68. data/src/core/ext/filters/fault_injection/fault_injection_filter.cc +133 -367
  69. data/src/core/ext/filters/fault_injection/fault_injection_filter.h +24 -1
  70. data/src/core/ext/filters/fault_injection/service_config_parser.cc +5 -5
  71. data/src/core/ext/filters/fault_injection/service_config_parser.h +9 -3
  72. data/src/core/ext/filters/http/client/http_client_filter.cc +79 -455
  73. data/src/core/ext/filters/http/client/http_client_filter.h +21 -4
  74. data/src/core/ext/filters/http/client_authority_filter.cc +31 -79
  75. data/src/core/ext/filters/http/client_authority_filter.h +24 -5
  76. data/src/core/ext/filters/http/http_filters_plugin.cc +20 -18
  77. data/src/core/ext/filters/http/message_compress/message_compress_filter.cc +1 -0
  78. data/src/core/ext/filters/http/message_compress/message_decompress_filter.cc +10 -2
  79. data/src/core/ext/filters/http/server/http_server_filter.cc +3 -116
  80. data/src/core/ext/filters/message_size/message_size_filter.cc +26 -34
  81. data/src/core/ext/filters/message_size/message_size_filter.h +9 -2
  82. data/src/core/ext/filters/rbac/rbac_filter.cc +13 -8
  83. data/src/core/ext/filters/rbac/rbac_filter.h +2 -0
  84. data/src/core/ext/filters/rbac/rbac_service_config_parser.cc +6 -5
  85. data/src/core/ext/filters/rbac/rbac_service_config_parser.h +6 -1
  86. data/src/core/ext/filters/server_config_selector/server_config_selector.cc +2 -8
  87. data/src/core/ext/filters/server_config_selector/server_config_selector.h +2 -2
  88. data/src/core/ext/filters/server_config_selector/server_config_selector_filter.cc +73 -200
  89. data/src/core/ext/transport/chttp2/client/chttp2_connector.cc +235 -0
  90. data/src/core/ext/transport/chttp2/server/chttp2_server.cc +153 -10
  91. data/src/core/ext/transport/chttp2/transport/chttp2_transport.cc +233 -59
  92. data/src/core/ext/transport/chttp2/transport/chttp2_transport.h +8 -2
  93. data/src/core/ext/transport/chttp2/transport/flow_control.cc +2 -2
  94. data/src/core/ext/transport/chttp2/transport/flow_control.h +3 -3
  95. data/src/core/ext/transport/chttp2/transport/frame_ping.cc +4 -4
  96. data/src/core/ext/transport/chttp2/transport/frame_rst_stream.cc +5 -0
  97. data/src/core/ext/transport/chttp2/transport/frame_settings.cc +2 -0
  98. data/src/core/ext/transport/chttp2/transport/hpack_encoder.cc +3 -8
  99. data/src/core/ext/transport/chttp2/transport/hpack_encoder.h +1 -1
  100. data/src/core/ext/transport/chttp2/transport/hpack_parser.cc +15 -51
  101. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.cc +2 -2
  102. data/src/core/ext/transport/chttp2/transport/internal.h +10 -8
  103. data/src/core/ext/transport/chttp2/transport/parsing.cc +11 -3
  104. data/src/core/ext/transport/chttp2/transport/writing.cc +34 -20
  105. data/src/core/ext/transport/inproc/inproc_transport.cc +16 -12
  106. data/src/core/ext/upb-generated/envoy/admin/v3/certs.upb.c +117 -0
  107. data/src/core/ext/upb-generated/envoy/admin/v3/certs.upb.h +482 -0
  108. data/src/core/ext/upb-generated/envoy/admin/v3/clusters.upb.c +121 -0
  109. data/src/core/ext/upb-generated/envoy/admin/v3/clusters.upb.h +553 -0
  110. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump.upb.c +182 -176
  111. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump.upb.h +1248 -685
  112. data/src/core/ext/upb-generated/envoy/admin/v3/init_dump.upb.c +56 -0
  113. data/src/core/ext/upb-generated/envoy/admin/v3/init_dump.upb.h +151 -0
  114. data/src/core/ext/upb-generated/envoy/admin/v3/listeners.upb.c +62 -0
  115. data/src/core/ext/upb-generated/envoy/admin/v3/listeners.upb.h +160 -0
  116. data/src/core/ext/upb-generated/envoy/admin/v3/memory.upb.c +46 -0
  117. data/src/core/ext/upb-generated/envoy/admin/v3/memory.upb.h +124 -0
  118. data/src/core/ext/upb-generated/envoy/admin/v3/metrics.upb.c +43 -0
  119. data/src/core/ext/upb-generated/envoy/admin/v3/metrics.upb.h +102 -0
  120. data/src/core/ext/upb-generated/envoy/admin/v3/mutex_stats.upb.c +43 -0
  121. data/src/core/ext/upb-generated/envoy/admin/v3/mutex_stats.upb.h +97 -0
  122. data/src/core/ext/upb-generated/envoy/admin/v3/server_info.upb.c +106 -0
  123. data/src/core/ext/upb-generated/envoy/admin/v3/server_info.upb.h +605 -0
  124. data/src/core/ext/upb-generated/envoy/admin/v3/tap.upb.c +48 -0
  125. data/src/core/ext/upb-generated/envoy/admin/v3/tap.upb.h +103 -0
  126. data/src/core/ext/upb-generated/envoy/annotations/deprecation.upb.c +14 -12
  127. data/src/core/ext/upb-generated/envoy/annotations/deprecation.upb.h +49 -16
  128. data/src/core/ext/upb-generated/envoy/annotations/resource.upb.c +13 -11
  129. data/src/core/ext/upb-generated/envoy/annotations/resource.upb.h +49 -23
  130. data/src/core/ext/upb-generated/envoy/config/accesslog/v3/accesslog.upb.c +98 -96
  131. data/src/core/ext/upb-generated/envoy/config/accesslog/v3/accesslog.upb.h +669 -386
  132. data/src/core/ext/upb-generated/envoy/config/bootstrap/v3/bootstrap.upb.c +185 -173
  133. data/src/core/ext/upb-generated/envoy/config/bootstrap/v3/bootstrap.upb.h +1269 -664
  134. data/src/core/ext/upb-generated/envoy/config/cluster/v3/circuit_breaker.upb.c +34 -26
  135. data/src/core/ext/upb-generated/envoy/config/cluster/v3/circuit_breaker.upb.h +200 -91
  136. data/src/core/ext/upb-generated/envoy/config/cluster/v3/cluster.upb.c +252 -238
  137. data/src/core/ext/upb-generated/envoy/config/cluster/v3/cluster.upb.h +1670 -827
  138. data/src/core/ext/upb-generated/envoy/config/cluster/v3/filter.upb.c +10 -8
  139. data/src/core/ext/upb-generated/envoy/config/cluster/v3/filter.upb.h +42 -24
  140. data/src/core/ext/upb-generated/envoy/config/cluster/v3/outlier_detection.upb.c +49 -27
  141. data/src/core/ext/upb-generated/envoy/config/cluster/v3/outlier_detection.upb.h +272 -99
  142. data/src/core/ext/upb-generated/envoy/config/common/matcher/v3/matcher.upb.c +299 -0
  143. data/src/core/ext/upb-generated/envoy/config/common/matcher/v3/matcher.upb.h +1381 -0
  144. data/src/core/ext/upb-generated/envoy/config/core/v3/address.upb.c +54 -50
  145. data/src/core/ext/upb-generated/envoy/config/core/v3/address.upb.h +354 -190
  146. data/src/core/ext/upb-generated/envoy/config/core/v3/backoff.upb.c +11 -8
  147. data/src/core/ext/upb-generated/envoy/config/core/v3/backoff.upb.h +45 -25
  148. data/src/core/ext/upb-generated/envoy/config/core/v3/base.upb.c +157 -154
  149. data/src/core/ext/upb-generated/envoy/config/core/v3/base.upb.h +1068 -582
  150. data/src/core/ext/upb-generated/envoy/config/core/v3/config_source.upb.c +87 -42
  151. data/src/core/ext/upb-generated/envoy/config/core/v3/config_source.upb.h +525 -167
  152. data/src/core/ext/upb-generated/envoy/config/core/v3/event_service_config.upb.c +9 -7
  153. data/src/core/ext/upb-generated/envoy/config/core/v3/event_service_config.upb.h +38 -24
  154. data/src/core/ext/upb-generated/envoy/config/core/v3/extension.upb.c +11 -29
  155. data/src/core/ext/upb-generated/envoy/config/core/v3/extension.upb.h +41 -101
  156. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_method_list.upb.c +58 -0
  157. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_method_list.upb.h +151 -0
  158. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_service.upb.c +108 -104
  159. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_service.upb.h +768 -410
  160. data/src/core/ext/upb-generated/envoy/config/core/v3/health_check.upb.c +115 -84
  161. data/src/core/ext/upb-generated/envoy/config/core/v3/health_check.upb.h +736 -349
  162. data/src/core/ext/upb-generated/envoy/config/core/v3/http_uri.upb.c +11 -9
  163. data/src/core/ext/upb-generated/envoy/config/core/v3/http_uri.upb.h +57 -31
  164. data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.c +162 -108
  165. data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.h +992 -397
  166. data/src/core/ext/upb-generated/envoy/config/core/v3/proxy_protocol.upb.c +8 -6
  167. data/src/core/ext/upb-generated/envoy/config/core/v3/proxy_protocol.upb.h +28 -17
  168. data/src/core/ext/upb-generated/envoy/config/core/v3/resolver.upb.c +15 -13
  169. data/src/core/ext/upb-generated/envoy/config/core/v3/resolver.upb.h +83 -49
  170. data/src/core/ext/upb-generated/envoy/config/core/v3/socket_option.upb.c +13 -11
  171. data/src/core/ext/upb-generated/envoy/config/core/v3/socket_option.upb.h +75 -34
  172. data/src/core/ext/upb-generated/envoy/config/core/v3/substitution_format_string.upb.c +15 -13
  173. data/src/core/ext/upb-generated/envoy/config/core/v3/substitution_format_string.upb.h +93 -49
  174. data/src/core/ext/upb-generated/envoy/config/core/v3/udp_socket_config.upb.c +11 -9
  175. data/src/core/ext/upb-generated/envoy/config/core/v3/udp_socket_config.upb.h +46 -26
  176. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint.upb.c +34 -32
  177. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint.upb.h +194 -109
  178. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint_components.upb.c +51 -48
  179. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint_components.upb.h +349 -190
  180. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/load_report.upb.c +49 -47
  181. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/load_report.upb.h +357 -188
  182. data/src/core/ext/upb-generated/envoy/config/listener/v3/api_listener.upb.c +9 -7
  183. data/src/core/ext/upb-generated/envoy/config/listener/v3/api_listener.upb.h +34 -21
  184. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener.upb.c +72 -61
  185. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener.upb.h +504 -260
  186. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener_components.upb.c +77 -69
  187. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener_components.upb.h +560 -301
  188. data/src/core/ext/upb-generated/envoy/config/listener/v3/quic_config.upb.c +19 -15
  189. data/src/core/ext/upb-generated/envoy/config/listener/v3/quic_config.upb.h +104 -49
  190. data/src/core/ext/upb-generated/envoy/config/listener/v3/udp_listener_config.upb.c +12 -10
  191. data/src/core/ext/upb-generated/envoy/config/listener/v3/udp_listener_config.upb.h +66 -41
  192. data/src/core/ext/upb-generated/envoy/config/metrics/v3/metrics_service.upb.c +53 -0
  193. data/src/core/ext/upb-generated/envoy/config/metrics/v3/metrics_service.upb.h +136 -0
  194. data/src/core/ext/upb-generated/envoy/config/metrics/v3/stats.upb.c +58 -55
  195. data/src/core/ext/upb-generated/envoy/config/metrics/v3/stats.upb.h +413 -235
  196. data/src/core/ext/upb-generated/envoy/config/overload/v3/overload.upb.c +62 -60
  197. data/src/core/ext/upb-generated/envoy/config/overload/v3/overload.upb.h +406 -237
  198. data/src/core/ext/upb-generated/envoy/config/rbac/v3/rbac.upb.c +82 -76
  199. data/src/core/ext/upb-generated/envoy/config/rbac/v3/rbac.upb.h +562 -294
  200. data/src/core/ext/upb-generated/envoy/config/route/v3/route.upb.c +37 -31
  201. data/src/core/ext/upb-generated/envoy/config/route/v3/route.upb.h +271 -142
  202. data/src/core/ext/upb-generated/envoy/config/route/v3/route_components.upb.c +503 -475
  203. data/src/core/ext/upb-generated/envoy/config/route/v3/route_components.upb.h +3642 -1901
  204. data/src/core/ext/upb-generated/envoy/config/route/v3/scoped_route.upb.c +25 -19
  205. data/src/core/ext/upb-generated/envoy/config/route/v3/scoped_route.upb.h +148 -72
  206. data/src/core/ext/upb-generated/envoy/config/tap/v3/common.upb.c +222 -0
  207. data/src/core/ext/upb-generated/envoy/config/tap/v3/common.upb.h +1052 -0
  208. data/src/core/ext/upb-generated/envoy/config/trace/v3/datadog.upb.c +44 -0
  209. data/src/core/ext/upb-generated/envoy/config/trace/v3/datadog.upb.h +88 -0
  210. data/src/core/ext/upb-generated/envoy/config/trace/v3/dynamic_ot.upb.c +49 -0
  211. data/src/core/ext/upb-generated/envoy/config/trace/v3/dynamic_ot.upb.h +103 -0
  212. data/src/core/ext/upb-generated/envoy/config/trace/v3/http_tracer.upb.c +15 -13
  213. data/src/core/ext/upb-generated/envoy/config/trace/v3/http_tracer.upb.h +77 -46
  214. data/src/core/ext/upb-generated/envoy/config/trace/v3/lightstep.upb.c +52 -0
  215. data/src/core/ext/upb-generated/envoy/config/trace/v3/lightstep.upb.h +134 -0
  216. data/src/core/ext/upb-generated/envoy/config/trace/v3/opencensus.upb.c +63 -0
  217. data/src/core/ext/upb-generated/envoy/config/trace/v3/opencensus.upb.h +250 -0
  218. data/src/core/ext/upb-generated/envoy/config/trace/v3/service.upb.c +47 -0
  219. data/src/core/ext/upb-generated/envoy/config/trace/v3/service.upb.h +94 -0
  220. data/src/core/ext/upb-generated/envoy/config/trace/v3/skywalking.upb.c +69 -0
  221. data/src/core/ext/upb-generated/envoy/config/trace/v3/skywalking.upb.h +213 -0
  222. data/src/core/ext/upb-generated/envoy/config/trace/v3/trace.upb.c +32 -0
  223. data/src/core/ext/upb-generated/envoy/config/trace/v3/trace.upb.h +42 -0
  224. data/src/core/ext/upb-generated/envoy/config/trace/v3/xray.upb.c +71 -0
  225. data/src/core/ext/upb-generated/envoy/config/trace/v3/xray.upb.h +218 -0
  226. data/src/core/ext/upb-generated/envoy/config/trace/v3/zipkin.upb.c +54 -0
  227. data/src/core/ext/upb-generated/envoy/config/trace/v3/zipkin.upb.h +146 -0
  228. data/src/core/ext/upb-generated/envoy/extensions/clusters/aggregate/v3/cluster.upb.c +8 -6
  229. data/src/core/ext/upb-generated/envoy/extensions/clusters/aggregate/v3/cluster.upb.h +34 -24
  230. data/src/core/ext/upb-generated/envoy/extensions/filters/common/fault/v3/fault.upb.c +29 -27
  231. data/src/core/ext/upb-generated/envoy/extensions/filters/common/fault/v3/fault.upb.h +188 -113
  232. data/src/core/ext/upb-generated/envoy/extensions/filters/http/fault/v3/fault.upb.c +36 -34
  233. data/src/core/ext/upb-generated/envoy/extensions/filters/http/fault/v3/fault.upb.h +260 -132
  234. data/src/core/ext/upb-generated/envoy/extensions/filters/http/rbac/v3/rbac.upb.c +17 -14
  235. data/src/core/ext/upb-generated/envoy/extensions/filters/http/rbac/v3/rbac.upb.h +86 -49
  236. data/src/core/ext/upb-generated/envoy/extensions/filters/http/router/v3/router.upb.c +16 -14
  237. data/src/core/ext/upb-generated/envoy/extensions/filters/http/router/v3/router.upb.h +86 -43
  238. data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.c +229 -198
  239. data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.h +1553 -734
  240. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/cert.upb.c +3 -1
  241. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/cert.upb.h +2 -1
  242. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/common.upb.c +87 -58
  243. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/common.upb.h +554 -235
  244. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/secret.upb.c +26 -24
  245. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/secret.upb.h +156 -87
  246. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls.upb.c +98 -71
  247. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls.upb.h +622 -263
  248. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upb.c +62 -0
  249. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upb.h +160 -0
  250. data/src/core/ext/upb-generated/envoy/service/discovery/v3/ads.upb.c +6 -4
  251. data/src/core/ext/upb-generated/envoy/service/discovery/v3/ads.upb.h +22 -16
  252. data/src/core/ext/upb-generated/envoy/service/discovery/v3/discovery.upb.c +67 -65
  253. data/src/core/ext/upb-generated/envoy/service/discovery/v3/discovery.upb.h +474 -256
  254. data/src/core/ext/upb-generated/envoy/service/load_stats/v3/lrs.upb.c +18 -16
  255. data/src/core/ext/upb-generated/envoy/service/load_stats/v3/lrs.upb.h +107 -62
  256. data/src/core/ext/upb-generated/envoy/service/status/v3/csds.upb.c +51 -49
  257. data/src/core/ext/upb-generated/envoy/service/status/v3/csds.upb.h +347 -186
  258. data/src/core/ext/upb-generated/envoy/type/http/v3/cookie.upb.c +48 -0
  259. data/src/core/ext/upb-generated/envoy/type/http/v3/cookie.upb.h +112 -0
  260. data/src/core/ext/upb-generated/envoy/type/http/v3/path_transformation.upb.c +20 -18
  261. data/src/core/ext/upb-generated/envoy/type/http/v3/path_transformation.upb.h +124 -82
  262. data/src/core/ext/upb-generated/envoy/type/matcher/v3/http_inputs.upb.c +74 -0
  263. data/src/core/ext/upb-generated/envoy/type/matcher/v3/http_inputs.upb.h +214 -0
  264. data/src/core/ext/upb-generated/envoy/type/matcher/v3/metadata.upb.c +16 -14
  265. data/src/core/ext/upb-generated/envoy/type/matcher/v3/metadata.upb.h +99 -57
  266. data/src/core/ext/upb-generated/envoy/type/matcher/v3/node.upb.c +10 -8
  267. data/src/core/ext/upb-generated/envoy/type/matcher/v3/node.upb.h +50 -31
  268. data/src/core/ext/upb-generated/envoy/type/matcher/v3/number.upb.c +10 -8
  269. data/src/core/ext/upb-generated/envoy/type/matcher/v3/number.upb.h +48 -27
  270. data/src/core/ext/upb-generated/envoy/type/matcher/v3/path.upb.c +9 -7
  271. data/src/core/ext/upb-generated/envoy/type/matcher/v3/path.upb.h +38 -24
  272. data/src/core/ext/upb-generated/envoy/type/matcher/v3/regex.upb.c +21 -19
  273. data/src/core/ext/upb-generated/envoy/type/matcher/v3/regex.upb.h +117 -69
  274. data/src/core/ext/upb-generated/envoy/type/matcher/v3/string.upb.c +19 -17
  275. data/src/core/ext/upb-generated/envoy/type/matcher/v3/string.upb.h +123 -65
  276. data/src/core/ext/upb-generated/envoy/type/matcher/v3/struct.upb.c +14 -12
  277. data/src/core/ext/upb-generated/envoy/type/matcher/v3/struct.upb.h +85 -53
  278. data/src/core/ext/upb-generated/envoy/type/matcher/v3/value.upb.c +23 -21
  279. data/src/core/ext/upb-generated/envoy/type/matcher/v3/value.upb.h +150 -83
  280. data/src/core/ext/upb-generated/envoy/type/metadata/v3/metadata.upb.c +32 -30
  281. data/src/core/ext/upb-generated/envoy/type/metadata/v3/metadata.upb.h +230 -146
  282. data/src/core/ext/upb-generated/envoy/type/tracing/v3/custom_tag.upb.c +36 -34
  283. data/src/core/ext/upb-generated/envoy/type/tracing/v3/custom_tag.upb.h +235 -131
  284. data/src/core/ext/upb-generated/envoy/type/v3/hash_policy.upb.c +66 -0
  285. data/src/core/ext/upb-generated/envoy/type/v3/hash_policy.upb.h +201 -0
  286. data/src/core/ext/upb-generated/envoy/type/v3/http.upb.c +3 -1
  287. data/src/core/ext/upb-generated/envoy/type/v3/http.upb.h +2 -1
  288. data/src/core/ext/upb-generated/envoy/type/v3/http_status.upb.c +42 -0
  289. data/src/core/ext/upb-generated/envoy/type/v3/http_status.upb.h +139 -0
  290. data/src/core/ext/upb-generated/envoy/type/v3/percent.upb.c +13 -11
  291. data/src/core/ext/upb-generated/envoy/type/v3/percent.upb.h +62 -36
  292. data/src/core/ext/upb-generated/envoy/type/v3/range.upb.c +19 -17
  293. data/src/core/ext/upb-generated/envoy/type/v3/range.upb.h +98 -52
  294. data/src/core/ext/upb-generated/envoy/type/v3/ratelimit_unit.upb.c +26 -0
  295. data/src/core/ext/upb-generated/envoy/type/v3/ratelimit_unit.upb.h +41 -0
  296. data/src/core/ext/upb-generated/envoy/type/v3/semantic_version.upb.c +10 -8
  297. data/src/core/ext/upb-generated/envoy/type/v3/semantic_version.upb.h +40 -19
  298. data/src/core/ext/upb-generated/envoy/type/v3/token_bucket.upb.c +51 -0
  299. data/src/core/ext/upb-generated/envoy/type/v3/token_bucket.upb.h +127 -0
  300. data/src/core/ext/upb-generated/google/api/annotations.upb.c +8 -6
  301. data/src/core/ext/upb-generated/google/api/annotations.upb.h +22 -6
  302. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/checked.upb.c +109 -103
  303. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/checked.upb.h +720 -382
  304. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/syntax.upb.c +120 -112
  305. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/syntax.upb.h +795 -402
  306. data/src/core/ext/upb-generated/google/api/http.upb.c +29 -27
  307. data/src/core/ext/upb-generated/google/api/http.upb.h +216 -115
  308. data/src/core/ext/upb-generated/google/api/httpbody.upb.c +46 -0
  309. data/src/core/ext/upb-generated/google/api/httpbody.upb.h +111 -0
  310. data/src/core/ext/upb-generated/google/protobuf/any.upb.c +9 -7
  311. data/src/core/ext/upb-generated/google/protobuf/any.upb.h +38 -22
  312. data/src/core/ext/upb-generated/google/protobuf/descriptor.upb.c +291 -237
  313. data/src/core/ext/upb-generated/google/protobuf/descriptor.upb.h +2076 -1030
  314. data/src/core/ext/upb-generated/google/protobuf/duration.upb.c +9 -7
  315. data/src/core/ext/upb-generated/google/protobuf/duration.upb.h +36 -20
  316. data/src/core/ext/upb-generated/google/protobuf/empty.upb.c +6 -4
  317. data/src/core/ext/upb-generated/google/protobuf/empty.upb.h +22 -16
  318. data/src/core/ext/upb-generated/google/protobuf/struct.upb.c +31 -29
  319. data/src/core/ext/upb-generated/google/protobuf/struct.upb.h +177 -93
  320. data/src/core/ext/upb-generated/google/protobuf/timestamp.upb.c +9 -7
  321. data/src/core/ext/upb-generated/google/protobuf/timestamp.upb.h +36 -20
  322. data/src/core/ext/upb-generated/google/protobuf/wrappers.upb.c +40 -38
  323. data/src/core/ext/upb-generated/google/protobuf/wrappers.upb.h +240 -149
  324. data/src/core/ext/upb-generated/google/rpc/status.upb.c +11 -9
  325. data/src/core/ext/upb-generated/google/rpc/status.upb.h +52 -30
  326. data/src/core/ext/upb-generated/opencensus/proto/trace/v1/trace_config.upb.c +84 -0
  327. data/src/core/ext/upb-generated/opencensus/proto/trace/v1/trace_config.upb.h +319 -0
  328. data/src/core/ext/upb-generated/src/proto/grpc/gcp/altscontext.upb.c +21 -19
  329. data/src/core/ext/upb-generated/src/proto/grpc/gcp/altscontext.upb.h +103 -48
  330. data/src/core/ext/upb-generated/src/proto/grpc/gcp/handshaker.upb.c +102 -96
  331. data/src/core/ext/upb-generated/src/proto/grpc/gcp/handshaker.upb.h +685 -359
  332. data/src/core/ext/upb-generated/src/proto/grpc/gcp/transport_security_common.upb.c +16 -13
  333. data/src/core/ext/upb-generated/src/proto/grpc/gcp/transport_security_common.upb.h +76 -41
  334. data/src/core/ext/upb-generated/src/proto/grpc/health/v1/health.upb.c +12 -10
  335. data/src/core/ext/upb-generated/src/proto/grpc/health/v1/health.upb.h +56 -35
  336. data/src/core/ext/upb-generated/src/proto/grpc/lb/v1/load_balancer.upb.c +57 -55
  337. data/src/core/ext/upb-generated/src/proto/grpc/lb/v1/load_balancer.upb.h +383 -219
  338. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls.upb.c +22 -20
  339. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls.upb.h +115 -63
  340. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls_config.upb.c +175 -0
  341. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls_config.upb.h +764 -0
  342. data/src/core/ext/upb-generated/udpa/annotations/migrate.upb.c +36 -34
  343. data/src/core/ext/upb-generated/udpa/annotations/migrate.upb.h +189 -78
  344. data/src/core/ext/upb-generated/udpa/annotations/security.upb.c +14 -12
  345. data/src/core/ext/upb-generated/udpa/annotations/security.upb.h +53 -22
  346. data/src/core/ext/upb-generated/udpa/annotations/sensitive.upb.c +7 -5
  347. data/src/core/ext/upb-generated/udpa/annotations/sensitive.upb.h +15 -6
  348. data/src/core/ext/upb-generated/udpa/annotations/status.upb.c +14 -12
  349. data/src/core/ext/upb-generated/udpa/annotations/status.upb.h +55 -24
  350. data/src/core/ext/upb-generated/udpa/annotations/versioning.upb.c +13 -11
  351. data/src/core/ext/upb-generated/udpa/annotations/versioning.upb.h +49 -23
  352. data/src/core/ext/upb-generated/validate/validate.upb.c +339 -312
  353. data/src/core/ext/upb-generated/validate/validate.upb.h +2726 -1180
  354. data/src/core/ext/upb-generated/xds/annotations/v3/migrate.upb.c +110 -0
  355. data/src/core/ext/upb-generated/xds/annotations/v3/migrate.upb.h +278 -0
  356. data/src/core/ext/upb-generated/xds/annotations/v3/security.upb.c +55 -0
  357. data/src/core/ext/upb-generated/xds/annotations/v3/security.upb.h +108 -0
  358. data/src/core/ext/upb-generated/xds/annotations/v3/sensitive.upb.c +38 -0
  359. data/src/core/ext/upb-generated/xds/annotations/v3/sensitive.upb.h +46 -0
  360. data/src/core/ext/upb-generated/xds/annotations/v3/status.upb.c +34 -32
  361. data/src/core/ext/upb-generated/xds/annotations/v3/status.upb.h +171 -80
  362. data/src/core/ext/upb-generated/xds/annotations/v3/versioning.upb.c +53 -0
  363. data/src/core/ext/upb-generated/xds/annotations/v3/versioning.upb.h +99 -0
  364. data/src/core/ext/upb-generated/xds/core/v3/authority.upb.c +8 -6
  365. data/src/core/ext/upb-generated/xds/core/v3/authority.upb.h +30 -19
  366. data/src/core/ext/upb-generated/xds/core/v3/collection_entry.upb.c +18 -16
  367. data/src/core/ext/upb-generated/xds/core/v3/collection_entry.upb.h +98 -55
  368. data/src/core/ext/upb-generated/xds/core/v3/context_params.upb.c +14 -12
  369. data/src/core/ext/upb-generated/xds/core/v3/context_params.upb.h +53 -30
  370. data/src/core/ext/upb-generated/xds/core/v3/extension.upb.c +46 -0
  371. data/src/core/ext/upb-generated/xds/core/v3/extension.upb.h +103 -0
  372. data/src/core/ext/upb-generated/xds/core/v3/resource.upb.c +12 -10
  373. data/src/core/ext/upb-generated/xds/core/v3/resource.upb.h +55 -30
  374. data/src/core/ext/upb-generated/xds/core/v3/resource_locator.upb.c +20 -18
  375. data/src/core/ext/upb-generated/xds/core/v3/resource_locator.upb.h +130 -70
  376. data/src/core/ext/upb-generated/xds/core/v3/resource_name.upb.c +12 -10
  377. data/src/core/ext/upb-generated/xds/core/v3/resource_name.upb.h +58 -30
  378. data/src/core/ext/upb-generated/xds/data/orca/v3/orca_load_report.upb.c +23 -21
  379. data/src/core/ext/upb-generated/xds/data/orca/v3/orca_load_report.upb.h +101 -46
  380. data/src/core/ext/upb-generated/xds/type/matcher/v3/matcher.upb.c +207 -0
  381. data/src/core/ext/upb-generated/xds/type/matcher/v3/matcher.upb.h +878 -0
  382. data/src/core/ext/upb-generated/xds/type/matcher/v3/regex.upb.c +52 -0
  383. data/src/core/ext/upb-generated/xds/type/matcher/v3/regex.upb.h +143 -0
  384. data/src/core/ext/upb-generated/xds/type/matcher/v3/string.upb.c +65 -0
  385. data/src/core/ext/upb-generated/xds/type/matcher/v3/string.upb.h +218 -0
  386. data/src/core/ext/upb-generated/xds/type/v3/typed_struct.upb.c +10 -8
  387. data/src/core/ext/upb-generated/xds/type/v3/typed_struct.upb.h +42 -24
  388. data/src/core/ext/upbdefs-generated/envoy/admin/v3/certs.upbdefs.c +84 -0
  389. data/src/core/ext/upbdefs-generated/envoy/admin/v3/certs.upbdefs.h +55 -0
  390. data/src/core/ext/upbdefs-generated/envoy/admin/v3/clusters.upbdefs.c +127 -0
  391. data/src/core/ext/upbdefs-generated/envoy/admin/v3/clusters.upbdefs.h +50 -0
  392. data/src/core/ext/upbdefs-generated/envoy/admin/v3/config_dump.upbdefs.c +14 -12
  393. data/src/core/ext/upbdefs-generated/envoy/admin/v3/config_dump.upbdefs.h +67 -67
  394. data/src/core/ext/upbdefs-generated/envoy/admin/v3/init_dump.upbdefs.c +43 -0
  395. data/src/core/ext/upbdefs-generated/envoy/admin/v3/init_dump.upbdefs.h +40 -0
  396. data/src/core/ext/upbdefs-generated/envoy/admin/v3/listeners.upbdefs.c +53 -0
  397. data/src/core/ext/upbdefs-generated/envoy/admin/v3/listeners.upbdefs.h +40 -0
  398. data/src/core/ext/upbdefs-generated/envoy/admin/v3/memory.upbdefs.c +49 -0
  399. data/src/core/ext/upbdefs-generated/envoy/admin/v3/memory.upbdefs.h +35 -0
  400. data/src/core/ext/upbdefs-generated/envoy/admin/v3/metrics.upbdefs.c +46 -0
  401. data/src/core/ext/upbdefs-generated/envoy/admin/v3/metrics.upbdefs.h +35 -0
  402. data/src/core/ext/upbdefs-generated/envoy/admin/v3/mutex_stats.upbdefs.c +46 -0
  403. data/src/core/ext/upbdefs-generated/envoy/admin/v3/mutex_stats.upbdefs.h +35 -0
  404. data/src/core/ext/upbdefs-generated/envoy/admin/v3/server_info.upbdefs.c +142 -0
  405. data/src/core/ext/upbdefs-generated/envoy/admin/v3/server_info.upbdefs.h +40 -0
  406. data/src/core/ext/upbdefs-generated/envoy/admin/v3/tap.upbdefs.c +51 -0
  407. data/src/core/ext/upbdefs-generated/envoy/admin/v3/tap.upbdefs.h +35 -0
  408. data/src/core/ext/upbdefs-generated/envoy/annotations/deprecation.upbdefs.c +8 -6
  409. data/src/core/ext/upbdefs-generated/envoy/annotations/deprecation.upbdefs.h +1 -1
  410. data/src/core/ext/upbdefs-generated/envoy/annotations/resource.upbdefs.c +8 -6
  411. data/src/core/ext/upbdefs-generated/envoy/annotations/resource.upbdefs.h +4 -4
  412. data/src/core/ext/upbdefs-generated/envoy/config/accesslog/v3/accesslog.upbdefs.c +20 -17
  413. data/src/core/ext/upbdefs-generated/envoy/config/accesslog/v3/accesslog.upbdefs.h +46 -46
  414. data/src/core/ext/upbdefs-generated/envoy/config/bootstrap/v3/bootstrap.upbdefs.c +248 -240
  415. data/src/core/ext/upbdefs-generated/envoy/config/bootstrap/v3/bootstrap.upbdefs.h +55 -55
  416. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/circuit_breaker.upbdefs.c +58 -51
  417. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/circuit_breaker.upbdefs.h +10 -10
  418. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/cluster.upbdefs.c +385 -371
  419. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/cluster.upbdefs.h +76 -76
  420. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/filter.upbdefs.c +14 -11
  421. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/filter.upbdefs.h +4 -4
  422. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/outlier_detection.upbdefs.c +23 -16
  423. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/outlier_detection.upbdefs.h +4 -4
  424. data/src/core/ext/upbdefs-generated/envoy/config/common/matcher/v3/matcher.upbdefs.c +206 -0
  425. data/src/core/ext/upbdefs-generated/envoy/config/common/matcher/v3/matcher.upbdefs.h +105 -0
  426. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/address.upbdefs.c +15 -13
  427. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/address.upbdefs.h +22 -22
  428. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/backoff.upbdefs.c +15 -12
  429. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/backoff.upbdefs.h +4 -4
  430. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/base.upbdefs.c +85 -80
  431. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/base.upbdefs.h +73 -73
  432. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/config_source.upbdefs.c +138 -101
  433. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/config_source.upbdefs.h +26 -16
  434. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/event_service_config.upbdefs.c +14 -12
  435. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/event_service_config.upbdefs.h +4 -4
  436. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/extension.upbdefs.c +22 -34
  437. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/extension.upbdefs.h +4 -9
  438. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/grpc_method_list.upbdefs.c +53 -0
  439. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/grpc_method_list.upbdefs.h +40 -0
  440. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/grpc_service.upbdefs.c +21 -18
  441. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/grpc_service.upbdefs.h +43 -43
  442. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/health_check.upbdefs.c +177 -166
  443. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/health_check.upbdefs.h +30 -25
  444. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/http_uri.upbdefs.c +14 -12
  445. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/http_uri.upbdefs.h +4 -4
  446. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/protocol.upbdefs.c +250 -221
  447. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/protocol.upbdefs.h +53 -43
  448. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/proxy_protocol.upbdefs.c +12 -9
  449. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/proxy_protocol.upbdefs.h +4 -4
  450. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/resolver.upbdefs.c +14 -11
  451. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/resolver.upbdefs.h +7 -7
  452. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/socket_option.upbdefs.c +14 -11
  453. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/socket_option.upbdefs.h +4 -4
  454. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/substitution_format_string.upbdefs.c +18 -15
  455. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/substitution_format_string.upbdefs.h +4 -4
  456. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/udp_socket_config.upbdefs.c +13 -11
  457. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/udp_socket_config.upbdefs.h +4 -4
  458. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint.upbdefs.c +18 -15
  459. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint.upbdefs.h +13 -13
  460. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint_components.upbdefs.c +19 -16
  461. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint_components.upbdefs.h +19 -19
  462. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/load_report.upbdefs.c +18 -15
  463. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/load_report.upbdefs.h +16 -16
  464. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/api_listener.upbdefs.c +14 -11
  465. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/api_listener.upbdefs.h +4 -4
  466. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener.upbdefs.c +52 -45
  467. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener.upbdefs.h +19 -19
  468. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener_components.upbdefs.c +153 -147
  469. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener_components.upbdefs.h +22 -22
  470. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/quic_config.upbdefs.c +19 -16
  471. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/quic_config.upbdefs.h +4 -4
  472. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/udp_listener_config.upbdefs.c +15 -12
  473. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/udp_listener_config.upbdefs.h +7 -7
  474. data/src/core/ext/upbdefs-generated/envoy/config/metrics/v3/metrics_service.upbdefs.c +69 -0
  475. data/src/core/ext/upbdefs-generated/envoy/config/metrics/v3/metrics_service.upbdefs.h +35 -0
  476. data/src/core/ext/upbdefs-generated/envoy/config/metrics/v3/stats.upbdefs.c +17 -14
  477. data/src/core/ext/upbdefs-generated/envoy/config/metrics/v3/stats.upbdefs.h +25 -25
  478. data/src/core/ext/upbdefs-generated/envoy/config/overload/v3/overload.upbdefs.c +17 -14
  479. data/src/core/ext/upbdefs-generated/envoy/config/overload/v3/overload.upbdefs.h +28 -28
  480. data/src/core/ext/upbdefs-generated/envoy/config/rbac/v3/rbac.upbdefs.c +23 -21
  481. data/src/core/ext/upbdefs-generated/envoy/config/rbac/v3/rbac.upbdefs.h +25 -25
  482. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route.upbdefs.c +36 -27
  483. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route.upbdefs.h +10 -10
  484. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route_components.upbdefs.c +826 -803
  485. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route_components.upbdefs.h +160 -160
  486. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/scoped_route.upbdefs.c +52 -37
  487. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/scoped_route.upbdefs.h +10 -10
  488. data/src/core/ext/upbdefs-generated/envoy/config/tap/v3/common.upbdefs.c +188 -0
  489. data/src/core/ext/upbdefs-generated/envoy/config/tap/v3/common.upbdefs.h +85 -0
  490. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/datadog.upbdefs.c +54 -0
  491. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/datadog.upbdefs.h +35 -0
  492. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/dynamic_ot.upbdefs.c +57 -0
  493. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/dynamic_ot.upbdefs.h +35 -0
  494. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/http_tracer.upbdefs.c +15 -12
  495. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/http_tracer.upbdefs.h +7 -7
  496. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/lightstep.upbdefs.c +72 -0
  497. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/lightstep.upbdefs.h +35 -0
  498. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/opencensus.upbdefs.c +99 -0
  499. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/opencensus.upbdefs.h +35 -0
  500. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/service.upbdefs.c +52 -0
  501. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/service.upbdefs.h +35 -0
  502. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/skywalking.upbdefs.c +71 -0
  503. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/skywalking.upbdefs.h +40 -0
  504. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/trace.upbdefs.c +57 -0
  505. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/trace.upbdefs.h +30 -0
  506. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/xray.upbdefs.c +75 -0
  507. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/xray.upbdefs.h +40 -0
  508. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/zipkin.upbdefs.c +77 -0
  509. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/zipkin.upbdefs.h +35 -0
  510. data/src/core/ext/upbdefs-generated/envoy/extensions/clusters/aggregate/v3/cluster.upbdefs.c +15 -11
  511. data/src/core/ext/upbdefs-generated/envoy/extensions/clusters/aggregate/v3/cluster.upbdefs.h +4 -4
  512. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/common/fault/v3/fault.upbdefs.c +17 -14
  513. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/common/fault/v3/fault.upbdefs.h +16 -16
  514. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/fault/v3/fault.upbdefs.c +18 -15
  515. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/fault/v3/fault.upbdefs.h +10 -10
  516. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/rbac/v3/rbac.upbdefs.c +14 -11
  517. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/rbac/v3/rbac.upbdefs.h +7 -7
  518. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/router/v3/router.upbdefs.c +17 -13
  519. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/router/v3/router.upbdefs.h +4 -4
  520. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.c +197 -172
  521. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.h +63 -58
  522. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/cert.upbdefs.c +15 -11
  523. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/cert.upbdefs.h +1 -1
  524. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.c +169 -140
  525. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.h +24 -19
  526. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/secret.upbdefs.c +19 -16
  527. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/secret.upbdefs.h +10 -10
  528. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls.upbdefs.c +217 -199
  529. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls.upbdefs.h +24 -19
  530. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upbdefs.c +58 -0
  531. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upbdefs.h +40 -0
  532. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/ads.upbdefs.c +14 -11
  533. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/ads.upbdefs.h +4 -4
  534. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/discovery.upbdefs.c +17 -14
  535. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/discovery.upbdefs.h +22 -22
  536. data/src/core/ext/upbdefs-generated/envoy/service/load_stats/v3/lrs.upbdefs.c +16 -13
  537. data/src/core/ext/upbdefs-generated/envoy/service/load_stats/v3/lrs.upbdefs.h +7 -7
  538. data/src/core/ext/upbdefs-generated/envoy/service/status/v3/csds.upbdefs.c +20 -17
  539. data/src/core/ext/upbdefs-generated/envoy/service/status/v3/csds.upbdefs.h +16 -16
  540. data/src/core/ext/upbdefs-generated/envoy/type/http/v3/cookie.upbdefs.c +46 -0
  541. data/src/core/ext/upbdefs-generated/envoy/type/http/v3/cookie.upbdefs.h +35 -0
  542. data/src/core/ext/upbdefs-generated/envoy/type/http/v3/path_transformation.upbdefs.c +13 -10
  543. data/src/core/ext/upbdefs-generated/envoy/type/http/v3/path_transformation.upbdefs.h +13 -13
  544. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/http_inputs.upbdefs.c +52 -0
  545. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/http_inputs.upbdefs.h +50 -0
  546. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/metadata.upbdefs.c +15 -12
  547. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/metadata.upbdefs.h +7 -7
  548. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/node.upbdefs.c +15 -12
  549. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/node.upbdefs.h +4 -4
  550. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/number.upbdefs.c +15 -12
  551. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/number.upbdefs.h +4 -4
  552. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/path.upbdefs.c +15 -12
  553. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/path.upbdefs.h +4 -4
  554. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/regex.upbdefs.c +15 -12
  555. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/regex.upbdefs.h +10 -10
  556. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/string.upbdefs.c +15 -12
  557. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/string.upbdefs.h +7 -7
  558. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/struct.upbdefs.c +14 -12
  559. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/struct.upbdefs.h +7 -7
  560. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/value.upbdefs.c +16 -13
  561. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/value.upbdefs.h +10 -10
  562. data/src/core/ext/upbdefs-generated/envoy/type/metadata/v3/metadata.upbdefs.c +13 -10
  563. data/src/core/ext/upbdefs-generated/envoy/type/metadata/v3/metadata.upbdefs.h +22 -22
  564. data/src/core/ext/upbdefs-generated/envoy/type/tracing/v3/custom_tag.upbdefs.c +14 -11
  565. data/src/core/ext/upbdefs-generated/envoy/type/tracing/v3/custom_tag.upbdefs.h +16 -16
  566. data/src/core/ext/upbdefs-generated/envoy/type/v3/hash_policy.upbdefs.c +53 -0
  567. data/src/core/ext/upbdefs-generated/envoy/type/v3/hash_policy.upbdefs.h +45 -0
  568. data/src/core/ext/upbdefs-generated/envoy/type/v3/http.upbdefs.c +10 -8
  569. data/src/core/ext/upbdefs-generated/envoy/type/v3/http.upbdefs.h +1 -1
  570. data/src/core/ext/upbdefs-generated/envoy/type/v3/http_status.upbdefs.c +94 -0
  571. data/src/core/ext/upbdefs-generated/envoy/type/v3/http_status.upbdefs.h +35 -0
  572. data/src/core/ext/upbdefs-generated/envoy/type/v3/percent.upbdefs.c +12 -10
  573. data/src/core/ext/upbdefs-generated/envoy/type/v3/percent.upbdefs.h +7 -7
  574. data/src/core/ext/upbdefs-generated/envoy/type/v3/range.upbdefs.c +11 -8
  575. data/src/core/ext/upbdefs-generated/envoy/type/v3/range.upbdefs.h +10 -10
  576. data/src/core/ext/upbdefs-generated/envoy/type/v3/ratelimit_unit.upbdefs.c +38 -0
  577. data/src/core/ext/upbdefs-generated/envoy/type/v3/ratelimit_unit.upbdefs.h +30 -0
  578. data/src/core/ext/upbdefs-generated/envoy/type/v3/semantic_version.upbdefs.c +11 -9
  579. data/src/core/ext/upbdefs-generated/envoy/type/v3/semantic_version.upbdefs.h +4 -4
  580. data/src/core/ext/upbdefs-generated/envoy/type/v3/token_bucket.upbdefs.c +57 -0
  581. data/src/core/ext/upbdefs-generated/envoy/type/v3/token_bucket.upbdefs.h +35 -0
  582. data/src/core/ext/upbdefs-generated/google/api/annotations.upbdefs.c +5 -5
  583. data/src/core/ext/upbdefs-generated/google/api/annotations.upbdefs.h +1 -1
  584. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/checked.upbdefs.c +6 -6
  585. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/checked.upbdefs.h +40 -40
  586. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/syntax.upbdefs.c +6 -6
  587. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/syntax.upbdefs.h +43 -43
  588. data/src/core/ext/upbdefs-generated/google/api/http.upbdefs.c +3 -3
  589. data/src/core/ext/upbdefs-generated/google/api/http.upbdefs.h +10 -10
  590. data/src/core/ext/upbdefs-generated/google/api/httpbody.upbdefs.c +39 -0
  591. data/src/core/ext/upbdefs-generated/google/api/httpbody.upbdefs.h +35 -0
  592. data/src/core/ext/upbdefs-generated/google/protobuf/any.upbdefs.c +3 -3
  593. data/src/core/ext/upbdefs-generated/google/protobuf/any.upbdefs.h +4 -4
  594. data/src/core/ext/upbdefs-generated/google/protobuf/descriptor.upbdefs.c +3 -3
  595. data/src/core/ext/upbdefs-generated/google/protobuf/descriptor.upbdefs.h +82 -82
  596. data/src/core/ext/upbdefs-generated/google/protobuf/duration.upbdefs.c +3 -3
  597. data/src/core/ext/upbdefs-generated/google/protobuf/duration.upbdefs.h +4 -4
  598. data/src/core/ext/upbdefs-generated/google/protobuf/empty.upbdefs.c +3 -3
  599. data/src/core/ext/upbdefs-generated/google/protobuf/empty.upbdefs.h +4 -4
  600. data/src/core/ext/upbdefs-generated/google/protobuf/struct.upbdefs.c +3 -3
  601. data/src/core/ext/upbdefs-generated/google/protobuf/struct.upbdefs.h +13 -13
  602. data/src/core/ext/upbdefs-generated/google/protobuf/timestamp.upbdefs.c +3 -3
  603. data/src/core/ext/upbdefs-generated/google/protobuf/timestamp.upbdefs.h +4 -4
  604. data/src/core/ext/upbdefs-generated/google/protobuf/wrappers.upbdefs.c +3 -3
  605. data/src/core/ext/upbdefs-generated/google/protobuf/wrappers.upbdefs.h +28 -28
  606. data/src/core/ext/upbdefs-generated/google/rpc/status.upbdefs.c +4 -4
  607. data/src/core/ext/upbdefs-generated/google/rpc/status.upbdefs.h +4 -4
  608. data/src/core/ext/upbdefs-generated/opencensus/proto/trace/v1/trace_config.upbdefs.c +67 -0
  609. data/src/core/ext/upbdefs-generated/opencensus/proto/trace/v1/trace_config.upbdefs.h +50 -0
  610. data/src/core/ext/upbdefs-generated/src/proto/grpc/lookup/v1/rls_config.upbdefs.c +99 -0
  611. data/src/core/ext/upbdefs-generated/src/proto/grpc/lookup/v1/rls_config.upbdefs.h +75 -0
  612. data/src/core/ext/upbdefs-generated/udpa/annotations/migrate.upbdefs.c +4 -4
  613. data/src/core/ext/upbdefs-generated/udpa/annotations/migrate.upbdefs.h +10 -10
  614. data/src/core/ext/upbdefs-generated/udpa/annotations/security.upbdefs.c +5 -5
  615. data/src/core/ext/upbdefs-generated/udpa/annotations/security.upbdefs.h +4 -4
  616. data/src/core/ext/upbdefs-generated/udpa/annotations/sensitive.upbdefs.c +4 -4
  617. data/src/core/ext/upbdefs-generated/udpa/annotations/sensitive.upbdefs.h +1 -1
  618. data/src/core/ext/upbdefs-generated/udpa/annotations/status.upbdefs.c +4 -4
  619. data/src/core/ext/upbdefs-generated/udpa/annotations/status.upbdefs.h +4 -4
  620. data/src/core/ext/upbdefs-generated/udpa/annotations/versioning.upbdefs.c +4 -4
  621. data/src/core/ext/upbdefs-generated/udpa/annotations/versioning.upbdefs.h +4 -4
  622. data/src/core/ext/upbdefs-generated/validate/validate.upbdefs.c +6 -6
  623. data/src/core/ext/upbdefs-generated/validate/validate.upbdefs.h +70 -70
  624. data/src/core/ext/upbdefs-generated/xds/annotations/v3/migrate.upbdefs.c +63 -0
  625. data/src/core/ext/upbdefs-generated/xds/annotations/v3/migrate.upbdefs.h +45 -0
  626. data/src/core/ext/upbdefs-generated/xds/annotations/v3/security.upbdefs.c +47 -0
  627. data/src/core/ext/upbdefs-generated/xds/annotations/v3/security.upbdefs.h +35 -0
  628. data/src/core/ext/upbdefs-generated/xds/annotations/v3/sensitive.upbdefs.c +35 -0
  629. data/src/core/ext/upbdefs-generated/xds/annotations/v3/sensitive.upbdefs.h +30 -0
  630. data/src/core/ext/upbdefs-generated/xds/annotations/v3/status.upbdefs.c +4 -4
  631. data/src/core/ext/upbdefs-generated/xds/annotations/v3/status.upbdefs.h +13 -13
  632. data/src/core/ext/upbdefs-generated/xds/annotations/v3/versioning.upbdefs.c +40 -0
  633. data/src/core/ext/upbdefs-generated/xds/annotations/v3/versioning.upbdefs.h +35 -0
  634. data/src/core/ext/upbdefs-generated/xds/core/v3/authority.upbdefs.c +5 -5
  635. data/src/core/ext/upbdefs-generated/xds/core/v3/authority.upbdefs.h +4 -4
  636. data/src/core/ext/upbdefs-generated/xds/core/v3/collection_entry.upbdefs.c +7 -7
  637. data/src/core/ext/upbdefs-generated/xds/core/v3/collection_entry.upbdefs.h +7 -7
  638. data/src/core/ext/upbdefs-generated/xds/core/v3/context_params.upbdefs.c +4 -4
  639. data/src/core/ext/upbdefs-generated/xds/core/v3/context_params.upbdefs.h +7 -7
  640. data/src/core/ext/upbdefs-generated/xds/core/v3/extension.upbdefs.c +41 -0
  641. data/src/core/ext/upbdefs-generated/xds/core/v3/extension.upbdefs.h +35 -0
  642. data/src/core/ext/upbdefs-generated/xds/core/v3/resource.upbdefs.c +6 -6
  643. data/src/core/ext/upbdefs-generated/xds/core/v3/resource.upbdefs.h +4 -4
  644. data/src/core/ext/upbdefs-generated/xds/core/v3/resource_locator.upbdefs.c +6 -6
  645. data/src/core/ext/upbdefs-generated/xds/core/v3/resource_locator.upbdefs.h +7 -7
  646. data/src/core/ext/upbdefs-generated/xds/core/v3/resource_name.upbdefs.c +6 -6
  647. data/src/core/ext/upbdefs-generated/xds/core/v3/resource_name.upbdefs.h +4 -4
  648. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/matcher.upbdefs.c +126 -0
  649. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/matcher.upbdefs.h +80 -0
  650. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/regex.upbdefs.c +40 -0
  651. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/regex.upbdefs.h +40 -0
  652. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/string.upbdefs.c +52 -0
  653. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/string.upbdefs.h +40 -0
  654. data/src/core/ext/upbdefs-generated/xds/type/v3/typed_struct.upbdefs.c +5 -5
  655. data/src/core/ext/upbdefs-generated/xds/type/v3/typed_struct.upbdefs.h +4 -4
  656. data/src/core/ext/xds/certificate_provider_store.cc +8 -0
  657. data/src/core/ext/xds/certificate_provider_store.h +9 -0
  658. data/src/core/ext/xds/file_watcher_certificate_provider_factory.cc +4 -4
  659. data/src/core/ext/xds/file_watcher_certificate_provider_factory.h +2 -2
  660. data/src/core/ext/xds/upb_utils.h +8 -6
  661. data/src/core/ext/xds/xds_api.cc +72 -35
  662. data/src/core/ext/xds/xds_api.h +4 -4
  663. data/src/core/ext/xds/xds_bootstrap.cc +37 -5
  664. data/src/core/ext/xds/xds_bootstrap.h +13 -0
  665. data/src/core/ext/xds/xds_certificate_provider.cc +2 -0
  666. data/src/core/ext/xds/xds_certificate_provider.h +8 -0
  667. data/src/core/ext/xds/xds_channel_stack_modifier.cc +14 -17
  668. data/src/core/ext/xds/xds_channel_stack_modifier.h +4 -3
  669. data/src/core/ext/xds/xds_client.cc +220 -193
  670. data/src/core/ext/xds/xds_client.h +35 -19
  671. data/src/core/ext/xds/xds_client_stats.cc +15 -15
  672. data/src/core/ext/xds/xds_client_stats.h +5 -4
  673. data/src/core/ext/xds/xds_cluster.cc +18 -16
  674. data/src/core/ext/xds/xds_cluster.h +3 -6
  675. data/src/core/ext/xds/xds_cluster_specifier_plugin.cc +142 -0
  676. data/src/core/ext/xds/xds_cluster_specifier_plugin.h +79 -0
  677. data/src/core/ext/xds/xds_common_types.cc +10 -10
  678. data/src/core/ext/xds/xds_common_types.h +8 -23
  679. data/src/core/ext/xds/xds_endpoint.cc +14 -7
  680. data/src/core/ext/xds/xds_endpoint.h +1 -1
  681. data/src/core/ext/xds/xds_http_fault_filter.cc +7 -7
  682. data/src/core/ext/xds/xds_http_fault_filter.h +3 -3
  683. data/src/core/ext/xds/xds_http_filters.cc +6 -5
  684. data/src/core/ext/xds/xds_http_filters.h +4 -4
  685. data/src/core/ext/xds/xds_http_rbac_filter.cc +5 -5
  686. data/src/core/ext/xds/xds_http_rbac_filter.h +3 -3
  687. data/src/core/ext/xds/xds_listener.cc +15 -12
  688. data/src/core/ext/xds/xds_listener.h +1 -1
  689. data/src/core/ext/xds/xds_resource_type.h +1 -1
  690. data/src/core/ext/xds/xds_route_config.cc +175 -46
  691. data/src/core/ext/xds/xds_route_config.h +14 -11
  692. data/src/core/ext/xds/xds_routing.cc +1 -1
  693. data/src/core/ext/xds/xds_server_config_fetcher.cc +20 -24
  694. data/src/core/lib/avl/avl.h +68 -5
  695. data/src/core/lib/backoff/backoff.cc +7 -10
  696. data/src/core/lib/backoff/backoff.h +8 -8
  697. data/src/core/lib/channel/call_finalization.h +86 -0
  698. data/src/core/lib/channel/call_tracer.h +4 -1
  699. data/src/core/lib/channel/channel_args.cc +161 -22
  700. data/src/core/lib/channel/channel_args.h +210 -7
  701. data/src/core/lib/channel/channel_args_preconditioning.cc +3 -8
  702. data/src/core/lib/channel/channel_args_preconditioning.h +1 -2
  703. data/src/core/lib/channel/channel_stack.cc +2 -3
  704. data/src/core/lib/channel/channel_stack.h +38 -5
  705. data/src/core/lib/channel/channel_stack_builder.cc +23 -266
  706. data/src/core/lib/channel/channel_stack_builder.h +118 -146
  707. data/src/core/lib/channel/channel_stack_builder_impl.cc +102 -0
  708. data/src/core/lib/channel/channel_stack_builder_impl.h +48 -0
  709. data/src/core/lib/channel/channel_trace.cc +3 -6
  710. data/src/core/lib/channel/connected_channel.cc +9 -4
  711. data/src/core/lib/channel/connected_channel.h +2 -1
  712. data/src/core/lib/channel/context.h +11 -0
  713. data/src/core/lib/channel/handshaker.cc +1 -1
  714. data/src/core/lib/channel/handshaker.h +1 -1
  715. data/src/core/lib/channel/promise_based_filter.cc +1002 -0
  716. data/src/core/lib/channel/promise_based_filter.h +437 -0
  717. data/src/core/lib/compression/compression.cc +1 -1
  718. data/src/core/lib/compression/compression_internal.cc +2 -8
  719. data/src/core/lib/config/core_configuration.cc +8 -2
  720. data/src/core/lib/config/core_configuration.h +39 -0
  721. data/src/core/lib/debug/stats_data.cc +2 -6
  722. data/src/core/lib/debug/stats_data.h +18 -21
  723. data/src/core/{ext/filters/max_age/max_age_filter.h → lib/event_engine/default_event_engine_factory.cc} +11 -10
  724. data/src/core/lib/event_engine/event_engine.cc +23 -8
  725. data/src/core/lib/event_engine/event_engine_factory.h +3 -0
  726. data/src/core/lib/event_engine/memory_allocator.cc +9 -13
  727. data/src/core/lib/event_engine/{event_engine_factory.cc → resolved_address.cc} +10 -20
  728. data/src/core/lib/gpr/sync_posix.cc +1 -0
  729. data/src/core/lib/gpr/time.cc +2 -1
  730. data/src/core/lib/gpr/tls.h +1 -0
  731. data/src/core/lib/gpr/useful.h +14 -0
  732. data/src/core/lib/gprpp/bitset.h +12 -0
  733. data/src/core/lib/gprpp/capture.h +76 -0
  734. data/src/core/lib/gprpp/cpp_impl_of.h +4 -0
  735. data/src/core/lib/gprpp/debug_location.h +2 -0
  736. data/src/core/lib/gprpp/match.h +73 -0
  737. data/src/core/lib/gprpp/overload.h +59 -0
  738. data/src/core/lib/gprpp/ref_counted.h +2 -0
  739. data/src/core/lib/gprpp/single_set_ptr.h +87 -0
  740. data/src/core/lib/gprpp/status_helper.cc +30 -14
  741. data/src/core/lib/gprpp/status_helper.h +4 -4
  742. data/src/core/lib/gprpp/time.cc +198 -0
  743. data/src/core/lib/gprpp/time.h +292 -0
  744. data/src/core/lib/http/format_request.cc +28 -25
  745. data/src/core/lib/http/format_request.h +7 -6
  746. data/src/core/lib/http/httpcli.cc +306 -229
  747. data/src/core/lib/http/httpcli.h +182 -77
  748. data/src/core/lib/http/httpcli_security_connector.cc +64 -75
  749. data/src/core/lib/http/httpcli_ssl_credentials.h +37 -0
  750. data/src/core/lib/http/parser.cc +80 -9
  751. data/src/core/lib/http/parser.h +15 -2
  752. data/src/core/lib/iomgr/buffer_list.h +5 -5
  753. data/src/core/lib/iomgr/error.cc +13 -12
  754. data/src/core/lib/iomgr/error.h +0 -5
  755. data/src/core/lib/iomgr/ev_apple.cc +6 -5
  756. data/src/core/lib/iomgr/ev_epoll1_linux.cc +8 -7
  757. data/src/core/lib/iomgr/ev_poll_posix.cc +7 -7
  758. data/src/core/lib/iomgr/ev_posix.cc +9 -10
  759. data/src/core/lib/iomgr/ev_posix.h +1 -1
  760. data/src/core/lib/iomgr/event_engine/pollset.cc +2 -3
  761. data/src/core/lib/iomgr/event_engine/resolver.cc +1 -1
  762. data/src/core/lib/iomgr/event_engine/tcp.cc +4 -3
  763. data/src/core/lib/iomgr/event_engine/timer.cc +3 -4
  764. data/src/core/lib/iomgr/exec_ctx.cc +3 -88
  765. data/src/core/lib/iomgr/exec_ctx.h +7 -23
  766. data/src/core/lib/iomgr/fork_posix.cc +1 -1
  767. data/src/core/lib/iomgr/iocp_windows.cc +9 -9
  768. data/src/core/lib/iomgr/iocp_windows.h +1 -1
  769. data/src/core/lib/iomgr/polling_entity.h +6 -0
  770. data/src/core/lib/iomgr/pollset.cc +1 -1
  771. data/src/core/lib/iomgr/pollset.h +4 -4
  772. data/src/core/lib/iomgr/pollset_windows.cc +2 -2
  773. data/src/core/lib/iomgr/port.h +4 -9
  774. data/src/core/lib/iomgr/resolve_address_posix.cc +1 -1
  775. data/src/core/lib/iomgr/sockaddr_utils_posix.cc +62 -0
  776. data/src/core/lib/iomgr/socket_utils_common_posix.cc +0 -17
  777. data/src/core/lib/iomgr/tcp_client.cc +1 -1
  778. data/src/core/lib/iomgr/tcp_client.h +3 -2
  779. data/src/core/lib/iomgr/tcp_client_cfstream.cc +1 -1
  780. data/src/core/lib/iomgr/tcp_client_posix.cc +4 -4
  781. data/src/core/lib/iomgr/tcp_client_posix.h +1 -1
  782. data/src/core/lib/iomgr/tcp_client_windows.cc +1 -1
  783. data/src/core/lib/iomgr/tcp_posix.cc +95 -36
  784. data/src/core/lib/iomgr/tcp_server_posix.cc +26 -17
  785. data/src/core/lib/iomgr/tcp_windows.cc +17 -10
  786. data/src/core/lib/iomgr/timer.cc +2 -2
  787. data/src/core/lib/iomgr/timer.h +11 -6
  788. data/src/core/lib/iomgr/timer_generic.cc +96 -77
  789. data/src/core/lib/iomgr/timer_manager.cc +15 -14
  790. data/src/core/lib/iomgr/work_serializer.cc +15 -10
  791. data/src/core/lib/json/json_util.cc +4 -4
  792. data/src/core/lib/json/json_util.h +5 -5
  793. data/src/core/lib/promise/activity.cc +14 -8
  794. data/src/core/lib/promise/activity.h +143 -131
  795. data/src/core/lib/promise/arena_promise.h +188 -0
  796. data/src/core/lib/promise/call_push_pull.h +144 -0
  797. data/src/core/lib/promise/detail/basic_seq.h +92 -3
  798. data/src/core/lib/promise/detail/promise_factory.h +1 -1
  799. data/src/core/lib/promise/detail/status.h +2 -1
  800. data/src/core/lib/promise/intra_activity_waiter.h +49 -0
  801. data/src/core/lib/promise/latch.h +104 -0
  802. data/src/core/lib/promise/loop.h +34 -8
  803. data/src/core/lib/promise/poll.h +6 -0
  804. data/src/core/lib/promise/promise.h +95 -0
  805. data/src/core/lib/promise/seq.h +19 -1
  806. data/src/core/lib/promise/sleep.cc +74 -0
  807. data/src/core/lib/promise/sleep.h +66 -0
  808. data/src/core/lib/promise/try_seq.h +157 -0
  809. data/src/core/lib/resolver/resolver_factory.h +22 -26
  810. data/src/core/lib/resolver/resolver_registry.cc +98 -137
  811. data/src/core/lib/resolver/resolver_registry.h +59 -33
  812. data/src/core/lib/resource_quota/api.cc +5 -30
  813. data/src/core/lib/resource_quota/api.h +1 -1
  814. data/src/core/lib/resource_quota/memory_quota.cc +118 -94
  815. data/src/core/lib/resource_quota/memory_quota.h +100 -64
  816. data/src/core/lib/resource_quota/resource_quota.h +8 -0
  817. data/src/core/lib/security/authorization/authorization_policy_provider.h +7 -0
  818. data/src/core/lib/security/authorization/evaluate_args.cc +1 -11
  819. data/src/core/lib/security/authorization/evaluate_args.h +0 -1
  820. data/src/core/lib/security/authorization/grpc_server_authz_filter.cc +106 -0
  821. data/src/core/lib/security/authorization/grpc_server_authz_filter.h +50 -0
  822. data/src/core/lib/security/authorization/matchers.cc +5 -5
  823. data/src/core/lib/security/authorization/matchers.h +2 -2
  824. data/src/core/lib/security/authorization/rbac_policy.cc +3 -3
  825. data/src/core/lib/security/authorization/rbac_policy.h +3 -2
  826. data/src/core/lib/security/context/security_context.h +8 -1
  827. data/src/core/lib/security/credentials/alts/alts_credentials.cc +6 -5
  828. data/src/core/lib/security/credentials/alts/alts_credentials.h +10 -0
  829. data/src/core/lib/security/credentials/call_creds_util.cc +87 -0
  830. data/src/core/lib/security/credentials/call_creds_util.h +42 -0
  831. data/src/core/lib/security/credentials/channel_creds_registry.h +97 -0
  832. data/src/core/lib/security/credentials/channel_creds_registry_init.cc +70 -0
  833. data/src/core/lib/security/credentials/composite/composite_credentials.cc +24 -83
  834. data/src/core/lib/security/credentials/composite/composite_credentials.h +23 -11
  835. data/src/core/lib/security/credentials/credentials.cc +2 -3
  836. data/src/core/lib/security/credentials/credentials.h +70 -66
  837. data/src/core/lib/security/credentials/external/aws_external_account_credentials.cc +46 -27
  838. data/src/core/lib/security/credentials/external/aws_external_account_credentials.h +1 -0
  839. data/src/core/lib/security/credentials/external/external_account_credentials.cc +49 -29
  840. data/src/core/lib/security/credentials/external/external_account_credentials.h +4 -3
  841. data/src/core/lib/security/credentials/external/file_external_account_credentials.cc +0 -1
  842. data/src/core/lib/security/credentials/external/url_external_account_credentials.cc +33 -12
  843. data/src/core/lib/security/credentials/external/url_external_account_credentials.h +1 -0
  844. data/src/core/lib/security/credentials/fake/fake_credentials.cc +23 -28
  845. data/src/core/lib/security/credentials/fake/fake_credentials.h +16 -16
  846. data/src/core/lib/security/credentials/google_default/google_default_credentials.cc +19 -9
  847. data/src/core/lib/security/credentials/google_default/google_default_credentials.h +9 -3
  848. data/src/core/lib/security/credentials/iam/iam_credentials.cc +15 -19
  849. data/src/core/lib/security/credentials/iam/iam_credentials.h +14 -9
  850. data/src/core/lib/security/credentials/insecure/insecure_credentials.cc +25 -26
  851. data/src/core/lib/security/credentials/insecure/insecure_credentials.h +57 -0
  852. data/src/core/lib/security/credentials/jwt/jwt_credentials.cc +23 -23
  853. data/src/core/lib/security/credentials/jwt/jwt_credentials.h +13 -9
  854. data/src/core/lib/security/credentials/jwt/jwt_verifier.cc +50 -30
  855. data/src/core/lib/security/credentials/jwt/jwt_verifier.h +1 -1
  856. data/src/core/lib/security/credentials/local/local_credentials.cc +6 -6
  857. data/src/core/lib/security/credentials/local/local_credentials.h +10 -0
  858. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.cc +128 -128
  859. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.h +57 -28
  860. data/src/core/lib/security/credentials/plugin/plugin_credentials.cc +96 -151
  861. data/src/core/lib/security/credentials/plugin/plugin_credentials.h +56 -28
  862. data/src/core/lib/security/credentials/ssl/ssl_credentials.cc +6 -4
  863. data/src/core/lib/security/credentials/ssl/ssl_credentials.h +14 -3
  864. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.h +49 -0
  865. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_verifier.cc +8 -0
  866. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_verifier.h +42 -3
  867. data/src/core/lib/security/credentials/tls/grpc_tls_credentials_options.cc +19 -0
  868. data/src/core/lib/security/credentials/tls/grpc_tls_credentials_options.h +66 -86
  869. data/src/core/lib/security/credentials/tls/tls_credentials.cc +9 -6
  870. data/src/core/lib/security/credentials/tls/tls_credentials.h +6 -0
  871. data/src/core/lib/security/credentials/xds/xds_credentials.cc +48 -50
  872. data/src/core/lib/security/credentials/xds/xds_credentials.h +36 -5
  873. data/src/core/lib/security/security_connector/alts/alts_security_connector.cc +8 -14
  874. data/src/core/lib/security/security_connector/alts/alts_security_connector.h +1 -1
  875. data/src/core/lib/security/security_connector/fake/fake_security_connector.cc +4 -12
  876. data/src/core/lib/security/security_connector/fake/fake_security_connector.h +0 -2
  877. data/src/core/lib/security/security_connector/insecure/insecure_security_connector.cc +6 -16
  878. data/src/core/lib/security/security_connector/insecure/insecure_security_connector.h +4 -9
  879. data/src/core/lib/security/security_connector/local/local_security_connector.cc +10 -18
  880. data/src/core/lib/security/security_connector/security_connector.cc +3 -11
  881. data/src/core/lib/security/security_connector/security_connector.h +20 -20
  882. data/src/core/lib/security/security_connector/ssl/ssl_security_connector.cc +10 -13
  883. data/src/core/lib/security/security_connector/ssl_utils.cc +15 -7
  884. data/src/core/lib/security/security_connector/ssl_utils.h +8 -3
  885. data/src/core/lib/security/security_connector/tls/tls_security_connector.cc +27 -16
  886. data/src/core/lib/security/security_connector/tls/tls_security_connector.h +6 -6
  887. data/src/core/lib/security/transport/auth_filters.h +31 -5
  888. data/src/core/lib/security/transport/client_auth_filter.cc +90 -373
  889. data/src/core/lib/security/transport/secure_endpoint.cc +198 -129
  890. data/src/core/lib/security/transport/secure_endpoint.h +1 -1
  891. data/src/core/lib/security/transport/security_handshaker.cc +20 -10
  892. data/src/core/lib/security/transport/server_auth_filter.cc +1 -0
  893. data/src/core/lib/service_config/service_config.h +6 -51
  894. data/src/core/lib/service_config/{service_config.cc → service_config_impl.cc} +19 -16
  895. data/src/core/lib/service_config/service_config_impl.h +125 -0
  896. data/src/core/lib/service_config/service_config_parser.cc +30 -26
  897. data/src/core/lib/service_config/service_config_parser.h +36 -27
  898. data/src/core/lib/slice/slice.cc +76 -181
  899. data/src/core/lib/slice/slice.h +28 -15
  900. data/src/core/lib/slice/slice_internal.h +12 -30
  901. data/src/core/lib/slice/slice_refcount.cc +18 -0
  902. data/src/core/lib/slice/slice_refcount.h +2 -72
  903. data/src/core/lib/slice/slice_refcount_base.h +16 -120
  904. data/src/core/lib/surface/builtins.cc +6 -6
  905. data/src/core/lib/surface/call.cc +1026 -899
  906. data/src/core/lib/surface/call.h +1 -15
  907. data/src/core/lib/surface/channel.cc +28 -32
  908. data/src/core/lib/surface/channel.h +6 -7
  909. data/src/core/lib/surface/channel_init.cc +2 -3
  910. data/src/core/lib/surface/channel_init.h +3 -7
  911. data/src/core/lib/surface/completion_queue.cc +10 -9
  912. data/src/core/lib/surface/init.cc +78 -7
  913. data/src/core/lib/surface/init.h +0 -2
  914. data/src/core/lib/surface/lame_client.cc +2 -1
  915. data/src/core/lib/surface/server.cc +14 -36
  916. data/src/core/lib/surface/server.h +4 -5
  917. data/src/core/lib/surface/version.cc +2 -2
  918. data/src/core/lib/transport/bdp_estimator.cc +9 -10
  919. data/src/core/lib/transport/bdp_estimator.h +2 -2
  920. data/src/core/lib/transport/byte_stream.cc +2 -0
  921. data/src/core/lib/transport/error_utils.cc +5 -3
  922. data/src/core/lib/transport/error_utils.h +2 -15
  923. data/src/core/lib/transport/metadata_batch.h +286 -104
  924. data/src/core/lib/transport/parsed_metadata.h +33 -17
  925. data/src/core/lib/transport/status_conversion.cc +2 -2
  926. data/src/core/lib/transport/status_conversion.h +1 -1
  927. data/src/core/lib/transport/timeout_encoding.cc +32 -29
  928. data/src/core/lib/transport/timeout_encoding.h +3 -3
  929. data/src/core/lib/transport/transport.cc +3 -1
  930. data/src/core/lib/transport/transport.h +102 -2
  931. data/src/core/lib/transport/transport_impl.h +14 -0
  932. data/src/core/lib/transport/transport_op_string.cc +5 -14
  933. data/src/core/lib/uri/uri_parser.cc +4 -0
  934. data/src/core/lib/uri/uri_parser.h +1 -0
  935. data/src/core/plugin_registry/grpc_plugin_registry.cc +21 -92
  936. data/src/core/plugin_registry/grpc_plugin_registry_extra.cc +85 -0
  937. data/src/core/tsi/alts/handshaker/alts_handshaker_client.cc +26 -21
  938. data/src/core/tsi/alts/handshaker/alts_shared_resource.cc +9 -1
  939. data/src/core/tsi/alts/handshaker/alts_tsi_handshaker.cc +21 -13
  940. data/src/core/tsi/alts/handshaker/alts_tsi_utils.cc +2 -2
  941. data/src/core/tsi/alts/handshaker/alts_tsi_utils.h +1 -1
  942. data/src/core/tsi/alts/handshaker/transport_security_common_api.cc +2 -2
  943. data/src/core/tsi/alts/handshaker/transport_security_common_api.h +2 -2
  944. data/src/core/tsi/local_transport_security.cc +3 -11
  945. data/src/core/tsi/local_transport_security.h +1 -4
  946. data/src/core/tsi/ssl/key_logging/ssl_key_logging.cc +141 -0
  947. data/src/core/tsi/ssl/key_logging/ssl_key_logging.h +81 -0
  948. data/src/core/tsi/ssl_transport_security.cc +127 -39
  949. data/src/core/tsi/ssl_transport_security.h +28 -2
  950. data/src/core/tsi/transport_security_interface.h +2 -0
  951. data/src/ruby/ext/grpc/extconf.rb +1 -1
  952. data/src/ruby/ext/grpc/rb_channel.c +5 -2
  953. data/src/ruby/ext/grpc/rb_grpc_imports.generated.c +18 -24
  954. data/src/ruby/ext/grpc/rb_grpc_imports.generated.h +27 -36
  955. data/src/ruby/ext/grpc/rb_server.c +7 -4
  956. data/src/ruby/lib/grpc/generic/active_call.rb +7 -1
  957. data/src/ruby/lib/grpc/grpc.rb +1 -1
  958. data/src/ruby/lib/grpc/version.rb +1 -1
  959. data/src/ruby/pb/generate_proto_ruby.sh +1 -0
  960. data/src/ruby/pb/test/client.rb +769 -0
  961. data/src/ruby/pb/test/server.rb +252 -0
  962. data/src/ruby/pb/test/xds_client.rb +415 -0
  963. data/third_party/cares/cares/{ares.h → include/ares.h} +73 -1
  964. data/third_party/cares/cares/{ares_dns.h → include/ares_dns.h} +9 -0
  965. data/third_party/cares/cares/{ares_rules.h → include/ares_rules.h} +0 -0
  966. data/third_party/cares/cares/{ares_version.h → include/ares_version.h} +3 -3
  967. data/third_party/cares/cares/{ares__close_sockets.c → src/lib/ares__close_sockets.c} +2 -2
  968. data/third_party/cares/cares/{ares__get_hostent.c → src/lib/ares__get_hostent.c} +1 -2
  969. data/third_party/cares/cares/src/lib/ares__parse_into_addrinfo.c +260 -0
  970. data/third_party/cares/cares/{ares__read_line.c → src/lib/ares__read_line.c} +0 -0
  971. data/third_party/cares/cares/src/lib/ares__readaddrinfo.c +264 -0
  972. data/third_party/cares/cares/src/lib/ares__sortaddrinfo.c +499 -0
  973. data/third_party/cares/cares/{ares__timeval.c → src/lib/ares__timeval.c} +0 -0
  974. data/third_party/cares/cares/src/lib/ares_android.c +444 -0
  975. data/third_party/cares/cares/src/lib/ares_android.h +27 -0
  976. data/third_party/cares/cares/{ares_cancel.c → src/lib/ares_cancel.c} +0 -0
  977. data/third_party/cares/cares/{ares_create_query.c → src/lib/ares_create_query.c} +8 -17
  978. data/third_party/cares/cares/{ares_data.c → src/lib/ares_data.c} +18 -0
  979. data/third_party/cares/cares/{ares_data.h → src/lib/ares_data.h} +2 -0
  980. data/third_party/cares/cares/{ares_destroy.c → src/lib/ares_destroy.c} +0 -0
  981. data/third_party/cares/cares/{ares_expand_name.c → src/lib/ares_expand_name.c} +114 -23
  982. data/third_party/cares/cares/{ares_expand_string.c → src/lib/ares_expand_string.c} +2 -5
  983. data/third_party/cares/cares/{ares_fds.c → src/lib/ares_fds.c} +0 -0
  984. data/third_party/cares/cares/{ares_free_hostent.c → src/lib/ares_free_hostent.c} +6 -4
  985. data/third_party/cares/cares/{ares_free_string.c → src/lib/ares_free_string.c} +0 -0
  986. data/third_party/cares/cares/src/lib/ares_freeaddrinfo.c +59 -0
  987. data/third_party/cares/cares/src/lib/ares_getaddrinfo.c +772 -0
  988. data/third_party/cares/cares/{ares_getenv.c → src/lib/ares_getenv.c} +0 -2
  989. data/third_party/cares/cares/{ares_getenv.h → src/lib/ares_getenv.h} +0 -0
  990. data/third_party/cares/cares/{ares_gethostbyaddr.c → src/lib/ares_gethostbyaddr.c} +2 -9
  991. data/third_party/cares/cares/{ares_gethostbyname.c → src/lib/ares_gethostbyname.c} +25 -20
  992. data/third_party/cares/cares/{ares_getnameinfo.c → src/lib/ares_getnameinfo.c} +4 -10
  993. data/third_party/cares/cares/{ares_getsock.c → src/lib/ares_getsock.c} +0 -0
  994. data/third_party/cares/cares/{ares_inet_net_pton.h → src/lib/ares_inet_net_pton.h} +0 -0
  995. data/third_party/cares/cares/{ares_init.c → src/lib/ares_init.c} +79 -40
  996. data/third_party/cares/cares/{ares_iphlpapi.h → src/lib/ares_iphlpapi.h} +0 -0
  997. data/third_party/cares/cares/{ares_ipv6.h → src/lib/ares_ipv6.h} +7 -0
  998. data/third_party/cares/cares/{ares_library_init.c → src/lib/ares_library_init.c} +7 -2
  999. data/third_party/cares/cares/{ares_library_init.h → src/lib/ares_library_init.h} +1 -1
  1000. data/third_party/cares/cares/{ares_llist.c → src/lib/ares_llist.c} +0 -0
  1001. data/third_party/cares/cares/{ares_llist.h → src/lib/ares_llist.h} +0 -0
  1002. data/third_party/cares/cares/{ares_mkquery.c → src/lib/ares_mkquery.c} +0 -0
  1003. data/third_party/cares/cares/src/lib/ares_nameser.h +482 -0
  1004. data/third_party/cares/cares/{ares_nowarn.c → src/lib/ares_nowarn.c} +0 -0
  1005. data/third_party/cares/cares/{ares_nowarn.h → src/lib/ares_nowarn.h} +0 -0
  1006. data/third_party/cares/cares/{ares_options.c → src/lib/ares_options.c} +0 -0
  1007. data/third_party/cares/cares/src/lib/ares_parse_a_reply.c +209 -0
  1008. data/third_party/cares/cares/src/lib/ares_parse_aaaa_reply.c +212 -0
  1009. data/third_party/cares/cares/src/lib/ares_parse_caa_reply.c +199 -0
  1010. data/third_party/cares/cares/{ares_parse_mx_reply.c → src/lib/ares_parse_mx_reply.c} +2 -8
  1011. data/third_party/cares/cares/{ares_parse_naptr_reply.c → src/lib/ares_parse_naptr_reply.c} +2 -13
  1012. data/third_party/cares/cares/{ares_parse_ns_reply.c → src/lib/ares_parse_ns_reply.c} +5 -11
  1013. data/third_party/cares/cares/{ares_parse_ptr_reply.c → src/lib/ares_parse_ptr_reply.c} +53 -46
  1014. data/third_party/cares/cares/src/lib/ares_parse_soa_reply.c +179 -0
  1015. data/third_party/cares/cares/{ares_parse_srv_reply.c → src/lib/ares_parse_srv_reply.c} +2 -13
  1016. data/third_party/cares/cares/{ares_parse_txt_reply.c → src/lib/ares_parse_txt_reply.c} +3 -9
  1017. data/third_party/cares/cares/{ares_platform.c → src/lib/ares_platform.c} +0 -0
  1018. data/third_party/cares/cares/{ares_platform.h → src/lib/ares_platform.h} +0 -0
  1019. data/third_party/cares/cares/{ares_private.h → src/lib/ares_private.h} +52 -11
  1020. data/third_party/cares/cares/{ares_process.c → src/lib/ares_process.c} +127 -52
  1021. data/third_party/cares/cares/{ares_query.c → src/lib/ares_query.c} +3 -9
  1022. data/third_party/cares/cares/{ares_search.c → src/lib/ares_search.c} +5 -7
  1023. data/third_party/cares/cares/{ares_send.c → src/lib/ares_send.c} +2 -8
  1024. data/third_party/cares/cares/{ares_setup.h → src/lib/ares_setup.h} +4 -1
  1025. data/third_party/cares/cares/{ares_strcasecmp.c → src/lib/ares_strcasecmp.c} +0 -0
  1026. data/third_party/cares/cares/{ares_strcasecmp.h → src/lib/ares_strcasecmp.h} +0 -0
  1027. data/third_party/cares/cares/{ares_strdup.c → src/lib/ares_strdup.c} +0 -0
  1028. data/third_party/cares/cares/{ares_strdup.h → src/lib/ares_strdup.h} +0 -0
  1029. data/third_party/cares/cares/{ares_strerror.c → src/lib/ares_strerror.c} +0 -0
  1030. data/third_party/cares/cares/{ares_strsplit.c → src/lib/ares_strsplit.c} +4 -0
  1031. data/third_party/cares/cares/{ares_strsplit.h → src/lib/ares_strsplit.h} +0 -0
  1032. data/third_party/cares/cares/{ares_timeout.c → src/lib/ares_timeout.c} +0 -0
  1033. data/third_party/cares/cares/{ares_version.c → src/lib/ares_version.c} +0 -0
  1034. data/third_party/cares/cares/{ares_writev.c → src/lib/ares_writev.c} +0 -0
  1035. data/third_party/cares/cares/src/lib/ares_writev.h +36 -0
  1036. data/third_party/cares/cares/{bitncmp.c → src/lib/bitncmp.c} +0 -0
  1037. data/third_party/cares/cares/{bitncmp.h → src/lib/bitncmp.h} +0 -0
  1038. data/third_party/cares/cares/src/lib/config-dos.h +115 -0
  1039. data/third_party/cares/cares/{config-win32.h → src/lib/config-win32.h} +0 -0
  1040. data/third_party/cares/cares/{inet_net_pton.c → src/lib/inet_net_pton.c} +2 -8
  1041. data/third_party/cares/cares/{inet_ntop.c → src/lib/inet_ntop.c} +2 -8
  1042. data/third_party/cares/cares/{setup_once.h → src/lib/setup_once.h} +0 -0
  1043. data/third_party/cares/cares/{windows_port.c → src/lib/windows_port.c} +0 -0
  1044. data/third_party/upb/third_party/utf8_range/naive.c +92 -0
  1045. data/third_party/upb/third_party/utf8_range/range2-neon.c +157 -0
  1046. data/third_party/upb/third_party/utf8_range/range2-sse.c +170 -0
  1047. data/third_party/upb/third_party/utf8_range/utf8_range.h +9 -0
  1048. data/third_party/upb/upb/decode.c +542 -319
  1049. data/third_party/upb/upb/decode.h +43 -17
  1050. data/third_party/upb/upb/decode_fast.c +303 -301
  1051. data/third_party/upb/upb/decode_fast.h +18 -18
  1052. data/third_party/upb/upb/decode_internal.h +73 -56
  1053. data/third_party/upb/upb/def.c +1926 -1078
  1054. data/third_party/upb/upb/def.h +329 -288
  1055. data/third_party/upb/upb/def.hpp +129 -172
  1056. data/third_party/upb/upb/encode.c +208 -175
  1057. data/third_party/upb/upb/encode.h +15 -17
  1058. data/third_party/upb/upb/json_encode.c +776 -0
  1059. data/third_party/upb/upb/json_encode.h +62 -0
  1060. data/third_party/upb/upb/msg.c +142 -124
  1061. data/third_party/upb/upb/msg.h +39 -33
  1062. data/third_party/upb/upb/msg_internal.h +342 -280
  1063. data/third_party/upb/upb/port_def.inc +8 -0
  1064. data/third_party/upb/upb/port_undef.inc +1 -0
  1065. data/third_party/upb/upb/reflection.c +239 -199
  1066. data/third_party/upb/upb/reflection.h +87 -67
  1067. data/third_party/upb/upb/reflection.hpp +6 -6
  1068. data/third_party/upb/upb/table.c +231 -147
  1069. data/third_party/upb/upb/table_internal.h +129 -95
  1070. data/third_party/upb/upb/text_encode.c +113 -90
  1071. data/third_party/upb/upb/text_encode.h +10 -10
  1072. data/third_party/upb/upb/upb.c +111 -72
  1073. data/third_party/upb/upb/upb.h +157 -151
  1074. data/third_party/upb/upb/upb.hpp +31 -28
  1075. data/third_party/upb/upb/upb_internal.h +21 -11
  1076. data/third_party/zlib/crc32.c +966 -292
  1077. data/third_party/zlib/crc32.h +9441 -436
  1078. data/third_party/zlib/deflate.c +78 -30
  1079. data/third_party/zlib/deflate.h +12 -15
  1080. data/third_party/zlib/gzguts.h +3 -2
  1081. data/third_party/zlib/gzlib.c +5 -3
  1082. data/third_party/zlib/gzread.c +5 -7
  1083. data/third_party/zlib/gzwrite.c +25 -13
  1084. data/third_party/zlib/infback.c +2 -1
  1085. data/third_party/zlib/inffast.c +14 -14
  1086. data/third_party/zlib/inflate.c +39 -8
  1087. data/third_party/zlib/inflate.h +3 -2
  1088. data/third_party/zlib/inftrees.c +3 -3
  1089. data/third_party/zlib/trees.c +27 -48
  1090. data/third_party/zlib/zlib.h +123 -100
  1091. data/third_party/zlib/zutil.c +2 -2
  1092. data/third_party/zlib/zutil.h +12 -9
  1093. metadata +337 -185
  1094. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_channel.h +0 -44
  1095. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_channel_secure.cc +0 -83
  1096. data/src/core/ext/filters/client_idle/client_idle_filter.cc +0 -264
  1097. data/src/core/ext/filters/max_age/max_age_filter.cc +0 -560
  1098. data/src/core/ext/transport/chttp2/client/insecure/channel_create.cc +0 -122
  1099. data/src/core/ext/transport/chttp2/client/insecure/channel_create_posix.cc +0 -92
  1100. data/src/core/ext/transport/chttp2/client/secure/secure_channel_create.cc +0 -192
  1101. data/src/core/ext/transport/chttp2/server/insecure/server_chttp2.cc +0 -52
  1102. data/src/core/ext/transport/chttp2/server/insecure/server_chttp2_posix.cc +0 -79
  1103. data/src/core/ext/transport/chttp2/server/secure/server_secure_chttp2.cc +0 -125
  1104. data/src/core/ext/transport/chttp2/transport/chttp2_plugin.cc +0 -36
  1105. data/src/core/ext/upb-generated/envoy/service/cluster/v3/cds.upb.c +0 -38
  1106. data/src/core/ext/upb-generated/envoy/service/cluster/v3/cds.upb.h +0 -64
  1107. data/src/core/ext/upb-generated/envoy/service/endpoint/v3/eds.upb.c +0 -38
  1108. data/src/core/ext/upb-generated/envoy/service/endpoint/v3/eds.upb.h +0 -64
  1109. data/src/core/ext/upb-generated/envoy/service/listener/v3/lds.upb.c +0 -38
  1110. data/src/core/ext/upb-generated/envoy/service/listener/v3/lds.upb.h +0 -64
  1111. data/src/core/ext/upb-generated/envoy/service/route/v3/rds.upb.c +0 -38
  1112. data/src/core/ext/upb-generated/envoy/service/route/v3/rds.upb.h +0 -64
  1113. data/src/core/ext/upb-generated/envoy/service/route/v3/srds.upb.c +0 -38
  1114. data/src/core/ext/upb-generated/envoy/service/route/v3/srds.upb.h +0 -64
  1115. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/eval.upb.c +0 -102
  1116. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/eval.upb.h +0 -306
  1117. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/explain.upb.c +0 -56
  1118. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/explain.upb.h +0 -135
  1119. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/value.upb.c +0 -115
  1120. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/value.upb.h +0 -371
  1121. data/src/core/ext/upbdefs-generated/envoy/service/cluster/v3/cds.upbdefs.c +0 -67
  1122. data/src/core/ext/upbdefs-generated/envoy/service/cluster/v3/cds.upbdefs.h +0 -35
  1123. data/src/core/ext/upbdefs-generated/envoy/service/endpoint/v3/eds.upbdefs.c +0 -68
  1124. data/src/core/ext/upbdefs-generated/envoy/service/endpoint/v3/eds.upbdefs.h +0 -35
  1125. data/src/core/ext/upbdefs-generated/envoy/service/listener/v3/lds.upbdefs.c +0 -67
  1126. data/src/core/ext/upbdefs-generated/envoy/service/listener/v3/lds.upbdefs.h +0 -35
  1127. data/src/core/ext/upbdefs-generated/envoy/service/route/v3/rds.upbdefs.c +0 -75
  1128. data/src/core/ext/upbdefs-generated/envoy/service/route/v3/rds.upbdefs.h +0 -35
  1129. data/src/core/ext/upbdefs-generated/envoy/service/route/v3/srds.upbdefs.c +0 -69
  1130. data/src/core/ext/upbdefs-generated/envoy/service/route/v3/srds.upbdefs.h +0 -35
  1131. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/eval.upbdefs.c +0 -58
  1132. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/eval.upbdefs.h +0 -55
  1133. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/explain.upbdefs.c +0 -44
  1134. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/explain.upbdefs.h +0 -40
  1135. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/value.upbdefs.c +0 -75
  1136. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/value.upbdefs.h +0 -55
  1137. data/src/core/ext/xds/xds_channel_creds.cc +0 -108
  1138. data/src/core/ext/xds/xds_channel_creds.h +0 -50
  1139. data/src/core/lib/iomgr/ev_epollex_linux.cc +0 -1654
  1140. data/src/core/lib/iomgr/ev_epollex_linux.h +0 -30
  1141. data/src/core/lib/iomgr/iomgr_custom.cc +0 -82
  1142. data/src/core/lib/iomgr/iomgr_custom.h +0 -49
  1143. data/src/core/lib/iomgr/is_epollexclusive_available.cc +0 -119
  1144. data/src/core/lib/iomgr/is_epollexclusive_available.h +0 -36
  1145. data/src/core/lib/iomgr/pollset_custom.cc +0 -105
  1146. data/src/core/lib/iomgr/pollset_custom.h +0 -37
  1147. data/src/core/lib/iomgr/pollset_set_custom.cc +0 -47
  1148. data/src/core/lib/iomgr/pollset_set_custom.h +0 -26
  1149. data/src/core/lib/iomgr/resolve_address_custom.cc +0 -191
  1150. data/src/core/lib/iomgr/resolve_address_custom.h +0 -126
  1151. data/src/core/lib/iomgr/sys_epoll_wrapper.h +0 -30
  1152. data/src/core/lib/iomgr/tcp_client_custom.cc +0 -146
  1153. data/src/core/lib/iomgr/tcp_custom.cc +0 -350
  1154. data/src/core/lib/iomgr/tcp_custom.h +0 -85
  1155. data/src/core/lib/iomgr/tcp_server_custom.cc +0 -457
  1156. data/src/core/lib/iomgr/timer_custom.cc +0 -96
  1157. data/src/core/lib/iomgr/timer_custom.h +0 -43
  1158. data/src/core/lib/security/authorization/sdk_server_authz_filter.cc +0 -173
  1159. data/src/core/lib/security/authorization/sdk_server_authz_filter.h +0 -67
  1160. data/src/core/lib/slice/slice_intern.cc +0 -269
  1161. data/src/core/lib/slice/slice_utils.h +0 -200
  1162. data/src/core/lib/surface/init_secure.cc +0 -103
  1163. data/third_party/cares/cares/ares_getopt.c +0 -122
  1164. data/third_party/cares/cares/ares_getopt.h +0 -53
  1165. data/third_party/cares/cares/ares_parse_a_reply.c +0 -264
  1166. data/third_party/cares/cares/ares_parse_aaaa_reply.c +0 -264
  1167. data/third_party/cares/cares/ares_parse_soa_reply.c +0 -133
@@ -1,1654 +0,0 @@
1
- /*
2
- *
3
- * Copyright 2017 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
- #include <grpc/support/port_platform.h>
20
-
21
- #include <grpc/support/log.h>
22
-
23
- #include "src/core/lib/iomgr/port.h"
24
-
25
- /* This polling engine is only relevant on linux kernels supporting epoll() */
26
- #ifdef GRPC_LINUX_EPOLL_CREATE1
27
-
28
- #include <assert.h>
29
- #include <errno.h>
30
- #include <limits.h>
31
- #include <poll.h>
32
- #include <pthread.h>
33
- #include <string.h>
34
- #include <sys/epoll.h>
35
- #include <sys/socket.h>
36
- #include <sys/syscall.h>
37
- #include <unistd.h>
38
-
39
- #include <string>
40
-
41
- #include "absl/container/inlined_vector.h"
42
- #include "absl/strings/str_cat.h"
43
- #include "absl/strings/str_format.h"
44
-
45
- #include <grpc/support/alloc.h>
46
-
47
- #include "src/core/lib/debug/stats.h"
48
- #include "src/core/lib/gpr/spinlock.h"
49
- #include "src/core/lib/gpr/tls.h"
50
- #include "src/core/lib/gpr/useful.h"
51
- #include "src/core/lib/gprpp/manual_constructor.h"
52
- #include "src/core/lib/gprpp/ref_counted.h"
53
- #include "src/core/lib/gprpp/sync.h"
54
- #include "src/core/lib/iomgr/block_annotate.h"
55
- #include "src/core/lib/iomgr/ev_epollex_linux.h"
56
- #include "src/core/lib/iomgr/iomgr_internal.h"
57
- #include "src/core/lib/iomgr/is_epollexclusive_available.h"
58
- #include "src/core/lib/iomgr/lockfree_event.h"
59
- #include "src/core/lib/iomgr/sys_epoll_wrapper.h"
60
- #include "src/core/lib/iomgr/timer.h"
61
- #include "src/core/lib/iomgr/wakeup_fd_posix.h"
62
- #include "src/core/lib/profiling/timers.h"
63
-
64
- // debug aid: create workers on the heap (allows asan to spot
65
- // use-after-destruction)
66
- //#define GRPC_EPOLLEX_CREATE_WORKERS_ON_HEAP 1
67
-
68
- #define MAX_EPOLL_EVENTS 100
69
- #define MAX_FDS_IN_CACHE 32
70
-
71
- grpc_core::DebugOnlyTraceFlag grpc_trace_pollable_refcount(false,
72
- "pollable_refcount");
73
-
74
- /*******************************************************************************
75
- * pollable Declarations
76
- */
77
-
78
- typedef enum { PO_MULTI, PO_FD, PO_EMPTY } pollable_type;
79
-
80
- typedef struct pollable pollable;
81
-
82
- /// A pollable is something that can be polled: it has an epoll set to poll on,
83
- /// and a wakeup fd for kicks
84
- /// There are three broad types:
85
- /// - PO_EMPTY - the empty pollable, used before file descriptors are added to
86
- /// a pollset
87
- /// - PO_FD - a pollable containing only one FD - used to optimize single-fd
88
- /// pollsets (which are common with synchronous api usage)
89
- /// - PO_MULTI - a pollable containing many fds
90
- struct pollable {
91
- pollable_type type; // immutable
92
- grpc_core::RefCount refs;
93
-
94
- int epfd;
95
- grpc_wakeup_fd wakeup;
96
-
97
- // The following are relevant only for type PO_FD
98
- grpc_fd* owner_fd; // Set to the owner_fd if the type is PO_FD
99
- gpr_mu owner_orphan_mu; // Synchronizes access to owner_orphaned field
100
- bool owner_orphaned; // Is the owner fd orphaned
101
-
102
- grpc_pollset_set* pollset_set;
103
- pollable* next;
104
- pollable* prev;
105
-
106
- gpr_mu mu;
107
- grpc_pollset_worker* root_worker;
108
-
109
- int event_cursor;
110
- int event_count;
111
- struct epoll_event events[MAX_EPOLL_EVENTS];
112
- };
113
-
114
- static const char* pollable_type_string(pollable_type t) {
115
- switch (t) {
116
- case PO_MULTI:
117
- return "pollset";
118
- case PO_FD:
119
- return "fd";
120
- case PO_EMPTY:
121
- return "empty";
122
- }
123
- return "<invalid>";
124
- }
125
-
126
- static std::string pollable_desc(pollable* p) {
127
- return absl::StrFormat("type=%s epfd=%d wakeup=%d",
128
- pollable_type_string(p->type), p->epfd,
129
- p->wakeup.read_fd);
130
- }
131
-
132
- /// Shared empty pollable - used by pollset to poll on until the first fd is
133
- /// added
134
- static pollable* g_empty_pollable;
135
-
136
- static grpc_error_handle pollable_create(pollable_type type, pollable** p);
137
- static pollable* pollable_ref(pollable* p,
138
- const grpc_core::DebugLocation& dbg_loc,
139
- const char* reason) {
140
- p->refs.Ref(dbg_loc, reason);
141
- return p;
142
- }
143
- static void pollable_unref(pollable* p, const grpc_core::DebugLocation& dbg_loc,
144
- const char* reason) {
145
- if (p == nullptr) return;
146
- if (GPR_UNLIKELY(p != nullptr && p->refs.Unref(dbg_loc, reason))) {
147
- GRPC_FD_TRACE("pollable_unref: Closing epfd: %d", p->epfd);
148
- close(p->epfd);
149
- grpc_wakeup_fd_destroy(&p->wakeup);
150
- gpr_mu_destroy(&p->owner_orphan_mu);
151
- gpr_mu_destroy(&p->mu);
152
- gpr_free(p);
153
- }
154
- }
155
- #define POLLABLE_REF(p, r) pollable_ref((p), DEBUG_LOCATION, (r))
156
- #define POLLABLE_UNREF(p, r) pollable_unref((p), DEBUG_LOCATION, (r))
157
-
158
- /*******************************************************************************
159
- * Fd Declarations
160
- */
161
-
162
- struct grpc_fd {
163
- grpc_fd(int fd, const char* name, bool track_err)
164
- : fd(fd), track_err(track_err) {
165
- gpr_mu_init(&orphan_mu);
166
- gpr_mu_init(&pollable_mu);
167
- read_closure.InitEvent();
168
- write_closure.InitEvent();
169
- error_closure.InitEvent();
170
-
171
- std::string fd_name = absl::StrCat(name, " fd=", fd);
172
- grpc_iomgr_register_object(&iomgr_object, fd_name.c_str());
173
- #ifndef NDEBUG
174
- if (GRPC_TRACE_FLAG_ENABLED(grpc_trace_fd_refcount)) {
175
- gpr_log(GPR_DEBUG, "FD %d %p create %s", fd, this, fd_name.c_str());
176
- }
177
- #endif
178
- }
179
-
180
- // This is really the dtor, but the poller threads waking up from
181
- // epoll_wait() may access the (read|write|error)_closure after destruction.
182
- // Since the object will be added to the free pool, this behavior is
183
- // not going to cause issues, except spurious events if the FD is reused
184
- // while the race happens.
185
- void destroy() {
186
- grpc_iomgr_unregister_object(&iomgr_object);
187
-
188
- POLLABLE_UNREF(pollable_obj, "fd_pollable");
189
-
190
- // To clear out the allocations of pollset_fds, we need to swap its
191
- // contents with a newly-constructed (and soon to be destructed) local
192
- // variable of its same type. This is because InlinedVector::clear is _not_
193
- // guaranteed to actually free up allocations and this is important since
194
- // this object doesn't have a conventional destructor.
195
- absl::InlinedVector<int, 1> pollset_fds_tmp;
196
- pollset_fds_tmp.swap(pollset_fds);
197
-
198
- gpr_mu_destroy(&pollable_mu);
199
- gpr_mu_destroy(&orphan_mu);
200
-
201
- read_closure.DestroyEvent();
202
- write_closure.DestroyEvent();
203
- error_closure.DestroyEvent();
204
-
205
- invalidate();
206
- }
207
-
208
- #ifndef NDEBUG
209
- /* Since an fd is never really destroyed (i.e gpr_free() is not called), it is
210
- * hard-to-debug cases where fd fields are accessed even after calling
211
- * fd_destroy(). The following invalidates fd fields to make catching such
212
- * errors easier */
213
- void invalidate() {
214
- fd = -1;
215
- gpr_atm_no_barrier_store(&refst, -1);
216
- memset(&orphan_mu, -1, sizeof(orphan_mu));
217
- memset(&pollable_mu, -1, sizeof(pollable_mu));
218
- pollable_obj = nullptr;
219
- on_done_closure = nullptr;
220
- memset(&iomgr_object, -1, sizeof(iomgr_object));
221
- track_err = false;
222
- }
223
- #else
224
- void invalidate() {}
225
- #endif
226
-
227
- int fd;
228
-
229
- // refst format:
230
- // bit 0 : 1=Active / 0=Orphaned
231
- // bits 1-n : refcount
232
- // Ref/Unref by two to avoid altering the orphaned bit
233
- gpr_atm refst = 1;
234
-
235
- gpr_mu orphan_mu;
236
-
237
- // Protects pollable_obj and pollset_fds.
238
- gpr_mu pollable_mu;
239
- absl::InlinedVector<int, 1> pollset_fds; // Used in PO_MULTI.
240
- pollable* pollable_obj = nullptr; // Used in PO_FD.
241
-
242
- grpc_core::LockfreeEvent read_closure;
243
- grpc_core::LockfreeEvent write_closure;
244
- grpc_core::LockfreeEvent error_closure;
245
-
246
- struct grpc_fd* freelist_next = nullptr;
247
- grpc_closure* on_done_closure = nullptr;
248
-
249
- grpc_iomgr_object iomgr_object;
250
-
251
- // Do we need to track EPOLLERR events separately?
252
- bool track_err;
253
- };
254
-
255
- static void fd_global_init(void);
256
- static void fd_global_shutdown(void);
257
-
258
- /*******************************************************************************
259
- * Pollset Declarations
260
- */
261
-
262
- struct pwlink {
263
- grpc_pollset_worker* next;
264
- grpc_pollset_worker* prev;
265
- };
266
- typedef enum { PWLINK_POLLABLE = 0, PWLINK_POLLSET, PWLINK_COUNT } pwlinks;
267
-
268
- struct grpc_pollset_worker {
269
- bool kicked;
270
- bool initialized_cv;
271
- #ifndef NDEBUG
272
- // debug aid: which thread started this worker
273
- pid_t originator;
274
- #endif
275
- gpr_cv cv;
276
- grpc_pollset* pollset;
277
- pollable* pollable_obj;
278
-
279
- pwlink links[PWLINK_COUNT];
280
- };
281
-
282
- struct grpc_pollset {
283
- gpr_mu mu;
284
- gpr_atm worker_count;
285
- gpr_atm active_pollable_type;
286
- pollable* active_pollable;
287
- bool kicked_without_poller;
288
- grpc_closure* shutdown_closure;
289
- bool already_shutdown;
290
- grpc_pollset_worker* root_worker;
291
- int containing_pollset_set_count;
292
- };
293
-
294
- /*******************************************************************************
295
- * Pollset-set Declarations
296
- */
297
-
298
- struct grpc_pollset_set {
299
- grpc_core::RefCount refs;
300
- gpr_mu mu;
301
- grpc_pollset_set* parent;
302
-
303
- size_t pollset_count;
304
- size_t pollset_capacity;
305
- grpc_pollset** pollsets;
306
-
307
- size_t fd_count;
308
- size_t fd_capacity;
309
- grpc_fd** fds;
310
- };
311
-
312
- /*******************************************************************************
313
- * Common helpers
314
- */
315
-
316
- static bool append_error(grpc_error_handle* composite, grpc_error_handle error,
317
- const char* desc) {
318
- if (error == GRPC_ERROR_NONE) return true;
319
- if (*composite == GRPC_ERROR_NONE) {
320
- *composite = GRPC_ERROR_CREATE_FROM_COPIED_STRING(desc);
321
- }
322
- *composite = grpc_error_add_child(*composite, error);
323
- return false;
324
- }
325
-
326
- /*******************************************************************************
327
- * Fd Definitions
328
- */
329
-
330
- /* We need to keep a freelist not because of any concerns of malloc performance
331
- * but instead so that implementations with multiple threads in (for example)
332
- * epoll_wait deal with the race between pollset removal and incoming poll
333
- * notifications.
334
- *
335
- * The problem is that the poller ultimately holds a reference to this
336
- * object, so it is very difficult to know when is safe to free it, at least
337
- * without some expensive synchronization.
338
- *
339
- * If we keep the object freelisted, in the worst case losing this race just
340
- * becomes a spurious read notification on a reused fd.
341
- */
342
-
343
- static grpc_fd* fd_freelist = nullptr;
344
- static gpr_mu fd_freelist_mu;
345
-
346
- #ifndef NDEBUG
347
- #define REF_BY(fd, n, reason) ref_by(fd, n, reason, __FILE__, __LINE__)
348
- #define UNREF_BY(fd, n, reason) unref_by(fd, n, reason, __FILE__, __LINE__)
349
- static void ref_by(grpc_fd* fd, int n, const char* reason, const char* file,
350
- int line) {
351
- if (GRPC_TRACE_FLAG_ENABLED(grpc_trace_fd_refcount)) {
352
- gpr_log(GPR_DEBUG,
353
- "FD %d %p ref %d %" PRIdPTR " -> %" PRIdPTR " [%s; %s:%d]",
354
- fd->fd, fd, n, gpr_atm_no_barrier_load(&fd->refst),
355
- gpr_atm_no_barrier_load(&fd->refst) + n, reason, file, line);
356
- }
357
- #else
358
- #define REF_BY(fd, n, reason) \
359
- do { \
360
- ref_by(fd, n); \
361
- (void)(reason); \
362
- } while (0)
363
- #define UNREF_BY(fd, n, reason) \
364
- do { \
365
- unref_by(fd, n); \
366
- (void)(reason); \
367
- } while (0)
368
- static void ref_by(grpc_fd* fd, int n) {
369
- #endif
370
- GPR_ASSERT(gpr_atm_no_barrier_fetch_add(&fd->refst, n) > 0);
371
- }
372
-
373
- /* Uninitialize and add to the freelist */
374
- static void fd_destroy(void* arg, grpc_error_handle /*error*/) {
375
- grpc_fd* fd = static_cast<grpc_fd*>(arg);
376
- fd->destroy();
377
-
378
- /* Add the fd to the freelist */
379
- gpr_mu_lock(&fd_freelist_mu);
380
- fd->freelist_next = fd_freelist;
381
- fd_freelist = fd;
382
- gpr_mu_unlock(&fd_freelist_mu);
383
- }
384
-
385
- #ifndef NDEBUG
386
- static void unref_by(grpc_fd* fd, int n, const char* reason, const char* file,
387
- int line) {
388
- if (GRPC_TRACE_FLAG_ENABLED(grpc_trace_fd_refcount)) {
389
- gpr_log(GPR_DEBUG,
390
- "FD %d %p unref %d %" PRIdPTR " -> %" PRIdPTR " [%s; %s:%d]",
391
- fd->fd, fd, n, gpr_atm_no_barrier_load(&fd->refst),
392
- gpr_atm_no_barrier_load(&fd->refst) - n, reason, file, line);
393
- }
394
- #else
395
- static void unref_by(grpc_fd* fd, int n) {
396
- #endif
397
- gpr_atm old = gpr_atm_full_fetch_add(&fd->refst, -n);
398
- if (old == n) {
399
- grpc_core::ExecCtx::Run(
400
- DEBUG_LOCATION,
401
- GRPC_CLOSURE_CREATE(fd_destroy, fd, grpc_schedule_on_exec_ctx),
402
- GRPC_ERROR_NONE);
403
- } else {
404
- GPR_ASSERT(old > n);
405
- }
406
- }
407
-
408
- static void fd_global_init(void) { gpr_mu_init(&fd_freelist_mu); }
409
-
410
- static void fd_global_shutdown(void) {
411
- // TODO(guantaol): We don't have a reasonable explanation about this
412
- // lock()/unlock() pattern. It can be a valid barrier if there is at most one
413
- // pending lock() at this point. Otherwise, there is still a possibility of
414
- // use-after-free race. Need to reason about the code and/or clean it up.
415
- gpr_mu_lock(&fd_freelist_mu);
416
- gpr_mu_unlock(&fd_freelist_mu);
417
- while (fd_freelist != nullptr) {
418
- grpc_fd* fd = fd_freelist;
419
- fd_freelist = fd_freelist->freelist_next;
420
- gpr_free(fd);
421
- }
422
- gpr_mu_destroy(&fd_freelist_mu);
423
- }
424
-
425
- static grpc_fd* fd_create(int fd, const char* name, bool track_err) {
426
- grpc_fd* new_fd = nullptr;
427
-
428
- gpr_mu_lock(&fd_freelist_mu);
429
- if (fd_freelist != nullptr) {
430
- new_fd = fd_freelist;
431
- fd_freelist = fd_freelist->freelist_next;
432
- }
433
- gpr_mu_unlock(&fd_freelist_mu);
434
-
435
- if (new_fd == nullptr) {
436
- new_fd = static_cast<grpc_fd*>(gpr_malloc(sizeof(grpc_fd)));
437
- }
438
-
439
- return new (new_fd) grpc_fd(fd, name, track_err);
440
- }
441
-
442
- static int fd_wrapped_fd(grpc_fd* fd) {
443
- int ret_fd = fd->fd;
444
- return (gpr_atm_acq_load(&fd->refst) & 1) ? ret_fd : -1;
445
- }
446
-
447
- static void fd_orphan(grpc_fd* fd, grpc_closure* on_done, int* release_fd,
448
- const char* reason) {
449
- bool is_fd_closed = false;
450
-
451
- gpr_mu_lock(&fd->orphan_mu);
452
-
453
- // Get the fd->pollable_obj and set the owner_orphaned on that pollable to
454
- // true so that the pollable will no longer access its owner_fd field.
455
- gpr_mu_lock(&fd->pollable_mu);
456
- pollable* pollable_obj = fd->pollable_obj;
457
-
458
- if (pollable_obj) {
459
- gpr_mu_lock(&pollable_obj->owner_orphan_mu);
460
- pollable_obj->owner_orphaned = true;
461
- }
462
-
463
- fd->on_done_closure = on_done;
464
-
465
- /* If release_fd is not NULL, we should be relinquishing control of the file
466
- descriptor fd->fd (but we still own the grpc_fd structure). */
467
- if (release_fd != nullptr) {
468
- // Remove the FD from all epolls sets, before releasing it.
469
- // Otherwise, we will receive epoll events after we release the FD.
470
- epoll_event ev_fd;
471
- memset(&ev_fd, 0, sizeof(ev_fd));
472
- if (pollable_obj != nullptr) { // For PO_FD.
473
- epoll_ctl(pollable_obj->epfd, EPOLL_CTL_DEL, fd->fd, &ev_fd);
474
- }
475
- for (size_t i = 0; i < fd->pollset_fds.size(); ++i) { // For PO_MULTI.
476
- const int epfd = fd->pollset_fds[i];
477
- epoll_ctl(epfd, EPOLL_CTL_DEL, fd->fd, &ev_fd);
478
- }
479
- *release_fd = fd->fd;
480
- } else {
481
- close(fd->fd);
482
- is_fd_closed = true;
483
- }
484
-
485
- // TODO(sreek): handle fd removal (where is_fd_closed=false)
486
- if (!is_fd_closed) {
487
- GRPC_FD_TRACE("epoll_fd %p (%d) was orphaned but not closed.", fd, fd->fd);
488
- }
489
-
490
- /* Remove the active status but keep referenced. We want this grpc_fd struct
491
- to be alive (and not added to freelist) until the end of this function */
492
- REF_BY(fd, 1, reason);
493
-
494
- grpc_core::ExecCtx::Run(DEBUG_LOCATION, fd->on_done_closure, GRPC_ERROR_NONE);
495
-
496
- if (pollable_obj) {
497
- gpr_mu_unlock(&pollable_obj->owner_orphan_mu);
498
- }
499
-
500
- gpr_mu_unlock(&fd->pollable_mu);
501
- gpr_mu_unlock(&fd->orphan_mu);
502
-
503
- UNREF_BY(fd, 2, reason); /* Drop the reference */
504
- }
505
-
506
- static bool fd_is_shutdown(grpc_fd* fd) {
507
- return fd->read_closure.IsShutdown();
508
- }
509
-
510
- /* Might be called multiple times */
511
- static void fd_shutdown(grpc_fd* fd, grpc_error_handle why) {
512
- if (fd->read_closure.SetShutdown(GRPC_ERROR_REF(why))) {
513
- if (shutdown(fd->fd, SHUT_RDWR)) {
514
- if (errno != ENOTCONN) {
515
- gpr_log(GPR_ERROR, "Error shutting down fd %d. errno: %d",
516
- grpc_fd_wrapped_fd(fd), errno);
517
- }
518
- }
519
- fd->write_closure.SetShutdown(GRPC_ERROR_REF(why));
520
- fd->error_closure.SetShutdown(GRPC_ERROR_REF(why));
521
- }
522
- GRPC_ERROR_UNREF(why);
523
- }
524
-
525
- static void fd_notify_on_read(grpc_fd* fd, grpc_closure* closure) {
526
- fd->read_closure.NotifyOn(closure);
527
- }
528
-
529
- static void fd_notify_on_write(grpc_fd* fd, grpc_closure* closure) {
530
- fd->write_closure.NotifyOn(closure);
531
- }
532
-
533
- static void fd_notify_on_error(grpc_fd* fd, grpc_closure* closure) {
534
- fd->error_closure.NotifyOn(closure);
535
- }
536
-
537
- static bool fd_has_pollset(grpc_fd* fd, grpc_pollset* pollset) {
538
- const int epfd = pollset->active_pollable->epfd;
539
- grpc_core::MutexLockForGprMu lock(&fd->pollable_mu);
540
- for (size_t i = 0; i < fd->pollset_fds.size(); ++i) {
541
- if (fd->pollset_fds[i] == epfd) {
542
- return true;
543
- }
544
- }
545
- return false;
546
- }
547
-
548
- static void fd_add_pollset(grpc_fd* fd, grpc_pollset* pollset) {
549
- const int epfd = pollset->active_pollable->epfd;
550
- grpc_core::MutexLockForGprMu lock(&fd->pollable_mu);
551
- fd->pollset_fds.push_back(epfd);
552
- }
553
-
554
- /*******************************************************************************
555
- * Pollable Definitions
556
- */
557
-
558
- static grpc_error_handle pollable_create(pollable_type type, pollable** p) {
559
- *p = nullptr;
560
-
561
- int epfd = epoll_create1(EPOLL_CLOEXEC);
562
- if (epfd == -1) {
563
- return GRPC_OS_ERROR(errno, "epoll_create1");
564
- }
565
- GRPC_FD_TRACE("Pollable_create: created epfd: %d (type: %d)", epfd, type);
566
- *p = static_cast<pollable*>(gpr_malloc(sizeof(**p)));
567
- grpc_error_handle err = grpc_wakeup_fd_init(&(*p)->wakeup);
568
- if (err != GRPC_ERROR_NONE) {
569
- GRPC_FD_TRACE(
570
- "Pollable_create: closed epfd: %d (type: %d). wakeupfd_init error",
571
- epfd, type);
572
- close(epfd);
573
- gpr_free(*p);
574
- *p = nullptr;
575
- return err;
576
- }
577
- struct epoll_event ev;
578
- ev.events = static_cast<uint32_t>(EPOLLIN | EPOLLET);
579
- ev.data.ptr =
580
- reinterpret_cast<void*>(1 | reinterpret_cast<intptr_t>(&(*p)->wakeup));
581
- if (epoll_ctl(epfd, EPOLL_CTL_ADD, (*p)->wakeup.read_fd, &ev) != 0) {
582
- err = GRPC_OS_ERROR(errno, "epoll_ctl");
583
- GRPC_FD_TRACE(
584
- "Pollable_create: closed epfd: %d (type: %d). epoll_ctl error", epfd,
585
- type);
586
- close(epfd);
587
- grpc_wakeup_fd_destroy(&(*p)->wakeup);
588
- gpr_free(*p);
589
- *p = nullptr;
590
- return err;
591
- }
592
-
593
- (*p)->type = type;
594
- new (&(*p)->refs) grpc_core::RefCount(
595
- 1, GRPC_TRACE_FLAG_ENABLED(grpc_trace_pollable_refcount)
596
- ? "pollable_refcount"
597
- : nullptr);
598
- gpr_mu_init(&(*p)->mu);
599
- (*p)->epfd = epfd;
600
- (*p)->owner_fd = nullptr;
601
- gpr_mu_init(&(*p)->owner_orphan_mu);
602
- (*p)->owner_orphaned = false;
603
- (*p)->pollset_set = nullptr;
604
- (*p)->next = (*p)->prev = *p;
605
- (*p)->root_worker = nullptr;
606
- (*p)->event_cursor = 0;
607
- (*p)->event_count = 0;
608
- return GRPC_ERROR_NONE;
609
- }
610
-
611
- static grpc_error_handle pollable_add_fd(pollable* p, grpc_fd* fd) {
612
- grpc_error_handle error = GRPC_ERROR_NONE;
613
- static const char* err_desc = "pollable_add_fd";
614
- const int epfd = p->epfd;
615
- if (GRPC_TRACE_FLAG_ENABLED(grpc_polling_trace)) {
616
- gpr_log(GPR_INFO, "add fd %p (%d) to pollable %p", fd, fd->fd, p);
617
- }
618
-
619
- struct epoll_event ev_fd;
620
- ev_fd.events =
621
- static_cast<uint32_t>(EPOLLET | EPOLLIN | EPOLLOUT | EPOLLEXCLUSIVE);
622
- /* Use the second least significant bit of ev_fd.data.ptr to store track_err
623
- * to avoid synchronization issues when accessing it after receiving an event.
624
- * Accessing fd would be a data race there because the fd might have been
625
- * returned to the free list at that point. */
626
- ev_fd.data.ptr = reinterpret_cast<void*>(reinterpret_cast<intptr_t>(fd) |
627
- (fd->track_err ? 2 : 0));
628
- GRPC_STATS_INC_SYSCALL_EPOLL_CTL();
629
- if (epoll_ctl(epfd, EPOLL_CTL_ADD, fd->fd, &ev_fd) != 0) {
630
- switch (errno) {
631
- case EEXIST:
632
- break;
633
- default:
634
- append_error(&error, GRPC_OS_ERROR(errno, "epoll_ctl"), err_desc);
635
- }
636
- }
637
-
638
- return error;
639
- }
640
-
641
- /*******************************************************************************
642
- * Pollset Definitions
643
- */
644
-
645
- static GPR_THREAD_LOCAL(grpc_pollset*) g_current_thread_pollset;
646
- static GPR_THREAD_LOCAL(grpc_pollset_worker*) g_current_thread_worker;
647
-
648
- /* Global state management */
649
- static grpc_error_handle pollset_global_init(void) {
650
- return pollable_create(PO_EMPTY, &g_empty_pollable);
651
- }
652
-
653
- static void pollset_global_shutdown(void) {
654
- POLLABLE_UNREF(g_empty_pollable, "g_empty_pollable");
655
- }
656
-
657
- /* pollset->mu must be held while calling this function */
658
- static void pollset_maybe_finish_shutdown(grpc_pollset* pollset) {
659
- if (GRPC_TRACE_FLAG_ENABLED(grpc_polling_trace)) {
660
- gpr_log(GPR_INFO,
661
- "PS:%p (pollable:%p) maybe_finish_shutdown sc=%p (target:!NULL) "
662
- "rw=%p (target:NULL) cpsc=%d (target:0)",
663
- pollset, pollset->active_pollable, pollset->shutdown_closure,
664
- pollset->root_worker, pollset->containing_pollset_set_count);
665
- }
666
- if (pollset->shutdown_closure != nullptr && pollset->root_worker == nullptr &&
667
- pollset->containing_pollset_set_count == 0) {
668
- GPR_TIMER_MARK("pollset_finish_shutdown", 0);
669
- grpc_core::ExecCtx::Run(DEBUG_LOCATION, pollset->shutdown_closure,
670
- GRPC_ERROR_NONE);
671
- pollset->shutdown_closure = nullptr;
672
- pollset->already_shutdown = true;
673
- }
674
- }
675
-
676
- /* pollset->mu must be held before calling this function,
677
- * pollset->active_pollable->mu & specific_worker->pollable_obj->mu must not be
678
- * held */
679
- static grpc_error_handle kick_one_worker(grpc_pollset_worker* specific_worker) {
680
- GPR_TIMER_SCOPE("kick_one_worker", 0);
681
- pollable* p = specific_worker->pollable_obj;
682
- grpc_core::MutexLockForGprMu lock(&p->mu);
683
- GPR_ASSERT(specific_worker != nullptr);
684
- if (specific_worker->kicked) {
685
- if (GRPC_TRACE_FLAG_ENABLED(grpc_polling_trace)) {
686
- gpr_log(GPR_INFO, "PS:%p kicked_specific_but_already_kicked", p);
687
- }
688
- GRPC_STATS_INC_POLLSET_KICKED_AGAIN();
689
- return GRPC_ERROR_NONE;
690
- }
691
- if (g_current_thread_worker == specific_worker) {
692
- if (GRPC_TRACE_FLAG_ENABLED(grpc_polling_trace)) {
693
- gpr_log(GPR_INFO, "PS:%p kicked_specific_but_awake", p);
694
- }
695
- GRPC_STATS_INC_POLLSET_KICK_OWN_THREAD();
696
- specific_worker->kicked = true;
697
- return GRPC_ERROR_NONE;
698
- }
699
- if (specific_worker == p->root_worker) {
700
- GRPC_STATS_INC_POLLSET_KICK_WAKEUP_FD();
701
- if (GRPC_TRACE_FLAG_ENABLED(grpc_polling_trace)) {
702
- gpr_log(GPR_INFO, "PS:%p kicked_specific_via_wakeup_fd", p);
703
- }
704
- specific_worker->kicked = true;
705
- grpc_error_handle error = grpc_wakeup_fd_wakeup(&p->wakeup);
706
- return error;
707
- }
708
- if (specific_worker->initialized_cv) {
709
- GRPC_STATS_INC_POLLSET_KICK_WAKEUP_CV();
710
- if (GRPC_TRACE_FLAG_ENABLED(grpc_polling_trace)) {
711
- gpr_log(GPR_INFO, "PS:%p kicked_specific_via_cv", p);
712
- }
713
- specific_worker->kicked = true;
714
- gpr_cv_signal(&specific_worker->cv);
715
- return GRPC_ERROR_NONE;
716
- }
717
- // we can get here during end_worker after removing specific_worker from the
718
- // pollable list but before removing it from the pollset list
719
- return GRPC_ERROR_NONE;
720
- }
721
-
722
- static grpc_error_handle pollset_kick(grpc_pollset* pollset,
723
- grpc_pollset_worker* specific_worker) {
724
- GPR_TIMER_SCOPE("pollset_kick", 0);
725
- GRPC_STATS_INC_POLLSET_KICK();
726
- if (GRPC_TRACE_FLAG_ENABLED(grpc_polling_trace)) {
727
- gpr_log(GPR_INFO,
728
- "PS:%p kick %p tls_pollset=%p tls_worker=%p pollset.root_worker=%p",
729
- pollset, specific_worker,
730
- static_cast<void*>(g_current_thread_pollset),
731
- static_cast<void*>(g_current_thread_worker), pollset->root_worker);
732
- }
733
- if (specific_worker == nullptr) {
734
- if (g_current_thread_pollset != pollset) {
735
- if (pollset->root_worker == nullptr) {
736
- if (GRPC_TRACE_FLAG_ENABLED(grpc_polling_trace)) {
737
- gpr_log(GPR_INFO, "PS:%p kicked_any_without_poller", pollset);
738
- }
739
- GRPC_STATS_INC_POLLSET_KICKED_WITHOUT_POLLER();
740
- pollset->kicked_without_poller = true;
741
- return GRPC_ERROR_NONE;
742
- } else {
743
- // We've been asked to kick a poller, but we haven't been told which one
744
- // ... any will do
745
- // We look at the pollset worker list because:
746
- // 1. the pollable list may include workers from other pollers, so we'd
747
- // need to do an O(N) search
748
- // 2. we'd additionally need to take the pollable lock, which we've so
749
- // far avoided
750
- // Now, we would prefer to wake a poller in cv_wait, and not in
751
- // epoll_wait (since the latter would imply the need to do an additional
752
- // wakeup)
753
- // We know that if a worker is at the root of a pollable, it's (likely)
754
- // also the root of a pollset, and we know that if a worker is NOT at
755
- // the root of a pollset, it's (likely) not at the root of a pollable,
756
- // so we take our chances and choose the SECOND worker enqueued against
757
- // the pollset as a worker that's likely to be in cv_wait
758
- return kick_one_worker(
759
- pollset->root_worker->links[PWLINK_POLLSET].next);
760
- }
761
- } else {
762
- if (GRPC_TRACE_FLAG_ENABLED(grpc_polling_trace)) {
763
- gpr_log(GPR_INFO, "PS:%p kicked_any_but_awake", pollset);
764
- }
765
- GRPC_STATS_INC_POLLSET_KICK_OWN_THREAD();
766
- return GRPC_ERROR_NONE;
767
- }
768
- } else {
769
- return kick_one_worker(specific_worker);
770
- }
771
- }
772
-
773
- static grpc_error_handle pollset_kick_all(grpc_pollset* pollset) {
774
- GPR_TIMER_SCOPE("pollset_kick_all", 0);
775
- grpc_error_handle error = GRPC_ERROR_NONE;
776
- const char* err_desc = "pollset_kick_all";
777
- grpc_pollset_worker* w = pollset->root_worker;
778
- if (w != nullptr) {
779
- do {
780
- GRPC_STATS_INC_POLLSET_KICK();
781
- append_error(&error, kick_one_worker(w), err_desc);
782
- w = w->links[PWLINK_POLLSET].next;
783
- } while (w != pollset->root_worker);
784
- }
785
- return error;
786
- }
787
-
788
- static void pollset_init(grpc_pollset* pollset, gpr_mu** mu) {
789
- gpr_mu_init(&pollset->mu);
790
- gpr_atm_no_barrier_store(&pollset->worker_count, 0);
791
- gpr_atm_no_barrier_store(&pollset->active_pollable_type, PO_EMPTY);
792
- pollset->active_pollable = POLLABLE_REF(g_empty_pollable, "pollset");
793
- pollset->kicked_without_poller = false;
794
- pollset->shutdown_closure = nullptr;
795
- pollset->already_shutdown = false;
796
- pollset->root_worker = nullptr;
797
- pollset->containing_pollset_set_count = 0;
798
- *mu = &pollset->mu;
799
- }
800
-
801
- static int poll_deadline_to_millis_timeout(grpc_millis millis) {
802
- if (millis == GRPC_MILLIS_INF_FUTURE) return -1;
803
- grpc_millis delta = millis - grpc_core::ExecCtx::Get()->Now();
804
- if (delta > INT_MAX) {
805
- return INT_MAX;
806
- } else if (delta < 0) {
807
- return 0;
808
- } else {
809
- return static_cast<int>(delta);
810
- }
811
- }
812
-
813
- static void fd_become_readable(grpc_fd* fd) { fd->read_closure.SetReady(); }
814
-
815
- static void fd_become_writable(grpc_fd* fd) { fd->write_closure.SetReady(); }
816
-
817
- static void fd_has_errors(grpc_fd* fd) { fd->error_closure.SetReady(); }
818
-
819
- /* Get the pollable_obj attached to this fd. If none is attached, create a new
820
- * pollable object (of type PO_FD), attach it to the fd and return it
821
- *
822
- * Note that if a pollable object is already attached to the fd, it may be of
823
- * either PO_FD or PO_MULTI type */
824
- static grpc_error_handle get_fd_pollable(grpc_fd* fd, pollable** p) {
825
- gpr_mu_lock(&fd->pollable_mu);
826
- grpc_error_handle error = GRPC_ERROR_NONE;
827
- static const char* err_desc = "get_fd_pollable";
828
- if (fd->pollable_obj == nullptr) {
829
- if (append_error(&error, pollable_create(PO_FD, &fd->pollable_obj),
830
- err_desc)) {
831
- fd->pollable_obj->owner_fd = fd;
832
- if (!append_error(&error, pollable_add_fd(fd->pollable_obj, fd),
833
- err_desc)) {
834
- POLLABLE_UNREF(fd->pollable_obj, "fd_pollable");
835
- fd->pollable_obj = nullptr;
836
- }
837
- }
838
- }
839
- if (error == GRPC_ERROR_NONE) {
840
- GPR_ASSERT(fd->pollable_obj != nullptr);
841
- *p = POLLABLE_REF(fd->pollable_obj, "pollset");
842
- } else {
843
- GPR_ASSERT(fd->pollable_obj == nullptr);
844
- *p = nullptr;
845
- }
846
- gpr_mu_unlock(&fd->pollable_mu);
847
- return error;
848
- }
849
-
850
- /* pollset->po.mu lock must be held by the caller before calling this */
851
- static void pollset_shutdown(grpc_pollset* pollset, grpc_closure* closure) {
852
- GPR_TIMER_SCOPE("pollset_shutdown", 0);
853
- GPR_ASSERT(pollset->shutdown_closure == nullptr);
854
- pollset->shutdown_closure = closure;
855
- GRPC_LOG_IF_ERROR("pollset_shutdown", pollset_kick_all(pollset));
856
- pollset_maybe_finish_shutdown(pollset);
857
- }
858
-
859
- static grpc_error_handle pollable_process_events(grpc_pollset* pollset,
860
- pollable* pollable_obj,
861
- bool drain) {
862
- GPR_TIMER_SCOPE("pollable_process_events", 0);
863
- static const char* err_desc = "pollset_process_events";
864
- // Use a simple heuristic to determine how many fd events to process
865
- // per loop iteration. (events/workers)
866
- int handle_count = 1;
867
- int worker_count = gpr_atm_no_barrier_load(&pollset->worker_count);
868
- GPR_ASSERT(worker_count > 0);
869
- handle_count =
870
- (pollable_obj->event_count - pollable_obj->event_cursor) / worker_count;
871
- if (handle_count == 0) {
872
- handle_count = 1;
873
- }
874
- grpc_error_handle error = GRPC_ERROR_NONE;
875
- for (int i = 0; (drain || i < handle_count) &&
876
- pollable_obj->event_cursor != pollable_obj->event_count;
877
- i++) {
878
- int n = pollable_obj->event_cursor++;
879
- struct epoll_event* ev = &pollable_obj->events[n];
880
- void* data_ptr = ev->data.ptr;
881
- if (1 & reinterpret_cast<intptr_t>(data_ptr)) {
882
- if (GRPC_TRACE_FLAG_ENABLED(grpc_polling_trace)) {
883
- gpr_log(GPR_INFO, "PS:%p got pollset_wakeup %p", pollset, data_ptr);
884
- }
885
- append_error(
886
- &error,
887
- grpc_wakeup_fd_consume_wakeup(reinterpret_cast<grpc_wakeup_fd*>(
888
- ~static_cast<intptr_t>(1) &
889
- reinterpret_cast<intptr_t>(data_ptr))),
890
- err_desc);
891
- } else {
892
- grpc_fd* fd =
893
- reinterpret_cast<grpc_fd*>(reinterpret_cast<intptr_t>(data_ptr) & ~2);
894
- bool track_err = reinterpret_cast<intptr_t>(data_ptr) & 2;
895
- bool cancel = (ev->events & EPOLLHUP) != 0;
896
- bool error = (ev->events & EPOLLERR) != 0;
897
- bool read_ev = (ev->events & (EPOLLIN | EPOLLPRI)) != 0;
898
- bool write_ev = (ev->events & EPOLLOUT) != 0;
899
- bool err_fallback = error && !track_err;
900
-
901
- if (GRPC_TRACE_FLAG_ENABLED(grpc_polling_trace)) {
902
- gpr_log(GPR_INFO,
903
- "PS:%p got fd %p: cancel=%d read=%d "
904
- "write=%d",
905
- pollset, fd, cancel, read_ev, write_ev);
906
- }
907
- if (error && !err_fallback) {
908
- fd_has_errors(fd);
909
- }
910
- if (read_ev || cancel || err_fallback) {
911
- fd_become_readable(fd);
912
- }
913
- if (write_ev || cancel || err_fallback) {
914
- fd_become_writable(fd);
915
- }
916
- }
917
- }
918
-
919
- return error;
920
- }
921
-
922
- /* pollset_shutdown is guaranteed to be called before pollset_destroy. */
923
- static void pollset_destroy(grpc_pollset* pollset) {
924
- POLLABLE_UNREF(pollset->active_pollable, "pollset");
925
- pollset->active_pollable = nullptr;
926
- gpr_mu_destroy(&pollset->mu);
927
- }
928
-
929
- static grpc_error_handle pollable_epoll(pollable* p, grpc_millis deadline) {
930
- GPR_TIMER_SCOPE("pollable_epoll", 0);
931
- int timeout = poll_deadline_to_millis_timeout(deadline);
932
-
933
- if (GRPC_TRACE_FLAG_ENABLED(grpc_polling_trace)) {
934
- gpr_log(GPR_INFO, "POLLABLE:%p[%s] poll for %dms", p,
935
- pollable_desc(p).c_str(), timeout);
936
- }
937
-
938
- if (timeout != 0) {
939
- GRPC_SCHEDULING_START_BLOCKING_REGION;
940
- }
941
- int r;
942
- do {
943
- GRPC_STATS_INC_SYSCALL_POLL();
944
- r = epoll_wait(p->epfd, p->events, MAX_EPOLL_EVENTS, timeout);
945
- } while (r < 0 && errno == EINTR);
946
- if (timeout != 0) {
947
- GRPC_SCHEDULING_END_BLOCKING_REGION;
948
- }
949
-
950
- if (r < 0) return GRPC_OS_ERROR(errno, "epoll_wait");
951
-
952
- if (GRPC_TRACE_FLAG_ENABLED(grpc_polling_trace)) {
953
- gpr_log(GPR_INFO, "POLLABLE:%p got %d events", p, r);
954
- }
955
-
956
- p->event_cursor = 0;
957
- p->event_count = r;
958
-
959
- return GRPC_ERROR_NONE;
960
- }
961
-
962
- /* Return true if first in list */
963
- static bool worker_insert(grpc_pollset_worker** root_worker,
964
- grpc_pollset_worker* worker, pwlinks link) {
965
- if (*root_worker == nullptr) {
966
- *root_worker = worker;
967
- worker->links[link].next = worker->links[link].prev = worker;
968
- return true;
969
- } else {
970
- worker->links[link].next = *root_worker;
971
- worker->links[link].prev = worker->links[link].next->links[link].prev;
972
- worker->links[link].next->links[link].prev = worker;
973
- worker->links[link].prev->links[link].next = worker;
974
- return false;
975
- }
976
- }
977
-
978
- /* returns the new root IFF the root changed */
979
- typedef enum { WRR_NEW_ROOT, WRR_EMPTIED, WRR_REMOVED } worker_remove_result;
980
-
981
- static worker_remove_result worker_remove(grpc_pollset_worker** root_worker,
982
- grpc_pollset_worker* worker,
983
- pwlinks link) {
984
- if (worker == *root_worker) {
985
- if (worker == worker->links[link].next) {
986
- *root_worker = nullptr;
987
- return WRR_EMPTIED;
988
- } else {
989
- *root_worker = worker->links[link].next;
990
- worker->links[link].prev->links[link].next = worker->links[link].next;
991
- worker->links[link].next->links[link].prev = worker->links[link].prev;
992
- return WRR_NEW_ROOT;
993
- }
994
- } else {
995
- worker->links[link].prev->links[link].next = worker->links[link].next;
996
- worker->links[link].next->links[link].prev = worker->links[link].prev;
997
- return WRR_REMOVED;
998
- }
999
- }
1000
-
1001
- /* Return true if this thread should poll */
1002
- static bool begin_worker(grpc_pollset* pollset, grpc_pollset_worker* worker,
1003
- grpc_pollset_worker** worker_hdl,
1004
- grpc_millis deadline) {
1005
- GPR_TIMER_SCOPE("begin_worker", 0);
1006
- bool do_poll =
1007
- (pollset->shutdown_closure == nullptr && !pollset->already_shutdown);
1008
- gpr_atm_no_barrier_fetch_add(&pollset->worker_count, 1);
1009
- if (worker_hdl != nullptr) *worker_hdl = worker;
1010
- worker->initialized_cv = false;
1011
- worker->kicked = false;
1012
- worker->pollset = pollset;
1013
- worker->pollable_obj =
1014
- POLLABLE_REF(pollset->active_pollable, "pollset_worker");
1015
- worker_insert(&pollset->root_worker, worker, PWLINK_POLLSET);
1016
- gpr_mu_lock(&worker->pollable_obj->mu);
1017
- if (!worker_insert(&worker->pollable_obj->root_worker, worker,
1018
- PWLINK_POLLABLE)) {
1019
- worker->initialized_cv = true;
1020
- gpr_cv_init(&worker->cv);
1021
- gpr_mu_unlock(&pollset->mu);
1022
- if (GRPC_TRACE_FLAG_ENABLED(grpc_polling_trace) &&
1023
- worker->pollable_obj->root_worker != worker) {
1024
- gpr_log(GPR_INFO, "PS:%p wait %p w=%p for %dms", pollset,
1025
- worker->pollable_obj, worker,
1026
- poll_deadline_to_millis_timeout(deadline));
1027
- }
1028
- while (do_poll && worker->pollable_obj->root_worker != worker) {
1029
- if (gpr_cv_wait(&worker->cv, &worker->pollable_obj->mu,
1030
- grpc_millis_to_timespec(deadline, GPR_CLOCK_REALTIME))) {
1031
- if (GRPC_TRACE_FLAG_ENABLED(grpc_polling_trace)) {
1032
- gpr_log(GPR_INFO, "PS:%p timeout_wait %p w=%p", pollset,
1033
- worker->pollable_obj, worker);
1034
- }
1035
- do_poll = false;
1036
- } else if (worker->kicked) {
1037
- if (GRPC_TRACE_FLAG_ENABLED(grpc_polling_trace)) {
1038
- gpr_log(GPR_INFO, "PS:%p wakeup %p w=%p", pollset,
1039
- worker->pollable_obj, worker);
1040
- }
1041
- do_poll = false;
1042
- } else if (GRPC_TRACE_FLAG_ENABLED(grpc_polling_trace) &&
1043
- worker->pollable_obj->root_worker != worker) {
1044
- gpr_log(GPR_INFO, "PS:%p spurious_wakeup %p w=%p", pollset,
1045
- worker->pollable_obj, worker);
1046
- }
1047
- }
1048
- grpc_core::ExecCtx::Get()->InvalidateNow();
1049
- } else {
1050
- gpr_mu_unlock(&pollset->mu);
1051
- }
1052
- gpr_mu_unlock(&worker->pollable_obj->mu);
1053
-
1054
- return do_poll;
1055
- }
1056
-
1057
- static void end_worker(grpc_pollset* pollset, grpc_pollset_worker* worker,
1058
- grpc_pollset_worker** /*worker_hdl*/) {
1059
- GPR_TIMER_SCOPE("end_worker", 0);
1060
- gpr_mu_lock(&pollset->mu);
1061
- gpr_mu_lock(&worker->pollable_obj->mu);
1062
- switch (worker_remove(&worker->pollable_obj->root_worker, worker,
1063
- PWLINK_POLLABLE)) {
1064
- case WRR_NEW_ROOT: {
1065
- // wakeup new poller
1066
- grpc_pollset_worker* new_root = worker->pollable_obj->root_worker;
1067
- GPR_ASSERT(new_root->initialized_cv);
1068
- gpr_cv_signal(&new_root->cv);
1069
- break;
1070
- }
1071
- case WRR_EMPTIED:
1072
- if (pollset->active_pollable != worker->pollable_obj) {
1073
- // pollable no longer being polled: flush events
1074
- (void)pollable_process_events(pollset, worker->pollable_obj, true);
1075
- }
1076
- break;
1077
- case WRR_REMOVED:
1078
- break;
1079
- }
1080
- gpr_mu_unlock(&worker->pollable_obj->mu);
1081
- POLLABLE_UNREF(worker->pollable_obj, "pollset_worker");
1082
- if (worker_remove(&pollset->root_worker, worker, PWLINK_POLLSET) ==
1083
- WRR_EMPTIED) {
1084
- pollset_maybe_finish_shutdown(pollset);
1085
- }
1086
- if (worker->initialized_cv) {
1087
- gpr_cv_destroy(&worker->cv);
1088
- }
1089
- gpr_atm_no_barrier_fetch_add(&pollset->worker_count, -1);
1090
- }
1091
-
1092
- #ifndef NDEBUG
1093
- static long sys_gettid(void) { return syscall(__NR_gettid); }
1094
- #endif
1095
-
1096
- /* pollset->mu lock must be held by the caller before calling this.
1097
- The function pollset_work() may temporarily release the lock (pollset->po.mu)
1098
- during the course of its execution but it will always re-acquire the lock and
1099
- ensure that it is held by the time the function returns */
1100
- static grpc_error_handle pollset_work(grpc_pollset* pollset,
1101
- grpc_pollset_worker** worker_hdl,
1102
- grpc_millis deadline) {
1103
- GPR_TIMER_SCOPE("pollset_work", 0);
1104
- #ifdef GRPC_EPOLLEX_CREATE_WORKERS_ON_HEAP
1105
- grpc_pollset_worker* worker =
1106
- (grpc_pollset_worker*)gpr_malloc(sizeof(*worker));
1107
- #define WORKER_PTR (worker)
1108
- #else
1109
- grpc_pollset_worker worker;
1110
- #define WORKER_PTR (&worker)
1111
- #endif
1112
- #ifndef NDEBUG
1113
- WORKER_PTR->originator = sys_gettid();
1114
- #endif
1115
- if (GRPC_TRACE_FLAG_ENABLED(grpc_polling_trace)) {
1116
- gpr_log(GPR_INFO,
1117
- "PS:%p work hdl=%p worker=%p now=%" PRId64 " deadline=%" PRId64
1118
- " kwp=%d pollable=%p",
1119
- pollset, worker_hdl, WORKER_PTR, grpc_core::ExecCtx::Get()->Now(),
1120
- deadline, pollset->kicked_without_poller, pollset->active_pollable);
1121
- }
1122
- static const char* err_desc = "pollset_work";
1123
- grpc_error_handle error = GRPC_ERROR_NONE;
1124
- if (pollset->kicked_without_poller) {
1125
- pollset->kicked_without_poller = false;
1126
- } else {
1127
- if (begin_worker(pollset, WORKER_PTR, worker_hdl, deadline)) {
1128
- g_current_thread_pollset = pollset;
1129
- g_current_thread_worker = WORKER_PTR;
1130
- if (WORKER_PTR->pollable_obj->event_cursor ==
1131
- WORKER_PTR->pollable_obj->event_count) {
1132
- append_error(&error, pollable_epoll(WORKER_PTR->pollable_obj, deadline),
1133
- err_desc);
1134
- }
1135
- append_error(
1136
- &error,
1137
- pollable_process_events(pollset, WORKER_PTR->pollable_obj, false),
1138
- err_desc);
1139
- grpc_core::ExecCtx::Get()->Flush();
1140
- g_current_thread_pollset = nullptr;
1141
- g_current_thread_worker = nullptr;
1142
- }
1143
- end_worker(pollset, WORKER_PTR, worker_hdl);
1144
- }
1145
- #ifdef GRPC_EPOLLEX_CREATE_WORKERS_ON_HEAP
1146
- gpr_free(worker);
1147
- #endif
1148
- #undef WORKER_PTR
1149
- return error;
1150
- }
1151
-
1152
- static grpc_error_handle pollset_transition_pollable_from_empty_to_fd_locked(
1153
- grpc_pollset* pollset, grpc_fd* fd) {
1154
- static const char* err_desc = "pollset_transition_pollable_from_empty_to_fd";
1155
- grpc_error_handle error = GRPC_ERROR_NONE;
1156
- if (GRPC_TRACE_FLAG_ENABLED(grpc_polling_trace)) {
1157
- gpr_log(GPR_INFO,
1158
- "PS:%p add fd %p (%d); transition pollable from empty to fd",
1159
- pollset, fd, fd->fd);
1160
- }
1161
- append_error(&error, pollset_kick_all(pollset), err_desc);
1162
- POLLABLE_UNREF(pollset->active_pollable, "pollset");
1163
- append_error(&error, get_fd_pollable(fd, &pollset->active_pollable),
1164
- err_desc);
1165
- return error;
1166
- }
1167
-
1168
- static grpc_error_handle pollset_transition_pollable_from_fd_to_multi_locked(
1169
- grpc_pollset* pollset, grpc_fd* and_add_fd) {
1170
- static const char* err_desc = "pollset_transition_pollable_from_fd_to_multi";
1171
- grpc_error_handle error = GRPC_ERROR_NONE;
1172
- if (GRPC_TRACE_FLAG_ENABLED(grpc_polling_trace)) {
1173
- gpr_log(
1174
- GPR_INFO,
1175
- "PS:%p add fd %p (%d); transition pollable from fd %p to multipoller",
1176
- pollset, and_add_fd, and_add_fd ? and_add_fd->fd : -1,
1177
- pollset->active_pollable->owner_fd);
1178
- }
1179
- append_error(&error, pollset_kick_all(pollset), err_desc);
1180
- grpc_fd* initial_fd = pollset->active_pollable->owner_fd;
1181
- POLLABLE_UNREF(pollset->active_pollable, "pollset");
1182
- pollset->active_pollable = nullptr;
1183
- if (append_error(&error, pollable_create(PO_MULTI, &pollset->active_pollable),
1184
- err_desc)) {
1185
- append_error(&error, pollable_add_fd(pollset->active_pollable, initial_fd),
1186
- err_desc);
1187
- if (and_add_fd != nullptr) {
1188
- append_error(&error,
1189
- pollable_add_fd(pollset->active_pollable, and_add_fd),
1190
- err_desc);
1191
- }
1192
- }
1193
- return error;
1194
- }
1195
-
1196
- /* expects pollsets locked, flag whether fd is locked or not */
1197
- static grpc_error_handle pollset_add_fd_locked(grpc_pollset* pollset,
1198
- grpc_fd* fd) {
1199
- grpc_error_handle error = GRPC_ERROR_NONE;
1200
- pollable* po_at_start =
1201
- POLLABLE_REF(pollset->active_pollable, "pollset_add_fd");
1202
- switch (pollset->active_pollable->type) {
1203
- case PO_EMPTY:
1204
- /* empty pollable --> single fd pollable */
1205
- error = pollset_transition_pollable_from_empty_to_fd_locked(pollset, fd);
1206
- break;
1207
- case PO_FD:
1208
- gpr_mu_lock(&po_at_start->owner_orphan_mu);
1209
- if (po_at_start->owner_orphaned) {
1210
- error =
1211
- pollset_transition_pollable_from_empty_to_fd_locked(pollset, fd);
1212
- } else {
1213
- /* fd --> multipoller */
1214
- error =
1215
- pollset_transition_pollable_from_fd_to_multi_locked(pollset, fd);
1216
- }
1217
- gpr_mu_unlock(&po_at_start->owner_orphan_mu);
1218
- break;
1219
- case PO_MULTI:
1220
- error = pollable_add_fd(pollset->active_pollable, fd);
1221
- break;
1222
- }
1223
- if (error != GRPC_ERROR_NONE) {
1224
- POLLABLE_UNREF(pollset->active_pollable, "pollset");
1225
- pollset->active_pollable = po_at_start;
1226
- } else {
1227
- gpr_atm_rel_store(&pollset->active_pollable_type,
1228
- pollset->active_pollable->type);
1229
- POLLABLE_UNREF(po_at_start, "pollset_add_fd");
1230
- }
1231
- return error;
1232
- }
1233
-
1234
- static grpc_error_handle pollset_as_multipollable_locked(
1235
- grpc_pollset* pollset, pollable** pollable_obj) {
1236
- grpc_error_handle error = GRPC_ERROR_NONE;
1237
- pollable* po_at_start =
1238
- POLLABLE_REF(pollset->active_pollable, "pollset_as_multipollable");
1239
- switch (pollset->active_pollable->type) {
1240
- case PO_EMPTY:
1241
- POLLABLE_UNREF(pollset->active_pollable, "pollset");
1242
- error = pollable_create(PO_MULTI, &pollset->active_pollable);
1243
- /* Any workers currently polling on this pollset must now be woked up so
1244
- * that they can pick up the new active_pollable */
1245
- if (GRPC_TRACE_FLAG_ENABLED(grpc_polling_trace)) {
1246
- gpr_log(GPR_INFO,
1247
- "PS:%p active pollable transition from empty to multi",
1248
- pollset);
1249
- }
1250
- static const char* err_desc =
1251
- "pollset_as_multipollable_locked: empty -> multi";
1252
- append_error(&error, pollset_kick_all(pollset), err_desc);
1253
- break;
1254
- case PO_FD:
1255
- gpr_mu_lock(&po_at_start->owner_orphan_mu);
1256
- if (po_at_start->owner_orphaned) {
1257
- // Unlock before Unref'ing the pollable
1258
- gpr_mu_unlock(&po_at_start->owner_orphan_mu);
1259
- POLLABLE_UNREF(pollset->active_pollable, "pollset");
1260
- error = pollable_create(PO_MULTI, &pollset->active_pollable);
1261
- } else {
1262
- error = pollset_transition_pollable_from_fd_to_multi_locked(pollset,
1263
- nullptr);
1264
- gpr_mu_unlock(&po_at_start->owner_orphan_mu);
1265
- }
1266
- break;
1267
- case PO_MULTI:
1268
- break;
1269
- }
1270
- if (error != GRPC_ERROR_NONE) {
1271
- POLLABLE_UNREF(pollset->active_pollable, "pollset");
1272
- pollset->active_pollable = po_at_start;
1273
- *pollable_obj = nullptr;
1274
- } else {
1275
- gpr_atm_rel_store(&pollset->active_pollable_type,
1276
- pollset->active_pollable->type);
1277
- *pollable_obj = POLLABLE_REF(pollset->active_pollable, "pollset_set");
1278
- POLLABLE_UNREF(po_at_start, "pollset_as_multipollable");
1279
- }
1280
- return error;
1281
- }
1282
-
1283
- static void pollset_add_fd(grpc_pollset* pollset, grpc_fd* fd) {
1284
- GPR_TIMER_SCOPE("pollset_add_fd", 0);
1285
-
1286
- // We never transition from PO_MULTI to other modes (i.e., PO_FD or PO_EMPTY)
1287
- // and, thus, it is safe to simply store and check whether the FD has already
1288
- // been added to the active pollable previously.
1289
- if (gpr_atm_acq_load(&pollset->active_pollable_type) == PO_MULTI &&
1290
- fd_has_pollset(fd, pollset)) {
1291
- return;
1292
- }
1293
-
1294
- grpc_core::MutexLockForGprMu lock(&pollset->mu);
1295
- grpc_error_handle error = pollset_add_fd_locked(pollset, fd);
1296
-
1297
- // If we are in PO_MULTI mode, we should update the pollsets of the FD.
1298
- if (gpr_atm_no_barrier_load(&pollset->active_pollable_type) == PO_MULTI) {
1299
- fd_add_pollset(fd, pollset);
1300
- }
1301
-
1302
- GRPC_LOG_IF_ERROR("pollset_add_fd", error);
1303
- }
1304
-
1305
- /*******************************************************************************
1306
- * Pollset-set Definitions
1307
- */
1308
-
1309
- static grpc_pollset_set* pss_lock_adam(grpc_pollset_set* pss) {
1310
- gpr_mu_lock(&pss->mu);
1311
- while (pss->parent != nullptr) {
1312
- gpr_mu_unlock(&pss->mu);
1313
- pss = pss->parent;
1314
- gpr_mu_lock(&pss->mu);
1315
- }
1316
- return pss;
1317
- }
1318
-
1319
- static grpc_pollset_set* pollset_set_create(void) {
1320
- grpc_pollset_set* pss =
1321
- static_cast<grpc_pollset_set*>(gpr_zalloc(sizeof(*pss)));
1322
- gpr_mu_init(&pss->mu);
1323
- new (&pss->refs) grpc_core::RefCount();
1324
- return pss;
1325
- }
1326
-
1327
- static void pollset_set_unref(grpc_pollset_set* pss) {
1328
- if (pss == nullptr) return;
1329
- if (GPR_LIKELY(!pss->refs.Unref())) return;
1330
- pollset_set_unref(pss->parent);
1331
- gpr_mu_destroy(&pss->mu);
1332
- for (size_t i = 0; i < pss->pollset_count; i++) {
1333
- gpr_mu_lock(&pss->pollsets[i]->mu);
1334
- if (0 == --pss->pollsets[i]->containing_pollset_set_count) {
1335
- pollset_maybe_finish_shutdown(pss->pollsets[i]);
1336
- }
1337
- gpr_mu_unlock(&pss->pollsets[i]->mu);
1338
- }
1339
- for (size_t i = 0; i < pss->fd_count; i++) {
1340
- UNREF_BY(pss->fds[i], 2, "pollset_set");
1341
- }
1342
- gpr_free(pss->pollsets);
1343
- gpr_free(pss->fds);
1344
- gpr_free(pss);
1345
- }
1346
-
1347
- static void pollset_set_add_fd(grpc_pollset_set* pss, grpc_fd* fd) {
1348
- GPR_TIMER_SCOPE("pollset_set_add_fd", 0);
1349
- if (GRPC_TRACE_FLAG_ENABLED(grpc_polling_trace)) {
1350
- gpr_log(GPR_INFO, "PSS:%p: add fd %p (%d)", pss, fd, fd->fd);
1351
- }
1352
- grpc_error_handle error = GRPC_ERROR_NONE;
1353
- static const char* err_desc = "pollset_set_add_fd";
1354
- pss = pss_lock_adam(pss);
1355
- for (size_t i = 0; i < pss->pollset_count; i++) {
1356
- append_error(&error, pollable_add_fd(pss->pollsets[i]->active_pollable, fd),
1357
- err_desc);
1358
- }
1359
- if (pss->fd_count == pss->fd_capacity) {
1360
- pss->fd_capacity = std::max(pss->fd_capacity * 2, size_t(8));
1361
- pss->fds = static_cast<grpc_fd**>(
1362
- gpr_realloc(pss->fds, pss->fd_capacity * sizeof(*pss->fds)));
1363
- }
1364
- REF_BY(fd, 2, "pollset_set");
1365
- pss->fds[pss->fd_count++] = fd;
1366
- gpr_mu_unlock(&pss->mu);
1367
-
1368
- GRPC_LOG_IF_ERROR(err_desc, error);
1369
- }
1370
-
1371
- static void pollset_set_del_fd(grpc_pollset_set* pss, grpc_fd* fd) {
1372
- GPR_TIMER_SCOPE("pollset_set_del_fd", 0);
1373
- if (GRPC_TRACE_FLAG_ENABLED(grpc_polling_trace)) {
1374
- gpr_log(GPR_INFO, "PSS:%p: del fd %p", pss, fd);
1375
- }
1376
- pss = pss_lock_adam(pss);
1377
- size_t i;
1378
- for (i = 0; i < pss->fd_count; i++) {
1379
- if (pss->fds[i] == fd) {
1380
- UNREF_BY(fd, 2, "pollset_set");
1381
- break;
1382
- }
1383
- }
1384
- GPR_ASSERT(i != pss->fd_count);
1385
- for (; i < pss->fd_count - 1; i++) {
1386
- pss->fds[i] = pss->fds[i + 1];
1387
- }
1388
- pss->fd_count--;
1389
- gpr_mu_unlock(&pss->mu);
1390
- }
1391
-
1392
- static void pollset_set_del_pollset(grpc_pollset_set* pss, grpc_pollset* ps) {
1393
- GPR_TIMER_SCOPE("pollset_set_del_pollset", 0);
1394
- if (GRPC_TRACE_FLAG_ENABLED(grpc_polling_trace)) {
1395
- gpr_log(GPR_INFO, "PSS:%p: del pollset %p", pss, ps);
1396
- }
1397
- pss = pss_lock_adam(pss);
1398
- size_t i;
1399
- for (i = 0; i < pss->pollset_count; i++) {
1400
- if (pss->pollsets[i] == ps) {
1401
- break;
1402
- }
1403
- }
1404
- GPR_ASSERT(i != pss->pollset_count);
1405
- for (; i < pss->pollset_count - 1; i++) {
1406
- pss->pollsets[i] = pss->pollsets[i + 1];
1407
- }
1408
- pss->pollset_count--;
1409
- gpr_mu_unlock(&pss->mu);
1410
- gpr_mu_lock(&ps->mu);
1411
- if (0 == --ps->containing_pollset_set_count) {
1412
- pollset_maybe_finish_shutdown(ps);
1413
- }
1414
- gpr_mu_unlock(&ps->mu);
1415
- }
1416
-
1417
- // add all fds to pollables, and output a new array of unorphaned out_fds
1418
- // assumes pollsets are multipollable
1419
- static grpc_error_handle add_fds_to_pollsets(grpc_fd** fds, size_t fd_count,
1420
- grpc_pollset** pollsets,
1421
- size_t pollset_count,
1422
- const char* err_desc,
1423
- grpc_fd** out_fds,
1424
- size_t* out_fd_count) {
1425
- GPR_TIMER_SCOPE("add_fds_to_pollsets", 0);
1426
- grpc_error_handle error = GRPC_ERROR_NONE;
1427
- for (size_t i = 0; i < fd_count; i++) {
1428
- gpr_mu_lock(&fds[i]->orphan_mu);
1429
- if ((gpr_atm_no_barrier_load(&fds[i]->refst) & 1) == 0) {
1430
- gpr_mu_unlock(&fds[i]->orphan_mu);
1431
- UNREF_BY(fds[i], 2, "pollset_set");
1432
- } else {
1433
- for (size_t j = 0; j < pollset_count; j++) {
1434
- append_error(&error,
1435
- pollable_add_fd(pollsets[j]->active_pollable, fds[i]),
1436
- err_desc);
1437
- }
1438
- gpr_mu_unlock(&fds[i]->orphan_mu);
1439
- out_fds[(*out_fd_count)++] = fds[i];
1440
- }
1441
- }
1442
- return error;
1443
- }
1444
-
1445
- static void pollset_set_add_pollset(grpc_pollset_set* pss, grpc_pollset* ps) {
1446
- GPR_TIMER_SCOPE("pollset_set_add_pollset", 0);
1447
- if (GRPC_TRACE_FLAG_ENABLED(grpc_polling_trace)) {
1448
- gpr_log(GPR_INFO, "PSS:%p: add pollset %p", pss, ps);
1449
- }
1450
- grpc_error_handle error = GRPC_ERROR_NONE;
1451
- static const char* err_desc = "pollset_set_add_pollset";
1452
- pollable* pollable_obj = nullptr;
1453
- gpr_mu_lock(&ps->mu);
1454
- if (!GRPC_LOG_IF_ERROR(err_desc,
1455
- pollset_as_multipollable_locked(ps, &pollable_obj))) {
1456
- GPR_ASSERT(pollable_obj == nullptr);
1457
- gpr_mu_unlock(&ps->mu);
1458
- return;
1459
- }
1460
- ps->containing_pollset_set_count++;
1461
- gpr_mu_unlock(&ps->mu);
1462
- pss = pss_lock_adam(pss);
1463
- size_t initial_fd_count = pss->fd_count;
1464
- pss->fd_count = 0;
1465
- append_error(&error,
1466
- add_fds_to_pollsets(pss->fds, initial_fd_count, &ps, 1, err_desc,
1467
- pss->fds, &pss->fd_count),
1468
- err_desc);
1469
- if (pss->pollset_count == pss->pollset_capacity) {
1470
- pss->pollset_capacity = std::max(pss->pollset_capacity * 2, size_t(8));
1471
- pss->pollsets = static_cast<grpc_pollset**>(gpr_realloc(
1472
- pss->pollsets, pss->pollset_capacity * sizeof(*pss->pollsets)));
1473
- }
1474
- pss->pollsets[pss->pollset_count++] = ps;
1475
- gpr_mu_unlock(&pss->mu);
1476
- POLLABLE_UNREF(pollable_obj, "pollset_set");
1477
-
1478
- GRPC_LOG_IF_ERROR(err_desc, error);
1479
- }
1480
-
1481
- static void pollset_set_add_pollset_set(grpc_pollset_set* a,
1482
- grpc_pollset_set* b) {
1483
- GPR_TIMER_SCOPE("pollset_set_add_pollset_set", 0);
1484
- if (GRPC_TRACE_FLAG_ENABLED(grpc_polling_trace)) {
1485
- gpr_log(GPR_INFO, "PSS: merge (%p, %p)", a, b);
1486
- }
1487
- grpc_error_handle error = GRPC_ERROR_NONE;
1488
- static const char* err_desc = "pollset_set_add_fd";
1489
- for (;;) {
1490
- if (a == b) {
1491
- // pollset ancestors are the same: nothing to do
1492
- return;
1493
- }
1494
- if (a > b) {
1495
- std::swap(a, b);
1496
- }
1497
- gpr_mu* a_mu = &a->mu;
1498
- gpr_mu* b_mu = &b->mu;
1499
- gpr_mu_lock(a_mu);
1500
- gpr_mu_lock(b_mu);
1501
- if (a->parent != nullptr) {
1502
- a = a->parent;
1503
- } else if (b->parent != nullptr) {
1504
- b = b->parent;
1505
- } else {
1506
- break; // exit loop, both pollsets locked
1507
- }
1508
- gpr_mu_unlock(a_mu);
1509
- gpr_mu_unlock(b_mu);
1510
- }
1511
- // try to do the least copying possible
1512
- // TODO(sreek): there's probably a better heuristic here
1513
- const size_t a_size = a->fd_count + a->pollset_count;
1514
- const size_t b_size = b->fd_count + b->pollset_count;
1515
- if (b_size > a_size) {
1516
- std::swap(a, b);
1517
- }
1518
- if (GRPC_TRACE_FLAG_ENABLED(grpc_polling_trace)) {
1519
- gpr_log(GPR_INFO, "PSS: parent %p to %p", b, a);
1520
- }
1521
- a->refs.Ref();
1522
- b->parent = a;
1523
- if (a->fd_capacity < a->fd_count + b->fd_count) {
1524
- a->fd_capacity = std::max(2 * a->fd_capacity, a->fd_count + b->fd_count);
1525
- a->fds = static_cast<grpc_fd**>(
1526
- gpr_realloc(a->fds, a->fd_capacity * sizeof(*a->fds)));
1527
- }
1528
- size_t initial_a_fd_count = a->fd_count;
1529
- a->fd_count = 0;
1530
- append_error(
1531
- &error,
1532
- add_fds_to_pollsets(a->fds, initial_a_fd_count, b->pollsets,
1533
- b->pollset_count, "merge_a2b", a->fds, &a->fd_count),
1534
- err_desc);
1535
- append_error(
1536
- &error,
1537
- add_fds_to_pollsets(b->fds, b->fd_count, a->pollsets, a->pollset_count,
1538
- "merge_b2a", a->fds, &a->fd_count),
1539
- err_desc);
1540
- if (a->pollset_capacity < a->pollset_count + b->pollset_count) {
1541
- a->pollset_capacity =
1542
- std::max(2 * a->pollset_capacity, a->pollset_count + b->pollset_count);
1543
- a->pollsets = static_cast<grpc_pollset**>(
1544
- gpr_realloc(a->pollsets, a->pollset_capacity * sizeof(*a->pollsets)));
1545
- }
1546
- if (b->pollset_count > 0) {
1547
- memcpy(a->pollsets + a->pollset_count, b->pollsets,
1548
- b->pollset_count * sizeof(*b->pollsets));
1549
- }
1550
- a->pollset_count += b->pollset_count;
1551
- gpr_free(b->fds);
1552
- gpr_free(b->pollsets);
1553
- b->fds = nullptr;
1554
- b->pollsets = nullptr;
1555
- b->fd_count = b->fd_capacity = b->pollset_count = b->pollset_capacity = 0;
1556
- gpr_mu_unlock(&a->mu);
1557
- gpr_mu_unlock(&b->mu);
1558
- }
1559
-
1560
- static void pollset_set_del_pollset_set(grpc_pollset_set* /*bag*/,
1561
- grpc_pollset_set* /*item*/) {}
1562
-
1563
- /*******************************************************************************
1564
- * Event engine binding
1565
- */
1566
-
1567
- static bool is_any_background_poller_thread(void) { return false; }
1568
-
1569
- static void shutdown_background_closure(void) {}
1570
-
1571
- static bool add_closure_to_background_poller(grpc_closure* /*closure*/,
1572
- grpc_error_handle /*error*/) {
1573
- return false;
1574
- }
1575
-
1576
- static void shutdown_engine(void) {
1577
- fd_global_shutdown();
1578
- pollset_global_shutdown();
1579
- }
1580
-
1581
- static const grpc_event_engine_vtable vtable = {
1582
- sizeof(grpc_pollset),
1583
- true,
1584
- false,
1585
-
1586
- fd_create,
1587
- fd_wrapped_fd,
1588
- fd_orphan,
1589
- fd_shutdown,
1590
- fd_notify_on_read,
1591
- fd_notify_on_write,
1592
- fd_notify_on_error,
1593
- fd_become_readable,
1594
- fd_become_writable,
1595
- fd_has_errors,
1596
- fd_is_shutdown,
1597
-
1598
- pollset_init,
1599
- pollset_shutdown,
1600
- pollset_destroy,
1601
- pollset_work,
1602
- pollset_kick,
1603
- pollset_add_fd,
1604
-
1605
- pollset_set_create,
1606
- pollset_set_unref, // destroy ==> unref 1 public ref
1607
- pollset_set_add_pollset,
1608
- pollset_set_del_pollset,
1609
- pollset_set_add_pollset_set,
1610
- pollset_set_del_pollset_set,
1611
- pollset_set_add_fd,
1612
- pollset_set_del_fd,
1613
-
1614
- is_any_background_poller_thread,
1615
- shutdown_background_closure,
1616
- shutdown_engine,
1617
- add_closure_to_background_poller,
1618
- };
1619
-
1620
- const grpc_event_engine_vtable* grpc_init_epollex_linux(
1621
- bool /*explicitly_requested*/) {
1622
- if (!grpc_has_wakeup_fd()) {
1623
- gpr_log(GPR_ERROR, "Skipping epollex because of no wakeup fd.");
1624
- return nullptr;
1625
- }
1626
-
1627
- if (!grpc_is_epollexclusive_available()) {
1628
- gpr_log(GPR_INFO, "Skipping epollex because it is not supported.");
1629
- return nullptr;
1630
- }
1631
-
1632
- fd_global_init();
1633
-
1634
- if (!GRPC_LOG_IF_ERROR("pollset_global_init", pollset_global_init())) {
1635
- pollset_global_shutdown();
1636
- fd_global_shutdown();
1637
- return nullptr;
1638
- }
1639
-
1640
- return &vtable;
1641
- }
1642
-
1643
- #else /* defined(GRPC_LINUX_EPOLL_CREATE1) */
1644
- #if defined(GRPC_POSIX_SOCKET_EV_EPOLLEX)
1645
- #include "src/core/lib/iomgr/ev_epollex_linux.h"
1646
- /* If GRPC_LINUX_EPOLL_CREATE1 is not defined, it means
1647
- epoll_create1 is not available. Return NULL */
1648
- const grpc_event_engine_vtable* grpc_init_epollex_linux(
1649
- bool /*explicitly_requested*/) {
1650
- return nullptr;
1651
- }
1652
- #endif /* defined(GRPC_POSIX_SOCKET_EV_EPOLLEX) */
1653
-
1654
- #endif /* !defined(GRPC_LINUX_EPOLL_CREATE1) */