grpc 1.40.0.pre1 → 1.42.0.pre1

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 (1093) hide show
  1. checksums.yaml +4 -4
  2. data/Makefile +68 -64
  3. data/etc/roots.pem +335 -326
  4. data/include/grpc/byte_buffer.h +1 -1
  5. data/include/grpc/byte_buffer_reader.h +1 -1
  6. data/include/grpc/event_engine/endpoint_config.h +6 -11
  7. data/include/grpc/event_engine/event_engine.h +131 -86
  8. data/include/grpc/event_engine/internal/memory_allocator_impl.h +98 -0
  9. data/include/grpc/event_engine/memory_allocator.h +210 -0
  10. data/include/grpc/event_engine/port.h +1 -3
  11. data/include/grpc/fork.h +1 -1
  12. data/include/grpc/grpc.h +14 -4
  13. data/include/grpc/grpc_posix.h +5 -2
  14. data/include/grpc/grpc_security.h +18 -0
  15. data/include/grpc/grpc_security_constants.h +1 -0
  16. data/include/grpc/impl/codegen/atm.h +5 -3
  17. data/include/grpc/impl/codegen/atm_gcc_atomic.h +2 -0
  18. data/include/grpc/impl/codegen/atm_gcc_sync.h +2 -0
  19. data/include/grpc/impl/codegen/atm_windows.h +2 -0
  20. data/include/grpc/impl/codegen/byte_buffer.h +2 -0
  21. data/include/grpc/impl/codegen/byte_buffer_reader.h +2 -0
  22. data/include/grpc/impl/codegen/compression_types.h +2 -0
  23. data/include/grpc/impl/codegen/connectivity_state.h +2 -0
  24. data/include/grpc/impl/codegen/fork.h +2 -0
  25. data/include/grpc/impl/codegen/gpr_slice.h +2 -0
  26. data/include/grpc/impl/codegen/gpr_types.h +2 -0
  27. data/include/grpc/impl/codegen/grpc_types.h +4 -5
  28. data/include/grpc/impl/codegen/log.h +2 -0
  29. data/include/grpc/impl/codegen/port_platform.h +33 -22
  30. data/include/grpc/impl/codegen/propagation_bits.h +2 -0
  31. data/include/grpc/impl/codegen/slice.h +2 -0
  32. data/include/grpc/impl/codegen/status.h +2 -0
  33. data/include/grpc/impl/codegen/sync.h +8 -5
  34. data/include/grpc/impl/codegen/sync_abseil.h +2 -0
  35. data/include/grpc/impl/codegen/sync_custom.h +2 -0
  36. data/include/grpc/impl/codegen/sync_generic.h +3 -0
  37. data/include/grpc/impl/codegen/sync_posix.h +4 -2
  38. data/include/grpc/impl/codegen/sync_windows.h +2 -0
  39. data/include/grpc/slice.h +1 -1
  40. data/include/grpc/status.h +1 -1
  41. data/include/grpc/support/atm.h +1 -1
  42. data/include/grpc/support/atm_gcc_atomic.h +1 -1
  43. data/include/grpc/support/atm_gcc_sync.h +1 -1
  44. data/include/grpc/support/atm_windows.h +1 -1
  45. data/include/grpc/support/log.h +1 -1
  46. data/include/grpc/support/port_platform.h +1 -1
  47. data/include/grpc/support/sync.h +1 -1
  48. data/include/grpc/support/sync_abseil.h +1 -1
  49. data/include/grpc/support/sync_custom.h +1 -1
  50. data/include/grpc/support/sync_generic.h +1 -1
  51. data/include/grpc/support/sync_posix.h +1 -1
  52. data/include/grpc/support/sync_windows.h +1 -1
  53. data/include/grpc/support/time.h +2 -2
  54. data/src/core/ext/filters/census/grpc_context.cc +1 -0
  55. data/src/core/ext/filters/client_channel/backend_metric.cc +18 -20
  56. data/src/core/ext/filters/client_channel/backup_poller.cc +2 -1
  57. data/src/core/ext/filters/client_channel/backup_poller.h +1 -0
  58. data/src/core/ext/filters/client_channel/channel_connectivity.cc +72 -91
  59. data/src/core/ext/filters/client_channel/client_channel.cc +196 -289
  60. data/src/core/ext/filters/client_channel/client_channel.h +75 -28
  61. data/src/core/ext/filters/client_channel/client_channel_channelz.cc +6 -5
  62. data/src/core/ext/filters/client_channel/client_channel_channelz.h +1 -1
  63. data/src/core/ext/filters/client_channel/client_channel_factory.cc +2 -1
  64. data/src/core/ext/filters/client_channel/client_channel_factory.h +17 -19
  65. data/src/core/ext/filters/client_channel/client_channel_plugin.cc +16 -15
  66. data/src/core/ext/filters/client_channel/config_selector.cc +2 -1
  67. data/src/core/ext/filters/client_channel/config_selector.h +4 -5
  68. data/src/core/ext/filters/client_channel/connector.h +18 -18
  69. data/src/core/ext/filters/client_channel/dynamic_filters.cc +1 -1
  70. data/src/core/ext/filters/client_channel/global_subchannel_pool.h +0 -1
  71. data/src/core/ext/filters/client_channel/health/health_check_client.cc +19 -17
  72. data/src/core/ext/filters/client_channel/health/health_check_client.h +4 -3
  73. data/src/core/ext/filters/client_channel/http_connect_handshaker.cc +8 -7
  74. data/src/core/ext/filters/client_channel/http_connect_handshaker.h +10 -2
  75. data/src/core/ext/filters/client_channel/lb_policy/child_policy_handler.cc +6 -2
  76. data/src/core/ext/filters/client_channel/lb_policy/grpclb/client_load_reporting_filter.cc +6 -15
  77. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb.cc +168 -90
  78. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb.h +4 -0
  79. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_balancer_addresses.cc +1 -1
  80. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_channel_secure.cc +1 -2
  81. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_client_stats.cc +2 -2
  82. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_client_stats.h +2 -2
  83. data/src/core/ext/filters/client_channel/lb_policy/grpclb/load_balancer_api.cc +2 -3
  84. data/src/core/ext/filters/client_channel/lb_policy/pick_first/pick_first.cc +23 -7
  85. data/src/core/ext/filters/client_channel/lb_policy/priority/priority.cc +29 -33
  86. data/src/core/ext/filters/client_channel/lb_policy/ring_hash/ring_hash.cc +3 -3
  87. data/src/core/ext/filters/client_channel/lb_policy/rls/rls.cc +2502 -0
  88. data/src/core/ext/filters/client_channel/lb_policy/round_robin/round_robin.cc +6 -1
  89. data/src/core/ext/filters/client_channel/lb_policy/subchannel_list.h +2 -2
  90. data/src/core/ext/filters/client_channel/lb_policy/weighted_target/weighted_target.cc +9 -9
  91. data/src/core/ext/filters/client_channel/lb_policy/xds/cds.cc +21 -20
  92. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_channel_args.h +1 -1
  93. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_impl.cc +15 -7
  94. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_manager.cc +10 -9
  95. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_resolver.cc +9 -19
  96. data/src/core/ext/filters/client_channel/lb_policy.h +21 -44
  97. data/src/core/ext/filters/client_channel/lb_policy_factory.h +1 -0
  98. data/src/core/ext/filters/client_channel/lb_policy_registry.cc +4 -7
  99. data/src/core/ext/filters/client_channel/resolver/binder/binder_resolver.cc +139 -0
  100. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/dns_resolver_ares.cc +13 -15
  101. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver.h +1 -0
  102. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver_posix.cc +4 -3
  103. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver_windows.cc +9 -8
  104. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.cc +26 -58
  105. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.h +21 -1
  106. data/src/core/ext/filters/client_channel/resolver/dns/native/dns_resolver.cc +7 -2
  107. data/src/core/ext/filters/client_channel/resolver/fake/fake_resolver.cc +5 -3
  108. data/src/core/ext/filters/client_channel/resolver/google_c2p/google_c2p_resolver.cc +5 -5
  109. data/src/core/ext/filters/client_channel/resolver/xds/xds_resolver.cc +82 -76
  110. data/src/core/ext/filters/client_channel/resolver.h +1 -1
  111. data/src/core/ext/filters/client_channel/resolver_factory.h +2 -0
  112. data/src/core/ext/filters/client_channel/resolver_registry.cc +6 -8
  113. data/src/core/ext/filters/client_channel/resolver_result_parsing.cc +3 -4
  114. data/src/core/ext/filters/client_channel/resolver_result_parsing.h +1 -1
  115. data/src/core/ext/filters/client_channel/retry_filter.cc +64 -89
  116. data/src/core/ext/filters/client_channel/retry_service_config.h +1 -1
  117. data/src/core/ext/filters/client_channel/retry_throttle.cc +17 -48
  118. data/src/core/ext/filters/client_channel/server_address.h +1 -1
  119. data/src/core/ext/filters/client_channel/service_config_channel_arg_filter.cc +49 -36
  120. data/src/core/ext/filters/client_channel/subchannel.cc +85 -143
  121. data/src/core/ext/filters/client_channel/subchannel.h +29 -49
  122. data/src/core/ext/filters/client_channel/subchannel_pool_interface.cc +22 -7
  123. data/src/core/ext/filters/client_channel/subchannel_pool_interface.h +11 -2
  124. data/src/core/ext/filters/client_idle/client_idle_filter.cc +29 -206
  125. data/src/core/ext/filters/client_idle/idle_filter_state.cc +96 -0
  126. data/src/core/ext/filters/client_idle/idle_filter_state.h +66 -0
  127. data/src/core/ext/filters/deadline/deadline_filter.cc +23 -26
  128. data/src/core/ext/filters/fault_injection/fault_injection_filter.cc +27 -25
  129. data/src/core/ext/filters/fault_injection/service_config_parser.cc +6 -14
  130. data/src/core/ext/filters/fault_injection/service_config_parser.h +1 -1
  131. data/src/core/ext/filters/http/client/http_client_filter.cc +44 -46
  132. data/src/core/ext/filters/http/client_authority_filter.cc +16 -16
  133. data/src/core/ext/filters/http/http_filters_plugin.cc +53 -71
  134. data/src/core/ext/filters/http/message_compress/message_compress_filter.cc +19 -13
  135. data/src/core/ext/filters/http/message_compress/message_decompress_filter.cc +8 -9
  136. data/src/core/ext/filters/http/server/http_server_filter.cc +77 -72
  137. data/src/core/ext/filters/max_age/max_age_filter.cc +24 -26
  138. data/src/core/ext/filters/message_size/message_size_filter.cc +28 -29
  139. data/src/core/ext/filters/message_size/message_size_filter.h +1 -1
  140. data/src/core/ext/{filters/client_channel → service_config}/service_config.cc +2 -2
  141. data/src/core/ext/{filters/client_channel → service_config}/service_config.h +4 -4
  142. data/src/core/ext/service_config/service_config_call_data.h +72 -0
  143. data/src/core/ext/{filters/client_channel → service_config}/service_config_parser.cc +3 -3
  144. data/src/core/ext/{filters/client_channel → service_config}/service_config_parser.h +8 -6
  145. data/src/core/ext/transport/chttp2/alpn/alpn.cc +2 -1
  146. data/src/core/ext/transport/chttp2/client/chttp2_connector.cc +29 -15
  147. data/src/core/ext/transport/chttp2/client/chttp2_connector.h +2 -0
  148. data/src/core/ext/transport/chttp2/client/insecure/channel_create.cc +21 -27
  149. data/src/core/ext/transport/chttp2/client/insecure/channel_create_posix.cc +10 -6
  150. data/src/core/ext/transport/chttp2/client/secure/secure_channel_create.cc +29 -53
  151. data/src/core/ext/transport/chttp2/server/chttp2_server.cc +74 -53
  152. data/src/core/ext/transport/chttp2/server/insecure/server_chttp2.cc +0 -1
  153. data/src/core/ext/transport/chttp2/server/insecure/server_chttp2_posix.cc +12 -6
  154. data/src/core/ext/transport/chttp2/server/secure/server_secure_chttp2.cc +5 -9
  155. data/src/core/ext/transport/chttp2/transport/bin_decoder.cc +3 -1
  156. data/src/core/ext/transport/chttp2/transport/bin_decoder.h +2 -1
  157. data/src/core/ext/transport/chttp2/transport/bin_encoder.cc +1 -0
  158. data/src/core/ext/transport/chttp2/transport/chttp2_transport.cc +83 -88
  159. data/src/core/ext/transport/chttp2/transport/chttp2_transport.h +4 -1
  160. data/src/core/ext/transport/chttp2/transport/context_list.h +1 -2
  161. data/src/core/ext/transport/chttp2/transport/flow_control.cc +56 -37
  162. data/src/core/ext/transport/chttp2/transport/flow_control.h +13 -7
  163. data/src/core/ext/transport/chttp2/transport/frame_data.cc +11 -11
  164. data/src/core/ext/transport/chttp2/transport/frame_data.h +1 -0
  165. data/src/core/ext/transport/chttp2/transport/frame_goaway.cc +6 -4
  166. data/src/core/ext/transport/chttp2/transport/frame_goaway.h +1 -0
  167. data/src/core/ext/transport/chttp2/transport/frame_ping.cc +6 -5
  168. data/src/core/ext/transport/chttp2/transport/frame_ping.h +1 -0
  169. data/src/core/ext/transport/chttp2/transport/frame_rst_stream.cc +5 -8
  170. data/src/core/ext/transport/chttp2/transport/frame_rst_stream.h +1 -0
  171. data/src/core/ext/transport/chttp2/transport/frame_settings.cc +38 -7
  172. data/src/core/ext/transport/chttp2/transport/frame_settings.h +1 -0
  173. data/src/core/ext/transport/chttp2/transport/frame_window_update.cc +12 -7
  174. data/src/core/ext/transport/chttp2/transport/frame_window_update.h +1 -0
  175. data/src/core/ext/transport/chttp2/transport/hpack_constants.h +41 -0
  176. data/src/core/ext/transport/chttp2/transport/hpack_encoder.cc +311 -665
  177. data/src/core/ext/transport/chttp2/transport/hpack_encoder.h +240 -70
  178. data/src/core/ext/transport/chttp2/transport/hpack_encoder_index.h +107 -0
  179. data/src/core/ext/transport/chttp2/transport/hpack_encoder_table.cc +86 -0
  180. data/src/core/ext/transport/chttp2/transport/hpack_encoder_table.h +69 -0
  181. data/src/core/ext/transport/chttp2/transport/hpack_parser.cc +816 -1039
  182. data/src/core/ext/transport/chttp2/transport/hpack_parser.h +75 -177
  183. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.cc +146 -0
  184. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.h +137 -0
  185. data/src/core/ext/transport/chttp2/transport/hpack_utils.cc +46 -0
  186. data/src/core/{lib/transport/authority_override.h → ext/transport/chttp2/transport/hpack_utils.h} +8 -15
  187. data/src/core/ext/transport/chttp2/transport/internal.h +6 -5
  188. data/src/core/ext/transport/chttp2/transport/parsing.cc +50 -203
  189. data/src/core/ext/transport/chttp2/transport/popularity_count.h +60 -0
  190. data/src/core/ext/transport/chttp2/transport/stream_lists.cc +2 -2
  191. data/src/core/ext/transport/chttp2/transport/varint.cc +7 -3
  192. data/src/core/ext/transport/chttp2/transport/varint.h +39 -28
  193. data/src/core/ext/transport/chttp2/transport/writing.cc +61 -50
  194. data/src/core/ext/transport/inproc/inproc_transport.cc +111 -113
  195. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump.upb.c +96 -96
  196. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump.upb.h +221 -89
  197. data/src/core/ext/upb-generated/envoy/annotations/deprecation.upb.c +1 -1
  198. data/src/core/ext/upb-generated/envoy/annotations/deprecation.upb.h +1 -1
  199. data/src/core/ext/upb-generated/envoy/annotations/resource.upb.c +3 -3
  200. data/src/core/ext/upb-generated/envoy/annotations/resource.upb.h +11 -5
  201. data/src/core/ext/upb-generated/envoy/config/accesslog/v3/accesslog.upb.c +48 -48
  202. data/src/core/ext/upb-generated/envoy/config/accesslog/v3/accesslog.upb.h +151 -61
  203. data/src/core/ext/upb-generated/envoy/config/bootstrap/v3/bootstrap.upb.c +99 -99
  204. data/src/core/ext/upb-generated/envoy/config/bootstrap/v3/bootstrap.upb.h +171 -69
  205. data/src/core/ext/upb-generated/envoy/config/cluster/v3/circuit_breaker.upb.c +15 -15
  206. data/src/core/ext/upb-generated/envoy/config/cluster/v3/circuit_breaker.upb.h +31 -13
  207. data/src/core/ext/upb-generated/envoy/config/cluster/v3/cluster.upb.c +164 -131
  208. data/src/core/ext/upb-generated/envoy/config/cluster/v3/cluster.upb.h +368 -102
  209. data/src/core/ext/upb-generated/envoy/config/cluster/v3/filter.upb.c +4 -4
  210. data/src/core/ext/upb-generated/envoy/config/cluster/v3/filter.upb.h +11 -5
  211. data/src/core/ext/upb-generated/envoy/config/cluster/v3/outlier_detection.upb.c +23 -23
  212. data/src/core/ext/upb-generated/envoy/config/cluster/v3/outlier_detection.upb.h +11 -5
  213. data/src/core/ext/upb-generated/envoy/config/core/v3/address.upb.c +28 -28
  214. data/src/core/ext/upb-generated/envoy/config/core/v3/address.upb.h +71 -29
  215. data/src/core/ext/upb-generated/envoy/config/core/v3/backoff.upb.c +4 -4
  216. data/src/core/ext/upb-generated/envoy/config/core/v3/backoff.upb.h +11 -5
  217. data/src/core/ext/upb-generated/envoy/config/core/v3/base.upb.c +95 -83
  218. data/src/core/ext/upb-generated/envoy/config/core/v3/base.upb.h +254 -85
  219. data/src/core/ext/upb-generated/envoy/config/core/v3/config_source.upb.c +24 -24
  220. data/src/core/ext/upb-generated/envoy/config/core/v3/config_source.upb.h +51 -21
  221. data/src/core/ext/upb-generated/envoy/config/core/v3/event_service_config.upb.c +3 -3
  222. data/src/core/ext/upb-generated/envoy/config/core/v3/event_service_config.upb.h +11 -5
  223. data/src/core/ext/upb-generated/envoy/config/core/v3/extension.upb.c +9 -9
  224. data/src/core/ext/upb-generated/envoy/config/core/v3/extension.upb.h +21 -9
  225. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_service.upb.c +62 -62
  226. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_service.upb.h +131 -53
  227. data/src/core/ext/upb-generated/envoy/config/core/v3/health_check.upb.c +53 -52
  228. data/src/core/ext/upb-generated/envoy/config/core/v3/health_check.upb.h +96 -33
  229. data/src/core/ext/upb-generated/envoy/config/core/v3/http_uri.upb.c +5 -5
  230. data/src/core/ext/upb-generated/envoy/config/core/v3/http_uri.upb.h +11 -5
  231. data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.c +71 -66
  232. data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.h +164 -57
  233. data/src/core/ext/upb-generated/envoy/config/core/v3/proxy_protocol.upb.c +3 -3
  234. data/src/core/ext/upb-generated/envoy/config/core/v3/proxy_protocol.upb.h +11 -5
  235. data/src/core/ext/upb-generated/envoy/config/core/v3/resolver.upb.c +7 -7
  236. data/src/core/ext/upb-generated/envoy/config/core/v3/resolver.upb.h +21 -9
  237. data/src/core/ext/upb-generated/envoy/config/core/v3/socket_option.upb.c +8 -8
  238. data/src/core/ext/upb-generated/envoy/config/core/v3/socket_option.upb.h +11 -5
  239. data/src/core/ext/upb-generated/envoy/config/core/v3/substitution_format_string.upb.c +8 -8
  240. data/src/core/ext/upb-generated/envoy/config/core/v3/substitution_format_string.upb.h +11 -5
  241. data/src/core/ext/upb-generated/envoy/config/core/v3/udp_socket_config.upb.c +4 -4
  242. data/src/core/ext/upb-generated/envoy/config/core/v3/udp_socket_config.upb.h +11 -5
  243. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint.upb.c +16 -16
  244. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint.upb.h +31 -13
  245. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint_components.upb.c +56 -22
  246. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint_components.upb.h +174 -17
  247. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/load_report.upb.c +32 -32
  248. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/load_report.upb.h +51 -21
  249. data/src/core/ext/upb-generated/envoy/config/listener/v3/api_listener.upb.c +3 -3
  250. data/src/core/ext/upb-generated/envoy/config/listener/v3/api_listener.upb.h +11 -5
  251. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener.upb.c +37 -37
  252. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener.upb.h +61 -25
  253. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener_components.upb.c +40 -40
  254. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener_components.upb.h +71 -29
  255. data/src/core/ext/upb-generated/envoy/config/listener/v3/quic_config.upb.c +9 -9
  256. data/src/core/ext/upb-generated/envoy/config/listener/v3/quic_config.upb.h +11 -5
  257. data/src/core/ext/upb-generated/envoy/config/listener/v3/udp_listener_config.upb.c +5 -5
  258. data/src/core/ext/upb-generated/envoy/config/listener/v3/udp_listener_config.upb.h +21 -9
  259. data/src/core/ext/upb-generated/envoy/config/metrics/v3/stats.upb.c +30 -30
  260. data/src/core/ext/upb-generated/envoy/config/metrics/v3/stats.upb.h +81 -33
  261. data/src/core/ext/upb-generated/envoy/config/overload/v3/overload.upb.c +41 -29
  262. data/src/core/ext/upb-generated/envoy/config/overload/v3/overload.upb.h +141 -43
  263. data/src/core/ext/upb-generated/envoy/config/rbac/v3/rbac.upb.c +49 -43
  264. data/src/core/ext/upb-generated/envoy/config/rbac/v3/rbac.upb.h +105 -29
  265. data/src/core/ext/upb-generated/envoy/config/route/v3/route.upb.c +18 -18
  266. data/src/core/ext/upb-generated/envoy/config/route/v3/route.upb.h +31 -13
  267. data/src/core/ext/upb-generated/envoy/config/route/v3/route_components.upb.c +286 -279
  268. data/src/core/ext/upb-generated/envoy/config/route/v3/route_components.upb.h +618 -267
  269. data/src/core/ext/upb-generated/envoy/config/route/v3/scoped_route.upb.c +10 -10
  270. data/src/core/ext/upb-generated/envoy/config/route/v3/scoped_route.upb.h +31 -13
  271. data/src/core/ext/upb-generated/envoy/config/trace/v3/http_tracer.upb.c +6 -6
  272. data/src/core/ext/upb-generated/envoy/config/trace/v3/http_tracer.upb.h +21 -9
  273. data/src/core/ext/upb-generated/envoy/extensions/clusters/aggregate/v3/cluster.upb.c +3 -3
  274. data/src/core/ext/upb-generated/envoy/extensions/clusters/aggregate/v3/cluster.upb.h +11 -5
  275. data/src/core/ext/upb-generated/envoy/extensions/filters/common/fault/v3/fault.upb.c +13 -13
  276. data/src/core/ext/upb-generated/envoy/extensions/filters/common/fault/v3/fault.upb.h +51 -21
  277. data/src/core/ext/upb-generated/envoy/extensions/filters/http/fault/v3/fault.upb.c +23 -23
  278. data/src/core/ext/upb-generated/envoy/extensions/filters/http/fault/v3/fault.upb.h +31 -13
  279. data/src/core/ext/upb-generated/envoy/extensions/filters/http/router/v3/router.upb.c +9 -9
  280. data/src/core/ext/upb-generated/envoy/extensions/filters/http/router/v3/router.upb.h +11 -5
  281. data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.c +115 -116
  282. data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.h +191 -77
  283. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/cert.upb.c +1 -1
  284. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/cert.upb.h +1 -1
  285. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/common.upb.c +46 -32
  286. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/common.upb.h +118 -34
  287. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/secret.upb.c +12 -12
  288. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/secret.upb.h +31 -13
  289. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls.upb.c +44 -42
  290. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls.upb.h +108 -55
  291. data/src/core/ext/upb-generated/envoy/service/cluster/v3/cds.upb.c +2 -2
  292. data/src/core/ext/upb-generated/envoy/service/cluster/v3/cds.upb.h +11 -5
  293. data/src/core/ext/upb-generated/envoy/service/discovery/v3/ads.upb.c +2 -2
  294. data/src/core/ext/upb-generated/envoy/service/discovery/v3/ads.upb.h +11 -5
  295. data/src/core/ext/upb-generated/envoy/service/discovery/v3/discovery.upb.c +42 -42
  296. data/src/core/ext/upb-generated/envoy/service/discovery/v3/discovery.upb.h +61 -25
  297. data/src/core/ext/upb-generated/envoy/service/endpoint/v3/eds.upb.c +2 -2
  298. data/src/core/ext/upb-generated/envoy/service/endpoint/v3/eds.upb.h +11 -5
  299. data/src/core/ext/upb-generated/envoy/service/listener/v3/lds.upb.c +2 -2
  300. data/src/core/ext/upb-generated/envoy/service/listener/v3/lds.upb.h +11 -5
  301. data/src/core/ext/upb-generated/envoy/service/load_stats/v3/lrs.upb.c +9 -9
  302. data/src/core/ext/upb-generated/envoy/service/load_stats/v3/lrs.upb.h +21 -9
  303. data/src/core/ext/upb-generated/envoy/service/route/v3/rds.upb.c +2 -2
  304. data/src/core/ext/upb-generated/envoy/service/route/v3/rds.upb.h +11 -5
  305. data/src/core/ext/upb-generated/envoy/service/route/v3/srds.upb.c +2 -2
  306. data/src/core/ext/upb-generated/envoy/service/route/v3/srds.upb.h +11 -5
  307. data/src/core/ext/upb-generated/envoy/service/status/v3/csds.upb.c +28 -28
  308. data/src/core/ext/upb-generated/envoy/service/status/v3/csds.upb.h +51 -21
  309. data/src/core/ext/upb-generated/envoy/type/http/v3/path_transformation.upb.c +8 -8
  310. data/src/core/ext/upb-generated/envoy/type/http/v3/path_transformation.upb.h +41 -17
  311. data/src/core/ext/upb-generated/envoy/type/matcher/v3/metadata.upb.c +9 -8
  312. data/src/core/ext/upb-generated/envoy/type/matcher/v3/metadata.upb.h +25 -9
  313. data/src/core/ext/upb-generated/envoy/type/matcher/v3/node.upb.c +4 -4
  314. data/src/core/ext/upb-generated/envoy/type/matcher/v3/node.upb.h +11 -5
  315. data/src/core/ext/upb-generated/envoy/type/matcher/v3/number.upb.c +4 -4
  316. data/src/core/ext/upb-generated/envoy/type/matcher/v3/number.upb.h +11 -5
  317. data/src/core/ext/upb-generated/envoy/type/matcher/v3/path.upb.c +3 -3
  318. data/src/core/ext/upb-generated/envoy/type/matcher/v3/path.upb.h +11 -5
  319. data/src/core/ext/upb-generated/envoy/type/matcher/v3/regex.upb.c +9 -9
  320. data/src/core/ext/upb-generated/envoy/type/matcher/v3/regex.upb.h +31 -13
  321. data/src/core/ext/upb-generated/envoy/type/matcher/v3/string.upb.c +10 -10
  322. data/src/core/ext/upb-generated/envoy/type/matcher/v3/string.upb.h +21 -9
  323. data/src/core/ext/upb-generated/envoy/type/matcher/v3/struct.upb.c +6 -6
  324. data/src/core/ext/upb-generated/envoy/type/matcher/v3/struct.upb.h +21 -9
  325. data/src/core/ext/upb-generated/envoy/type/matcher/v3/value.upb.c +11 -11
  326. data/src/core/ext/upb-generated/envoy/type/matcher/v3/value.upb.h +31 -13
  327. data/src/core/ext/upb-generated/envoy/type/metadata/v3/metadata.upb.c +15 -15
  328. data/src/core/ext/upb-generated/envoy/type/metadata/v3/metadata.upb.h +71 -29
  329. data/src/core/ext/upb-generated/envoy/type/tracing/v3/custom_tag.upb.c +19 -19
  330. data/src/core/ext/upb-generated/envoy/type/tracing/v3/custom_tag.upb.h +51 -21
  331. data/src/core/ext/upb-generated/envoy/type/v3/http.upb.c +1 -1
  332. data/src/core/ext/upb-generated/envoy/type/v3/http.upb.h +1 -1
  333. data/src/core/ext/upb-generated/envoy/type/v3/percent.upb.c +6 -6
  334. data/src/core/ext/upb-generated/envoy/type/v3/percent.upb.h +21 -9
  335. data/src/core/ext/upb-generated/envoy/type/v3/range.upb.c +10 -10
  336. data/src/core/ext/upb-generated/envoy/type/v3/range.upb.h +31 -13
  337. data/src/core/ext/upb-generated/envoy/type/v3/semantic_version.upb.c +5 -5
  338. data/src/core/ext/upb-generated/envoy/type/v3/semantic_version.upb.h +11 -5
  339. data/src/core/ext/upb-generated/google/api/annotations.upb.c +1 -1
  340. data/src/core/ext/upb-generated/google/api/annotations.upb.h +1 -1
  341. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/checked.upb.c +58 -58
  342. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/checked.upb.h +111 -45
  343. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/syntax.upb.c +68 -68
  344. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/syntax.upb.h +121 -49
  345. data/src/core/ext/upb-generated/google/api/http.upb.c +18 -18
  346. data/src/core/ext/upb-generated/google/api/http.upb.h +31 -13
  347. data/src/core/ext/upb-generated/google/protobuf/any.upb.c +4 -4
  348. data/src/core/ext/upb-generated/google/protobuf/any.upb.h +11 -5
  349. data/src/core/ext/upb-generated/google/protobuf/descriptor.upb.c +153 -153
  350. data/src/core/ext/upb-generated/google/protobuf/descriptor.upb.h +271 -109
  351. data/src/core/ext/upb-generated/google/protobuf/duration.upb.c +4 -4
  352. data/src/core/ext/upb-generated/google/protobuf/duration.upb.h +11 -5
  353. data/src/core/ext/upb-generated/google/protobuf/empty.upb.c +2 -2
  354. data/src/core/ext/upb-generated/google/protobuf/empty.upb.h +11 -5
  355. data/src/core/ext/upb-generated/google/protobuf/struct.upb.c +15 -15
  356. data/src/core/ext/upb-generated/google/protobuf/struct.upb.h +31 -13
  357. data/src/core/ext/upb-generated/google/protobuf/timestamp.upb.c +4 -4
  358. data/src/core/ext/upb-generated/google/protobuf/timestamp.upb.h +11 -5
  359. data/src/core/ext/upb-generated/google/protobuf/wrappers.upb.c +19 -19
  360. data/src/core/ext/upb-generated/google/protobuf/wrappers.upb.h +91 -37
  361. data/src/core/ext/upb-generated/google/rpc/status.upb.c +5 -5
  362. data/src/core/ext/upb-generated/google/rpc/status.upb.h +11 -5
  363. data/src/core/ext/upb-generated/src/proto/grpc/gcp/altscontext.upb.c +12 -12
  364. data/src/core/ext/upb-generated/src/proto/grpc/gcp/altscontext.upb.h +11 -5
  365. data/src/core/ext/upb-generated/src/proto/grpc/gcp/handshaker.upb.c +60 -60
  366. data/src/core/ext/upb-generated/src/proto/grpc/gcp/handshaker.upb.h +101 -41
  367. data/src/core/ext/upb-generated/src/proto/grpc/gcp/transport_security_common.upb.c +7 -7
  368. data/src/core/ext/upb-generated/src/proto/grpc/gcp/transport_security_common.upb.h +21 -9
  369. data/src/core/ext/upb-generated/src/proto/grpc/health/v1/health.upb.c +5 -5
  370. data/src/core/ext/upb-generated/src/proto/grpc/health/v1/health.upb.h +21 -9
  371. data/src/core/ext/upb-generated/src/proto/grpc/lb/v1/load_balancer.upb.c +31 -31
  372. data/src/core/ext/upb-generated/src/proto/grpc/lb/v1/load_balancer.upb.h +91 -37
  373. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls.upb.c +55 -0
  374. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls.upb.h +154 -0
  375. data/src/core/ext/upb-generated/udpa/annotations/migrate.upb.c +8 -8
  376. data/src/core/ext/upb-generated/udpa/annotations/migrate.upb.h +31 -13
  377. data/src/core/ext/upb-generated/udpa/annotations/security.upb.c +4 -6
  378. data/src/core/ext/upb-generated/udpa/annotations/security.upb.h +11 -5
  379. data/src/core/ext/upb-generated/udpa/annotations/sensitive.upb.c +1 -1
  380. data/src/core/ext/upb-generated/udpa/annotations/sensitive.upb.h +1 -1
  381. data/src/core/ext/upb-generated/udpa/annotations/status.upb.c +4 -4
  382. data/src/core/ext/upb-generated/udpa/annotations/status.upb.h +11 -5
  383. data/src/core/ext/upb-generated/udpa/annotations/versioning.upb.c +3 -3
  384. data/src/core/ext/upb-generated/udpa/annotations/versioning.upb.h +11 -5
  385. data/src/core/ext/upb-generated/validate/validate.upb.c +220 -220
  386. data/src/core/ext/upb-generated/validate/validate.upb.h +231 -93
  387. data/src/core/ext/upb-generated/xds/annotations/v3/status.upb.c +58 -0
  388. data/src/core/ext/upb-generated/xds/annotations/v3/status.upb.h +182 -0
  389. data/src/core/ext/upb-generated/xds/core/v3/authority.upb.c +4 -4
  390. data/src/core/ext/upb-generated/xds/core/v3/authority.upb.h +11 -5
  391. data/src/core/ext/upb-generated/xds/core/v3/collection_entry.upb.c +9 -9
  392. data/src/core/ext/upb-generated/xds/core/v3/collection_entry.upb.h +21 -9
  393. data/src/core/ext/upb-generated/xds/core/v3/context_params.upb.c +7 -7
  394. data/src/core/ext/upb-generated/xds/core/v3/context_params.upb.h +11 -5
  395. data/src/core/ext/upb-generated/xds/core/v3/resource.upb.c +6 -6
  396. data/src/core/ext/upb-generated/xds/core/v3/resource.upb.h +11 -5
  397. data/src/core/ext/upb-generated/xds/core/v3/resource_locator.upb.c +12 -12
  398. data/src/core/ext/upb-generated/xds/core/v3/resource_locator.upb.h +21 -9
  399. data/src/core/ext/upb-generated/xds/core/v3/resource_name.upb.c +7 -7
  400. data/src/core/ext/upb-generated/xds/core/v3/resource_name.upb.h +11 -5
  401. data/src/core/ext/upb-generated/xds/data/orca/v3/orca_load_report.upb.c +58 -0
  402. data/src/core/ext/upb-generated/xds/data/orca/v3/orca_load_report.upb.h +130 -0
  403. data/src/core/ext/upb-generated/xds/type/v3/typed_struct.upb.c +33 -0
  404. data/src/core/ext/upb-generated/xds/type/v3/typed_struct.upb.h +83 -0
  405. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/cluster.upbdefs.c +410 -384
  406. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/cluster.upbdefs.h +10 -0
  407. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/base.upbdefs.c +101 -88
  408. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/base.upbdefs.h +5 -0
  409. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/health_check.upbdefs.c +59 -56
  410. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/protocol.upbdefs.c +59 -46
  411. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint_components.upbdefs.c +90 -63
  412. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint_components.upbdefs.h +10 -0
  413. data/src/core/ext/upbdefs-generated/envoy/config/overload/v3/overload.upbdefs.c +30 -19
  414. data/src/core/ext/upbdefs-generated/envoy/config/overload/v3/overload.upbdefs.h +5 -0
  415. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route_components.upbdefs.c +801 -783
  416. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.c +96 -100
  417. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.c +133 -115
  418. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.h +5 -0
  419. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls.upbdefs.c +178 -173
  420. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/metadata.upbdefs.c +14 -13
  421. data/src/core/ext/upbdefs-generated/google/protobuf/descriptor.upbdefs.c +103 -103
  422. data/src/core/ext/upbdefs-generated/udpa/annotations/migrate.upbdefs.c +5 -4
  423. data/src/core/ext/upbdefs-generated/udpa/annotations/security.upbdefs.c +19 -23
  424. data/src/core/ext/upbdefs-generated/udpa/annotations/sensitive.upbdefs.c +4 -3
  425. data/src/core/ext/upbdefs-generated/udpa/annotations/status.upbdefs.c +5 -3
  426. data/src/core/ext/upbdefs-generated/udpa/annotations/versioning.upbdefs.c +5 -4
  427. data/src/core/ext/upbdefs-generated/xds/annotations/v3/status.upbdefs.c +75 -0
  428. data/src/core/ext/upbdefs-generated/xds/annotations/v3/status.upbdefs.h +50 -0
  429. data/src/core/ext/upbdefs-generated/xds/core/v3/authority.upbdefs.c +13 -12
  430. data/src/core/ext/upbdefs-generated/xds/core/v3/collection_entry.upbdefs.c +25 -24
  431. data/src/core/ext/upbdefs-generated/xds/core/v3/context_params.upbdefs.c +16 -15
  432. data/src/core/ext/upbdefs-generated/xds/core/v3/resource.upbdefs.c +17 -16
  433. data/src/core/ext/upbdefs-generated/xds/core/v3/resource_locator.upbdefs.c +33 -32
  434. data/src/core/ext/upbdefs-generated/xds/core/v3/resource_name.upbdefs.c +19 -18
  435. data/src/core/ext/upbdefs-generated/xds/type/v3/typed_struct.upbdefs.c +45 -0
  436. data/src/core/ext/upbdefs-generated/xds/type/v3/typed_struct.upbdefs.h +35 -0
  437. data/src/core/ext/xds/certificate_provider_registry.cc +2 -2
  438. data/src/core/ext/xds/xds_api.cc +1140 -1314
  439. data/src/core/ext/xds/xds_api.h +150 -115
  440. data/src/core/ext/xds/xds_bootstrap.cc +27 -52
  441. data/src/core/ext/xds/xds_bootstrap.h +10 -0
  442. data/src/core/ext/xds/xds_certificate_provider.cc +3 -3
  443. data/src/core/ext/xds/xds_channel_stack_modifier.cc +113 -0
  444. data/src/core/ext/xds/xds_channel_stack_modifier.h +52 -0
  445. data/src/core/ext/xds/xds_client.cc +572 -320
  446. data/src/core/ext/xds/xds_client.h +42 -37
  447. data/src/core/ext/xds/xds_client_stats.cc +16 -15
  448. data/src/core/ext/xds/xds_client_stats.h +7 -7
  449. data/src/core/ext/xds/xds_http_fault_filter.cc +4 -3
  450. data/src/core/ext/xds/xds_http_fault_filter.h +3 -2
  451. data/src/core/ext/xds/xds_http_filters.cc +1 -0
  452. data/src/core/ext/xds/xds_server_config_fetcher.cc +15 -17
  453. data/src/core/lib/address_utils/parse_address.cc +6 -8
  454. data/src/core/lib/address_utils/sockaddr_utils.cc +2 -2
  455. data/src/core/lib/avl/avl.cc +5 -5
  456. data/src/core/lib/backoff/backoff.cc +1 -1
  457. data/src/core/lib/channel/channel_args.cc +26 -7
  458. data/src/core/lib/channel/channel_args.h +9 -0
  459. data/src/core/lib/channel/channel_stack.cc +5 -3
  460. data/src/core/lib/channel/channel_stack_builder.cc +4 -14
  461. data/src/core/lib/channel/channel_stack_builder.h +0 -8
  462. data/src/core/lib/channel/channel_trace.cc +5 -4
  463. data/src/core/lib/channel/channel_trace.h +2 -1
  464. data/src/core/lib/channel/channelz.cc +43 -39
  465. data/src/core/lib/channel/channelz.h +29 -29
  466. data/src/core/lib/channel/channelz_registry.cc +8 -7
  467. data/src/core/lib/channel/channelz_registry.h +1 -1
  468. data/src/core/lib/channel/connected_channel.cc +2 -3
  469. data/src/core/lib/channel/connected_channel.h +1 -2
  470. data/src/core/lib/channel/handshaker.cc +2 -1
  471. data/src/core/lib/channel/handshaker.h +1 -2
  472. data/src/core/lib/channel/handshaker_factory.h +10 -2
  473. data/src/core/lib/channel/handshaker_registry.cc +15 -70
  474. data/src/core/lib/channel/handshaker_registry.h +29 -12
  475. data/src/core/lib/channel/status_util.h +2 -2
  476. data/src/core/lib/compression/algorithm_metadata.h +1 -0
  477. data/src/core/lib/compression/compression.cc +2 -2
  478. data/src/core/lib/compression/compression_args.cc +8 -5
  479. data/src/core/lib/compression/compression_internal.cc +4 -6
  480. data/src/core/lib/compression/compression_internal.h +1 -1
  481. data/src/core/lib/compression/message_compress.cc +2 -2
  482. data/src/core/lib/compression/stream_compression.cc +2 -1
  483. data/src/core/lib/compression/stream_compression.h +2 -1
  484. data/src/core/lib/compression/stream_compression_gzip.cc +2 -1
  485. data/src/core/lib/compression/stream_compression_identity.cc +2 -1
  486. data/src/core/lib/config/core_configuration.cc +96 -0
  487. data/src/core/lib/config/core_configuration.h +146 -0
  488. data/src/core/lib/debug/stats.cc +1 -1
  489. data/src/core/lib/debug/stats.h +1 -0
  490. data/src/core/lib/debug/stats_data.cc +15 -14
  491. data/src/core/lib/debug/stats_data.h +1 -0
  492. data/src/core/lib/debug/trace.cc +1 -0
  493. data/src/core/lib/debug/trace.h +2 -1
  494. data/src/core/lib/event_engine/endpoint_config.cc +0 -1
  495. data/src/core/lib/event_engine/event_engine.cc +3 -3
  496. data/src/core/lib/event_engine/sockaddr.cc +3 -3
  497. data/src/core/lib/gpr/alloc.cc +4 -3
  498. data/src/core/lib/gpr/atm.cc +1 -1
  499. data/src/core/lib/gpr/cpu_posix.cc +1 -1
  500. data/src/core/lib/gpr/env_linux.cc +1 -2
  501. data/src/core/lib/gpr/env_posix.cc +2 -3
  502. data/src/core/lib/gpr/log.cc +3 -3
  503. data/src/core/lib/gpr/log_android.cc +3 -2
  504. data/src/core/lib/gpr/log_linux.cc +7 -4
  505. data/src/core/lib/gpr/log_posix.cc +6 -3
  506. data/src/core/lib/gpr/string.cc +2 -2
  507. data/src/core/lib/gpr/string.h +2 -2
  508. data/src/core/lib/gpr/sync.cc +2 -2
  509. data/src/core/lib/gpr/sync_abseil.cc +7 -6
  510. data/src/core/lib/gpr/sync_posix.cc +3 -3
  511. data/src/core/lib/gpr/time.cc +3 -2
  512. data/src/core/lib/gpr/time_windows.cc +3 -2
  513. data/src/core/lib/gpr/tls.h +119 -40
  514. data/src/core/lib/gpr/tmpfile_posix.cc +1 -2
  515. data/src/core/lib/gpr/useful.h +79 -32
  516. data/src/core/lib/gprpp/arena.cc +2 -1
  517. data/src/core/lib/gprpp/arena.h +15 -5
  518. data/src/core/lib/gprpp/atomic_utils.h +47 -0
  519. data/src/core/lib/gprpp/bitset.h +188 -0
  520. data/src/core/lib/gprpp/chunked_vector.h +211 -0
  521. data/src/core/lib/{transport/authority_override.cc → gprpp/construct_destruct.h} +16 -17
  522. data/src/core/lib/gprpp/dual_ref_counted.h +25 -26
  523. data/src/core/lib/gprpp/fork.cc +14 -12
  524. data/src/core/lib/gprpp/fork.h +4 -4
  525. data/src/core/lib/gprpp/global_config.h +1 -2
  526. data/src/core/lib/gprpp/global_config_env.cc +7 -7
  527. data/src/core/lib/gprpp/global_config_generic.h +2 -2
  528. data/src/core/lib/gprpp/manual_constructor.h +8 -5
  529. data/src/core/lib/gprpp/match.h +73 -0
  530. data/src/core/lib/gprpp/memory.h +9 -3
  531. data/src/core/lib/gprpp/mpscq.cc +7 -7
  532. data/src/core/lib/gprpp/mpscq.h +6 -5
  533. data/src/core/lib/gprpp/orphanable.h +3 -3
  534. data/src/core/lib/gprpp/overload.h +59 -0
  535. data/src/core/lib/gprpp/ref_counted.h +18 -18
  536. data/src/core/lib/gprpp/status_helper.cc +27 -7
  537. data/src/core/lib/gprpp/status_helper.h +12 -1
  538. data/src/core/lib/gprpp/sync.h +3 -1
  539. data/src/core/lib/gprpp/table.h +411 -0
  540. data/src/core/lib/gprpp/thd_posix.cc +5 -5
  541. data/src/core/lib/gprpp/thd_windows.cc +4 -11
  542. data/src/core/lib/gprpp/time_util.cc +2 -2
  543. data/src/core/lib/gprpp/time_util.h +2 -2
  544. data/src/core/lib/http/format_request.cc +1 -0
  545. data/src/core/lib/http/format_request.h +1 -0
  546. data/src/core/lib/http/httpcli.cc +202 -184
  547. data/src/core/lib/http/httpcli.h +3 -0
  548. data/src/core/lib/http/httpcli_security_connector.cc +5 -8
  549. data/src/core/lib/http/parser.cc +2 -2
  550. data/src/core/lib/http/parser.h +1 -0
  551. data/src/core/lib/iomgr/buffer_list.cc +2 -1
  552. data/src/core/lib/iomgr/buffer_list.h +1 -2
  553. data/src/core/lib/iomgr/call_combiner.cc +29 -10
  554. data/src/core/lib/iomgr/cfstream_handle.cc +1 -1
  555. data/src/core/lib/iomgr/combiner.cc +9 -23
  556. data/src/core/lib/iomgr/combiner.h +1 -0
  557. data/src/core/lib/iomgr/dualstack_socket_posix.cc +1 -0
  558. data/src/core/lib/iomgr/endpoint.cc +0 -4
  559. data/src/core/lib/iomgr/endpoint.h +1 -3
  560. data/src/core/lib/iomgr/endpoint_cfstream.cc +16 -26
  561. data/src/core/lib/iomgr/endpoint_cfstream.h +1 -1
  562. data/src/core/lib/iomgr/endpoint_pair.h +1 -0
  563. data/src/core/lib/iomgr/endpoint_pair_event_engine.cc +1 -2
  564. data/src/core/lib/iomgr/endpoint_pair_posix.cc +15 -11
  565. data/src/core/lib/iomgr/endpoint_pair_windows.cc +17 -9
  566. data/src/core/lib/iomgr/error.cc +113 -52
  567. data/src/core/lib/iomgr/error.h +73 -18
  568. data/src/core/lib/iomgr/error_cfstream.cc +7 -2
  569. data/src/core/lib/iomgr/error_internal.h +1 -0
  570. data/src/core/lib/iomgr/ev_epoll1_linux.cc +17 -24
  571. data/src/core/lib/iomgr/ev_epollex_linux.cc +22 -29
  572. data/src/core/lib/iomgr/ev_poll_posix.cc +42 -45
  573. data/src/core/lib/iomgr/ev_posix.cc +1 -2
  574. data/src/core/lib/iomgr/event_engine/closure.cc +41 -18
  575. data/src/core/lib/iomgr/event_engine/closure.h +10 -1
  576. data/src/core/lib/iomgr/event_engine/endpoint.cc +6 -25
  577. data/src/core/lib/iomgr/event_engine/endpoint.h +1 -2
  578. data/src/core/lib/iomgr/event_engine/iomgr.cc +18 -19
  579. data/src/core/lib/iomgr/event_engine/iomgr.h +20 -2
  580. data/src/core/lib/iomgr/event_engine/pollset.cc +5 -4
  581. data/src/core/lib/iomgr/event_engine/resolver.cc +12 -8
  582. data/src/core/lib/iomgr/event_engine/tcp.cc +60 -30
  583. data/src/core/lib/iomgr/event_engine/timer.cc +7 -2
  584. data/src/core/lib/iomgr/exec_ctx.cc +4 -13
  585. data/src/core/lib/iomgr/exec_ctx.h +11 -19
  586. data/src/core/lib/iomgr/executor/mpmcqueue.cc +15 -16
  587. data/src/core/lib/iomgr/executor/mpmcqueue.h +7 -11
  588. data/src/core/lib/iomgr/executor/threadpool.cc +2 -2
  589. data/src/core/lib/iomgr/executor/threadpool.h +2 -1
  590. data/src/core/lib/iomgr/executor.cc +11 -26
  591. data/src/core/lib/iomgr/grpc_if_nametoindex_posix.cc +2 -2
  592. data/src/core/lib/iomgr/grpc_if_nametoindex_unsupported.cc +2 -2
  593. data/src/core/lib/iomgr/internal_errqueue.cc +3 -2
  594. data/src/core/lib/iomgr/iocp_windows.cc +1 -0
  595. data/src/core/lib/iomgr/iomgr.cc +3 -1
  596. data/src/core/lib/iomgr/iomgr.h +2 -2
  597. data/src/core/lib/iomgr/iomgr_custom.cc +2 -2
  598. data/src/core/lib/iomgr/iomgr_custom.h +2 -2
  599. data/src/core/lib/iomgr/iomgr_internal.cc +6 -10
  600. data/src/core/lib/iomgr/iomgr_internal.h +3 -2
  601. data/src/core/lib/iomgr/iomgr_windows.cc +1 -2
  602. data/src/core/lib/iomgr/is_epollexclusive_available.cc +4 -4
  603. data/src/core/lib/iomgr/load_file.cc +2 -2
  604. data/src/core/lib/iomgr/lockfree_event.cc +18 -0
  605. data/src/core/lib/iomgr/polling_entity.cc +2 -2
  606. data/src/core/lib/iomgr/pollset_custom.cc +4 -5
  607. data/src/core/lib/iomgr/pollset_custom.h +3 -3
  608. data/src/core/lib/iomgr/pollset_set_custom.cc +1 -2
  609. data/src/core/lib/iomgr/pollset_set_windows.cc +1 -0
  610. data/src/core/lib/iomgr/port.h +0 -5
  611. data/src/core/lib/iomgr/python_util.h +1 -0
  612. data/src/core/lib/iomgr/resolve_address.cc +2 -1
  613. data/src/core/lib/iomgr/resolve_address.h +0 -4
  614. data/src/core/lib/iomgr/resolve_address_custom.cc +4 -4
  615. data/src/core/lib/iomgr/resolve_address_custom.h +0 -1
  616. data/src/core/lib/iomgr/resolve_address_posix.cc +7 -11
  617. data/src/core/lib/iomgr/resolve_address_windows.cc +6 -8
  618. data/src/core/lib/iomgr/resource_quota.cc +136 -49
  619. data/src/core/lib/iomgr/resource_quota.h +66 -17
  620. data/src/core/lib/iomgr/sockaddr.h +1 -1
  621. data/src/core/lib/iomgr/socket_factory_posix.cc +5 -5
  622. data/src/core/lib/iomgr/socket_factory_posix.h +1 -0
  623. data/src/core/lib/iomgr/socket_mutator.cc +2 -2
  624. data/src/core/lib/iomgr/socket_mutator.h +2 -2
  625. data/src/core/lib/iomgr/socket_utils_common_posix.cc +4 -5
  626. data/src/core/lib/iomgr/socket_utils_linux.cc +4 -4
  627. data/src/core/lib/iomgr/socket_utils_posix.cc +2 -2
  628. data/src/core/lib/iomgr/socket_utils_posix.h +2 -2
  629. data/src/core/lib/iomgr/socket_utils_windows.cc +2 -2
  630. data/src/core/lib/iomgr/tcp_client.cc +4 -2
  631. data/src/core/lib/iomgr/tcp_client.h +4 -0
  632. data/src/core/lib/iomgr/tcp_client_cfstream.cc +14 -22
  633. data/src/core/lib/iomgr/tcp_client_custom.cc +10 -18
  634. data/src/core/lib/iomgr/tcp_client_posix.cc +33 -27
  635. data/src/core/lib/iomgr/tcp_client_posix.h +5 -2
  636. data/src/core/lib/iomgr/tcp_client_windows.cc +16 -9
  637. data/src/core/lib/iomgr/tcp_custom.cc +11 -23
  638. data/src/core/lib/iomgr/tcp_custom.h +2 -1
  639. data/src/core/lib/iomgr/tcp_posix.cc +33 -64
  640. data/src/core/lib/iomgr/tcp_posix.h +11 -12
  641. data/src/core/lib/iomgr/tcp_server.cc +6 -4
  642. data/src/core/lib/iomgr/tcp_server.h +12 -9
  643. data/src/core/lib/iomgr/tcp_server_custom.cc +17 -34
  644. data/src/core/lib/iomgr/tcp_server_posix.cc +23 -17
  645. data/src/core/lib/iomgr/tcp_server_utils_posix.h +3 -0
  646. data/src/core/lib/iomgr/tcp_server_utils_posix_common.cc +1 -2
  647. data/src/core/lib/iomgr/tcp_server_utils_posix_ifaddrs.cc +3 -4
  648. data/src/core/lib/iomgr/tcp_server_utils_posix_noifaddrs.cc +4 -4
  649. data/src/core/lib/iomgr/tcp_server_windows.cc +17 -14
  650. data/src/core/lib/iomgr/tcp_windows.cc +8 -27
  651. data/src/core/lib/iomgr/tcp_windows.h +2 -1
  652. data/src/core/lib/iomgr/timer.cc +1 -0
  653. data/src/core/lib/iomgr/timer.h +1 -2
  654. data/src/core/lib/iomgr/timer_custom.cc +2 -2
  655. data/src/core/lib/iomgr/timer_generic.cc +21 -51
  656. data/src/core/lib/iomgr/timer_generic.h +1 -0
  657. data/src/core/lib/iomgr/timer_heap.cc +2 -3
  658. data/src/core/lib/iomgr/unix_sockets_posix.cc +3 -5
  659. data/src/core/lib/iomgr/unix_sockets_posix.h +2 -3
  660. data/src/core/lib/iomgr/wakeup_fd_nospecial.cc +1 -0
  661. data/src/core/lib/iomgr/wakeup_fd_pipe.cc +2 -3
  662. data/src/core/lib/iomgr/wakeup_fd_posix.cc +1 -0
  663. data/src/core/lib/iomgr/work_serializer.cc +4 -4
  664. data/src/core/lib/iomgr/work_serializer.h +1 -1
  665. data/src/core/lib/json/json_reader.cc +9 -17
  666. data/src/core/lib/json/json_util.cc +68 -0
  667. data/src/core/lib/json/json_util.h +65 -115
  668. data/src/core/lib/json/json_writer.cc +0 -3
  669. data/src/core/lib/matchers/matchers.h +0 -1
  670. data/src/core/lib/profiling/basic_timers.cc +8 -6
  671. data/src/core/lib/profiling/stap_timers.cc +2 -2
  672. data/src/core/lib/security/authorization/authorization_policy_provider.h +5 -4
  673. data/src/core/lib/security/authorization/authorization_policy_provider_vtable.cc +1 -1
  674. data/src/core/lib/security/authorization/evaluate_args.cc +16 -12
  675. data/src/core/lib/security/authorization/sdk_server_authz_filter.cc +171 -0
  676. data/src/core/lib/security/authorization/sdk_server_authz_filter.h +67 -0
  677. data/src/core/lib/security/context/security_context.cc +11 -8
  678. data/src/core/lib/security/credentials/alts/check_gcp_environment_linux.cc +2 -2
  679. data/src/core/lib/security/credentials/alts/check_gcp_environment_no_op.cc +2 -2
  680. data/src/core/lib/security/credentials/alts/check_gcp_environment_windows.cc +2 -2
  681. data/src/core/lib/security/credentials/composite/composite_credentials.cc +5 -4
  682. data/src/core/lib/security/credentials/credentials.cc +10 -8
  683. data/src/core/lib/security/credentials/credentials.h +7 -2
  684. data/src/core/lib/security/credentials/credentials_metadata.cc +2 -3
  685. data/src/core/lib/security/credentials/external/aws_external_account_credentials.cc +13 -26
  686. data/src/core/lib/security/credentials/external/aws_external_account_credentials.h +1 -2
  687. data/src/core/lib/security/credentials/external/aws_request_signer.cc +3 -3
  688. data/src/core/lib/security/credentials/external/external_account_credentials.cc +60 -33
  689. data/src/core/lib/security/credentials/external/external_account_credentials.h +1 -0
  690. data/src/core/lib/security/credentials/external/url_external_account_credentials.cc +2 -4
  691. data/src/core/lib/security/credentials/google_default/credentials_generic.cc +1 -2
  692. data/src/core/lib/security/credentials/google_default/google_default_credentials.cc +56 -4
  693. data/src/core/lib/security/credentials/iam/iam_credentials.cc +2 -1
  694. data/src/core/lib/security/credentials/jwt/json_token.cc +1 -1
  695. data/src/core/lib/security/credentials/jwt/json_token.h +2 -1
  696. data/src/core/lib/security/credentials/jwt/jwt_credentials.cc +31 -14
  697. data/src/core/lib/security/credentials/jwt/jwt_credentials.h +11 -3
  698. data/src/core/lib/security/credentials/jwt/jwt_verifier.cc +5 -11
  699. data/src/core/lib/security/credentials/jwt/jwt_verifier.h +3 -3
  700. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.cc +3 -7
  701. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.h +1 -0
  702. data/src/core/lib/security/credentials/plugin/plugin_credentials.cc +4 -6
  703. data/src/core/lib/security/credentials/ssl/ssl_credentials.cc +4 -4
  704. data/src/core/lib/security/credentials/ssl/ssl_credentials.h +0 -1
  705. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_distributor.cc +3 -2
  706. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_distributor.h +10 -6
  707. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.cc +2 -1
  708. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.h +7 -5
  709. data/src/core/lib/security/credentials/tls/grpc_tls_credentials_options.h +2 -2
  710. data/src/core/lib/security/security_connector/fake/fake_security_connector.cc +6 -8
  711. data/src/core/lib/security/security_connector/load_system_roots_fallback.cc +1 -0
  712. data/src/core/lib/security/security_connector/load_system_roots_linux.cc +3 -3
  713. data/src/core/lib/security/security_connector/security_connector.cc +9 -4
  714. data/src/core/lib/security/security_connector/security_connector.h +1 -1
  715. data/src/core/lib/security/security_connector/ssl/ssl_security_connector.cc +4 -7
  716. data/src/core/lib/security/security_connector/ssl/ssl_security_connector.h +1 -2
  717. data/src/core/lib/security/security_connector/ssl_utils.cc +3 -4
  718. data/src/core/lib/security/security_connector/tls/tls_security_connector.cc +10 -14
  719. data/src/core/lib/security/security_connector/tls/tls_security_connector.h +0 -2
  720. data/src/core/lib/security/transport/auth_filters.h +1 -0
  721. data/src/core/lib/security/transport/client_auth_filter.cc +9 -11
  722. data/src/core/lib/security/transport/secure_endpoint.cc +4 -14
  723. data/src/core/lib/security/transport/secure_endpoint.h +1 -0
  724. data/src/core/lib/security/transport/security_handshaker.cc +78 -47
  725. data/src/core/lib/security/transport/security_handshaker.h +2 -1
  726. data/src/core/lib/security/transport/server_auth_filter.cc +3 -5
  727. data/src/core/lib/security/transport/tsi_error.cc +3 -5
  728. data/src/core/lib/security/util/json_util.cc +6 -8
  729. data/src/core/lib/slice/percent_encoding.cc +73 -30
  730. data/src/core/lib/slice/percent_encoding.h +29 -28
  731. data/src/core/lib/slice/slice.cc +14 -21
  732. data/src/core/lib/{gpr/tls_pthread.cc → slice/slice_api.cc} +15 -6
  733. data/src/core/lib/slice/slice_buffer.cc +6 -7
  734. data/src/core/lib/slice/slice_intern.cc +10 -16
  735. data/src/core/lib/slice/slice_internal.h +3 -246
  736. data/src/core/lib/slice/slice_refcount.cc +17 -0
  737. data/src/core/lib/slice/slice_refcount.h +121 -0
  738. data/src/core/lib/slice/slice_refcount_base.h +173 -0
  739. data/src/core/lib/slice/slice_split.cc +100 -0
  740. data/src/core/lib/slice/slice_split.h +40 -0
  741. data/src/core/lib/slice/slice_string_helpers.cc +0 -83
  742. data/src/core/lib/slice/slice_string_helpers.h +0 -11
  743. data/src/core/lib/slice/static_slice.cc +529 -0
  744. data/src/core/lib/slice/static_slice.h +331 -0
  745. data/src/core/lib/surface/api_trace.cc +2 -1
  746. data/src/core/lib/surface/api_trace.h +1 -0
  747. data/src/core/lib/surface/builtins.cc +49 -0
  748. data/src/core/{ext/filters/workarounds/workaround_cronet_compression_filter.h → lib/surface/builtins.h} +8 -9
  749. data/src/core/lib/surface/byte_buffer_reader.cc +1 -1
  750. data/src/core/lib/surface/call.cc +112 -128
  751. data/src/core/lib/surface/call.h +3 -9
  752. data/src/core/lib/surface/call_details.cc +2 -2
  753. data/src/core/lib/surface/call_log_batch.cc +2 -2
  754. data/src/core/lib/surface/channel.cc +41 -41
  755. data/src/core/lib/surface/channel.h +14 -11
  756. data/src/core/lib/surface/channel_init.cc +23 -76
  757. data/src/core/lib/surface/channel_init.h +52 -44
  758. data/src/core/lib/surface/channel_ping.cc +1 -2
  759. data/src/core/lib/surface/channel_stack_type.cc +2 -1
  760. data/src/core/lib/surface/completion_queue.cc +60 -69
  761. data/src/core/lib/surface/completion_queue_factory.cc +2 -1
  762. data/src/core/lib/surface/completion_queue_factory.h +1 -0
  763. data/src/core/lib/surface/event_string.cc +1 -0
  764. data/src/core/lib/surface/init.cc +4 -48
  765. data/src/core/lib/surface/init.h +0 -1
  766. data/src/core/lib/surface/init_secure.cc +36 -14
  767. data/src/core/lib/surface/lame_client.cc +24 -16
  768. data/src/core/lib/surface/lame_client.h +1 -1
  769. data/src/core/lib/surface/metadata_array.cc +2 -2
  770. data/src/core/lib/surface/server.cc +42 -50
  771. data/src/core/lib/surface/server.h +28 -23
  772. data/src/core/lib/surface/validate_metadata.cc +49 -18
  773. data/src/core/lib/surface/version.cc +2 -2
  774. data/src/core/lib/transport/bdp_estimator.cc +1 -1
  775. data/src/core/lib/transport/byte_stream.h +1 -0
  776. data/src/core/lib/transport/connectivity_state.cc +8 -5
  777. data/src/core/lib/transport/connectivity_state.h +2 -2
  778. data/src/core/lib/transport/error_utils.cc +43 -17
  779. data/src/core/lib/transport/error_utils.h +1 -1
  780. data/src/core/lib/transport/metadata.cc +41 -20
  781. data/src/core/lib/transport/metadata.h +15 -12
  782. data/src/core/lib/transport/metadata_batch.cc +39 -364
  783. data/src/core/lib/transport/metadata_batch.h +916 -67
  784. data/src/core/lib/transport/parsed_metadata.h +263 -0
  785. data/src/core/lib/transport/pid_controller.cc +4 -4
  786. data/src/core/lib/transport/static_metadata.cc +714 -846
  787. data/src/core/lib/transport/static_metadata.h +115 -379
  788. data/src/core/lib/transport/status_metadata.cc +1 -0
  789. data/src/core/lib/transport/transport.cc +4 -5
  790. data/src/core/lib/transport/transport_op_string.cc +40 -20
  791. data/src/core/plugin_registry/grpc_plugin_registry.cc +76 -41
  792. data/src/core/tsi/alts/crypt/aes_gcm.cc +6 -3
  793. data/src/core/tsi/alts/crypt/gsec.h +2 -3
  794. data/src/core/tsi/alts/frame_protector/alts_frame_protector.cc +13 -12
  795. data/src/core/tsi/alts/frame_protector/frame_handler.cc +10 -11
  796. data/src/core/tsi/alts/handshaker/alts_handshaker_client.cc +3 -4
  797. data/src/core/tsi/alts/handshaker/alts_handshaker_client.h +2 -3
  798. data/src/core/tsi/alts/handshaker/alts_tsi_handshaker.cc +12 -2
  799. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_integrity_only_record_protocol.cc +2 -2
  800. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_record_protocol_common.cc +1 -1
  801. data/src/core/tsi/alts/zero_copy_frame_protector/alts_zero_copy_grpc_protector.cc +2 -2
  802. data/src/core/tsi/fake_transport_security.cc +15 -7
  803. data/src/core/tsi/local_transport_security.cc +36 -73
  804. data/src/core/tsi/ssl/session_cache/ssl_session_cache.cc +20 -53
  805. data/src/core/tsi/ssl/session_cache/ssl_session_cache.h +4 -3
  806. data/src/core/tsi/ssl/session_cache/ssl_session_openssl.cc +2 -2
  807. data/src/core/tsi/ssl_transport_security.cc +21 -11
  808. data/src/core/tsi/ssl_transport_security.h +3 -1
  809. data/src/core/tsi/transport_security.cc +15 -3
  810. data/src/core/tsi/transport_security.h +16 -1
  811. data/src/core/tsi/transport_security_grpc.h +1 -0
  812. data/src/core/tsi/transport_security_interface.h +26 -0
  813. data/src/ruby/ext/grpc/extconf.rb +12 -9
  814. data/src/ruby/ext/grpc/rb_byte_buffer.c +2 -1
  815. data/src/ruby/ext/grpc/rb_call.c +5 -5
  816. data/src/ruby/ext/grpc/rb_call_credentials.c +5 -5
  817. data/src/ruby/ext/grpc/rb_channel.c +10 -8
  818. data/src/ruby/ext/grpc/rb_channel_args.c +2 -2
  819. data/src/ruby/ext/grpc/rb_channel_credentials.c +4 -4
  820. data/src/ruby/ext/grpc/rb_channel_credentials.h +1 -0
  821. data/src/ruby/ext/grpc/rb_completion_queue.c +3 -2
  822. data/src/ruby/ext/grpc/rb_compression_options.c +5 -4
  823. data/src/ruby/ext/grpc/rb_event_thread.c +4 -4
  824. data/src/ruby/ext/grpc/rb_grpc.c +5 -4
  825. data/src/ruby/ext/grpc/rb_grpc.h +1 -0
  826. data/src/ruby/ext/grpc/rb_grpc_imports.generated.c +4 -0
  827. data/src/ruby/ext/grpc/rb_grpc_imports.generated.h +6 -0
  828. data/src/ruby/ext/grpc/rb_server.c +6 -5
  829. data/src/ruby/ext/grpc/rb_server_credentials.c +3 -3
  830. data/src/ruby/ext/grpc/rb_server_credentials.h +1 -0
  831. data/src/ruby/ext/grpc/rb_xds_channel_credentials.c +8 -5
  832. data/src/ruby/ext/grpc/rb_xds_channel_credentials.h +3 -1
  833. data/src/ruby/ext/grpc/rb_xds_server_credentials.c +6 -5
  834. data/src/ruby/ext/grpc/rb_xds_server_credentials.h +3 -1
  835. data/src/ruby/lib/grpc/version.rb +1 -1
  836. data/src/ruby/pb/src/proto/grpc/testing/test_pb.rb +2 -2
  837. data/src/ruby/spec/client_server_spec.rb +1 -1
  838. data/third_party/abseil-cpp/absl/base/internal/thread_identity.cc +4 -4
  839. data/third_party/abseil-cpp/absl/base/internal/thread_identity.h +11 -6
  840. data/third_party/address_sorting/address_sorting_posix.c +1 -0
  841. data/third_party/boringssl-with-bazel/err_data.c +300 -292
  842. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_bitstr.c +52 -47
  843. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_bool.c +21 -22
  844. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_d2i_fp.c +0 -2
  845. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_gentm.c +6 -1
  846. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_mbstr.c +16 -23
  847. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_object.c +14 -7
  848. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_print.c +19 -29
  849. data/third_party/boringssl-with-bazel/src/crypto/{x509 → asn1}/a_strex.c +269 -272
  850. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_strnid.c +106 -153
  851. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_time.c +3 -3
  852. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_type.c +1 -1
  853. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_utctm.c +1 -40
  854. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_utf8.c +1 -1
  855. data/third_party/boringssl-with-bazel/src/crypto/asn1/asn1_par.c +1 -1
  856. data/third_party/boringssl-with-bazel/src/crypto/{x509 → asn1}/charmap.h +0 -0
  857. data/third_party/boringssl-with-bazel/src/crypto/asn1/{asn1_locl.h → internal.h} +58 -1
  858. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_dec.c +9 -9
  859. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_enc.c +290 -199
  860. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_fre.c +9 -9
  861. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_new.c +10 -14
  862. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_utl.c +2 -1
  863. data/third_party/boringssl-with-bazel/src/crypto/asn1/time_support.c +1 -1
  864. data/third_party/boringssl-with-bazel/src/crypto/base64/base64.c +11 -8
  865. data/third_party/boringssl-with-bazel/src/crypto/bio/bio_mem.c +1 -7
  866. data/third_party/boringssl-with-bazel/src/crypto/bio/connect.c +1 -5
  867. data/third_party/boringssl-with-bazel/src/crypto/bio/fd.c +0 -4
  868. data/third_party/boringssl-with-bazel/src/crypto/bio/file.c +1 -7
  869. data/third_party/boringssl-with-bazel/src/crypto/bio/pair.c +1 -6
  870. data/third_party/boringssl-with-bazel/src/crypto/bio/socket.c +3 -17
  871. data/third_party/boringssl-with-bazel/src/crypto/blake2/blake2.c +4 -6
  872. data/third_party/boringssl-with-bazel/src/crypto/bytestring/cbb.c +9 -0
  873. data/third_party/boringssl-with-bazel/src/crypto/bytestring/cbs.c +8 -0
  874. data/third_party/boringssl-with-bazel/src/crypto/chacha/chacha.c +38 -47
  875. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/cipher_extra.c +45 -65
  876. data/third_party/boringssl-with-bazel/src/crypto/conf/conf.c +14 -3
  877. data/third_party/boringssl-with-bazel/src/crypto/digest_extra/digest_extra.c +6 -3
  878. data/third_party/boringssl-with-bazel/src/crypto/evp/scrypt.c +32 -34
  879. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/div.c +26 -9
  880. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/gcd_extra.c +3 -2
  881. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/internal.h +5 -2
  882. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/sqrt.c +5 -9
  883. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/e_aes.c +10 -0
  884. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/des/des.c +10 -11
  885. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/des/internal.h +1 -3
  886. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digest/digest.c +2 -0
  887. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/md4/md4.c +4 -7
  888. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/md5/md5.c +4 -7
  889. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/gcm_nohw.c +1 -1
  890. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/internal.h +5 -9
  891. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/rand.c +2 -2
  892. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/urandom.c +4 -6
  893. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/rsa.c +24 -9
  894. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/rsa_impl.c +4 -2
  895. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/sha1.c +35 -35
  896. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/sha256.c +11 -10
  897. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/sha512.c +10 -37
  898. data/third_party/boringssl-with-bazel/src/crypto/hpke/hpke.c +34 -0
  899. data/third_party/boringssl-with-bazel/src/crypto/hrss/hrss.c +219 -121
  900. data/third_party/boringssl-with-bazel/src/crypto/hrss/internal.h +9 -2
  901. data/third_party/boringssl-with-bazel/src/crypto/internal.h +62 -2
  902. data/third_party/boringssl-with-bazel/src/crypto/lhash/internal.h +253 -0
  903. data/third_party/boringssl-with-bazel/src/crypto/lhash/lhash.c +28 -23
  904. data/third_party/boringssl-with-bazel/src/crypto/mem.c +14 -9
  905. data/third_party/boringssl-with-bazel/src/crypto/obj/obj.c +7 -3
  906. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_all.c +0 -9
  907. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_info.c +0 -2
  908. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_lib.c +0 -8
  909. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_pk8.c +0 -2
  910. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_pkey.c +0 -4
  911. data/third_party/boringssl-with-bazel/src/crypto/pkcs7/internal.h +16 -7
  912. data/third_party/boringssl-with-bazel/src/crypto/pkcs7/pkcs7.c +9 -4
  913. data/third_party/boringssl-with-bazel/src/crypto/pkcs7/pkcs7_x509.c +151 -12
  914. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/pkcs8_x509.c +1 -1
  915. data/third_party/boringssl-with-bazel/src/crypto/poly1305/poly1305.c +1 -1
  916. data/third_party/boringssl-with-bazel/src/crypto/pool/pool.c +1 -0
  917. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/deterministic.c +4 -0
  918. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/fuchsia.c +4 -0
  919. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/windows.c +4 -0
  920. data/third_party/boringssl-with-bazel/src/crypto/siphash/siphash.c +6 -6
  921. data/third_party/boringssl-with-bazel/src/crypto/x509/a_verify.c +15 -11
  922. data/third_party/boringssl-with-bazel/src/crypto/x509/algorithm.c +1 -1
  923. data/third_party/boringssl-with-bazel/src/crypto/x509/by_dir.c +1 -0
  924. data/third_party/boringssl-with-bazel/src/crypto/x509/by_file.c +2 -0
  925. data/third_party/boringssl-with-bazel/src/crypto/x509/internal.h +225 -2
  926. data/third_party/boringssl-with-bazel/src/crypto/x509/name_print.c +246 -0
  927. data/third_party/boringssl-with-bazel/src/crypto/x509/rsa_pss.c +15 -4
  928. data/third_party/boringssl-with-bazel/src/crypto/x509/t_crl.c +10 -5
  929. data/third_party/boringssl-with-bazel/src/crypto/x509/t_x509.c +0 -179
  930. data/third_party/boringssl-with-bazel/src/crypto/x509/t_x509a.c +4 -2
  931. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_att.c +6 -23
  932. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_ext.c +2 -2
  933. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_lu.c +1 -5
  934. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_obj.c +1 -0
  935. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_v3.c +25 -22
  936. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_vfy.c +11 -54
  937. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_vpm.c +1 -1
  938. data/third_party/boringssl-with-bazel/src/crypto/x509/x509cset.c +1 -0
  939. data/third_party/boringssl-with-bazel/src/crypto/x509/x509name.c +2 -4
  940. data/third_party/boringssl-with-bazel/src/crypto/x509/x_algor.c +1 -3
  941. data/third_party/boringssl-with-bazel/src/crypto/x509/x_all.c +0 -16
  942. data/third_party/boringssl-with-bazel/src/crypto/x509/x_crl.c +9 -11
  943. data/third_party/boringssl-with-bazel/src/crypto/x509/x_exten.c +2 -0
  944. data/third_party/boringssl-with-bazel/src/crypto/x509/x_name.c +23 -21
  945. data/third_party/boringssl-with-bazel/src/crypto/x509/x_x509.c +12 -11
  946. data/third_party/boringssl-with-bazel/src/crypto/x509v3/internal.h +16 -0
  947. data/third_party/boringssl-with-bazel/src/crypto/x509v3/pcy_cache.c +1 -0
  948. data/third_party/boringssl-with-bazel/src/crypto/x509v3/pcy_data.c +1 -1
  949. data/third_party/boringssl-with-bazel/src/crypto/x509v3/pcy_int.h +1 -1
  950. data/third_party/boringssl-with-bazel/src/crypto/x509v3/pcy_map.c +1 -0
  951. data/third_party/boringssl-with-bazel/src/crypto/x509v3/pcy_tree.c +4 -3
  952. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_akey.c +24 -5
  953. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_alt.c +17 -8
  954. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_bitst.c +3 -0
  955. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_conf.c +1 -0
  956. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_cpols.c +6 -6
  957. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_crld.c +4 -2
  958. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_enum.c +5 -0
  959. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_lib.c +2 -0
  960. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_ncons.c +112 -55
  961. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_pci.c +2 -1
  962. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_prn.c +14 -13
  963. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_purp.c +1 -1
  964. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_utl.c +76 -31
  965. data/third_party/boringssl-with-bazel/src/include/openssl/asn1.h +521 -296
  966. data/third_party/boringssl-with-bazel/src/include/openssl/asn1t.h +2 -9
  967. data/third_party/boringssl-with-bazel/src/include/openssl/base.h +10 -5
  968. data/third_party/boringssl-with-bazel/src/include/openssl/bio.h +3 -1
  969. data/third_party/boringssl-with-bazel/src/include/openssl/bn.h +3 -3
  970. data/third_party/boringssl-with-bazel/src/include/openssl/bytestring.h +9 -0
  971. data/third_party/boringssl-with-bazel/src/include/openssl/cipher.h +8 -2
  972. data/third_party/boringssl-with-bazel/src/include/openssl/conf.h +8 -5
  973. data/third_party/boringssl-with-bazel/src/include/openssl/digest.h +3 -0
  974. data/third_party/boringssl-with-bazel/src/include/openssl/evp.h +6 -0
  975. data/third_party/boringssl-with-bazel/src/include/openssl/hkdf.h +4 -0
  976. data/third_party/boringssl-with-bazel/src/include/openssl/hpke.h +25 -0
  977. data/third_party/boringssl-with-bazel/src/include/openssl/hrss.h +14 -12
  978. data/third_party/boringssl-with-bazel/src/include/openssl/lhash.h +4 -205
  979. data/third_party/boringssl-with-bazel/src/include/openssl/mem.h +12 -3
  980. data/third_party/boringssl-with-bazel/src/include/openssl/obj.h +5 -4
  981. data/third_party/boringssl-with-bazel/src/include/openssl/pem.h +0 -20
  982. data/third_party/boringssl-with-bazel/src/include/openssl/pkcs7.h +12 -5
  983. data/third_party/boringssl-with-bazel/src/include/openssl/rsa.h +5 -0
  984. data/third_party/boringssl-with-bazel/src/include/openssl/span.h +37 -15
  985. data/third_party/boringssl-with-bazel/src/include/openssl/ssl.h +81 -15
  986. data/third_party/boringssl-with-bazel/src/include/openssl/tls1.h +31 -32
  987. data/third_party/boringssl-with-bazel/src/include/openssl/x509.h +713 -146
  988. data/third_party/boringssl-with-bazel/src/include/openssl/x509_vfy.h +16 -695
  989. data/third_party/boringssl-with-bazel/src/include/openssl/x509v3.h +48 -13
  990. data/third_party/boringssl-with-bazel/src/ssl/d1_both.cc +9 -16
  991. data/third_party/boringssl-with-bazel/src/ssl/encrypted_client_hello.cc +310 -359
  992. data/third_party/boringssl-with-bazel/src/ssl/{t1_lib.cc → extensions.cc} +110 -159
  993. data/third_party/boringssl-with-bazel/src/ssl/handshake.cc +24 -13
  994. data/third_party/boringssl-with-bazel/src/ssl/handshake_client.cc +145 -142
  995. data/third_party/boringssl-with-bazel/src/ssl/handshake_server.cc +106 -99
  996. data/third_party/boringssl-with-bazel/src/ssl/internal.h +87 -48
  997. data/third_party/boringssl-with-bazel/src/ssl/s3_lib.cc +1 -2
  998. data/third_party/boringssl-with-bazel/src/ssl/ssl_cipher.cc +2 -2
  999. data/third_party/boringssl-with-bazel/src/ssl/ssl_key_share.cc +11 -5
  1000. data/third_party/boringssl-with-bazel/src/ssl/ssl_lib.cc +2 -51
  1001. data/third_party/boringssl-with-bazel/src/ssl/ssl_session.cc +121 -65
  1002. data/third_party/boringssl-with-bazel/src/ssl/ssl_transcript.cc +6 -12
  1003. data/third_party/boringssl-with-bazel/src/ssl/ssl_x509.cc +28 -23
  1004. data/third_party/boringssl-with-bazel/src/ssl/tls13_both.cc +14 -27
  1005. data/third_party/boringssl-with-bazel/src/ssl/tls13_client.cc +210 -212
  1006. data/third_party/boringssl-with-bazel/src/ssl/tls13_enc.cc +30 -41
  1007. data/third_party/boringssl-with-bazel/src/ssl/tls13_server.cc +48 -34
  1008. data/third_party/re2/re2/compile.cc +91 -109
  1009. data/third_party/re2/re2/dfa.cc +27 -39
  1010. data/third_party/re2/re2/filtered_re2.cc +18 -2
  1011. data/third_party/re2/re2/filtered_re2.h +10 -5
  1012. data/third_party/re2/re2/nfa.cc +1 -1
  1013. data/third_party/re2/re2/parse.cc +42 -23
  1014. data/third_party/re2/re2/perl_groups.cc +34 -34
  1015. data/third_party/re2/re2/prefilter.cc +3 -2
  1016. data/third_party/re2/re2/prog.cc +182 -4
  1017. data/third_party/re2/re2/prog.h +28 -9
  1018. data/third_party/re2/re2/re2.cc +87 -118
  1019. data/third_party/re2/re2/re2.h +156 -141
  1020. data/third_party/re2/re2/regexp.cc +12 -5
  1021. data/third_party/re2/re2/regexp.h +8 -2
  1022. data/third_party/re2/re2/set.cc +31 -9
  1023. data/third_party/re2/re2/set.h +9 -4
  1024. data/third_party/re2/re2/simplify.cc +11 -3
  1025. data/third_party/re2/re2/tostring.cc +1 -1
  1026. data/third_party/re2/re2/walker-inl.h +1 -1
  1027. data/third_party/re2/util/mutex.h +2 -2
  1028. data/third_party/re2/util/pcre.h +3 -3
  1029. data/third_party/upb/upb/decode.c +129 -60
  1030. data/third_party/upb/upb/decode.h +32 -4
  1031. data/third_party/upb/upb/decode_fast.c +513 -500
  1032. data/third_party/upb/upb/decode_fast.h +27 -0
  1033. data/third_party/upb/upb/{decode.int.h → decode_internal.h} +38 -8
  1034. data/third_party/upb/upb/def.c +171 -181
  1035. data/third_party/upb/upb/def.h +41 -19
  1036. data/third_party/upb/upb/def.hpp +29 -0
  1037. data/third_party/upb/upb/encode.c +49 -16
  1038. data/third_party/upb/upb/encode.h +29 -2
  1039. data/third_party/upb/upb/msg.c +169 -28
  1040. data/third_party/upb/upb/msg.h +75 -580
  1041. data/third_party/upb/upb/msg_internal.h +687 -0
  1042. data/third_party/upb/upb/port_def.inc +85 -24
  1043. data/third_party/upb/upb/port_undef.inc +38 -1
  1044. data/third_party/upb/upb/reflection.c +29 -37
  1045. data/third_party/upb/upb/reflection.h +36 -8
  1046. data/third_party/upb/upb/reflection.hpp +37 -0
  1047. data/third_party/upb/upb/table.c +211 -86
  1048. data/third_party/upb/upb/{table.int.h → table_internal.h} +56 -180
  1049. data/third_party/upb/upb/text_encode.c +32 -4
  1050. data/third_party/upb/upb/text_encode.h +26 -0
  1051. data/third_party/upb/upb/upb.c +59 -8
  1052. data/third_party/upb/upb/upb.h +36 -6
  1053. data/third_party/upb/upb/upb.hpp +24 -0
  1054. data/third_party/upb/upb/upb_internal.h +58 -0
  1055. metadata +102 -87
  1056. data/include/grpc/event_engine/slice_allocator.h +0 -66
  1057. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver_libuv.cc +0 -179
  1058. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper_libuv.cc +0 -38
  1059. data/src/core/ext/filters/client_channel/service_config_call_data.h +0 -126
  1060. data/src/core/ext/filters/workarounds/workaround_cronet_compression_filter.cc +0 -211
  1061. data/src/core/ext/filters/workarounds/workaround_utils.cc +0 -53
  1062. data/src/core/ext/filters/workarounds/workaround_utils.h +0 -39
  1063. data/src/core/ext/transport/chttp2/client/authority.cc +0 -42
  1064. data/src/core/ext/transport/chttp2/client/authority.h +0 -36
  1065. data/src/core/ext/transport/chttp2/transport/chttp2_slice_allocator.cc +0 -66
  1066. data/src/core/ext/transport/chttp2/transport/chttp2_slice_allocator.h +0 -74
  1067. data/src/core/ext/transport/chttp2/transport/hpack_table.cc +0 -243
  1068. data/src/core/ext/transport/chttp2/transport/hpack_table.h +0 -148
  1069. data/src/core/ext/transport/chttp2/transport/incoming_metadata.cc +0 -66
  1070. data/src/core/ext/transport/chttp2/transport/incoming_metadata.h +0 -58
  1071. data/src/core/ext/upb-generated/udpa/data/orca/v1/orca_load_report.upb.c +0 -58
  1072. data/src/core/ext/upb-generated/udpa/data/orca/v1/orca_load_report.upb.h +0 -124
  1073. data/src/core/ext/upb-generated/udpa/type/v1/typed_struct.upb.c +0 -33
  1074. data/src/core/ext/upb-generated/udpa/type/v1/typed_struct.upb.h +0 -77
  1075. data/src/core/ext/upbdefs-generated/udpa/type/v1/typed_struct.upbdefs.c +0 -44
  1076. data/src/core/ext/upbdefs-generated/udpa/type/v1/typed_struct.upbdefs.h +0 -35
  1077. data/src/core/lib/gpr/tls_gcc.h +0 -52
  1078. data/src/core/lib/gpr/tls_msvc.h +0 -54
  1079. data/src/core/lib/gpr/tls_pthread.h +0 -56
  1080. data/src/core/lib/gpr/tls_stdcpp.h +0 -48
  1081. data/src/core/lib/gprpp/atomic.h +0 -104
  1082. data/src/core/lib/iomgr/endpoint_pair_uv.cc +0 -40
  1083. data/src/core/lib/iomgr/iomgr_uv.cc +0 -43
  1084. data/src/core/lib/iomgr/pollset_uv.cc +0 -95
  1085. data/src/core/lib/iomgr/pollset_uv.h +0 -36
  1086. data/src/core/lib/iomgr/sockaddr_custom.h +0 -54
  1087. data/src/core/lib/iomgr/socket_utils_uv.cc +0 -49
  1088. data/src/core/lib/iomgr/tcp_uv.cc +0 -421
  1089. data/src/core/lib/iomgr/timer_uv.cc +0 -66
  1090. data/src/core/lib/iomgr/udp_server.cc +0 -748
  1091. data/src/core/lib/iomgr/udp_server.h +0 -103
  1092. data/third_party/upb/third_party/wyhash/wyhash.h +0 -145
  1093. data/third_party/upb/upb/upb.int.h +0 -29
@@ -102,18 +102,6 @@ class XdsClient : public DualRefCounted<XdsClient> {
102
102
 
103
103
  grpc_pollset_set* interested_parties() const { return interested_parties_; }
104
104
 
105
- // TODO(roth): When we add federation, there will be multiple channels
106
- // inside the XdsClient, and the set of channels may change over time,
107
- // but not every channel may use every one of the child channels, so
108
- // this API will need to change. At minumum, we will need to hold a
109
- // ref to the parent channelz node so that we can update its list of
110
- // children as the set of xDS channels changes. However, we may also
111
- // want to make this a bit more selective such that only those
112
- // channels on which a given parent channel is actually requesting
113
- // resources will actually be marked as its children.
114
- void AddChannelzLinkage(channelz::ChannelNode* parent_channelz_node);
115
- void RemoveChannelzLinkage(channelz::ChannelNode* parent_channelz_node);
116
-
117
105
  void Orphan() override;
118
106
 
119
107
  // Start and cancel listener data watch for a listener.
@@ -210,12 +198,7 @@ class XdsClient : public DualRefCounted<XdsClient> {
210
198
  private:
211
199
  // Contains a channel to the xds server and all the data related to the
212
200
  // channel. Holds a ref to the xds client object.
213
- //
214
- // Currently, there is only one ChannelState object per XdsClient
215
- // object, and it has essentially the same lifetime. But in the
216
- // future, when we add federation support, a single XdsClient may have
217
- // multiple underlying channels to talk to different xDS servers.
218
- class ChannelState : public InternallyRefCounted<ChannelState> {
201
+ class ChannelState : public DualRefCounted<ChannelState> {
219
202
  public:
220
203
  template <typename T>
221
204
  class RetryableCall;
@@ -243,9 +226,11 @@ class XdsClient : public DualRefCounted<XdsClient> {
243
226
  void StartConnectivityWatchLocked();
244
227
  void CancelConnectivityWatchLocked();
245
228
 
246
- void SubscribeLocked(const std::string& type_url, const std::string& name)
229
+ void SubscribeLocked(const std::string& type_url,
230
+ const XdsApi::ResourceName& resource)
247
231
  ABSL_EXCLUSIVE_LOCKS_REQUIRED(&XdsClient::mu_);
248
- void UnsubscribeLocked(const std::string& type_url, const std::string& name,
232
+ void UnsubscribeLocked(const std::string& type_url,
233
+ const XdsApi::ResourceName& resource,
249
234
  bool delay_unsubscription)
250
235
  ABSL_EXCLUSIVE_LOCKS_REQUIRED(&XdsClient::mu_);
251
236
 
@@ -260,11 +245,15 @@ class XdsClient : public DualRefCounted<XdsClient> {
260
245
  // The channel and its status.
261
246
  grpc_channel* channel_;
262
247
  bool shutting_down_ = false;
263
- StateWatcher* watcher_ = nullptr;
248
+ StateWatcher* watcher_;
264
249
 
265
250
  // The retryable XDS calls.
266
251
  OrphanablePtr<RetryableCall<AdsCallState>> ads_calld_;
267
252
  OrphanablePtr<RetryableCall<LrsCallState>> lrs_calld_;
253
+
254
+ // Stores the most recent accepted resource version for each resource type.
255
+ std::map<std::string /*type*/, std::string /*version*/>
256
+ resource_type_version_map_;
268
257
  };
269
258
 
270
259
  struct ListenerState {
@@ -302,6 +291,20 @@ class XdsClient : public DualRefCounted<XdsClient> {
302
291
  XdsApi::ResourceMetadata meta;
303
292
  };
304
293
 
294
+ struct AuthorityState {
295
+ RefCountedPtr<ChannelState> channel_state;
296
+ std::map<std::string /*listener_name*/, ListenerState> listener_map;
297
+ std::map<std::string /*route_config_name*/, RouteConfigState>
298
+ route_config_map;
299
+ std::map<std::string /*cluster_name*/, ClusterState> cluster_map;
300
+ std::map<std::string /*eds_service_name*/, EndpointState> endpoint_map;
301
+
302
+ bool HasSubscribedResources() {
303
+ return !listener_map.empty() || !route_config_map.empty() ||
304
+ !cluster_map.empty() || !endpoint_map.empty();
305
+ }
306
+ };
307
+
305
308
  struct LoadReportState {
306
309
  struct LocalityState {
307
310
  XdsClusterLocalityStats* locality_stats = nullptr;
@@ -324,6 +327,9 @@ class XdsClient : public DualRefCounted<XdsClient> {
324
327
  bool send_all_clusters, const std::set<std::string>& clusters)
325
328
  ABSL_EXCLUSIVE_LOCKS_REQUIRED(mu_);
326
329
 
330
+ RefCountedPtr<ChannelState> GetOrCreateChannelStateLocked(
331
+ const XdsBootstrap::XdsServer& server) ABSL_EXCLUSIVE_LOCKS_REQUIRED(mu_);
332
+
327
333
  std::unique_ptr<XdsBootstrap> bootstrap_;
328
334
  grpc_channel_args* args_;
329
335
  const grpc_millis request_timeout_;
@@ -333,20 +339,11 @@ class XdsClient : public DualRefCounted<XdsClient> {
333
339
 
334
340
  Mutex mu_;
335
341
 
336
- // The channel for communicating with the xds server.
337
- OrphanablePtr<ChannelState> chand_ ABSL_GUARDED_BY(mu_);
338
-
339
- // One entry for each watched LDS resource.
340
- std::map<std::string /*listener_name*/, ListenerState> listener_map_
341
- ABSL_GUARDED_BY(mu_);
342
- // One entry for each watched RDS resource.
343
- std::map<std::string /*route_config_name*/, RouteConfigState>
344
- route_config_map_ ABSL_GUARDED_BY(mu_);
345
- // One entry for each watched CDS resource.
346
- std::map<std::string /*cluster_name*/, ClusterState> cluster_map_
342
+ // Map of existing xDS server channels.
343
+ std::map<XdsBootstrap::XdsServer, ChannelState*> xds_server_channel_map_
347
344
  ABSL_GUARDED_BY(mu_);
348
- // One entry for each watched EDS resource.
349
- std::map<std::string /*eds_service_name*/, EndpointState> endpoint_map_
345
+
346
+ std::map<std::string /*authority*/, AuthorityState> authority_state_map_
350
347
  ABSL_GUARDED_BY(mu_);
351
348
 
352
349
  // Load report data.
@@ -355,9 +352,17 @@ class XdsClient : public DualRefCounted<XdsClient> {
355
352
  LoadReportState>
356
353
  load_report_map_ ABSL_GUARDED_BY(mu_);
357
354
 
358
- // Stores the most recent accepted resource version for each resource type.
359
- std::map<std::string /*type*/, std::string /*version*/> resource_version_map_
360
- ABSL_GUARDED_BY(mu_);
355
+ // Stores started watchers whose resource name was not parsed successfully,
356
+ // waiting to be cancelled or reset in Orphan().
357
+ std::map<ListenerWatcherInterface*, std::unique_ptr<ListenerWatcherInterface>>
358
+ invalid_listener_watchers_ ABSL_GUARDED_BY(mu_);
359
+ std::map<RouteConfigWatcherInterface*,
360
+ std::unique_ptr<RouteConfigWatcherInterface>>
361
+ invalid_route_config_watchers_ ABSL_GUARDED_BY(mu_);
362
+ std::map<ClusterWatcherInterface*, std::unique_ptr<ClusterWatcherInterface>>
363
+ invalid_cluster_watchers_ ABSL_GUARDED_BY(mu_);
364
+ std::map<EndpointWatcherInterface*, std::unique_ptr<EndpointWatcherInterface>>
365
+ invalid_endpoint_watchers_ ABSL_GUARDED_BY(mu_);
361
366
 
362
367
  bool shutting_down_ ABSL_GUARDED_BY(mu_) = false;
363
368
  };
@@ -31,8 +31,8 @@ namespace grpc_core {
31
31
 
32
32
  namespace {
33
33
 
34
- uint64_t GetAndResetCounter(Atomic<uint64_t>* from) {
35
- return from->Exchange(0, MemoryOrder::RELAXED);
34
+ uint64_t GetAndResetCounter(std::atomic<uint64_t>* from) {
35
+ return from->exchange(0, std::memory_order_relaxed);
36
36
  }
37
37
 
38
38
  } // namespace
@@ -82,7 +82,7 @@ XdsClusterDropStats::Snapshot XdsClusterDropStats::GetSnapshotAndReset() {
82
82
  }
83
83
 
84
84
  void XdsClusterDropStats::AddUncategorizedDrops() {
85
- uncategorized_drops_.FetchAdd(1);
85
+ uncategorized_drops_.fetch_add(1);
86
86
  }
87
87
 
88
88
  void XdsClusterDropStats::AddCallDropped(const std::string& category) {
@@ -132,28 +132,29 @@ XdsClusterLocalityStats::~XdsClusterLocalityStats() {
132
132
 
133
133
  XdsClusterLocalityStats::Snapshot
134
134
  XdsClusterLocalityStats::GetSnapshotAndReset() {
135
- Snapshot snapshot = {GetAndResetCounter(&total_successful_requests_),
136
- // Don't reset total_requests_in_progress because it's
137
- // not related to a single reporting interval.
138
- total_requests_in_progress_.Load(MemoryOrder::RELAXED),
139
- GetAndResetCounter(&total_error_requests_),
140
- GetAndResetCounter(&total_issued_requests_),
141
- {}};
135
+ Snapshot snapshot = {
136
+ GetAndResetCounter(&total_successful_requests_),
137
+ // Don't reset total_requests_in_progress because it's
138
+ // not related to a single reporting interval.
139
+ total_requests_in_progress_.load(std::memory_order_relaxed),
140
+ GetAndResetCounter(&total_error_requests_),
141
+ GetAndResetCounter(&total_issued_requests_),
142
+ {}};
142
143
  MutexLock lock(&backend_metrics_mu_);
143
144
  snapshot.backend_metrics = std::move(backend_metrics_);
144
145
  return snapshot;
145
146
  }
146
147
 
147
148
  void XdsClusterLocalityStats::AddCallStarted() {
148
- total_issued_requests_.FetchAdd(1, MemoryOrder::RELAXED);
149
- total_requests_in_progress_.FetchAdd(1, MemoryOrder::RELAXED);
149
+ total_issued_requests_.fetch_add(1, std::memory_order_relaxed);
150
+ total_requests_in_progress_.fetch_add(1, std::memory_order_relaxed);
150
151
  }
151
152
 
152
153
  void XdsClusterLocalityStats::AddCallFinished(bool fail) {
153
- Atomic<uint64_t>& to_increment =
154
+ std::atomic<uint64_t>& to_increment =
154
155
  fail ? total_error_requests_ : total_successful_requests_;
155
- to_increment.FetchAdd(1, MemoryOrder::RELAXED);
156
- total_requests_in_progress_.FetchAdd(-1, MemoryOrder::ACQ_REL);
156
+ to_increment.fetch_add(1, std::memory_order_relaxed);
157
+ total_requests_in_progress_.fetch_add(-1, std::memory_order_acq_rel);
157
158
  }
158
159
 
159
160
  } // namespace grpc_core
@@ -21,6 +21,7 @@
21
21
 
22
22
  #include <grpc/support/port_platform.h>
23
23
 
24
+ #include <atomic>
24
25
  #include <map>
25
26
  #include <string>
26
27
 
@@ -29,7 +30,6 @@
29
30
  #include "absl/strings/string_view.h"
30
31
 
31
32
  #include "src/core/lib/gpr/useful.h"
32
- #include "src/core/lib/gprpp/atomic.h"
33
33
  #include "src/core/lib/gprpp/memory.h"
34
34
  #include "src/core/lib/gprpp/ref_counted.h"
35
35
  #include "src/core/lib/gprpp/sync.h"
@@ -46,7 +46,7 @@ class XdsLocalityName : public RefCounted<XdsLocalityName> {
46
46
  struct Less {
47
47
  bool operator()(const XdsLocalityName* lhs,
48
48
  const XdsLocalityName* rhs) const {
49
- if (lhs == nullptr || rhs == nullptr) return GPR_ICMP(lhs, rhs);
49
+ if (lhs == nullptr || rhs == nullptr) return QsortCompare(lhs, rhs);
50
50
  return lhs->Compare(*rhs) < 0;
51
51
  }
52
52
 
@@ -144,7 +144,7 @@ class XdsClusterDropStats : public RefCounted<XdsClusterDropStats> {
144
144
  absl::string_view lrs_server_name_;
145
145
  absl::string_view cluster_name_;
146
146
  absl::string_view eds_service_name_;
147
- Atomic<uint64_t> uncategorized_drops_{0};
147
+ std::atomic<uint64_t> uncategorized_drops_{0};
148
148
  // Protects categorized_drops_. A mutex is necessary because the length of
149
149
  // dropped_requests can be accessed by both the picker (from data plane
150
150
  // mutex) and the load reporting thread (from the control plane combiner).
@@ -221,10 +221,10 @@ class XdsClusterLocalityStats : public RefCounted<XdsClusterLocalityStats> {
221
221
  absl::string_view eds_service_name_;
222
222
  RefCountedPtr<XdsLocalityName> name_;
223
223
 
224
- Atomic<uint64_t> total_successful_requests_{0};
225
- Atomic<uint64_t> total_requests_in_progress_{0};
226
- Atomic<uint64_t> total_error_requests_{0};
227
- Atomic<uint64_t> total_issued_requests_{0};
224
+ std::atomic<uint64_t> total_successful_requests_{0};
225
+ std::atomic<uint64_t> total_requests_in_progress_{0};
226
+ std::atomic<uint64_t> total_error_requests_{0};
227
+ std::atomic<uint64_t> total_issued_requests_{0};
228
228
 
229
229
  // Protects backend_metrics_. A mutex is necessary because the length of
230
230
  // backend_metrics_ can be accessed by both the callback intercepting the
@@ -18,8 +18,6 @@
18
18
 
19
19
  #include "src/core/ext/xds/xds_http_fault_filter.h"
20
20
 
21
- #include <grpc/grpc.h>
22
-
23
21
  #include <string>
24
22
 
25
23
  #include "absl/status/statusor.h"
@@ -33,6 +31,10 @@
33
31
  #include "google/protobuf/any.upb.h"
34
32
  #include "google/protobuf/duration.upb.h"
35
33
  #include "google/protobuf/wrappers.upb.h"
34
+ #include "upb/def.h"
35
+
36
+ #include <grpc/grpc.h>
37
+
36
38
  #include "src/core/ext/filters/fault_injection/fault_injection_filter.h"
37
39
  #include "src/core/ext/xds/xds_http_filters.h"
38
40
  #include "src/core/lib/channel/channel_args.h"
@@ -40,7 +42,6 @@
40
42
  #include "src/core/lib/channel/status_util.h"
41
43
  #include "src/core/lib/json/json.h"
42
44
  #include "src/core/lib/transport/status_conversion.h"
43
- #include "upb/def.h"
44
45
 
45
46
  namespace grpc_core {
46
47
 
@@ -19,11 +19,12 @@
19
19
 
20
20
  #include <grpc/support/port_platform.h>
21
21
 
22
+ #include "absl/status/statusor.h"
23
+ #include "upb/def.h"
24
+
22
25
  #include <grpc/grpc.h>
23
26
 
24
- #include "absl/status/statusor.h"
25
27
  #include "src/core/ext/xds/xds_http_filters.h"
26
- #include "upb/def.h"
27
28
 
28
29
  namespace grpc_core {
29
30
 
@@ -20,6 +20,7 @@
20
20
 
21
21
  #include "envoy/extensions/filters/http/router/v3/router.upb.h"
22
22
  #include "envoy/extensions/filters/http/router/v3/router.upbdefs.h"
23
+
23
24
  #include "src/core/ext/xds/xds_http_fault_filter.h"
24
25
 
25
26
  namespace grpc_core {
@@ -259,12 +259,12 @@ FilterChainMatchManager::CreateOrGetXdsCertificateProviderFromFilterChainData(
259
259
  // Configure root cert.
260
260
  absl::string_view root_provider_instance_name =
261
261
  filter_chain->downstream_tls_context.common_tls_context
262
- .combined_validation_context
263
- .validation_context_certificate_provider_instance.instance_name;
262
+ .certificate_validation_context.ca_certificate_provider_instance
263
+ .instance_name;
264
264
  absl::string_view root_provider_cert_name =
265
265
  filter_chain->downstream_tls_context.common_tls_context
266
- .combined_validation_context
267
- .validation_context_certificate_provider_instance.certificate_name;
266
+ .certificate_validation_context.ca_certificate_provider_instance
267
+ .certificate_name;
268
268
  if (!root_provider_instance_name.empty()) {
269
269
  certificate_providers.root =
270
270
  xds_client_->certificate_provider_store()
@@ -278,10 +278,10 @@ FilterChainMatchManager::CreateOrGetXdsCertificateProviderFromFilterChainData(
278
278
  // Configure identity cert.
279
279
  absl::string_view identity_provider_instance_name =
280
280
  filter_chain->downstream_tls_context.common_tls_context
281
- .tls_certificate_certificate_provider_instance.instance_name;
281
+ .tls_certificate_provider_instance.instance_name;
282
282
  absl::string_view identity_provider_cert_name =
283
283
  filter_chain->downstream_tls_context.common_tls_context
284
- .tls_certificate_certificate_provider_instance.certificate_name;
284
+ .tls_certificate_provider_instance.certificate_name;
285
285
  if (!identity_provider_instance_name.empty()) {
286
286
  certificate_providers.instance =
287
287
  xds_client_->certificate_provider_store()
@@ -353,12 +353,12 @@ class XdsServerConfigFetcher : public grpc_server_config_fetcher {
353
353
  GPR_ASSERT(xds_client_ != nullptr);
354
354
  }
355
355
 
356
- void StartWatch(std::string listening_address, grpc_channel_args* args,
356
+ void StartWatch(std::string listening_address,
357
357
  std::unique_ptr<grpc_server_config_fetcher::WatcherInterface>
358
358
  watcher) override {
359
359
  grpc_server_config_fetcher::WatcherInterface* watcher_ptr = watcher.get();
360
360
  auto listener_watcher = absl::make_unique<ListenerWatcher>(
361
- std::move(watcher), args, xds_client_, serving_status_notifier_,
361
+ std::move(watcher), xds_client_, serving_status_notifier_,
362
362
  listening_address);
363
363
  auto* listener_watcher_ptr = listener_watcher.get();
364
364
  listening_address = absl::StrReplaceAll(
@@ -396,17 +396,14 @@ class XdsServerConfigFetcher : public grpc_server_config_fetcher {
396
396
  explicit ListenerWatcher(
397
397
  std::unique_ptr<grpc_server_config_fetcher::WatcherInterface>
398
398
  server_config_watcher,
399
- grpc_channel_args* args, RefCountedPtr<XdsClient> xds_client,
399
+ RefCountedPtr<XdsClient> xds_client,
400
400
  grpc_server_xds_status_notifier serving_status_notifier,
401
401
  std::string listening_address)
402
402
  : server_config_watcher_(std::move(server_config_watcher)),
403
- args_(args),
404
403
  xds_client_(std::move(xds_client)),
405
404
  serving_status_notifier_(serving_status_notifier),
406
405
  listening_address_(std::move(listening_address)) {}
407
406
 
408
- ~ListenerWatcher() override { grpc_channel_args_destroy(args_); }
409
-
410
407
  // Deleted due to special handling required for args_. Copy the channel args
411
408
  // if we ever need these.
412
409
  ListenerWatcher(const ListenerWatcher&) = delete;
@@ -428,7 +425,7 @@ class XdsServerConfigFetcher : public grpc_server_config_fetcher {
428
425
  if (serving_status_notifier_.on_serving_status_update != nullptr) {
429
426
  serving_status_notifier_.on_serving_status_update(
430
427
  serving_status_notifier_.user_data, listening_address_.c_str(),
431
- GRPC_STATUS_OK, "");
428
+ {GRPC_STATUS_OK, ""});
432
429
  } else {
433
430
  gpr_log(GPR_INFO,
434
431
  "xDS Listener resource obtained; will start serving on %s",
@@ -459,7 +456,7 @@ class XdsServerConfigFetcher : public grpc_server_config_fetcher {
459
456
  if (serving_status_notifier_.on_serving_status_update != nullptr) {
460
457
  serving_status_notifier_.on_serving_status_update(
461
458
  serving_status_notifier_.user_data, listening_address_.c_str(),
462
- GRPC_STATUS_UNAVAILABLE, grpc_error_std_string(error).c_str());
459
+ {GRPC_STATUS_UNAVAILABLE, grpc_error_std_string(error).c_str()});
463
460
  } else {
464
461
  gpr_log(
465
462
  GPR_ERROR,
@@ -486,8 +483,8 @@ class XdsServerConfigFetcher : public grpc_server_config_fetcher {
486
483
  if (serving_status_notifier_.on_serving_status_update != nullptr) {
487
484
  serving_status_notifier_.on_serving_status_update(
488
485
  serving_status_notifier_.user_data, listening_address_.c_str(),
489
- static_cast<grpc_status_code>(status.raw_code()),
490
- std::string(status.message()).c_str());
486
+ {static_cast<grpc_status_code>(status.raw_code()),
487
+ std::string(status.message()).c_str()});
491
488
  }
492
489
  }
493
490
 
@@ -498,7 +495,6 @@ class XdsServerConfigFetcher : public grpc_server_config_fetcher {
498
495
  private:
499
496
  std::unique_ptr<grpc_server_config_fetcher::WatcherInterface>
500
497
  server_config_watcher_;
501
- grpc_channel_args* args_;
502
498
  RefCountedPtr<XdsClient> xds_client_;
503
499
  grpc_server_xds_status_notifier serving_status_notifier_;
504
500
  std::string listening_address_;
@@ -524,10 +520,12 @@ grpc_server_config_fetcher* grpc_server_config_fetcher_xds_create(
524
520
  grpc_server_xds_status_notifier notifier, const grpc_channel_args* args) {
525
521
  grpc_core::ApplicationCallbackExecCtx callback_exec_ctx;
526
522
  grpc_core::ExecCtx exec_ctx;
523
+ args = grpc_channel_args_remove_grpc_internal(args);
527
524
  GRPC_API_TRACE("grpc_server_config_fetcher_xds_create()", 0, ());
528
525
  grpc_error_handle error = GRPC_ERROR_NONE;
529
526
  grpc_core::RefCountedPtr<grpc_core::XdsClient> xds_client =
530
527
  grpc_core::XdsClient::GetOrCreate(args, &error);
528
+ grpc_channel_args_destroy(args);
531
529
  if (error != GRPC_ERROR_NONE) {
532
530
  gpr_log(GPR_ERROR, "Failed to create xds client: %s",
533
531
  grpc_error_std_string(error).c_str());
@@ -83,14 +83,13 @@ namespace grpc_core {
83
83
 
84
84
  grpc_error_handle UnixSockaddrPopulate(absl::string_view path,
85
85
  grpc_resolved_address* resolved_addr) {
86
+ memset(resolved_addr, 0, sizeof(*resolved_addr));
86
87
  struct sockaddr_un* un =
87
88
  reinterpret_cast<struct sockaddr_un*>(resolved_addr->addr);
88
89
  const size_t maxlen = sizeof(un->sun_path) - 1;
89
90
  if (path.size() > maxlen) {
90
- return GRPC_ERROR_CREATE_FROM_COPIED_STRING(
91
- absl::StrCat("Path name should not have more than ", maxlen,
92
- " characters")
93
- .c_str());
91
+ return GRPC_ERROR_CREATE_FROM_CPP_STRING(absl::StrCat(
92
+ "Path name should not have more than ", maxlen, " characters"));
94
93
  }
95
94
  un->sun_family = AF_UNIX;
96
95
  path.copy(un->sun_path, path.size());
@@ -101,14 +100,13 @@ grpc_error_handle UnixSockaddrPopulate(absl::string_view path,
101
100
 
102
101
  grpc_error_handle UnixAbstractSockaddrPopulate(
103
102
  absl::string_view path, grpc_resolved_address* resolved_addr) {
103
+ memset(resolved_addr, 0, sizeof(*resolved_addr));
104
104
  struct sockaddr_un* un =
105
105
  reinterpret_cast<struct sockaddr_un*>(resolved_addr->addr);
106
106
  const size_t maxlen = sizeof(un->sun_path) - 1;
107
107
  if (path.size() > maxlen) {
108
- return GRPC_ERROR_CREATE_FROM_COPIED_STRING(
109
- absl::StrCat("Path name should not have more than ", maxlen,
110
- " characters")
111
- .c_str());
108
+ return GRPC_ERROR_CREATE_FROM_CPP_STRING(absl::StrCat(
109
+ "Path name should not have more than ", maxlen, " characters"));
112
110
  }
113
111
  un->sun_family = AF_UNIX;
114
112
  un->sun_path[0] = '\0';
@@ -212,8 +212,8 @@ grpc_error_handle grpc_string_to_sockaddr(grpc_resolved_address* out,
212
212
  addr4->sin_family = GRPC_AF_INET;
213
213
  out->len = sizeof(grpc_sockaddr_in);
214
214
  } else {
215
- return GRPC_ERROR_CREATE_FROM_COPIED_STRING(
216
- absl::StrCat("Failed to parse address:", addr).c_str());
215
+ return GRPC_ERROR_CREATE_FROM_CPP_STRING(
216
+ absl::StrCat("Failed to parse address:", addr));
217
217
  }
218
218
  grpc_sockaddr_set_port(out, port);
219
219
  return GRPC_ERROR_NONE;
@@ -23,11 +23,11 @@
23
23
  #include <assert.h>
24
24
  #include <stdlib.h>
25
25
 
26
+ #include <algorithm>
27
+
26
28
  #include <grpc/support/alloc.h>
27
29
  #include <grpc/support/string_util.h>
28
30
 
29
- #include "src/core/lib/gpr/useful.h"
30
-
31
31
  grpc_avl grpc_avl_create(const grpc_avl_vtable* vtable) {
32
32
  grpc_avl out;
33
33
  out.vtable = vtable;
@@ -63,8 +63,8 @@ static long node_height(grpc_avl_node* node) {
63
63
  #ifndef NDEBUG
64
64
  static long calculate_height(grpc_avl_node* node) {
65
65
  return node == nullptr ? 0
66
- : 1 + GPR_MAX(calculate_height(node->left),
67
- calculate_height(node->right));
66
+ : 1 + std::max(calculate_height(node->left),
67
+ calculate_height(node->right));
68
68
  }
69
69
 
70
70
  static grpc_avl_node* assert_invariants(grpc_avl_node* n) {
@@ -87,7 +87,7 @@ grpc_avl_node* new_node(void* key, void* value, grpc_avl_node* left,
87
87
  node->value = value;
88
88
  node->left = assert_invariants(left);
89
89
  node->right = assert_invariants(right);
90
- node->height = 1 + GPR_MAX(node_height(left), node_height(right));
90
+ node->height = 1 + std::max(node_height(left), node_height(right));
91
91
  return node;
92
92
  }
93
93
 
@@ -39,7 +39,7 @@ double generate_uniform_random_number(uint32_t* rng_state) {
39
39
  double generate_uniform_random_number_between(uint32_t* rng_state, double a,
40
40
  double b) {
41
41
  if (a == b) return a;
42
- if (a > b) GPR_SWAP(double, a, b); // make sure a < b
42
+ if (a > b) std::swap(a, b); // make sure a < b
43
43
  const double range = b - a;
44
44
  return a + generate_uniform_random_number(rng_state) * range;
45
45
  }
@@ -18,11 +18,14 @@
18
18
 
19
19
  #include <grpc/support/port_platform.h>
20
20
 
21
+ #include "src/core/lib/channel/channel_args.h"
22
+
21
23
  #include <limits.h>
22
24
  #include <string.h>
23
25
 
24
26
  #include <vector>
25
27
 
28
+ #include "absl/strings/match.h"
26
29
  #include "absl/strings/str_format.h"
27
30
  #include "absl/strings/str_join.h"
28
31
 
@@ -33,7 +36,6 @@
33
36
  #include <grpc/support/log.h>
34
37
  #include <grpc/support/string_util.h>
35
38
 
36
- #include "src/core/lib/channel/channel_args.h"
37
39
  #include "src/core/lib/gpr/string.h"
38
40
  #include "src/core/lib/gpr/useful.h"
39
41
 
@@ -71,6 +73,22 @@ grpc_channel_args* grpc_channel_args_copy_and_remove(
71
73
  num_to_remove, nullptr, 0);
72
74
  }
73
75
 
76
+ grpc_channel_args* grpc_channel_args_remove_grpc_internal(
77
+ const grpc_channel_args* src) {
78
+ if (src == nullptr) return nullptr;
79
+ // Create result.
80
+ grpc_channel_args* dst =
81
+ static_cast<grpc_channel_args*>(gpr_malloc(sizeof(grpc_channel_args)));
82
+ dst->args =
83
+ static_cast<grpc_arg*>(gpr_malloc(sizeof(grpc_arg) * src->num_args));
84
+ dst->num_args = 0;
85
+ for (size_t i = 0; i < src->num_args; ++i) {
86
+ if (absl::StartsWith(src->args[i].key, "grpc.internal.")) continue;
87
+ dst->args[dst->num_args++] = copy_arg(&src->args[i]);
88
+ }
89
+ return dst;
90
+ }
91
+
74
92
  static bool should_remove_arg(const grpc_arg* arg, const char** to_remove,
75
93
  size_t num_to_remove) {
76
94
  for (size_t i = 0; i < num_to_remove; ++i) {
@@ -145,7 +163,7 @@ grpc_channel_args* grpc_channel_args_union(const grpc_channel_args* a,
145
163
  }
146
164
 
147
165
  static int cmp_arg(const grpc_arg* a, const grpc_arg* b) {
148
- int c = GPR_ICMP(a->type, b->type);
166
+ int c = grpc_core::QsortCompare(a->type, b->type);
149
167
  if (c != 0) return c;
150
168
  c = strcmp(a->key, b->key);
151
169
  if (c != 0) return c;
@@ -153,11 +171,12 @@ static int cmp_arg(const grpc_arg* a, const grpc_arg* b) {
153
171
  case GRPC_ARG_STRING:
154
172
  return strcmp(a->value.string, b->value.string);
155
173
  case GRPC_ARG_INTEGER:
156
- return GPR_ICMP(a->value.integer, b->value.integer);
174
+ return grpc_core::QsortCompare(a->value.integer, b->value.integer);
157
175
  case GRPC_ARG_POINTER:
158
- c = GPR_ICMP(a->value.pointer.p, b->value.pointer.p);
176
+ c = grpc_core::QsortCompare(a->value.pointer.p, b->value.pointer.p);
159
177
  if (c != 0) {
160
- c = GPR_ICMP(a->value.pointer.vtable, b->value.pointer.vtable);
178
+ c = grpc_core::QsortCompare(a->value.pointer.vtable,
179
+ b->value.pointer.vtable);
161
180
  if (c == 0) {
162
181
  c = a->value.pointer.vtable->cmp(a->value.pointer.p,
163
182
  b->value.pointer.p);
@@ -174,7 +193,7 @@ static int cmp_key_stable(const void* ap, const void* bp) {
174
193
  const grpc_arg* const* a = static_cast<const grpc_arg* const*>(ap);
175
194
  const grpc_arg* const* b = static_cast<const grpc_arg* const*>(bp);
176
195
  int c = strcmp((*a)->key, (*b)->key);
177
- if (c == 0) c = GPR_ICMP(*a, *b);
196
+ if (c == 0) c = grpc_core::QsortCompare(*a, *b);
178
197
  return c;
179
198
  }
180
199
 
@@ -224,7 +243,7 @@ int grpc_channel_args_compare(const grpc_channel_args* a,
224
243
  const grpc_channel_args* b) {
225
244
  if (a == nullptr && b == nullptr) return 0;
226
245
  if (a == nullptr || b == nullptr) return a == nullptr ? -1 : 1;
227
- int c = GPR_ICMP(a->num_args, b->num_args);
246
+ int c = grpc_core::QsortCompare(a->num_args, b->num_args);
228
247
  if (c != 0) return c;
229
248
  for (size_t i = 0; i < a->num_args; i++) {
230
249
  c = cmp_arg(&a->args[i], &b->args[i]);
@@ -41,6 +41,15 @@ grpc_channel_args* grpc_channel_args_copy_and_add(const grpc_channel_args* src,
41
41
  const grpc_arg* to_add,
42
42
  size_t num_to_add);
43
43
 
44
+ /** Remove any channel args prefixed with 'grpc.internal.'
45
+ * These are used for internal implementation details and are not intended to
46
+ * be exposed to users.
47
+ * Returns a new channel args instance.
48
+ * Does not take ownership of \a src.
49
+ * Should be called by any public API that receives channel args. */
50
+ grpc_channel_args* grpc_channel_args_remove_grpc_internal(
51
+ const grpc_channel_args* src);
52
+
44
53
  /** Copies the arguments in \a src except for those whose keys are in
45
54
  \a to_remove. */
46
55
  grpc_channel_args* grpc_channel_args_copy_and_remove(
@@ -18,14 +18,16 @@
18
18
 
19
19
  #include <grpc/support/port_platform.h>
20
20
 
21
- #include <grpc/support/alloc.h>
22
- #include <grpc/support/log.h>
23
21
  #include "src/core/lib/channel/channel_stack.h"
24
- #include "src/core/lib/gpr/alloc.h"
25
22
 
26
23
  #include <stdlib.h>
27
24
  #include <string.h>
28
25
 
26
+ #include <grpc/support/alloc.h>
27
+ #include <grpc/support/log.h>
28
+
29
+ #include "src/core/lib/gpr/alloc.h"
30
+
29
31
  grpc_core::TraceFlag grpc_trace_channel(false, "channel");
30
32
 
31
33
  /* Memory layouts.