grpc 1.63.0 → 1.66.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (1652) hide show
  1. checksums.yaml +4 -4
  2. data/Makefile +116 -104
  3. data/include/grpc/credentials.h +1222 -0
  4. data/include/grpc/event_engine/event_engine.h +27 -6
  5. data/include/grpc/event_engine/extensible.h +3 -0
  6. data/include/grpc/event_engine/memory_request.h +18 -0
  7. data/include/grpc/grpc.h +7 -0
  8. data/include/grpc/grpc_crl_provider.h +1 -0
  9. data/include/grpc/grpc_security.h +0 -1171
  10. data/include/grpc/impl/channel_arg_names.h +7 -6
  11. data/include/grpc/module.modulemap +2 -0
  12. data/include/grpc/passive_listener.h +62 -0
  13. data/include/grpc/support/log.h +7 -35
  14. data/include/grpc/support/metrics.h +14 -3
  15. data/include/grpc/support/port_platform.h +25 -0
  16. data/src/core/{lib/channel → channelz}/channel_trace.cc +57 -63
  17. data/src/core/{lib/channel → channelz}/channel_trace.h +22 -20
  18. data/src/core/{lib/channel → channelz}/channelz.cc +71 -9
  19. data/src/core/{lib/channel → channelz}/channelz.h +52 -13
  20. data/src/core/{lib/channel → channelz}/channelz_registry.cc +11 -9
  21. data/src/core/{lib/channel → channelz}/channelz_registry.h +6 -6
  22. data/src/core/client_channel/backup_poller.cc +4 -5
  23. data/src/core/client_channel/client_channel.cc +1419 -0
  24. data/src/core/client_channel/client_channel.h +243 -0
  25. data/src/core/client_channel/client_channel_filter.cc +349 -872
  26. data/src/core/client_channel/client_channel_filter.h +13 -68
  27. data/src/core/client_channel/client_channel_internal.h +25 -7
  28. data/src/core/client_channel/client_channel_plugin.cc +1 -14
  29. data/src/core/client_channel/client_channel_service_config.h +4 -4
  30. data/src/core/client_channel/config_selector.h +22 -18
  31. data/src/core/client_channel/connector.h +1 -1
  32. data/src/core/client_channel/direct_channel.cc +83 -0
  33. data/src/core/client_channel/direct_channel.h +101 -0
  34. data/src/core/client_channel/dynamic_filters.cc +9 -6
  35. data/src/core/client_channel/dynamic_filters.h +1 -3
  36. data/src/core/client_channel/lb_metadata.cc +120 -0
  37. data/src/core/client_channel/lb_metadata.h +56 -0
  38. data/src/core/client_channel/load_balanced_call_destination.cc +274 -0
  39. data/src/core/client_channel/load_balanced_call_destination.h +49 -0
  40. data/src/core/client_channel/local_subchannel_pool.cc +5 -3
  41. data/src/core/client_channel/retry_filter.cc +4 -11
  42. data/src/core/client_channel/retry_filter.h +5 -9
  43. data/src/core/client_channel/retry_filter_legacy_call_data.cc +234 -261
  44. data/src/core/client_channel/retry_filter_legacy_call_data.h +0 -2
  45. data/src/core/client_channel/retry_service_config.cc +4 -5
  46. data/src/core/client_channel/retry_service_config.h +3 -3
  47. data/src/core/client_channel/subchannel.cc +284 -156
  48. data/src/core/client_channel/subchannel.h +31 -25
  49. data/src/core/client_channel/subchannel_pool_interface.cc +0 -2
  50. data/src/core/client_channel/subchannel_pool_interface.h +2 -4
  51. data/src/core/client_channel/subchannel_stream_client.cc +41 -52
  52. data/src/core/client_channel/subchannel_stream_client.h +2 -4
  53. data/src/core/ext/filters/backend_metrics/backend_metric_filter.cc +17 -20
  54. data/src/core/ext/filters/backend_metrics/backend_metric_filter.h +5 -2
  55. data/src/core/ext/filters/backend_metrics/backend_metric_provider.h +7 -0
  56. data/src/core/ext/filters/census/grpc_context.cc +6 -8
  57. data/src/core/ext/filters/channel_idle/legacy_channel_idle_filter.cc +28 -28
  58. data/src/core/ext/filters/channel_idle/legacy_channel_idle_filter.h +16 -11
  59. data/src/core/ext/filters/fault_injection/fault_injection_filter.cc +15 -21
  60. data/src/core/ext/filters/fault_injection/fault_injection_filter.h +7 -4
  61. data/src/core/ext/filters/fault_injection/fault_injection_service_config_parser.h +3 -3
  62. data/src/core/ext/filters/http/client/http_client_filter.cc +7 -5
  63. data/src/core/ext/filters/http/client/http_client_filter.h +8 -5
  64. data/src/core/ext/filters/http/client_authority_filter.cc +6 -5
  65. data/src/core/ext/filters/http/client_authority_filter.h +8 -4
  66. data/src/core/ext/filters/http/message_compress/compression_filter.cc +35 -42
  67. data/src/core/ext/filters/http/message_compress/compression_filter.h +15 -8
  68. data/src/core/ext/filters/http/server/http_server_filter.cc +8 -8
  69. data/src/core/ext/filters/http/server/http_server_filter.h +8 -5
  70. data/src/core/ext/filters/message_size/message_size_filter.cc +27 -41
  71. data/src/core/ext/filters/message_size/message_size_filter.h +18 -12
  72. data/src/core/ext/filters/rbac/rbac_filter.cc +14 -12
  73. data/src/core/ext/filters/rbac/rbac_filter.h +8 -5
  74. data/src/core/ext/filters/rbac/rbac_service_config_parser.cc +2 -2
  75. data/src/core/ext/filters/rbac/rbac_service_config_parser.h +1 -1
  76. data/src/core/ext/filters/stateful_session/stateful_session_filter.cc +15 -20
  77. data/src/core/ext/filters/stateful_session/stateful_session_filter.h +6 -2
  78. data/src/core/ext/filters/stateful_session/stateful_session_service_config_parser.h +3 -3
  79. data/src/core/ext/transport/chttp2/alpn/alpn.cc +5 -4
  80. data/src/core/ext/transport/chttp2/alpn/alpn.h +2 -2
  81. data/src/core/ext/transport/chttp2/client/chttp2_connector.cc +68 -96
  82. data/src/core/ext/transport/chttp2/client/chttp2_connector.h +3 -9
  83. data/src/core/ext/transport/chttp2/server/chttp2_server.cc +307 -254
  84. data/src/core/ext/transport/chttp2/server/chttp2_server.h +36 -3
  85. data/src/core/ext/transport/chttp2/transport/bin_decoder.cc +23 -35
  86. data/src/core/ext/transport/chttp2/transport/bin_decoder.h +1 -2
  87. data/src/core/ext/transport/chttp2/transport/bin_encoder.cc +8 -7
  88. data/src/core/ext/transport/chttp2/transport/bin_encoder.h +1 -2
  89. data/src/core/ext/transport/chttp2/transport/chttp2_transport.cc +367 -321
  90. data/src/core/ext/transport/chttp2/transport/chttp2_transport.h +12 -13
  91. data/src/core/ext/transport/chttp2/transport/context_list_entry.h +3 -3
  92. data/src/core/ext/transport/chttp2/transport/decode_huff.cc +2 -2
  93. data/src/core/ext/transport/chttp2/transport/decode_huff.h +2 -2
  94. data/src/core/ext/transport/chttp2/transport/flow_control.cc +9 -11
  95. data/src/core/ext/transport/chttp2/transport/flow_control.h +4 -6
  96. data/src/core/ext/transport/chttp2/transport/frame.cc +4 -4
  97. data/src/core/ext/transport/chttp2/transport/frame.h +2 -2
  98. data/src/core/ext/transport/chttp2/transport/frame_data.cc +6 -10
  99. data/src/core/ext/transport/chttp2/transport/frame_data.h +3 -3
  100. data/src/core/ext/transport/chttp2/transport/frame_goaway.cc +5 -5
  101. data/src/core/ext/transport/chttp2/transport/frame_goaway.h +1 -2
  102. data/src/core/ext/transport/chttp2/transport/frame_ping.cc +14 -17
  103. data/src/core/ext/transport/chttp2/transport/frame_ping.h +1 -2
  104. data/src/core/ext/transport/chttp2/transport/frame_rst_stream.cc +16 -15
  105. data/src/core/ext/transport/chttp2/transport/frame_rst_stream.h +6 -5
  106. data/src/core/ext/transport/chttp2/transport/frame_settings.cc +18 -16
  107. data/src/core/ext/transport/chttp2/transport/frame_settings.h +1 -2
  108. data/src/core/ext/transport/chttp2/transport/frame_window_update.cc +11 -7
  109. data/src/core/ext/transport/chttp2/transport/frame_window_update.h +4 -3
  110. data/src/core/ext/transport/chttp2/transport/hpack_constants.h +2 -2
  111. data/src/core/ext/transport/chttp2/transport/hpack_encoder.cc +13 -12
  112. data/src/core/ext/transport/chttp2/transport/hpack_encoder.h +14 -9
  113. data/src/core/ext/transport/chttp2/transport/hpack_encoder_table.cc +10 -9
  114. data/src/core/ext/transport/chttp2/transport/hpack_encoder_table.h +2 -2
  115. data/src/core/ext/transport/chttp2/transport/hpack_parse_result.cc +4 -3
  116. data/src/core/ext/transport/chttp2/transport/hpack_parse_result.h +3 -3
  117. data/src/core/ext/transport/chttp2/transport/hpack_parser.cc +75 -68
  118. data/src/core/ext/transport/chttp2/transport/hpack_parser.h +4 -3
  119. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.cc +8 -13
  120. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.h +2 -2
  121. data/src/core/ext/transport/chttp2/transport/http2_settings.cc +3 -3
  122. data/src/core/ext/transport/chttp2/transport/http2_settings.h +3 -3
  123. data/src/core/ext/transport/chttp2/transport/huffsyms.cc +2 -2
  124. data/src/core/ext/transport/chttp2/transport/internal.h +79 -26
  125. data/src/core/ext/transport/chttp2/transport/max_concurrent_streams_policy.cc +4 -3
  126. data/src/core/ext/transport/chttp2/transport/max_concurrent_streams_policy.h +2 -2
  127. data/src/core/ext/transport/chttp2/transport/parsing.cc +87 -97
  128. data/src/core/ext/transport/chttp2/transport/ping_abuse_policy.cc +1 -2
  129. data/src/core/ext/transport/chttp2/transport/ping_abuse_policy.h +2 -2
  130. data/src/core/ext/transport/chttp2/transport/ping_callbacks.cc +3 -5
  131. data/src/core/ext/transport/chttp2/transport/ping_callbacks.h +1 -4
  132. data/src/core/ext/transport/chttp2/transport/ping_rate_policy.cc +30 -15
  133. data/src/core/ext/transport/chttp2/transport/ping_rate_policy.h +7 -6
  134. data/src/core/ext/transport/chttp2/transport/stream_lists.cc +17 -18
  135. data/src/core/ext/transport/chttp2/transport/varint.cc +2 -2
  136. data/src/core/ext/transport/chttp2/transport/varint.h +4 -3
  137. data/src/core/ext/transport/chttp2/transport/write_size_policy.cc +4 -3
  138. data/src/core/ext/transport/chttp2/transport/write_size_policy.h +2 -2
  139. data/src/core/ext/transport/chttp2/transport/writing.cc +164 -126
  140. data/src/core/ext/transport/inproc/inproc_transport.cc +152 -69
  141. data/src/core/ext/transport/inproc/inproc_transport.h +2 -5
  142. data/src/core/ext/transport/inproc/legacy_inproc_transport.cc +116 -116
  143. data/src/core/ext/transport/inproc/legacy_inproc_transport.h +1 -4
  144. data/src/core/ext/upb-gen/envoy/admin/v3/certs.upb.h +11 -11
  145. data/src/core/ext/upb-gen/envoy/admin/v3/certs.upb_minitable.c +15 -0
  146. data/src/core/ext/upb-gen/envoy/admin/v3/clusters.upb.h +23 -23
  147. data/src/core/ext/upb-gen/envoy/admin/v3/clusters.upb_minitable.c +12 -0
  148. data/src/core/ext/upb-gen/envoy/admin/v3/config_dump.upb.h +11 -11
  149. data/src/core/ext/upb-gen/envoy/admin/v3/config_dump.upb_minitable.c +15 -0
  150. data/src/core/ext/upb-gen/envoy/admin/v3/config_dump_shared.upb.h +50 -50
  151. data/src/core/ext/upb-gen/envoy/admin/v3/config_dump_shared.upb_minitable.c +57 -0
  152. data/src/core/ext/upb-gen/envoy/admin/v3/init_dump.upb.h +1 -1
  153. data/src/core/ext/upb-gen/envoy/admin/v3/init_dump.upb_minitable.c +6 -0
  154. data/src/core/ext/upb-gen/envoy/admin/v3/listeners.upb.h +2 -2
  155. data/src/core/ext/upb-gen/envoy/admin/v3/listeners.upb_minitable.c +6 -0
  156. data/src/core/ext/upb-gen/envoy/admin/v3/memory.upb.h +6 -6
  157. data/src/core/ext/upb-gen/envoy/admin/v3/memory.upb_minitable.c +3 -0
  158. data/src/core/ext/upb-gen/envoy/admin/v3/metrics.upb.h +3 -3
  159. data/src/core/ext/upb-gen/envoy/admin/v3/metrics.upb_minitable.c +3 -0
  160. data/src/core/ext/upb-gen/envoy/admin/v3/mutex_stats.upb.h +3 -3
  161. data/src/core/ext/upb-gen/envoy/admin/v3/mutex_stats.upb_minitable.c +3 -0
  162. data/src/core/ext/upb-gen/envoy/admin/v3/server_info.upb.h +110 -78
  163. data/src/core/ext/upb-gen/envoy/admin/v3/server_info.upb_minitable.c +23 -15
  164. data/src/core/ext/upb-gen/envoy/admin/v3/tap.upb.h +2 -2
  165. data/src/core/ext/upb-gen/envoy/admin/v3/tap.upb_minitable.c +3 -0
  166. data/src/core/ext/upb-gen/envoy/annotations/deprecation.upb.h +4 -4
  167. data/src/core/ext/upb-gen/envoy/annotations/resource.upb.h +11 -2
  168. data/src/core/ext/upb-gen/envoy/annotations/resource.upb_minitable.c +3 -0
  169. data/src/core/ext/upb-gen/envoy/config/accesslog/v3/accesslog.upb.h +30 -30
  170. data/src/core/ext/upb-gen/envoy/config/accesslog/v3/accesslog.upb_minitable.c +48 -0
  171. data/src/core/ext/upb-gen/envoy/config/bootstrap/v3/bootstrap.upb.h +361 -250
  172. data/src/core/ext/upb-gen/envoy/config/bootstrap/v3/bootstrap.upb_minitable.c +139 -48
  173. data/src/core/ext/upb-gen/envoy/config/bootstrap/v3/bootstrap.upb_minitable.h +1 -0
  174. data/src/core/ext/upb-gen/envoy/config/cluster/v3/circuit_breaker.upb.h +10 -10
  175. data/src/core/ext/upb-gen/envoy/config/cluster/v3/circuit_breaker.upb_minitable.c +9 -0
  176. data/src/core/ext/upb-gen/envoy/config/cluster/v3/cluster.upb.h +314 -137
  177. data/src/core/ext/upb-gen/envoy/config/cluster/v3/cluster.upb_minitable.c +120 -22
  178. data/src/core/ext/upb-gen/envoy/config/cluster/v3/cluster.upb_minitable.h +1 -0
  179. data/src/core/ext/upb-gen/envoy/config/cluster/v3/filter.upb.h +3 -3
  180. data/src/core/ext/upb-gen/envoy/config/cluster/v3/filter.upb_minitable.c +3 -0
  181. data/src/core/ext/upb-gen/envoy/config/cluster/v3/outlier_detection.upb.h +115 -23
  182. data/src/core/ext/upb-gen/envoy/config/cluster/v3/outlier_detection.upb_minitable.c +27 -3
  183. data/src/core/ext/upb-gen/envoy/config/common/matcher/v3/matcher.upb.h +31 -31
  184. data/src/core/ext/upb-gen/envoy/config/common/matcher/v3/matcher.upb_minitable.c +45 -0
  185. data/src/core/ext/upb-gen/envoy/config/core/v3/address.upb.h +23 -23
  186. data/src/core/ext/upb-gen/envoy/config/core/v3/address.upb_minitable.c +24 -0
  187. data/src/core/ext/upb-gen/envoy/config/core/v3/backoff.upb.h +2 -2
  188. data/src/core/ext/upb-gen/envoy/config/core/v3/backoff.upb_minitable.c +3 -0
  189. data/src/core/ext/upb-gen/envoy/config/core/v3/base.upb.h +646 -68
  190. data/src/core/ext/upb-gen/envoy/config/core/v3/base.upb_minitable.c +230 -16
  191. data/src/core/ext/upb-gen/envoy/config/core/v3/base.upb_minitable.h +5 -0
  192. data/src/core/ext/upb-gen/envoy/config/core/v3/config_source.upb.h +21 -21
  193. data/src/core/ext/upb-gen/envoy/config/core/v3/config_source.upb_minitable.c +21 -0
  194. data/src/core/ext/upb-gen/envoy/config/core/v3/event_service_config.upb.h +1 -1
  195. data/src/core/ext/upb-gen/envoy/config/core/v3/event_service_config.upb_minitable.c +3 -0
  196. data/src/core/ext/upb-gen/envoy/config/core/v3/extension.upb.h +2 -2
  197. data/src/core/ext/upb-gen/envoy/config/core/v3/extension.upb_minitable.c +3 -0
  198. data/src/core/ext/upb-gen/envoy/config/core/v3/grpc_method_list.upb.h +1 -1
  199. data/src/core/ext/upb-gen/envoy/config/core/v3/grpc_method_list.upb_minitable.c +6 -0
  200. data/src/core/ext/upb-gen/envoy/config/core/v3/grpc_service.upb.h +130 -58
  201. data/src/core/ext/upb-gen/envoy/config/core/v3/grpc_service.upb_minitable.c +63 -12
  202. data/src/core/ext/upb-gen/envoy/config/core/v3/health_check.upb.h +104 -58
  203. data/src/core/ext/upb-gen/envoy/config/core/v3/health_check.upb_minitable.c +42 -11
  204. data/src/core/ext/upb-gen/envoy/config/core/v3/http_service.upb.h +1 -1
  205. data/src/core/ext/upb-gen/envoy/config/core/v3/http_service.upb_minitable.c +3 -0
  206. data/src/core/ext/upb-gen/envoy/config/core/v3/http_uri.upb.h +3 -3
  207. data/src/core/ext/upb-gen/envoy/config/core/v3/http_uri.upb_minitable.c +3 -0
  208. data/src/core/ext/upb-gen/envoy/config/core/v3/protocol.upb.h +132 -72
  209. data/src/core/ext/upb-gen/envoy/config/core/v3/protocol.upb_minitable.c +65 -11
  210. data/src/core/ext/upb-gen/envoy/config/core/v3/proxy_protocol.upb.h +3 -3
  211. data/src/core/ext/upb-gen/envoy/config/core/v3/proxy_protocol.upb_minitable.c +6 -0
  212. data/src/core/ext/upb-gen/envoy/config/core/v3/resolver.upb.h +3 -3
  213. data/src/core/ext/upb-gen/envoy/config/core/v3/resolver.upb_minitable.c +6 -0
  214. data/src/core/ext/upb-gen/envoy/config/core/v3/socket_option.upb.h +6 -6
  215. data/src/core/ext/upb-gen/envoy/config/core/v3/socket_option.upb_minitable.c +6 -0
  216. data/src/core/ext/upb-gen/envoy/config/core/v3/substitution_format_string.upb.h +7 -7
  217. data/src/core/ext/upb-gen/envoy/config/core/v3/substitution_format_string.upb_minitable.c +6 -0
  218. data/src/core/ext/upb-gen/envoy/config/core/v3/udp_socket_config.upb.h +2 -2
  219. data/src/core/ext/upb-gen/envoy/config/core/v3/udp_socket_config.upb_minitable.c +3 -0
  220. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/endpoint.upb.h +7 -7
  221. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/endpoint.upb_minitable.c +12 -0
  222. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/endpoint_components.upb.h +58 -30
  223. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/endpoint_components.upb_minitable.c +30 -7
  224. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/load_report.upb.h +237 -33
  225. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/load_report.upb_minitable.c +58 -12
  226. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/load_report.upb_minitable.h +1 -0
  227. data/src/core/ext/upb-gen/envoy/config/listener/v3/api_listener.upb.h +1 -1
  228. data/src/core/ext/upb-gen/envoy/config/listener/v3/api_listener.upb_minitable.c +3 -0
  229. data/src/core/ext/upb-gen/envoy/config/listener/v3/listener.upb.h +59 -43
  230. data/src/core/ext/upb-gen/envoy/config/listener/v3/listener.upb_minitable.c +37 -6
  231. data/src/core/ext/upb-gen/envoy/config/listener/v3/listener_components.upb.h +25 -25
  232. data/src/core/ext/upb-gen/envoy/config/listener/v3/listener_components.upb_minitable.c +21 -0
  233. data/src/core/ext/upb-gen/envoy/config/listener/v3/quic_config.upb.h +66 -9
  234. data/src/core/ext/upb-gen/envoy/config/listener/v3/quic_config.upb_minitable.c +10 -3
  235. data/src/core/ext/upb-gen/envoy/config/listener/v3/udp_listener_config.upb.h +3 -3
  236. data/src/core/ext/upb-gen/envoy/config/listener/v3/udp_listener_config.upb_minitable.c +6 -0
  237. data/src/core/ext/upb-gen/envoy/config/metrics/v3/metrics_service.upb.h +5 -5
  238. data/src/core/ext/upb-gen/envoy/config/metrics/v3/metrics_service.upb_minitable.c +3 -0
  239. data/src/core/ext/upb-gen/envoy/config/metrics/v3/stats.upb.h +18 -18
  240. data/src/core/ext/upb-gen/envoy/config/metrics/v3/stats.upb_minitable.c +24 -0
  241. data/src/core/ext/upb-gen/envoy/config/overload/v3/overload.upb.h +17 -17
  242. data/src/core/ext/upb-gen/envoy/config/overload/v3/overload.upb_minitable.c +30 -0
  243. data/src/core/ext/upb-gen/envoy/config/rbac/v3/rbac.upb.h +63 -34
  244. data/src/core/ext/upb-gen/envoy/config/rbac/v3/rbac.upb_minitable.c +39 -4
  245. data/src/core/ext/upb-gen/envoy/config/route/v3/route.upb.h +9 -9
  246. data/src/core/ext/upb-gen/envoy/config/route/v3/route.upb_minitable.c +9 -0
  247. data/src/core/ext/upb-gen/envoy/config/route/v3/route_components.upb.h +273 -229
  248. data/src/core/ext/upb-gen/envoy/config/route/v3/route_components.upb_minitable.c +191 -14
  249. data/src/core/ext/upb-gen/envoy/config/route/v3/scoped_route.upb.h +6 -6
  250. data/src/core/ext/upb-gen/envoy/config/route/v3/scoped_route.upb_minitable.c +9 -0
  251. data/src/core/ext/upb-gen/envoy/config/tap/v3/common.upb.h +31 -31
  252. data/src/core/ext/upb-gen/envoy/config/tap/v3/common.upb_minitable.c +36 -0
  253. data/src/core/ext/upb-gen/envoy/config/trace/v3/datadog.upb.h +109 -12
  254. data/src/core/ext/upb-gen/envoy/config/trace/v3/datadog.upb_minitable.c +38 -11
  255. data/src/core/ext/upb-gen/envoy/config/trace/v3/datadog.upb_minitable.h +1 -0
  256. data/src/core/ext/upb-gen/envoy/config/trace/v3/dynamic_ot.upb.h +2 -2
  257. data/src/core/ext/upb-gen/envoy/config/trace/v3/dynamic_ot.upb_minitable.c +3 -0
  258. data/src/core/ext/upb-gen/envoy/config/trace/v3/http_tracer.upb.h +3 -3
  259. data/src/core/ext/upb-gen/envoy/config/trace/v3/http_tracer.upb_minitable.c +6 -0
  260. data/src/core/ext/upb-gen/envoy/config/trace/v3/lightstep.upb.h +3 -3
  261. data/src/core/ext/upb-gen/envoy/config/trace/v3/lightstep.upb_minitable.c +3 -0
  262. data/src/core/ext/upb-gen/envoy/config/trace/v3/opencensus.upb.h +11 -11
  263. data/src/core/ext/upb-gen/envoy/config/trace/v3/opencensus.upb_minitable.c +3 -0
  264. data/src/core/ext/upb-gen/envoy/config/trace/v3/opentelemetry.upb.h +4 -4
  265. data/src/core/ext/upb-gen/envoy/config/trace/v3/opentelemetry.upb_minitable.c +3 -0
  266. data/src/core/ext/upb-gen/envoy/config/trace/v3/service.upb.h +1 -1
  267. data/src/core/ext/upb-gen/envoy/config/trace/v3/service.upb_minitable.c +3 -0
  268. data/src/core/ext/upb-gen/envoy/config/trace/v3/skywalking.upb.h +6 -6
  269. data/src/core/ext/upb-gen/envoy/config/trace/v3/skywalking.upb_minitable.c +6 -0
  270. data/src/core/ext/upb-gen/envoy/config/trace/v3/xray.upb.h +6 -6
  271. data/src/core/ext/upb-gen/envoy/config/trace/v3/xray.upb_minitable.c +6 -0
  272. data/src/core/ext/upb-gen/envoy/config/trace/v3/zipkin.upb.h +7 -7
  273. data/src/core/ext/upb-gen/envoy/config/trace/v3/zipkin.upb_minitable.c +3 -0
  274. data/src/core/ext/upb-gen/envoy/data/accesslog/v3/accesslog.upb.h +114 -98
  275. data/src/core/ext/upb-gen/envoy/data/accesslog/v3/accesslog.upb_minitable.c +52 -3
  276. data/src/core/ext/upb-gen/envoy/extensions/clusters/aggregate/v3/cluster.upb_minitable.c +3 -0
  277. data/src/core/ext/upb-gen/envoy/extensions/filters/common/fault/v3/fault.upb.h +7 -7
  278. data/src/core/ext/upb-gen/envoy/extensions/filters/common/fault/v3/fault.upb_minitable.c +15 -0
  279. data/src/core/ext/upb-gen/envoy/extensions/filters/http/fault/v3/fault.upb.h +18 -18
  280. data/src/core/ext/upb-gen/envoy/extensions/filters/http/fault/v3/fault.upb_minitable.c +9 -0
  281. data/src/core/ext/upb-gen/envoy/extensions/filters/http/rbac/v3/rbac.upb.h +41 -9
  282. data/src/core/ext/upb-gen/envoy/extensions/filters/http/rbac/v3/rbac.upb_minitable.c +15 -3
  283. data/src/core/ext/upb-gen/envoy/extensions/filters/http/router/v3/router.upb.h +8 -8
  284. data/src/core/ext/upb-gen/envoy/extensions/filters/http/router/v3/router.upb_minitable.c +6 -0
  285. data/src/core/ext/upb-gen/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upb.h +4 -4
  286. data/src/core/ext/upb-gen/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upb_minitable.c +6 -0
  287. data/src/core/ext/upb-gen/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.h +146 -130
  288. data/src/core/ext/upb-gen/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb_minitable.c +74 -10
  289. data/src/core/ext/upb-gen/envoy/extensions/http/stateful_session/cookie/v3/cookie.upb.h +1 -1
  290. data/src/core/ext/upb-gen/envoy/extensions/http/stateful_session/cookie/v3/cookie.upb_minitable.c +3 -0
  291. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/client_side_weighted_round_robin/v3/client_side_weighted_round_robin.upb.h +6 -6
  292. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/client_side_weighted_round_robin/v3/client_side_weighted_round_robin.upb_minitable.c +3 -0
  293. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/common/v3/common.upb.h +10 -10
  294. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/common/v3/common.upb_minitable.c +15 -0
  295. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/pick_first/v3/pick_first.upb.h +1 -1
  296. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/pick_first/v3/pick_first.upb_minitable.c +3 -0
  297. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/ring_hash/v3/ring_hash.upb.h +7 -7
  298. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/ring_hash/v3/ring_hash.upb_minitable.c +3 -0
  299. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/wrr_locality/v3/wrr_locality.upb.h +1 -1
  300. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/wrr_locality/v3/wrr_locality.upb_minitable.c +3 -0
  301. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/common.upb.h +111 -27
  302. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/common.upb_minitable.c +43 -7
  303. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/common.upb_minitable.h +1 -0
  304. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/secret.upb.h +8 -8
  305. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/secret.upb_minitable.c +9 -0
  306. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/tls.upb.h +35 -35
  307. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/tls.upb_minitable.c +21 -0
  308. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upb.h +2 -2
  309. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upb_minitable.c +6 -0
  310. data/src/core/ext/upb-gen/envoy/extensions/upstreams/http/v3/http_protocol_options.upb.h +16 -16
  311. data/src/core/ext/upb-gen/envoy/extensions/upstreams/http/v3/http_protocol_options.upb_minitable.c +12 -0
  312. data/src/core/ext/upb-gen/envoy/service/discovery/v3/ads.upb_minitable.c +3 -0
  313. data/src/core/ext/upb-gen/envoy/service/discovery/v3/discovery.upb.h +36 -36
  314. data/src/core/ext/upb-gen/envoy/service/discovery/v3/discovery.upb_minitable.c +42 -0
  315. data/src/core/ext/upb-gen/envoy/service/load_stats/v3/lrs.upb.h +4 -4
  316. data/src/core/ext/upb-gen/envoy/service/load_stats/v3/lrs.upb_minitable.c +6 -0
  317. data/src/core/ext/upb-gen/envoy/service/status/v3/csds.upb.h +20 -20
  318. data/src/core/ext/upb-gen/envoy/service/status/v3/csds.upb_minitable.c +15 -0
  319. data/src/core/ext/upb-gen/envoy/type/http/v3/cookie.upb.h +3 -3
  320. data/src/core/ext/upb-gen/envoy/type/http/v3/cookie.upb_minitable.c +3 -0
  321. data/src/core/ext/upb-gen/envoy/type/http/v3/path_transformation.upb.h +2 -2
  322. data/src/core/ext/upb-gen/envoy/type/http/v3/path_transformation.upb_minitable.c +12 -0
  323. data/src/core/ext/upb-gen/envoy/type/matcher/v3/filter_state.upb.h +2 -2
  324. data/src/core/ext/upb-gen/envoy/type/matcher/v3/filter_state.upb_minitable.c +3 -0
  325. data/src/core/ext/upb-gen/envoy/type/matcher/v3/http_inputs.upb.h +5 -5
  326. data/src/core/ext/upb-gen/envoy/type/matcher/v3/http_inputs.upb_minitable.c +15 -0
  327. data/src/core/ext/upb-gen/envoy/type/matcher/v3/metadata.upb.h +4 -4
  328. data/src/core/ext/upb-gen/envoy/type/matcher/v3/metadata.upb_minitable.c +6 -0
  329. data/src/core/ext/upb-gen/envoy/type/matcher/v3/node.upb.h +1 -1
  330. data/src/core/ext/upb-gen/envoy/type/matcher/v3/node.upb_minitable.c +3 -0
  331. data/src/core/ext/upb-gen/envoy/type/matcher/v3/number.upb.h +2 -2
  332. data/src/core/ext/upb-gen/envoy/type/matcher/v3/number.upb_minitable.c +3 -0
  333. data/src/core/ext/upb-gen/envoy/type/matcher/v3/path.upb.h +1 -1
  334. data/src/core/ext/upb-gen/envoy/type/matcher/v3/path.upb_minitable.c +3 -0
  335. data/src/core/ext/upb-gen/envoy/type/matcher/v3/regex.upb.h +5 -5
  336. data/src/core/ext/upb-gen/envoy/type/matcher/v3/regex.upb_minitable.c +9 -0
  337. data/src/core/ext/upb-gen/envoy/type/matcher/v3/status_code_input.upb_minitable.c +6 -0
  338. data/src/core/ext/upb-gen/envoy/type/matcher/v3/string.upb.h +37 -6
  339. data/src/core/ext/upb-gen/envoy/type/matcher/v3/string.upb_minitable.c +20 -3
  340. data/src/core/ext/upb-gen/envoy/type/matcher/v3/struct.upb.h +2 -2
  341. data/src/core/ext/upb-gen/envoy/type/matcher/v3/struct.upb_minitable.c +6 -0
  342. data/src/core/ext/upb-gen/envoy/type/matcher/v3/value.upb.h +8 -8
  343. data/src/core/ext/upb-gen/envoy/type/matcher/v3/value.upb_minitable.c +12 -0
  344. data/src/core/ext/upb-gen/envoy/type/metadata/v3/metadata.upb.h +6 -6
  345. data/src/core/ext/upb-gen/envoy/type/metadata/v3/metadata.upb_minitable.c +21 -0
  346. data/src/core/ext/upb-gen/envoy/type/tracing/v3/custom_tag.upb.h +13 -13
  347. data/src/core/ext/upb-gen/envoy/type/tracing/v3/custom_tag.upb_minitable.c +15 -0
  348. data/src/core/ext/upb-gen/envoy/type/v3/hash_policy.upb.h +3 -3
  349. data/src/core/ext/upb-gen/envoy/type/v3/hash_policy.upb_minitable.c +9 -0
  350. data/src/core/ext/upb-gen/envoy/type/v3/http_status.upb.h +1 -1
  351. data/src/core/ext/upb-gen/envoy/type/v3/http_status.upb_minitable.c +3 -0
  352. data/src/core/ext/upb-gen/envoy/type/v3/percent.upb.h +3 -3
  353. data/src/core/ext/upb-gen/envoy/type/v3/percent.upb_minitable.c +6 -0
  354. data/src/core/ext/upb-gen/envoy/type/v3/range.upb.h +6 -6
  355. data/src/core/ext/upb-gen/envoy/type/v3/range.upb_minitable.c +9 -0
  356. data/src/core/ext/upb-gen/envoy/type/v3/ratelimit_strategy.upb.h +5 -5
  357. data/src/core/ext/upb-gen/envoy/type/v3/ratelimit_strategy.upb_minitable.c +6 -0
  358. data/src/core/ext/upb-gen/envoy/type/v3/semantic_version.upb.h +3 -3
  359. data/src/core/ext/upb-gen/envoy/type/v3/semantic_version.upb_minitable.c +3 -0
  360. data/src/core/ext/upb-gen/envoy/type/v3/token_bucket.upb.h +3 -3
  361. data/src/core/ext/upb-gen/envoy/type/v3/token_bucket.upb_minitable.c +3 -0
  362. data/src/core/ext/upb-gen/google/api/annotations.upb.h +10 -1
  363. data/src/core/ext/upb-gen/google/api/expr/v1alpha1/checked.upb.h +32 -32
  364. data/src/core/ext/upb-gen/google/api/expr/v1alpha1/checked.upb_minitable.c +39 -0
  365. data/src/core/ext/upb-gen/google/api/expr/v1alpha1/syntax.upb.h +43 -43
  366. data/src/core/ext/upb-gen/google/api/expr/v1alpha1/syntax.upb_minitable.c +42 -0
  367. data/src/core/ext/upb-gen/google/api/http.upb.h +12 -12
  368. data/src/core/ext/upb-gen/google/api/http.upb_minitable.c +9 -0
  369. data/src/core/ext/upb-gen/google/api/httpbody.upb.h +2 -2
  370. data/src/core/ext/upb-gen/google/api/httpbody.upb_minitable.c +3 -0
  371. data/src/core/ext/upb-gen/google/protobuf/any.upb.h +2 -2
  372. data/src/core/ext/upb-gen/google/protobuf/any.upb_minitable.c +3 -0
  373. data/src/core/ext/upb-gen/google/protobuf/descriptor.upb.h +381 -177
  374. data/src/core/ext/upb-gen/google/protobuf/descriptor.upb_minitable.c +148 -22
  375. data/src/core/ext/upb-gen/google/protobuf/descriptor.upb_minitable.h +1 -0
  376. data/src/core/ext/upb-gen/google/protobuf/duration.upb.h +2 -2
  377. data/src/core/ext/upb-gen/google/protobuf/duration.upb_minitable.c +3 -0
  378. data/src/core/ext/upb-gen/google/protobuf/empty.upb_minitable.c +3 -0
  379. data/src/core/ext/upb-gen/google/protobuf/struct.upb.h +6 -6
  380. data/src/core/ext/upb-gen/google/protobuf/struct.upb_minitable.c +12 -0
  381. data/src/core/ext/upb-gen/google/protobuf/timestamp.upb.h +2 -2
  382. data/src/core/ext/upb-gen/google/protobuf/timestamp.upb_minitable.c +3 -0
  383. data/src/core/ext/upb-gen/google/protobuf/wrappers.upb.h +9 -9
  384. data/src/core/ext/upb-gen/google/protobuf/wrappers.upb_minitable.c +27 -0
  385. data/src/core/ext/upb-gen/google/rpc/status.upb.h +2 -2
  386. data/src/core/ext/upb-gen/google/rpc/status.upb_minitable.c +3 -0
  387. data/src/core/ext/upb-gen/opencensus/proto/trace/v1/trace_config.upb.h +10 -10
  388. data/src/core/ext/upb-gen/opencensus/proto/trace/v1/trace_config.upb_minitable.c +12 -0
  389. data/src/core/ext/upb-gen/src/proto/grpc/gcp/altscontext.upb.h +6 -6
  390. data/src/core/ext/upb-gen/src/proto/grpc/gcp/altscontext.upb_minitable.c +6 -0
  391. data/src/core/ext/upb-gen/src/proto/grpc/gcp/handshaker.upb.h +35 -35
  392. data/src/core/ext/upb-gen/src/proto/grpc/gcp/handshaker.upb_minitable.c +36 -0
  393. data/src/core/ext/upb-gen/src/proto/grpc/gcp/transport_security_common.upb.h +4 -4
  394. data/src/core/ext/upb-gen/src/proto/grpc/gcp/transport_security_common.upb_minitable.c +6 -0
  395. data/src/core/ext/upb-gen/src/proto/grpc/health/v1/health.upb.h +2 -2
  396. data/src/core/ext/upb-gen/src/proto/grpc/health/v1/health.upb_minitable.c +6 -0
  397. data/src/core/ext/upb-gen/src/proto/grpc/lb/v1/load_balancer.upb.h +18 -18
  398. data/src/core/ext/upb-gen/src/proto/grpc/lb/v1/load_balancer.upb_minitable.c +27 -0
  399. data/src/core/ext/upb-gen/src/proto/grpc/lookup/v1/rls.upb.h +4 -4
  400. data/src/core/ext/upb-gen/src/proto/grpc/lookup/v1/rls.upb_minitable.c +9 -0
  401. data/src/core/ext/upb-gen/src/proto/grpc/lookup/v1/rls_config.upb.h +15 -15
  402. data/src/core/ext/upb-gen/src/proto/grpc/lookup/v1/rls_config.upb_minitable.c +27 -0
  403. data/src/core/ext/upb-gen/udpa/annotations/migrate.upb.h +54 -9
  404. data/src/core/ext/upb-gen/udpa/annotations/migrate.upb_minitable.c +9 -0
  405. data/src/core/ext/upb-gen/udpa/annotations/security.upb.h +12 -3
  406. data/src/core/ext/upb-gen/udpa/annotations/security.upb_minitable.c +3 -0
  407. data/src/core/ext/upb-gen/udpa/annotations/sensitive.upb.h +1 -1
  408. data/src/core/ext/upb-gen/udpa/annotations/status.upb.h +12 -3
  409. data/src/core/ext/upb-gen/udpa/annotations/status.upb_minitable.c +3 -0
  410. data/src/core/ext/upb-gen/udpa/annotations/versioning.upb.h +11 -2
  411. data/src/core/ext/upb-gen/udpa/annotations/versioning.upb_minitable.c +3 -0
  412. data/src/core/ext/upb-gen/validate/validate.upb.h +175 -166
  413. data/src/core/ext/upb-gen/validate/validate.upb_minitable.c +69 -0
  414. data/src/core/ext/upb-gen/xds/annotations/v3/migrate.upb.h +54 -9
  415. data/src/core/ext/upb-gen/xds/annotations/v3/migrate.upb_minitable.c +9 -0
  416. data/src/core/ext/upb-gen/xds/annotations/v3/security.upb.h +12 -3
  417. data/src/core/ext/upb-gen/xds/annotations/v3/security.upb_minitable.c +3 -0
  418. data/src/core/ext/upb-gen/xds/annotations/v3/sensitive.upb.h +1 -1
  419. data/src/core/ext/upb-gen/xds/annotations/v3/status.upb.h +35 -8
  420. data/src/core/ext/upb-gen/xds/annotations/v3/status.upb_minitable.c +12 -0
  421. data/src/core/ext/upb-gen/xds/annotations/v3/versioning.upb.h +11 -2
  422. data/src/core/ext/upb-gen/xds/annotations/v3/versioning.upb_minitable.c +3 -0
  423. data/src/core/ext/upb-gen/xds/core/v3/authority.upb.h +1 -1
  424. data/src/core/ext/upb-gen/xds/core/v3/authority.upb_minitable.c +3 -0
  425. data/src/core/ext/upb-gen/xds/core/v3/cidr.upb.h +2 -2
  426. data/src/core/ext/upb-gen/xds/core/v3/cidr.upb_minitable.c +3 -0
  427. data/src/core/ext/upb-gen/xds/core/v3/collection_entry.upb.h +5 -5
  428. data/src/core/ext/upb-gen/xds/core/v3/collection_entry.upb_minitable.c +6 -0
  429. data/src/core/ext/upb-gen/xds/core/v3/context_params.upb_minitable.c +6 -0
  430. data/src/core/ext/upb-gen/xds/core/v3/extension.upb.h +2 -2
  431. data/src/core/ext/upb-gen/xds/core/v3/extension.upb_minitable.c +3 -0
  432. data/src/core/ext/upb-gen/xds/core/v3/resource.upb.h +3 -3
  433. data/src/core/ext/upb-gen/xds/core/v3/resource.upb_minitable.c +3 -0
  434. data/src/core/ext/upb-gen/xds/core/v3/resource_locator.upb.h +7 -7
  435. data/src/core/ext/upb-gen/xds/core/v3/resource_locator.upb_minitable.c +6 -0
  436. data/src/core/ext/upb-gen/xds/core/v3/resource_name.upb.h +4 -4
  437. data/src/core/ext/upb-gen/xds/core/v3/resource_name.upb_minitable.c +3 -0
  438. data/src/core/ext/upb-gen/xds/data/orca/v3/orca_load_report.upb.h +6 -6
  439. data/src/core/ext/upb-gen/xds/data/orca/v3/orca_load_report.upb_minitable.c +12 -0
  440. data/src/core/ext/upb-gen/xds/service/orca/v3/orca.upb.h +1 -1
  441. data/src/core/ext/upb-gen/xds/service/orca/v3/orca.upb_minitable.c +3 -0
  442. data/src/core/ext/upb-gen/xds/type/matcher/v3/cel.upb.h +2 -2
  443. data/src/core/ext/upb-gen/xds/type/matcher/v3/cel.upb_minitable.c +3 -0
  444. data/src/core/ext/upb-gen/xds/type/matcher/v3/domain.upb.h +1 -1
  445. data/src/core/ext/upb-gen/xds/type/matcher/v3/domain.upb_minitable.c +6 -0
  446. data/src/core/ext/upb-gen/xds/type/matcher/v3/http_inputs.upb_minitable.c +3 -0
  447. data/src/core/ext/upb-gen/xds/type/matcher/v3/ip.upb.h +2 -2
  448. data/src/core/ext/upb-gen/xds/type/matcher/v3/ip.upb_minitable.c +6 -0
  449. data/src/core/ext/upb-gen/xds/type/matcher/v3/matcher.upb.h +18 -18
  450. data/src/core/ext/upb-gen/xds/type/matcher/v3/matcher.upb_minitable.c +30 -0
  451. data/src/core/ext/upb-gen/xds/type/matcher/v3/range.upb.h +3 -3
  452. data/src/core/ext/upb-gen/xds/type/matcher/v3/range.upb_minitable.c +18 -0
  453. data/src/core/ext/upb-gen/xds/type/matcher/v3/regex.upb.h +2 -2
  454. data/src/core/ext/upb-gen/xds/type/matcher/v3/regex.upb_minitable.c +6 -0
  455. data/src/core/ext/upb-gen/xds/type/matcher/v3/string.upb.h +6 -6
  456. data/src/core/ext/upb-gen/xds/type/matcher/v3/string.upb_minitable.c +6 -0
  457. data/src/core/ext/upb-gen/xds/type/v3/cel.upb.h +4 -4
  458. data/src/core/ext/upb-gen/xds/type/v3/cel.upb_minitable.c +6 -0
  459. data/src/core/ext/upb-gen/xds/type/v3/range.upb.h +6 -6
  460. data/src/core/ext/upb-gen/xds/type/v3/range.upb_minitable.c +9 -0
  461. data/src/core/ext/upb-gen/xds/type/v3/typed_struct.upb.h +2 -2
  462. data/src/core/ext/upb-gen/xds/type/v3/typed_struct.upb_minitable.c +3 -0
  463. data/src/core/ext/upbdefs-gen/envoy/admin/v3/server_info.upbdefs.c +86 -81
  464. data/src/core/ext/upbdefs-gen/envoy/config/accesslog/v3/accesslog.upbdefs.c +61 -60
  465. data/src/core/ext/upbdefs-gen/envoy/config/bootstrap/v3/bootstrap.upbdefs.c +221 -210
  466. data/src/core/ext/upbdefs-gen/envoy/config/bootstrap/v3/bootstrap.upbdefs.h +5 -0
  467. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/cluster.upbdefs.c +317 -297
  468. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/cluster.upbdefs.h +5 -0
  469. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/outlier_detection.upbdefs.c +114 -105
  470. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/base.upbdefs.c +185 -140
  471. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/base.upbdefs.h +25 -0
  472. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/config_source.upbdefs.c +10 -11
  473. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/grpc_service.upbdefs.c +173 -164
  474. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/health_check.upbdefs.c +197 -187
  475. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/protocol.upbdefs.c +229 -222
  476. data/src/core/ext/upbdefs-gen/envoy/config/endpoint/v3/endpoint_components.upbdefs.c +39 -36
  477. data/src/core/ext/upbdefs-gen/envoy/config/endpoint/v3/load_report.upbdefs.c +122 -93
  478. data/src/core/ext/upbdefs-gen/envoy/config/endpoint/v3/load_report.upbdefs.h +5 -0
  479. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/listener.upbdefs.c +41 -39
  480. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/quic_config.upbdefs.c +20 -12
  481. data/src/core/ext/upbdefs-gen/envoy/config/rbac/v3/rbac.upbdefs.c +69 -65
  482. data/src/core/ext/upbdefs-gen/envoy/config/route/v3/route_components.upbdefs.c +611 -604
  483. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/datadog.upbdefs.c +30 -20
  484. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/datadog.upbdefs.h +5 -0
  485. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/dynamic_ot.upbdefs.c +18 -17
  486. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/opencensus.upbdefs.c +62 -59
  487. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/zipkin.upbdefs.c +21 -20
  488. data/src/core/ext/upbdefs-gen/envoy/data/accesslog/v3/accesslog.upbdefs.c +145 -142
  489. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/rbac/v3/rbac.upbdefs.c +36 -33
  490. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.c +290 -288
  491. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.c +82 -75
  492. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.h +5 -0
  493. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/string.upbdefs.c +39 -33
  494. data/src/core/ext/upbdefs-gen/google/protobuf/descriptor.upbdefs.c +281 -256
  495. data/src/core/ext/upbdefs-gen/google/protobuf/descriptor.upbdefs.h +5 -0
  496. data/src/core/{lib/transport → handshaker/endpoint_info}/endpoint_info_handshaker.cc +15 -13
  497. data/src/core/{lib/transport → handshaker/endpoint_info}/endpoint_info_handshaker.h +3 -3
  498. data/src/core/handshaker/handshaker.cc +210 -0
  499. data/src/core/{lib/transport → handshaker}/handshaker.h +55 -48
  500. data/src/core/{lib/transport → handshaker}/handshaker_factory.h +19 -3
  501. data/src/core/{lib/transport → handshaker}/handshaker_registry.cc +3 -3
  502. data/src/core/{lib/transport → handshaker}/handshaker_registry.h +6 -6
  503. data/src/core/{lib/transport → handshaker/http_connect}/http_connect_handshaker.cc +112 -156
  504. data/src/core/{lib/transport → handshaker/http_connect}/http_connect_handshaker.h +3 -3
  505. data/src/core/{client_channel → handshaker/http_connect}/http_proxy_mapper.cc +29 -34
  506. data/src/core/{client_channel → handshaker/http_connect}/http_proxy_mapper.h +6 -6
  507. data/src/core/{lib/handshaker → handshaker}/proxy_mapper.h +5 -5
  508. data/src/core/{lib/handshaker → handshaker}/proxy_mapper_registry.cc +3 -3
  509. data/src/core/{lib/handshaker → handshaker}/proxy_mapper_registry.h +6 -6
  510. data/src/core/{lib/security/transport → handshaker/security}/secure_endpoint.cc +87 -72
  511. data/src/core/{lib/security/transport → handshaker/security}/secure_endpoint.h +9 -10
  512. data/src/core/{lib/security/transport → handshaker/security}/security_handshaker.cc +125 -161
  513. data/src/core/{lib/security/transport → handshaker/security}/security_handshaker.h +5 -6
  514. data/src/core/{lib/transport → handshaker/tcp_connect}/tcp_connect_handshaker.cc +45 -57
  515. data/src/core/{lib/transport → handshaker/tcp_connect}/tcp_connect_handshaker.h +3 -3
  516. data/src/core/lib/address_utils/parse_address.cc +30 -40
  517. data/src/core/lib/address_utils/parse_address.h +2 -2
  518. data/src/core/lib/address_utils/sockaddr_utils.cc +20 -15
  519. data/src/core/lib/address_utils/sockaddr_utils.h +2 -2
  520. data/src/core/lib/avl/avl.h +3 -3
  521. data/src/core/lib/backoff/backoff.cc +2 -2
  522. data/src/core/lib/backoff/backoff.h +2 -2
  523. data/src/core/lib/backoff/random_early_detection.cc +2 -2
  524. data/src/core/lib/backoff/random_early_detection.h +2 -2
  525. data/src/core/lib/channel/call_finalization.h +2 -2
  526. data/src/core/lib/channel/channel_args.cc +17 -21
  527. data/src/core/lib/channel/channel_args.h +25 -10
  528. data/src/core/lib/channel/channel_args_preconditioning.cc +2 -2
  529. data/src/core/lib/channel/channel_args_preconditioning.h +1 -2
  530. data/src/core/lib/channel/channel_stack.cc +16 -78
  531. data/src/core/lib/channel/channel_stack.h +11 -46
  532. data/src/core/lib/channel/channel_stack_builder.cc +2 -2
  533. data/src/core/lib/channel/channel_stack_builder.h +2 -7
  534. data/src/core/lib/channel/channel_stack_builder_impl.cc +1 -150
  535. data/src/core/lib/channel/channel_stack_builder_impl.h +2 -4
  536. data/src/core/lib/channel/connected_channel.cc +41 -695
  537. data/src/core/lib/channel/promise_based_filter.cc +230 -266
  538. data/src/core/lib/channel/promise_based_filter.h +224 -548
  539. data/src/core/lib/channel/status_util.cc +3 -3
  540. data/src/core/lib/channel/status_util.h +1 -2
  541. data/src/core/lib/compression/compression.cc +5 -6
  542. data/src/core/lib/compression/compression_internal.cc +3 -3
  543. data/src/core/lib/compression/compression_internal.h +1 -2
  544. data/src/core/lib/compression/message_compress.cc +15 -14
  545. data/src/core/lib/compression/message_compress.h +1 -2
  546. data/src/core/lib/config/config_vars.cc +6 -18
  547. data/src/core/lib/config/config_vars.h +3 -13
  548. data/src/core/lib/config/config_vars_non_generated.cc +2 -2
  549. data/src/core/lib/config/core_configuration.cc +9 -8
  550. data/src/core/lib/config/core_configuration.h +8 -8
  551. data/src/core/lib/config/load_config.cc +4 -4
  552. data/src/core/lib/config/load_config.h +2 -2
  553. data/src/core/lib/debug/event_log.cc +3 -3
  554. data/src/core/lib/debug/event_log.h +3 -3
  555. data/src/core/lib/debug/trace.cc +45 -63
  556. data/src/core/lib/debug/trace.h +2 -97
  557. data/src/core/lib/debug/trace_flags.cc +257 -0
  558. data/src/core/lib/debug/trace_flags.h +134 -0
  559. data/src/core/lib/debug/trace_impl.h +119 -0
  560. data/src/core/lib/event_engine/ares_resolver.cc +70 -26
  561. data/src/core/lib/event_engine/ares_resolver.h +15 -10
  562. data/src/core/lib/event_engine/cf_engine/cf_engine.cc +14 -13
  563. data/src/core/lib/event_engine/cf_engine/cfstream_endpoint.cc +32 -31
  564. data/src/core/lib/event_engine/cf_engine/dns_service_resolver.cc +19 -24
  565. data/src/core/lib/event_engine/cf_engine/dns_service_resolver.h +2 -1
  566. data/src/core/lib/event_engine/channel_args_endpoint_config.cc +1 -2
  567. data/src/core/lib/event_engine/channel_args_endpoint_config.h +1 -2
  568. data/src/core/lib/event_engine/common_closures.h +1 -2
  569. data/src/core/lib/event_engine/default_event_engine.cc +7 -9
  570. data/src/core/lib/event_engine/default_event_engine.h +1 -2
  571. data/src/core/lib/event_engine/default_event_engine_factory.cc +1 -2
  572. data/src/core/lib/event_engine/default_event_engine_factory.h +1 -2
  573. data/src/core/lib/event_engine/event_engine.cc +35 -5
  574. data/src/core/lib/event_engine/event_engine_context.h +5 -4
  575. data/src/core/lib/event_engine/extensions/can_track_errors.h +2 -2
  576. data/src/core/lib/event_engine/extensions/chaotic_good_extension.h +2 -2
  577. data/src/core/lib/event_engine/extensions/supports_fd.h +8 -2
  578. data/src/core/lib/event_engine/extensions/tcp_trace.h +43 -0
  579. data/src/core/lib/event_engine/forkable.cc +11 -11
  580. data/src/core/lib/event_engine/forkable.h +1 -13
  581. data/src/core/lib/event_engine/grpc_polled_fd.h +1 -2
  582. data/src/core/lib/event_engine/handle_containers.h +1 -2
  583. data/src/core/lib/event_engine/memory_allocator_factory.h +1 -2
  584. data/src/core/lib/event_engine/poller.h +1 -2
  585. data/src/core/lib/event_engine/posix.h +1 -2
  586. data/src/core/lib/event_engine/posix_engine/ev_epoll1_linux.cc +19 -19
  587. data/src/core/lib/event_engine/posix_engine/ev_epoll1_linux.h +1 -2
  588. data/src/core/lib/event_engine/posix_engine/ev_poll_posix.cc +11 -11
  589. data/src/core/lib/event_engine/posix_engine/ev_poll_posix.h +1 -2
  590. data/src/core/lib/event_engine/posix_engine/event_poller.h +1 -2
  591. data/src/core/lib/event_engine/posix_engine/event_poller_posix_default.cc +2 -2
  592. data/src/core/lib/event_engine/posix_engine/event_poller_posix_default.h +2 -2
  593. data/src/core/lib/event_engine/posix_engine/grpc_polled_fd_posix.h +1 -2
  594. data/src/core/lib/event_engine/posix_engine/internal_errqueue.cc +5 -5
  595. data/src/core/lib/event_engine/posix_engine/internal_errqueue.h +2 -2
  596. data/src/core/lib/event_engine/posix_engine/lockfree_event.cc +3 -3
  597. data/src/core/lib/event_engine/posix_engine/lockfree_event.h +2 -2
  598. data/src/core/lib/event_engine/posix_engine/native_posix_dns_resolver.cc +1 -1
  599. data/src/core/lib/event_engine/posix_engine/native_posix_dns_resolver.h +2 -2
  600. data/src/core/lib/event_engine/posix_engine/posix_endpoint.cc +75 -88
  601. data/src/core/lib/event_engine/posix_engine/posix_endpoint.h +14 -13
  602. data/src/core/lib/event_engine/posix_engine/posix_engine.cc +41 -38
  603. data/src/core/lib/event_engine/posix_engine/posix_engine.h +3 -2
  604. data/src/core/lib/event_engine/posix_engine/posix_engine_closure.h +1 -2
  605. data/src/core/lib/event_engine/posix_engine/posix_engine_listener.cc +20 -21
  606. data/src/core/lib/event_engine/posix_engine/posix_engine_listener.h +1 -2
  607. data/src/core/lib/event_engine/posix_engine/posix_engine_listener_utils.cc +24 -28
  608. data/src/core/lib/event_engine/posix_engine/posix_engine_listener_utils.h +1 -2
  609. data/src/core/lib/event_engine/posix_engine/tcp_socket_utils.cc +39 -30
  610. data/src/core/lib/event_engine/posix_engine/tcp_socket_utils.h +5 -3
  611. data/src/core/lib/event_engine/posix_engine/timer.cc +2 -3
  612. data/src/core/lib/event_engine/posix_engine/timer.h +1 -2
  613. data/src/core/lib/event_engine/posix_engine/timer_heap.cc +2 -2
  614. data/src/core/lib/event_engine/posix_engine/timer_heap.h +2 -2
  615. data/src/core/lib/event_engine/posix_engine/timer_manager.cc +16 -19
  616. data/src/core/lib/event_engine/posix_engine/timer_manager.h +1 -2
  617. data/src/core/lib/event_engine/posix_engine/traced_buffer_list.cc +3 -3
  618. data/src/core/lib/event_engine/posix_engine/traced_buffer_list.h +1 -2
  619. data/src/core/lib/event_engine/posix_engine/wakeup_fd_eventfd.cc +2 -2
  620. data/src/core/lib/event_engine/posix_engine/wakeup_fd_eventfd.h +2 -2
  621. data/src/core/lib/event_engine/posix_engine/wakeup_fd_pipe.cc +2 -2
  622. data/src/core/lib/event_engine/posix_engine/wakeup_fd_pipe.h +2 -2
  623. data/src/core/lib/event_engine/posix_engine/wakeup_fd_posix.h +2 -2
  624. data/src/core/lib/event_engine/posix_engine/wakeup_fd_posix_default.cc +2 -2
  625. data/src/core/lib/event_engine/posix_engine/wakeup_fd_posix_default.h +2 -2
  626. data/src/core/lib/event_engine/query_extensions.h +3 -2
  627. data/src/core/lib/event_engine/ref_counted_dns_resolver_interface.h +1 -2
  628. data/src/core/lib/event_engine/resolved_address.cc +5 -4
  629. data/src/core/lib/event_engine/resolved_address_internal.h +1 -2
  630. data/src/core/lib/event_engine/shim.cc +3 -3
  631. data/src/core/lib/event_engine/slice.cc +4 -3
  632. data/src/core/lib/event_engine/slice_buffer.cc +1 -2
  633. data/src/core/lib/event_engine/tcp_socket_utils.cc +18 -16
  634. data/src/core/lib/event_engine/tcp_socket_utils.h +1 -2
  635. data/src/core/lib/event_engine/thread_local.cc +2 -2
  636. data/src/core/lib/event_engine/thread_local.h +1 -1
  637. data/src/core/lib/event_engine/thread_pool/thread_count.cc +4 -4
  638. data/src/core/lib/event_engine/thread_pool/thread_count.h +2 -3
  639. data/src/core/lib/event_engine/thread_pool/thread_pool.h +1 -2
  640. data/src/core/lib/event_engine/thread_pool/thread_pool_factory.cc +2 -2
  641. data/src/core/lib/event_engine/thread_pool/work_stealing_thread_pool.cc +35 -38
  642. data/src/core/lib/event_engine/thread_pool/work_stealing_thread_pool.h +4 -8
  643. data/src/core/lib/event_engine/thready_event_engine/thready_event_engine.cc +48 -21
  644. data/src/core/lib/event_engine/thready_event_engine/thready_event_engine.h +5 -5
  645. data/src/core/lib/event_engine/time_util.cc +1 -2
  646. data/src/core/lib/event_engine/time_util.h +1 -2
  647. data/src/core/lib/event_engine/utils.cc +1 -2
  648. data/src/core/lib/event_engine/utils.h +1 -2
  649. data/src/core/lib/event_engine/windows/grpc_polled_fd_windows.cc +31 -30
  650. data/src/core/lib/event_engine/windows/iocp.cc +20 -17
  651. data/src/core/lib/event_engine/windows/iocp.h +1 -1
  652. data/src/core/lib/event_engine/windows/win_socket.cc +46 -34
  653. data/src/core/lib/event_engine/windows/win_socket.h +4 -5
  654. data/src/core/lib/event_engine/windows/windows_endpoint.cc +34 -33
  655. data/src/core/lib/event_engine/windows/windows_engine.cc +237 -127
  656. data/src/core/lib/event_engine/windows/windows_engine.h +136 -25
  657. data/src/core/lib/event_engine/windows/windows_listener.cc +27 -40
  658. data/src/core/lib/event_engine/work_queue/basic_work_queue.cc +2 -2
  659. data/src/core/lib/event_engine/work_queue/basic_work_queue.h +1 -2
  660. data/src/core/lib/event_engine/work_queue/work_queue.h +1 -2
  661. data/src/core/lib/experiments/config.cc +49 -21
  662. data/src/core/lib/experiments/config.h +57 -3
  663. data/src/core/lib/experiments/experiments.cc +72 -209
  664. data/src/core/lib/experiments/experiments.h +64 -97
  665. data/src/core/lib/gprpp/atomic_utils.h +2 -2
  666. data/src/core/lib/gprpp/bitset.h +4 -4
  667. data/src/core/lib/gprpp/chunked_vector.h +6 -5
  668. data/src/core/lib/gprpp/construct_destruct.h +4 -4
  669. data/src/core/lib/gprpp/crash.cc +3 -5
  670. data/src/core/lib/gprpp/crash.h +2 -2
  671. data/src/core/lib/gprpp/debug_location.h +9 -2
  672. data/src/core/lib/gprpp/directory_reader.h +2 -2
  673. data/src/core/lib/gprpp/down_cast.h +5 -5
  674. data/src/core/lib/gprpp/dual_ref_counted.h +54 -41
  675. data/src/core/lib/gprpp/dump_args.cc +54 -0
  676. data/src/core/lib/gprpp/dump_args.h +117 -0
  677. data/src/core/lib/gprpp/env.h +2 -2
  678. data/src/core/lib/gprpp/examine_stack.cc +2 -2
  679. data/src/core/lib/gprpp/examine_stack.h +2 -2
  680. data/src/core/lib/gprpp/fork.cc +1 -2
  681. data/src/core/lib/gprpp/fork.h +2 -2
  682. data/src/core/lib/gprpp/glob.cc +70 -0
  683. data/src/core/lib/gprpp/glob.h +29 -0
  684. data/src/core/lib/gprpp/host_port.cc +6 -4
  685. data/src/core/lib/gprpp/host_port.h +2 -2
  686. data/src/core/lib/gprpp/linux/env.cc +2 -2
  687. data/src/core/lib/gprpp/load_file.cc +1 -2
  688. data/src/core/lib/gprpp/load_file.h +2 -2
  689. data/src/core/lib/gprpp/manual_constructor.h +2 -2
  690. data/src/core/lib/gprpp/match.h +2 -2
  691. data/src/core/lib/gprpp/memory.h +1 -2
  692. data/src/core/lib/gprpp/mpscq.cc +2 -2
  693. data/src/core/lib/gprpp/mpscq.h +5 -4
  694. data/src/core/lib/gprpp/no_destruct.h +2 -2
  695. data/src/core/lib/gprpp/notification.h +2 -2
  696. data/src/core/lib/gprpp/orphanable.h +2 -2
  697. data/src/core/lib/gprpp/overload.h +2 -2
  698. data/src/core/lib/gprpp/per_cpu.cc +2 -3
  699. data/src/core/lib/gprpp/per_cpu.h +1 -2
  700. data/src/core/lib/gprpp/posix/directory_reader.cc +2 -2
  701. data/src/core/lib/gprpp/posix/stat.cc +8 -7
  702. data/src/core/lib/gprpp/posix/thd.cc +18 -19
  703. data/src/core/lib/gprpp/ref_counted.h +35 -26
  704. data/src/core/lib/gprpp/ref_counted_ptr.h +2 -2
  705. data/src/core/lib/gprpp/ref_counted_string.cc +1 -2
  706. data/src/core/lib/gprpp/ref_counted_string.h +2 -2
  707. data/src/core/lib/gprpp/single_set_ptr.h +9 -6
  708. data/src/core/lib/gprpp/sorted_pack.h +2 -2
  709. data/src/core/lib/gprpp/stat.h +2 -2
  710. data/src/core/lib/gprpp/status_helper.cc +15 -34
  711. data/src/core/lib/gprpp/status_helper.h +5 -33
  712. data/src/core/lib/gprpp/strerror.cc +2 -2
  713. data/src/core/lib/gprpp/strerror.h +2 -2
  714. data/src/core/lib/gprpp/sync.h +5 -5
  715. data/src/core/lib/gprpp/table.h +25 -17
  716. data/src/core/lib/gprpp/tchar.cc +2 -2
  717. data/src/core/lib/gprpp/thd.h +7 -7
  718. data/src/core/lib/gprpp/time.cc +9 -10
  719. data/src/core/lib/gprpp/time.h +16 -21
  720. data/src/core/lib/gprpp/time_averaged_stats.cc +2 -2
  721. data/src/core/lib/gprpp/time_util.cc +5 -4
  722. data/src/core/lib/gprpp/time_util.h +1 -2
  723. data/src/core/lib/gprpp/unique_type_name.h +31 -11
  724. data/src/core/lib/gprpp/uuid_v4.cc +2 -2
  725. data/src/core/lib/gprpp/uuid_v4.h +2 -2
  726. data/src/core/lib/gprpp/validation_errors.cc +12 -3
  727. data/src/core/lib/gprpp/validation_errors.h +13 -2
  728. data/src/core/lib/gprpp/windows/stat.cc +6 -5
  729. data/src/core/lib/gprpp/windows/thd.cc +7 -4
  730. data/src/core/lib/gprpp/work_serializer.cc +75 -79
  731. data/src/core/lib/gprpp/work_serializer.h +1 -2
  732. data/src/core/lib/iomgr/buffer_list.cc +5 -4
  733. data/src/core/lib/iomgr/buffer_list.h +1 -2
  734. data/src/core/lib/iomgr/call_combiner.cc +42 -66
  735. data/src/core/lib/iomgr/call_combiner.h +9 -10
  736. data/src/core/lib/iomgr/cfstream_handle.cc +14 -16
  737. data/src/core/lib/iomgr/closure.cc +2 -2
  738. data/src/core/lib/iomgr/closure.h +11 -12
  739. data/src/core/lib/iomgr/combiner.cc +37 -47
  740. data/src/core/lib/iomgr/combiner.h +1 -4
  741. data/src/core/lib/iomgr/endpoint.cc +1 -7
  742. data/src/core/lib/iomgr/endpoint.h +3 -4
  743. data/src/core/lib/iomgr/endpoint_cfstream.cc +47 -71
  744. data/src/core/lib/iomgr/endpoint_pair_posix.cc +6 -5
  745. data/src/core/lib/iomgr/endpoint_pair_windows.cc +15 -15
  746. data/src/core/lib/iomgr/error.cc +19 -27
  747. data/src/core/lib/iomgr/error.h +4 -4
  748. data/src/core/lib/iomgr/ev_apple.cc +3 -5
  749. data/src/core/lib/iomgr/ev_epoll1_linux.cc +87 -92
  750. data/src/core/lib/iomgr/ev_poll_posix.cc +61 -52
  751. data/src/core/lib/iomgr/ev_posix.cc +12 -13
  752. data/src/core/lib/iomgr/ev_posix.h +13 -10
  753. data/src/core/lib/iomgr/event_engine_shims/closure.cc +9 -10
  754. data/src/core/lib/iomgr/event_engine_shims/closure.h +1 -2
  755. data/src/core/lib/iomgr/event_engine_shims/endpoint.cc +26 -42
  756. data/src/core/lib/iomgr/event_engine_shims/endpoint.h +1 -2
  757. data/src/core/lib/iomgr/event_engine_shims/tcp_client.cc +8 -12
  758. data/src/core/lib/iomgr/event_engine_shims/tcp_client.h +1 -2
  759. data/src/core/lib/iomgr/exec_ctx.cc +13 -13
  760. data/src/core/lib/iomgr/exec_ctx.h +7 -5
  761. data/src/core/lib/iomgr/executor.cc +20 -27
  762. data/src/core/lib/iomgr/executor.h +1 -1
  763. data/src/core/lib/iomgr/fork_posix.cc +8 -10
  764. data/src/core/lib/iomgr/fork_windows.cc +3 -1
  765. data/src/core/lib/iomgr/grpc_if_nametoindex.h +2 -2
  766. data/src/core/lib/iomgr/grpc_if_nametoindex_posix.cc +2 -3
  767. data/src/core/lib/iomgr/grpc_if_nametoindex_unsupported.cc +3 -5
  768. data/src/core/lib/iomgr/internal_errqueue.cc +5 -4
  769. data/src/core/lib/iomgr/iocp_windows.cc +13 -9
  770. data/src/core/lib/iomgr/iocp_windows.h +0 -1
  771. data/src/core/lib/iomgr/iomgr.cc +14 -19
  772. data/src/core/lib/iomgr/iomgr.h +2 -2
  773. data/src/core/lib/iomgr/iomgr_internal.cc +2 -2
  774. data/src/core/lib/iomgr/iomgr_internal.h +2 -2
  775. data/src/core/lib/iomgr/iomgr_windows.cc +4 -2
  776. data/src/core/lib/iomgr/lockfree_event.cc +13 -17
  777. data/src/core/lib/iomgr/lockfree_event.h +1 -2
  778. data/src/core/lib/iomgr/polling_entity.cc +5 -5
  779. data/src/core/lib/iomgr/pollset.cc +2 -2
  780. data/src/core/lib/iomgr/pollset.h +0 -3
  781. data/src/core/lib/iomgr/pollset_set.cc +2 -2
  782. data/src/core/lib/iomgr/pollset_set_windows.cc +2 -2
  783. data/src/core/lib/iomgr/pollset_windows.cc +0 -2
  784. data/src/core/lib/iomgr/pollset_windows.h +0 -1
  785. data/src/core/lib/iomgr/python_util.h +1 -2
  786. data/src/core/lib/iomgr/resolve_address.cc +1 -2
  787. data/src/core/lib/iomgr/resolve_address.h +1 -2
  788. data/src/core/lib/iomgr/resolve_address_impl.h +2 -2
  789. data/src/core/lib/iomgr/resolve_address_posix.cc +7 -14
  790. data/src/core/lib/iomgr/resolve_address_posix.h +2 -2
  791. data/src/core/lib/iomgr/resolve_address_windows.cc +1 -1
  792. data/src/core/lib/iomgr/resolve_address_windows.h +2 -2
  793. data/src/core/lib/iomgr/resolved_address.h +2 -2
  794. data/src/core/lib/iomgr/sockaddr_utils_posix.cc +3 -1
  795. data/src/core/lib/iomgr/socket_factory_posix.cc +1 -1
  796. data/src/core/lib/iomgr/socket_factory_posix.h +1 -2
  797. data/src/core/lib/iomgr/socket_mutator.cc +2 -3
  798. data/src/core/lib/iomgr/socket_mutator.h +1 -2
  799. data/src/core/lib/iomgr/socket_utils.h +2 -2
  800. data/src/core/lib/iomgr/socket_utils_common_posix.cc +41 -46
  801. data/src/core/lib/iomgr/socket_utils_posix.cc +2 -2
  802. data/src/core/lib/iomgr/socket_utils_posix.h +1 -2
  803. data/src/core/lib/iomgr/socket_windows.cc +8 -9
  804. data/src/core/lib/iomgr/tcp_client.cc +2 -2
  805. data/src/core/lib/iomgr/tcp_client.h +1 -2
  806. data/src/core/lib/iomgr/tcp_client_cfstream.cc +11 -12
  807. data/src/core/lib/iomgr/tcp_client_posix.cc +20 -26
  808. data/src/core/lib/iomgr/tcp_client_windows.cc +9 -9
  809. data/src/core/lib/iomgr/tcp_posix.cc +129 -159
  810. data/src/core/lib/iomgr/tcp_posix.h +0 -2
  811. data/src/core/lib/iomgr/tcp_server.cc +2 -2
  812. data/src/core/lib/iomgr/tcp_server.h +1 -2
  813. data/src/core/lib/iomgr/tcp_server_posix.cc +55 -67
  814. data/src/core/lib/iomgr/tcp_server_utils_posix.h +2 -2
  815. data/src/core/lib/iomgr/tcp_server_utils_posix_common.cc +10 -12
  816. data/src/core/lib/iomgr/tcp_server_utils_posix_ifaddrs.cc +9 -8
  817. data/src/core/lib/iomgr/tcp_server_windows.cc +25 -30
  818. data/src/core/lib/iomgr/tcp_windows.cc +41 -59
  819. data/src/core/lib/iomgr/timer.cc +2 -2
  820. data/src/core/lib/iomgr/timer.h +1 -2
  821. data/src/core/lib/iomgr/timer_generic.cc +72 -84
  822. data/src/core/lib/iomgr/timer_generic.h +0 -1
  823. data/src/core/lib/iomgr/timer_heap.cc +2 -3
  824. data/src/core/lib/iomgr/timer_manager.cc +25 -39
  825. data/src/core/lib/iomgr/timer_manager.h +2 -2
  826. data/src/core/lib/iomgr/unix_sockets_posix.cc +3 -2
  827. data/src/core/lib/iomgr/unix_sockets_posix.h +1 -2
  828. data/src/core/lib/iomgr/unix_sockets_posix_noop.cc +3 -1
  829. data/src/core/lib/iomgr/vsock.cc +3 -3
  830. data/src/core/lib/iomgr/vsock.h +1 -2
  831. data/src/core/lib/iomgr/wakeup_fd_pipe.cc +3 -3
  832. data/src/core/lib/matchers/matchers.cc +2 -2
  833. data/src/core/lib/matchers/matchers.h +2 -2
  834. data/src/core/lib/promise/activity.cc +4 -3
  835. data/src/core/lib/promise/activity.h +47 -13
  836. data/src/core/lib/promise/all_ok.h +17 -10
  837. data/src/core/lib/promise/arena_promise.h +2 -2
  838. data/src/core/lib/promise/cancel_callback.h +34 -6
  839. data/src/core/lib/promise/context.h +18 -7
  840. data/src/core/lib/promise/detail/basic_seq.h +1 -2
  841. data/src/core/lib/promise/detail/join_state.h +555 -759
  842. data/src/core/lib/promise/detail/promise_factory.h +46 -29
  843. data/src/core/lib/promise/detail/promise_like.h +29 -13
  844. data/src/core/lib/promise/detail/seq_state.h +1388 -1794
  845. data/src/core/lib/promise/detail/status.h +38 -16
  846. data/src/core/lib/promise/exec_ctx_wakeup_scheduler.h +2 -2
  847. data/src/core/lib/promise/for_each.h +101 -35
  848. data/src/core/lib/promise/if.h +21 -17
  849. data/src/core/lib/promise/interceptor_list.h +21 -23
  850. data/src/core/lib/promise/latch.h +26 -31
  851. data/src/core/lib/promise/loop.h +15 -10
  852. data/src/core/lib/promise/map.h +27 -9
  853. data/src/core/lib/promise/observable.h +182 -0
  854. data/src/core/lib/promise/party.cc +94 -76
  855. data/src/core/lib/promise/party.h +83 -102
  856. data/src/core/lib/promise/pipe.h +33 -53
  857. data/src/core/lib/promise/poll.h +105 -38
  858. data/src/core/lib/promise/prioritized_race.h +2 -2
  859. data/src/core/lib/promise/promise.h +14 -7
  860. data/src/core/lib/promise/race.h +12 -7
  861. data/src/core/lib/promise/seq.h +53 -38
  862. data/src/core/lib/promise/sleep.cc +1 -2
  863. data/src/core/lib/promise/sleep.h +1 -2
  864. data/src/core/lib/promise/status_flag.h +153 -52
  865. data/src/core/lib/promise/try_join.h +38 -21
  866. data/src/core/lib/promise/try_seq.h +87 -49
  867. data/src/core/lib/resource_quota/api.cc +1 -2
  868. data/src/core/lib/resource_quota/api.h +1 -2
  869. data/src/core/lib/resource_quota/arena.cc +63 -85
  870. data/src/core/lib/resource_quota/arena.h +141 -213
  871. data/src/core/lib/resource_quota/connection_quota.cc +8 -9
  872. data/src/core/lib/resource_quota/connection_quota.h +2 -2
  873. data/src/core/lib/resource_quota/memory_quota.cc +34 -36
  874. data/src/core/lib/resource_quota/memory_quota.h +9 -9
  875. data/src/core/lib/resource_quota/periodic_update.cc +6 -5
  876. data/src/core/lib/resource_quota/periodic_update.h +2 -2
  877. data/src/core/lib/resource_quota/resource_quota.cc +2 -2
  878. data/src/core/lib/resource_quota/resource_quota.h +2 -3
  879. data/src/core/lib/resource_quota/thread_quota.cc +4 -3
  880. data/src/core/lib/resource_quota/thread_quota.h +2 -2
  881. data/src/core/lib/security/authorization/audit_logging.cc +6 -6
  882. data/src/core/lib/security/authorization/audit_logging.h +1 -2
  883. data/src/core/lib/security/authorization/authorization_engine.h +2 -2
  884. data/src/core/lib/security/authorization/authorization_policy_provider.h +2 -3
  885. data/src/core/lib/security/authorization/authorization_policy_provider_vtable.cc +2 -3
  886. data/src/core/lib/security/authorization/evaluate_args.cc +8 -11
  887. data/src/core/lib/security/authorization/evaluate_args.h +1 -2
  888. data/src/core/lib/security/authorization/grpc_authorization_engine.cc +4 -3
  889. data/src/core/lib/security/authorization/grpc_authorization_engine.h +1 -2
  890. data/src/core/lib/security/authorization/grpc_server_authz_filter.cc +22 -28
  891. data/src/core/lib/security/authorization/grpc_server_authz_filter.h +10 -8
  892. data/src/core/lib/security/authorization/matchers.cc +4 -5
  893. data/src/core/lib/security/authorization/matchers.h +2 -2
  894. data/src/core/lib/security/authorization/rbac_policy.cc +2 -2
  895. data/src/core/lib/security/authorization/rbac_policy.h +1 -2
  896. data/src/core/lib/security/authorization/stdout_logger.cc +4 -3
  897. data/src/core/lib/security/authorization/stdout_logger.h +1 -2
  898. data/src/core/lib/security/certificate_provider/certificate_provider_factory.h +4 -4
  899. data/src/core/lib/security/certificate_provider/certificate_provider_registry.cc +6 -6
  900. data/src/core/lib/security/certificate_provider/certificate_provider_registry.h +2 -2
  901. data/src/core/lib/security/context/security_context.cc +48 -44
  902. data/src/core/lib/security/context/security_context.h +33 -10
  903. data/src/core/lib/security/credentials/alts/alts_credentials.cc +1 -2
  904. data/src/core/lib/security/credentials/alts/alts_credentials.h +3 -3
  905. data/src/core/lib/security/credentials/alts/check_gcp_environment.cc +4 -3
  906. data/src/core/lib/security/credentials/alts/check_gcp_environment_no_op.cc +2 -3
  907. data/src/core/lib/security/credentials/alts/grpc_alts_credentials_client_options.cc +5 -6
  908. data/src/core/lib/security/credentials/alts/grpc_alts_credentials_options.cc +4 -5
  909. data/src/core/lib/security/credentials/alts/grpc_alts_credentials_options.h +2 -2
  910. data/src/core/lib/security/credentials/alts/grpc_alts_credentials_server_options.cc +1 -2
  911. data/src/core/lib/security/credentials/call_creds_util.cc +3 -3
  912. data/src/core/lib/security/credentials/call_creds_util.h +2 -2
  913. data/src/core/lib/security/credentials/channel_creds_registry.h +4 -4
  914. data/src/core/lib/security/credentials/channel_creds_registry_init.cc +7 -5
  915. data/src/core/lib/security/credentials/composite/composite_credentials.cc +16 -17
  916. data/src/core/lib/security/credentials/composite/composite_credentials.h +3 -3
  917. data/src/core/lib/security/credentials/credentials.cc +21 -18
  918. data/src/core/lib/security/credentials/credentials.h +5 -4
  919. data/src/core/lib/security/credentials/external/aws_external_account_credentials.cc +9 -8
  920. data/src/core/lib/security/credentials/external/aws_external_account_credentials.h +4 -4
  921. data/src/core/lib/security/credentials/external/aws_request_signer.cc +2 -2
  922. data/src/core/lib/security/credentials/external/aws_request_signer.h +2 -2
  923. data/src/core/lib/security/credentials/external/external_account_credentials.cc +16 -17
  924. data/src/core/lib/security/credentials/external/external_account_credentials.h +5 -5
  925. data/src/core/lib/security/credentials/external/file_external_account_credentials.cc +3 -4
  926. data/src/core/lib/security/credentials/external/file_external_account_credentials.h +2 -2
  927. data/src/core/lib/security/credentials/external/url_external_account_credentials.cc +8 -7
  928. data/src/core/lib/security/credentials/external/url_external_account_credentials.h +3 -3
  929. data/src/core/lib/security/credentials/fake/fake_credentials.cc +2 -2
  930. data/src/core/lib/security/credentials/fake/fake_credentials.h +3 -3
  931. data/src/core/lib/security/credentials/google_default/credentials_generic.cc +4 -5
  932. data/src/core/lib/security/credentials/google_default/google_default_credentials.cc +21 -21
  933. data/src/core/lib/security/credentials/google_default/google_default_credentials.h +3 -3
  934. data/src/core/lib/security/credentials/iam/iam_credentials.cc +8 -10
  935. data/src/core/lib/security/credentials/iam/iam_credentials.h +3 -3
  936. data/src/core/lib/security/credentials/insecure/insecure_credentials.cc +2 -2
  937. data/src/core/lib/security/credentials/insecure/insecure_credentials.h +2 -2
  938. data/src/core/lib/security/credentials/jwt/json_token.cc +19 -19
  939. data/src/core/lib/security/credentials/jwt/json_token.h +2 -3
  940. data/src/core/lib/security/credentials/jwt/jwt_credentials.cc +18 -22
  941. data/src/core/lib/security/credentials/jwt/jwt_credentials.h +3 -3
  942. data/src/core/lib/security/credentials/jwt/jwt_verifier.cc +65 -69
  943. data/src/core/lib/security/credentials/jwt/jwt_verifier.h +2 -3
  944. data/src/core/lib/security/credentials/local/local_credentials.cc +1 -2
  945. data/src/core/lib/security/credentials/local/local_credentials.h +3 -3
  946. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.cc +40 -42
  947. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.h +6 -6
  948. data/src/core/lib/security/credentials/plugin/plugin_credentials.cc +20 -28
  949. data/src/core/lib/security/credentials/plugin/plugin_credentials.h +3 -5
  950. data/src/core/lib/security/credentials/ssl/ssl_credentials.cc +44 -54
  951. data/src/core/lib/security/credentials/ssl/ssl_credentials.h +6 -4
  952. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_distributor.cc +26 -25
  953. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_distributor.h +2 -2
  954. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_match.cc +2 -2
  955. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.cc +30 -39
  956. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.h +4 -4
  957. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_verifier.cc +5 -6
  958. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_verifier.h +5 -4
  959. data/src/core/lib/security/credentials/tls/grpc_tls_credentials_options.cc +25 -26
  960. data/src/core/lib/security/credentials/tls/grpc_tls_credentials_options.h +1 -0
  961. data/src/core/lib/security/credentials/tls/grpc_tls_crl_provider.cc +5 -7
  962. data/src/core/lib/security/credentials/tls/grpc_tls_crl_provider.h +1 -2
  963. data/src/core/lib/security/credentials/tls/tls_credentials.cc +15 -18
  964. data/src/core/lib/security/credentials/tls/tls_credentials.h +2 -2
  965. data/src/core/lib/security/credentials/tls/tls_utils.cc +5 -6
  966. data/src/core/lib/security/credentials/tls/tls_utils.h +1 -2
  967. data/src/core/lib/security/credentials/xds/xds_credentials.cc +20 -16
  968. data/src/core/lib/security/credentials/xds/xds_credentials.h +3 -3
  969. data/src/core/lib/security/security_connector/alts/alts_security_connector.cc +27 -30
  970. data/src/core/lib/security/security_connector/alts/alts_security_connector.h +2 -2
  971. data/src/core/lib/security/security_connector/fake/fake_security_connector.cc +20 -17
  972. data/src/core/lib/security/security_connector/fake/fake_security_connector.h +2 -2
  973. data/src/core/lib/security/security_connector/insecure/insecure_security_connector.cc +6 -5
  974. data/src/core/lib/security/security_connector/insecure/insecure_security_connector.h +3 -3
  975. data/src/core/lib/security/security_connector/load_system_roots.h +1 -2
  976. data/src/core/lib/security/security_connector/load_system_roots_supported.cc +8 -8
  977. data/src/core/lib/security/security_connector/load_system_roots_supported.h +1 -2
  978. data/src/core/lib/security/security_connector/load_system_roots_windows.cc +1 -1
  979. data/src/core/lib/security/security_connector/local/local_security_connector.cc +19 -23
  980. data/src/core/lib/security/security_connector/local/local_security_connector.h +2 -2
  981. data/src/core/lib/security/security_connector/security_connector.cc +11 -13
  982. data/src/core/lib/security/security_connector/security_connector.h +4 -6
  983. data/src/core/lib/security/security_connector/ssl/ssl_security_connector.cc +23 -25
  984. data/src/core/lib/security/security_connector/ssl/ssl_security_connector.h +2 -2
  985. data/src/core/lib/security/security_connector/ssl_utils.cc +32 -30
  986. data/src/core/lib/security/security_connector/ssl_utils.h +1 -2
  987. data/src/core/lib/security/security_connector/tls/tls_security_connector.cc +42 -53
  988. data/src/core/lib/security/security_connector/tls/tls_security_connector.h +3 -3
  989. data/src/core/lib/security/transport/auth_filters.h +18 -13
  990. data/src/core/lib/security/transport/client_auth_filter.cc +14 -20
  991. data/src/core/lib/security/transport/server_auth_filter.cc +18 -24
  992. data/src/core/lib/security/util/json_util.cc +1 -2
  993. data/src/core/lib/security/util/json_util.h +1 -1
  994. data/src/core/lib/slice/percent_encoding.cc +4 -3
  995. data/src/core/lib/slice/slice.cc +11 -10
  996. data/src/core/lib/slice/slice.h +5 -5
  997. data/src/core/lib/slice/slice_buffer.cc +15 -14
  998. data/src/core/lib/slice/slice_buffer.h +1 -2
  999. data/src/core/lib/slice/slice_internal.h +3 -3
  1000. data/src/core/lib/slice/slice_refcount.h +7 -12
  1001. data/src/core/lib/slice/slice_string_helpers.cc +3 -3
  1002. data/src/core/lib/slice/slice_string_helpers.h +1 -2
  1003. data/src/core/lib/surface/byte_buffer.cc +1 -2
  1004. data/src/core/lib/surface/byte_buffer_reader.cc +4 -3
  1005. data/src/core/lib/surface/call.cc +179 -3962
  1006. data/src/core/lib/surface/call.h +172 -94
  1007. data/src/core/lib/surface/call_details.cc +5 -5
  1008. data/src/core/lib/surface/call_log_batch.cc +6 -8
  1009. data/src/core/lib/surface/call_test_only.h +1 -2
  1010. data/src/core/lib/surface/call_utils.cc +274 -0
  1011. data/src/core/lib/surface/call_utils.h +449 -0
  1012. data/src/core/lib/surface/channel.cc +48 -44
  1013. data/src/core/lib/surface/channel.h +12 -10
  1014. data/src/core/lib/surface/channel_create.cc +31 -13
  1015. data/src/core/lib/surface/channel_create.h +5 -4
  1016. data/src/core/lib/surface/channel_init.cc +271 -266
  1017. data/src/core/lib/surface/channel_init.h +178 -116
  1018. data/src/core/lib/surface/channel_stack_type.cc +2 -2
  1019. data/src/core/lib/surface/client_call.cc +430 -0
  1020. data/src/core/lib/surface/client_call.h +180 -0
  1021. data/src/core/lib/surface/completion_queue.cc +88 -107
  1022. data/src/core/lib/surface/completion_queue.h +1 -10
  1023. data/src/core/lib/surface/completion_queue_factory.cc +9 -8
  1024. data/src/core/lib/surface/completion_queue_factory.h +1 -2
  1025. data/src/core/lib/surface/event_string.cc +2 -2
  1026. data/src/core/lib/surface/event_string.h +1 -2
  1027. data/src/core/lib/surface/filter_stack_call.cc +1158 -0
  1028. data/src/core/lib/surface/filter_stack_call.h +369 -0
  1029. data/src/core/lib/surface/init.cc +33 -15
  1030. data/src/core/lib/surface/init_internally.cc +2 -2
  1031. data/src/core/lib/surface/lame_client.cc +11 -15
  1032. data/src/core/lib/surface/lame_client.h +8 -11
  1033. data/src/core/lib/surface/legacy_channel.cc +60 -45
  1034. data/src/core/lib/surface/legacy_channel.h +11 -21
  1035. data/src/core/lib/surface/metadata_array.cc +5 -5
  1036. data/src/core/lib/surface/server_call.cc +224 -0
  1037. data/src/core/lib/surface/server_call.h +169 -0
  1038. data/src/core/lib/surface/validate_metadata.cc +1 -2
  1039. data/src/core/lib/surface/validate_metadata.h +3 -3
  1040. data/src/core/lib/surface/version.cc +3 -4
  1041. data/src/core/lib/transport/bdp_estimator.cc +14 -16
  1042. data/src/core/lib/transport/bdp_estimator.h +11 -13
  1043. data/src/core/lib/transport/{call_size_estimator.cc → call_arena_allocator.cc} +3 -3
  1044. data/src/core/lib/transport/{call_size_estimator.h → call_arena_allocator.h} +31 -6
  1045. data/src/core/lib/transport/call_destination.h +76 -0
  1046. data/src/core/lib/transport/call_filters.cc +100 -314
  1047. data/src/core/lib/transport/call_filters.h +459 -726
  1048. data/src/core/lib/transport/call_final_info.cc +2 -2
  1049. data/src/core/lib/transport/call_final_info.h +1 -2
  1050. data/src/core/lib/transport/call_spine.cc +104 -79
  1051. data/src/core/lib/transport/call_spine.h +215 -242
  1052. data/src/core/lib/transport/call_state.cc +39 -0
  1053. data/src/core/lib/transport/call_state.h +957 -0
  1054. data/src/core/lib/transport/connectivity_state.cc +37 -37
  1055. data/src/core/lib/transport/connectivity_state.h +1 -4
  1056. data/src/core/lib/transport/error_utils.cc +1 -2
  1057. data/src/core/lib/transport/error_utils.h +1 -2
  1058. data/src/core/lib/transport/interception_chain.cc +147 -0
  1059. data/src/core/lib/transport/interception_chain.h +244 -0
  1060. data/src/core/lib/transport/message.cc +1 -2
  1061. data/src/core/lib/transport/metadata.cc +29 -5
  1062. data/src/core/lib/transport/metadata.h +37 -2
  1063. data/src/core/lib/transport/metadata_batch.cc +2 -2
  1064. data/src/core/lib/transport/metadata_batch.h +48 -5
  1065. data/src/core/lib/transport/metadata_compression_traits.h +2 -2
  1066. data/src/core/lib/transport/metadata_info.cc +2 -2
  1067. data/src/core/lib/transport/metadata_info.h +1 -1
  1068. data/src/core/lib/transport/parsed_metadata.cc +2 -2
  1069. data/src/core/lib/transport/parsed_metadata.h +1 -2
  1070. data/src/core/lib/transport/simple_slice_based_metadata.h +2 -2
  1071. data/src/core/lib/transport/status_conversion.cc +2 -2
  1072. data/src/core/lib/transport/status_conversion.h +1 -2
  1073. data/src/core/lib/transport/timeout_encoding.cc +5 -5
  1074. data/src/core/lib/transport/timeout_encoding.h +2 -2
  1075. data/src/core/lib/transport/transport.cc +4 -8
  1076. data/src/core/lib/transport/transport.h +89 -79
  1077. data/src/core/lib/transport/transport_op_string.cc +1 -2
  1078. data/src/core/lib/uri/uri_parser.cc +3 -3
  1079. data/src/core/lib/uri/uri_parser.h +2 -2
  1080. data/src/core/load_balancing/address_filtering.cc +2 -2
  1081. data/src/core/load_balancing/address_filtering.h +2 -2
  1082. data/src/core/load_balancing/backend_metric_data.h +2 -2
  1083. data/src/core/load_balancing/backend_metric_parser.cc +2 -2
  1084. data/src/core/load_balancing/backend_metric_parser.h +2 -2
  1085. data/src/core/load_balancing/child_policy_handler.cc +38 -41
  1086. data/src/core/load_balancing/child_policy_handler.h +2 -2
  1087. data/src/core/load_balancing/delegating_helper.h +2 -3
  1088. data/src/core/load_balancing/endpoint_list.cc +11 -13
  1089. data/src/core/load_balancing/endpoint_list.h +16 -10
  1090. data/src/core/load_balancing/grpclb/client_load_reporting_filter.cc +30 -32
  1091. data/src/core/load_balancing/grpclb/client_load_reporting_filter.h +23 -8
  1092. data/src/core/load_balancing/grpclb/grpclb.cc +160 -176
  1093. data/src/core/load_balancing/grpclb/grpclb_balancer_addresses.cc +3 -3
  1094. data/src/core/load_balancing/grpclb/grpclb_balancer_addresses.h +1 -2
  1095. data/src/core/load_balancing/grpclb/grpclb_client_stats.cc +1 -2
  1096. data/src/core/load_balancing/grpclb/grpclb_client_stats.h +1 -2
  1097. data/src/core/load_balancing/grpclb/load_balancer_api.cc +4 -6
  1098. data/src/core/load_balancing/grpclb/load_balancer_api.h +2 -3
  1099. data/src/core/load_balancing/health_check_client.cc +47 -57
  1100. data/src/core/load_balancing/health_check_client.h +2 -2
  1101. data/src/core/load_balancing/health_check_client_internal.h +1 -2
  1102. data/src/core/load_balancing/lb_policy.cc +7 -10
  1103. data/src/core/load_balancing/lb_policy.h +62 -27
  1104. data/src/core/load_balancing/lb_policy_factory.h +3 -3
  1105. data/src/core/load_balancing/lb_policy_registry.cc +5 -6
  1106. data/src/core/load_balancing/lb_policy_registry.h +3 -3
  1107. data/src/core/load_balancing/oob_backend_metric.cc +10 -13
  1108. data/src/core/load_balancing/oob_backend_metric.h +2 -2
  1109. data/src/core/load_balancing/oob_backend_metric_internal.h +1 -2
  1110. data/src/core/load_balancing/outlier_detection/outlier_detection.cc +122 -142
  1111. data/src/core/load_balancing/outlier_detection/outlier_detection.h +5 -5
  1112. data/src/core/load_balancing/pick_first/pick_first.cc +1212 -251
  1113. data/src/core/load_balancing/priority/priority.cc +104 -112
  1114. data/src/core/load_balancing/ring_hash/ring_hash.cc +79 -70
  1115. data/src/core/load_balancing/ring_hash/ring_hash.h +5 -5
  1116. data/src/core/load_balancing/rls/rls.cc +331 -282
  1117. data/src/core/load_balancing/round_robin/round_robin.cc +82 -73
  1118. data/src/core/load_balancing/subchannel_interface.h +5 -2
  1119. data/src/core/load_balancing/weighted_round_robin/static_stride_scheduler.cc +4 -4
  1120. data/src/core/load_balancing/weighted_round_robin/static_stride_scheduler.h +2 -2
  1121. data/src/core/load_balancing/weighted_round_robin/weighted_round_robin.cc +154 -132
  1122. data/src/core/load_balancing/weighted_target/weighted_target.cc +76 -87
  1123. data/src/core/load_balancing/weighted_target/weighted_target.h +1 -1
  1124. data/src/core/load_balancing/xds/cds.cc +47 -50
  1125. data/src/core/load_balancing/xds/xds_cluster_impl.cc +128 -103
  1126. data/src/core/load_balancing/xds/xds_cluster_manager.cc +48 -65
  1127. data/src/core/load_balancing/xds/xds_override_host.cc +114 -138
  1128. data/src/core/load_balancing/xds/xds_override_host.h +5 -5
  1129. data/src/core/load_balancing/xds/xds_wrr_locality.cc +31 -33
  1130. data/src/core/plugin_registry/grpc_plugin_registry.cc +11 -10
  1131. data/src/core/plugin_registry/grpc_plugin_registry_extra.cc +1 -2
  1132. data/src/core/resolver/binder/binder_resolver.cc +7 -6
  1133. data/src/core/resolver/dns/c_ares/dns_resolver_ares.cc +17 -8
  1134. data/src/core/resolver/dns/c_ares/dns_resolver_ares.h +2 -2
  1135. data/src/core/resolver/dns/c_ares/grpc_ares_ev_driver.h +3 -3
  1136. data/src/core/resolver/dns/c_ares/grpc_ares_ev_driver_posix.cc +4 -3
  1137. data/src/core/resolver/dns/c_ares/grpc_ares_ev_driver_windows.cc +36 -35
  1138. data/src/core/resolver/dns/c_ares/grpc_ares_wrapper.cc +33 -50
  1139. data/src/core/resolver/dns/c_ares/grpc_ares_wrapper.h +7 -12
  1140. data/src/core/resolver/dns/c_ares/grpc_ares_wrapper_posix.cc +1 -1
  1141. data/src/core/resolver/dns/c_ares/grpc_ares_wrapper_windows.cc +2 -2
  1142. data/src/core/resolver/dns/dns_resolver_plugin.cc +10 -10
  1143. data/src/core/resolver/dns/event_engine/event_engine_client_channel_resolver.cc +12 -18
  1144. data/src/core/resolver/dns/event_engine/event_engine_client_channel_resolver.h +3 -3
  1145. data/src/core/resolver/dns/event_engine/service_config_helper.cc +7 -7
  1146. data/src/core/resolver/dns/event_engine/service_config_helper.h +2 -2
  1147. data/src/core/resolver/dns/native/dns_resolver.cc +17 -20
  1148. data/src/core/resolver/endpoint_addresses.cc +5 -5
  1149. data/src/core/resolver/endpoint_addresses.h +5 -2
  1150. data/src/core/resolver/fake/fake_resolver.cc +5 -5
  1151. data/src/core/resolver/fake/fake_resolver.h +2 -3
  1152. data/src/core/resolver/google_c2p/google_c2p_resolver.cc +22 -23
  1153. data/src/core/resolver/polling_resolver.cc +35 -40
  1154. data/src/core/resolver/polling_resolver.h +1 -2
  1155. data/src/core/resolver/resolver.cc +3 -7
  1156. data/src/core/resolver/resolver.h +2 -7
  1157. data/src/core/resolver/resolver_factory.h +3 -3
  1158. data/src/core/resolver/resolver_registry.cc +11 -13
  1159. data/src/core/resolver/resolver_registry.h +3 -3
  1160. data/src/core/resolver/sockaddr/sockaddr_resolver.cc +5 -6
  1161. data/src/core/resolver/xds/xds_dependency_manager.cc +94 -84
  1162. data/src/core/resolver/xds/xds_dependency_manager.h +11 -7
  1163. data/src/core/resolver/xds/xds_resolver.cc +103 -83
  1164. data/src/core/resolver/xds/xds_resolver_attributes.h +7 -3
  1165. data/src/core/{lib/surface → server}/server.cc +376 -498
  1166. data/src/core/{lib/surface → server}/server.h +43 -26
  1167. data/src/core/{lib/channel → server}/server_call_tracer_filter.cc +19 -22
  1168. data/src/core/{lib/channel → server}/server_call_tracer_filter.h +3 -3
  1169. data/src/core/{ext/filters/server_config_selector → server}/server_config_selector.h +6 -6
  1170. data/src/core/{ext/filters/server_config_selector → server}/server_config_selector_filter.cc +45 -42
  1171. data/src/core/{ext/filters/server_config_selector → server}/server_config_selector_filter.h +3 -3
  1172. data/src/core/{lib/surface → server}/server_interface.h +6 -4
  1173. data/src/core/{ext/xds → server}/xds_channel_stack_modifier.cc +5 -5
  1174. data/src/core/{ext/xds → server}/xds_channel_stack_modifier.h +5 -6
  1175. data/src/core/{ext/xds → server}/xds_server_config_fetcher.cc +64 -70
  1176. data/src/core/service_config/service_config.h +2 -3
  1177. data/src/core/service_config/service_config_call_data.h +17 -14
  1178. data/src/core/service_config/service_config_channel_arg_filter.cc +15 -13
  1179. data/src/core/service_config/service_config_impl.cc +7 -7
  1180. data/src/core/service_config/service_config_impl.h +4 -4
  1181. data/src/core/service_config/service_config_parser.cc +4 -8
  1182. data/src/core/service_config/service_config_parser.h +3 -3
  1183. data/src/core/{lib/channel → telemetry}/call_tracer.cc +59 -35
  1184. data/src/core/{lib/channel → telemetry}/call_tracer.h +48 -11
  1185. data/src/core/{lib/debug → telemetry}/histogram_view.cc +2 -2
  1186. data/src/core/{lib/debug → telemetry}/histogram_view.h +5 -5
  1187. data/src/core/telemetry/metrics.cc +178 -0
  1188. data/src/core/telemetry/metrics.h +567 -0
  1189. data/src/core/{lib/debug → telemetry}/stats.cc +3 -3
  1190. data/src/core/{lib/debug → telemetry}/stats.h +7 -7
  1191. data/src/core/{lib/debug → telemetry}/stats_data.cc +3 -3
  1192. data/src/core/{lib/debug → telemetry}/stats_data.h +6 -6
  1193. data/src/core/{lib/channel → telemetry}/tcp_tracer.h +5 -5
  1194. data/src/core/tsi/alts/crypt/aes_gcm.cc +1 -2
  1195. data/src/core/tsi/alts/crypt/gsec.cc +1 -2
  1196. data/src/core/tsi/alts/crypt/gsec.h +1 -2
  1197. data/src/core/tsi/alts/frame_protector/alts_counter.cc +1 -2
  1198. data/src/core/tsi/alts/frame_protector/alts_counter.h +1 -2
  1199. data/src/core/tsi/alts/frame_protector/alts_crypter.cc +1 -2
  1200. data/src/core/tsi/alts/frame_protector/alts_crypter.h +1 -2
  1201. data/src/core/tsi/alts/frame_protector/alts_frame_protector.cc +13 -15
  1202. data/src/core/tsi/alts/frame_protector/alts_frame_protector.h +2 -2
  1203. data/src/core/tsi/alts/frame_protector/alts_record_protocol_crypter_common.cc +1 -2
  1204. data/src/core/tsi/alts/frame_protector/alts_record_protocol_crypter_common.h +1 -2
  1205. data/src/core/tsi/alts/frame_protector/alts_seal_privacy_integrity_crypter.cc +1 -2
  1206. data/src/core/tsi/alts/frame_protector/alts_unseal_privacy_integrity_crypter.cc +1 -2
  1207. data/src/core/tsi/alts/frame_protector/frame_handler.cc +9 -9
  1208. data/src/core/tsi/alts/frame_protector/frame_handler.h +2 -2
  1209. data/src/core/tsi/alts/handshaker/alts_handshaker_client.cc +69 -72
  1210. data/src/core/tsi/alts/handshaker/alts_handshaker_client.h +1 -2
  1211. data/src/core/tsi/alts/handshaker/alts_shared_resource.cc +5 -4
  1212. data/src/core/tsi/alts/handshaker/alts_shared_resource.h +1 -2
  1213. data/src/core/tsi/alts/handshaker/alts_tsi_handshaker.cc +59 -61
  1214. data/src/core/tsi/alts/handshaker/alts_tsi_handshaker.h +1 -2
  1215. data/src/core/tsi/alts/handshaker/alts_tsi_utils.cc +7 -5
  1216. data/src/core/tsi/alts/handshaker/alts_tsi_utils.h +1 -2
  1217. data/src/core/tsi/alts/handshaker/transport_security_common_api.cc +17 -24
  1218. data/src/core/tsi/alts/handshaker/transport_security_common_api.h +1 -2
  1219. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_integrity_only_record_protocol.cc +16 -16
  1220. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_integrity_only_record_protocol.h +2 -2
  1221. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_privacy_integrity_record_protocol.cc +12 -13
  1222. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_privacy_integrity_record_protocol.h +2 -2
  1223. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_record_protocol.h +1 -2
  1224. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_record_protocol_common.cc +15 -11
  1225. data/src/core/tsi/alts/zero_copy_frame_protector/alts_iovec_record_protocol.cc +1 -2
  1226. data/src/core/tsi/alts/zero_copy_frame_protector/alts_iovec_record_protocol.h +2 -2
  1227. data/src/core/tsi/alts/zero_copy_frame_protector/alts_zero_copy_grpc_protector.cc +12 -13
  1228. data/src/core/tsi/alts/zero_copy_frame_protector/alts_zero_copy_grpc_protector.h +2 -2
  1229. data/src/core/tsi/fake_transport_security.cc +28 -29
  1230. data/src/core/tsi/local_transport_security.cc +7 -7
  1231. data/src/core/tsi/local_transport_security.h +1 -2
  1232. data/src/core/tsi/ssl/key_logging/ssl_key_logging.cc +11 -12
  1233. data/src/core/tsi/ssl/key_logging/ssl_key_logging.h +1 -2
  1234. data/src/core/tsi/ssl/session_cache/ssl_session.h +1 -2
  1235. data/src/core/tsi/ssl/session_cache/ssl_session_cache.cc +15 -14
  1236. data/src/core/tsi/ssl/session_cache/ssl_session_cache.h +1 -2
  1237. data/src/core/tsi/ssl/session_cache/ssl_session_openssl.cc +3 -4
  1238. data/src/core/tsi/ssl_transport_security.cc +128 -117
  1239. data/src/core/tsi/ssl_transport_security.h +1 -2
  1240. data/src/core/tsi/ssl_transport_security_utils.cc +87 -31
  1241. data/src/core/tsi/ssl_transport_security_utils.h +12 -2
  1242. data/src/core/tsi/ssl_types.h +2 -2
  1243. data/src/core/tsi/transport_security.cc +1 -6
  1244. data/src/core/tsi/transport_security.h +2 -4
  1245. data/src/core/tsi/transport_security_grpc.cc +2 -2
  1246. data/src/core/tsi/transport_security_grpc.h +1 -2
  1247. data/src/core/tsi/transport_security_interface.h +2 -6
  1248. data/src/core/{lib/gpr → util}/alloc.cc +3 -1
  1249. data/src/core/{lib/gpr → util}/alloc.h +3 -3
  1250. data/src/core/{lib/gpr → util}/android/log.cc +0 -31
  1251. data/src/core/{lib/gpr → util}/atm.cc +1 -1
  1252. data/src/core/{ext/gcp/metadata_query.cc → util/gcp_metadata_query.cc} +26 -26
  1253. data/src/core/{ext/gcp/metadata_query.h → util/gcp_metadata_query.h} +9 -9
  1254. data/src/core/{lib/http → util/http_client}/format_request.cc +2 -2
  1255. data/src/core/{lib/http → util/http_client}/format_request.h +4 -4
  1256. data/src/core/{lib/http → util/http_client}/httpcli.cc +31 -44
  1257. data/src/core/{lib/http → util/http_client}/httpcli.h +8 -9
  1258. data/src/core/{lib/http → util/http_client}/httpcli_security_connector.cc +10 -10
  1259. data/src/core/{lib/http → util/http_client}/httpcli_ssl_credentials.h +3 -3
  1260. data/src/core/{lib/http → util/http_client}/parser.cc +9 -10
  1261. data/src/core/{lib/http → util/http_client}/parser.h +3 -5
  1262. data/src/core/{lib → util}/json/json.h +3 -3
  1263. data/src/core/{lib → util}/json/json_args.h +3 -3
  1264. data/src/core/{lib → util}/json/json_channel_args.h +4 -4
  1265. data/src/core/{lib → util}/json/json_object_loader.cc +1 -1
  1266. data/src/core/{lib → util}/json/json_object_loader.h +5 -5
  1267. data/src/core/{lib → util}/json/json_reader.cc +4 -3
  1268. data/src/core/{lib → util}/json/json_reader.h +4 -4
  1269. data/src/core/{lib → util}/json/json_util.cc +3 -3
  1270. data/src/core/{lib → util}/json/json_util.h +4 -4
  1271. data/src/core/{lib → util}/json/json_writer.cc +1 -1
  1272. data/src/core/{lib → util}/json/json_writer.h +4 -4
  1273. data/src/core/util/latent_see.cc +113 -0
  1274. data/src/core/util/latent_see.h +214 -0
  1275. data/src/core/{lib/gpr → util}/linux/cpu.cc +8 -7
  1276. data/src/core/{lib/gpr → util}/linux/log.cc +0 -45
  1277. data/src/core/util/log.cc +149 -0
  1278. data/src/core/{lib/gpr → util}/msys/tmpfile.cc +2 -2
  1279. data/src/core/{lib/gpr → util}/posix/cpu.cc +4 -3
  1280. data/src/core/{lib/gpr → util}/posix/log.cc +0 -42
  1281. data/src/core/{lib/gpr → util}/posix/sync.cc +25 -23
  1282. data/src/core/{lib/gpr → util}/posix/time.cc +10 -7
  1283. data/src/core/{lib/gpr → util}/posix/tmpfile.cc +10 -8
  1284. data/src/core/{lib/gpr → util}/spinlock.h +3 -3
  1285. data/src/core/{lib/gpr → util}/string.cc +2 -2
  1286. data/src/core/{lib/gpr → util}/string.h +3 -3
  1287. data/src/core/{lib/gpr → util}/sync.cc +5 -3
  1288. data/src/core/{lib/gpr → util}/time.cc +10 -8
  1289. data/src/core/{lib/gpr → util}/time_precise.cc +5 -4
  1290. data/src/core/{lib/gpr → util}/time_precise.h +3 -3
  1291. data/src/core/{lib/gpr → util}/tmpfile.h +3 -3
  1292. data/src/core/{ext/xds → util}/upb_utils.h +3 -5
  1293. data/src/core/{lib/gpr → util}/useful.h +42 -47
  1294. data/src/core/{lib/gpr → util}/windows/log.cc +1 -44
  1295. data/src/core/{lib/gpr → util}/windows/string.cc +1 -1
  1296. data/src/core/{lib/gpr → util}/windows/string_util.cc +1 -1
  1297. data/src/core/{lib/gpr → util}/windows/sync.cc +3 -1
  1298. data/src/core/{lib/gpr → util}/windows/time.cc +5 -2
  1299. data/src/core/{lib/gpr → util}/windows/tmpfile.cc +1 -1
  1300. data/src/core/{ext/xds → xds/grpc}/certificate_provider_store.cc +5 -6
  1301. data/src/core/{ext/xds → xds/grpc}/certificate_provider_store.h +8 -9
  1302. data/src/core/{ext/xds → xds/grpc}/file_watcher_certificate_provider_factory.cc +5 -6
  1303. data/src/core/{ext/xds → xds/grpc}/file_watcher_certificate_provider_factory.h +7 -8
  1304. data/src/core/{ext/xds → xds/grpc}/xds_audit_logger_registry.cc +5 -4
  1305. data/src/core/{ext/xds → xds/grpc}/xds_audit_logger_registry.h +7 -7
  1306. data/src/core/{ext/xds → xds/grpc}/xds_bootstrap_grpc.cc +7 -133
  1307. data/src/core/{ext/xds → xds/grpc}/xds_bootstrap_grpc.h +15 -40
  1308. data/src/core/{ext/xds → xds/grpc}/xds_certificate_provider.cc +7 -6
  1309. data/src/core/{ext/xds → xds/grpc}/xds_certificate_provider.h +8 -7
  1310. data/src/core/{ext/xds → xds/grpc}/xds_client_grpc.cc +63 -47
  1311. data/src/core/{ext/xds → xds/grpc}/xds_client_grpc.h +10 -11
  1312. data/src/core/xds/grpc/xds_cluster.cc +80 -0
  1313. data/src/core/{ext/xds → xds/grpc}/xds_cluster.h +11 -47
  1314. data/src/core/{ext/xds/xds_cluster.cc → xds/grpc/xds_cluster_parser.cc} +22 -87
  1315. data/src/core/xds/grpc/xds_cluster_parser.h +57 -0
  1316. data/src/core/{ext/xds → xds/grpc}/xds_cluster_specifier_plugin.cc +6 -6
  1317. data/src/core/{ext/xds → xds/grpc}/xds_cluster_specifier_plugin.h +7 -7
  1318. data/src/core/xds/grpc/xds_common_types.cc +104 -0
  1319. data/src/core/{ext/xds → xds/grpc}/xds_common_types.h +11 -28
  1320. data/src/core/{ext/xds/xds_common_types.cc → xds/grpc/xds_common_types_parser.cc} +44 -86
  1321. data/src/core/xds/grpc/xds_common_types_parser.h +54 -0
  1322. data/src/core/xds/grpc/xds_endpoint.cc +97 -0
  1323. data/src/core/{ext/xds → xds/grpc}/xds_endpoint.h +7 -31
  1324. data/src/core/{ext/xds/xds_endpoint.cc → xds/grpc/xds_endpoint_parser.cc} +30 -108
  1325. data/src/core/xds/grpc/xds_endpoint_parser.h +48 -0
  1326. data/src/core/{ext/xds → xds/grpc}/xds_health_status.cc +1 -3
  1327. data/src/core/{ext/xds → xds/grpc}/xds_health_status.h +3 -5
  1328. data/src/core/{ext/xds → xds/grpc}/xds_http_fault_filter.cc +11 -7
  1329. data/src/core/{ext/xds → xds/grpc}/xds_http_fault_filter.h +9 -8
  1330. data/src/core/{ext/xds/xds_http_filters.h → xds/grpc/xds_http_filter.h} +10 -67
  1331. data/src/core/{ext/xds/xds_http_filters.cc → xds/grpc/xds_http_filter_registry.cc} +9 -9
  1332. data/src/core/xds/grpc/xds_http_filter_registry.h +98 -0
  1333. data/src/core/{ext/xds → xds/grpc}/xds_http_rbac_filter.cc +13 -10
  1334. data/src/core/{ext/xds → xds/grpc}/xds_http_rbac_filter.h +9 -8
  1335. data/src/core/{ext/xds → xds/grpc}/xds_http_stateful_session_filter.cc +13 -8
  1336. data/src/core/{ext/xds → xds/grpc}/xds_http_stateful_session_filter.h +9 -8
  1337. data/src/core/{ext/xds → xds/grpc}/xds_lb_policy_registry.cc +7 -9
  1338. data/src/core/{ext/xds → xds/grpc}/xds_lb_policy_registry.h +7 -7
  1339. data/src/core/xds/grpc/xds_listener.cc +176 -0
  1340. data/src/core/{ext/xds → xds/grpc}/xds_listener.h +9 -41
  1341. data/src/core/{ext/xds/xds_listener.cc → xds/grpc/xds_listener_parser.cc} +52 -197
  1342. data/src/core/xds/grpc/xds_listener_parser.h +60 -0
  1343. data/src/core/xds/grpc/xds_route_config.cc +282 -0
  1344. data/src/core/{ext/xds → xds/grpc}/xds_route_config.h +12 -44
  1345. data/src/core/{ext/xds/xds_route_config.cc → xds/grpc/xds_route_config_parser.cc} +55 -284
  1346. data/src/core/xds/grpc/xds_route_config_parser.h +80 -0
  1347. data/src/core/{ext/xds → xds/grpc}/xds_routing.cc +6 -6
  1348. data/src/core/{ext/xds → xds/grpc}/xds_routing.h +8 -8
  1349. data/src/core/xds/grpc/xds_server_grpc.cc +161 -0
  1350. data/src/core/xds/grpc/xds_server_grpc.h +63 -0
  1351. data/src/core/{ext/xds → xds/grpc}/xds_transport_grpc.cc +19 -20
  1352. data/src/core/{ext/xds → xds/grpc}/xds_transport_grpc.h +7 -8
  1353. data/src/core/{ext/xds → xds/xds_client}/xds_api.cc +18 -23
  1354. data/src/core/{ext/xds → xds/xds_client}/xds_api.h +7 -7
  1355. data/src/core/{ext/xds → xds/xds_client}/xds_bootstrap.cc +4 -4
  1356. data/src/core/{ext/xds → xds/xds_client}/xds_bootstrap.h +6 -6
  1357. data/src/core/{ext/xds → xds/xds_client}/xds_channel_args.h +3 -3
  1358. data/src/core/{ext/xds → xds/xds_client}/xds_client.cc +203 -238
  1359. data/src/core/{ext/xds → xds/xds_client}/xds_client.h +10 -14
  1360. data/src/core/{ext/xds → xds/xds_client}/xds_client_stats.cc +29 -31
  1361. data/src/core/{ext/xds → xds/xds_client}/xds_client_stats.h +8 -8
  1362. data/src/core/{ext/xds → xds/xds_client}/xds_metrics.h +7 -5
  1363. data/src/core/{ext/xds → xds/xds_client}/xds_resource_type.h +6 -6
  1364. data/src/core/{ext/xds → xds/xds_client}/xds_resource_type_impl.h +7 -7
  1365. data/src/core/{ext/xds → xds/xds_client}/xds_transport.h +6 -6
  1366. data/src/ruby/bin/math_pb.rb +1 -22
  1367. data/src/ruby/ext/grpc/rb_call.c +10 -3
  1368. data/src/ruby/ext/grpc/rb_call_credentials.c +2 -1
  1369. data/src/ruby/ext/grpc/rb_call_credentials.h +1 -0
  1370. data/src/ruby/ext/grpc/rb_channel.c +15 -14
  1371. data/src/ruby/ext/grpc/rb_channel_args.c +1 -1
  1372. data/src/ruby/ext/grpc/rb_channel_credentials.c +1 -0
  1373. data/src/ruby/ext/grpc/rb_completion_queue.c +15 -32
  1374. data/src/ruby/ext/grpc/rb_completion_queue.h +7 -1
  1375. data/src/ruby/ext/grpc/rb_compression_options.c +3 -3
  1376. data/src/ruby/ext/grpc/rb_event_thread.c +2 -2
  1377. data/src/ruby/ext/grpc/rb_grpc.c +5 -5
  1378. data/src/ruby/ext/grpc/rb_grpc.h +8 -0
  1379. data/src/ruby/ext/grpc/rb_grpc_imports.generated.c +130 -134
  1380. data/src/ruby/ext/grpc/rb_grpc_imports.generated.h +198 -203
  1381. data/src/ruby/ext/grpc/rb_server.c +40 -22
  1382. data/src/ruby/ext/grpc/rb_server_credentials.c +1 -0
  1383. data/src/ruby/ext/grpc/rb_server_credentials.h +1 -0
  1384. data/src/ruby/ext/grpc/rb_xds_channel_credentials.c +1 -0
  1385. data/src/ruby/ext/grpc/rb_xds_server_credentials.c +1 -0
  1386. data/src/ruby/ext/grpc/rb_xds_server_credentials.h +1 -0
  1387. data/src/ruby/lib/grpc/logconfig.rb +13 -0
  1388. data/src/ruby/lib/grpc/version.rb +1 -1
  1389. data/src/ruby/pb/grpc/health/v1/health_pb.rb +1 -22
  1390. data/src/ruby/pb/grpc/testing/duplicate/echo_duplicate_services_pb.rb +5 -5
  1391. data/src/ruby/pb/grpc/testing/metrics_pb.rb +10 -19
  1392. data/src/ruby/pb/grpc/testing/metrics_services_pb.rb +5 -5
  1393. data/src/ruby/pb/src/proto/grpc/testing/empty_pb.rb +1 -22
  1394. data/src/ruby/pb/src/proto/grpc/testing/messages_pb.rb +1 -22
  1395. data/src/ruby/pb/src/proto/grpc/testing/test_pb.rb +1 -22
  1396. data/src/ruby/spec/logconfig_spec.rb +30 -0
  1397. data/third_party/abseil-cpp/absl/log/check.h +209 -0
  1398. data/third_party/abseil-cpp/absl/log/internal/check_impl.h +150 -0
  1399. data/third_party/abseil-cpp/absl/log/internal/check_op.cc +118 -0
  1400. data/third_party/abseil-cpp/absl/log/internal/check_op.h +420 -0
  1401. data/third_party/boringssl-with-bazel/src/crypto/base64/base64.c +4 -0
  1402. data/third_party/boringssl-with-bazel/src/crypto/bio/bio.c +13 -18
  1403. data/third_party/boringssl-with-bazel/src/crypto/bio/file.c +25 -10
  1404. data/third_party/boringssl-with-bazel/src/crypto/bytestring/cbs.c +3 -18
  1405. data/third_party/boringssl-with-bazel/src/crypto/bytestring/unicode.c +3 -2
  1406. data/third_party/boringssl-with-bazel/src/crypto/chacha/chacha.c +1 -1
  1407. data/third_party/boringssl-with-bazel/src/crypto/chacha/internal.h +19 -15
  1408. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_chacha20poly1305.c +7 -0
  1409. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_des.c +48 -66
  1410. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_null.c +7 -3
  1411. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_rc2.c +20 -28
  1412. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_rc4.c +9 -4
  1413. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/tls_cbc.c +2 -2
  1414. data/third_party/boringssl-with-bazel/src/crypto/conf/conf.c +66 -41
  1415. data/third_party/boringssl-with-bazel/src/crypto/cpu_arm_linux.c +4 -1
  1416. data/third_party/boringssl-with-bazel/src/crypto/cpu_intel.c +0 -15
  1417. data/third_party/boringssl-with-bazel/src/crypto/crypto.c +7 -61
  1418. data/third_party/boringssl-with-bazel/src/crypto/curve25519/curve25519.c +7 -7
  1419. data/third_party/boringssl-with-bazel/src/crypto/digest_extra/digest_extra.c +1 -0
  1420. data/third_party/boringssl-with-bazel/src/crypto/dilithium/dilithium.c +1539 -0
  1421. data/third_party/boringssl-with-bazel/src/crypto/dilithium/internal.h +58 -0
  1422. data/third_party/boringssl-with-bazel/src/crypto/dsa/dsa.c +36 -20
  1423. data/third_party/boringssl-with-bazel/src/crypto/dsa/dsa_asn1.c +3 -4
  1424. data/third_party/boringssl-with-bazel/src/crypto/dsa/internal.h +2 -0
  1425. data/third_party/boringssl-with-bazel/src/crypto/err/err.c +81 -60
  1426. data/third_party/boringssl-with-bazel/src/crypto/evp/evp.c +41 -120
  1427. data/third_party/boringssl-with-bazel/src/crypto/evp/evp_asn1.c +13 -13
  1428. data/third_party/boringssl-with-bazel/src/crypto/evp/internal.h +7 -0
  1429. data/third_party/boringssl-with-bazel/src/crypto/evp/p_dh.c +137 -0
  1430. data/third_party/boringssl-with-bazel/src/crypto/evp/p_dh_asn1.c +120 -0
  1431. data/third_party/boringssl-with-bazel/src/crypto/evp/p_dsa_asn1.c +30 -0
  1432. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ec.c +3 -4
  1433. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ec_asn1.c +30 -0
  1434. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ed25519.c +1 -4
  1435. data/third_party/boringssl-with-bazel/src/crypto/evp/p_rsa_asn1.c +30 -0
  1436. data/third_party/boringssl-with-bazel/src/crypto/evp/p_x25519.c +1 -4
  1437. data/third_party/boringssl-with-bazel/src/crypto/ex_data.c +6 -7
  1438. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/aes.c +21 -0
  1439. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/internal.h +31 -7
  1440. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bcm.c +5 -2
  1441. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/bytes.c +1 -1
  1442. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/div.c +3 -3
  1443. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/div_extra.c +1 -1
  1444. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/exponentiation.c +46 -2
  1445. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/gcd_extra.c +8 -5
  1446. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/internal.h +33 -23
  1447. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/montgomery_inv.c +1 -1
  1448. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/mul.c +2 -2
  1449. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/prime.c +14 -7
  1450. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/random.c +2 -1
  1451. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/internal.h +0 -3
  1452. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/ec_key.c +11 -7
  1453. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p256-nistz.c +5 -0
  1454. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/scalar.c +5 -1
  1455. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/fips_shared_support.c +3 -6
  1456. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/fork_detect.h +2 -1
  1457. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/rsa.c +11 -11
  1458. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/rsa_impl.c +22 -8
  1459. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/self_check/fips.c +6 -4
  1460. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/service_indicator/service_indicator.c +3 -6
  1461. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/internal.h +78 -29
  1462. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/sha1.c +4 -4
  1463. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/sha256.c +3 -3
  1464. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/sha512.c +10 -4
  1465. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/tls/kdf.c +7 -0
  1466. data/third_party/boringssl-with-bazel/src/crypto/hpke/hpke.c +2 -0
  1467. data/third_party/boringssl-with-bazel/src/crypto/internal.h +62 -27
  1468. data/third_party/boringssl-with-bazel/src/crypto/kyber/internal.h +1 -1
  1469. data/third_party/boringssl-with-bazel/src/crypto/kyber/kyber.c +2 -1
  1470. data/third_party/boringssl-with-bazel/src/crypto/mem.c +18 -9
  1471. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_lib.c +18 -17
  1472. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_pk8.c +44 -41
  1473. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_pkey.c +13 -12
  1474. data/third_party/boringssl-with-bazel/src/crypto/spx/spx.c +7 -6
  1475. data/third_party/boringssl-with-bazel/src/crypto/x509/by_dir.c +26 -33
  1476. data/third_party/boringssl-with-bazel/src/crypto/x509/by_file.c +1 -1
  1477. data/third_party/boringssl-with-bazel/src/crypto/x509/internal.h +4 -5
  1478. data/third_party/boringssl-with-bazel/src/crypto/x509/rsa_pss.c +5 -1
  1479. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_cpols.c +9 -4
  1480. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_crld.c +2 -2
  1481. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_info.c +1 -1
  1482. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_lib.c +2 -0
  1483. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_utl.c +49 -16
  1484. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_lu.c +0 -10
  1485. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_trs.c +21 -25
  1486. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_vfy.c +8 -25
  1487. data/third_party/boringssl-with-bazel/src/crypto/x509/x_algor.c +2 -2
  1488. data/third_party/boringssl-with-bazel/src/crypto/x509/x_x509.c +1 -6
  1489. data/third_party/boringssl-with-bazel/{err_data.c → src/gen/crypto/err_data.c} +487 -485
  1490. data/third_party/boringssl-with-bazel/src/include/openssl/base.h +9 -1
  1491. data/third_party/boringssl-with-bazel/src/include/openssl/bio.h +85 -42
  1492. data/third_party/boringssl-with-bazel/src/include/openssl/bytestring.h +12 -4
  1493. data/third_party/boringssl-with-bazel/src/include/openssl/crypto.h +10 -11
  1494. data/third_party/boringssl-with-bazel/src/include/openssl/dh.h +17 -1
  1495. data/third_party/boringssl-with-bazel/src/include/openssl/dsa.h +10 -3
  1496. data/third_party/boringssl-with-bazel/src/include/openssl/err.h +13 -0
  1497. data/third_party/boringssl-with-bazel/src/include/openssl/evp.h +25 -14
  1498. data/third_party/boringssl-with-bazel/src/include/openssl/evp_errors.h +1 -0
  1499. data/third_party/boringssl-with-bazel/src/include/openssl/ex_data.h +15 -3
  1500. data/third_party/boringssl-with-bazel/src/include/openssl/experimental/dilithium.h +131 -0
  1501. data/third_party/boringssl-with-bazel/src/include/openssl/{kyber.h → experimental/kyber.h} +10 -0
  1502. data/third_party/boringssl-with-bazel/src/{crypto/spx/internal.h → include/openssl/experimental/spx.h} +24 -13
  1503. data/third_party/boringssl-with-bazel/src/include/openssl/obj.h +2 -2
  1504. data/third_party/boringssl-with-bazel/src/include/openssl/pem.h +63 -53
  1505. data/third_party/boringssl-with-bazel/src/include/openssl/rand.h +19 -10
  1506. data/third_party/boringssl-with-bazel/src/include/openssl/span.h +26 -12
  1507. data/third_party/boringssl-with-bazel/src/include/openssl/ssl.h +358 -102
  1508. data/third_party/boringssl-with-bazel/src/include/openssl/stack.h +10 -3
  1509. data/third_party/boringssl-with-bazel/src/include/openssl/target.h +13 -10
  1510. data/third_party/boringssl-with-bazel/src/include/openssl/tls1.h +2 -2
  1511. data/third_party/boringssl-with-bazel/src/include/openssl/x509.h +2931 -2453
  1512. data/third_party/boringssl-with-bazel/src/ssl/d1_both.cc +6 -8
  1513. data/third_party/boringssl-with-bazel/src/ssl/d1_pkt.cc +4 -4
  1514. data/third_party/boringssl-with-bazel/src/ssl/dtls_method.cc +1 -1
  1515. data/third_party/boringssl-with-bazel/src/ssl/dtls_record.cc +19 -18
  1516. data/third_party/boringssl-with-bazel/src/ssl/encrypted_client_hello.cc +3 -9
  1517. data/third_party/boringssl-with-bazel/src/ssl/extensions.cc +64 -58
  1518. data/third_party/boringssl-with-bazel/src/ssl/handoff.cc +1 -1
  1519. data/third_party/boringssl-with-bazel/src/ssl/handshake.cc +17 -7
  1520. data/third_party/boringssl-with-bazel/src/ssl/handshake_client.cc +69 -16
  1521. data/third_party/boringssl-with-bazel/src/ssl/handshake_server.cc +145 -114
  1522. data/third_party/boringssl-with-bazel/src/ssl/internal.h +243 -189
  1523. data/third_party/boringssl-with-bazel/src/ssl/s3_both.cc +1 -1
  1524. data/third_party/boringssl-with-bazel/src/ssl/s3_lib.cc +0 -1
  1525. data/third_party/boringssl-with-bazel/src/ssl/ssl_cert.cc +59 -385
  1526. data/third_party/boringssl-with-bazel/src/ssl/ssl_cipher.cc +21 -19
  1527. data/third_party/boringssl-with-bazel/src/ssl/ssl_credential.cc +423 -0
  1528. data/third_party/boringssl-with-bazel/src/ssl/ssl_file.cc +2 -2
  1529. data/third_party/boringssl-with-bazel/src/ssl/ssl_key_share.cc +2 -1
  1530. data/third_party/boringssl-with-bazel/src/ssl/ssl_lib.cc +108 -81
  1531. data/third_party/boringssl-with-bazel/src/ssl/ssl_privkey.cc +116 -93
  1532. data/third_party/boringssl-with-bazel/src/ssl/ssl_session.cc +6 -14
  1533. data/third_party/boringssl-with-bazel/src/ssl/ssl_versions.cc +1 -1
  1534. data/third_party/boringssl-with-bazel/src/ssl/ssl_x509.cc +48 -116
  1535. data/third_party/boringssl-with-bazel/src/ssl/tls13_both.cc +21 -27
  1536. data/third_party/boringssl-with-bazel/src/ssl/tls13_client.cc +36 -3
  1537. data/third_party/boringssl-with-bazel/src/ssl/tls13_server.cc +53 -18
  1538. data/third_party/boringssl-with-bazel/src/ssl/tls_record.cc +1 -1
  1539. data/third_party/upb/upb/base/string_view.h +1 -1
  1540. data/third_party/upb/upb/json/decode.c +1 -0
  1541. data/third_party/upb/upb/mem/arena.c +67 -2
  1542. data/third_party/upb/upb/mem/arena.h +11 -9
  1543. data/third_party/upb/upb/mem/internal/arena.h +11 -8
  1544. data/third_party/upb/upb/message/accessors.c +6 -5
  1545. data/third_party/upb/upb/message/accessors.h +49 -38
  1546. data/third_party/upb/upb/message/array.c +26 -3
  1547. data/third_party/upb/upb/message/array.h +17 -9
  1548. data/third_party/upb/upb/message/compat.c +5 -5
  1549. data/third_party/upb/upb/message/compat.h +3 -3
  1550. data/third_party/upb/upb/message/copy.c +12 -13
  1551. data/third_party/upb/upb/message/internal/accessors.h +45 -35
  1552. data/third_party/upb/upb/message/internal/array.h +23 -15
  1553. data/third_party/upb/upb/message/internal/compare_unknown.c +289 -0
  1554. data/third_party/upb/upb/message/internal/compare_unknown.h +49 -0
  1555. data/third_party/upb/upb/message/internal/extension.c +11 -12
  1556. data/third_party/upb/upb/message/internal/extension.h +9 -12
  1557. data/third_party/upb/upb/message/internal/map.h +15 -0
  1558. data/third_party/upb/upb/message/internal/map_sorter.h +4 -5
  1559. data/third_party/upb/upb/message/internal/message.c +20 -3
  1560. data/third_party/upb/upb/message/internal/message.h +10 -0
  1561. data/third_party/upb/upb/message/internal/tagged_ptr.h +5 -5
  1562. data/third_party/upb/upb/message/internal/types.h +41 -1
  1563. data/third_party/upb/upb/message/map.c +25 -0
  1564. data/third_party/upb/upb/message/map.h +11 -7
  1565. data/third_party/upb/upb/message/message.c +83 -4
  1566. data/third_party/upb/upb/message/message.h +20 -1
  1567. data/third_party/upb/upb/message/tagged_ptr.h +4 -8
  1568. data/third_party/upb/upb/mini_descriptor/build_enum.c +3 -3
  1569. data/third_party/upb/upb/mini_descriptor/build_enum.h +6 -14
  1570. data/third_party/upb/upb/mini_descriptor/decode.c +12 -1
  1571. data/third_party/upb/upb/mini_descriptor/link.c +16 -18
  1572. data/third_party/upb/upb/mini_table/enum.h +2 -4
  1573. data/third_party/upb/upb/mini_table/extension.h +4 -12
  1574. data/third_party/upb/upb/mini_table/field.h +12 -38
  1575. data/third_party/upb/upb/mini_table/file.h +6 -19
  1576. data/third_party/upb/upb/mini_table/internal/enum.h +1 -1
  1577. data/third_party/upb/upb/mini_table/internal/extension.h +9 -9
  1578. data/third_party/upb/upb/mini_table/internal/field.h +23 -23
  1579. data/third_party/upb/upb/mini_table/internal/file.h +7 -7
  1580. data/third_party/upb/upb/mini_table/internal/message.h +51 -27
  1581. data/third_party/upb/upb/mini_table/internal/sub.h +4 -4
  1582. data/third_party/upb/upb/mini_table/message.h +13 -22
  1583. data/third_party/upb/upb/mini_table/sub.h +4 -12
  1584. data/third_party/upb/upb/port/def.inc +12 -6
  1585. data/third_party/upb/upb/port/undef.inc +1 -1
  1586. data/third_party/upb/upb/reflection/def.hpp +27 -0
  1587. data/third_party/upb/upb/reflection/def_pool.h +2 -2
  1588. data/third_party/upb/upb/reflection/enum_def.c +5 -1
  1589. data/third_party/upb/upb/reflection/enum_def.h +1 -0
  1590. data/third_party/upb/upb/reflection/enum_value_def.c +3 -8
  1591. data/third_party/upb/upb/reflection/field_def.c +61 -24
  1592. data/third_party/upb/upb/reflection/field_def.h +3 -0
  1593. data/third_party/upb/upb/reflection/file_def.c +30 -4
  1594. data/third_party/upb/upb/reflection/file_def.h +3 -0
  1595. data/third_party/upb/upb/reflection/internal/upb_edition_defaults.h +1 -1
  1596. data/third_party/upb/upb/reflection/message.c +19 -7
  1597. data/third_party/upb/upb/reflection/message_def.c +14 -9
  1598. data/third_party/upb/upb/reflection/method_def.h +8 -7
  1599. data/third_party/upb/upb/reflection/service_def.h +6 -5
  1600. data/third_party/upb/upb/text/encode.c +10 -3
  1601. data/third_party/upb/upb/wire/decode.c +91 -57
  1602. data/third_party/upb/upb/wire/decode.h +11 -1
  1603. data/third_party/upb/upb/wire/encode.c +48 -30
  1604. data/third_party/upb/upb/wire/encode.h +9 -1
  1605. data/third_party/upb/upb/wire/eps_copy_input_stream.h +3 -3
  1606. data/third_party/upb/upb/wire/internal/decode_fast.c +25 -29
  1607. data/third_party/upb/upb/wire/internal/reader.h +3 -3
  1608. data/third_party/upb/upb/wire/reader.c +1 -2
  1609. data/third_party/upb/upb/wire/reader.h +4 -8
  1610. metadata +233 -200
  1611. data/src/core/client_channel/client_channel_channelz.cc +0 -93
  1612. data/src/core/client_channel/client_channel_channelz.h +0 -85
  1613. data/src/core/client_channel/config_selector.cc +0 -60
  1614. data/src/core/ext/filters/deadline/deadline_filter.cc +0 -407
  1615. data/src/core/ext/filters/deadline/deadline_filter.h +0 -85
  1616. data/src/core/ext/transport/chttp2/transport/http_trace.cc +0 -19
  1617. data/src/core/ext/transport/chttp2/transport/http_trace.h +0 -24
  1618. data/src/core/ext/transport/inproc/inproc_plugin.cc +0 -23
  1619. data/src/core/lib/channel/channel_stack_trace.cc +0 -19
  1620. data/src/core/lib/channel/channel_stack_trace.h +0 -24
  1621. data/src/core/lib/channel/context.h +0 -77
  1622. data/src/core/lib/channel/metrics.cc +0 -396
  1623. data/src/core/lib/channel/metrics.h +0 -406
  1624. data/src/core/lib/event_engine/trace.cc +0 -25
  1625. data/src/core/lib/event_engine/trace.h +0 -49
  1626. data/src/core/lib/gpr/log.cc +0 -166
  1627. data/src/core/lib/gpr/log_internal.h +0 -55
  1628. data/src/core/lib/iomgr/ev_windows.cc +0 -30
  1629. data/src/core/lib/promise/trace.cc +0 -20
  1630. data/src/core/lib/promise/trace.h +0 -24
  1631. data/src/core/lib/resource_quota/trace.cc +0 -19
  1632. data/src/core/lib/resource_quota/trace.h +0 -24
  1633. data/src/core/lib/security/transport/tsi_error.cc +0 -31
  1634. data/src/core/lib/security/transport/tsi_error.h +0 -30
  1635. data/src/core/lib/slice/slice_refcount.cc +0 -20
  1636. data/src/core/lib/surface/api_trace.cc +0 -25
  1637. data/src/core/lib/surface/api_trace.h +0 -53
  1638. data/src/core/lib/surface/call_trace.h +0 -24
  1639. data/src/core/lib/surface/wait_for_cq_end_op.cc +0 -75
  1640. data/src/core/lib/surface/wait_for_cq_end_op.h +0 -72
  1641. data/src/core/lib/transport/batch_builder.cc +0 -170
  1642. data/src/core/lib/transport/batch_builder.h +0 -476
  1643. data/src/core/lib/transport/handshaker.cc +0 -229
  1644. data/src/core/resolver/xds/xds_resolver_trace.cc +0 -25
  1645. data/src/core/resolver/xds/xds_resolver_trace.h +0 -30
  1646. data/third_party/boringssl-with-bazel/src/crypto/conf/conf_def.h +0 -122
  1647. data/third_party/boringssl-with-bazel/src/include/openssl/pki/certificate.h +0 -83
  1648. data/third_party/boringssl-with-bazel/src/include/openssl/pki/signature_verify_cache.h +0 -41
  1649. /data/src/core/{lib/gpr → util}/iphone/cpu.cc +0 -0
  1650. /data/src/core/{lib/gpr → util}/posix/string.cc +0 -0
  1651. /data/src/core/{lib/gpr → util}/sync_abseil.cc +0 -0
  1652. /data/src/core/{lib/gpr → util}/windows/cpu.cc +0 -0
@@ -14,8 +14,6 @@
14
14
  // limitations under the License.
15
15
  //
16
16
 
17
- #include <grpc/support/port_platform.h>
18
-
19
17
  #include "src/core/load_balancing/pick_first/pick_first.h"
20
18
 
21
19
  #include <inttypes.h>
@@ -29,6 +27,8 @@
29
27
  #include <vector>
30
28
 
31
29
  #include "absl/algorithm/container.h"
30
+ #include "absl/log/check.h"
31
+ #include "absl/log/log.h"
32
32
  #include "absl/random/random.h"
33
33
  #include "absl/status/status.h"
34
34
  #include "absl/status/statusor.h"
@@ -39,15 +39,13 @@
39
39
  #include <grpc/event_engine/event_engine.h>
40
40
  #include <grpc/impl/channel_arg_names.h>
41
41
  #include <grpc/impl/connectivity_state.h>
42
- #include <grpc/support/log.h>
42
+ #include <grpc/support/port_platform.h>
43
43
 
44
- #include "src/core/load_balancing/health_check_client.h"
45
44
  #include "src/core/lib/address_utils/sockaddr_utils.h"
46
45
  #include "src/core/lib/channel/channel_args.h"
47
- #include "src/core/lib/channel/metrics.h"
48
46
  #include "src/core/lib/config/core_configuration.h"
49
47
  #include "src/core/lib/debug/trace.h"
50
- #include "src/core/lib/gpr/useful.h"
48
+ #include "src/core/lib/experiments/experiments.h"
51
49
  #include "src/core/lib/gprpp/crash.h"
52
50
  #include "src/core/lib/gprpp/debug_location.h"
53
51
  #include "src/core/lib/gprpp/orphanable.h"
@@ -57,67 +55,1071 @@
57
55
  #include "src/core/lib/iomgr/exec_ctx.h"
58
56
  #include "src/core/lib/iomgr/iomgr_fwd.h"
59
57
  #include "src/core/lib/iomgr/resolved_address.h"
60
- #include "src/core/lib/json/json.h"
61
- #include "src/core/lib/json/json_args.h"
62
- #include "src/core/lib/json/json_object_loader.h"
63
58
  #include "src/core/lib/transport/connectivity_state.h"
59
+ #include "src/core/load_balancing/health_check_client.h"
64
60
  #include "src/core/load_balancing/lb_policy.h"
65
61
  #include "src/core/load_balancing/lb_policy_factory.h"
66
62
  #include "src/core/load_balancing/subchannel_interface.h"
67
63
  #include "src/core/resolver/endpoint_addresses.h"
64
+ #include "src/core/telemetry/metrics.h"
65
+ #include "src/core/util/json/json.h"
66
+ #include "src/core/util/json/json_args.h"
67
+ #include "src/core/util/json/json_object_loader.h"
68
+ #include "src/core/util/useful.h"
68
69
 
69
70
  namespace grpc_core {
70
71
 
71
- TraceFlag grpc_lb_pick_first_trace(false, "pick_first");
72
+ namespace {
73
+
74
+ //
75
+ // pick_first LB policy
76
+ //
77
+
78
+ constexpr absl::string_view kPickFirst = "pick_first";
79
+
80
+ const auto kMetricDisconnections =
81
+ GlobalInstrumentsRegistry::RegisterUInt64Counter(
82
+ "grpc.lb.pick_first.disconnections",
83
+ "EXPERIMENTAL. Number of times the selected subchannel becomes "
84
+ "disconnected.",
85
+ "{disconnection}", false)
86
+ .Labels(kMetricLabelTarget)
87
+ .Build();
88
+
89
+ const auto kMetricConnectionAttemptsSucceeded =
90
+ GlobalInstrumentsRegistry::RegisterUInt64Counter(
91
+ "grpc.lb.pick_first.connection_attempts_succeeded",
92
+ "EXPERIMENTAL. Number of successful connection attempts.", "{attempt}",
93
+ false)
94
+ .Labels(kMetricLabelTarget)
95
+ .Build();
96
+
97
+ const auto kMetricConnectionAttemptsFailed =
98
+ GlobalInstrumentsRegistry::RegisterUInt64Counter(
99
+ "grpc.lb.pick_first.connection_attempts_failed",
100
+ "EXPERIMENTAL. Number of failed connection attempts.", "{attempt}",
101
+ false)
102
+ .Labels(kMetricLabelTarget)
103
+ .Build();
104
+
105
+ class PickFirstConfig final : public LoadBalancingPolicy::Config {
106
+ public:
107
+ absl::string_view name() const override { return kPickFirst; }
108
+ bool shuffle_addresses() const { return shuffle_addresses_; }
109
+
110
+ static const JsonLoaderInterface* JsonLoader(const JsonArgs&) {
111
+ static const auto kJsonLoader =
112
+ JsonObjectLoader<PickFirstConfig>()
113
+ .OptionalField("shuffleAddressList",
114
+ &PickFirstConfig::shuffle_addresses_)
115
+ .Finish();
116
+ return kJsonLoader;
117
+ }
118
+
119
+ private:
120
+ bool shuffle_addresses_ = false;
121
+ };
122
+
123
+ class PickFirst final : public LoadBalancingPolicy {
124
+ public:
125
+ explicit PickFirst(Args args);
126
+
127
+ absl::string_view name() const override { return kPickFirst; }
128
+
129
+ absl::Status UpdateLocked(UpdateArgs args) override;
130
+ void ExitIdleLocked() override;
131
+ void ResetBackoffLocked() override;
132
+
133
+ private:
134
+ ~PickFirst() override;
135
+
136
+ // A list of subchannels that we will attempt connections on.
137
+ class SubchannelList final : public InternallyRefCounted<SubchannelList> {
138
+ public:
139
+ // Data about the subchannel that is needed only while attempting to
140
+ // connect.
141
+ class SubchannelData final {
142
+ public:
143
+ // Stores the subchannel and its watcher. This is the state that
144
+ // is retained once a subchannel is chosen.
145
+ class SubchannelState final
146
+ : public InternallyRefCounted<SubchannelState> {
147
+ public:
148
+ SubchannelState(SubchannelData* subchannel_data,
149
+ RefCountedPtr<SubchannelInterface> subchannel);
150
+
151
+ void Orphan() override;
152
+
153
+ SubchannelInterface* subchannel() const { return subchannel_.get(); }
154
+
155
+ void RequestConnection() { subchannel_->RequestConnection(); }
156
+
157
+ void ResetBackoffLocked() { subchannel_->ResetBackoff(); }
158
+
159
+ private:
160
+ // Watcher for subchannel connectivity state.
161
+ class Watcher
162
+ : public SubchannelInterface::ConnectivityStateWatcherInterface {
163
+ public:
164
+ explicit Watcher(RefCountedPtr<SubchannelState> subchannel_state)
165
+ : subchannel_state_(std::move(subchannel_state)) {}
166
+
167
+ ~Watcher() override {
168
+ subchannel_state_.reset(DEBUG_LOCATION, "Watcher dtor");
169
+ }
170
+
171
+ void OnConnectivityStateChange(grpc_connectivity_state new_state,
172
+ absl::Status status) override {
173
+ subchannel_state_->OnConnectivityStateChange(new_state,
174
+ std::move(status));
175
+ }
176
+
177
+ grpc_pollset_set* interested_parties() override {
178
+ return subchannel_state_->pick_first_->interested_parties();
179
+ }
180
+
181
+ private:
182
+ RefCountedPtr<SubchannelState> subchannel_state_;
183
+ };
184
+
185
+ // Selects this subchannel. Called when the subchannel reports READY.
186
+ void Select();
187
+
188
+ // This method will be invoked once soon after instantiation to report
189
+ // the current connectivity state, and it will then be invoked again
190
+ // whenever the connectivity state changes.
191
+ void OnConnectivityStateChange(grpc_connectivity_state new_state,
192
+ absl::Status status);
193
+
194
+ // If non-null, then we are still part of a subchannel list
195
+ // trying to connect.
196
+ SubchannelData* subchannel_data_;
197
+
198
+ // TODO(roth): Once we remove pollset_set, we should no longer
199
+ // need to hold a ref to PickFirst. Instead, we can make this a
200
+ // raw pointer and put it in an absl::variant with subchannel_data_.
201
+ RefCountedPtr<PickFirst> pick_first_;
202
+
203
+ RefCountedPtr<SubchannelInterface> subchannel_;
204
+ SubchannelInterface::ConnectivityStateWatcherInterface* watcher_ =
205
+ nullptr;
206
+ };
207
+
208
+ SubchannelData(SubchannelList* subchannel_list, size_t index,
209
+ RefCountedPtr<SubchannelInterface> subchannel);
210
+
211
+ absl::optional<grpc_connectivity_state> connectivity_state() const {
212
+ return connectivity_state_;
213
+ }
214
+ const absl::Status& connectivity_status() const {
215
+ return connectivity_status_;
216
+ }
217
+
218
+ void RequestConnection() { subchannel_state_->RequestConnection(); }
219
+
220
+ // Resets the connection backoff.
221
+ void ResetBackoffLocked() { subchannel_state_->ResetBackoffLocked(); }
222
+
223
+ // Requests a connection attempt to start on this subchannel,
224
+ // with appropriate Connection Attempt Delay.
225
+ // Used only during the Happy Eyeballs pass.
226
+ void RequestConnectionWithTimer();
227
+
228
+ bool seen_transient_failure() const { return seen_transient_failure_; }
229
+
230
+ private:
231
+ // This method will be invoked once soon after instantiation to report
232
+ // the current connectivity state, and it will then be invoked again
233
+ // whenever the connectivity state changes.
234
+ void OnConnectivityStateChange(grpc_connectivity_state new_state,
235
+ absl::Status status);
236
+
237
+ // Backpointer to owning subchannel list. Not owned.
238
+ SubchannelList* subchannel_list_;
239
+ // Our index within subchannel_list_.
240
+ const size_t index_;
241
+ // Subchannel state.
242
+ OrphanablePtr<SubchannelState> subchannel_state_;
243
+ // Data updated by the watcher.
244
+ absl::optional<grpc_connectivity_state> connectivity_state_;
245
+ absl::Status connectivity_status_;
246
+ bool seen_transient_failure_ = false;
247
+ };
248
+
249
+ SubchannelList(RefCountedPtr<PickFirst> policy,
250
+ EndpointAddressesIterator* addresses,
251
+ const ChannelArgs& args);
252
+
253
+ ~SubchannelList() override;
254
+
255
+ void Orphan() override;
256
+
257
+ // The number of subchannels in the list.
258
+ size_t size() const { return subchannels_.size(); }
259
+
260
+ // Resets connection backoff of all subchannels.
261
+ void ResetBackoffLocked();
262
+
263
+ bool IsHappyEyeballsPassComplete() const {
264
+ // Checking attempting_index_ here is just an optimization -- if
265
+ // we haven't actually tried all subchannels yet, then we don't
266
+ // need to iterate.
267
+ if (attempting_index_ < size()) return false;
268
+ for (const auto& sd : subchannels_) {
269
+ if (!sd->seen_transient_failure()) return false;
270
+ }
271
+ return true;
272
+ }
273
+
274
+ private:
275
+ // Returns true if all subchannels have seen their initial
276
+ // connectivity state notifications.
277
+ bool AllSubchannelsSeenInitialState() const {
278
+ return num_subchannels_seen_initial_notification_ == size();
279
+ }
280
+
281
+ // Looks through subchannels_ starting from attempting_index_ to
282
+ // find the first one not currently in TRANSIENT_FAILURE, then
283
+ // triggers a connection attempt for that subchannel. If there are
284
+ // no more subchannels not in TRANSIENT_FAILURE, calls
285
+ // MaybeFinishHappyEyeballsPass().
286
+ void StartConnectingNextSubchannel();
287
+
288
+ // Checks to see if the initial Happy Eyeballs pass is complete --
289
+ // i.e., all subchannels have seen TRANSIENT_FAILURE state at least once.
290
+ // If so, transitions to a mode where we try to connect to all subchannels
291
+ // in parallel and returns true.
292
+ void MaybeFinishHappyEyeballsPass();
293
+
294
+ // Backpointer to owning policy.
295
+ RefCountedPtr<PickFirst> policy_;
296
+
297
+ ChannelArgs args_;
298
+
299
+ // The list of subchannels.
300
+ std::vector<std::unique_ptr<SubchannelData>> subchannels_;
301
+
302
+ // Is this list shutting down? This may be true due to the shutdown of the
303
+ // policy itself or because a newer update has arrived while this one hadn't
304
+ // finished processing.
305
+ bool shutting_down_ = false;
306
+
307
+ size_t num_subchannels_seen_initial_notification_ = 0;
308
+
309
+ // The index into subchannels_ to which we are currently attempting
310
+ // to connect during the initial Happy Eyeballs pass. Once the
311
+ // initial pass is over, this will be equal to size().
312
+ size_t attempting_index_ = 0;
313
+ // Happy Eyeballs timer handle.
314
+ absl::optional<grpc_event_engine::experimental::EventEngine::TaskHandle>
315
+ timer_handle_;
316
+
317
+ // After the initial Happy Eyeballs pass, the number of failures
318
+ // we've seen. Every size() failures, we trigger re-resolution.
319
+ size_t num_failures_ = 0;
320
+
321
+ // The status from the last subchannel that reported TRANSIENT_FAILURE.
322
+ absl::Status last_failure_;
323
+ };
324
+
325
+ class HealthWatcher final
326
+ : public SubchannelInterface::ConnectivityStateWatcherInterface {
327
+ public:
328
+ explicit HealthWatcher(RefCountedPtr<PickFirst> policy)
329
+ : policy_(std::move(policy)) {}
330
+
331
+ ~HealthWatcher() override {
332
+ policy_.reset(DEBUG_LOCATION, "HealthWatcher dtor");
333
+ }
334
+
335
+ void OnConnectivityStateChange(grpc_connectivity_state new_state,
336
+ absl::Status status) override;
337
+
338
+ grpc_pollset_set* interested_parties() override {
339
+ return policy_->interested_parties();
340
+ }
341
+
342
+ private:
343
+ RefCountedPtr<PickFirst> policy_;
344
+ };
345
+
346
+ class Picker final : public SubchannelPicker {
347
+ public:
348
+ explicit Picker(RefCountedPtr<SubchannelInterface> subchannel)
349
+ : subchannel_(std::move(subchannel)) {}
350
+
351
+ PickResult Pick(PickArgs /*args*/) override {
352
+ return PickResult::Complete(subchannel_);
353
+ }
354
+
355
+ private:
356
+ RefCountedPtr<SubchannelInterface> subchannel_;
357
+ };
358
+
359
+ void ShutdownLocked() override;
360
+
361
+ void UpdateState(grpc_connectivity_state state, const absl::Status& status,
362
+ RefCountedPtr<SubchannelPicker> picker);
363
+
364
+ void AttemptToConnectUsingLatestUpdateArgsLocked();
365
+
366
+ void UnsetSelectedSubchannel();
367
+
368
+ void GoIdle();
369
+
370
+ // When ExitIdleLocked() is called, we create a subchannel_list_ and start
371
+ // trying to connect, but we don't actually change state_ until the first
372
+ // subchannel reports CONNECTING. So in order to know if we're really
373
+ // idle, we need to check both state_ and subchannel_list_.
374
+ bool IsIdle() const {
375
+ return state_ == GRPC_CHANNEL_IDLE && subchannel_list_ == nullptr;
376
+ }
377
+
378
+ // Whether we should enable health watching.
379
+ const bool enable_health_watch_;
380
+ // Whether we should omit our status message prefix.
381
+ const bool omit_status_message_prefix_;
382
+ // Connection Attempt Delay for Happy Eyeballs.
383
+ const Duration connection_attempt_delay_;
384
+
385
+ // Lateset update args.
386
+ UpdateArgs latest_update_args_;
387
+ // The list of subchannels that we're currently trying to connect to.
388
+ // Will generally be null when selected_ is set, except when we get a
389
+ // resolver update and need to check initial connectivity states for
390
+ // the new list to decide whether we keep using the existing
391
+ // connection or go IDLE.
392
+ OrphanablePtr<SubchannelList> subchannel_list_;
393
+ // Selected subchannel. Will generally be null when subchannel_list_
394
+ // is non-null, with the exception mentioned above.
395
+ OrphanablePtr<SubchannelList::SubchannelData::SubchannelState> selected_;
396
+ // Health watcher for the selected subchannel.
397
+ SubchannelInterface::ConnectivityStateWatcherInterface* health_watcher_ =
398
+ nullptr;
399
+ SubchannelInterface::DataWatcherInterface* health_data_watcher_ = nullptr;
400
+ // Current connectivity state.
401
+ grpc_connectivity_state state_ = GRPC_CHANNEL_CONNECTING;
402
+ // Are we shut down?
403
+ bool shutdown_ = false;
404
+ // Random bit generator used for shuffling addresses if configured
405
+ absl::BitGen bit_gen_;
406
+ };
407
+
408
+ PickFirst::PickFirst(Args args)
409
+ : LoadBalancingPolicy(std::move(args)),
410
+ enable_health_watch_(
411
+ channel_args()
412
+ .GetBool(GRPC_ARG_INTERNAL_PICK_FIRST_ENABLE_HEALTH_CHECKING)
413
+ .value_or(false)),
414
+ omit_status_message_prefix_(
415
+ channel_args()
416
+ .GetBool(GRPC_ARG_INTERNAL_PICK_FIRST_OMIT_STATUS_MESSAGE_PREFIX)
417
+ .value_or(false)),
418
+ connection_attempt_delay_(Duration::Milliseconds(
419
+ Clamp(channel_args()
420
+ .GetInt(GRPC_ARG_HAPPY_EYEBALLS_CONNECTION_ATTEMPT_DELAY_MS)
421
+ .value_or(250),
422
+ 100, 2000))) {
423
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
424
+ LOG(INFO) << "Pick First " << this << " created.";
425
+ }
426
+ }
427
+
428
+ PickFirst::~PickFirst() {
429
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
430
+ LOG(INFO) << "Destroying Pick First " << this;
431
+ }
432
+ CHECK(subchannel_list_ == nullptr);
433
+ }
434
+
435
+ void PickFirst::ShutdownLocked() {
436
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
437
+ LOG(INFO) << "Pick First " << this << " Shutting down";
438
+ }
439
+ shutdown_ = true;
440
+ UnsetSelectedSubchannel();
441
+ subchannel_list_.reset();
442
+ }
443
+
444
+ void PickFirst::ExitIdleLocked() {
445
+ if (shutdown_) return;
446
+ if (IsIdle()) {
447
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
448
+ LOG(INFO) << "Pick First " << this << " exiting idle";
449
+ }
450
+ AttemptToConnectUsingLatestUpdateArgsLocked();
451
+ }
452
+ }
453
+
454
+ void PickFirst::ResetBackoffLocked() {
455
+ if (subchannel_list_ != nullptr) subchannel_list_->ResetBackoffLocked();
456
+ }
457
+
458
+ void PickFirst::AttemptToConnectUsingLatestUpdateArgsLocked() {
459
+ // Create a subchannel list from latest_update_args_.
460
+ EndpointAddressesIterator* addresses = nullptr;
461
+ if (latest_update_args_.addresses.ok()) {
462
+ addresses = latest_update_args_.addresses->get();
463
+ }
464
+ // Replace subchannel_list_.
465
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first) && subchannel_list_ != nullptr) {
466
+ LOG(INFO) << "[PF " << this << "] Shutting down previous subchannel list "
467
+ << subchannel_list_.get();
468
+ }
469
+ subchannel_list_ = MakeOrphanable<SubchannelList>(
470
+ RefAsSubclass<PickFirst>(DEBUG_LOCATION, "SubchannelList"), addresses,
471
+ latest_update_args_.args);
472
+ // Empty update or no valid subchannels. Put the channel in
473
+ // TRANSIENT_FAILURE and request re-resolution. Also unset the
474
+ // current selected subchannel.
475
+ if (subchannel_list_->size() == 0) {
476
+ channel_control_helper()->RequestReresolution();
477
+ absl::Status status =
478
+ latest_update_args_.addresses.ok()
479
+ ? absl::UnavailableError(absl::StrCat(
480
+ "empty address list: ", latest_update_args_.resolution_note))
481
+ : latest_update_args_.addresses.status();
482
+ UpdateState(GRPC_CHANNEL_TRANSIENT_FAILURE, status,
483
+ MakeRefCounted<TransientFailurePicker>(status));
484
+ UnsetSelectedSubchannel();
485
+ }
486
+ }
487
+
488
+ absl::string_view GetAddressFamily(const grpc_resolved_address& address) {
489
+ const char* uri_scheme = grpc_sockaddr_get_uri_scheme(&address);
490
+ return absl::string_view(uri_scheme == nullptr ? "other" : uri_scheme);
491
+ };
492
+
493
+ // An endpoint list iterator that returns only entries for a specific
494
+ // address family, as indicated by the URI scheme.
495
+ class AddressFamilyIterator final {
496
+ public:
497
+ AddressFamilyIterator(absl::string_view scheme, size_t index)
498
+ : scheme_(scheme), index_(index) {}
499
+
500
+ EndpointAddresses* Next(EndpointAddressesList& endpoints,
501
+ std::vector<bool>* endpoints_moved) {
502
+ for (; index_ < endpoints.size(); ++index_) {
503
+ if (!(*endpoints_moved)[index_] &&
504
+ GetAddressFamily(endpoints[index_].address()) == scheme_) {
505
+ (*endpoints_moved)[index_] = true;
506
+ return &endpoints[index_++];
507
+ }
508
+ }
509
+ return nullptr;
510
+ }
511
+
512
+ private:
513
+ absl::string_view scheme_;
514
+ size_t index_;
515
+ };
516
+
517
+ absl::Status PickFirst::UpdateLocked(UpdateArgs args) {
518
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
519
+ if (args.addresses.ok()) {
520
+ LOG(INFO) << "Pick First " << this << " received update";
521
+ } else {
522
+ LOG(INFO) << "Pick First " << this
523
+ << " received update with address error: "
524
+ << args.addresses.status();
525
+ }
526
+ }
527
+ // Set return status based on the address list.
528
+ absl::Status status;
529
+ if (!args.addresses.ok()) {
530
+ status = args.addresses.status();
531
+ } else {
532
+ EndpointAddressesList endpoints;
533
+ (*args.addresses)->ForEach([&](const EndpointAddresses& endpoint) {
534
+ endpoints.push_back(endpoint);
535
+ });
536
+ if (endpoints.empty()) {
537
+ status = absl::UnavailableError("address list must not be empty");
538
+ } else {
539
+ // Shuffle the list if needed.
540
+ auto config = static_cast<PickFirstConfig*>(args.config.get());
541
+ if (config->shuffle_addresses()) {
542
+ absl::c_shuffle(endpoints, bit_gen_);
543
+ }
544
+ // Flatten the list so that we have one address per endpoint.
545
+ // While we're iterating, also determine the desired address family
546
+ // order and the index of the first element of each family, for use in
547
+ // the interleaving below.
548
+ std::set<absl::string_view> address_families;
549
+ std::vector<AddressFamilyIterator> address_family_order;
550
+ EndpointAddressesList flattened_endpoints;
551
+ for (const auto& endpoint : endpoints) {
552
+ for (const auto& address : endpoint.addresses()) {
553
+ flattened_endpoints.emplace_back(address, endpoint.args());
554
+ absl::string_view scheme = GetAddressFamily(address);
555
+ bool inserted = address_families.insert(scheme).second;
556
+ if (inserted) {
557
+ address_family_order.emplace_back(scheme,
558
+ flattened_endpoints.size() - 1);
559
+ }
560
+ }
561
+ }
562
+ endpoints = std::move(flattened_endpoints);
563
+ // Interleave addresses as per RFC-8305 section 4.
564
+ EndpointAddressesList interleaved_endpoints;
565
+ interleaved_endpoints.reserve(endpoints.size());
566
+ std::vector<bool> endpoints_moved(endpoints.size());
567
+ size_t scheme_index = 0;
568
+ for (size_t i = 0; i < endpoints.size(); ++i) {
569
+ EndpointAddresses* endpoint;
570
+ do {
571
+ auto& iterator = address_family_order[scheme_index++ %
572
+ address_family_order.size()];
573
+ endpoint = iterator.Next(endpoints, &endpoints_moved);
574
+ } while (endpoint == nullptr);
575
+ interleaved_endpoints.emplace_back(std::move(*endpoint));
576
+ }
577
+ endpoints = std::move(interleaved_endpoints);
578
+ args.addresses =
579
+ std::make_shared<EndpointAddressesListIterator>(std::move(endpoints));
580
+ }
581
+ }
582
+ // If the update contains a resolver error and we have a previous update
583
+ // that was not a resolver error, keep using the previous addresses.
584
+ if (!args.addresses.ok() && latest_update_args_.config != nullptr) {
585
+ args.addresses = std::move(latest_update_args_.addresses);
586
+ }
587
+ // Update latest_update_args_.
588
+ latest_update_args_ = std::move(args);
589
+ // If we are not in idle, start connection attempt immediately.
590
+ // Otherwise, we defer the attempt into ExitIdleLocked().
591
+ if (!IsIdle()) {
592
+ AttemptToConnectUsingLatestUpdateArgsLocked();
593
+ }
594
+ return status;
595
+ }
596
+
597
+ void PickFirst::UpdateState(grpc_connectivity_state state,
598
+ const absl::Status& status,
599
+ RefCountedPtr<SubchannelPicker> picker) {
600
+ state_ = state;
601
+ channel_control_helper()->UpdateState(state, status, std::move(picker));
602
+ }
603
+
604
+ void PickFirst::UnsetSelectedSubchannel() {
605
+ if (selected_ != nullptr && health_data_watcher_ != nullptr) {
606
+ selected_->subchannel()->CancelDataWatcher(health_data_watcher_);
607
+ }
608
+ selected_.reset();
609
+ health_watcher_ = nullptr;
610
+ health_data_watcher_ = nullptr;
611
+ }
612
+
613
+ void PickFirst::GoIdle() {
614
+ // Unset the selected subchannel.
615
+ UnsetSelectedSubchannel();
616
+ // Drop the current subchannel list, if any.
617
+ subchannel_list_.reset();
618
+ // Request a re-resolution.
619
+ // TODO(qianchengz): We may want to request re-resolution in
620
+ // ExitIdleLocked() instead.
621
+ channel_control_helper()->RequestReresolution();
622
+ // Enter idle.
623
+ UpdateState(GRPC_CHANNEL_IDLE, absl::Status(),
624
+ MakeRefCounted<QueuePicker>(Ref(DEBUG_LOCATION, "QueuePicker")));
625
+ }
626
+
627
+ //
628
+ // PickFirst::HealthWatcher
629
+ //
630
+
631
+ void PickFirst::HealthWatcher::OnConnectivityStateChange(
632
+ grpc_connectivity_state new_state, absl::Status status) {
633
+ if (policy_->health_watcher_ != this) return;
634
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
635
+ LOG(INFO) << "[PF " << policy_.get() << "] health watch state update: "
636
+ << ConnectivityStateName(new_state) << " (" << status << ")";
637
+ }
638
+ switch (new_state) {
639
+ case GRPC_CHANNEL_READY:
640
+ policy_->channel_control_helper()->UpdateState(
641
+ GRPC_CHANNEL_READY, absl::OkStatus(),
642
+ MakeRefCounted<Picker>(policy_->selected_->subchannel()->Ref()));
643
+ break;
644
+ case GRPC_CHANNEL_IDLE:
645
+ // If the subchannel becomes disconnected, the health watcher
646
+ // might happen to see the change before the raw connectivity
647
+ // state watcher does. In this case, ignore it, since the raw
648
+ // connectivity state watcher will handle it shortly.
649
+ break;
650
+ case GRPC_CHANNEL_CONNECTING:
651
+ policy_->channel_control_helper()->UpdateState(
652
+ new_state, absl::OkStatus(),
653
+ MakeRefCounted<QueuePicker>(policy_->Ref()));
654
+ break;
655
+ case GRPC_CHANNEL_TRANSIENT_FAILURE:
656
+ policy_->channel_control_helper()->UpdateState(
657
+ GRPC_CHANNEL_TRANSIENT_FAILURE, status,
658
+ MakeRefCounted<TransientFailurePicker>(status));
659
+ break;
660
+ case GRPC_CHANNEL_SHUTDOWN:
661
+ Crash("health watcher reported state SHUTDOWN");
662
+ }
663
+ }
664
+
665
+ //
666
+ // PickFirst::SubchannelList::SubchannelData::SubchannelState
667
+ //
668
+
669
+ PickFirst::SubchannelList::SubchannelData::SubchannelState::SubchannelState(
670
+ SubchannelData* subchannel_data,
671
+ RefCountedPtr<SubchannelInterface> subchannel)
672
+ : subchannel_data_(subchannel_data),
673
+ pick_first_(subchannel_data_->subchannel_list_->policy_),
674
+ subchannel_(std::move(subchannel)) {
675
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
676
+ LOG(INFO) << "[PF " << pick_first_.get() << "] subchannel state " << this
677
+ << " (subchannel " << subchannel_.get() << "): starting watch";
678
+ }
679
+ auto watcher = std::make_unique<Watcher>(Ref(DEBUG_LOCATION, "Watcher"));
680
+ watcher_ = watcher.get();
681
+ subchannel_->WatchConnectivityState(std::move(watcher));
682
+ }
683
+
684
+ void PickFirst::SubchannelList::SubchannelData::SubchannelState::Orphan() {
685
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
686
+ LOG(INFO) << "[PF " << pick_first_.get() << "] subchannel state " << this
687
+ << " (subchannel " << subchannel_.get()
688
+ << "): cancelling watch and unreffing subchannel";
689
+ }
690
+ subchannel_data_ = nullptr;
691
+ subchannel_->CancelConnectivityStateWatch(watcher_);
692
+ watcher_ = nullptr;
693
+ subchannel_.reset();
694
+ pick_first_.reset();
695
+ Unref();
696
+ }
697
+
698
+ void PickFirst::SubchannelList::SubchannelData::SubchannelState::Select() {
699
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
700
+ LOG(INFO) << "Pick First " << pick_first_.get() << " selected subchannel "
701
+ << subchannel_.get();
702
+ }
703
+ CHECK_NE(subchannel_data_, nullptr);
704
+ pick_first_->UnsetSelectedSubchannel(); // Cancel health watch, if any.
705
+ pick_first_->selected_ = std::move(subchannel_data_->subchannel_state_);
706
+ // If health checking is enabled, start the health watch, but don't
707
+ // report a new picker -- we want to stay in CONNECTING while we wait
708
+ // for the health status notification.
709
+ // If health checking is NOT enabled, report READY.
710
+ if (pick_first_->enable_health_watch_) {
711
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
712
+ LOG(INFO) << "[PF " << pick_first_.get() << "] starting health watch";
713
+ }
714
+ auto watcher = std::make_unique<HealthWatcher>(
715
+ pick_first_.Ref(DEBUG_LOCATION, "HealthWatcher"));
716
+ pick_first_->health_watcher_ = watcher.get();
717
+ auto health_data_watcher = MakeHealthCheckWatcher(
718
+ pick_first_->work_serializer(),
719
+ subchannel_data_->subchannel_list_->args_, std::move(watcher));
720
+ pick_first_->health_data_watcher_ = health_data_watcher.get();
721
+ subchannel_->AddDataWatcher(std::move(health_data_watcher));
722
+ } else {
723
+ pick_first_->UpdateState(GRPC_CHANNEL_READY, absl::Status(),
724
+ MakeRefCounted<Picker>(subchannel_));
725
+ }
726
+ // Report successful connection.
727
+ // We consider it a successful connection attempt only if the
728
+ // previous state was CONNECTING. In particular, we don't want to
729
+ // increment this counter if we got a new address list and found the
730
+ // existing connection already in state READY.
731
+ if (subchannel_data_->connectivity_state_ == GRPC_CHANNEL_CONNECTING) {
732
+ auto& stats_plugins =
733
+ pick_first_->channel_control_helper()->GetStatsPluginGroup();
734
+ stats_plugins.AddCounter(
735
+ kMetricConnectionAttemptsSucceeded, 1,
736
+ {pick_first_->channel_control_helper()->GetTarget()}, {});
737
+ }
738
+ // Drop our pointer to subchannel_data_, so that we know not to
739
+ // interact with it on subsequent connectivity state updates.
740
+ subchannel_data_ = nullptr;
741
+ // Clean up subchannel list.
742
+ pick_first_->subchannel_list_.reset();
743
+ }
744
+
745
+ void PickFirst::SubchannelList::SubchannelData::SubchannelState::
746
+ OnConnectivityStateChange(grpc_connectivity_state new_state,
747
+ absl::Status status) {
748
+ if (watcher_ == nullptr) return;
749
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
750
+ LOG(INFO) << "[PF " << pick_first_.get() << "] subchannel state " << this
751
+ << " (subchannel " << subchannel_.get()
752
+ << "): connectivity changed: new_state="
753
+ << ConnectivityStateName(new_state) << ", status=" << status
754
+ << ", watcher=" << watcher_
755
+ << ", subchannel_data_=" << subchannel_data_
756
+ << ", pick_first_->selected_=" << pick_first_->selected_.get();
757
+ }
758
+ // If we're still part of a subchannel list trying to connect, check
759
+ // if we're connected.
760
+ if (subchannel_data_ != nullptr) {
761
+ // If the subchannel is READY, use it.
762
+ // Otherwise, tell the subchannel list to keep trying.
763
+ if (new_state == GRPC_CHANNEL_READY) {
764
+ Select();
765
+ } else {
766
+ subchannel_data_->OnConnectivityStateChange(new_state, std::move(status));
767
+ }
768
+ return;
769
+ }
770
+ // We aren't trying to connect, so we must be the selected subchannel.
771
+ CHECK(pick_first_->selected_.get() == this);
772
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
773
+ LOG(INFO) << "Pick First " << pick_first_.get()
774
+ << " selected subchannel connectivity changed to "
775
+ << ConnectivityStateName(new_state);
776
+ }
777
+ // Any state change is considered to be a failure of the existing
778
+ // connection. Report the failure.
779
+ auto& stats_plugins =
780
+ pick_first_->channel_control_helper()->GetStatsPluginGroup();
781
+ stats_plugins.AddCounter(kMetricDisconnections, 1,
782
+ {pick_first_->channel_control_helper()->GetTarget()},
783
+ {});
784
+ // Report IDLE.
785
+ pick_first_->GoIdle();
786
+ }
787
+
788
+ //
789
+ // PickFirst::SubchannelList::SubchannelData
790
+ //
791
+
792
+ PickFirst::SubchannelList::SubchannelData::SubchannelData(
793
+ SubchannelList* subchannel_list, size_t index,
794
+ RefCountedPtr<SubchannelInterface> subchannel)
795
+ : subchannel_list_(subchannel_list), index_(index) {
796
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
797
+ LOG(INFO) << "[PF " << subchannel_list_->policy_.get()
798
+ << "] subchannel list " << subchannel_list_ << " index " << index_
799
+ << ": creating subchannel data";
800
+ }
801
+ subchannel_state_ =
802
+ MakeOrphanable<SubchannelState>(this, std::move(subchannel));
803
+ }
804
+
805
+ void PickFirst::SubchannelList::SubchannelData::OnConnectivityStateChange(
806
+ grpc_connectivity_state new_state, absl::Status status) {
807
+ PickFirst* p = subchannel_list_->policy_.get();
808
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
809
+ LOG(INFO) << "[PF " << p << "] subchannel list " << subchannel_list_
810
+ << " index " << index_ << " of " << subchannel_list_->size()
811
+ << " (subchannel_state " << subchannel_state_.get()
812
+ << "): connectivity changed: old_state="
813
+ << (connectivity_state_.has_value()
814
+ ? ConnectivityStateName(*connectivity_state_)
815
+ : "N/A")
816
+ << ", new_state=" << ConnectivityStateName(new_state)
817
+ << ", status=" << status
818
+ << ", seen_transient_failure=" << seen_transient_failure_
819
+ << ", p->selected_=" << p->selected_.get()
820
+ << ", p->subchannel_list_=" << p->subchannel_list_.get()
821
+ << ", p->subchannel_list_->shutting_down_="
822
+ << p->subchannel_list_->shutting_down_;
823
+ }
824
+ if (subchannel_list_->shutting_down_) return;
825
+ // The notification must be for a subchannel in the current list.
826
+ CHECK(subchannel_list_ == p->subchannel_list_.get());
827
+ // SHUTDOWN should never happen.
828
+ CHECK(new_state != GRPC_CHANNEL_SHUTDOWN);
829
+ // READY should be caught by SubchannelState, in which case it will
830
+ // not call us in the first place.
831
+ CHECK(new_state != GRPC_CHANNEL_READY);
832
+ // Update state.
833
+ absl::optional<grpc_connectivity_state> old_state = connectivity_state_;
834
+ connectivity_state_ = new_state;
835
+ connectivity_status_ = std::move(status);
836
+ // Make sure we note when a subchannel has seen TRANSIENT_FAILURE.
837
+ bool prev_seen_transient_failure = seen_transient_failure_;
838
+ if (new_state == GRPC_CHANNEL_TRANSIENT_FAILURE) {
839
+ seen_transient_failure_ = true;
840
+ subchannel_list_->last_failure_ = connectivity_status_;
841
+ }
842
+ // If this is the initial connectivity state update for this subchannel,
843
+ // increment the counter in the subchannel list.
844
+ if (!old_state.has_value()) {
845
+ ++subchannel_list_->num_subchannels_seen_initial_notification_;
846
+ }
847
+ // If we haven't yet seen the initial connectivity state notification
848
+ // for all subchannels, do nothing.
849
+ if (!subchannel_list_->AllSubchannelsSeenInitialState()) return;
850
+ // If we're still here and this is the initial connectivity state
851
+ // notification for this subchannel, that means it was the last one to
852
+ // see its initial notification. So we now have enough state to
853
+ // figure out how to proceed.
854
+ if (!old_state.has_value()) {
855
+ // If we already have a selected subchannel and we got here, that
856
+ // means that none of the subchannels on the new list are in READY
857
+ // state, which means that the address we're currently connected to
858
+ // is not in the new list. In that case, we drop the current
859
+ // connection and report IDLE.
860
+ if (p->selected_ != nullptr) {
861
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
862
+ LOG(INFO) << "[PF " << p << "] subchannel list " << subchannel_list_
863
+ << ": new update has no subchannels in "
864
+ << "state READY; dropping existing connection and going IDLE";
865
+ }
866
+ p->GoIdle();
867
+ } else {
868
+ // Start trying to connect, starting with the first subchannel.
869
+ subchannel_list_->StartConnectingNextSubchannel();
870
+ }
871
+ return;
872
+ }
873
+ // We've already started trying to connect. Any subchannel that
874
+ // reports TF is a connection attempt failure.
875
+ if (new_state == GRPC_CHANNEL_TRANSIENT_FAILURE) {
876
+ auto& stats_plugins = subchannel_list_->policy_->channel_control_helper()
877
+ ->GetStatsPluginGroup();
878
+ stats_plugins.AddCounter(
879
+ kMetricConnectionAttemptsFailed, 1,
880
+ {subchannel_list_->policy_->channel_control_helper()->GetTarget()}, {});
881
+ }
882
+ // Otherwise, process connectivity state change.
883
+ switch (*connectivity_state_) {
884
+ case GRPC_CHANNEL_TRANSIENT_FAILURE: {
885
+ // If this is the first failure we've seen on this subchannel,
886
+ // then we're still in the Happy Eyeballs pass.
887
+ if (!prev_seen_transient_failure && seen_transient_failure_) {
888
+ // If a connection attempt fails before the timer fires, then
889
+ // cancel the timer and start connecting on the next subchannel.
890
+ if (index_ == subchannel_list_->attempting_index_) {
891
+ if (subchannel_list_->timer_handle_.has_value()) {
892
+ p->channel_control_helper()->GetEventEngine()->Cancel(
893
+ *subchannel_list_->timer_handle_);
894
+ }
895
+ ++subchannel_list_->attempting_index_;
896
+ subchannel_list_->StartConnectingNextSubchannel();
897
+ } else {
898
+ // If this was the last subchannel to fail, check if the Happy
899
+ // Eyeballs pass is complete.
900
+ subchannel_list_->MaybeFinishHappyEyeballsPass();
901
+ }
902
+ } else if (subchannel_list_->IsHappyEyeballsPassComplete()) {
903
+ // We're done with the initial Happy Eyeballs pass and in a mode
904
+ // where we're attempting to connect to every subchannel in
905
+ // parallel. We count the number of failed connection attempts,
906
+ // and when that is equal to the number of subchannels, request
907
+ // re-resolution and report TRANSIENT_FAILURE again, so that the
908
+ // caller has the most recent status message. Note that this
909
+ // isn't necessarily the same as saying that we've seen one
910
+ // failure for each subchannel in the list, because the backoff
911
+ // state may be different in each subchannel, so we may have seen
912
+ // one subchannel fail more than once and another subchannel not
913
+ // fail at all. But it's a good enough heuristic.
914
+ ++subchannel_list_->num_failures_;
915
+ if (subchannel_list_->num_failures_ % subchannel_list_->size() == 0) {
916
+ p->channel_control_helper()->RequestReresolution();
917
+ status = absl::UnavailableError(absl::StrCat(
918
+ (p->omit_status_message_prefix_
919
+ ? ""
920
+ : "failed to connect to all addresses; last error: "),
921
+ connectivity_status_.ToString()));
922
+ p->UpdateState(GRPC_CHANNEL_TRANSIENT_FAILURE, status,
923
+ MakeRefCounted<TransientFailurePicker>(status));
924
+ }
925
+ }
926
+ break;
927
+ }
928
+ case GRPC_CHANNEL_IDLE:
929
+ // If we've finished the first Happy Eyeballs pass, then we go
930
+ // into a mode where we immediately try to connect to every
931
+ // subchannel in parallel.
932
+ if (subchannel_list_->IsHappyEyeballsPassComplete()) {
933
+ subchannel_state_->RequestConnection();
934
+ }
935
+ break;
936
+ case GRPC_CHANNEL_CONNECTING:
937
+ // Only update connectivity state only if we're not already in
938
+ // TRANSIENT_FAILURE.
939
+ // TODO(roth): Squelch duplicate CONNECTING updates.
940
+ if (p->state_ != GRPC_CHANNEL_TRANSIENT_FAILURE) {
941
+ p->UpdateState(GRPC_CHANNEL_CONNECTING, absl::Status(),
942
+ MakeRefCounted<QueuePicker>(nullptr));
943
+ }
944
+ break;
945
+ default:
946
+ // We handled READY above, and we should never see SHUTDOWN.
947
+ GPR_UNREACHABLE_CODE(break);
948
+ }
949
+ }
72
950
 
73
- namespace {
951
+ void PickFirst::SubchannelList::SubchannelData::RequestConnectionWithTimer() {
952
+ CHECK(connectivity_state_.has_value());
953
+ if (connectivity_state_ == GRPC_CHANNEL_IDLE) {
954
+ subchannel_state_->RequestConnection();
955
+ } else {
956
+ CHECK(connectivity_state_ == GRPC_CHANNEL_CONNECTING);
957
+ }
958
+ // If this is not the last subchannel in the list, start the timer.
959
+ if (index_ != subchannel_list_->size() - 1) {
960
+ PickFirst* p = subchannel_list_->policy_.get();
961
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
962
+ LOG(INFO) << "Pick First " << p << " subchannel list " << subchannel_list_
963
+ << ": starting Connection Attempt Delay timer for "
964
+ << p->connection_attempt_delay_.millis() << "ms for index "
965
+ << index_;
966
+ }
967
+ subchannel_list_->timer_handle_ =
968
+ p->channel_control_helper()->GetEventEngine()->RunAfter(
969
+ p->connection_attempt_delay_,
970
+ [subchannel_list =
971
+ subchannel_list_->Ref(DEBUG_LOCATION, "timer")]() mutable {
972
+ ApplicationCallbackExecCtx application_exec_ctx;
973
+ ExecCtx exec_ctx;
974
+ auto* sl = subchannel_list.get();
975
+ sl->policy_->work_serializer()->Run(
976
+ [subchannel_list = std::move(subchannel_list)]() {
977
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
978
+ LOG(INFO)
979
+ << "Pick First " << subchannel_list->policy_.get()
980
+ << " subchannel list " << subchannel_list.get()
981
+ << ": Connection Attempt Delay timer fired "
982
+ "(shutting_down="
983
+ << subchannel_list->shutting_down_ << ", selected="
984
+ << subchannel_list->policy_->selected_.get() << ")";
985
+ }
986
+ if (subchannel_list->shutting_down_) return;
987
+ if (subchannel_list->policy_->selected_ != nullptr) return;
988
+ ++subchannel_list->attempting_index_;
989
+ subchannel_list->StartConnectingNextSubchannel();
990
+ },
991
+ DEBUG_LOCATION);
992
+ });
993
+ }
994
+ }
74
995
 
75
996
  //
76
- // pick_first LB policy
997
+ // PickFirst::SubchannelList
77
998
  //
78
999
 
79
- constexpr absl::string_view kPickFirst = "pick_first";
80
-
81
- const auto kMetricDisconnections =
82
- GlobalInstrumentsRegistry::RegisterUInt64Counter(
83
- "grpc.lb.pick_first.disconnections",
84
- "EXPERIMENTAL. Number of times the selected subchannel becomes "
85
- "disconnected.",
86
- "{disconnection}", {kMetricLabelTarget}, {}, false);
1000
+ PickFirst::SubchannelList::SubchannelList(RefCountedPtr<PickFirst> policy,
1001
+ EndpointAddressesIterator* addresses,
1002
+ const ChannelArgs& args)
1003
+ : InternallyRefCounted<SubchannelList>(
1004
+ GRPC_TRACE_FLAG_ENABLED(pick_first) ? "SubchannelList" : nullptr),
1005
+ policy_(std::move(policy)),
1006
+ args_(args.Remove(GRPC_ARG_INTERNAL_PICK_FIRST_ENABLE_HEALTH_CHECKING)
1007
+ .Remove(
1008
+ GRPC_ARG_INTERNAL_PICK_FIRST_OMIT_STATUS_MESSAGE_PREFIX)) {
1009
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
1010
+ LOG(INFO) << "[PF " << policy_.get() << "] Creating subchannel list "
1011
+ << this << " - channel args: " << args_.ToString();
1012
+ }
1013
+ if (addresses == nullptr) return;
1014
+ // Create a subchannel for each address.
1015
+ addresses->ForEach([&](const EndpointAddresses& address) {
1016
+ CHECK_EQ(address.addresses().size(), 1u);
1017
+ RefCountedPtr<SubchannelInterface> subchannel =
1018
+ policy_->channel_control_helper()->CreateSubchannel(
1019
+ address.address(), address.args(), args_);
1020
+ if (subchannel == nullptr) {
1021
+ // Subchannel could not be created.
1022
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
1023
+ LOG(INFO) << "[PF " << policy_.get()
1024
+ << "] could not create subchannel for address "
1025
+ << address.ToString() << ", ignoring";
1026
+ }
1027
+ return;
1028
+ }
1029
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
1030
+ LOG(INFO) << "[PF " << policy_.get() << "] subchannel list " << this
1031
+ << " index " << subchannels_.size() << ": Created subchannel "
1032
+ << subchannel.get() << " for address " << address.ToString();
1033
+ }
1034
+ subchannels_.emplace_back(std::make_unique<SubchannelData>(
1035
+ this, subchannels_.size(), std::move(subchannel)));
1036
+ });
1037
+ }
87
1038
 
88
- const auto kMetricConnectionAttemptsSucceeded =
89
- GlobalInstrumentsRegistry::RegisterUInt64Counter(
90
- "grpc.lb.pick_first.connection_attempts_succeeded",
91
- "EXPERIMENTAL. Number of successful connection attempts.",
92
- "{attempt}", {kMetricLabelTarget}, {}, false);
1039
+ PickFirst::SubchannelList::~SubchannelList() {
1040
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
1041
+ LOG(INFO) << "[PF " << policy_.get() << "] Destroying subchannel_list "
1042
+ << this;
1043
+ }
1044
+ }
93
1045
 
94
- const auto kMetricConnectionAttemptsFailed =
95
- GlobalInstrumentsRegistry::RegisterUInt64Counter(
96
- "grpc.lb.pick_first.connection_attempts_failed",
97
- "EXPERIMENTAL. Number of failed connection attempts.",
98
- "{attempt}", {kMetricLabelTarget}, {}, false);
1046
+ void PickFirst::SubchannelList::Orphan() {
1047
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
1048
+ LOG(INFO) << "[PF " << policy_.get() << "] Shutting down subchannel_list "
1049
+ << this;
1050
+ }
1051
+ CHECK(!shutting_down_);
1052
+ shutting_down_ = true;
1053
+ // Cancel Happy Eyeballs timer, if any.
1054
+ if (timer_handle_.has_value()) {
1055
+ policy_->channel_control_helper()->GetEventEngine()->Cancel(*timer_handle_);
1056
+ }
1057
+ Unref();
1058
+ }
99
1059
 
100
- class PickFirstConfig final : public LoadBalancingPolicy::Config {
101
- public:
102
- absl::string_view name() const override { return kPickFirst; }
103
- bool shuffle_addresses() const { return shuffle_addresses_; }
1060
+ void PickFirst::SubchannelList::ResetBackoffLocked() {
1061
+ for (auto& sd : subchannels_) {
1062
+ sd->ResetBackoffLocked();
1063
+ }
1064
+ }
104
1065
 
105
- static const JsonLoaderInterface* JsonLoader(const JsonArgs&) {
106
- static const auto kJsonLoader =
107
- JsonObjectLoader<PickFirstConfig>()
108
- .OptionalField("shuffleAddressList",
109
- &PickFirstConfig::shuffle_addresses_)
110
- .Finish();
111
- return kJsonLoader;
1066
+ void PickFirst::SubchannelList::StartConnectingNextSubchannel() {
1067
+ // Find the next subchannel not in state TRANSIENT_FAILURE.
1068
+ // We skip subchannels in state TRANSIENT_FAILURE to avoid a
1069
+ // large recursion that could overflow the stack.
1070
+ for (; attempting_index_ < size(); ++attempting_index_) {
1071
+ SubchannelData* sc = subchannels_[attempting_index_].get();
1072
+ CHECK(sc->connectivity_state().has_value());
1073
+ if (sc->connectivity_state() != GRPC_CHANNEL_TRANSIENT_FAILURE) {
1074
+ // Found a subchannel not in TRANSIENT_FAILURE, so trigger a
1075
+ // connection attempt.
1076
+ sc->RequestConnectionWithTimer();
1077
+ return;
1078
+ }
112
1079
  }
1080
+ // If we didn't find a subchannel to request a connection on, check to
1081
+ // see if the Happy Eyeballs pass is complete.
1082
+ MaybeFinishHappyEyeballsPass();
1083
+ }
113
1084
 
114
- private:
115
- bool shuffle_addresses_ = false;
116
- };
1085
+ void PickFirst::SubchannelList::MaybeFinishHappyEyeballsPass() {
1086
+ // Make sure all subchannels have finished a connection attempt before
1087
+ // we consider the Happy Eyeballs pass complete.
1088
+ if (!IsHappyEyeballsPassComplete()) return;
1089
+ // We didn't find another subchannel not in state TRANSIENT_FAILURE,
1090
+ // so report TRANSIENT_FAILURE and switch to a mode in which we try to
1091
+ // connect to all addresses in parallel.
1092
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
1093
+ LOG(INFO) << "Pick First " << policy_.get() << " subchannel list " << this
1094
+ << " failed to connect to all subchannels";
1095
+ }
1096
+ // Re-resolve and report TRANSIENT_FAILURE.
1097
+ policy_->channel_control_helper()->RequestReresolution();
1098
+ absl::Status status = absl::UnavailableError(
1099
+ absl::StrCat((policy_->omit_status_message_prefix_
1100
+ ? ""
1101
+ : "failed to connect to all addresses; last error: "),
1102
+ last_failure_.ToString()));
1103
+ policy_->UpdateState(GRPC_CHANNEL_TRANSIENT_FAILURE, status,
1104
+ MakeRefCounted<TransientFailurePicker>(status));
1105
+ // Drop the existing (working) connection, if any. This may be
1106
+ // sub-optimal, but we can't ignore what the control plane told us.
1107
+ policy_->UnsetSelectedSubchannel();
1108
+ // We now transition into a mode where we try to connect to all
1109
+ // subchannels in parallel. For any subchannel currently in IDLE,
1110
+ // trigger a connection attempt. For any subchannel not currently in
1111
+ // IDLE, we will trigger a connection attempt when it does report IDLE.
1112
+ for (auto& sd : subchannels_) {
1113
+ if (sd->connectivity_state() == GRPC_CHANNEL_IDLE) {
1114
+ sd->RequestConnection();
1115
+ }
1116
+ }
1117
+ }
117
1118
 
118
- class PickFirst final : public LoadBalancingPolicy {
1119
+ // TODO(roth): Remove this when the pick_first_new experiment is removed.
1120
+ class OldPickFirst final : public LoadBalancingPolicy {
119
1121
  public:
120
- explicit PickFirst(Args args);
1122
+ explicit OldPickFirst(Args args);
121
1123
 
122
1124
  absl::string_view name() const override { return kPickFirst; }
123
1125
 
@@ -126,7 +1128,7 @@ class PickFirst final : public LoadBalancingPolicy {
126
1128
  void ResetBackoffLocked() override;
127
1129
 
128
1130
  private:
129
- ~PickFirst() override;
1131
+ ~OldPickFirst() override;
130
1132
 
131
1133
  class SubchannelList final : public InternallyRefCounted<SubchannelList> {
132
1134
  public:
@@ -211,7 +1213,7 @@ class PickFirst final : public LoadBalancingPolicy {
211
1213
  bool seen_transient_failure_ = false;
212
1214
  };
213
1215
 
214
- SubchannelList(RefCountedPtr<PickFirst> policy,
1216
+ SubchannelList(RefCountedPtr<OldPickFirst> policy,
215
1217
  EndpointAddressesIterator* addresses,
216
1218
  const ChannelArgs& args);
217
1219
 
@@ -257,7 +1259,7 @@ class PickFirst final : public LoadBalancingPolicy {
257
1259
  void MaybeFinishHappyEyeballsPass();
258
1260
 
259
1261
  // Backpointer to owning policy.
260
- RefCountedPtr<PickFirst> policy_;
1262
+ RefCountedPtr<OldPickFirst> policy_;
261
1263
 
262
1264
  ChannelArgs args_;
263
1265
 
@@ -290,7 +1292,7 @@ class PickFirst final : public LoadBalancingPolicy {
290
1292
  class HealthWatcher final
291
1293
  : public SubchannelInterface::ConnectivityStateWatcherInterface {
292
1294
  public:
293
- explicit HealthWatcher(RefCountedPtr<PickFirst> policy)
1295
+ explicit HealthWatcher(RefCountedPtr<OldPickFirst> policy)
294
1296
  : policy_(std::move(policy)) {}
295
1297
 
296
1298
  ~HealthWatcher() override {
@@ -305,7 +1307,7 @@ class PickFirst final : public LoadBalancingPolicy {
305
1307
  }
306
1308
 
307
1309
  private:
308
- RefCountedPtr<PickFirst> policy_;
1310
+ RefCountedPtr<OldPickFirst> policy_;
309
1311
  };
310
1312
 
311
1313
  class Picker final : public SubchannelPicker {
@@ -365,7 +1367,7 @@ class PickFirst final : public LoadBalancingPolicy {
365
1367
  absl::BitGen bit_gen_;
366
1368
  };
367
1369
 
368
- PickFirst::PickFirst(Args args)
1370
+ OldPickFirst::OldPickFirst(Args args)
369
1371
  : LoadBalancingPolicy(std::move(args)),
370
1372
  enable_health_watch_(
371
1373
  channel_args()
@@ -380,22 +1382,22 @@ PickFirst::PickFirst(Args args)
380
1382
  .GetInt(GRPC_ARG_HAPPY_EYEBALLS_CONNECTION_ATTEMPT_DELAY_MS)
381
1383
  .value_or(250),
382
1384
  100, 2000))) {
383
- if (GRPC_TRACE_FLAG_ENABLED(grpc_lb_pick_first_trace)) {
384
- gpr_log(GPR_INFO, "Pick First %p created.", this);
1385
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
1386
+ LOG(INFO) << "Pick First " << this << " created.";
385
1387
  }
386
1388
  }
387
1389
 
388
- PickFirst::~PickFirst() {
389
- if (GRPC_TRACE_FLAG_ENABLED(grpc_lb_pick_first_trace)) {
390
- gpr_log(GPR_INFO, "Destroying Pick First %p", this);
1390
+ OldPickFirst::~OldPickFirst() {
1391
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
1392
+ LOG(INFO) << "Destroying Pick First " << this;
391
1393
  }
392
- GPR_ASSERT(subchannel_list_ == nullptr);
393
- GPR_ASSERT(latest_pending_subchannel_list_ == nullptr);
1394
+ CHECK(subchannel_list_ == nullptr);
1395
+ CHECK(latest_pending_subchannel_list_ == nullptr);
394
1396
  }
395
1397
 
396
- void PickFirst::ShutdownLocked() {
397
- if (GRPC_TRACE_FLAG_ENABLED(grpc_lb_pick_first_trace)) {
398
- gpr_log(GPR_INFO, "Pick First %p Shutting down", this);
1398
+ void OldPickFirst::ShutdownLocked() {
1399
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
1400
+ LOG(INFO) << "Pick First " << this << " Shutting down";
399
1401
  }
400
1402
  shutdown_ = true;
401
1403
  UnsetSelectedSubchannel();
@@ -403,38 +1405,38 @@ void PickFirst::ShutdownLocked() {
403
1405
  latest_pending_subchannel_list_.reset();
404
1406
  }
405
1407
 
406
- void PickFirst::ExitIdleLocked() {
1408
+ void OldPickFirst::ExitIdleLocked() {
407
1409
  if (shutdown_) return;
408
1410
  if (IsIdle()) {
409
- if (GRPC_TRACE_FLAG_ENABLED(grpc_lb_pick_first_trace)) {
410
- gpr_log(GPR_INFO, "Pick First %p exiting idle", this);
1411
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
1412
+ LOG(INFO) << "Pick First " << this << " exiting idle";
411
1413
  }
412
1414
  AttemptToConnectUsingLatestUpdateArgsLocked();
413
1415
  }
414
1416
  }
415
1417
 
416
- void PickFirst::ResetBackoffLocked() {
1418
+ void OldPickFirst::ResetBackoffLocked() {
417
1419
  if (subchannel_list_ != nullptr) subchannel_list_->ResetBackoffLocked();
418
1420
  if (latest_pending_subchannel_list_ != nullptr) {
419
1421
  latest_pending_subchannel_list_->ResetBackoffLocked();
420
1422
  }
421
1423
  }
422
1424
 
423
- void PickFirst::AttemptToConnectUsingLatestUpdateArgsLocked() {
1425
+ void OldPickFirst::AttemptToConnectUsingLatestUpdateArgsLocked() {
424
1426
  // Create a subchannel list from latest_update_args_.
425
1427
  EndpointAddressesIterator* addresses = nullptr;
426
1428
  if (latest_update_args_.addresses.ok()) {
427
1429
  addresses = latest_update_args_.addresses->get();
428
1430
  }
429
1431
  // Replace latest_pending_subchannel_list_.
430
- if (GRPC_TRACE_FLAG_ENABLED(grpc_lb_pick_first_trace) &&
1432
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first) &&
431
1433
  latest_pending_subchannel_list_ != nullptr) {
432
- gpr_log(GPR_INFO,
433
- "[PF %p] Shutting down previous pending subchannel list %p", this,
434
- latest_pending_subchannel_list_.get());
1434
+ LOG(INFO) << "[PF " << this
1435
+ << "] Shutting down previous pending subchannel list "
1436
+ << latest_pending_subchannel_list_.get();
435
1437
  }
436
1438
  latest_pending_subchannel_list_ = MakeOrphanable<SubchannelList>(
437
- RefAsSubclass<PickFirst>(), addresses, latest_update_args_.args);
1439
+ RefAsSubclass<OldPickFirst>(), addresses, latest_update_args_.args);
438
1440
  // Empty update or no valid subchannels. Put the channel in
439
1441
  // TRANSIENT_FAILURE and request re-resolution.
440
1442
  if (latest_pending_subchannel_list_->size() == 0) {
@@ -451,51 +1453,22 @@ void PickFirst::AttemptToConnectUsingLatestUpdateArgsLocked() {
451
1453
  // the current list, replace the current subchannel list immediately.
452
1454
  if (latest_pending_subchannel_list_->size() == 0 || selected_ == nullptr) {
453
1455
  UnsetSelectedSubchannel();
454
- if (GRPC_TRACE_FLAG_ENABLED(grpc_lb_pick_first_trace) &&
455
- subchannel_list_ != nullptr) {
456
- gpr_log(GPR_INFO, "[PF %p] Shutting down previous subchannel list %p",
457
- this, subchannel_list_.get());
1456
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first) && subchannel_list_ != nullptr) {
1457
+ LOG(INFO) << "[PF " << this << "] Shutting down previous subchannel list "
1458
+ << subchannel_list_.get();
458
1459
  }
459
1460
  subchannel_list_ = std::move(latest_pending_subchannel_list_);
460
1461
  }
461
1462
  }
462
1463
 
463
- absl::string_view GetAddressFamily(const grpc_resolved_address& address) {
464
- const char* uri_scheme = grpc_sockaddr_get_uri_scheme(&address);
465
- return absl::string_view(uri_scheme == nullptr ? "other" : uri_scheme);
466
- };
467
-
468
- // An endpoint list iterator that returns only entries for a specific
469
- // address family, as indicated by the URI scheme.
470
- class AddressFamilyIterator final {
471
- public:
472
- AddressFamilyIterator(absl::string_view scheme, size_t index)
473
- : scheme_(scheme), index_(index) {}
474
-
475
- EndpointAddresses* Next(EndpointAddressesList& endpoints,
476
- std::vector<bool>* endpoints_moved) {
477
- for (; index_ < endpoints.size(); ++index_) {
478
- if (!(*endpoints_moved)[index_] &&
479
- GetAddressFamily(endpoints[index_].address()) == scheme_) {
480
- (*endpoints_moved)[index_] = true;
481
- return &endpoints[index_++];
482
- }
483
- }
484
- return nullptr;
485
- }
486
-
487
- private:
488
- absl::string_view scheme_;
489
- size_t index_;
490
- };
491
-
492
- absl::Status PickFirst::UpdateLocked(UpdateArgs args) {
493
- if (GRPC_TRACE_FLAG_ENABLED(grpc_lb_pick_first_trace)) {
1464
+ absl::Status OldPickFirst::UpdateLocked(UpdateArgs args) {
1465
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
494
1466
  if (args.addresses.ok()) {
495
- gpr_log(GPR_INFO, "Pick First %p received update", this);
1467
+ LOG(INFO) << "Pick First " << this << " received update";
496
1468
  } else {
497
- gpr_log(GPR_INFO, "Pick First %p received update with address error: %s",
498
- this, args.addresses.status().ToString().c_str());
1469
+ LOG(INFO) << "Pick First " << this
1470
+ << " received update with address error: "
1471
+ << args.addresses.status();
499
1472
  }
500
1473
  }
501
1474
  // Set return status based on the address list.
@@ -568,14 +1541,14 @@ absl::Status PickFirst::UpdateLocked(UpdateArgs args) {
568
1541
  return status;
569
1542
  }
570
1543
 
571
- void PickFirst::UpdateState(grpc_connectivity_state state,
572
- const absl::Status& status,
573
- RefCountedPtr<SubchannelPicker> picker) {
1544
+ void OldPickFirst::UpdateState(grpc_connectivity_state state,
1545
+ const absl::Status& status,
1546
+ RefCountedPtr<SubchannelPicker> picker) {
574
1547
  state_ = state;
575
1548
  channel_control_helper()->UpdateState(state, status, std::move(picker));
576
1549
  }
577
1550
 
578
- void PickFirst::UnsetSelectedSubchannel() {
1551
+ void OldPickFirst::UnsetSelectedSubchannel() {
579
1552
  if (selected_ != nullptr && health_data_watcher_ != nullptr) {
580
1553
  selected_->subchannel()->CancelDataWatcher(health_data_watcher_);
581
1554
  }
@@ -585,16 +1558,15 @@ void PickFirst::UnsetSelectedSubchannel() {
585
1558
  }
586
1559
 
587
1560
  //
588
- // PickFirst::HealthWatcher
1561
+ // OldPickFirst::HealthWatcher
589
1562
  //
590
1563
 
591
- void PickFirst::HealthWatcher::OnConnectivityStateChange(
1564
+ void OldPickFirst::HealthWatcher::OnConnectivityStateChange(
592
1565
  grpc_connectivity_state new_state, absl::Status status) {
593
1566
  if (policy_->health_watcher_ != this) return;
594
- if (GRPC_TRACE_FLAG_ENABLED(grpc_lb_pick_first_trace)) {
595
- gpr_log(GPR_INFO, "[PF %p] health watch state update: %s (%s)",
596
- policy_.get(), ConnectivityStateName(new_state),
597
- status.ToString().c_str());
1567
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
1568
+ LOG(INFO) << "[PF " << policy_.get() << "] health watch state update: "
1569
+ << ConnectivityStateName(new_state) << " (" << status << ")";
598
1570
  }
599
1571
  switch (new_state) {
600
1572
  case GRPC_CHANNEL_READY:
@@ -624,21 +1596,19 @@ void PickFirst::HealthWatcher::OnConnectivityStateChange(
624
1596
  }
625
1597
 
626
1598
  //
627
- // PickFirst::SubchannelList::SubchannelData
1599
+ // OldPickFirst::SubchannelList::SubchannelData
628
1600
  //
629
1601
 
630
- PickFirst::SubchannelList::SubchannelData::SubchannelData(
1602
+ OldPickFirst::SubchannelList::SubchannelData::SubchannelData(
631
1603
  SubchannelList* subchannel_list, size_t index,
632
1604
  RefCountedPtr<SubchannelInterface> subchannel)
633
1605
  : subchannel_list_(subchannel_list),
634
1606
  index_(index),
635
1607
  subchannel_(std::move(subchannel)) {
636
- if (GRPC_TRACE_FLAG_ENABLED(grpc_lb_pick_first_trace)) {
637
- gpr_log(GPR_INFO,
638
- "[PF %p] subchannel list %p index %" PRIuPTR
639
- " (subchannel %p): starting watch",
640
- subchannel_list_->policy_.get(), subchannel_list_, index_,
641
- subchannel_.get());
1608
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
1609
+ LOG(INFO) << "[PF " << subchannel_list_->policy_.get()
1610
+ << "] subchannel list " << subchannel_list_ << " index " << index_
1611
+ << " (subchannel " << subchannel_.get() << "): starting watch";
642
1612
  }
643
1613
  auto watcher = std::make_unique<Watcher>(
644
1614
  subchannel_list_->Ref(DEBUG_LOCATION, "Watcher"), index_);
@@ -646,14 +1616,14 @@ PickFirst::SubchannelList::SubchannelData::SubchannelData(
646
1616
  subchannel_->WatchConnectivityState(std::move(watcher));
647
1617
  }
648
1618
 
649
- void PickFirst::SubchannelList::SubchannelData::ShutdownLocked() {
1619
+ void OldPickFirst::SubchannelList::SubchannelData::ShutdownLocked() {
650
1620
  if (subchannel_ != nullptr) {
651
- if (GRPC_TRACE_FLAG_ENABLED(grpc_lb_pick_first_trace)) {
652
- gpr_log(GPR_INFO,
653
- "[PF %p] subchannel list %p index %" PRIuPTR " of %" PRIuPTR
654
- " (subchannel %p): cancelling watch and unreffing subchannel",
655
- subchannel_list_->policy_.get(), subchannel_list_, index_,
656
- subchannel_list_->size(), subchannel_.get());
1621
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
1622
+ LOG(INFO) << "[PF " << subchannel_list_->policy_.get()
1623
+ << "] subchannel list " << subchannel_list_ << " index "
1624
+ << index_ << " of " << subchannel_list_->size()
1625
+ << " (subchannel " << subchannel_.get()
1626
+ << "): cancelling watch and unreffing subchannel";
657
1627
  }
658
1628
  subchannel_->CancelConnectivityStateWatch(pending_watcher_);
659
1629
  pending_watcher_ = nullptr;
@@ -661,46 +1631,45 @@ void PickFirst::SubchannelList::SubchannelData::ShutdownLocked() {
661
1631
  }
662
1632
  }
663
1633
 
664
- void PickFirst::SubchannelList::SubchannelData::OnConnectivityStateChange(
1634
+ void OldPickFirst::SubchannelList::SubchannelData::OnConnectivityStateChange(
665
1635
  grpc_connectivity_state new_state, absl::Status status) {
666
- PickFirst* p = subchannel_list_->policy_.get();
667
- if (GRPC_TRACE_FLAG_ENABLED(grpc_lb_pick_first_trace)) {
668
- gpr_log(
669
- GPR_INFO,
670
- "[PF %p] subchannel list %p index %" PRIuPTR " of %" PRIuPTR
671
- " (subchannel %p): connectivity changed: old_state=%s, new_state=%s, "
672
- "status=%s, shutting_down=%d, pending_watcher=%p, "
673
- "seen_transient_failure=%d, p->selected_=%p, "
674
- "p->subchannel_list_=%p, p->latest_pending_subchannel_list_=%p",
675
- p, subchannel_list_, index_, subchannel_list_->size(),
676
- subchannel_.get(),
677
- (connectivity_state_.has_value()
678
- ? ConnectivityStateName(*connectivity_state_)
679
- : "N/A"),
680
- ConnectivityStateName(new_state), status.ToString().c_str(),
681
- subchannel_list_->shutting_down_, pending_watcher_,
682
- seen_transient_failure_, p->selected_, p->subchannel_list_.get(),
683
- p->latest_pending_subchannel_list_.get());
1636
+ OldPickFirst* p = subchannel_list_->policy_.get();
1637
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
1638
+ LOG(INFO) << "[PF " << p << "] subchannel list " << subchannel_list_
1639
+ << " index " << index_ << " of " << subchannel_list_->size()
1640
+ << " (subchannel " << subchannel_.get()
1641
+ << "): connectivity changed: old_state="
1642
+ << (connectivity_state_.has_value()
1643
+ ? ConnectivityStateName(*connectivity_state_)
1644
+ : "N/A")
1645
+ << ", new_state=" << ConnectivityStateName(new_state)
1646
+ << ", status=" << status
1647
+ << ", shutting_down=" << subchannel_list_->shutting_down_
1648
+ << ", pending_watcher=" << pending_watcher_
1649
+ << ", seen_transient_failure=" << seen_transient_failure_
1650
+ << ", p->selected_=" << p->selected_
1651
+ << ", p->subchannel_list_=" << p->subchannel_list_.get()
1652
+ << ", p->latest_pending_subchannel_list_="
1653
+ << p->latest_pending_subchannel_list_.get();
684
1654
  }
685
1655
  if (subchannel_list_->shutting_down_ || pending_watcher_ == nullptr) return;
686
- auto& stats_plugins =
687
- subchannel_list_->policy_->channel_control_helper()
688
- ->GetStatsPluginGroup();
1656
+ auto& stats_plugins = subchannel_list_->policy_->channel_control_helper()
1657
+ ->GetStatsPluginGroup();
689
1658
  // The notification must be for a subchannel in either the current or
690
1659
  // latest pending subchannel lists.
691
- GPR_ASSERT(subchannel_list_ == p->subchannel_list_.get() ||
692
- subchannel_list_ == p->latest_pending_subchannel_list_.get());
693
- GPR_ASSERT(new_state != GRPC_CHANNEL_SHUTDOWN);
1660
+ CHECK(subchannel_list_ == p->subchannel_list_.get() ||
1661
+ subchannel_list_ == p->latest_pending_subchannel_list_.get());
1662
+ CHECK(new_state != GRPC_CHANNEL_SHUTDOWN);
694
1663
  absl::optional<grpc_connectivity_state> old_state = connectivity_state_;
695
1664
  connectivity_state_ = new_state;
696
1665
  connectivity_status_ = std::move(status);
697
1666
  // Handle updates for the currently selected subchannel.
698
1667
  if (p->selected_ == this) {
699
- GPR_ASSERT(subchannel_list_ == p->subchannel_list_.get());
700
- if (GRPC_TRACE_FLAG_ENABLED(grpc_lb_pick_first_trace)) {
701
- gpr_log(GPR_INFO,
702
- "Pick First %p selected subchannel connectivity changed to %s", p,
703
- ConnectivityStateName(new_state));
1668
+ CHECK(subchannel_list_ == p->subchannel_list_.get());
1669
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
1670
+ LOG(INFO) << "Pick First " << p
1671
+ << " selected subchannel connectivity changed to "
1672
+ << ConnectivityStateName(new_state);
704
1673
  }
705
1674
  // Any state change is considered to be a failure of the existing
706
1675
  // connection.
@@ -716,12 +1685,10 @@ void PickFirst::SubchannelList::SubchannelData::OnConnectivityStateChange(
716
1685
  p->channel_control_helper()->RequestReresolution();
717
1686
  // If there is a pending update, switch to the pending update.
718
1687
  if (p->latest_pending_subchannel_list_ != nullptr) {
719
- if (GRPC_TRACE_FLAG_ENABLED(grpc_lb_pick_first_trace)) {
720
- gpr_log(GPR_INFO,
721
- "Pick First %p promoting pending subchannel list %p to "
722
- "replace %p",
723
- p, p->latest_pending_subchannel_list_.get(),
724
- p->subchannel_list_.get());
1688
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
1689
+ LOG(INFO) << "Pick First " << p << " promoting pending subchannel "
1690
+ << "list " << p->latest_pending_subchannel_list_.get()
1691
+ << " to replace " << p->subchannel_list_.get();
725
1692
  }
726
1693
  p->UnsetSelectedSubchannel();
727
1694
  p->subchannel_list_ = std::move(p->latest_pending_subchannel_list_);
@@ -869,22 +1836,22 @@ void PickFirst::SubchannelList::SubchannelData::OnConnectivityStateChange(
869
1836
  }
870
1837
  }
871
1838
 
872
- void PickFirst::SubchannelList::SubchannelData::RequestConnectionWithTimer() {
873
- GPR_ASSERT(connectivity_state_.has_value());
1839
+ void OldPickFirst::SubchannelList::SubchannelData::
1840
+ RequestConnectionWithTimer() {
1841
+ CHECK(connectivity_state_.has_value());
874
1842
  if (connectivity_state_ == GRPC_CHANNEL_IDLE) {
875
1843
  subchannel_->RequestConnection();
876
1844
  } else {
877
- GPR_ASSERT(connectivity_state_ == GRPC_CHANNEL_CONNECTING);
1845
+ CHECK(connectivity_state_ == GRPC_CHANNEL_CONNECTING);
878
1846
  }
879
1847
  // If this is not the last subchannel in the list, start the timer.
880
1848
  if (index_ != subchannel_list_->size() - 1) {
881
- PickFirst* p = subchannel_list_->policy_.get();
882
- if (GRPC_TRACE_FLAG_ENABLED(grpc_lb_pick_first_trace)) {
883
- gpr_log(GPR_INFO,
884
- "Pick First %p subchannel list %p: starting Connection "
885
- "Attempt Delay timer for %" PRId64 "ms for index %" PRIuPTR,
886
- p, subchannel_list_, p->connection_attempt_delay_.millis(),
887
- index_);
1849
+ OldPickFirst* p = subchannel_list_->policy_.get();
1850
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
1851
+ LOG(INFO) << "Pick First " << p << " subchannel list " << subchannel_list_
1852
+ << ": starting Connection Attempt Delay timer for "
1853
+ << p->connection_attempt_delay_.millis() << "ms for index "
1854
+ << index_;
888
1855
  }
889
1856
  subchannel_list_->timer_handle_ =
890
1857
  p->channel_control_helper()->GetEventEngine()->RunAfter(
@@ -896,15 +1863,14 @@ void PickFirst::SubchannelList::SubchannelData::RequestConnectionWithTimer() {
896
1863
  auto* sl = subchannel_list.get();
897
1864
  sl->policy_->work_serializer()->Run(
898
1865
  [subchannel_list = std::move(subchannel_list)]() {
899
- if (GRPC_TRACE_FLAG_ENABLED(grpc_lb_pick_first_trace)) {
900
- gpr_log(GPR_INFO,
901
- "Pick First %p subchannel list %p: Connection "
902
- "Attempt Delay timer fired (shutting_down=%d, "
903
- "selected=%p)",
904
- subchannel_list->policy_.get(),
905
- subchannel_list.get(),
906
- subchannel_list->shutting_down_,
907
- subchannel_list->policy_->selected_);
1866
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
1867
+ LOG(INFO)
1868
+ << "Pick First " << subchannel_list->policy_.get()
1869
+ << " subchannel list " << subchannel_list.get()
1870
+ << ": Connection Attempt Delay timer fired "
1871
+ << "(shutting_down="
1872
+ << subchannel_list->shutting_down_ << ", selected="
1873
+ << subchannel_list->policy_->selected_ << ")";
908
1874
  }
909
1875
  if (subchannel_list->shutting_down_) return;
910
1876
  if (subchannel_list->policy_->selected_ != nullptr) return;
@@ -916,8 +1882,9 @@ void PickFirst::SubchannelList::SubchannelData::RequestConnectionWithTimer() {
916
1882
  }
917
1883
  }
918
1884
 
919
- void PickFirst::SubchannelList::SubchannelData::ProcessUnselectedReadyLocked() {
920
- PickFirst* p = subchannel_list_->policy_.get();
1885
+ void OldPickFirst::SubchannelList::SubchannelData::
1886
+ ProcessUnselectedReadyLocked() {
1887
+ OldPickFirst* p = subchannel_list_->policy_.get();
921
1888
  // Cancel Happy Eyeballs timer, if any.
922
1889
  if (subchannel_list_->timer_handle_.has_value()) {
923
1890
  p->channel_control_helper()->GetEventEngine()->Cancel(
@@ -932,24 +1899,22 @@ void PickFirst::SubchannelList::SubchannelData::ProcessUnselectedReadyLocked() {
932
1899
  // for a subchannel in p->latest_pending_subchannel_list_. The
933
1900
  // goal here is to find a subchannel from the update that we can
934
1901
  // select in place of the current one.
935
- GPR_ASSERT(subchannel_list_ == p->subchannel_list_.get() ||
936
- subchannel_list_ == p->latest_pending_subchannel_list_.get());
1902
+ CHECK(subchannel_list_ == p->subchannel_list_.get() ||
1903
+ subchannel_list_ == p->latest_pending_subchannel_list_.get());
937
1904
  // Case 2. Promote p->latest_pending_subchannel_list_ to p->subchannel_list_.
938
1905
  if (subchannel_list_ == p->latest_pending_subchannel_list_.get()) {
939
- if (GRPC_TRACE_FLAG_ENABLED(grpc_lb_pick_first_trace)) {
940
- gpr_log(GPR_INFO,
941
- "Pick First %p promoting pending subchannel list %p to "
942
- "replace %p",
943
- p, p->latest_pending_subchannel_list_.get(),
944
- p->subchannel_list_.get());
1906
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
1907
+ LOG(INFO) << "Pick First " << p << " promoting pending subchannel list "
1908
+ << p->latest_pending_subchannel_list_.get() << " to replace "
1909
+ << p->subchannel_list_.get();
945
1910
  }
946
1911
  p->UnsetSelectedSubchannel();
947
1912
  p->subchannel_list_ = std::move(p->latest_pending_subchannel_list_);
948
1913
  }
949
1914
  // Cases 1 and 2.
950
- if (GRPC_TRACE_FLAG_ENABLED(grpc_lb_pick_first_trace)) {
951
- gpr_log(GPR_INFO, "Pick First %p selected subchannel %p", p,
952
- subchannel_.get());
1915
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
1916
+ LOG(INFO) << "Pick First " << p << " selected subchannel "
1917
+ << subchannel_.get();
953
1918
  }
954
1919
  p->selected_ = this;
955
1920
  // If health checking is enabled, start the health watch, but don't
@@ -957,11 +1922,11 @@ void PickFirst::SubchannelList::SubchannelData::ProcessUnselectedReadyLocked() {
957
1922
  // for the health status notification.
958
1923
  // If health checking is NOT enabled, report READY.
959
1924
  if (p->enable_health_watch_) {
960
- if (GRPC_TRACE_FLAG_ENABLED(grpc_lb_pick_first_trace)) {
961
- gpr_log(GPR_INFO, "[PF %p] starting health watch", p);
1925
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
1926
+ LOG(INFO) << "[PF " << p << "] starting health watch";
962
1927
  }
963
1928
  auto watcher = std::make_unique<HealthWatcher>(
964
- p->RefAsSubclass<PickFirst>(DEBUG_LOCATION, "HealthWatcher"));
1929
+ p->RefAsSubclass<OldPickFirst>(DEBUG_LOCATION, "HealthWatcher"));
965
1930
  p->health_watcher_ = watcher.get();
966
1931
  auto health_data_watcher = MakeHealthCheckWatcher(
967
1932
  p->work_serializer(), subchannel_list_->args_, std::move(watcher));
@@ -980,63 +1945,60 @@ void PickFirst::SubchannelList::SubchannelData::ProcessUnselectedReadyLocked() {
980
1945
  }
981
1946
 
982
1947
  //
983
- // PickFirst::SubchannelList
1948
+ // OldPickFirst::SubchannelList
984
1949
  //
985
1950
 
986
- PickFirst::SubchannelList::SubchannelList(RefCountedPtr<PickFirst> policy,
987
- EndpointAddressesIterator* addresses,
988
- const ChannelArgs& args)
1951
+ OldPickFirst::SubchannelList::SubchannelList(
1952
+ RefCountedPtr<OldPickFirst> policy, EndpointAddressesIterator* addresses,
1953
+ const ChannelArgs& args)
989
1954
  : InternallyRefCounted<SubchannelList>(
990
- GRPC_TRACE_FLAG_ENABLED(grpc_lb_pick_first_trace) ? "SubchannelList"
991
- : nullptr),
1955
+ GRPC_TRACE_FLAG_ENABLED(pick_first) ? "SubchannelList" : nullptr),
992
1956
  policy_(std::move(policy)),
993
1957
  args_(args.Remove(GRPC_ARG_INTERNAL_PICK_FIRST_ENABLE_HEALTH_CHECKING)
994
1958
  .Remove(
995
1959
  GRPC_ARG_INTERNAL_PICK_FIRST_OMIT_STATUS_MESSAGE_PREFIX)) {
996
- if (GRPC_TRACE_FLAG_ENABLED(grpc_lb_pick_first_trace)) {
997
- gpr_log(GPR_INFO, "[PF %p] Creating subchannel list %p - channel args: %s",
998
- policy_.get(), this, args_.ToString().c_str());
1960
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
1961
+ LOG(INFO) << "[PF " << policy_.get() << "] Creating subchannel list "
1962
+ << this << " - channel args: " << args_.ToString();
999
1963
  }
1000
1964
  if (addresses == nullptr) return;
1001
1965
  // Create a subchannel for each address.
1002
1966
  addresses->ForEach([&](const EndpointAddresses& address) {
1003
- GPR_ASSERT(address.addresses().size() == 1);
1967
+ CHECK_EQ(address.addresses().size(), 1u);
1004
1968
  RefCountedPtr<SubchannelInterface> subchannel =
1005
1969
  policy_->channel_control_helper()->CreateSubchannel(
1006
1970
  address.address(), address.args(), args_);
1007
1971
  if (subchannel == nullptr) {
1008
1972
  // Subchannel could not be created.
1009
- if (GRPC_TRACE_FLAG_ENABLED(grpc_lb_pick_first_trace)) {
1010
- gpr_log(GPR_INFO,
1011
- "[PF %p] could not create subchannel for address %s, ignoring",
1012
- policy_.get(), address.ToString().c_str());
1973
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
1974
+ LOG(INFO) << "[PF " << policy_.get()
1975
+ << "] could not create subchannel for address "
1976
+ << address.ToString() << ", ignoring";
1013
1977
  }
1014
1978
  return;
1015
1979
  }
1016
- if (GRPC_TRACE_FLAG_ENABLED(grpc_lb_pick_first_trace)) {
1017
- gpr_log(GPR_INFO,
1018
- "[PF %p] subchannel list %p index %" PRIuPTR
1019
- ": Created subchannel %p for address %s",
1020
- policy_.get(), this, subchannels_.size(), subchannel.get(),
1021
- address.ToString().c_str());
1980
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
1981
+ LOG(INFO) << "[PF " << policy_.get() << "] subchannel list " << this
1982
+ << " index " << subchannels_.size() << ": Created subchannel "
1983
+ << subchannel.get() << " for address " << address.ToString();
1022
1984
  }
1023
1985
  subchannels_.emplace_back(this, subchannels_.size(), std::move(subchannel));
1024
1986
  });
1025
1987
  }
1026
1988
 
1027
- PickFirst::SubchannelList::~SubchannelList() {
1028
- if (GRPC_TRACE_FLAG_ENABLED(grpc_lb_pick_first_trace)) {
1029
- gpr_log(GPR_INFO, "[PF %p] Destroying subchannel_list %p", policy_.get(),
1030
- this);
1989
+ OldPickFirst::SubchannelList::~SubchannelList() {
1990
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
1991
+ LOG(INFO) << "[PF " << policy_.get() << "] Destroying subchannel_list "
1992
+ << this;
1031
1993
  }
1032
1994
  }
1033
1995
 
1034
- void PickFirst::SubchannelList::Orphan() {
1035
- if (GRPC_TRACE_FLAG_ENABLED(grpc_lb_pick_first_trace)) {
1036
- gpr_log(GPR_INFO, "[PF %p] Shutting down subchannel_list %p", policy_.get(),
1037
- this);
1996
+ void OldPickFirst::SubchannelList::Orphan() {
1997
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
1998
+ LOG(INFO) << "[PF " << policy_.get() << "] Shutting down subchannel_list "
1999
+ << this;
1038
2000
  }
1039
- GPR_ASSERT(!shutting_down_);
2001
+ CHECK(!shutting_down_);
1040
2002
  shutting_down_ = true;
1041
2003
  for (auto& sd : subchannels_) {
1042
2004
  sd.ShutdownLocked();
@@ -1047,19 +2009,19 @@ void PickFirst::SubchannelList::Orphan() {
1047
2009
  Unref();
1048
2010
  }
1049
2011
 
1050
- void PickFirst::SubchannelList::ResetBackoffLocked() {
2012
+ void OldPickFirst::SubchannelList::ResetBackoffLocked() {
1051
2013
  for (auto& sd : subchannels_) {
1052
2014
  sd.ResetBackoffLocked();
1053
2015
  }
1054
2016
  }
1055
2017
 
1056
- void PickFirst::SubchannelList::StartConnectingNextSubchannel() {
2018
+ void OldPickFirst::SubchannelList::StartConnectingNextSubchannel() {
1057
2019
  // Find the next subchannel not in state TRANSIENT_FAILURE.
1058
2020
  // We skip subchannels in state TRANSIENT_FAILURE to avoid a
1059
2021
  // large recursion that could overflow the stack.
1060
2022
  for (; attempting_index_ < size(); ++attempting_index_) {
1061
2023
  SubchannelData* sc = &subchannels_[attempting_index_];
1062
- GPR_ASSERT(sc->connectivity_state().has_value());
2024
+ CHECK(sc->connectivity_state().has_value());
1063
2025
  if (sc->connectivity_state() != GRPC_CHANNEL_TRANSIENT_FAILURE) {
1064
2026
  // Found a subchannel not in TRANSIENT_FAILURE, so trigger a
1065
2027
  // connection attempt.
@@ -1072,29 +2034,26 @@ void PickFirst::SubchannelList::StartConnectingNextSubchannel() {
1072
2034
  MaybeFinishHappyEyeballsPass();
1073
2035
  }
1074
2036
 
1075
- void PickFirst::SubchannelList::MaybeFinishHappyEyeballsPass() {
2037
+ void OldPickFirst::SubchannelList::MaybeFinishHappyEyeballsPass() {
1076
2038
  // Make sure all subchannels have finished a connection attempt before
1077
2039
  // we consider the Happy Eyeballs pass complete.
1078
2040
  if (!IsHappyEyeballsPassComplete()) return;
1079
2041
  // We didn't find another subchannel not in state TRANSIENT_FAILURE,
1080
2042
  // so report TRANSIENT_FAILURE and switch to a mode in which we try to
1081
2043
  // connect to all addresses in parallel.
1082
- if (GRPC_TRACE_FLAG_ENABLED(grpc_lb_pick_first_trace)) {
1083
- gpr_log(GPR_INFO,
1084
- "Pick First %p subchannel list %p failed to connect to "
1085
- "all subchannels",
1086
- policy_.get(), this);
2044
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
2045
+ LOG(INFO) << "Pick First " << policy_.get() << " subchannel list " << this
2046
+ << " failed to connect to all subchannels";
1087
2047
  }
1088
2048
  // In case 2, swap to the new subchannel list. This means reporting
1089
2049
  // TRANSIENT_FAILURE and dropping the existing (working) connection,
1090
2050
  // but we can't ignore what the control plane has told us.
1091
2051
  if (policy_->latest_pending_subchannel_list_.get() == this) {
1092
- if (GRPC_TRACE_FLAG_ENABLED(grpc_lb_pick_first_trace)) {
1093
- gpr_log(GPR_INFO,
1094
- "Pick First %p promoting pending subchannel list %p to "
1095
- "replace %p",
1096
- policy_.get(), policy_->latest_pending_subchannel_list_.get(),
1097
- this);
2052
+ if (GRPC_TRACE_FLAG_ENABLED(pick_first)) {
2053
+ LOG(INFO) << "Pick First " << policy_.get()
2054
+ << " promoting pending subchannel list "
2055
+ << policy_->latest_pending_subchannel_list_.get()
2056
+ << " to replace " << this;
1098
2057
  }
1099
2058
  policy_->UnsetSelectedSubchannel();
1100
2059
  policy_->subchannel_list_ =
@@ -1123,7 +2082,6 @@ void PickFirst::SubchannelList::MaybeFinishHappyEyeballsPass() {
1123
2082
  }
1124
2083
  }
1125
2084
  }
1126
-
1127
2085
  //
1128
2086
  // factory
1129
2087
  //
@@ -1132,6 +2090,9 @@ class PickFirstFactory final : public LoadBalancingPolicyFactory {
1132
2090
  public:
1133
2091
  OrphanablePtr<LoadBalancingPolicy> CreateLoadBalancingPolicy(
1134
2092
  LoadBalancingPolicy::Args args) const override {
2093
+ if (!IsPickFirstNewEnabled()) {
2094
+ return MakeOrphanable<OldPickFirst>(std::move(args));
2095
+ }
1135
2096
  return MakeOrphanable<PickFirst>(std::move(args));
1136
2097
  }
1137
2098