grpc 1.64.3 → 1.71.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (3205) hide show
  1. checksums.yaml +4 -4
  2. data/Makefile +372 -376
  3. data/include/grpc/compression.h +1 -2
  4. data/include/grpc/credentials.h +2 -3
  5. data/include/grpc/event_engine/README.md +1 -1
  6. data/include/grpc/event_engine/endpoint_config.h +7 -7
  7. data/include/grpc/event_engine/event_engine.h +83 -20
  8. data/include/grpc/event_engine/extensible.h +5 -2
  9. data/include/grpc/event_engine/internal/memory_allocator_impl.h +4 -4
  10. data/include/grpc/event_engine/internal/slice_cast.h +1 -1
  11. data/include/grpc/event_engine/memory_allocator.h +3 -4
  12. data/include/grpc/event_engine/memory_request.h +19 -2
  13. data/include/grpc/event_engine/slice.h +3 -5
  14. data/include/grpc/event_engine/slice_buffer.h +6 -8
  15. data/include/grpc/grpc.h +1 -2
  16. data/include/grpc/grpc_audit_logging.h +3 -3
  17. data/include/grpc/grpc_crl_provider.h +5 -5
  18. data/include/grpc/grpc_posix.h +1 -2
  19. data/include/grpc/grpc_security.h +1 -2
  20. data/include/grpc/impl/call.h +2 -2
  21. data/include/grpc/impl/channel_arg_names.h +10 -4
  22. data/include/grpc/impl/grpc_types.h +1 -2
  23. data/include/grpc/impl/slice_type.h +1 -2
  24. data/include/grpc/module.modulemap +1 -0
  25. data/include/grpc/passive_listener.h +62 -0
  26. data/include/grpc/status.h +1 -1
  27. data/include/grpc/support/alloc.h +1 -2
  28. data/include/grpc/support/atm.h +0 -13
  29. data/include/grpc/support/json.h +17 -18
  30. data/include/grpc/support/log.h +37 -64
  31. data/include/grpc/support/metrics.h +21 -6
  32. data/include/grpc/support/port_platform.h +31 -1
  33. data/include/grpc/support/sync_generic.h +2 -4
  34. data/include/grpc/support/sync_posix.h +1 -2
  35. data/include/grpc/support/time.h +1 -2
  36. data/src/core/call/request_buffer.cc +224 -0
  37. data/src/core/call/request_buffer.h +192 -0
  38. data/src/core/channelz/channel_trace.cc +6 -7
  39. data/src/core/channelz/channel_trace.h +6 -8
  40. data/src/core/channelz/channelz.cc +10 -12
  41. data/src/core/channelz/channelz.h +18 -39
  42. data/src/core/channelz/channelz_registry.cc +10 -18
  43. data/src/core/channelz/channelz_registry.h +4 -5
  44. data/src/core/client_channel/backup_poller.cc +25 -16
  45. data/src/core/client_channel/client_channel.cc +1415 -0
  46. data/src/core/client_channel/client_channel.h +245 -0
  47. data/src/core/client_channel/client_channel_args.h +21 -0
  48. data/src/core/client_channel/client_channel_factory.cc +2 -2
  49. data/src/core/client_channel/client_channel_factory.h +1 -2
  50. data/src/core/client_channel/client_channel_filter.cc +391 -981
  51. data/src/core/client_channel/client_channel_filter.h +32 -83
  52. data/src/core/client_channel/client_channel_internal.h +23 -9
  53. data/src/core/client_channel/client_channel_plugin.cc +4 -18
  54. data/src/core/client_channel/client_channel_service_config.cc +3 -4
  55. data/src/core/client_channel/client_channel_service_config.h +12 -14
  56. data/src/core/client_channel/config_selector.h +21 -22
  57. data/src/core/client_channel/connector.h +3 -3
  58. data/src/core/client_channel/direct_channel.cc +83 -0
  59. data/src/core/client_channel/direct_channel.h +101 -0
  60. data/src/core/client_channel/dynamic_filters.cc +16 -14
  61. data/src/core/client_channel/dynamic_filters.h +9 -10
  62. data/src/core/client_channel/global_subchannel_pool.cc +2 -2
  63. data/src/core/client_channel/global_subchannel_pool.h +2 -3
  64. data/src/core/client_channel/lb_metadata.cc +119 -0
  65. data/src/core/client_channel/lb_metadata.h +55 -0
  66. data/src/core/client_channel/load_balanced_call_destination.cc +273 -0
  67. data/src/core/client_channel/load_balanced_call_destination.h +48 -0
  68. data/src/core/client_channel/local_subchannel_pool.cc +2 -5
  69. data/src/core/client_channel/local_subchannel_pool.h +1 -1
  70. data/src/core/client_channel/retry_filter.cc +9 -18
  71. data/src/core/client_channel/retry_filter.h +7 -16
  72. data/src/core/client_channel/retry_filter_legacy_call_data.cc +219 -331
  73. data/src/core/client_channel/retry_filter_legacy_call_data.h +18 -21
  74. data/src/core/client_channel/retry_interceptor.cc +408 -0
  75. data/src/core/client_channel/retry_interceptor.h +157 -0
  76. data/src/core/client_channel/retry_service_config.cc +11 -14
  77. data/src/core/client_channel/retry_service_config.h +22 -11
  78. data/src/core/client_channel/retry_throttle.cc +34 -20
  79. data/src/core/client_channel/retry_throttle.h +6 -9
  80. data/src/core/client_channel/subchannel.cc +324 -239
  81. data/src/core/client_channel/subchannel.h +52 -44
  82. data/src/core/client_channel/subchannel_interface_internal.h +1 -1
  83. data/src/core/client_channel/subchannel_pool_interface.cc +1 -5
  84. data/src/core/client_channel/subchannel_pool_interface.h +4 -7
  85. data/src/core/client_channel/subchannel_stream_client.cc +43 -60
  86. data/src/core/client_channel/subchannel_stream_client.h +13 -17
  87. data/src/core/config/config_vars.cc +152 -0
  88. data/src/core/config/config_vars.h +129 -0
  89. data/src/core/config/config_vars_non_generated.cc +49 -0
  90. data/src/core/config/core_configuration.cc +111 -0
  91. data/src/core/config/core_configuration.h +242 -0
  92. data/src/core/config/load_config.cc +78 -0
  93. data/src/core/config/load_config.h +54 -0
  94. data/src/core/ext/filters/backend_metrics/backend_metric_filter.cc +25 -37
  95. data/src/core/ext/filters/backend_metrics/backend_metric_filter.h +9 -7
  96. data/src/core/ext/filters/backend_metrics/backend_metric_provider.h +7 -0
  97. data/src/core/ext/filters/census/grpc_context.cc +7 -10
  98. data/src/core/ext/filters/channel_idle/idle_filter_state.cc +1 -2
  99. data/src/core/ext/filters/channel_idle/idle_filter_state.h +0 -1
  100. data/src/core/ext/filters/channel_idle/legacy_channel_idle_filter.cc +37 -48
  101. data/src/core/ext/filters/channel_idle/legacy_channel_idle_filter.h +12 -8
  102. data/src/core/ext/filters/fault_injection/fault_injection_filter.cc +23 -33
  103. data/src/core/ext/filters/fault_injection/fault_injection_filter.h +9 -8
  104. data/src/core/ext/filters/fault_injection/fault_injection_service_config_parser.cc +3 -4
  105. data/src/core/ext/filters/fault_injection/fault_injection_service_config_parser.h +7 -10
  106. data/src/core/ext/filters/gcp_authentication/gcp_authentication_filter.cc +198 -0
  107. data/src/core/ext/filters/gcp_authentication/gcp_authentication_filter.h +97 -0
  108. data/src/core/ext/filters/gcp_authentication/gcp_authentication_service_config_parser.cc +80 -0
  109. data/src/core/ext/filters/gcp_authentication/gcp_authentication_service_config_parser.h +86 -0
  110. data/src/core/ext/filters/http/client/http_client_filter.cc +14 -13
  111. data/src/core/ext/filters/http/client/http_client_filter.h +6 -4
  112. data/src/core/ext/filters/http/client_authority_filter.cc +14 -18
  113. data/src/core/ext/filters/http/client_authority_filter.h +8 -6
  114. data/src/core/ext/filters/http/http_filters_plugin.cc +1 -2
  115. data/src/core/ext/filters/http/message_compress/compression_filter.cc +64 -64
  116. data/src/core/ext/filters/http/message_compress/compression_filter.h +24 -15
  117. data/src/core/ext/filters/http/server/http_server_filter.cc +18 -20
  118. data/src/core/ext/filters/http/server/http_server_filter.h +6 -4
  119. data/src/core/ext/filters/message_size/message_size_filter.cc +43 -55
  120. data/src/core/ext/filters/message_size/message_size_filter.h +30 -29
  121. data/src/core/ext/filters/rbac/rbac_filter.cc +8 -18
  122. data/src/core/ext/filters/rbac/rbac_filter.h +8 -7
  123. data/src/core/ext/filters/rbac/rbac_service_config_parser.cc +19 -13
  124. data/src/core/ext/filters/rbac/rbac_service_config_parser.h +3 -5
  125. data/src/core/ext/filters/stateful_session/stateful_session_filter.cc +14 -21
  126. data/src/core/ext/filters/stateful_session/stateful_session_filter.h +8 -7
  127. data/src/core/ext/filters/stateful_session/stateful_session_service_config_parser.cc +3 -4
  128. data/src/core/ext/filters/stateful_session/stateful_session_service_config_parser.h +8 -10
  129. data/src/core/ext/transport/chttp2/alpn/alpn.cc +2 -4
  130. data/src/core/ext/transport/chttp2/alpn/alpn.h +1 -2
  131. data/src/core/ext/transport/chttp2/client/chttp2_connector.cc +76 -109
  132. data/src/core/ext/transport/chttp2/client/chttp2_connector.h +8 -13
  133. data/src/core/ext/transport/chttp2/server/chttp2_server.cc +999 -375
  134. data/src/core/ext/transport/chttp2/server/chttp2_server.h +222 -13
  135. data/src/core/ext/transport/chttp2/transport/bin_decoder.cc +22 -34
  136. data/src/core/ext/transport/chttp2/transport/bin_decoder.h +2 -3
  137. data/src/core/ext/transport/chttp2/transport/bin_encoder.cc +4 -7
  138. data/src/core/ext/transport/chttp2/transport/bin_encoder.h +1 -2
  139. data/src/core/ext/transport/chttp2/transport/call_tracer_wrapper.cc +53 -0
  140. data/src/core/ext/transport/chttp2/transport/call_tracer_wrapper.h +72 -0
  141. data/src/core/ext/transport/chttp2/transport/chttp2_transport.cc +706 -555
  142. data/src/core/ext/transport/chttp2/transport/chttp2_transport.h +22 -23
  143. data/src/core/ext/transport/chttp2/transport/context_list_entry.h +2 -3
  144. data/src/core/ext/transport/chttp2/transport/decode_huff.h +4 -4
  145. data/src/core/ext/transport/chttp2/transport/flow_control.cc +9 -14
  146. data/src/core/ext/transport/chttp2/transport/flow_control.h +5 -10
  147. data/src/core/ext/transport/chttp2/transport/frame.cc +24 -7
  148. data/src/core/ext/transport/chttp2/transport/frame.h +16 -7
  149. data/src/core/ext/transport/chttp2/transport/frame_data.cc +19 -20
  150. data/src/core/ext/transport/chttp2/transport/frame_data.h +4 -5
  151. data/src/core/ext/transport/chttp2/transport/frame_goaway.cc +11 -14
  152. data/src/core/ext/transport/chttp2/transport/frame_goaway.h +1 -2
  153. data/src/core/ext/transport/chttp2/transport/frame_ping.cc +14 -19
  154. data/src/core/ext/transport/chttp2/transport/frame_ping.h +1 -2
  155. data/src/core/ext/transport/chttp2/transport/frame_rst_stream.cc +17 -18
  156. data/src/core/ext/transport/chttp2/transport/frame_rst_stream.h +6 -5
  157. data/src/core/ext/transport/chttp2/transport/frame_security.cc +80 -0
  158. data/src/core/ext/transport/chttp2/transport/frame_security.h +44 -0
  159. data/src/core/ext/transport/chttp2/transport/frame_settings.cc +41 -25
  160. data/src/core/ext/transport/chttp2/transport/frame_settings.h +3 -4
  161. data/src/core/ext/transport/chttp2/transport/frame_window_update.cc +28 -7
  162. data/src/core/ext/transport/chttp2/transport/frame_window_update.h +4 -3
  163. data/src/core/ext/transport/chttp2/transport/hpack_constants.h +2 -2
  164. data/src/core/ext/transport/chttp2/transport/hpack_encoder.cc +19 -21
  165. data/src/core/ext/transport/chttp2/transport/hpack_encoder.h +19 -15
  166. data/src/core/ext/transport/chttp2/transport/hpack_encoder_table.cc +2 -3
  167. data/src/core/ext/transport/chttp2/transport/hpack_encoder_table.h +4 -5
  168. data/src/core/ext/transport/chttp2/transport/hpack_parse_result.cc +2 -4
  169. data/src/core/ext/transport/chttp2/transport/hpack_parse_result.h +6 -9
  170. data/src/core/ext/transport/chttp2/transport/hpack_parser.cc +55 -58
  171. data/src/core/ext/transport/chttp2/transport/hpack_parser.h +10 -13
  172. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.cc +41 -16
  173. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.h +29 -10
  174. data/src/core/ext/transport/chttp2/transport/http2_settings.cc +14 -6
  175. data/src/core/ext/transport/chttp2/transport/http2_settings.h +13 -7
  176. data/src/core/ext/transport/chttp2/transport/internal.h +86 -83
  177. data/src/core/ext/transport/chttp2/transport/legacy_frame.h +1 -0
  178. data/src/core/ext/transport/chttp2/transport/parsing.cc +135 -121
  179. data/src/core/ext/transport/chttp2/transport/ping_abuse_policy.cc +4 -4
  180. data/src/core/ext/transport/chttp2/transport/ping_abuse_policy.h +3 -3
  181. data/src/core/ext/transport/chttp2/transport/ping_callbacks.cc +4 -7
  182. data/src/core/ext/transport/chttp2/transport/ping_callbacks.h +5 -9
  183. data/src/core/ext/transport/chttp2/transport/ping_rate_policy.cc +35 -20
  184. data/src/core/ext/transport/chttp2/transport/ping_rate_policy.h +9 -10
  185. data/src/core/ext/transport/chttp2/transport/stream_lists.cc +14 -16
  186. data/src/core/ext/transport/chttp2/transport/stream_lists.h +65 -0
  187. data/src/core/ext/transport/chttp2/transport/varint.cc +6 -6
  188. data/src/core/ext/transport/chttp2/transport/varint.h +1 -3
  189. data/src/core/ext/transport/chttp2/transport/write_size_policy.cc +2 -3
  190. data/src/core/ext/transport/chttp2/transport/write_size_policy.h +3 -4
  191. data/src/core/ext/transport/chttp2/transport/writing.cc +149 -130
  192. data/src/core/ext/transport/inproc/inproc_transport.cc +151 -71
  193. data/src/core/ext/transport/inproc/inproc_transport.h +1 -3
  194. data/src/core/ext/transport/inproc/legacy_inproc_transport.cc +133 -129
  195. data/src/core/ext/transport/inproc/legacy_inproc_transport.h +0 -2
  196. data/src/core/ext/upb-gen/envoy/admin/v3/certs.upb.h +46 -15
  197. data/src/core/ext/upb-gen/envoy/admin/v3/certs.upb_minitable.c +40 -18
  198. data/src/core/ext/upb-gen/envoy/admin/v3/certs.upb_minitable.h +10 -4
  199. data/src/core/ext/upb-gen/envoy/admin/v3/clusters.upb.h +59 -27
  200. data/src/core/ext/upb-gen/envoy/admin/v3/clusters.upb_minitable.c +36 -18
  201. data/src/core/ext/upb-gen/envoy/admin/v3/clusters.upb_minitable.h +9 -4
  202. data/src/core/ext/upb-gen/envoy/admin/v3/config_dump.upb.h +50 -15
  203. data/src/core/ext/upb-gen/envoy/admin/v3/config_dump.upb_minitable.c +44 -22
  204. data/src/core/ext/upb-gen/envoy/admin/v3/config_dump.upb_minitable.h +10 -4
  205. data/src/core/ext/upb-gen/envoy/admin/v3/config_dump_shared.upb.h +190 -55
  206. data/src/core/ext/upb-gen/envoy/admin/v3/config_dump_shared.upb_minitable.c +162 -84
  207. data/src/core/ext/upb-gen/envoy/admin/v3/config_dump_shared.upb_minitable.h +24 -4
  208. data/src/core/ext/upb-gen/envoy/admin/v3/init_dump.upb.h +11 -5
  209. data/src/core/ext/upb-gen/envoy/admin/v3/init_dump.upb_minitable.c +14 -4
  210. data/src/core/ext/upb-gen/envoy/admin/v3/init_dump.upb_minitable.h +7 -4
  211. data/src/core/ext/upb-gen/envoy/admin/v3/listeners.upb.h +19 -6
  212. data/src/core/ext/upb-gen/envoy/admin/v3/listeners.upb_minitable.c +18 -8
  213. data/src/core/ext/upb-gen/envoy/admin/v3/listeners.upb_minitable.h +7 -4
  214. data/src/core/ext/upb-gen/envoy/admin/v3/memory.upb.h +11 -10
  215. data/src/core/ext/upb-gen/envoy/admin/v3/memory.upb_minitable.c +7 -1
  216. data/src/core/ext/upb-gen/envoy/admin/v3/memory.upb_minitable.h +6 -4
  217. data/src/core/ext/upb-gen/envoy/admin/v3/metrics.upb.h +8 -7
  218. data/src/core/ext/upb-gen/envoy/admin/v3/metrics.upb_minitable.c +7 -1
  219. data/src/core/ext/upb-gen/envoy/admin/v3/metrics.upb_minitable.h +6 -4
  220. data/src/core/ext/upb-gen/envoy/admin/v3/mutex_stats.upb.h +8 -7
  221. data/src/core/ext/upb-gen/envoy/admin/v3/mutex_stats.upb_minitable.c +7 -1
  222. data/src/core/ext/upb-gen/envoy/admin/v3/mutex_stats.upb_minitable.h +6 -4
  223. data/src/core/ext/upb-gen/envoy/admin/v3/server_info.upb.h +145 -82
  224. data/src/core/ext/upb-gen/envoy/admin/v3/server_info.upb_minitable.c +40 -27
  225. data/src/core/ext/upb-gen/envoy/admin/v3/server_info.upb_minitable.h +7 -4
  226. data/src/core/ext/upb-gen/envoy/admin/v3/tap.upb.h +9 -6
  227. data/src/core/ext/upb-gen/envoy/admin/v3/tap.upb_minitable.c +10 -4
  228. data/src/core/ext/upb-gen/envoy/admin/v3/tap.upb_minitable.h +6 -4
  229. data/src/core/ext/upb-gen/envoy/annotations/deprecation.upb.h +9 -8
  230. data/src/core/ext/upb-gen/envoy/annotations/deprecation.upb_minitable.c +7 -1
  231. data/src/core/ext/upb-gen/envoy/annotations/deprecation.upb_minitable.h +5 -4
  232. data/src/core/ext/upb-gen/envoy/annotations/resource.upb.h +18 -8
  233. data/src/core/ext/upb-gen/envoy/annotations/resource.upb_minitable.c +13 -6
  234. data/src/core/ext/upb-gen/envoy/annotations/resource.upb_minitable.h +6 -4
  235. data/src/core/ext/upb-gen/envoy/config/accesslog/v3/accesslog.upb.h +91 -34
  236. data/src/core/ext/upb-gen/envoy/config/accesslog/v3/accesslog.upb_minitable.c +114 -48
  237. data/src/core/ext/upb-gen/envoy/config/accesslog/v3/accesslog.upb_minitable.h +21 -4
  238. data/src/core/ext/upb-gen/envoy/config/bootstrap/v3/bootstrap.upb.h +544 -254
  239. data/src/core/ext/upb-gen/envoy/config/bootstrap/v3/bootstrap.upb_minitable.c +265 -149
  240. data/src/core/ext/upb-gen/envoy/config/bootstrap/v3/bootstrap.upb_minitable.h +29 -4
  241. data/src/core/ext/upb-gen/envoy/config/cluster/v3/circuit_breaker.upb.h +41 -14
  242. data/src/core/ext/upb-gen/envoy/config/cluster/v3/circuit_breaker.upb_minitable.c +31 -17
  243. data/src/core/ext/upb-gen/envoy/config/cluster/v3/circuit_breaker.upb_minitable.h +8 -4
  244. data/src/core/ext/upb-gen/envoy/config/cluster/v3/cluster.upb.h +529 -141
  245. data/src/core/ext/upb-gen/envoy/config/cluster/v3/cluster.upb_minitable.c +270 -143
  246. data/src/core/ext/upb-gen/envoy/config/cluster/v3/cluster.upb_minitable.h +31 -4
  247. data/src/core/ext/upb-gen/envoy/config/cluster/v3/filter.upb.h +12 -7
  248. data/src/core/ext/upb-gen/envoy/config/cluster/v3/filter.upb_minitable.c +11 -5
  249. data/src/core/ext/upb-gen/envoy/config/cluster/v3/filter.upb_minitable.h +6 -4
  250. data/src/core/ext/upb-gen/envoy/config/cluster/v3/outlier_detection.upb.h +171 -27
  251. data/src/core/ext/upb-gen/envoy/config/cluster/v3/outlier_detection.upb_minitable.c +54 -27
  252. data/src/core/ext/upb-gen/envoy/config/cluster/v3/outlier_detection.upb_minitable.h +6 -4
  253. data/src/core/ext/upb-gen/envoy/config/common/matcher/v3/matcher.upb.h +127 -35
  254. data/src/core/ext/upb-gen/envoy/config/common/matcher/v3/matcher.upb_minitable.c +125 -63
  255. data/src/core/ext/upb-gen/envoy/config/common/matcher/v3/matcher.upb_minitable.h +20 -4
  256. data/src/core/ext/upb-gen/envoy/config/core/v3/address.upb.h +67 -27
  257. data/src/core/ext/upb-gen/envoy/config/core/v3/address.upb_minitable.c +60 -26
  258. data/src/core/ext/upb-gen/envoy/config/core/v3/address.upb_minitable.h +13 -4
  259. data/src/core/ext/upb-gen/envoy/config/core/v3/backoff.upb.h +11 -6
  260. data/src/core/ext/upb-gen/envoy/config/core/v3/backoff.upb_minitable.c +11 -5
  261. data/src/core/ext/upb-gen/envoy/config/core/v3/backoff.upb_minitable.h +6 -4
  262. data/src/core/ext/upb-gen/envoy/config/core/v3/base.upb.h +871 -72
  263. data/src/core/ext/upb-gen/envoy/config/core/v3/base.upb_minitable.c +346 -75
  264. data/src/core/ext/upb-gen/envoy/config/core/v3/base.upb_minitable.h +41 -4
  265. data/src/core/ext/upb-gen/envoy/config/core/v3/config_source.upb.h +67 -25
  266. data/src/core/ext/upb-gen/envoy/config/core/v3/config_source.upb_minitable.c +57 -27
  267. data/src/core/ext/upb-gen/envoy/config/core/v3/config_source.upb_minitable.h +12 -4
  268. data/src/core/ext/upb-gen/envoy/config/core/v3/event_service_config.upb.h +8 -5
  269. data/src/core/ext/upb-gen/envoy/config/core/v3/event_service_config.upb_minitable.c +10 -4
  270. data/src/core/ext/upb-gen/envoy/config/core/v3/event_service_config.upb_minitable.h +6 -4
  271. data/src/core/ext/upb-gen/envoy/config/core/v3/extension.upb.h +9 -6
  272. data/src/core/ext/upb-gen/envoy/config/core/v3/extension.upb_minitable.c +10 -4
  273. data/src/core/ext/upb-gen/envoy/config/core/v3/extension.upb_minitable.h +6 -4
  274. data/src/core/ext/upb-gen/envoy/config/core/v3/grpc_method_list.upb.h +11 -5
  275. data/src/core/ext/upb-gen/envoy/config/core/v3/grpc_method_list.upb_minitable.c +14 -4
  276. data/src/core/ext/upb-gen/envoy/config/core/v3/grpc_method_list.upb_minitable.h +7 -4
  277. data/src/core/ext/upb-gen/envoy/config/core/v3/grpc_service.upb.h +201 -62
  278. data/src/core/ext/upb-gen/envoy/config/core/v3/grpc_service.upb_minitable.c +120 -53
  279. data/src/core/ext/upb-gen/envoy/config/core/v3/grpc_service.upb_minitable.h +19 -4
  280. data/src/core/ext/upb-gen/envoy/config/core/v3/health_check.upb.h +196 -62
  281. data/src/core/ext/upb-gen/envoy/config/core/v3/health_check.upb_minitable.c +95 -53
  282. data/src/core/ext/upb-gen/envoy/config/core/v3/health_check.upb_minitable.h +14 -4
  283. data/src/core/ext/upb-gen/envoy/config/core/v3/http_service.upb.h +13 -5
  284. data/src/core/ext/upb-gen/envoy/config/core/v3/http_service.upb_minitable.c +11 -5
  285. data/src/core/ext/upb-gen/envoy/config/core/v3/http_service.upb_minitable.h +6 -4
  286. data/src/core/ext/upb-gen/envoy/config/core/v3/http_uri.upb.h +10 -7
  287. data/src/core/ext/upb-gen/envoy/config/core/v3/http_uri.upb_minitable.c +10 -4
  288. data/src/core/ext/upb-gen/envoy/config/core/v3/http_uri.upb_minitable.h +6 -4
  289. data/src/core/ext/upb-gen/envoy/config/core/v3/protocol.upb.h +322 -76
  290. data/src/core/ext/upb-gen/envoy/config/core/v3/protocol.upb_minitable.c +162 -84
  291. data/src/core/ext/upb-gen/envoy/config/core/v3/protocol.upb_minitable.h +21 -4
  292. data/src/core/ext/upb-gen/envoy/config/core/v3/proxy_protocol.upb.h +10 -7
  293. data/src/core/ext/upb-gen/envoy/config/core/v3/proxy_protocol.upb_minitable.c +14 -4
  294. data/src/core/ext/upb-gen/envoy/config/core/v3/proxy_protocol.upb_minitable.h +7 -4
  295. data/src/core/ext/upb-gen/envoy/config/core/v3/resolver.upb.h +15 -7
  296. data/src/core/ext/upb-gen/envoy/config/core/v3/resolver.upb_minitable.c +15 -5
  297. data/src/core/ext/upb-gen/envoy/config/core/v3/resolver.upb_minitable.h +7 -4
  298. data/src/core/ext/upb-gen/envoy/config/core/v3/socket_cmsg_headers.upb.h +151 -0
  299. data/src/core/ext/upb-gen/envoy/config/core/v3/socket_cmsg_headers.upb_minitable.c +60 -0
  300. data/src/core/ext/upb-gen/envoy/config/core/v3/socket_cmsg_headers.upb_minitable.h +32 -0
  301. data/src/core/ext/upb-gen/envoy/config/core/v3/socket_option.upb.h +244 -31
  302. data/src/core/ext/upb-gen/envoy/config/core/v3/socket_option.upb_minitable.c +79 -21
  303. data/src/core/ext/upb-gen/envoy/config/core/v3/socket_option.upb_minitable.h +13 -4
  304. data/src/core/ext/upb-gen/envoy/config/core/v3/substitution_format_string.upb.h +23 -11
  305. data/src/core/ext/upb-gen/envoy/config/core/v3/substitution_format_string.upb_minitable.c +17 -7
  306. data/src/core/ext/upb-gen/envoy/config/core/v3/substitution_format_string.upb_minitable.h +7 -4
  307. data/src/core/ext/upb-gen/envoy/config/core/v3/udp_socket_config.upb.h +11 -6
  308. data/src/core/ext/upb-gen/envoy/config/core/v3/udp_socket_config.upb_minitable.c +11 -5
  309. data/src/core/ext/upb-gen/envoy/config/core/v3/udp_socket_config.upb_minitable.h +6 -4
  310. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/endpoint.upb.h +42 -11
  311. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/endpoint.upb_minitable.c +35 -17
  312. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/endpoint.upb_minitable.h +9 -4
  313. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/endpoint_components.upb.h +106 -34
  314. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/endpoint_components.upb_minitable.c +69 -37
  315. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/endpoint_components.upb_minitable.h +12 -4
  316. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/load_report.upb.h +281 -37
  317. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/load_report.upb_minitable.c +81 -27
  318. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/load_report.upb_minitable.h +12 -4
  319. data/src/core/ext/upb-gen/envoy/config/listener/v3/api_listener.upb.h +8 -5
  320. data/src/core/ext/upb-gen/envoy/config/listener/v3/api_listener.upb_minitable.c +10 -4
  321. data/src/core/ext/upb-gen/envoy/config/listener/v3/api_listener.upb_minitable.h +6 -4
  322. data/src/core/ext/upb-gen/envoy/config/listener/v3/listener.upb.h +142 -47
  323. data/src/core/ext/upb-gen/envoy/config/listener/v3/listener.upb_minitable.c +90 -47
  324. data/src/core/ext/upb-gen/envoy/config/listener/v3/listener.upb_minitable.h +15 -4
  325. data/src/core/ext/upb-gen/envoy/config/listener/v3/listener_components.upb.h +92 -129
  326. data/src/core/ext/upb-gen/envoy/config/listener/v3/listener_components.upb_minitable.c +66 -57
  327. data/src/core/ext/upb-gen/envoy/config/listener/v3/listener_components.upb_minitable.h +11 -5
  328. data/src/core/ext/upb-gen/envoy/config/listener/v3/quic_config.upb.h +178 -13
  329. data/src/core/ext/upb-gen/envoy/config/listener/v3/quic_config.upb_minitable.c +46 -14
  330. data/src/core/ext/upb-gen/envoy/config/listener/v3/quic_config.upb_minitable.h +6 -4
  331. data/src/core/ext/upb-gen/envoy/config/listener/v3/udp_listener_config.upb.h +14 -7
  332. data/src/core/ext/upb-gen/envoy/config/listener/v3/udp_listener_config.upb_minitable.c +16 -6
  333. data/src/core/ext/upb-gen/envoy/config/listener/v3/udp_listener_config.upb_minitable.h +7 -4
  334. data/src/core/ext/upb-gen/envoy/config/metrics/v3/metrics_service.upb.h +14 -9
  335. data/src/core/ext/upb-gen/envoy/config/metrics/v3/metrics_service.upb_minitable.c +11 -5
  336. data/src/core/ext/upb-gen/envoy/config/metrics/v3/metrics_service.upb_minitable.h +6 -4
  337. data/src/core/ext/upb-gen/envoy/config/metrics/v3/stats.upb.h +51 -22
  338. data/src/core/ext/upb-gen/envoy/config/metrics/v3/stats.upb_minitable.c +58 -24
  339. data/src/core/ext/upb-gen/envoy/config/metrics/v3/stats.upb_minitable.h +13 -4
  340. data/src/core/ext/upb-gen/envoy/config/overload/v3/overload.upb.h +70 -22
  341. data/src/core/ext/upb-gen/envoy/config/overload/v3/overload.upb_minitable.c +71 -29
  342. data/src/core/ext/upb-gen/envoy/config/overload/v3/overload.upb_minitable.h +15 -4
  343. data/src/core/ext/upb-gen/envoy/config/rbac/v3/rbac.upb.h +311 -38
  344. data/src/core/ext/upb-gen/envoy/config/rbac/v3/rbac.upb_minitable.c +141 -63
  345. data/src/core/ext/upb-gen/envoy/config/rbac/v3/rbac.upb_minitable.h +18 -4
  346. data/src/core/ext/upb-gen/envoy/config/route/v3/route.upb.h +61 -13
  347. data/src/core/ext/upb-gen/envoy/config/route/v3/route.upb_minitable.c +33 -19
  348. data/src/core/ext/upb-gen/envoy/config/route/v3/route.upb_minitable.h +8 -4
  349. data/src/core/ext/upb-gen/envoy/config/route/v3/route_components.upb.h +961 -237
  350. data/src/core/ext/upb-gen/envoy/config/route/v3/route_components.upb_minitable.c +567 -273
  351. data/src/core/ext/upb-gen/envoy/config/route/v3/route_components.upb_minitable.h +67 -4
  352. data/src/core/ext/upb-gen/envoy/config/route/v3/scoped_route.upb.h +20 -10
  353. data/src/core/ext/upb-gen/envoy/config/route/v3/scoped_route.upb_minitable.c +22 -8
  354. data/src/core/ext/upb-gen/envoy/config/route/v3/scoped_route.upb_minitable.h +8 -4
  355. data/src/core/ext/upb-gen/envoy/config/tap/v3/common.upb.h +100 -35
  356. data/src/core/ext/upb-gen/envoy/config/tap/v3/common.upb_minitable.c +95 -45
  357. data/src/core/ext/upb-gen/envoy/config/tap/v3/common.upb_minitable.h +17 -4
  358. data/src/core/ext/upb-gen/envoy/config/trace/v3/datadog.upb.h +118 -16
  359. data/src/core/ext/upb-gen/envoy/config/trace/v3/datadog.upb_minitable.c +43 -12
  360. data/src/core/ext/upb-gen/envoy/config/trace/v3/datadog.upb_minitable.h +8 -4
  361. data/src/core/ext/upb-gen/envoy/config/trace/v3/dynamic_ot.upb.h +9 -6
  362. data/src/core/ext/upb-gen/envoy/config/trace/v3/dynamic_ot.upb_minitable.c +10 -4
  363. data/src/core/ext/upb-gen/envoy/config/trace/v3/dynamic_ot.upb_minitable.h +6 -4
  364. data/src/core/ext/upb-gen/envoy/config/trace/v3/http_tracer.upb.h +12 -7
  365. data/src/core/ext/upb-gen/envoy/config/trace/v3/http_tracer.upb_minitable.c +17 -7
  366. data/src/core/ext/upb-gen/envoy/config/trace/v3/http_tracer.upb_minitable.h +7 -4
  367. data/src/core/ext/upb-gen/envoy/config/trace/v3/lightstep.upb.h +10 -7
  368. data/src/core/ext/upb-gen/envoy/config/trace/v3/lightstep.upb_minitable.c +10 -4
  369. data/src/core/ext/upb-gen/envoy/config/trace/v3/lightstep.upb_minitable.h +6 -4
  370. data/src/core/ext/upb-gen/envoy/config/trace/v3/opentelemetry.upb.h +20 -8
  371. data/src/core/ext/upb-gen/envoy/config/trace/v3/opentelemetry.upb_minitable.c +13 -7
  372. data/src/core/ext/upb-gen/envoy/config/trace/v3/opentelemetry.upb_minitable.h +6 -4
  373. data/src/core/ext/upb-gen/envoy/config/trace/v3/service.upb.h +8 -5
  374. data/src/core/ext/upb-gen/envoy/config/trace/v3/service.upb_minitable.c +10 -4
  375. data/src/core/ext/upb-gen/envoy/config/trace/v3/service.upb_minitable.h +6 -4
  376. data/src/core/ext/upb-gen/envoy/config/trace/v3/skywalking.upb.h +17 -10
  377. data/src/core/ext/upb-gen/envoy/config/trace/v3/skywalking.upb_minitable.c +18 -8
  378. data/src/core/ext/upb-gen/envoy/config/trace/v3/skywalking.upb_minitable.h +7 -4
  379. data/src/core/ext/upb-gen/envoy/config/trace/v3/trace.upb.h +5 -6
  380. data/src/core/ext/upb-gen/envoy/config/trace/v3/trace.upb_minitable.c +3 -2
  381. data/src/core/ext/upb-gen/envoy/config/trace/v3/trace.upb_minitable.h +5 -5
  382. data/src/core/ext/upb-gen/envoy/config/trace/v3/xray.upb.h +19 -10
  383. data/src/core/ext/upb-gen/envoy/config/trace/v3/xray.upb_minitable.c +19 -9
  384. data/src/core/ext/upb-gen/envoy/config/trace/v3/xray.upb_minitable.h +7 -4
  385. data/src/core/ext/upb-gen/envoy/config/trace/v3/zipkin.upb.h +14 -11
  386. data/src/core/ext/upb-gen/envoy/config/trace/v3/zipkin.upb_minitable.c +10 -4
  387. data/src/core/ext/upb-gen/envoy/config/trace/v3/zipkin.upb_minitable.h +6 -4
  388. data/src/core/ext/upb-gen/envoy/data/accesslog/v3/accesslog.upb.h +216 -102
  389. data/src/core/ext/upb-gen/envoy/data/accesslog/v3/accesslog.upb_minitable.c +124 -57
  390. data/src/core/ext/upb-gen/envoy/data/accesslog/v3/accesslog.upb_minitable.h +21 -4
  391. data/src/core/ext/upb-gen/envoy/extensions/clusters/aggregate/v3/cluster.upb.h +5 -4
  392. data/src/core/ext/upb-gen/envoy/extensions/clusters/aggregate/v3/cluster.upb_minitable.c +7 -1
  393. data/src/core/ext/upb-gen/envoy/extensions/clusters/aggregate/v3/cluster.upb_minitable.h +6 -4
  394. data/src/core/ext/upb-gen/envoy/extensions/filters/common/fault/v3/fault.upb.h +24 -11
  395. data/src/core/ext/upb-gen/envoy/extensions/filters/common/fault/v3/fault.upb_minitable.c +33 -11
  396. data/src/core/ext/upb-gen/envoy/extensions/filters/common/fault/v3/fault.upb_minitable.h +10 -4
  397. data/src/core/ext/upb-gen/envoy/extensions/filters/http/fault/v3/fault.upb.h +42 -22
  398. data/src/core/ext/upb-gen/envoy/extensions/filters/http/fault/v3/fault.upb_minitable.c +27 -13
  399. data/src/core/ext/upb-gen/envoy/extensions/filters/http/fault/v3/fault.upb_minitable.h +8 -4
  400. data/src/core/ext/upb-gen/envoy/extensions/filters/http/gcp_authn/v3/gcp_authn.upb.h +444 -0
  401. data/src/core/ext/upb-gen/envoy/extensions/filters/http/gcp_authn/v3/gcp_authn.upb_minitable.c +135 -0
  402. data/src/core/ext/upb-gen/envoy/extensions/filters/http/gcp_authn/v3/gcp_authn.upb_minitable.h +38 -0
  403. data/src/core/ext/upb-gen/envoy/extensions/filters/http/rbac/v3/rbac.upb.h +56 -13
  404. data/src/core/ext/upb-gen/envoy/extensions/filters/http/rbac/v3/rbac.upb_minitable.c +29 -13
  405. data/src/core/ext/upb-gen/envoy/extensions/filters/http/rbac/v3/rbac.upb_minitable.h +7 -4
  406. data/src/core/ext/upb-gen/envoy/extensions/filters/http/router/v3/router.upb.h +29 -12
  407. data/src/core/ext/upb-gen/envoy/extensions/filters/http/router/v3/router.upb_minitable.c +20 -10
  408. data/src/core/ext/upb-gen/envoy/extensions/filters/http/router/v3/router.upb_minitable.h +7 -4
  409. data/src/core/ext/upb-gen/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upb.h +13 -8
  410. data/src/core/ext/upb-gen/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upb_minitable.c +17 -7
  411. data/src/core/ext/upb-gen/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upb_minitable.h +7 -4
  412. data/src/core/ext/upb-gen/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.h +343 -134
  413. data/src/core/ext/upb-gen/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb_minitable.c +209 -121
  414. data/src/core/ext/upb-gen/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb_minitable.h +26 -4
  415. data/src/core/ext/upb-gen/envoy/extensions/http/stateful_session/cookie/v3/cookie.upb.h +8 -5
  416. data/src/core/ext/upb-gen/envoy/extensions/http/stateful_session/cookie/v3/cookie.upb_minitable.c +10 -4
  417. data/src/core/ext/upb-gen/envoy/extensions/http/stateful_session/cookie/v3/cookie.upb_minitable.h +6 -4
  418. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/client_side_weighted_round_robin/v3/client_side_weighted_round_robin.upb.h +83 -10
  419. 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 +28 -11
  420. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/client_side_weighted_round_robin/v3/client_side_weighted_round_robin.upb_minitable.h +6 -4
  421. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/common/v3/common.upb.h +31 -14
  422. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/common/v3/common.upb_minitable.c +39 -17
  423. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/common/v3/common.upb_minitable.h +10 -4
  424. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/pick_first/v3/pick_first.upb.h +6 -5
  425. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/pick_first/v3/pick_first.upb_minitable.c +7 -1
  426. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/pick_first/v3/pick_first.upb_minitable.h +6 -4
  427. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/ring_hash/v3/ring_hash.upb.h +22 -11
  428. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/ring_hash/v3/ring_hash.upb_minitable.c +14 -8
  429. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/ring_hash/v3/ring_hash.upb_minitable.h +6 -4
  430. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/wrr_locality/v3/wrr_locality.upb.h +8 -5
  431. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/wrr_locality/v3/wrr_locality.upb_minitable.c +10 -4
  432. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/wrr_locality/v3/wrr_locality.upb_minitable.h +6 -4
  433. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/http_11_proxy/v3/upstream_http_11_connect.upb.h +105 -0
  434. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/http_11_proxy/v3/upstream_http_11_connect.upb_minitable.c +51 -0
  435. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/http_11_proxy/v3/upstream_http_11_connect.upb_minitable.h +32 -0
  436. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/cert.upb.h +5 -4
  437. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/cert.upb_minitable.c +3 -1
  438. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/cert.upb_minitable.h +5 -4
  439. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/common.upb.h +170 -31
  440. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/common.upb_minitable.c +83 -37
  441. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/common.upb_minitable.h +14 -4
  442. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/secret.upb.h +25 -12
  443. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/secret.upb_minitable.c +27 -13
  444. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/secret.upb_minitable.h +8 -4
  445. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/tls.upb.h +214 -63
  446. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/tls.upb_minitable.c +100 -61
  447. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/tls.upb_minitable.h +12 -4
  448. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upb.h +51 -13
  449. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upb_minitable.c +23 -11
  450. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upb_minitable.h +7 -4
  451. data/src/core/ext/upb-gen/envoy/extensions/upstreams/http/v3/http_protocol_options.upb.h +58 -20
  452. data/src/core/ext/upb-gen/envoy/extensions/upstreams/http/v3/http_protocol_options.upb_minitable.c +44 -26
  453. data/src/core/ext/upb-gen/envoy/extensions/upstreams/http/v3/http_protocol_options.upb_minitable.h +9 -4
  454. data/src/core/ext/upb-gen/envoy/service/discovery/v3/ads.upb.h +5 -4
  455. data/src/core/ext/upb-gen/envoy/service/discovery/v3/ads.upb_minitable.c +7 -1
  456. data/src/core/ext/upb-gen/envoy/service/discovery/v3/ads.upb_minitable.h +6 -4
  457. data/src/core/ext/upb-gen/envoy/service/discovery/v3/discovery.upb.h +373 -58
  458. data/src/core/ext/upb-gen/envoy/service/discovery/v3/discovery.upb_minitable.c +144 -61
  459. data/src/core/ext/upb-gen/envoy/service/discovery/v3/discovery.upb_minitable.h +21 -4
  460. data/src/core/ext/upb-gen/envoy/service/load_stats/v3/lrs.upb.h +18 -8
  461. data/src/core/ext/upb-gen/envoy/service/load_stats/v3/lrs.upb_minitable.c +18 -8
  462. data/src/core/ext/upb-gen/envoy/service/load_stats/v3/lrs.upb_minitable.h +7 -4
  463. data/src/core/ext/upb-gen/envoy/service/status/v3/csds.upb.h +67 -25
  464. data/src/core/ext/upb-gen/envoy/service/status/v3/csds.upb_minitable.c +47 -25
  465. data/src/core/ext/upb-gen/envoy/service/status/v3/csds.upb_minitable.h +10 -4
  466. data/src/core/ext/upb-gen/envoy/type/http/v3/cookie.upb.h +10 -7
  467. data/src/core/ext/upb-gen/envoy/type/http/v3/cookie.upb_minitable.c +10 -4
  468. data/src/core/ext/upb-gen/envoy/type/http/v3/cookie.upb_minitable.h +6 -4
  469. data/src/core/ext/upb-gen/envoy/type/http/v3/path_transformation.upb.h +16 -6
  470. data/src/core/ext/upb-gen/envoy/type/http/v3/path_transformation.upb_minitable.c +26 -8
  471. data/src/core/ext/upb-gen/envoy/type/http/v3/path_transformation.upb_minitable.h +9 -4
  472. data/src/core/ext/upb-gen/envoy/type/matcher/v3/address.upb.h +142 -0
  473. data/src/core/ext/upb-gen/envoy/type/matcher/v3/address.upb_minitable.c +55 -0
  474. data/src/core/ext/upb-gen/envoy/type/matcher/v3/address.upb_minitable.h +32 -0
  475. data/src/core/ext/upb-gen/envoy/type/matcher/v3/filter_state.upb.h +42 -6
  476. data/src/core/ext/upb-gen/envoy/type/matcher/v3/filter_state.upb_minitable.c +16 -7
  477. data/src/core/ext/upb-gen/envoy/type/matcher/v3/filter_state.upb_minitable.h +6 -4
  478. data/src/core/ext/upb-gen/envoy/type/matcher/v3/http_inputs.upb.h +10 -9
  479. data/src/core/ext/upb-gen/envoy/type/matcher/v3/http_inputs.upb_minitable.c +23 -1
  480. data/src/core/ext/upb-gen/envoy/type/matcher/v3/http_inputs.upb_minitable.h +10 -4
  481. data/src/core/ext/upb-gen/envoy/type/matcher/v3/metadata.upb.h +16 -8
  482. data/src/core/ext/upb-gen/envoy/type/matcher/v3/metadata.upb_minitable.c +15 -5
  483. data/src/core/ext/upb-gen/envoy/type/matcher/v3/metadata.upb_minitable.h +7 -4
  484. data/src/core/ext/upb-gen/envoy/type/matcher/v3/node.upb.h +13 -5
  485. data/src/core/ext/upb-gen/envoy/type/matcher/v3/node.upb_minitable.c +11 -5
  486. data/src/core/ext/upb-gen/envoy/type/matcher/v3/node.upb_minitable.h +6 -4
  487. data/src/core/ext/upb-gen/envoy/type/matcher/v3/number.upb.h +9 -6
  488. data/src/core/ext/upb-gen/envoy/type/matcher/v3/number.upb_minitable.c +10 -4
  489. data/src/core/ext/upb-gen/envoy/type/matcher/v3/number.upb_minitable.h +6 -4
  490. data/src/core/ext/upb-gen/envoy/type/matcher/v3/path.upb.h +8 -5
  491. data/src/core/ext/upb-gen/envoy/type/matcher/v3/path.upb_minitable.c +10 -4
  492. data/src/core/ext/upb-gen/envoy/type/matcher/v3/path.upb_minitable.h +6 -4
  493. data/src/core/ext/upb-gen/envoy/type/matcher/v3/regex.upb.h +16 -9
  494. data/src/core/ext/upb-gen/envoy/type/matcher/v3/regex.upb_minitable.c +24 -10
  495. data/src/core/ext/upb-gen/envoy/type/matcher/v3/regex.upb_minitable.h +8 -4
  496. data/src/core/ext/upb-gen/envoy/type/matcher/v3/status_code_input.upb.h +5 -4
  497. data/src/core/ext/upb-gen/envoy/type/matcher/v3/status_code_input.upb_minitable.c +11 -1
  498. data/src/core/ext/upb-gen/envoy/type/matcher/v3/status_code_input.upb_minitable.h +7 -4
  499. data/src/core/ext/upb-gen/envoy/type/matcher/v3/string.upb.h +51 -10
  500. data/src/core/ext/upb-gen/envoy/type/matcher/v3/string.upb_minitable.c +30 -9
  501. data/src/core/ext/upb-gen/envoy/type/matcher/v3/string.upb_minitable.h +7 -4
  502. data/src/core/ext/upb-gen/envoy/type/matcher/v3/struct.upb.h +14 -6
  503. data/src/core/ext/upb-gen/envoy/type/matcher/v3/struct.upb_minitable.c +15 -5
  504. data/src/core/ext/upb-gen/envoy/type/matcher/v3/struct.upb_minitable.h +7 -4
  505. data/src/core/ext/upb-gen/envoy/type/matcher/v3/value.upb.h +30 -12
  506. data/src/core/ext/upb-gen/envoy/type/matcher/v3/value.upb_minitable.c +32 -14
  507. data/src/core/ext/upb-gen/envoy/type/matcher/v3/value.upb_minitable.h +9 -4
  508. data/src/core/ext/upb-gen/envoy/type/metadata/v3/metadata.upb.h +24 -10
  509. data/src/core/ext/upb-gen/envoy/type/metadata/v3/metadata.upb_minitable.c +40 -10
  510. data/src/core/ext/upb-gen/envoy/type/metadata/v3/metadata.upb_minitable.h +12 -4
  511. data/src/core/ext/upb-gen/envoy/type/tracing/v3/custom_tag.upb.h +30 -17
  512. data/src/core/ext/upb-gen/envoy/type/tracing/v3/custom_tag.upb_minitable.c +33 -11
  513. data/src/core/ext/upb-gen/envoy/type/tracing/v3/custom_tag.upb_minitable.h +10 -4
  514. data/src/core/ext/upb-gen/envoy/type/v3/hash_policy.upb.h +12 -7
  515. data/src/core/ext/upb-gen/envoy/type/v3/hash_policy.upb_minitable.c +19 -5
  516. data/src/core/ext/upb-gen/envoy/type/v3/hash_policy.upb_minitable.h +8 -4
  517. data/src/core/ext/upb-gen/envoy/type/v3/http.upb.h +5 -4
  518. data/src/core/ext/upb-gen/envoy/type/v3/http.upb_minitable.c +3 -1
  519. data/src/core/ext/upb-gen/envoy/type/v3/http.upb_minitable.h +5 -4
  520. data/src/core/ext/upb-gen/envoy/type/v3/http_status.upb.h +6 -5
  521. data/src/core/ext/upb-gen/envoy/type/v3/http_status.upb_minitable.c +7 -1
  522. data/src/core/ext/upb-gen/envoy/type/v3/http_status.upb_minitable.h +6 -4
  523. data/src/core/ext/upb-gen/envoy/type/v3/percent.upb.h +8 -7
  524. data/src/core/ext/upb-gen/envoy/type/v3/percent.upb_minitable.c +11 -1
  525. data/src/core/ext/upb-gen/envoy/type/v3/percent.upb_minitable.h +7 -4
  526. data/src/core/ext/upb-gen/envoy/type/v3/range.upb.h +11 -10
  527. data/src/core/ext/upb-gen/envoy/type/v3/range.upb_minitable.c +15 -1
  528. data/src/core/ext/upb-gen/envoy/type/v3/range.upb_minitable.h +8 -4
  529. data/src/core/ext/upb-gen/envoy/type/v3/ratelimit_strategy.upb.h +14 -9
  530. data/src/core/ext/upb-gen/envoy/type/v3/ratelimit_strategy.upb_minitable.c +15 -5
  531. data/src/core/ext/upb-gen/envoy/type/v3/ratelimit_strategy.upb_minitable.h +7 -4
  532. data/src/core/ext/upb-gen/envoy/type/v3/ratelimit_unit.upb.h +5 -4
  533. data/src/core/ext/upb-gen/envoy/type/v3/ratelimit_unit.upb_minitable.c +3 -1
  534. data/src/core/ext/upb-gen/envoy/type/v3/ratelimit_unit.upb_minitable.h +5 -4
  535. data/src/core/ext/upb-gen/envoy/type/v3/semantic_version.upb.h +8 -7
  536. data/src/core/ext/upb-gen/envoy/type/v3/semantic_version.upb_minitable.c +7 -1
  537. data/src/core/ext/upb-gen/envoy/type/v3/semantic_version.upb_minitable.h +6 -4
  538. data/src/core/ext/upb-gen/envoy/type/v3/token_bucket.upb.h +12 -7
  539. data/src/core/ext/upb-gen/envoy/type/v3/token_bucket.upb_minitable.c +11 -5
  540. data/src/core/ext/upb-gen/envoy/type/v3/token_bucket.upb_minitable.h +6 -4
  541. data/src/core/ext/upb-gen/google/api/annotations.upb.h +17 -7
  542. data/src/core/ext/upb-gen/google/api/annotations.upb_minitable.c +5 -2
  543. data/src/core/ext/upb-gen/google/api/annotations.upb_minitable.h +5 -4
  544. data/src/core/ext/upb-gen/google/api/expr/v1alpha1/checked.upb.h +135 -36
  545. data/src/core/ext/upb-gen/google/api/expr/v1alpha1/checked.upb_minitable.c +121 -56
  546. data/src/core/ext/upb-gen/google/api/expr/v1alpha1/checked.upb_minitable.h +18 -4
  547. data/src/core/ext/upb-gen/google/api/expr/v1alpha1/syntax.upb.h +525 -69
  548. data/src/core/ext/upb-gen/google/api/expr/v1alpha1/syntax.upb_minitable.c +202 -68
  549. data/src/core/ext/upb-gen/google/api/expr/v1alpha1/syntax.upb_minitable.h +23 -4
  550. data/src/core/ext/upb-gen/google/api/http.upb.h +30 -16
  551. data/src/core/ext/upb-gen/google/api/http.upb_minitable.c +22 -8
  552. data/src/core/ext/upb-gen/google/api/http.upb_minitable.h +8 -4
  553. data/src/core/ext/upb-gen/google/api/httpbody.upb.h +12 -6
  554. data/src/core/ext/upb-gen/google/api/httpbody.upb_minitable.c +10 -4
  555. data/src/core/ext/upb-gen/google/api/httpbody.upb_minitable.h +6 -4
  556. data/src/core/ext/upb-gen/google/protobuf/any.upb.h +8 -6
  557. data/src/core/ext/upb-gen/google/protobuf/any.upb_minitable.c +7 -1
  558. data/src/core/ext/upb-gen/google/protobuf/any.upb_minitable.h +6 -4
  559. data/src/core/ext/upb-gen/google/protobuf/descriptor.upb.h +583 -181
  560. data/src/core/ext/upb-gen/google/protobuf/descriptor.upb_minitable.c +376 -215
  561. data/src/core/ext/upb-gen/google/protobuf/descriptor.upb_minitable.h +56 -21
  562. data/src/core/ext/upb-gen/google/protobuf/duration.upb.h +8 -6
  563. data/src/core/ext/upb-gen/google/protobuf/duration.upb_minitable.c +7 -1
  564. data/src/core/ext/upb-gen/google/protobuf/duration.upb_minitable.h +6 -4
  565. data/src/core/ext/upb-gen/google/protobuf/empty.upb.h +6 -4
  566. data/src/core/ext/upb-gen/google/protobuf/empty.upb_minitable.c +7 -1
  567. data/src/core/ext/upb-gen/google/protobuf/empty.upb_minitable.h +6 -4
  568. data/src/core/ext/upb-gen/google/protobuf/struct.upb.h +33 -10
  569. data/src/core/ext/upb-gen/google/protobuf/struct.upb_minitable.c +32 -14
  570. data/src/core/ext/upb-gen/google/protobuf/struct.upb_minitable.h +9 -4
  571. data/src/core/ext/upb-gen/google/protobuf/timestamp.upb.h +8 -6
  572. data/src/core/ext/upb-gen/google/protobuf/timestamp.upb_minitable.c +7 -1
  573. data/src/core/ext/upb-gen/google/protobuf/timestamp.upb_minitable.h +6 -4
  574. data/src/core/ext/upb-gen/google/protobuf/wrappers.upb.h +15 -13
  575. data/src/core/ext/upb-gen/google/protobuf/wrappers.upb_minitable.c +39 -1
  576. data/src/core/ext/upb-gen/google/protobuf/wrappers.upb_minitable.h +14 -4
  577. data/src/core/ext/upb-gen/google/rpc/status.upb.h +12 -6
  578. data/src/core/ext/upb-gen/google/rpc/status.upb_minitable.c +10 -4
  579. data/src/core/ext/upb-gen/google/rpc/status.upb_minitable.h +6 -4
  580. data/src/core/ext/upb-gen/src/proto/grpc/gcp/altscontext.upb.h +19 -10
  581. data/src/core/ext/upb-gen/src/proto/grpc/gcp/altscontext.upb_minitable.c +15 -5
  582. data/src/core/ext/upb-gen/src/proto/grpc/gcp/altscontext.upb_minitable.h +7 -4
  583. data/src/core/ext/upb-gen/src/proto/grpc/gcp/handshaker.upb.h +98 -39
  584. data/src/core/ext/upb-gen/src/proto/grpc/gcp/handshaker.upb_minitable.c +87 -37
  585. data/src/core/ext/upb-gen/src/proto/grpc/gcp/handshaker.upb_minitable.h +17 -4
  586. data/src/core/ext/upb-gen/src/proto/grpc/gcp/transport_security_common.upb.h +14 -8
  587. data/src/core/ext/upb-gen/src/proto/grpc/gcp/transport_security_common.upb_minitable.c +15 -5
  588. data/src/core/ext/upb-gen/src/proto/grpc/gcp/transport_security_common.upb_minitable.h +7 -4
  589. data/src/core/ext/upb-gen/src/proto/grpc/health/v1/health.upb.h +8 -6
  590. data/src/core/ext/upb-gen/src/proto/grpc/health/v1/health.upb_minitable.c +11 -1
  591. data/src/core/ext/upb-gen/src/proto/grpc/health/v1/health.upb_minitable.h +7 -4
  592. data/src/core/ext/upb-gen/src/proto/grpc/lb/v1/load_balancer.upb.h +47 -22
  593. data/src/core/ext/upb-gen/src/proto/grpc/lb/v1/load_balancer.upb_minitable.c +58 -20
  594. data/src/core/ext/upb-gen/src/proto/grpc/lb/v1/load_balancer.upb_minitable.h +14 -4
  595. data/src/core/ext/upb-gen/src/proto/grpc/lookup/v1/rls.upb.h +16 -8
  596. data/src/core/ext/upb-gen/src/proto/grpc/lookup/v1/rls.upb_minitable.c +18 -4
  597. data/src/core/ext/upb-gen/src/proto/grpc/lookup/v1/rls.upb_minitable.h +8 -4
  598. data/src/core/ext/upb-gen/src/proto/grpc/lookup/v1/rls_config.upb.h +72 -19
  599. data/src/core/ext/upb-gen/src/proto/grpc/lookup/v1/rls_config.upb_minitable.c +60 -22
  600. data/src/core/ext/upb-gen/src/proto/grpc/lookup/v1/rls_config.upb_minitable.h +14 -4
  601. data/src/core/ext/upb-gen/udpa/annotations/migrate.upb.h +69 -23
  602. data/src/core/ext/upb-gen/udpa/annotations/migrate.upb_minitable.c +31 -12
  603. data/src/core/ext/upb-gen/udpa/annotations/migrate.upb_minitable.h +8 -4
  604. data/src/core/ext/upb-gen/udpa/annotations/security.upb.h +19 -9
  605. data/src/core/ext/upb-gen/udpa/annotations/security.upb_minitable.c +13 -6
  606. data/src/core/ext/upb-gen/udpa/annotations/security.upb_minitable.h +6 -4
  607. data/src/core/ext/upb-gen/udpa/annotations/sensitive.upb.h +6 -5
  608. data/src/core/ext/upb-gen/udpa/annotations/sensitive.upb_minitable.c +4 -1
  609. data/src/core/ext/upb-gen/udpa/annotations/sensitive.upb_minitable.h +5 -4
  610. data/src/core/ext/upb-gen/udpa/annotations/status.upb.h +19 -9
  611. data/src/core/ext/upb-gen/udpa/annotations/status.upb_minitable.c +13 -6
  612. data/src/core/ext/upb-gen/udpa/annotations/status.upb_minitable.h +6 -4
  613. data/src/core/ext/upb-gen/udpa/annotations/versioning.upb.h +18 -8
  614. data/src/core/ext/upb-gen/udpa/annotations/versioning.upb_minitable.c +13 -6
  615. data/src/core/ext/upb-gen/udpa/annotations/versioning.upb_minitable.h +6 -4
  616. data/src/core/ext/upb-gen/validate/validate.upb.h +264 -172
  617. data/src/core/ext/upb-gen/validate/validate.upb_minitable.c +185 -87
  618. data/src/core/ext/upb-gen/validate/validate.upb_minitable.h +29 -5
  619. data/src/core/ext/upb-gen/xds/annotations/v3/migrate.upb.h +69 -23
  620. data/src/core/ext/upb-gen/xds/annotations/v3/migrate.upb_minitable.c +31 -12
  621. data/src/core/ext/upb-gen/xds/annotations/v3/migrate.upb_minitable.h +8 -4
  622. data/src/core/ext/upb-gen/xds/annotations/v3/security.upb.h +19 -9
  623. data/src/core/ext/upb-gen/xds/annotations/v3/security.upb_minitable.c +13 -6
  624. data/src/core/ext/upb-gen/xds/annotations/v3/security.upb_minitable.h +6 -4
  625. data/src/core/ext/upb-gen/xds/annotations/v3/sensitive.upb.h +6 -5
  626. data/src/core/ext/upb-gen/xds/annotations/v3/sensitive.upb_minitable.c +4 -1
  627. data/src/core/ext/upb-gen/xds/annotations/v3/sensitive.upb_minitable.h +5 -4
  628. data/src/core/ext/upb-gen/xds/annotations/v3/status.upb.h +46 -18
  629. data/src/core/ext/upb-gen/xds/annotations/v3/status.upb_minitable.c +32 -11
  630. data/src/core/ext/upb-gen/xds/annotations/v3/status.upb_minitable.h +9 -4
  631. data/src/core/ext/upb-gen/xds/annotations/v3/versioning.upb.h +18 -8
  632. data/src/core/ext/upb-gen/xds/annotations/v3/versioning.upb_minitable.c +13 -6
  633. data/src/core/ext/upb-gen/xds/annotations/v3/versioning.upb_minitable.h +6 -4
  634. data/src/core/ext/upb-gen/xds/core/v3/authority.upb.h +6 -5
  635. data/src/core/ext/upb-gen/xds/core/v3/authority.upb_minitable.c +7 -1
  636. data/src/core/ext/upb-gen/xds/core/v3/authority.upb_minitable.h +6 -4
  637. data/src/core/ext/upb-gen/xds/core/v3/cidr.upb.h +9 -6
  638. data/src/core/ext/upb-gen/xds/core/v3/cidr.upb_minitable.c +10 -4
  639. data/src/core/ext/upb-gen/xds/core/v3/cidr.upb_minitable.h +6 -4
  640. data/src/core/ext/upb-gen/xds/core/v3/collection_entry.upb.h +16 -9
  641. data/src/core/ext/upb-gen/xds/core/v3/collection_entry.upb_minitable.c +18 -8
  642. data/src/core/ext/upb-gen/xds/core/v3/collection_entry.upb_minitable.h +7 -4
  643. data/src/core/ext/upb-gen/xds/core/v3/context_params.upb.h +11 -4
  644. data/src/core/ext/upb-gen/xds/core/v3/context_params.upb_minitable.c +14 -4
  645. data/src/core/ext/upb-gen/xds/core/v3/context_params.upb_minitable.h +7 -4
  646. data/src/core/ext/upb-gen/xds/core/v3/extension.upb.h +9 -6
  647. data/src/core/ext/upb-gen/xds/core/v3/extension.upb_minitable.c +10 -4
  648. data/src/core/ext/upb-gen/xds/core/v3/extension.upb_minitable.h +6 -4
  649. data/src/core/ext/upb-gen/xds/core/v3/resource.upb.h +12 -7
  650. data/src/core/ext/upb-gen/xds/core/v3/resource.upb_minitable.c +11 -5
  651. data/src/core/ext/upb-gen/xds/core/v3/resource.upb_minitable.h +6 -4
  652. data/src/core/ext/upb-gen/xds/core/v3/resource_locator.upb.h +21 -11
  653. data/src/core/ext/upb-gen/xds/core/v3/resource_locator.upb_minitable.c +18 -8
  654. data/src/core/ext/upb-gen/xds/core/v3/resource_locator.upb_minitable.h +7 -4
  655. data/src/core/ext/upb-gen/xds/core/v3/resource_name.upb.h +11 -8
  656. data/src/core/ext/upb-gen/xds/core/v3/resource_name.upb_minitable.c +10 -4
  657. data/src/core/ext/upb-gen/xds/core/v3/resource_name.upb_minitable.h +6 -4
  658. data/src/core/ext/upb-gen/xds/data/orca/v3/orca_load_report.upb.h +29 -10
  659. data/src/core/ext/upb-gen/xds/data/orca/v3/orca_load_report.upb_minitable.c +24 -6
  660. data/src/core/ext/upb-gen/xds/data/orca/v3/orca_load_report.upb_minitable.h +9 -4
  661. data/src/core/ext/upb-gen/xds/service/orca/v3/orca.upb.h +8 -5
  662. data/src/core/ext/upb-gen/xds/service/orca/v3/orca.upb_minitable.c +10 -4
  663. data/src/core/ext/upb-gen/xds/service/orca/v3/orca.upb_minitable.h +6 -4
  664. data/src/core/ext/upb-gen/xds/type/matcher/v3/cel.upb.h +9 -6
  665. data/src/core/ext/upb-gen/xds/type/matcher/v3/cel.upb_minitable.c +10 -4
  666. data/src/core/ext/upb-gen/xds/type/matcher/v3/cel.upb_minitable.h +6 -4
  667. data/src/core/ext/upb-gen/xds/type/matcher/v3/domain.upb.h +13 -5
  668. data/src/core/ext/upb-gen/xds/type/matcher/v3/domain.upb_minitable.c +17 -7
  669. data/src/core/ext/upb-gen/xds/type/matcher/v3/domain.upb_minitable.h +7 -4
  670. data/src/core/ext/upb-gen/xds/type/matcher/v3/http_inputs.upb.h +5 -4
  671. data/src/core/ext/upb-gen/xds/type/matcher/v3/http_inputs.upb_minitable.c +7 -1
  672. data/src/core/ext/upb-gen/xds/type/matcher/v3/http_inputs.upb_minitable.h +6 -4
  673. data/src/core/ext/upb-gen/xds/type/matcher/v3/ip.upb.h +19 -6
  674. data/src/core/ext/upb-gen/xds/type/matcher/v3/ip.upb_minitable.c +18 -8
  675. data/src/core/ext/upb-gen/xds/type/matcher/v3/ip.upb_minitable.h +7 -4
  676. data/src/core/ext/upb-gen/xds/type/matcher/v3/matcher.upb.h +81 -22
  677. data/src/core/ext/upb-gen/xds/type/matcher/v3/matcher.upb_minitable.c +85 -43
  678. data/src/core/ext/upb-gen/xds/type/matcher/v3/matcher.upb_minitable.h +15 -4
  679. data/src/core/ext/upb-gen/xds/type/matcher/v3/range.upb.h +44 -7
  680. data/src/core/ext/upb-gen/xds/type/matcher/v3/range.upb_minitable.c +48 -22
  681. data/src/core/ext/upb-gen/xds/type/matcher/v3/range.upb_minitable.h +11 -4
  682. data/src/core/ext/upb-gen/xds/type/matcher/v3/regex.upb.h +9 -6
  683. data/src/core/ext/upb-gen/xds/type/matcher/v3/regex.upb_minitable.c +14 -4
  684. data/src/core/ext/upb-gen/xds/type/matcher/v3/regex.upb_minitable.h +7 -4
  685. data/src/core/ext/upb-gen/xds/type/matcher/v3/string.upb.h +18 -10
  686. data/src/core/ext/upb-gen/xds/type/matcher/v3/string.upb_minitable.c +17 -7
  687. data/src/core/ext/upb-gen/xds/type/matcher/v3/string.upb_minitable.h +7 -4
  688. data/src/core/ext/upb-gen/xds/type/v3/cel.upb.h +17 -8
  689. data/src/core/ext/upb-gen/xds/type/v3/cel.upb_minitable.c +19 -9
  690. data/src/core/ext/upb-gen/xds/type/v3/cel.upb_minitable.h +7 -4
  691. data/src/core/ext/upb-gen/xds/type/v3/range.upb.h +12 -10
  692. data/src/core/ext/upb-gen/xds/type/v3/range.upb_minitable.c +15 -1
  693. data/src/core/ext/upb-gen/xds/type/v3/range.upb_minitable.h +8 -4
  694. data/src/core/ext/upb-gen/xds/type/v3/typed_struct.upb.h +9 -6
  695. data/src/core/ext/upb-gen/xds/type/v3/typed_struct.upb_minitable.c +10 -4
  696. data/src/core/ext/upb-gen/xds/type/v3/typed_struct.upb_minitable.h +6 -4
  697. data/src/core/ext/upbdefs-gen/envoy/admin/v3/certs.upbdefs.c +2 -1
  698. data/src/core/ext/upbdefs-gen/envoy/admin/v3/certs.upbdefs.h +5 -4
  699. data/src/core/ext/upbdefs-gen/envoy/admin/v3/clusters.upbdefs.c +2 -1
  700. data/src/core/ext/upbdefs-gen/envoy/admin/v3/clusters.upbdefs.h +5 -4
  701. data/src/core/ext/upbdefs-gen/envoy/admin/v3/config_dump.upbdefs.c +2 -1
  702. data/src/core/ext/upbdefs-gen/envoy/admin/v3/config_dump.upbdefs.h +5 -4
  703. data/src/core/ext/upbdefs-gen/envoy/admin/v3/config_dump_shared.upbdefs.c +13 -11
  704. data/src/core/ext/upbdefs-gen/envoy/admin/v3/config_dump_shared.upbdefs.h +5 -4
  705. data/src/core/ext/upbdefs-gen/envoy/admin/v3/init_dump.upbdefs.c +2 -1
  706. data/src/core/ext/upbdefs-gen/envoy/admin/v3/init_dump.upbdefs.h +5 -4
  707. data/src/core/ext/upbdefs-gen/envoy/admin/v3/listeners.upbdefs.c +2 -1
  708. data/src/core/ext/upbdefs-gen/envoy/admin/v3/listeners.upbdefs.h +5 -4
  709. data/src/core/ext/upbdefs-gen/envoy/admin/v3/memory.upbdefs.c +2 -1
  710. data/src/core/ext/upbdefs-gen/envoy/admin/v3/memory.upbdefs.h +5 -4
  711. data/src/core/ext/upbdefs-gen/envoy/admin/v3/metrics.upbdefs.c +2 -1
  712. data/src/core/ext/upbdefs-gen/envoy/admin/v3/metrics.upbdefs.h +5 -4
  713. data/src/core/ext/upbdefs-gen/envoy/admin/v3/mutex_stats.upbdefs.c +2 -1
  714. data/src/core/ext/upbdefs-gen/envoy/admin/v3/mutex_stats.upbdefs.h +5 -4
  715. data/src/core/ext/upbdefs-gen/envoy/admin/v3/server_info.upbdefs.c +90 -82
  716. data/src/core/ext/upbdefs-gen/envoy/admin/v3/server_info.upbdefs.h +5 -4
  717. data/src/core/ext/upbdefs-gen/envoy/admin/v3/tap.upbdefs.c +2 -1
  718. data/src/core/ext/upbdefs-gen/envoy/admin/v3/tap.upbdefs.h +5 -4
  719. data/src/core/ext/upbdefs-gen/envoy/annotations/deprecation.upbdefs.c +2 -1
  720. data/src/core/ext/upbdefs-gen/envoy/annotations/deprecation.upbdefs.h +5 -4
  721. data/src/core/ext/upbdefs-gen/envoy/annotations/resource.upbdefs.c +2 -1
  722. data/src/core/ext/upbdefs-gen/envoy/annotations/resource.upbdefs.h +5 -4
  723. data/src/core/ext/upbdefs-gen/envoy/config/accesslog/v3/accesslog.upbdefs.c +63 -61
  724. data/src/core/ext/upbdefs-gen/envoy/config/accesslog/v3/accesslog.upbdefs.h +5 -4
  725. data/src/core/ext/upbdefs-gen/envoy/config/bootstrap/v3/bootstrap.upbdefs.c +223 -211
  726. data/src/core/ext/upbdefs-gen/envoy/config/bootstrap/v3/bootstrap.upbdefs.h +10 -4
  727. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/circuit_breaker.upbdefs.c +2 -1
  728. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/circuit_breaker.upbdefs.h +5 -4
  729. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/cluster.upbdefs.c +419 -393
  730. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/cluster.upbdefs.h +10 -4
  731. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/filter.upbdefs.c +2 -1
  732. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/filter.upbdefs.h +5 -4
  733. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/outlier_detection.upbdefs.c +116 -106
  734. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/outlier_detection.upbdefs.h +5 -4
  735. data/src/core/ext/upbdefs-gen/envoy/config/common/matcher/v3/matcher.upbdefs.c +2 -1
  736. data/src/core/ext/upbdefs-gen/envoy/config/common/matcher/v3/matcher.upbdefs.h +5 -4
  737. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/address.upbdefs.c +2 -1
  738. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/address.upbdefs.h +5 -4
  739. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/backoff.upbdefs.c +2 -1
  740. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/backoff.upbdefs.h +5 -4
  741. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/base.upbdefs.c +201 -147
  742. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/base.upbdefs.h +35 -4
  743. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/config_source.upbdefs.c +12 -12
  744. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/config_source.upbdefs.h +5 -4
  745. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/event_service_config.upbdefs.c +2 -1
  746. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/event_service_config.upbdefs.h +5 -4
  747. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/extension.upbdefs.c +2 -1
  748. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/extension.upbdefs.h +5 -4
  749. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/grpc_method_list.upbdefs.c +2 -1
  750. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/grpc_method_list.upbdefs.h +5 -4
  751. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/grpc_service.upbdefs.c +175 -165
  752. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/grpc_service.upbdefs.h +5 -4
  753. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/health_check.upbdefs.c +199 -188
  754. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/health_check.upbdefs.h +5 -4
  755. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/http_service.upbdefs.c +2 -1
  756. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/http_service.upbdefs.h +5 -4
  757. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/http_uri.upbdefs.c +2 -1
  758. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/http_uri.upbdefs.h +5 -4
  759. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/protocol.upbdefs.c +272 -255
  760. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/protocol.upbdefs.h +5 -4
  761. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/proxy_protocol.upbdefs.c +2 -1
  762. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/proxy_protocol.upbdefs.h +5 -4
  763. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/resolver.upbdefs.c +2 -1
  764. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/resolver.upbdefs.h +5 -4
  765. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/socket_cmsg_headers.upbdefs.c +46 -0
  766. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/socket_cmsg_headers.upbdefs.h +33 -0
  767. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/socket_option.upbdefs.c +31 -20
  768. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/socket_option.upbdefs.h +20 -4
  769. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/substitution_format_string.upbdefs.c +2 -1
  770. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/substitution_format_string.upbdefs.h +5 -4
  771. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/udp_socket_config.upbdefs.c +2 -1
  772. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/udp_socket_config.upbdefs.h +5 -4
  773. data/src/core/ext/upbdefs-gen/envoy/config/endpoint/v3/endpoint.upbdefs.c +2 -1
  774. data/src/core/ext/upbdefs-gen/envoy/config/endpoint/v3/endpoint.upbdefs.h +5 -4
  775. data/src/core/ext/upbdefs-gen/envoy/config/endpoint/v3/endpoint_components.upbdefs.c +41 -37
  776. data/src/core/ext/upbdefs-gen/envoy/config/endpoint/v3/endpoint_components.upbdefs.h +5 -4
  777. data/src/core/ext/upbdefs-gen/envoy/config/endpoint/v3/load_report.upbdefs.c +124 -94
  778. data/src/core/ext/upbdefs-gen/envoy/config/endpoint/v3/load_report.upbdefs.h +10 -4
  779. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/api_listener.upbdefs.c +2 -1
  780. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/api_listener.upbdefs.h +5 -4
  781. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/listener.upbdefs.c +43 -40
  782. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/listener.upbdefs.h +5 -4
  783. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/listener_components.upbdefs.c +60 -66
  784. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/listener_components.upbdefs.h +5 -9
  785. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/quic_config.upbdefs.c +75 -56
  786. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/quic_config.upbdefs.h +5 -4
  787. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/udp_listener_config.upbdefs.c +2 -1
  788. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/udp_listener_config.upbdefs.h +5 -4
  789. data/src/core/ext/upbdefs-gen/envoy/config/metrics/v3/metrics_service.upbdefs.c +2 -1
  790. data/src/core/ext/upbdefs-gen/envoy/config/metrics/v3/metrics_service.upbdefs.h +5 -4
  791. data/src/core/ext/upbdefs-gen/envoy/config/metrics/v3/stats.upbdefs.c +2 -1
  792. data/src/core/ext/upbdefs-gen/envoy/config/metrics/v3/stats.upbdefs.h +5 -4
  793. data/src/core/ext/upbdefs-gen/envoy/config/overload/v3/overload.upbdefs.c +51 -49
  794. data/src/core/ext/upbdefs-gen/envoy/config/overload/v3/overload.upbdefs.h +5 -4
  795. data/src/core/ext/upbdefs-gen/envoy/config/rbac/v3/rbac.upbdefs.c +119 -97
  796. data/src/core/ext/upbdefs-gen/envoy/config/rbac/v3/rbac.upbdefs.h +10 -4
  797. data/src/core/ext/upbdefs-gen/envoy/config/route/v3/route.upbdefs.c +2 -1
  798. data/src/core/ext/upbdefs-gen/envoy/config/route/v3/route.upbdefs.h +5 -4
  799. data/src/core/ext/upbdefs-gen/envoy/config/route/v3/route_components.upbdefs.c +922 -895
  800. data/src/core/ext/upbdefs-gen/envoy/config/route/v3/route_components.upbdefs.h +15 -4
  801. data/src/core/ext/upbdefs-gen/envoy/config/route/v3/scoped_route.upbdefs.c +2 -1
  802. data/src/core/ext/upbdefs-gen/envoy/config/route/v3/scoped_route.upbdefs.h +5 -4
  803. data/src/core/ext/upbdefs-gen/envoy/config/tap/v3/common.upbdefs.c +2 -1
  804. data/src/core/ext/upbdefs-gen/envoy/config/tap/v3/common.upbdefs.h +5 -4
  805. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/datadog.upbdefs.c +32 -21
  806. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/datadog.upbdefs.h +10 -4
  807. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/dynamic_ot.upbdefs.c +20 -18
  808. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/dynamic_ot.upbdefs.h +5 -4
  809. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/http_tracer.upbdefs.c +2 -1
  810. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/http_tracer.upbdefs.h +5 -4
  811. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/lightstep.upbdefs.c +2 -1
  812. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/lightstep.upbdefs.h +5 -4
  813. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/opentelemetry.upbdefs.c +2 -1
  814. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/opentelemetry.upbdefs.h +5 -4
  815. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/service.upbdefs.c +2 -1
  816. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/service.upbdefs.h +5 -4
  817. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/skywalking.upbdefs.c +2 -1
  818. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/skywalking.upbdefs.h +5 -4
  819. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/trace.upbdefs.c +17 -19
  820. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/trace.upbdefs.h +5 -4
  821. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/xray.upbdefs.c +2 -1
  822. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/xray.upbdefs.h +5 -4
  823. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/zipkin.upbdefs.c +23 -21
  824. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/zipkin.upbdefs.h +5 -4
  825. data/src/core/ext/upbdefs-gen/envoy/data/accesslog/v3/accesslog.upbdefs.c +147 -143
  826. data/src/core/ext/upbdefs-gen/envoy/data/accesslog/v3/accesslog.upbdefs.h +5 -4
  827. data/src/core/ext/upbdefs-gen/envoy/extensions/clusters/aggregate/v3/cluster.upbdefs.c +2 -1
  828. data/src/core/ext/upbdefs-gen/envoy/extensions/clusters/aggregate/v3/cluster.upbdefs.h +5 -4
  829. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/common/fault/v3/fault.upbdefs.c +2 -1
  830. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/common/fault/v3/fault.upbdefs.h +5 -4
  831. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/fault/v3/fault.upbdefs.c +2 -1
  832. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/fault/v3/fault.upbdefs.h +5 -4
  833. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/gcp_authn/v3/gcp_authn.upbdefs.c +87 -0
  834. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/gcp_authn/v3/gcp_authn.upbdefs.h +48 -0
  835. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/rbac/v3/rbac.upbdefs.c +38 -34
  836. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/rbac/v3/rbac.upbdefs.h +5 -4
  837. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/router/v3/router.upbdefs.c +2 -1
  838. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/router/v3/router.upbdefs.h +5 -4
  839. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upbdefs.c +2 -1
  840. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upbdefs.h +5 -4
  841. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.c +465 -459
  842. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.h +5 -4
  843. data/src/core/ext/upbdefs-gen/envoy/extensions/http/stateful_session/cookie/v3/cookie.upbdefs.c +2 -1
  844. data/src/core/ext/upbdefs-gen/envoy/extensions/http/stateful_session/cookie/v3/cookie.upbdefs.h +5 -4
  845. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/http_11_proxy/v3/upstream_http_11_connect.upbdefs.c +50 -0
  846. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/http_11_proxy/v3/upstream_http_11_connect.upbdefs.h +33 -0
  847. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/cert.upbdefs.c +2 -1
  848. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/cert.upbdefs.h +5 -4
  849. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.c +96 -88
  850. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.h +10 -4
  851. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/secret.upbdefs.c +2 -1
  852. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/secret.upbdefs.h +5 -4
  853. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/tls.upbdefs.c +204 -192
  854. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/tls.upbdefs.h +5 -4
  855. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upbdefs.c +21 -18
  856. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upbdefs.h +5 -4
  857. data/src/core/ext/upbdefs-gen/envoy/extensions/upstreams/http/v3/http_protocol_options.upbdefs.c +2 -1
  858. data/src/core/ext/upbdefs-gen/envoy/extensions/upstreams/http/v3/http_protocol_options.upbdefs.h +5 -4
  859. data/src/core/ext/upbdefs-gen/envoy/service/discovery/v3/ads.upbdefs.c +2 -1
  860. data/src/core/ext/upbdefs-gen/envoy/service/discovery/v3/ads.upbdefs.h +5 -4
  861. data/src/core/ext/upbdefs-gen/envoy/service/discovery/v3/discovery.upbdefs.c +150 -136
  862. data/src/core/ext/upbdefs-gen/envoy/service/discovery/v3/discovery.upbdefs.h +10 -4
  863. data/src/core/ext/upbdefs-gen/envoy/service/load_stats/v3/lrs.upbdefs.c +2 -1
  864. data/src/core/ext/upbdefs-gen/envoy/service/load_stats/v3/lrs.upbdefs.h +5 -4
  865. data/src/core/ext/upbdefs-gen/envoy/service/status/v3/csds.upbdefs.c +25 -23
  866. data/src/core/ext/upbdefs-gen/envoy/service/status/v3/csds.upbdefs.h +5 -4
  867. data/src/core/ext/upbdefs-gen/envoy/type/http/v3/cookie.upbdefs.c +2 -1
  868. data/src/core/ext/upbdefs-gen/envoy/type/http/v3/cookie.upbdefs.h +5 -4
  869. data/src/core/ext/upbdefs-gen/envoy/type/http/v3/path_transformation.upbdefs.c +2 -1
  870. data/src/core/ext/upbdefs-gen/envoy/type/http/v3/path_transformation.upbdefs.h +5 -4
  871. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/address.upbdefs.c +41 -0
  872. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/address.upbdefs.h +33 -0
  873. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/filter_state.upbdefs.c +28 -20
  874. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/filter_state.upbdefs.h +5 -4
  875. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/http_inputs.upbdefs.c +2 -1
  876. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/http_inputs.upbdefs.h +5 -4
  877. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/metadata.upbdefs.c +2 -1
  878. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/metadata.upbdefs.h +5 -4
  879. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/node.upbdefs.c +2 -1
  880. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/node.upbdefs.h +5 -4
  881. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/number.upbdefs.c +2 -1
  882. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/number.upbdefs.h +5 -4
  883. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/path.upbdefs.c +2 -1
  884. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/path.upbdefs.h +5 -4
  885. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/regex.upbdefs.c +2 -1
  886. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/regex.upbdefs.h +5 -4
  887. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/status_code_input.upbdefs.c +2 -1
  888. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/status_code_input.upbdefs.h +5 -4
  889. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/string.upbdefs.c +41 -34
  890. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/string.upbdefs.h +5 -4
  891. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/struct.upbdefs.c +2 -1
  892. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/struct.upbdefs.h +5 -4
  893. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/value.upbdefs.c +2 -1
  894. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/value.upbdefs.h +5 -4
  895. data/src/core/ext/upbdefs-gen/envoy/type/metadata/v3/metadata.upbdefs.c +2 -1
  896. data/src/core/ext/upbdefs-gen/envoy/type/metadata/v3/metadata.upbdefs.h +5 -4
  897. data/src/core/ext/upbdefs-gen/envoy/type/tracing/v3/custom_tag.upbdefs.c +2 -1
  898. data/src/core/ext/upbdefs-gen/envoy/type/tracing/v3/custom_tag.upbdefs.h +5 -4
  899. data/src/core/ext/upbdefs-gen/envoy/type/v3/hash_policy.upbdefs.c +2 -1
  900. data/src/core/ext/upbdefs-gen/envoy/type/v3/hash_policy.upbdefs.h +5 -4
  901. data/src/core/ext/upbdefs-gen/envoy/type/v3/http.upbdefs.c +2 -1
  902. data/src/core/ext/upbdefs-gen/envoy/type/v3/http.upbdefs.h +5 -4
  903. data/src/core/ext/upbdefs-gen/envoy/type/v3/http_status.upbdefs.c +2 -1
  904. data/src/core/ext/upbdefs-gen/envoy/type/v3/http_status.upbdefs.h +5 -4
  905. data/src/core/ext/upbdefs-gen/envoy/type/v3/percent.upbdefs.c +2 -1
  906. data/src/core/ext/upbdefs-gen/envoy/type/v3/percent.upbdefs.h +5 -4
  907. data/src/core/ext/upbdefs-gen/envoy/type/v3/range.upbdefs.c +2 -1
  908. data/src/core/ext/upbdefs-gen/envoy/type/v3/range.upbdefs.h +5 -4
  909. data/src/core/ext/upbdefs-gen/envoy/type/v3/ratelimit_strategy.upbdefs.c +2 -1
  910. data/src/core/ext/upbdefs-gen/envoy/type/v3/ratelimit_strategy.upbdefs.h +5 -4
  911. data/src/core/ext/upbdefs-gen/envoy/type/v3/ratelimit_unit.upbdefs.c +2 -1
  912. data/src/core/ext/upbdefs-gen/envoy/type/v3/ratelimit_unit.upbdefs.h +5 -4
  913. data/src/core/ext/upbdefs-gen/envoy/type/v3/semantic_version.upbdefs.c +2 -1
  914. data/src/core/ext/upbdefs-gen/envoy/type/v3/semantic_version.upbdefs.h +5 -4
  915. data/src/core/ext/upbdefs-gen/envoy/type/v3/token_bucket.upbdefs.c +2 -1
  916. data/src/core/ext/upbdefs-gen/envoy/type/v3/token_bucket.upbdefs.h +5 -4
  917. data/src/core/ext/upbdefs-gen/google/api/annotations.upbdefs.c +2 -1
  918. data/src/core/ext/upbdefs-gen/google/api/annotations.upbdefs.h +5 -4
  919. data/src/core/ext/upbdefs-gen/google/api/expr/v1alpha1/checked.upbdefs.c +110 -108
  920. data/src/core/ext/upbdefs-gen/google/api/expr/v1alpha1/checked.upbdefs.h +5 -4
  921. data/src/core/ext/upbdefs-gen/google/api/expr/v1alpha1/syntax.upbdefs.c +103 -79
  922. data/src/core/ext/upbdefs-gen/google/api/expr/v1alpha1/syntax.upbdefs.h +15 -4
  923. data/src/core/ext/upbdefs-gen/google/api/http.upbdefs.c +2 -1
  924. data/src/core/ext/upbdefs-gen/google/api/http.upbdefs.h +5 -4
  925. data/src/core/ext/upbdefs-gen/google/api/httpbody.upbdefs.c +2 -1
  926. data/src/core/ext/upbdefs-gen/google/api/httpbody.upbdefs.h +5 -4
  927. data/src/core/ext/upbdefs-gen/google/protobuf/any.upbdefs.c +2 -1
  928. data/src/core/ext/upbdefs-gen/google/protobuf/any.upbdefs.h +5 -4
  929. data/src/core/ext/upbdefs-gen/google/protobuf/descriptor.upbdefs.c +485 -458
  930. data/src/core/ext/upbdefs-gen/google/protobuf/descriptor.upbdefs.h +10 -4
  931. data/src/core/ext/upbdefs-gen/google/protobuf/duration.upbdefs.c +2 -1
  932. data/src/core/ext/upbdefs-gen/google/protobuf/duration.upbdefs.h +5 -4
  933. data/src/core/ext/upbdefs-gen/google/protobuf/empty.upbdefs.c +2 -1
  934. data/src/core/ext/upbdefs-gen/google/protobuf/empty.upbdefs.h +5 -4
  935. data/src/core/ext/upbdefs-gen/google/protobuf/struct.upbdefs.c +2 -1
  936. data/src/core/ext/upbdefs-gen/google/protobuf/struct.upbdefs.h +5 -4
  937. data/src/core/ext/upbdefs-gen/google/protobuf/timestamp.upbdefs.c +2 -1
  938. data/src/core/ext/upbdefs-gen/google/protobuf/timestamp.upbdefs.h +5 -4
  939. data/src/core/ext/upbdefs-gen/google/protobuf/wrappers.upbdefs.c +2 -1
  940. data/src/core/ext/upbdefs-gen/google/protobuf/wrappers.upbdefs.h +5 -4
  941. data/src/core/ext/upbdefs-gen/google/rpc/status.upbdefs.c +2 -1
  942. data/src/core/ext/upbdefs-gen/google/rpc/status.upbdefs.h +5 -4
  943. data/src/core/ext/upbdefs-gen/src/proto/grpc/lookup/v1/rls_config.upbdefs.c +2 -1
  944. data/src/core/ext/upbdefs-gen/src/proto/grpc/lookup/v1/rls_config.upbdefs.h +5 -4
  945. data/src/core/ext/upbdefs-gen/udpa/annotations/migrate.upbdefs.c +2 -1
  946. data/src/core/ext/upbdefs-gen/udpa/annotations/migrate.upbdefs.h +5 -4
  947. data/src/core/ext/upbdefs-gen/udpa/annotations/security.upbdefs.c +2 -1
  948. data/src/core/ext/upbdefs-gen/udpa/annotations/security.upbdefs.h +5 -4
  949. data/src/core/ext/upbdefs-gen/udpa/annotations/sensitive.upbdefs.c +2 -1
  950. data/src/core/ext/upbdefs-gen/udpa/annotations/sensitive.upbdefs.h +5 -4
  951. data/src/core/ext/upbdefs-gen/udpa/annotations/status.upbdefs.c +2 -1
  952. data/src/core/ext/upbdefs-gen/udpa/annotations/status.upbdefs.h +5 -4
  953. data/src/core/ext/upbdefs-gen/udpa/annotations/versioning.upbdefs.c +2 -1
  954. data/src/core/ext/upbdefs-gen/udpa/annotations/versioning.upbdefs.h +5 -4
  955. data/src/core/ext/upbdefs-gen/validate/validate.upbdefs.c +2 -1
  956. data/src/core/ext/upbdefs-gen/validate/validate.upbdefs.h +5 -4
  957. data/src/core/ext/upbdefs-gen/xds/annotations/v3/migrate.upbdefs.c +2 -1
  958. data/src/core/ext/upbdefs-gen/xds/annotations/v3/migrate.upbdefs.h +5 -4
  959. data/src/core/ext/upbdefs-gen/xds/annotations/v3/security.upbdefs.c +2 -1
  960. data/src/core/ext/upbdefs-gen/xds/annotations/v3/security.upbdefs.h +5 -4
  961. data/src/core/ext/upbdefs-gen/xds/annotations/v3/sensitive.upbdefs.c +2 -1
  962. data/src/core/ext/upbdefs-gen/xds/annotations/v3/sensitive.upbdefs.h +5 -4
  963. data/src/core/ext/upbdefs-gen/xds/annotations/v3/status.upbdefs.c +2 -1
  964. data/src/core/ext/upbdefs-gen/xds/annotations/v3/status.upbdefs.h +5 -4
  965. data/src/core/ext/upbdefs-gen/xds/annotations/v3/versioning.upbdefs.c +2 -1
  966. data/src/core/ext/upbdefs-gen/xds/annotations/v3/versioning.upbdefs.h +5 -4
  967. data/src/core/ext/upbdefs-gen/xds/core/v3/authority.upbdefs.c +2 -1
  968. data/src/core/ext/upbdefs-gen/xds/core/v3/authority.upbdefs.h +5 -4
  969. data/src/core/ext/upbdefs-gen/xds/core/v3/cidr.upbdefs.c +2 -1
  970. data/src/core/ext/upbdefs-gen/xds/core/v3/cidr.upbdefs.h +5 -4
  971. data/src/core/ext/upbdefs-gen/xds/core/v3/collection_entry.upbdefs.c +2 -1
  972. data/src/core/ext/upbdefs-gen/xds/core/v3/collection_entry.upbdefs.h +5 -4
  973. data/src/core/ext/upbdefs-gen/xds/core/v3/context_params.upbdefs.c +2 -1
  974. data/src/core/ext/upbdefs-gen/xds/core/v3/context_params.upbdefs.h +5 -4
  975. data/src/core/ext/upbdefs-gen/xds/core/v3/extension.upbdefs.c +2 -1
  976. data/src/core/ext/upbdefs-gen/xds/core/v3/extension.upbdefs.h +5 -4
  977. data/src/core/ext/upbdefs-gen/xds/core/v3/resource.upbdefs.c +2 -1
  978. data/src/core/ext/upbdefs-gen/xds/core/v3/resource.upbdefs.h +5 -4
  979. data/src/core/ext/upbdefs-gen/xds/core/v3/resource_locator.upbdefs.c +2 -1
  980. data/src/core/ext/upbdefs-gen/xds/core/v3/resource_locator.upbdefs.h +5 -4
  981. data/src/core/ext/upbdefs-gen/xds/core/v3/resource_name.upbdefs.c +2 -1
  982. data/src/core/ext/upbdefs-gen/xds/core/v3/resource_name.upbdefs.h +5 -4
  983. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/cel.upbdefs.c +2 -1
  984. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/cel.upbdefs.h +5 -4
  985. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/domain.upbdefs.c +2 -1
  986. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/domain.upbdefs.h +5 -4
  987. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/http_inputs.upbdefs.c +2 -1
  988. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/http_inputs.upbdefs.h +5 -4
  989. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/ip.upbdefs.c +2 -1
  990. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/ip.upbdefs.h +5 -4
  991. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/matcher.upbdefs.c +2 -1
  992. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/matcher.upbdefs.h +5 -4
  993. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/range.upbdefs.c +2 -1
  994. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/range.upbdefs.h +5 -4
  995. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/regex.upbdefs.c +2 -1
  996. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/regex.upbdefs.h +5 -4
  997. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/string.upbdefs.c +2 -1
  998. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/string.upbdefs.h +5 -4
  999. data/src/core/ext/upbdefs-gen/xds/type/v3/cel.upbdefs.c +2 -1
  1000. data/src/core/ext/upbdefs-gen/xds/type/v3/cel.upbdefs.h +5 -4
  1001. data/src/core/ext/upbdefs-gen/xds/type/v3/range.upbdefs.c +2 -1
  1002. data/src/core/ext/upbdefs-gen/xds/type/v3/range.upbdefs.h +5 -4
  1003. data/src/core/ext/upbdefs-gen/xds/type/v3/typed_struct.upbdefs.c +2 -1
  1004. data/src/core/ext/upbdefs-gen/xds/type/v3/typed_struct.upbdefs.h +5 -4
  1005. data/src/core/filter/blackboard.cc +33 -0
  1006. data/src/core/filter/blackboard.h +70 -0
  1007. data/src/core/filter/filter_args.h +112 -0
  1008. data/src/core/handshaker/endpoint_info/endpoint_info_handshaker.cc +13 -12
  1009. data/src/core/handshaker/endpoint_info/endpoint_info_handshaker.h +1 -1
  1010. data/src/core/handshaker/handshaker.cc +124 -159
  1011. data/src/core/handshaker/handshaker.h +58 -52
  1012. data/src/core/handshaker/handshaker_registry.cc +1 -2
  1013. data/src/core/handshaker/handshaker_registry.h +2 -2
  1014. data/src/core/handshaker/http_connect/http_connect_handshaker.cc +120 -162
  1015. data/src/core/handshaker/http_connect/http_connect_handshaker.h +1 -1
  1016. data/src/core/handshaker/http_connect/http_proxy_mapper.cc +61 -69
  1017. data/src/core/handshaker/http_connect/http_proxy_mapper.h +7 -8
  1018. data/src/core/handshaker/http_connect/xds_http_proxy_mapper.cc +57 -0
  1019. data/src/core/handshaker/http_connect/xds_http_proxy_mapper.h +46 -0
  1020. data/src/core/handshaker/proxy_mapper.h +6 -7
  1021. data/src/core/handshaker/proxy_mapper_registry.cc +7 -8
  1022. data/src/core/handshaker/proxy_mapper_registry.h +6 -7
  1023. data/src/core/handshaker/security/secure_endpoint.cc +97 -84
  1024. data/src/core/handshaker/security/secure_endpoint.h +6 -7
  1025. data/src/core/handshaker/security/security_handshaker.cc +168 -224
  1026. data/src/core/handshaker/security/security_handshaker.h +3 -4
  1027. data/src/core/handshaker/tcp_connect/tcp_connect_handshaker.cc +54 -66
  1028. data/src/core/handshaker/tcp_connect/tcp_connect_handshaker.h +1 -1
  1029. data/src/core/lib/address_utils/parse_address.cc +30 -43
  1030. data/src/core/lib/address_utils/parse_address.h +2 -4
  1031. data/src/core/lib/address_utils/sockaddr_utils.cc +9 -12
  1032. data/src/core/lib/address_utils/sockaddr_utils.h +1 -3
  1033. data/src/core/lib/channel/call_finalization.h +2 -2
  1034. data/src/core/lib/channel/channel_args.cc +30 -36
  1035. data/src/core/lib/channel/channel_args.h +43 -29
  1036. data/src/core/lib/channel/channel_args_preconditioning.cc +2 -2
  1037. data/src/core/lib/channel/channel_args_preconditioning.h +4 -4
  1038. data/src/core/lib/channel/channel_stack.cc +13 -76
  1039. data/src/core/lib/channel/channel_stack.h +26 -61
  1040. data/src/core/lib/channel/channel_stack_builder.cc +2 -2
  1041. data/src/core/lib/channel/channel_stack_builder.h +3 -9
  1042. data/src/core/lib/channel/channel_stack_builder_impl.cc +5 -150
  1043. data/src/core/lib/channel/channel_stack_builder_impl.h +14 -4
  1044. data/src/core/lib/channel/connected_channel.cc +48 -690
  1045. data/src/core/lib/channel/promise_based_filter.cc +190 -260
  1046. data/src/core/lib/channel/promise_based_filter.h +214 -625
  1047. data/src/core/lib/channel/status_util.cc +2 -4
  1048. data/src/core/lib/channel/status_util.h +3 -3
  1049. data/src/core/lib/compression/compression.cc +9 -10
  1050. data/src/core/lib/compression/compression_internal.cc +14 -17
  1051. data/src/core/lib/compression/compression_internal.h +6 -8
  1052. data/src/core/lib/compression/message_compress.cc +9 -12
  1053. data/src/core/lib/debug/trace.cc +48 -66
  1054. data/src/core/lib/debug/trace.h +2 -97
  1055. data/src/core/lib/debug/trace_flags.cc +245 -0
  1056. data/src/core/lib/debug/trace_flags.h +132 -0
  1057. data/src/core/lib/debug/trace_impl.h +125 -0
  1058. data/src/core/lib/event_engine/ares_resolver.cc +158 -86
  1059. data/src/core/lib/event_engine/ares_resolver.h +19 -30
  1060. data/src/core/lib/event_engine/cf_engine/cf_engine.cc +15 -20
  1061. data/src/core/lib/event_engine/cf_engine/cf_engine.h +3 -5
  1062. data/src/core/lib/event_engine/cf_engine/cfstream_endpoint.cc +50 -38
  1063. data/src/core/lib/event_engine/cf_engine/cfstream_endpoint.h +6 -10
  1064. data/src/core/lib/event_engine/cf_engine/cftype_unique_ref.h +3 -5
  1065. data/src/core/lib/event_engine/cf_engine/dns_service_resolver.cc +27 -35
  1066. data/src/core/lib/event_engine/cf_engine/dns_service_resolver.h +5 -9
  1067. data/src/core/lib/event_engine/channel_args_endpoint_config.cc +7 -10
  1068. data/src/core/lib/event_engine/channel_args_endpoint_config.h +7 -9
  1069. data/src/core/lib/event_engine/common_closures.h +5 -7
  1070. data/src/core/lib/event_engine/default_event_engine.cc +69 -42
  1071. data/src/core/lib/event_engine/default_event_engine.h +27 -36
  1072. data/src/core/lib/event_engine/default_event_engine_factory.cc +8 -14
  1073. data/src/core/lib/event_engine/default_event_engine_factory.h +4 -6
  1074. data/src/core/lib/event_engine/event_engine.cc +37 -8
  1075. data/src/core/lib/event_engine/event_engine_context.h +4 -2
  1076. data/src/core/lib/event_engine/extensions/can_track_errors.h +4 -6
  1077. data/src/core/lib/event_engine/extensions/chaotic_good_extension.h +3 -6
  1078. data/src/core/lib/event_engine/extensions/supports_fd.h +29 -7
  1079. data/src/core/lib/event_engine/extensions/tcp_trace.h +40 -0
  1080. data/src/core/lib/event_engine/forkable.cc +9 -13
  1081. data/src/core/lib/event_engine/forkable.h +4 -18
  1082. data/src/core/lib/event_engine/grpc_polled_fd.h +5 -8
  1083. data/src/core/lib/event_engine/handle_containers.h +4 -7
  1084. data/src/core/lib/event_engine/memory_allocator_factory.h +5 -8
  1085. data/src/core/lib/event_engine/nameser.h +1 -1
  1086. data/src/core/lib/event_engine/poller.h +4 -6
  1087. data/src/core/lib/event_engine/posix.h +2 -4
  1088. data/src/core/lib/event_engine/posix_engine/ev_epoll1_linux.cc +25 -73
  1089. data/src/core/lib/event_engine/posix_engine/ev_epoll1_linux.h +10 -13
  1090. data/src/core/lib/event_engine/posix_engine/ev_poll_posix.cc +21 -72
  1091. data/src/core/lib/event_engine/posix_engine/ev_poll_posix.h +6 -9
  1092. data/src/core/lib/event_engine/posix_engine/event_poller.h +5 -8
  1093. data/src/core/lib/event_engine/posix_engine/event_poller_posix_default.cc +6 -9
  1094. data/src/core/lib/event_engine/posix_engine/event_poller_posix_default.h +4 -6
  1095. data/src/core/lib/event_engine/posix_engine/grpc_polled_fd_posix.h +6 -10
  1096. data/src/core/lib/event_engine/posix_engine/internal_errqueue.cc +6 -8
  1097. data/src/core/lib/event_engine/posix_engine/internal_errqueue.h +3 -6
  1098. data/src/core/lib/event_engine/posix_engine/lockfree_event.cc +7 -11
  1099. data/src/core/lib/event_engine/posix_engine/lockfree_event.h +4 -7
  1100. data/src/core/lib/event_engine/posix_engine/native_posix_dns_resolver.cc +5 -8
  1101. data/src/core/lib/event_engine/posix_engine/native_posix_dns_resolver.h +4 -7
  1102. data/src/core/lib/event_engine/posix_engine/posix_endpoint.cc +93 -89
  1103. data/src/core/lib/event_engine/posix_engine/posix_endpoint.h +13 -16
  1104. data/src/core/lib/event_engine/posix_engine/posix_engine.cc +84 -62
  1105. data/src/core/lib/event_engine/posix_engine/posix_engine.h +20 -20
  1106. data/src/core/lib/event_engine/posix_engine/posix_engine_closure.h +5 -7
  1107. data/src/core/lib/event_engine/posix_engine/posix_engine_listener.cc +27 -33
  1108. data/src/core/lib/event_engine/posix_engine/posix_engine_listener.h +16 -17
  1109. data/src/core/lib/event_engine/posix_engine/posix_engine_listener_utils.cc +24 -32
  1110. data/src/core/lib/event_engine/posix_engine/posix_engine_listener_utils.h +3 -6
  1111. data/src/core/lib/event_engine/posix_engine/tcp_socket_utils.cc +49 -44
  1112. data/src/core/lib/event_engine/posix_engine/tcp_socket_utils.h +12 -14
  1113. data/src/core/lib/event_engine/posix_engine/timer.cc +9 -11
  1114. data/src/core/lib/event_engine/posix_engine/timer.h +9 -13
  1115. data/src/core/lib/event_engine/posix_engine/timer_heap.cc +4 -7
  1116. data/src/core/lib/event_engine/posix_engine/timer_heap.h +4 -6
  1117. data/src/core/lib/event_engine/posix_engine/timer_manager.cc +17 -28
  1118. data/src/core/lib/event_engine/posix_engine/timer_manager.h +9 -13
  1119. data/src/core/lib/event_engine/posix_engine/traced_buffer_list.cc +11 -17
  1120. data/src/core/lib/event_engine/posix_engine/traced_buffer_list.h +27 -30
  1121. data/src/core/lib/event_engine/posix_engine/wakeup_fd_eventfd.cc +7 -10
  1122. data/src/core/lib/event_engine/posix_engine/wakeup_fd_eventfd.h +4 -7
  1123. data/src/core/lib/event_engine/posix_engine/wakeup_fd_pipe.cc +6 -9
  1124. data/src/core/lib/event_engine/posix_engine/wakeup_fd_pipe.h +4 -7
  1125. data/src/core/lib/event_engine/posix_engine/wakeup_fd_posix.h +4 -6
  1126. data/src/core/lib/event_engine/posix_engine/wakeup_fd_posix_default.cc +4 -7
  1127. data/src/core/lib/event_engine/posix_engine/wakeup_fd_posix_default.h +4 -6
  1128. data/src/core/lib/event_engine/query_extensions.h +4 -6
  1129. data/src/core/lib/event_engine/ref_counted_dns_resolver_interface.h +5 -9
  1130. data/src/core/lib/event_engine/resolved_address.cc +7 -9
  1131. data/src/core/lib/event_engine/resolved_address_internal.h +2 -4
  1132. data/src/core/lib/event_engine/shim.cc +3 -5
  1133. data/src/core/lib/event_engine/shim.h +2 -4
  1134. data/src/core/lib/event_engine/slice.cc +5 -10
  1135. data/src/core/lib/event_engine/slice_buffer.cc +3 -6
  1136. data/src/core/lib/event_engine/tcp_socket_utils.cc +15 -26
  1137. data/src/core/lib/event_engine/tcp_socket_utils.h +8 -10
  1138. data/src/core/lib/event_engine/thread_local.cc +2 -4
  1139. data/src/core/lib/event_engine/thread_local.h +3 -5
  1140. data/src/core/lib/event_engine/thread_pool/thread_count.cc +7 -11
  1141. data/src/core/lib/event_engine/thread_pool/thread_count.h +10 -25
  1142. data/src/core/lib/event_engine/thread_pool/thread_pool.h +4 -8
  1143. data/src/core/lib/event_engine/thread_pool/thread_pool_factory.cc +4 -7
  1144. data/src/core/lib/event_engine/thread_pool/work_stealing_thread_pool.cc +43 -52
  1145. data/src/core/lib/event_engine/thread_pool/work_stealing_thread_pool.h +12 -19
  1146. data/src/core/lib/event_engine/thready_event_engine/thready_event_engine.cc +52 -27
  1147. data/src/core/lib/event_engine/thready_event_engine/thready_event_engine.h +11 -12
  1148. data/src/core/lib/event_engine/time_util.cc +4 -6
  1149. data/src/core/lib/event_engine/time_util.h +3 -6
  1150. data/src/core/lib/event_engine/utils.cc +21 -9
  1151. data/src/core/lib/event_engine/utils.h +12 -8
  1152. data/src/core/lib/event_engine/windows/grpc_polled_fd_windows.cc +128 -105
  1153. data/src/core/lib/event_engine/windows/grpc_polled_fd_windows.h +6 -10
  1154. data/src/core/lib/event_engine/windows/iocp.cc +16 -18
  1155. data/src/core/lib/event_engine/windows/iocp.h +4 -7
  1156. data/src/core/lib/event_engine/windows/native_windows_dns_resolver.cc +6 -10
  1157. data/src/core/lib/event_engine/windows/native_windows_dns_resolver.h +2 -4
  1158. data/src/core/lib/event_engine/windows/win_socket.cc +44 -37
  1159. data/src/core/lib/event_engine/windows/win_socket.h +10 -14
  1160. data/src/core/lib/event_engine/windows/windows_endpoint.cc +48 -37
  1161. data/src/core/lib/event_engine/windows/windows_endpoint.h +4 -6
  1162. data/src/core/lib/event_engine/windows/windows_engine.cc +245 -138
  1163. data/src/core/lib/event_engine/windows/windows_engine.h +145 -37
  1164. data/src/core/lib/event_engine/windows/windows_listener.cc +24 -41
  1165. data/src/core/lib/event_engine/windows/windows_listener.h +6 -9
  1166. data/src/core/lib/event_engine/work_queue/basic_work_queue.cc +5 -7
  1167. data/src/core/lib/event_engine/work_queue/basic_work_queue.h +5 -9
  1168. data/src/core/lib/event_engine/work_queue/work_queue.h +4 -7
  1169. data/src/core/lib/experiments/config.cc +55 -28
  1170. data/src/core/lib/experiments/config.h +56 -3
  1171. data/src/core/lib/experiments/experiments.cc +308 -366
  1172. data/src/core/lib/experiments/experiments.h +144 -155
  1173. data/src/core/lib/iomgr/buffer_list.cc +6 -6
  1174. data/src/core/lib/iomgr/buffer_list.h +23 -23
  1175. data/src/core/lib/iomgr/call_combiner.cc +39 -66
  1176. data/src/core/lib/iomgr/call_combiner.h +13 -17
  1177. data/src/core/lib/iomgr/cfstream_handle.cc +14 -22
  1178. data/src/core/lib/iomgr/cfstream_handle.h +1 -1
  1179. data/src/core/lib/iomgr/closure.cc +2 -2
  1180. data/src/core/lib/iomgr/closure.h +13 -21
  1181. data/src/core/lib/iomgr/combiner.cc +33 -49
  1182. data/src/core/lib/iomgr/combiner.h +2 -5
  1183. data/src/core/lib/iomgr/endpoint.cc +0 -6
  1184. data/src/core/lib/iomgr/endpoint.h +3 -4
  1185. data/src/core/lib/iomgr/endpoint_cfstream.cc +40 -73
  1186. data/src/core/lib/iomgr/endpoint_pair_posix.cc +3 -6
  1187. data/src/core/lib/iomgr/endpoint_pair_windows.cc +6 -8
  1188. data/src/core/lib/iomgr/error.cc +24 -34
  1189. data/src/core/lib/iomgr/error.h +7 -10
  1190. data/src/core/lib/iomgr/error_cfstream.cc +1 -3
  1191. data/src/core/lib/iomgr/ev_apple.cc +16 -24
  1192. data/src/core/lib/iomgr/ev_epoll1_linux.cc +69 -115
  1193. data/src/core/lib/iomgr/ev_poll_posix.cc +53 -53
  1194. data/src/core/lib/iomgr/ev_posix.cc +67 -58
  1195. data/src/core/lib/iomgr/ev_posix.h +9 -12
  1196. data/src/core/lib/iomgr/event_engine_shims/closure.cc +10 -14
  1197. data/src/core/lib/iomgr/event_engine_shims/closure.h +1 -2
  1198. data/src/core/lib/iomgr/event_engine_shims/endpoint.cc +34 -54
  1199. data/src/core/lib/iomgr/event_engine_shims/endpoint.h +2 -2
  1200. data/src/core/lib/iomgr/event_engine_shims/tcp_client.cc +9 -14
  1201. data/src/core/lib/iomgr/exec_ctx.cc +11 -21
  1202. data/src/core/lib/iomgr/exec_ctx.h +23 -146
  1203. data/src/core/lib/iomgr/executor.cc +55 -64
  1204. data/src/core/lib/iomgr/executor.h +2 -2
  1205. data/src/core/lib/iomgr/fork_posix.cc +11 -15
  1206. data/src/core/lib/iomgr/fork_windows.cc +3 -2
  1207. data/src/core/lib/iomgr/internal_errqueue.cc +4 -4
  1208. data/src/core/lib/iomgr/iocp_windows.cc +8 -10
  1209. data/src/core/lib/iomgr/iomgr.cc +18 -24
  1210. data/src/core/lib/iomgr/iomgr.h +1 -2
  1211. data/src/core/lib/iomgr/iomgr_internal.cc +1 -2
  1212. data/src/core/lib/iomgr/iomgr_internal.h +1 -2
  1213. data/src/core/lib/iomgr/iomgr_posix.cc +2 -1
  1214. data/src/core/lib/iomgr/iomgr_windows.cc +4 -5
  1215. data/src/core/lib/iomgr/lockfree_event.cc +10 -20
  1216. data/src/core/lib/iomgr/nameser.h +1 -1
  1217. data/src/core/lib/iomgr/polling_entity.cc +13 -7
  1218. data/src/core/lib/iomgr/pollset.h +0 -2
  1219. data/src/core/lib/iomgr/pollset_set_windows.cc +1 -2
  1220. data/src/core/lib/iomgr/pollset_windows.cc +2 -6
  1221. data/src/core/lib/iomgr/port.h +2 -2
  1222. data/src/core/lib/iomgr/resolve_address.cc +3 -5
  1223. data/src/core/lib/iomgr/resolve_address.h +4 -6
  1224. data/src/core/lib/iomgr/resolve_address_impl.h +1 -2
  1225. data/src/core/lib/iomgr/resolve_address_posix.cc +12 -23
  1226. data/src/core/lib/iomgr/resolve_address_posix.h +2 -2
  1227. data/src/core/lib/iomgr/resolve_address_windows.cc +9 -14
  1228. data/src/core/lib/iomgr/resolve_address_windows.h +2 -2
  1229. data/src/core/lib/iomgr/resolved_address.h +1 -2
  1230. data/src/core/lib/iomgr/sockaddr_utils_posix.cc +3 -6
  1231. data/src/core/lib/iomgr/socket_factory_posix.cc +1 -1
  1232. data/src/core/lib/iomgr/socket_mutator.cc +2 -3
  1233. data/src/core/lib/iomgr/socket_mutator.h +1 -2
  1234. data/src/core/lib/iomgr/socket_utils.h +1 -2
  1235. data/src/core/lib/iomgr/socket_utils_common_posix.cc +43 -52
  1236. data/src/core/lib/iomgr/socket_utils_linux.cc +1 -3
  1237. data/src/core/lib/iomgr/socket_utils_posix.cc +6 -8
  1238. data/src/core/lib/iomgr/socket_utils_windows.cc +1 -3
  1239. data/src/core/lib/iomgr/socket_windows.cc +7 -11
  1240. data/src/core/lib/iomgr/socket_windows.h +1 -2
  1241. data/src/core/lib/iomgr/tcp_client_cfstream.cc +12 -20
  1242. data/src/core/lib/iomgr/tcp_client_posix.cc +19 -32
  1243. data/src/core/lib/iomgr/tcp_client_windows.cc +8 -13
  1244. data/src/core/lib/iomgr/tcp_posix.cc +89 -158
  1245. data/src/core/lib/iomgr/tcp_posix.h +1 -3
  1246. data/src/core/lib/iomgr/tcp_server.h +2 -2
  1247. data/src/core/lib/iomgr/tcp_server_posix.cc +41 -61
  1248. data/src/core/lib/iomgr/tcp_server_utils_posix.h +2 -3
  1249. data/src/core/lib/iomgr/tcp_server_utils_posix_common.cc +7 -11
  1250. data/src/core/lib/iomgr/tcp_server_utils_posix_ifaddrs.cc +11 -13
  1251. data/src/core/lib/iomgr/tcp_server_windows.cc +20 -29
  1252. data/src/core/lib/iomgr/tcp_windows.cc +32 -62
  1253. data/src/core/lib/iomgr/timer.h +2 -2
  1254. data/src/core/lib/iomgr/timer_generic.cc +72 -105
  1255. data/src/core/lib/iomgr/timer_heap.cc +3 -4
  1256. data/src/core/lib/iomgr/timer_manager.cc +26 -52
  1257. data/src/core/lib/iomgr/timer_manager.h +1 -2
  1258. data/src/core/lib/iomgr/unix_sockets_posix.cc +4 -6
  1259. data/src/core/lib/iomgr/unix_sockets_posix.h +3 -4
  1260. data/src/core/lib/iomgr/unix_sockets_posix_noop.cc +0 -4
  1261. data/src/core/lib/iomgr/vsock.cc +3 -6
  1262. data/src/core/lib/iomgr/vsock.h +3 -4
  1263. data/src/core/lib/iomgr/wakeup_fd_eventfd.cc +2 -4
  1264. data/src/core/lib/iomgr/wakeup_fd_pipe.cc +6 -7
  1265. data/src/core/lib/promise/activity.cc +4 -4
  1266. data/src/core/lib/promise/activity.h +81 -29
  1267. data/src/core/lib/promise/all_ok.h +54 -11
  1268. data/src/core/lib/promise/arena_promise.h +2 -4
  1269. data/src/core/lib/promise/cancel_callback.h +34 -6
  1270. data/src/core/lib/promise/context.h +19 -10
  1271. data/src/core/lib/promise/detail/basic_seq.h +33 -20
  1272. data/src/core/lib/promise/detail/join_state.h +556 -814
  1273. data/src/core/lib/promise/detail/promise_factory.h +124 -48
  1274. data/src/core/lib/promise/detail/promise_like.h +50 -21
  1275. data/src/core/lib/promise/detail/seq_state.h +1378 -2254
  1276. data/src/core/lib/promise/detail/status.h +36 -15
  1277. data/src/core/lib/promise/exec_ctx_wakeup_scheduler.h +2 -3
  1278. data/src/core/lib/promise/for_each.h +46 -40
  1279. data/src/core/lib/promise/if.h +69 -37
  1280. data/src/core/lib/promise/interceptor_list.h +30 -44
  1281. data/src/core/lib/promise/latch.h +33 -40
  1282. data/src/core/lib/promise/loop.h +82 -29
  1283. data/src/core/lib/promise/map.h +186 -22
  1284. data/src/core/lib/promise/observable.h +181 -0
  1285. data/src/core/lib/promise/party.cc +326 -149
  1286. data/src/core/lib/promise/party.h +390 -395
  1287. data/src/core/lib/promise/pipe.h +33 -56
  1288. data/src/core/lib/promise/poll.h +120 -40
  1289. data/src/core/lib/promise/prioritized_race.h +17 -23
  1290. data/src/core/lib/promise/promise.h +15 -10
  1291. data/src/core/lib/promise/race.h +14 -17
  1292. data/src/core/lib/promise/seq.h +99 -71
  1293. data/src/core/lib/promise/sleep.cc +6 -6
  1294. data/src/core/lib/promise/sleep.h +19 -6
  1295. data/src/core/lib/promise/status_flag.h +173 -51
  1296. data/src/core/lib/promise/try_join.h +156 -26
  1297. data/src/core/lib/promise/try_seq.h +151 -89
  1298. data/src/core/lib/resource_quota/api.cc +4 -6
  1299. data/src/core/lib/resource_quota/api.h +2 -3
  1300. data/src/core/lib/resource_quota/arena.cc +64 -86
  1301. data/src/core/lib/resource_quota/arena.h +225 -210
  1302. data/src/core/lib/resource_quota/connection_quota.cc +2 -3
  1303. data/src/core/lib/resource_quota/connection_quota.h +9 -6
  1304. data/src/core/lib/resource_quota/memory_quota.cc +93 -90
  1305. data/src/core/lib/resource_quota/memory_quota.h +29 -23
  1306. data/src/core/lib/resource_quota/periodic_update.cc +5 -5
  1307. data/src/core/lib/resource_quota/periodic_update.h +2 -4
  1308. data/src/core/lib/resource_quota/resource_quota.h +8 -9
  1309. data/src/core/lib/resource_quota/thread_quota.cc +2 -3
  1310. data/src/core/lib/resource_quota/thread_quota.h +5 -6
  1311. data/src/core/lib/security/authorization/audit_logging.cc +5 -7
  1312. data/src/core/lib/security/authorization/audit_logging.h +5 -6
  1313. data/src/core/lib/security/authorization/authorization_engine.h +3 -3
  1314. data/src/core/lib/security/authorization/authorization_policy_provider.h +4 -5
  1315. data/src/core/lib/security/authorization/authorization_policy_provider_vtable.cc +2 -2
  1316. data/src/core/lib/security/authorization/evaluate_args.cc +13 -17
  1317. data/src/core/lib/security/authorization/evaluate_args.h +6 -7
  1318. data/src/core/lib/security/authorization/grpc_authorization_engine.cc +2 -4
  1319. data/src/core/lib/security/authorization/grpc_authorization_engine.h +2 -3
  1320. data/src/core/lib/security/authorization/grpc_server_authz_filter.cc +21 -36
  1321. data/src/core/lib/security/authorization/grpc_server_authz_filter.h +10 -8
  1322. data/src/core/lib/security/authorization/matchers.cc +5 -7
  1323. data/src/core/lib/security/authorization/matchers.h +5 -7
  1324. data/src/core/lib/security/authorization/rbac_policy.cc +3 -3
  1325. data/src/core/lib/security/authorization/rbac_policy.h +6 -8
  1326. data/src/core/lib/security/authorization/stdout_logger.cc +4 -5
  1327. data/src/core/lib/security/authorization/stdout_logger.h +4 -4
  1328. data/src/core/lib/security/certificate_provider/certificate_provider_factory.h +8 -9
  1329. data/src/core/lib/security/certificate_provider/certificate_provider_registry.cc +4 -5
  1330. data/src/core/lib/security/certificate_provider/certificate_provider_registry.h +2 -3
  1331. data/src/core/lib/security/context/security_context.cc +48 -48
  1332. data/src/core/lib/security/context/security_context.h +47 -18
  1333. data/src/core/lib/security/credentials/alts/alts_credentials.cc +5 -5
  1334. data/src/core/lib/security/credentials/alts/alts_credentials.h +9 -5
  1335. data/src/core/lib/security/credentials/alts/check_gcp_environment.cc +4 -4
  1336. data/src/core/lib/security/credentials/alts/check_gcp_environment_linux.cc +1 -2
  1337. data/src/core/lib/security/credentials/alts/check_gcp_environment_no_op.cc +3 -5
  1338. data/src/core/lib/security/credentials/alts/check_gcp_environment_windows.cc +3 -5
  1339. data/src/core/lib/security/credentials/alts/grpc_alts_credentials_client_options.cc +4 -5
  1340. data/src/core/lib/security/credentials/alts/grpc_alts_credentials_options.cc +3 -3
  1341. data/src/core/lib/security/credentials/call_creds_util.cc +8 -7
  1342. data/src/core/lib/security/credentials/call_creds_util.h +2 -2
  1343. data/src/core/lib/security/credentials/channel_creds_registry.h +7 -8
  1344. data/src/core/lib/security/credentials/channel_creds_registry_init.cc +15 -14
  1345. data/src/core/lib/security/credentials/composite/composite_credentials.cc +10 -14
  1346. data/src/core/lib/security/credentials/composite/composite_credentials.h +11 -10
  1347. data/src/core/lib/security/credentials/credentials.cc +18 -19
  1348. data/src/core/lib/security/credentials/credentials.h +12 -14
  1349. data/src/core/lib/security/credentials/external/aws_external_account_credentials.cc +335 -340
  1350. data/src/core/lib/security/credentials/external/aws_external_account_credentials.h +60 -48
  1351. data/src/core/lib/security/credentials/external/aws_request_signer.cc +4 -5
  1352. data/src/core/lib/security/credentials/external/aws_request_signer.h +3 -3
  1353. data/src/core/lib/security/credentials/external/external_account_credentials.cc +407 -374
  1354. data/src/core/lib/security/credentials/external/external_account_credentials.h +128 -60
  1355. data/src/core/lib/security/credentials/external/file_external_account_credentials.cc +89 -52
  1356. data/src/core/lib/security/credentials/external/file_external_account_credentials.h +32 -11
  1357. data/src/core/lib/security/credentials/external/url_external_account_credentials.cc +102 -129
  1358. data/src/core/lib/security/credentials/external/url_external_account_credentials.h +22 -24
  1359. data/src/core/lib/security/credentials/fake/fake_credentials.cc +2 -4
  1360. data/src/core/lib/security/credentials/fake/fake_credentials.h +9 -8
  1361. data/src/core/lib/security/credentials/gcp_service_account_identity/gcp_service_account_identity_credentials.cc +195 -0
  1362. data/src/core/lib/security/credentials/gcp_service_account_identity/gcp_service_account_identity_credentials.h +90 -0
  1363. data/src/core/lib/security/credentials/google_default/credentials_generic.cc +7 -8
  1364. data/src/core/lib/security/credentials/google_default/google_default_credentials.cc +58 -76
  1365. data/src/core/lib/security/credentials/google_default/google_default_credentials.h +8 -6
  1366. data/src/core/lib/security/credentials/iam/iam_credentials.cc +6 -11
  1367. data/src/core/lib/security/credentials/iam/iam_credentials.h +9 -8
  1368. data/src/core/lib/security/credentials/insecure/insecure_credentials.cc +2 -2
  1369. data/src/core/lib/security/credentials/insecure/insecure_credentials.h +2 -2
  1370. data/src/core/lib/security/credentials/jwt/json_token.cc +25 -29
  1371. data/src/core/lib/security/credentials/jwt/json_token.h +2 -3
  1372. data/src/core/lib/security/credentials/jwt/jwt_credentials.cc +23 -31
  1373. data/src/core/lib/security/credentials/jwt/jwt_credentials.h +12 -12
  1374. data/src/core/lib/security/credentials/jwt/jwt_verifier.cc +68 -76
  1375. data/src/core/lib/security/credentials/jwt/jwt_verifier.h +3 -4
  1376. data/src/core/lib/security/credentials/local/local_credentials.cc +2 -2
  1377. data/src/core/lib/security/credentials/local/local_credentials.h +3 -3
  1378. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.cc +196 -297
  1379. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.h +51 -74
  1380. data/src/core/lib/security/credentials/plugin/plugin_credentials.cc +20 -34
  1381. data/src/core/lib/security/credentials/plugin/plugin_credentials.h +12 -14
  1382. data/src/core/lib/security/credentials/ssl/ssl_credentials.cc +37 -49
  1383. data/src/core/lib/security/credentials/ssl/ssl_credentials.h +5 -8
  1384. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_distributor.cc +15 -17
  1385. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_distributor.h +18 -19
  1386. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_match.cc +1 -3
  1387. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.cc +122 -54
  1388. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.h +17 -16
  1389. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_verifier.cc +6 -10
  1390. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_verifier.h +9 -11
  1391. data/src/core/lib/security/credentials/tls/grpc_tls_credentials_options.cc +10 -13
  1392. data/src/core/lib/security/credentials/tls/grpc_tls_credentials_options.h +1 -1
  1393. data/src/core/lib/security/credentials/tls/grpc_tls_crl_provider.cc +6 -11
  1394. data/src/core/lib/security/credentials/tls/grpc_tls_crl_provider.h +9 -12
  1395. data/src/core/lib/security/credentials/tls/tls_credentials.cc +21 -24
  1396. data/src/core/lib/security/credentials/tls/tls_credentials.h +5 -3
  1397. data/src/core/lib/security/credentials/tls/tls_utils.cc +5 -6
  1398. data/src/core/lib/security/credentials/tls/tls_utils.h +3 -3
  1399. data/src/core/lib/security/credentials/token_fetcher/token_fetcher_credentials.cc +304 -0
  1400. data/src/core/lib/security/credentials/token_fetcher/token_fetcher_credentials.h +181 -0
  1401. data/src/core/lib/security/credentials/xds/xds_credentials.cc +16 -13
  1402. data/src/core/lib/security/credentials/xds/xds_credentials.h +7 -9
  1403. data/src/core/lib/security/security_connector/alts/alts_security_connector.cc +23 -28
  1404. data/src/core/lib/security/security_connector/alts/alts_security_connector.h +1 -1
  1405. data/src/core/lib/security/security_connector/fake/fake_security_connector.cc +27 -27
  1406. data/src/core/lib/security/security_connector/fake/fake_security_connector.h +1 -1
  1407. data/src/core/lib/security/security_connector/insecure/insecure_security_connector.cc +4 -7
  1408. data/src/core/lib/security/security_connector/insecure/insecure_security_connector.h +5 -6
  1409. data/src/core/lib/security/security_connector/load_system_roots_supported.cc +10 -12
  1410. data/src/core/lib/security/security_connector/load_system_roots_windows.cc +4 -6
  1411. data/src/core/lib/security/security_connector/local/local_security_connector.cc +26 -26
  1412. data/src/core/lib/security/security_connector/local/local_security_connector.h +1 -1
  1413. data/src/core/lib/security/security_connector/security_connector.cc +6 -11
  1414. data/src/core/lib/security/security_connector/security_connector.h +8 -11
  1415. data/src/core/lib/security/security_connector/ssl/ssl_security_connector.cc +23 -27
  1416. data/src/core/lib/security/security_connector/ssl/ssl_security_connector.h +2 -3
  1417. data/src/core/lib/security/security_connector/ssl_utils.cc +34 -35
  1418. data/src/core/lib/security/security_connector/ssl_utils.h +7 -9
  1419. data/src/core/lib/security/security_connector/tls/tls_security_connector.cc +46 -59
  1420. data/src/core/lib/security/security_connector/tls/tls_security_connector.h +20 -21
  1421. data/src/core/lib/security/transport/auth_filters.h +101 -9
  1422. data/src/core/lib/security/transport/client_auth_filter.cc +113 -32
  1423. data/src/core/lib/security/transport/server_auth_filter.cc +19 -38
  1424. data/src/core/lib/security/util/json_util.cc +4 -5
  1425. data/src/core/lib/security/util/json_util.h +1 -1
  1426. data/src/core/lib/slice/percent_encoding.cc +2 -5
  1427. data/src/core/lib/slice/slice.cc +4 -7
  1428. data/src/core/lib/slice/slice.h +6 -9
  1429. data/src/core/lib/slice/slice_buffer.cc +7 -9
  1430. data/src/core/lib/slice/slice_buffer.h +5 -6
  1431. data/src/core/lib/slice/slice_internal.h +3 -6
  1432. data/src/core/lib/slice/slice_refcount.h +8 -15
  1433. data/src/core/lib/slice/slice_string_helpers.cc +1 -1
  1434. data/src/core/lib/slice/slice_string_helpers.h +1 -2
  1435. data/src/core/lib/surface/byte_buffer.cc +1 -2
  1436. data/src/core/lib/surface/byte_buffer_reader.cc +3 -6
  1437. data/src/core/lib/surface/call.cc +158 -3826
  1438. data/src/core/lib/surface/call.h +67 -160
  1439. data/src/core/lib/surface/call_details.cc +4 -3
  1440. data/src/core/lib/surface/call_log_batch.cc +8 -11
  1441. data/src/core/lib/surface/call_test_only.h +1 -2
  1442. data/src/core/lib/surface/call_utils.cc +231 -0
  1443. data/src/core/lib/surface/call_utils.h +492 -0
  1444. data/src/core/lib/surface/channel.cc +47 -54
  1445. data/src/core/lib/surface/channel.h +24 -22
  1446. data/src/core/lib/surface/channel_create.cc +28 -13
  1447. data/src/core/lib/surface/channel_create.h +5 -5
  1448. data/src/core/lib/surface/channel_init.cc +270 -267
  1449. data/src/core/lib/surface/channel_init.h +173 -119
  1450. data/src/core/lib/surface/client_call.cc +456 -0
  1451. data/src/core/lib/surface/client_call.h +192 -0
  1452. data/src/core/lib/surface/completion_queue.cc +103 -138
  1453. data/src/core/lib/surface/completion_queue.h +4 -13
  1454. data/src/core/lib/surface/completion_queue_factory.cc +1 -3
  1455. data/src/core/lib/surface/connection_context.cc +77 -0
  1456. data/src/core/lib/surface/connection_context.h +156 -0
  1457. data/src/core/lib/surface/event_string.cc +9 -3
  1458. data/src/core/lib/surface/event_string.h +2 -2
  1459. data/src/core/lib/surface/filter_stack_call.cc +1154 -0
  1460. data/src/core/lib/surface/filter_stack_call.h +366 -0
  1461. data/src/core/lib/surface/init.cc +73 -28
  1462. data/src/core/lib/surface/init.h +5 -0
  1463. data/src/core/lib/surface/init_internally.h +13 -2
  1464. data/src/core/lib/surface/lame_client.cc +12 -15
  1465. data/src/core/lib/surface/lame_client.h +6 -5
  1466. data/src/core/lib/surface/legacy_channel.cc +67 -51
  1467. data/src/core/lib/surface/legacy_channel.h +16 -26
  1468. data/src/core/lib/surface/metadata_array.cc +5 -5
  1469. data/src/core/lib/surface/server_call.cc +259 -0
  1470. data/src/core/lib/surface/server_call.h +169 -0
  1471. data/src/core/lib/surface/validate_metadata.cc +3 -4
  1472. data/src/core/lib/surface/validate_metadata.h +2 -5
  1473. data/src/core/lib/surface/version.cc +2 -2
  1474. data/src/core/lib/transport/bdp_estimator.cc +12 -20
  1475. data/src/core/lib/transport/bdp_estimator.h +10 -16
  1476. data/src/core/lib/transport/call_arena_allocator.cc +4 -18
  1477. data/src/core/lib/transport/call_arena_allocator.h +30 -12
  1478. data/src/core/lib/transport/call_destination.h +76 -0
  1479. data/src/core/lib/transport/call_filters.cc +67 -405
  1480. data/src/core/lib/transport/call_filters.h +877 -778
  1481. data/src/core/lib/transport/call_final_info.cc +2 -2
  1482. data/src/core/lib/transport/call_final_info.h +3 -3
  1483. data/src/core/lib/transport/call_spine.cc +58 -74
  1484. data/src/core/lib/transport/call_spine.h +331 -361
  1485. data/src/core/lib/transport/call_state.cc +39 -0
  1486. data/src/core/lib/transport/call_state.h +1154 -0
  1487. data/src/core/lib/transport/connectivity_state.cc +43 -52
  1488. data/src/core/lib/transport/connectivity_state.h +7 -12
  1489. data/src/core/lib/transport/error_utils.cc +3 -4
  1490. data/src/core/lib/transport/error_utils.h +4 -5
  1491. data/src/core/lib/transport/http2_errors.h +5 -3
  1492. data/src/core/lib/transport/interception_chain.cc +155 -0
  1493. data/src/core/lib/transport/interception_chain.h +282 -0
  1494. data/src/core/lib/transport/message.cc +2 -2
  1495. data/src/core/lib/transport/message.h +5 -0
  1496. data/src/core/lib/transport/metadata.cc +27 -3
  1497. data/src/core/lib/transport/metadata.h +125 -2
  1498. data/src/core/lib/transport/metadata_batch.cc +14 -7
  1499. data/src/core/lib/transport/metadata_batch.h +152 -31
  1500. data/src/core/lib/transport/metadata_compression_traits.h +3 -4
  1501. data/src/core/lib/transport/metadata_info.h +1 -1
  1502. data/src/core/lib/transport/parsed_metadata.h +3 -5
  1503. data/src/core/lib/transport/simple_slice_based_metadata.h +1 -2
  1504. data/src/core/lib/transport/status_conversion.h +1 -1
  1505. data/src/core/lib/transport/timeout_encoding.cc +22 -23
  1506. data/src/core/lib/transport/timeout_encoding.h +4 -5
  1507. data/src/core/lib/transport/transport.cc +7 -13
  1508. data/src/core/lib/transport/transport.h +71 -63
  1509. data/src/core/lib/transport/transport_framing_endpoint_extension.h +47 -0
  1510. data/src/core/lib/transport/transport_op_string.cc +4 -6
  1511. data/src/core/load_balancing/address_filtering.cc +2 -4
  1512. data/src/core/load_balancing/address_filtering.h +4 -5
  1513. data/src/core/load_balancing/backend_metric_data.h +2 -2
  1514. data/src/core/load_balancing/backend_metric_parser.cc +22 -30
  1515. data/src/core/load_balancing/backend_metric_parser.h +1 -3
  1516. data/src/core/load_balancing/child_policy_handler.cc +37 -41
  1517. data/src/core/load_balancing/child_policy_handler.h +4 -5
  1518. data/src/core/load_balancing/delegating_helper.h +6 -7
  1519. data/src/core/load_balancing/endpoint_list.cc +23 -15
  1520. data/src/core/load_balancing/endpoint_list.h +27 -22
  1521. data/src/core/load_balancing/grpclb/client_load_reporting_filter.cc +12 -11
  1522. data/src/core/load_balancing/grpclb/client_load_reporting_filter.h +8 -5
  1523. data/src/core/load_balancing/grpclb/grpclb.cc +175 -226
  1524. data/src/core/load_balancing/grpclb/grpclb_balancer_addresses.cc +2 -3
  1525. data/src/core/load_balancing/grpclb/grpclb_client_stats.cc +2 -3
  1526. data/src/core/load_balancing/grpclb/grpclb_client_stats.h +5 -7
  1527. data/src/core/load_balancing/grpclb/load_balancer_api.cc +7 -10
  1528. data/src/core/load_balancing/grpclb/load_balancer_api.h +4 -6
  1529. data/src/core/load_balancing/health_check_client.cc +76 -128
  1530. data/src/core/load_balancing/health_check_client.h +3 -3
  1531. data/src/core/load_balancing/health_check_client_internal.h +15 -16
  1532. data/src/core/load_balancing/lb_policy.cc +9 -14
  1533. data/src/core/load_balancing/lb_policy.h +77 -51
  1534. data/src/core/load_balancing/lb_policy_factory.h +5 -6
  1535. data/src/core/load_balancing/lb_policy_registry.cc +15 -15
  1536. data/src/core/load_balancing/lb_policy_registry.h +5 -6
  1537. data/src/core/load_balancing/oob_backend_metric.cc +19 -25
  1538. data/src/core/load_balancing/oob_backend_metric.h +3 -3
  1539. data/src/core/load_balancing/oob_backend_metric_internal.h +8 -9
  1540. data/src/core/load_balancing/outlier_detection/outlier_detection.cc +191 -247
  1541. data/src/core/load_balancing/outlier_detection/outlier_detection.h +9 -10
  1542. data/src/core/load_balancing/pick_first/pick_first.cc +333 -381
  1543. data/src/core/load_balancing/priority/priority.cc +102 -151
  1544. data/src/core/load_balancing/ring_hash/ring_hash.cc +254 -226
  1545. data/src/core/load_balancing/ring_hash/ring_hash.h +10 -18
  1546. data/src/core/load_balancing/rls/rls.cc +434 -528
  1547. data/src/core/load_balancing/rls/rls.h +97 -1
  1548. data/src/core/load_balancing/round_robin/round_robin.cc +71 -103
  1549. data/src/core/load_balancing/subchannel_interface.h +17 -6
  1550. data/src/core/load_balancing/weighted_round_robin/static_stride_scheduler.cc +8 -9
  1551. data/src/core/load_balancing/weighted_round_robin/static_stride_scheduler.h +4 -5
  1552. data/src/core/load_balancing/weighted_round_robin/weighted_round_robin.cc +159 -185
  1553. data/src/core/load_balancing/weighted_target/weighted_target.cc +79 -123
  1554. data/src/core/load_balancing/xds/cds.cc +65 -85
  1555. data/src/core/load_balancing/xds/xds_cluster_impl.cc +192 -172
  1556. data/src/core/load_balancing/xds/xds_cluster_manager.cc +63 -103
  1557. data/src/core/load_balancing/xds/xds_override_host.cc +163 -272
  1558. data/src/core/load_balancing/xds/xds_override_host.h +6 -7
  1559. data/src/core/load_balancing/xds/xds_wrr_locality.cc +48 -60
  1560. data/src/core/plugin_registry/grpc_plugin_registry.cc +6 -8
  1561. data/src/core/plugin_registry/grpc_plugin_registry_extra.cc +6 -1
  1562. data/src/core/resolver/dns/c_ares/dns_resolver_ares.cc +98 -73
  1563. data/src/core/resolver/dns/c_ares/dns_resolver_ares.h +2 -3
  1564. data/src/core/resolver/dns/c_ares/grpc_ares_ev_driver.h +4 -6
  1565. data/src/core/resolver/dns/c_ares/grpc_ares_ev_driver_posix.cc +2 -6
  1566. data/src/core/resolver/dns/c_ares/grpc_ares_ev_driver_windows.cc +119 -101
  1567. data/src/core/resolver/dns/c_ares/grpc_ares_wrapper.cc +166 -151
  1568. data/src/core/resolver/dns/c_ares/grpc_ares_wrapper.h +4 -18
  1569. data/src/core/resolver/dns/c_ares/grpc_ares_wrapper_windows.cc +1 -1
  1570. data/src/core/resolver/dns/dns_resolver_plugin.cc +10 -11
  1571. data/src/core/resolver/dns/dns_resolver_plugin.h +1 -1
  1572. data/src/core/resolver/dns/event_engine/event_engine_client_channel_resolver.cc +62 -74
  1573. data/src/core/resolver/dns/event_engine/event_engine_client_channel_resolver.h +3 -4
  1574. data/src/core/resolver/dns/event_engine/service_config_helper.cc +8 -10
  1575. data/src/core/resolver/dns/event_engine/service_config_helper.h +2 -2
  1576. data/src/core/resolver/dns/native/dns_resolver.cc +23 -32
  1577. data/src/core/resolver/dns/native/dns_resolver.h +1 -1
  1578. data/src/core/resolver/endpoint_addresses.cc +2 -5
  1579. data/src/core/resolver/endpoint_addresses.h +5 -3
  1580. data/src/core/resolver/fake/fake_resolver.cc +18 -21
  1581. data/src/core/resolver/fake/fake_resolver.h +10 -11
  1582. data/src/core/resolver/google_c2p/google_c2p_resolver.cc +33 -38
  1583. data/src/core/resolver/polling_resolver.cc +41 -60
  1584. data/src/core/resolver/polling_resolver.h +11 -12
  1585. data/src/core/resolver/resolver.cc +2 -6
  1586. data/src/core/resolver/resolver.h +4 -10
  1587. data/src/core/resolver/resolver_factory.h +4 -5
  1588. data/src/core/resolver/resolver_registry.cc +12 -13
  1589. data/src/core/resolver/resolver_registry.h +4 -5
  1590. data/src/core/resolver/sockaddr/sockaddr_resolver.cc +8 -9
  1591. data/src/core/resolver/xds/xds_config.cc +95 -0
  1592. data/src/core/resolver/xds/xds_config.h +108 -0
  1593. data/src/core/resolver/xds/xds_dependency_manager.cc +260 -342
  1594. data/src/core/resolver/xds/xds_dependency_manager.h +34 -89
  1595. data/src/core/resolver/xds/xds_resolver.cc +188 -210
  1596. data/src/core/resolver/xds/xds_resolver_attributes.h +7 -4
  1597. data/src/core/server/server.cc +658 -501
  1598. data/src/core/server/server.h +261 -97
  1599. data/src/core/server/server_call_tracer_filter.cc +22 -25
  1600. data/src/core/server/server_call_tracer_filter.h +1 -1
  1601. data/src/core/server/server_config_selector.h +6 -7
  1602. data/src/core/server/server_config_selector_filter.cc +23 -25
  1603. data/src/core/server/server_interface.h +2 -0
  1604. data/src/core/server/xds_channel_stack_modifier.cc +5 -5
  1605. data/src/core/server/xds_channel_stack_modifier.h +6 -7
  1606. data/src/core/server/xds_server_config_fetcher.cc +147 -223
  1607. data/src/core/service_config/service_config.h +4 -6
  1608. data/src/core/service_config/service_config_call_data.h +21 -20
  1609. data/src/core/service_config/service_config_channel_arg_filter.cc +21 -29
  1610. data/src/core/service_config/service_config_impl.cc +12 -14
  1611. data/src/core/service_config/service_config_impl.h +5 -8
  1612. data/src/core/service_config/service_config_parser.cc +4 -8
  1613. data/src/core/service_config/service_config_parser.h +3 -5
  1614. data/src/core/telemetry/call_tracer.cc +386 -0
  1615. data/src/core/telemetry/call_tracer.h +264 -0
  1616. data/src/core/telemetry/histogram_view.cc +69 -0
  1617. data/src/core/telemetry/histogram_view.h +36 -0
  1618. data/src/core/telemetry/metrics.cc +180 -0
  1619. data/src/core/telemetry/metrics.h +563 -0
  1620. data/src/core/telemetry/stats.cc +67 -0
  1621. data/src/core/telemetry/stats.h +62 -0
  1622. data/src/core/telemetry/stats_data.cc +931 -0
  1623. data/src/core/telemetry/stats_data.h +705 -0
  1624. data/src/core/telemetry/tcp_tracer.h +143 -0
  1625. data/src/core/tsi/alts/crypt/aes_gcm.cc +5 -8
  1626. data/src/core/tsi/alts/crypt/gsec.cc +2 -3
  1627. data/src/core/tsi/alts/crypt/gsec.h +3 -4
  1628. data/src/core/tsi/alts/frame_protector/alts_counter.cc +1 -2
  1629. data/src/core/tsi/alts/frame_protector/alts_counter.h +3 -4
  1630. data/src/core/tsi/alts/frame_protector/alts_crypter.cc +1 -2
  1631. data/src/core/tsi/alts/frame_protector/alts_crypter.h +2 -3
  1632. data/src/core/tsi/alts/frame_protector/alts_frame_protector.cc +16 -18
  1633. data/src/core/tsi/alts/frame_protector/alts_frame_protector.h +1 -2
  1634. data/src/core/tsi/alts/frame_protector/alts_seal_privacy_integrity_crypter.cc +1 -1
  1635. data/src/core/tsi/alts/frame_protector/alts_unseal_privacy_integrity_crypter.cc +1 -1
  1636. data/src/core/tsi/alts/frame_protector/frame_handler.cc +11 -12
  1637. data/src/core/tsi/alts/frame_protector/frame_handler.h +1 -2
  1638. data/src/core/tsi/alts/handshaker/alts_handshaker_client.cc +43 -48
  1639. data/src/core/tsi/alts/handshaker/alts_shared_resource.cc +2 -4
  1640. data/src/core/tsi/alts/handshaker/alts_shared_resource.h +1 -1
  1641. data/src/core/tsi/alts/handshaker/alts_tsi_handshaker.cc +69 -71
  1642. data/src/core/tsi/alts/handshaker/alts_tsi_utils.cc +3 -3
  1643. data/src/core/tsi/alts/handshaker/transport_security_common_api.cc +17 -24
  1644. data/src/core/tsi/alts/handshaker/transport_security_common_api.h +3 -4
  1645. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_integrity_only_record_protocol.cc +14 -17
  1646. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_integrity_only_record_protocol.h +1 -2
  1647. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_privacy_integrity_record_protocol.cc +11 -12
  1648. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_privacy_integrity_record_protocol.h +1 -2
  1649. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_record_protocol_common.cc +9 -11
  1650. data/src/core/tsi/alts/zero_copy_frame_protector/alts_iovec_record_protocol.cc +3 -5
  1651. data/src/core/tsi/alts/zero_copy_frame_protector/alts_iovec_record_protocol.h +1 -2
  1652. data/src/core/tsi/alts/zero_copy_frame_protector/alts_zero_copy_grpc_protector.cc +10 -14
  1653. data/src/core/tsi/alts/zero_copy_frame_protector/alts_zero_copy_grpc_protector.h +1 -2
  1654. data/src/core/tsi/fake_transport_security.cc +32 -32
  1655. data/src/core/tsi/local_transport_security.cc +9 -10
  1656. data/src/core/tsi/ssl/key_logging/ssl_key_logging.cc +9 -12
  1657. data/src/core/tsi/ssl/key_logging/ssl_key_logging.h +8 -10
  1658. data/src/core/tsi/ssl/session_cache/ssl_session.h +4 -5
  1659. data/src/core/tsi/ssl/session_cache/ssl_session_cache.cc +7 -9
  1660. data/src/core/tsi/ssl/session_cache/ssl_session_cache.h +7 -8
  1661. data/src/core/tsi/ssl/session_cache/ssl_session_openssl.cc +2 -4
  1662. data/src/core/tsi/ssl_transport_security.cc +135 -113
  1663. data/src/core/tsi/ssl_transport_security.h +6 -8
  1664. data/src/core/tsi/ssl_transport_security_utils.cc +77 -24
  1665. data/src/core/tsi/ssl_transport_security_utils.h +14 -5
  1666. data/src/core/tsi/ssl_types.h +1 -2
  1667. data/src/core/tsi/transport_security.cc +2 -7
  1668. data/src/core/tsi/transport_security.h +1 -4
  1669. data/src/core/tsi/transport_security_interface.h +3 -8
  1670. data/src/core/util/alloc.cc +69 -0
  1671. data/src/core/util/alloc.h +28 -0
  1672. data/src/core/util/atomic_utils.h +47 -0
  1673. data/src/core/util/avl.h +324 -0
  1674. data/src/core/util/backoff.cc +57 -0
  1675. data/src/core/util/backoff.h +86 -0
  1676. data/src/core/util/bitset.h +224 -0
  1677. data/src/core/util/chunked_vector.h +256 -0
  1678. data/src/core/util/construct_destruct.h +41 -0
  1679. data/src/core/util/cpp_impl_of.h +49 -0
  1680. data/src/core/util/crash.cc +40 -0
  1681. data/src/core/util/crash.h +36 -0
  1682. data/src/core/util/debug_location.h +106 -0
  1683. data/src/core/util/directory_reader.h +48 -0
  1684. data/src/core/util/down_cast.h +48 -0
  1685. data/src/core/util/dual_ref_counted.h +376 -0
  1686. data/src/core/util/dump_args.cc +54 -0
  1687. data/src/core/util/dump_args.h +114 -0
  1688. data/src/core/util/env.h +52 -0
  1689. data/src/core/util/event_log.cc +87 -0
  1690. data/src/core/util/event_log.h +79 -0
  1691. data/src/core/util/examine_stack.cc +43 -0
  1692. data/src/core/util/examine_stack.h +44 -0
  1693. data/src/core/util/fork.cc +241 -0
  1694. data/src/core/util/fork.h +98 -0
  1695. data/src/core/util/gcp_metadata_query.cc +132 -0
  1696. data/src/core/util/gcp_metadata_query.h +86 -0
  1697. data/src/core/util/gethostname.h +26 -0
  1698. data/src/core/util/gethostname_fallback.cc +30 -0
  1699. data/src/core/util/gethostname_host_name_max.cc +39 -0
  1700. data/src/core/util/gethostname_sysconf.cc +39 -0
  1701. data/src/core/util/glob.cc +70 -0
  1702. data/src/core/util/glob.h +29 -0
  1703. data/src/core/util/gpr_time.cc +266 -0
  1704. data/src/core/util/grpc_if_nametoindex.h +29 -0
  1705. data/src/core/util/grpc_if_nametoindex_posix.cc +41 -0
  1706. data/src/core/util/grpc_if_nametoindex_unsupported.cc +36 -0
  1707. data/src/core/util/host_port.cc +114 -0
  1708. data/src/core/util/host_port.h +57 -0
  1709. data/src/core/util/http_client/format_request.cc +134 -0
  1710. data/src/core/util/http_client/format_request.h +37 -0
  1711. data/src/core/util/http_client/httpcli.cc +427 -0
  1712. data/src/core/util/http_client/httpcli.h +279 -0
  1713. data/src/core/util/http_client/httpcli_security_connector.cc +210 -0
  1714. data/src/core/util/http_client/httpcli_ssl_credentials.h +38 -0
  1715. data/src/core/util/http_client/parser.cc +447 -0
  1716. data/src/core/util/http_client/parser.h +126 -0
  1717. data/src/core/util/if_list.h +4530 -0
  1718. data/src/core/util/iphone/cpu.cc +43 -0
  1719. data/src/core/util/json/json.h +29 -0
  1720. data/src/core/util/json/json_args.h +34 -0
  1721. data/src/core/util/json/json_channel_args.h +42 -0
  1722. data/src/core/util/json/json_object_loader.cc +215 -0
  1723. data/src/core/util/json/json_object_loader.h +644 -0
  1724. data/src/core/util/json/json_reader.cc +953 -0
  1725. data/src/core/util/json/json_reader.h +33 -0
  1726. data/src/core/util/json/json_util.cc +101 -0
  1727. data/src/core/util/json/json_util.h +163 -0
  1728. data/src/core/util/json/json_writer.cc +337 -0
  1729. data/src/core/util/json/json_writer.h +33 -0
  1730. data/src/core/util/latent_see.cc +163 -0
  1731. data/src/core/util/latent_see.h +334 -0
  1732. data/src/core/util/linux/cpu.cc +86 -0
  1733. data/src/core/util/linux/env.cc +61 -0
  1734. data/src/core/util/load_file.cc +75 -0
  1735. data/src/core/util/load_file.h +33 -0
  1736. data/src/core/util/log.cc +127 -0
  1737. data/src/core/util/lru_cache.h +122 -0
  1738. data/src/core/util/manual_constructor.h +145 -0
  1739. data/src/core/util/match.h +74 -0
  1740. data/src/core/util/matchers.cc +336 -0
  1741. data/src/core/util/matchers.h +162 -0
  1742. data/src/core/util/memory.h +52 -0
  1743. data/src/core/util/mpscq.cc +108 -0
  1744. data/src/core/util/mpscq.h +98 -0
  1745. data/src/core/util/msys/tmpfile.cc +57 -0
  1746. data/src/core/util/no_destruct.h +95 -0
  1747. data/src/core/util/notification.h +66 -0
  1748. data/src/core/util/orphanable.h +153 -0
  1749. data/src/core/util/overload.h +59 -0
  1750. data/src/core/util/packed_table.h +40 -0
  1751. data/src/core/util/per_cpu.cc +34 -0
  1752. data/src/core/util/per_cpu.h +102 -0
  1753. data/src/core/util/posix/cpu.cc +83 -0
  1754. data/src/core/util/posix/directory_reader.cc +82 -0
  1755. data/src/core/util/posix/env.cc +47 -0
  1756. data/src/core/util/posix/stat.cc +54 -0
  1757. data/src/core/util/posix/string.cc +71 -0
  1758. data/src/core/util/posix/sync.cc +157 -0
  1759. data/src/core/util/posix/thd.cc +243 -0
  1760. data/src/core/util/posix/time.cc +122 -0
  1761. data/src/core/util/posix/tmpfile.cc +71 -0
  1762. data/src/core/util/random_early_detection.cc +33 -0
  1763. data/src/core/util/random_early_detection.h +61 -0
  1764. data/src/core/util/ref_counted.h +403 -0
  1765. data/src/core/util/ref_counted_ptr.h +443 -0
  1766. data/src/core/util/ref_counted_string.cc +42 -0
  1767. data/src/core/util/ref_counted_string.h +159 -0
  1768. data/src/core/util/ring_buffer.h +122 -0
  1769. data/src/core/util/single_set_ptr.h +89 -0
  1770. data/src/core/util/sorted_pack.h +89 -0
  1771. data/src/core/util/spinlock.h +51 -0
  1772. data/src/core/util/stat.h +35 -0
  1773. data/src/core/util/status_helper.cc +427 -0
  1774. data/src/core/util/status_helper.h +160 -0
  1775. data/src/core/util/strerror.cc +40 -0
  1776. data/src/core/util/strerror.h +29 -0
  1777. data/src/core/util/string.cc +341 -0
  1778. data/src/core/util/string.h +110 -0
  1779. data/src/core/util/sync.cc +123 -0
  1780. data/src/core/util/sync.h +199 -0
  1781. data/src/core/util/sync_abseil.cc +106 -0
  1782. data/src/core/util/table.h +471 -0
  1783. data/src/core/util/tchar.cc +49 -0
  1784. data/src/core/util/tchar.h +33 -0
  1785. data/src/core/util/thd.h +193 -0
  1786. data/src/core/util/time.cc +240 -0
  1787. data/src/core/util/time.h +385 -0
  1788. data/src/core/util/time_averaged_stats.cc +60 -0
  1789. data/src/core/util/time_averaged_stats.h +79 -0
  1790. data/src/core/util/time_precise.cc +167 -0
  1791. data/src/core/util/time_precise.h +68 -0
  1792. data/src/core/util/time_util.cc +80 -0
  1793. data/src/core/util/time_util.h +41 -0
  1794. data/src/core/util/tmpfile.h +31 -0
  1795. data/src/core/util/type_list.h +88 -0
  1796. data/src/core/util/unique_ptr_with_bitset.h +86 -0
  1797. data/src/core/util/unique_type_name.h +123 -0
  1798. data/src/core/util/upb_utils.h +43 -0
  1799. data/src/core/util/uri.cc +378 -0
  1800. data/src/core/util/uri.h +112 -0
  1801. data/src/core/util/useful.h +153 -0
  1802. data/src/core/util/uuid_v4.cc +37 -0
  1803. data/src/core/util/uuid_v4.h +35 -0
  1804. data/src/core/util/validation_errors.cc +73 -0
  1805. data/src/core/util/validation_errors.h +144 -0
  1806. data/src/core/util/wait_for_single_owner.h +62 -0
  1807. data/src/core/util/windows/cpu.cc +34 -0
  1808. data/src/core/util/windows/directory_reader.cc +79 -0
  1809. data/src/core/util/windows/env.cc +56 -0
  1810. data/src/core/util/windows/stat.cc +50 -0
  1811. data/src/core/util/windows/string.cc +68 -0
  1812. data/src/core/util/windows/string_util.cc +53 -0
  1813. data/src/core/util/windows/sync.cc +121 -0
  1814. data/src/core/util/windows/thd.cc +182 -0
  1815. data/src/core/util/windows/time.cc +104 -0
  1816. data/src/core/util/windows/tmpfile.cc +66 -0
  1817. data/src/core/util/work_serializer.cc +298 -0
  1818. data/src/core/util/work_serializer.h +81 -0
  1819. data/src/core/util/xxhash_inline.h +29 -0
  1820. data/src/core/xds/grpc/certificate_provider_store.cc +15 -21
  1821. data/src/core/xds/grpc/certificate_provider_store.h +13 -14
  1822. data/src/core/xds/grpc/file_watcher_certificate_provider_factory.cc +8 -9
  1823. data/src/core/xds/grpc/file_watcher_certificate_provider_factory.h +9 -10
  1824. data/src/core/xds/grpc/xds_audit_logger_registry.cc +6 -6
  1825. data/src/core/xds/grpc/xds_audit_logger_registry.h +4 -5
  1826. data/src/core/xds/grpc/xds_bootstrap_grpc.cc +18 -179
  1827. data/src/core/xds/grpc/xds_bootstrap_grpc.h +11 -41
  1828. data/src/core/xds/grpc/xds_certificate_provider.cc +19 -20
  1829. data/src/core/xds/grpc/xds_certificate_provider.h +12 -11
  1830. data/src/core/xds/grpc/xds_client_grpc.cc +104 -83
  1831. data/src/core/xds/grpc/xds_client_grpc.h +16 -10
  1832. data/src/core/xds/grpc/xds_cluster.cc +12 -737
  1833. data/src/core/xds/grpc/xds_cluster.h +40 -49
  1834. data/src/core/xds/grpc/xds_cluster_parser.cc +772 -0
  1835. data/src/core/xds/grpc/xds_cluster_parser.h +61 -0
  1836. data/src/core/xds/grpc/xds_cluster_specifier_plugin.cc +10 -13
  1837. data/src/core/xds/grpc/xds_cluster_specifier_plugin.h +5 -6
  1838. data/src/core/xds/grpc/xds_common_types.cc +33 -438
  1839. data/src/core/xds/grpc/xds_common_types.h +12 -30
  1840. data/src/core/xds/grpc/xds_common_types_parser.cc +501 -0
  1841. data/src/core/xds/grpc/xds_common_types_parser.h +77 -0
  1842. data/src/core/xds/grpc/xds_endpoint.cc +3 -424
  1843. data/src/core/xds/grpc/xds_endpoint.h +7 -29
  1844. data/src/core/xds/grpc/xds_endpoint_parser.cc +475 -0
  1845. data/src/core/xds/grpc/xds_endpoint_parser.h +47 -0
  1846. data/src/core/xds/grpc/xds_health_status.cc +4 -6
  1847. data/src/core/xds/grpc/xds_health_status.h +4 -6
  1848. data/src/core/xds/grpc/xds_http_fault_filter.cc +46 -36
  1849. data/src/core/xds/grpc/xds_http_fault_filter.h +15 -10
  1850. data/src/core/xds/grpc/xds_http_filter.h +134 -0
  1851. data/src/core/xds/grpc/xds_http_filter_registry.cc +122 -0
  1852. data/src/core/xds/grpc/xds_http_filter_registry.h +104 -0
  1853. data/src/core/xds/grpc/xds_http_gcp_authn_filter.cc +141 -0
  1854. data/src/core/xds/grpc/xds_http_gcp_authn_filter.h +61 -0
  1855. data/src/core/xds/grpc/xds_http_rbac_filter.cc +93 -71
  1856. data/src/core/xds/grpc/xds_http_rbac_filter.h +15 -10
  1857. data/src/core/xds/grpc/xds_http_stateful_session_filter.cc +34 -21
  1858. data/src/core/xds/grpc/xds_http_stateful_session_filter.h +15 -10
  1859. data/src/core/xds/grpc/xds_lb_policy_registry.cc +27 -32
  1860. data/src/core/xds/grpc/xds_lb_policy_registry.h +5 -6
  1861. data/src/core/xds/grpc/xds_listener.cc +20 -989
  1862. data/src/core/xds/grpc/xds_listener.h +12 -45
  1863. data/src/core/xds/grpc/xds_listener_parser.cc +1000 -0
  1864. data/src/core/xds/grpc/xds_listener_parser.h +60 -0
  1865. data/src/core/xds/grpc/xds_metadata.cc +62 -0
  1866. data/src/core/xds/grpc/xds_metadata.h +158 -0
  1867. data/src/core/xds/grpc/xds_metadata_parser.cc +197 -0
  1868. data/src/core/xds/grpc/xds_metadata_parser.h +35 -0
  1869. data/src/core/xds/grpc/xds_route_config.cc +12 -934
  1870. data/src/core/xds/grpc/xds_route_config.h +17 -50
  1871. data/src/core/xds/grpc/xds_route_config_parser.cc +960 -0
  1872. data/src/core/xds/grpc/xds_route_config_parser.h +77 -0
  1873. data/src/core/xds/grpc/xds_routing.cc +66 -33
  1874. data/src/core/xds/grpc/xds_routing.h +17 -11
  1875. data/src/core/xds/grpc/xds_server_grpc.cc +181 -0
  1876. data/src/core/xds/grpc/xds_server_grpc.h +66 -0
  1877. data/src/core/xds/grpc/xds_server_grpc_interface.h +33 -0
  1878. data/src/core/xds/grpc/xds_transport_grpc.cc +101 -59
  1879. data/src/core/xds/grpc/xds_transport_grpc.h +34 -23
  1880. data/src/core/xds/xds_client/lrs_client.cc +1280 -0
  1881. data/src/core/xds/xds_client/lrs_client.h +394 -0
  1882. data/src/core/xds/xds_client/xds_api.cc +28 -469
  1883. data/src/core/xds/xds_client/xds_api.h +6 -161
  1884. data/src/core/xds/xds_client/xds_backend_metric_propagation.cc +63 -0
  1885. data/src/core/xds/xds_client/xds_backend_metric_propagation.h +59 -0
  1886. data/src/core/xds/xds_client/xds_bootstrap.cc +13 -4
  1887. data/src/core/xds/xds_client/xds_bootstrap.h +10 -3
  1888. data/src/core/xds/xds_client/xds_client.cc +1122 -1414
  1889. data/src/core/xds/xds_client/xds_client.h +167 -117
  1890. data/src/core/xds/xds_client/xds_locality.h +102 -0
  1891. data/src/core/xds/xds_client/xds_metrics.h +2 -2
  1892. data/src/core/xds/xds_client/xds_resource_type.h +6 -8
  1893. data/src/core/xds/xds_client/xds_resource_type_impl.h +15 -11
  1894. data/src/core/xds/xds_client/xds_transport.h +29 -14
  1895. data/src/ruby/bin/math_pb.rb +1 -22
  1896. data/src/ruby/ext/grpc/extconf.rb +2 -1
  1897. data/src/ruby/ext/grpc/rb_byte_buffer.c +3 -3
  1898. data/src/ruby/ext/grpc/rb_call.c +15 -8
  1899. data/src/ruby/ext/grpc/rb_call_credentials.c +39 -33
  1900. data/src/ruby/ext/grpc/rb_channel.c +42 -37
  1901. data/src/ruby/ext/grpc/rb_channel_args.c +4 -4
  1902. data/src/ruby/ext/grpc/rb_channel_credentials.c +5 -6
  1903. data/src/ruby/ext/grpc/rb_channel_credentials.h +1 -2
  1904. data/src/ruby/ext/grpc/rb_completion_queue.c +18 -36
  1905. data/src/ruby/ext/grpc/rb_completion_queue.h +7 -1
  1906. data/src/ruby/ext/grpc/rb_compression_options.c +9 -10
  1907. data/src/ruby/ext/grpc/rb_event_thread.c +9 -9
  1908. data/src/ruby/ext/grpc/rb_grpc.c +16 -16
  1909. data/src/ruby/ext/grpc/rb_grpc.h +8 -1
  1910. data/src/ruby/ext/grpc/rb_grpc_imports.generated.c +6 -14
  1911. data/src/ruby/ext/grpc/rb_grpc_imports.generated.h +9 -21
  1912. data/src/ruby/ext/grpc/rb_server.c +47 -28
  1913. data/src/ruby/ext/grpc/rb_server_credentials.c +3 -3
  1914. data/src/ruby/ext/grpc/rb_server_credentials.h +1 -2
  1915. data/src/ruby/ext/grpc/rb_xds_channel_credentials.c +5 -6
  1916. data/src/ruby/ext/grpc/rb_xds_channel_credentials.h +1 -2
  1917. data/src/ruby/ext/grpc/rb_xds_server_credentials.c +4 -4
  1918. data/src/ruby/ext/grpc/rb_xds_server_credentials.h +1 -2
  1919. data/src/ruby/lib/grpc/generic/active_call.rb +8 -5
  1920. data/src/ruby/lib/grpc/logconfig.rb +13 -0
  1921. data/src/ruby/lib/grpc/version.rb +1 -1
  1922. data/src/ruby/pb/grpc/health/v1/health_pb.rb +1 -22
  1923. data/src/ruby/pb/grpc/testing/duplicate/echo_duplicate_services_pb.rb +5 -5
  1924. data/src/ruby/pb/grpc/testing/metrics_pb.rb +10 -19
  1925. data/src/ruby/pb/grpc/testing/metrics_services_pb.rb +5 -5
  1926. data/src/ruby/pb/src/proto/grpc/testing/empty_pb.rb +1 -22
  1927. data/src/ruby/pb/src/proto/grpc/testing/messages_pb.rb +1 -22
  1928. data/src/ruby/pb/src/proto/grpc/testing/test_pb.rb +1 -22
  1929. data/src/ruby/spec/call_spec.rb +53 -40
  1930. data/src/ruby/spec/channel_spec.rb +4 -2
  1931. data/src/ruby/spec/client_server_spec.rb +148 -507
  1932. data/src/ruby/spec/generic/active_call_spec.rb +64 -86
  1933. data/src/ruby/spec/generic/client_stub_spec.rb +20 -20
  1934. data/src/ruby/spec/logconfig_spec.rb +30 -0
  1935. data/src/ruby/spec/support/services.rb +3 -0
  1936. data/third_party/abseil-cpp/absl/algorithm/container.h +57 -18
  1937. data/third_party/abseil-cpp/absl/base/attributes.h +84 -0
  1938. data/third_party/abseil-cpp/absl/base/config.h +32 -51
  1939. data/third_party/abseil-cpp/absl/base/dynamic_annotations.h +0 -16
  1940. data/third_party/abseil-cpp/absl/base/internal/nullability_impl.h +3 -1
  1941. data/third_party/abseil-cpp/absl/base/internal/spinlock.h +13 -3
  1942. data/third_party/abseil-cpp/absl/base/internal/unscaledcycleclock.cc +0 -12
  1943. data/third_party/abseil-cpp/absl/base/internal/unscaledcycleclock_config.h +4 -4
  1944. data/third_party/abseil-cpp/absl/base/macros.h +48 -0
  1945. data/third_party/abseil-cpp/absl/base/no_destructor.h +35 -40
  1946. data/third_party/abseil-cpp/absl/base/nullability.h +33 -7
  1947. data/third_party/abseil-cpp/absl/base/optimization.h +11 -0
  1948. data/third_party/abseil-cpp/absl/base/options.h +1 -1
  1949. data/third_party/abseil-cpp/absl/base/prefetch.h +1 -1
  1950. data/third_party/abseil-cpp/absl/container/flat_hash_map.h +68 -12
  1951. data/third_party/abseil-cpp/absl/container/flat_hash_set.h +60 -6
  1952. data/third_party/abseil-cpp/absl/container/hash_container_defaults.h +45 -0
  1953. data/third_party/abseil-cpp/absl/container/inlined_vector.h +13 -0
  1954. data/third_party/abseil-cpp/absl/container/internal/common_policy_traits.h +20 -11
  1955. data/third_party/abseil-cpp/absl/container/internal/compressed_tuple.h +15 -16
  1956. data/third_party/abseil-cpp/absl/container/internal/container_memory.h +34 -1
  1957. data/third_party/abseil-cpp/absl/container/internal/hash_function_defaults.h +68 -1
  1958. data/third_party/abseil-cpp/absl/container/internal/hash_policy_traits.h +50 -0
  1959. data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler.cc +22 -7
  1960. data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler.h +26 -8
  1961. data/third_party/abseil-cpp/absl/container/internal/inlined_vector.h +39 -35
  1962. data/third_party/abseil-cpp/absl/container/internal/layout.h +190 -74
  1963. data/third_party/abseil-cpp/absl/container/internal/raw_hash_map.h +8 -6
  1964. data/third_party/abseil-cpp/absl/container/internal/raw_hash_set.cc +334 -71
  1965. data/third_party/abseil-cpp/absl/container/internal/raw_hash_set.h +1299 -458
  1966. data/third_party/abseil-cpp/absl/crc/internal/crc32_x86_arm_combined_simd.h +19 -17
  1967. data/third_party/abseil-cpp/absl/crc/internal/crc_cord_state.cc +4 -3
  1968. data/third_party/abseil-cpp/absl/crc/internal/crc_memcpy_fallback.cc +2 -1
  1969. data/third_party/abseil-cpp/absl/crc/internal/crc_memcpy_x86_arm_combined.cc +12 -8
  1970. data/third_party/abseil-cpp/absl/crc/internal/crc_non_temporal_memcpy.cc +1 -1
  1971. data/third_party/abseil-cpp/absl/crc/internal/crc_x86_arm_combined.cc +11 -7
  1972. data/third_party/abseil-cpp/absl/crc/internal/non_temporal_memcpy.h +18 -17
  1973. data/third_party/abseil-cpp/absl/debugging/internal/bounded_utf8_length_sequence.h +126 -0
  1974. data/third_party/abseil-cpp/absl/debugging/internal/decode_rust_punycode.cc +258 -0
  1975. data/third_party/abseil-cpp/absl/debugging/internal/decode_rust_punycode.h +55 -0
  1976. data/third_party/abseil-cpp/absl/debugging/internal/demangle.cc +1057 -86
  1977. data/third_party/abseil-cpp/absl/debugging/internal/demangle.h +3 -0
  1978. data/third_party/abseil-cpp/absl/debugging/internal/demangle_rust.cc +925 -0
  1979. data/third_party/abseil-cpp/absl/debugging/internal/demangle_rust.h +42 -0
  1980. data/third_party/abseil-cpp/absl/debugging/internal/elf_mem_image.cc +43 -16
  1981. data/third_party/abseil-cpp/absl/debugging/internal/elf_mem_image.h +8 -7
  1982. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_aarch64-inl.inc +10 -7
  1983. data/third_party/abseil-cpp/absl/debugging/internal/utf8_for_code_point.cc +70 -0
  1984. data/third_party/abseil-cpp/absl/debugging/internal/utf8_for_code_point.h +47 -0
  1985. data/third_party/abseil-cpp/absl/flags/commandlineflag.h +11 -0
  1986. data/third_party/abseil-cpp/absl/flags/flag.h +2 -0
  1987. data/third_party/abseil-cpp/absl/flags/internal/flag.cc +117 -30
  1988. data/third_party/abseil-cpp/absl/flags/internal/flag.h +192 -30
  1989. data/third_party/abseil-cpp/absl/flags/reflection.cc +10 -0
  1990. data/third_party/abseil-cpp/absl/functional/any_invocable.h +13 -3
  1991. data/third_party/abseil-cpp/absl/functional/bind_front.h +3 -2
  1992. data/third_party/abseil-cpp/absl/functional/internal/any_invocable.h +7 -7
  1993. data/third_party/abseil-cpp/absl/functional/internal/front_binder.h +9 -9
  1994. data/third_party/abseil-cpp/absl/hash/internal/hash.cc +1 -1
  1995. data/third_party/abseil-cpp/absl/hash/internal/hash.h +13 -3
  1996. data/third_party/abseil-cpp/absl/hash/internal/low_level_hash.cc +60 -28
  1997. data/third_party/abseil-cpp/absl/hash/internal/low_level_hash.h +4 -0
  1998. data/third_party/abseil-cpp/absl/log/absl_vlog_is_on.h +3 -3
  1999. data/third_party/abseil-cpp/absl/log/globals.h +28 -15
  2000. data/third_party/abseil-cpp/absl/log/internal/check_op.cc +20 -0
  2001. data/third_party/abseil-cpp/absl/log/internal/check_op.h +63 -21
  2002. data/third_party/abseil-cpp/absl/log/internal/conditions.h +2 -2
  2003. data/third_party/abseil-cpp/absl/log/internal/log_impl.h +23 -23
  2004. data/third_party/abseil-cpp/absl/log/internal/log_message.cc +104 -47
  2005. data/third_party/abseil-cpp/absl/log/internal/log_message.h +23 -4
  2006. data/third_party/abseil-cpp/absl/log/internal/nullstream.h +1 -10
  2007. data/third_party/abseil-cpp/absl/log/internal/strip.h +36 -0
  2008. data/third_party/abseil-cpp/absl/log/log.h +5 -1
  2009. data/third_party/abseil-cpp/absl/log/log_sink.h +11 -4
  2010. data/third_party/abseil-cpp/absl/log/vlog_is_on.h +3 -3
  2011. data/third_party/abseil-cpp/absl/meta/type_traits.h +138 -42
  2012. data/third_party/abseil-cpp/absl/numeric/int128.cc +0 -3
  2013. data/third_party/abseil-cpp/absl/numeric/int128.h +35 -5
  2014. data/third_party/abseil-cpp/absl/numeric/int128_have_intrinsic.inc +14 -0
  2015. data/third_party/abseil-cpp/absl/numeric/int128_no_intrinsic.inc +18 -0
  2016. data/third_party/abseil-cpp/absl/numeric/internal/bits.h +6 -2
  2017. data/third_party/abseil-cpp/absl/random/beta_distribution.h +8 -8
  2018. data/third_party/abseil-cpp/absl/random/bit_gen_ref.h +9 -7
  2019. data/third_party/abseil-cpp/absl/random/distributions.h +11 -11
  2020. data/third_party/abseil-cpp/absl/random/seed_sequences.h +2 -0
  2021. data/third_party/abseil-cpp/absl/status/internal/statusor_internal.h +61 -2
  2022. data/third_party/abseil-cpp/absl/status/status.cc +0 -4
  2023. data/third_party/abseil-cpp/absl/status/status.h +4 -4
  2024. data/third_party/abseil-cpp/absl/status/statusor.h +108 -142
  2025. data/third_party/abseil-cpp/absl/strings/ascii.cc +32 -71
  2026. data/third_party/abseil-cpp/absl/strings/cord.cc +20 -15
  2027. data/third_party/abseil-cpp/absl/strings/cord.h +68 -7
  2028. data/third_party/abseil-cpp/absl/strings/escaping.cc +96 -21
  2029. data/third_party/abseil-cpp/absl/strings/escaping.h +25 -8
  2030. data/third_party/abseil-cpp/absl/strings/has_absl_stringify.h +1 -0
  2031. data/third_party/abseil-cpp/absl/strings/internal/charconv_bigint.h +10 -0
  2032. data/third_party/abseil-cpp/absl/strings/internal/cord_internal.h +29 -9
  2033. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree.h +2 -2
  2034. data/third_party/abseil-cpp/absl/strings/internal/cordz_functions.cc +19 -13
  2035. data/third_party/abseil-cpp/absl/strings/internal/cordz_functions.h +23 -13
  2036. data/third_party/abseil-cpp/absl/strings/internal/cordz_handle.cc +24 -24
  2037. data/third_party/abseil-cpp/absl/strings/internal/cordz_info.cc +12 -7
  2038. data/third_party/abseil-cpp/absl/strings/internal/cordz_info.h +9 -4
  2039. data/third_party/abseil-cpp/absl/strings/internal/escaping.cc +5 -2
  2040. data/third_party/abseil-cpp/absl/strings/internal/str_join_internal.h +23 -2
  2041. data/third_party/abseil-cpp/absl/strings/internal/str_split_internal.h +5 -1
  2042. data/third_party/abseil-cpp/absl/strings/numbers.cc +107 -333
  2043. data/third_party/abseil-cpp/absl/strings/numbers.h +12 -151
  2044. data/third_party/abseil-cpp/absl/strings/str_cat.cc +49 -142
  2045. data/third_party/abseil-cpp/absl/strings/str_cat.h +70 -85
  2046. data/third_party/abseil-cpp/absl/strings/str_format.h +1 -1
  2047. data/third_party/abseil-cpp/absl/strings/str_join.h +19 -5
  2048. data/third_party/abseil-cpp/absl/strings/str_split.h +2 -2
  2049. data/third_party/abseil-cpp/absl/strings/string_view.h +3 -2
  2050. data/third_party/abseil-cpp/absl/strings/substitute.cc +4 -0
  2051. data/third_party/abseil-cpp/absl/synchronization/internal/graphcycles.cc +11 -2
  2052. data/third_party/abseil-cpp/absl/synchronization/internal/graphcycles.h +5 -0
  2053. data/third_party/abseil-cpp/absl/synchronization/mutex.h +5 -4
  2054. data/third_party/abseil-cpp/absl/time/civil_time.h +2 -2
  2055. data/third_party/abseil-cpp/absl/time/clock.cc +15 -1
  2056. data/third_party/abseil-cpp/absl/time/duration.cc +58 -53
  2057. data/third_party/abseil-cpp/absl/time/format.cc +2 -1
  2058. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_libc.cc +1 -1
  2059. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_lookup.cc +0 -29
  2060. data/third_party/abseil-cpp/absl/time/internal/cctz/src/tzfile.h +3 -3
  2061. data/third_party/abseil-cpp/absl/time/time.h +73 -29
  2062. data/third_party/abseil-cpp/absl/types/compare.h +505 -0
  2063. data/third_party/abseil-cpp/absl/types/internal/optional.h +2 -2
  2064. data/third_party/abseil-cpp/absl/types/internal/variant.h +55 -67
  2065. data/third_party/abseil-cpp/absl/types/optional.h +15 -18
  2066. data/third_party/abseil-cpp/absl/types/span.h +3 -2
  2067. data/third_party/abseil-cpp/absl/types/variant.h +19 -24
  2068. data/third_party/abseil-cpp/absl/utility/utility.h +3 -41
  2069. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_bitstr.cc +243 -0
  2070. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_bool.cc +53 -0
  2071. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_d2i_fp.cc +47 -0
  2072. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_dup.cc +42 -0
  2073. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_gentm.cc +109 -0
  2074. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_i2d_fp.cc +43 -0
  2075. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_int.cc +424 -0
  2076. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_mbstr.cc +239 -0
  2077. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_object.cc +193 -0
  2078. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_octet.cc +32 -0
  2079. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_strex.cc +415 -0
  2080. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_strnid.cc +206 -0
  2081. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_time.cc +224 -0
  2082. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_type.cc +172 -0
  2083. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_utctm.cc +109 -0
  2084. data/third_party/boringssl-with-bazel/src/crypto/asn1/asn1_lib.cc +355 -0
  2085. data/third_party/boringssl-with-bazel/src/crypto/asn1/asn1_par.cc +61 -0
  2086. data/third_party/boringssl-with-bazel/src/crypto/asn1/asn_pack.cc +56 -0
  2087. data/third_party/boringssl-with-bazel/src/crypto/asn1/f_int.cc +63 -0
  2088. data/third_party/boringssl-with-bazel/src/crypto/asn1/f_string.cc +52 -0
  2089. data/third_party/boringssl-with-bazel/src/crypto/asn1/internal.h +13 -57
  2090. data/third_party/boringssl-with-bazel/src/crypto/asn1/posix_time.cc +241 -0
  2091. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_dec.cc +932 -0
  2092. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_enc.cc +669 -0
  2093. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_fre.cc +164 -0
  2094. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_new.cc +276 -0
  2095. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_typ.cc +84 -0
  2096. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_utl.cc +229 -0
  2097. data/third_party/boringssl-with-bazel/src/crypto/base64/base64.cc +434 -0
  2098. data/third_party/boringssl-with-bazel/src/crypto/bcm_support.h +119 -0
  2099. data/third_party/boringssl-with-bazel/src/crypto/bio/bio.cc +658 -0
  2100. data/third_party/boringssl-with-bazel/src/crypto/bio/bio_mem.cc +268 -0
  2101. data/third_party/boringssl-with-bazel/src/crypto/bio/connect.cc +511 -0
  2102. data/third_party/boringssl-with-bazel/src/crypto/bio/errno.cc +50 -0
  2103. data/third_party/boringssl-with-bazel/src/crypto/bio/fd.cc +193 -0
  2104. data/third_party/boringssl-with-bazel/src/crypto/bio/file.cc +292 -0
  2105. data/third_party/boringssl-with-bazel/src/crypto/bio/hexdump.cc +152 -0
  2106. data/third_party/boringssl-with-bazel/src/crypto/bio/internal.h +13 -55
  2107. data/third_party/boringssl-with-bazel/src/crypto/bio/pair.cc +446 -0
  2108. data/third_party/boringssl-with-bazel/src/crypto/bio/printf.cc +59 -0
  2109. data/third_party/boringssl-with-bazel/src/crypto/bio/socket.cc +147 -0
  2110. data/third_party/boringssl-with-bazel/src/crypto/bio/socket_helper.cc +133 -0
  2111. data/third_party/boringssl-with-bazel/src/crypto/blake2/blake2.cc +169 -0
  2112. data/third_party/boringssl-with-bazel/src/crypto/bn/bn_asn1.cc +57 -0
  2113. data/third_party/boringssl-with-bazel/src/crypto/bn/convert.cc +423 -0
  2114. data/third_party/boringssl-with-bazel/src/crypto/buf/buf.cc +118 -0
  2115. data/third_party/boringssl-with-bazel/src/crypto/bytestring/asn1_compat.cc +53 -0
  2116. data/third_party/boringssl-with-bazel/src/crypto/bytestring/ber.cc +266 -0
  2117. data/third_party/boringssl-with-bazel/src/crypto/bytestring/cbb.cc +702 -0
  2118. data/third_party/boringssl-with-bazel/src/crypto/bytestring/cbs.cc +912 -0
  2119. data/third_party/boringssl-with-bazel/src/crypto/bytestring/internal.h +13 -13
  2120. data/third_party/boringssl-with-bazel/src/crypto/bytestring/unicode.cc +156 -0
  2121. data/third_party/boringssl-with-bazel/src/crypto/chacha/chacha.cc +224 -0
  2122. data/third_party/boringssl-with-bazel/src/crypto/chacha/internal.h +18 -18
  2123. data/third_party/boringssl-with-bazel/src/crypto/cipher/derive_key.cc +110 -0
  2124. data/third_party/boringssl-with-bazel/src/crypto/cipher/e_aesctrhmac.cc +279 -0
  2125. data/third_party/boringssl-with-bazel/src/crypto/cipher/e_aesgcmsiv.cc +845 -0
  2126. data/third_party/boringssl-with-bazel/src/crypto/cipher/e_chacha20poly1305.cc +341 -0
  2127. data/third_party/boringssl-with-bazel/src/crypto/cipher/e_des.cc +198 -0
  2128. data/third_party/boringssl-with-bazel/src/crypto/cipher/e_null.cc +51 -0
  2129. data/third_party/boringssl-with-bazel/src/crypto/cipher/e_rc2.cc +417 -0
  2130. data/third_party/boringssl-with-bazel/src/crypto/cipher/e_rc4.cc +54 -0
  2131. data/third_party/boringssl-with-bazel/src/crypto/cipher/e_tls.cc +599 -0
  2132. data/third_party/boringssl-with-bazel/src/crypto/cipher/get_cipher.cc +85 -0
  2133. data/third_party/boringssl-with-bazel/src/crypto/cipher/internal.h +240 -0
  2134. data/third_party/boringssl-with-bazel/src/crypto/cipher/tls_cbc.cc +476 -0
  2135. data/third_party/boringssl-with-bazel/src/crypto/conf/conf.cc +631 -0
  2136. data/third_party/boringssl-with-bazel/src/crypto/conf/internal.h +13 -13
  2137. data/third_party/boringssl-with-bazel/src/crypto/cpu_aarch64_apple.cc +75 -0
  2138. data/third_party/boringssl-with-bazel/src/crypto/cpu_aarch64_fuchsia.cc +55 -0
  2139. data/third_party/boringssl-with-bazel/src/crypto/cpu_aarch64_linux.cc +62 -0
  2140. data/third_party/boringssl-with-bazel/src/crypto/cpu_aarch64_openbsd.cc +61 -0
  2141. data/third_party/boringssl-with-bazel/src/crypto/cpu_aarch64_sysreg.cc +94 -0
  2142. data/third_party/boringssl-with-bazel/src/crypto/cpu_aarch64_win.cc +41 -0
  2143. data/third_party/boringssl-with-bazel/src/crypto/cpu_arm_freebsd.cc +54 -0
  2144. data/third_party/boringssl-with-bazel/src/crypto/cpu_arm_linux.cc +151 -0
  2145. data/third_party/boringssl-with-bazel/src/crypto/cpu_arm_linux.h +13 -13
  2146. data/third_party/boringssl-with-bazel/src/crypto/cpu_intel.cc +287 -0
  2147. data/third_party/boringssl-with-bazel/src/crypto/crypto.cc +183 -0
  2148. data/third_party/boringssl-with-bazel/src/crypto/curve25519/curve25519.cc +2154 -0
  2149. data/third_party/boringssl-with-bazel/src/crypto/curve25519/curve25519_64_adx.cc +18 -0
  2150. data/third_party/boringssl-with-bazel/src/crypto/curve25519/curve25519_tables.h +13 -13
  2151. data/third_party/boringssl-with-bazel/src/crypto/curve25519/internal.h +13 -13
  2152. data/third_party/boringssl-with-bazel/src/crypto/curve25519/spake25519.cc +529 -0
  2153. data/third_party/boringssl-with-bazel/src/crypto/des/des.cc +829 -0
  2154. data/third_party/boringssl-with-bazel/src/crypto/des/internal.h +27 -69
  2155. data/third_party/boringssl-with-bazel/src/crypto/dh/dh_asn1.cc +124 -0
  2156. data/third_party/boringssl-with-bazel/src/crypto/dh/params.cc +442 -0
  2157. data/third_party/boringssl-with-bazel/src/crypto/digest/digest_extra.cc +306 -0
  2158. data/third_party/boringssl-with-bazel/src/crypto/dsa/dsa.cc +951 -0
  2159. data/third_party/boringssl-with-bazel/src/crypto/dsa/dsa_asn1.cc +379 -0
  2160. data/third_party/boringssl-with-bazel/src/crypto/dsa/internal.h +13 -13
  2161. data/third_party/boringssl-with-bazel/src/crypto/ec/ec_asn1.cc +570 -0
  2162. data/third_party/boringssl-with-bazel/src/crypto/ec/ec_derive.cc +96 -0
  2163. data/third_party/boringssl-with-bazel/src/crypto/ec/hash_to_curve.cc +510 -0
  2164. data/third_party/boringssl-with-bazel/src/crypto/ec/internal.h +78 -0
  2165. data/third_party/boringssl-with-bazel/src/crypto/ecdh/ecdh.cc +73 -0
  2166. data/third_party/boringssl-with-bazel/src/crypto/ecdsa/ecdsa_asn1.cc +357 -0
  2167. data/third_party/boringssl-with-bazel/src/crypto/engine/engine.cc +95 -0
  2168. data/third_party/boringssl-with-bazel/src/crypto/err/err.cc +810 -0
  2169. data/third_party/boringssl-with-bazel/src/crypto/err/internal.h +13 -13
  2170. data/third_party/boringssl-with-bazel/src/crypto/evp/evp.cc +379 -0
  2171. data/third_party/boringssl-with-bazel/src/crypto/evp/evp_asn1.cc +471 -0
  2172. data/third_party/boringssl-with-bazel/src/crypto/evp/evp_ctx.cc +440 -0
  2173. data/third_party/boringssl-with-bazel/src/crypto/evp/internal.h +13 -55
  2174. data/third_party/boringssl-with-bazel/src/crypto/evp/p_dh.cc +153 -0
  2175. data/third_party/boringssl-with-bazel/src/crypto/evp/p_dh_asn1.cc +142 -0
  2176. data/third_party/boringssl-with-bazel/src/crypto/evp/p_dsa_asn1.cc +279 -0
  2177. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ec.cc +230 -0
  2178. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ec_asn1.cc +286 -0
  2179. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ed25519.cc +103 -0
  2180. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ed25519_asn1.cc +225 -0
  2181. data/third_party/boringssl-with-bazel/src/crypto/evp/p_hkdf.cc +236 -0
  2182. data/third_party/boringssl-with-bazel/src/crypto/evp/p_rsa.cc +609 -0
  2183. data/third_party/boringssl-with-bazel/src/crypto/evp/p_rsa_asn1.cc +198 -0
  2184. data/third_party/boringssl-with-bazel/src/crypto/evp/p_x25519.cc +109 -0
  2185. data/third_party/boringssl-with-bazel/src/crypto/evp/p_x25519_asn1.cc +237 -0
  2186. data/third_party/boringssl-with-bazel/src/crypto/evp/pbkdf.cc +98 -0
  2187. data/third_party/boringssl-with-bazel/src/crypto/evp/print.cc +342 -0
  2188. data/third_party/boringssl-with-bazel/src/crypto/evp/scrypt.cc +216 -0
  2189. data/third_party/boringssl-with-bazel/src/crypto/evp/sign.cc +114 -0
  2190. data/third_party/boringssl-with-bazel/src/crypto/ex_data.cc +141 -0
  2191. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/aes.cc.inc +191 -0
  2192. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/aes_nohw.cc.inc +1281 -0
  2193. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/cbc.cc.inc +130 -0
  2194. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/cfb.cc.inc +166 -0
  2195. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/ctr.cc.inc +100 -0
  2196. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/gcm.cc.inc +604 -0
  2197. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/gcm_nohw.cc.inc +302 -0
  2198. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/internal.h +450 -75
  2199. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/key_wrap.cc.inc +208 -0
  2200. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/mode_wrappers.cc.inc +84 -0
  2201. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/ofb.cc.inc +53 -0
  2202. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/polyval.cc.inc +89 -0
  2203. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bcm.cc +282 -0
  2204. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bcm_interface.h +729 -0
  2205. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/add.cc.inc +269 -0
  2206. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/asm/x86_64-gcc.cc.inc +554 -0
  2207. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/bn.cc.inc +374 -0
  2208. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/bytes.cc.inc +225 -0
  2209. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/cmp.cc.inc +159 -0
  2210. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/ctx.cc.inc +191 -0
  2211. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/div.cc.inc +825 -0
  2212. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/div_extra.cc.inc +87 -0
  2213. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/exponentiation.cc.inc +1227 -0
  2214. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/gcd.cc.inc +300 -0
  2215. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/gcd_extra.cc.inc +339 -0
  2216. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/generic.cc.inc +582 -0
  2217. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/internal.h +52 -151
  2218. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/jacobi.cc.inc +108 -0
  2219. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/montgomery.cc.inc +430 -0
  2220. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/montgomery_inv.cc.inc +222 -0
  2221. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/mul.cc.inc +698 -0
  2222. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/prime.cc.inc +980 -0
  2223. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/random.cc.inc +260 -0
  2224. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/rsaz_exp.cc.inc +142 -0
  2225. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/rsaz_exp.h +20 -17
  2226. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/shift.cc.inc +320 -0
  2227. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/sqrt.cc.inc +459 -0
  2228. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/aead.cc.inc +295 -0
  2229. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/cipher.cc.inc +672 -0
  2230. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/e_aes.cc.inc +1242 -0
  2231. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/e_aesccm.cc.inc +409 -0
  2232. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/internal.h +14 -65
  2233. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cmac/cmac.cc.inc +288 -0
  2234. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/delocate.h +26 -22
  2235. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/dh/check.cc.inc +203 -0
  2236. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/dh/dh.cc.inc +443 -0
  2237. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/dh/internal.h +13 -15
  2238. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digest/digest.cc.inc +250 -0
  2239. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digest/digests.cc.inc +178 -0
  2240. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digest/internal.h +13 -55
  2241. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digest/md32_common.h +13 -47
  2242. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digestsign/digestsign.cc.inc +226 -0
  2243. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/builtin_curves.h +91 -91
  2244. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/ec.cc.inc +986 -0
  2245. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/ec_key.cc.inc +501 -0
  2246. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/ec_montgomery.cc.inc +439 -0
  2247. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/felem.cc.inc +104 -0
  2248. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/internal.h +19 -66
  2249. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/oct.cc.inc +306 -0
  2250. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p224-64.cc.inc +1163 -0
  2251. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p256-nistz-table.h +15 -10
  2252. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p256-nistz.cc.inc +741 -0
  2253. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p256-nistz.h +87 -25
  2254. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p256.cc.inc +749 -0
  2255. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p256_table.h +13 -13
  2256. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/scalar.cc.inc +179 -0
  2257. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/simple.cc.inc +284 -0
  2258. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/simple_mul.cc.inc +269 -0
  2259. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/util.cc.inc +255 -0
  2260. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/wnaf.cc.inc +221 -0
  2261. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ecdh/ecdh.cc.inc +88 -0
  2262. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ecdsa/ecdsa.cc.inc +278 -0
  2263. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ecdsa/internal.h +41 -24
  2264. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/fips_shared_support.cc +28 -0
  2265. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/hkdf/hkdf.cc.inc +112 -0
  2266. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/hmac/hmac.cc.inc +215 -0
  2267. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/keccak/internal.h +70 -0
  2268. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/keccak/keccak.cc.inc +279 -0
  2269. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/mldsa/mldsa.cc.inc +1993 -0
  2270. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/mlkem/mlkem.cc.inc +1165 -0
  2271. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/ctrdrbg.cc.inc +214 -0
  2272. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/internal.h +19 -104
  2273. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/rand.cc.inc +483 -0
  2274. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/blinding.cc.inc +147 -0
  2275. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/internal.h +13 -56
  2276. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/padding.cc.inc +379 -0
  2277. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/rsa.cc.inc +983 -0
  2278. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/rsa_impl.cc.inc +1296 -0
  2279. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/self_check/fips.cc.inc +129 -0
  2280. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/self_check/self_check.cc.inc +1042 -0
  2281. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/service_indicator/internal.h +36 -36
  2282. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/service_indicator/service_indicator.cc.inc +327 -0
  2283. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/internal.h +51 -60
  2284. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/sha1.cc.inc +390 -0
  2285. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/sha256.cc.inc +299 -0
  2286. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/sha512.cc.inc +473 -0
  2287. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/slhdsa/address.h +119 -0
  2288. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/slhdsa/fors.cc.inc +169 -0
  2289. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/slhdsa/fors.h +58 -0
  2290. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/slhdsa/merkle.cc.inc +161 -0
  2291. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/slhdsa/merkle.h +70 -0
  2292. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/slhdsa/params.h +78 -0
  2293. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/slhdsa/slhdsa.cc.inc +329 -0
  2294. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/slhdsa/thash.cc.inc +173 -0
  2295. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/slhdsa/thash.h +85 -0
  2296. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/slhdsa/wots.cc.inc +171 -0
  2297. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/slhdsa/wots.h +50 -0
  2298. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/tls/internal.h +13 -13
  2299. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/tls/kdf.cc.inc +180 -0
  2300. data/third_party/boringssl-with-bazel/src/crypto/hpke/hpke.cc +1095 -0
  2301. data/third_party/boringssl-with-bazel/src/crypto/hrss/hrss.cc +2185 -0
  2302. data/third_party/boringssl-with-bazel/src/crypto/hrss/internal.h +13 -13
  2303. data/third_party/boringssl-with-bazel/src/crypto/internal.h +323 -449
  2304. data/third_party/boringssl-with-bazel/src/crypto/kyber/internal.h +13 -13
  2305. data/third_party/boringssl-with-bazel/src/crypto/kyber/kyber.cc +869 -0
  2306. data/third_party/boringssl-with-bazel/src/crypto/lhash/internal.h +31 -75
  2307. data/third_party/boringssl-with-bazel/src/crypto/lhash/lhash.cc +309 -0
  2308. data/third_party/boringssl-with-bazel/src/crypto/md4/md4.cc +194 -0
  2309. data/third_party/boringssl-with-bazel/src/crypto/md5/internal.h +37 -0
  2310. data/third_party/boringssl-with-bazel/src/crypto/md5/md5.cc +243 -0
  2311. data/third_party/boringssl-with-bazel/src/crypto/mem.cc +583 -0
  2312. data/third_party/boringssl-with-bazel/src/crypto/mldsa/mldsa.cc +90 -0
  2313. data/third_party/boringssl-with-bazel/src/crypto/mlkem/mlkem.cc +152 -0
  2314. data/third_party/boringssl-with-bazel/src/crypto/obj/obj.cc +519 -0
  2315. data/third_party/boringssl-with-bazel/src/crypto/obj/obj_dat.h +18 -57
  2316. data/third_party/boringssl-with-bazel/src/crypto/obj/obj_xref.cc +80 -0
  2317. data/third_party/boringssl-with-bazel/src/crypto/pem/internal.h +44 -0
  2318. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_all.cc +149 -0
  2319. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_info.cc +254 -0
  2320. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_lib.cc +741 -0
  2321. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_oth.cc +45 -0
  2322. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_pk8.cc +208 -0
  2323. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_pkey.cc +141 -0
  2324. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_x509.cc +22 -0
  2325. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_xaux.cc +22 -0
  2326. data/third_party/boringssl-with-bazel/src/crypto/pkcs7/internal.h +13 -13
  2327. data/third_party/boringssl-with-bazel/src/crypto/pkcs7/pkcs7.cc +193 -0
  2328. data/third_party/boringssl-with-bazel/src/crypto/pkcs7/pkcs7_x509.cc +526 -0
  2329. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/internal.h +14 -54
  2330. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/p5_pbev2.cc +275 -0
  2331. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/pkcs8.cc +487 -0
  2332. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/pkcs8_x509.cc +1304 -0
  2333. data/third_party/boringssl-with-bazel/src/crypto/poly1305/internal.h +13 -13
  2334. data/third_party/boringssl-with-bazel/src/crypto/poly1305/poly1305.cc +314 -0
  2335. data/third_party/boringssl-with-bazel/src/crypto/poly1305/poly1305_arm.cc +310 -0
  2336. data/third_party/boringssl-with-bazel/src/crypto/poly1305/poly1305_vec.cc +850 -0
  2337. data/third_party/boringssl-with-bazel/src/crypto/pool/internal.h +13 -13
  2338. data/third_party/boringssl-with-bazel/src/crypto/pool/pool.cc +262 -0
  2339. data/third_party/boringssl-with-bazel/src/crypto/rand/deterministic.cc +65 -0
  2340. data/third_party/boringssl-with-bazel/src/crypto/rand/fork_detect.cc +194 -0
  2341. data/third_party/boringssl-with-bazel/src/crypto/rand/forkunsafe.cc +44 -0
  2342. data/third_party/boringssl-with-bazel/src/crypto/rand/getentropy.cc +60 -0
  2343. data/third_party/boringssl-with-bazel/src/crypto/rand/getrandom_fillin.h +64 -0
  2344. data/third_party/boringssl-with-bazel/src/crypto/rand/ios.cc +42 -0
  2345. data/third_party/boringssl-with-bazel/src/crypto/rand/passive.cc +178 -0
  2346. data/third_party/boringssl-with-bazel/src/crypto/rand/rand.cc +77 -0
  2347. data/third_party/boringssl-with-bazel/src/crypto/rand/sysrand_internal.h +37 -0
  2348. data/third_party/boringssl-with-bazel/src/crypto/rand/trusty.cc +46 -0
  2349. data/third_party/boringssl-with-bazel/src/crypto/rand/urandom.cc +328 -0
  2350. data/third_party/boringssl-with-bazel/src/crypto/rand/windows.cc +102 -0
  2351. data/third_party/boringssl-with-bazel/src/crypto/rc4/rc4.cc +56 -0
  2352. data/third_party/boringssl-with-bazel/src/crypto/refcount.cc +59 -0
  2353. data/third_party/boringssl-with-bazel/src/crypto/rsa/internal.h +36 -0
  2354. data/third_party/boringssl-with-bazel/src/crypto/rsa/rsa_asn1.cc +283 -0
  2355. data/third_party/boringssl-with-bazel/src/crypto/rsa/rsa_crypt.cc +531 -0
  2356. data/third_party/boringssl-with-bazel/src/crypto/rsa/rsa_extra.cc +19 -0
  2357. data/third_party/boringssl-with-bazel/src/crypto/rsa/rsa_print.cc +27 -0
  2358. data/third_party/boringssl-with-bazel/src/crypto/sha/sha1.cc +52 -0
  2359. data/third_party/boringssl-with-bazel/src/crypto/sha/sha256.cc +87 -0
  2360. data/third_party/boringssl-with-bazel/src/crypto/sha/sha512.cc +104 -0
  2361. data/third_party/boringssl-with-bazel/src/crypto/siphash/siphash.cc +79 -0
  2362. data/third_party/boringssl-with-bazel/src/crypto/slhdsa/slhdsa.cc +113 -0
  2363. data/third_party/boringssl-with-bazel/src/crypto/spake2plus/internal.h +204 -0
  2364. data/third_party/boringssl-with-bazel/src/crypto/spake2plus/spake2plus.cc +501 -0
  2365. data/third_party/boringssl-with-bazel/src/crypto/stack/stack.cc +496 -0
  2366. data/third_party/boringssl-with-bazel/src/crypto/thread.cc +68 -0
  2367. data/third_party/boringssl-with-bazel/src/crypto/thread_none.cc +51 -0
  2368. data/third_party/boringssl-with-bazel/src/crypto/thread_pthread.cc +151 -0
  2369. data/third_party/boringssl-with-bazel/src/crypto/thread_win.cc +240 -0
  2370. data/third_party/boringssl-with-bazel/src/crypto/trust_token/internal.h +13 -13
  2371. data/third_party/boringssl-with-bazel/src/crypto/trust_token/pmbtoken.cc +1656 -0
  2372. data/third_party/boringssl-with-bazel/src/crypto/trust_token/trust_token.cc +685 -0
  2373. data/third_party/boringssl-with-bazel/src/crypto/trust_token/voprf.cc +1263 -0
  2374. data/third_party/boringssl-with-bazel/src/crypto/x509/a_digest.cc +52 -0
  2375. data/third_party/boringssl-with-bazel/src/crypto/x509/a_sign.cc +97 -0
  2376. data/third_party/boringssl-with-bazel/src/crypto/x509/a_verify.cc +74 -0
  2377. data/third_party/boringssl-with-bazel/src/crypto/x509/algorithm.cc +136 -0
  2378. data/third_party/boringssl-with-bazel/src/crypto/x509/asn1_gen.cc +542 -0
  2379. data/third_party/boringssl-with-bazel/src/crypto/x509/by_dir.cc +355 -0
  2380. data/third_party/boringssl-with-bazel/src/crypto/x509/by_file.cc +227 -0
  2381. data/third_party/boringssl-with-bazel/src/crypto/x509/ext_dat.h +13 -55
  2382. data/third_party/boringssl-with-bazel/src/crypto/x509/i2d_pr.cc +37 -0
  2383. data/third_party/boringssl-with-bazel/src/crypto/x509/internal.h +13 -61
  2384. data/third_party/boringssl-with-bazel/src/crypto/x509/name_print.cc +185 -0
  2385. data/third_party/boringssl-with-bazel/src/crypto/x509/policy.cc +796 -0
  2386. data/third_party/boringssl-with-bazel/src/crypto/x509/rsa_pss.cc +364 -0
  2387. data/third_party/boringssl-with-bazel/src/crypto/x509/t_crl.cc +103 -0
  2388. data/third_party/boringssl-with-bazel/src/crypto/x509/t_req.cc +203 -0
  2389. data/third_party/boringssl-with-bazel/src/crypto/x509/t_x509.cc +287 -0
  2390. data/third_party/boringssl-with-bazel/src/crypto/x509/t_x509a.cc +79 -0
  2391. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_akey.cc +181 -0
  2392. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_akeya.cc +31 -0
  2393. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_alt.cc +593 -0
  2394. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_bcons.cc +95 -0
  2395. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_bitst.cc +102 -0
  2396. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_conf.cc +374 -0
  2397. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_cpols.cc +444 -0
  2398. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_crld.cc +557 -0
  2399. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_enum.cc +73 -0
  2400. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_extku.cc +114 -0
  2401. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_genn.cc +228 -0
  2402. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_ia5.cc +79 -0
  2403. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_info.cc +164 -0
  2404. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_int.cc +81 -0
  2405. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_lib.cc +304 -0
  2406. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_ncons.cc +514 -0
  2407. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_ocsp.cc +89 -0
  2408. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_pcons.cc +101 -0
  2409. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_pmaps.cc +109 -0
  2410. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_prn.cc +183 -0
  2411. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_purp.cc +590 -0
  2412. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_skey.cc +131 -0
  2413. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_utl.cc +1342 -0
  2414. data/third_party/boringssl-with-bazel/src/crypto/x509/x509.cc +47 -0
  2415. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_att.cc +186 -0
  2416. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_cmp.cc +238 -0
  2417. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_d2.cc +66 -0
  2418. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_def.cc +44 -0
  2419. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_ext.cc +139 -0
  2420. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_lu.cc +554 -0
  2421. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_obj.cc +164 -0
  2422. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_req.cc +257 -0
  2423. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_set.cc +198 -0
  2424. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_trs.cc +118 -0
  2425. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_txt.cc +147 -0
  2426. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_v3.cc +249 -0
  2427. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_vfy.cc +1600 -0
  2428. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_vpm.cc +440 -0
  2429. data/third_party/boringssl-with-bazel/src/crypto/x509/x509cset.cc +235 -0
  2430. data/third_party/boringssl-with-bazel/src/crypto/x509/x509name.cc +365 -0
  2431. data/third_party/boringssl-with-bazel/src/crypto/x509/x509rset.cc +67 -0
  2432. data/third_party/boringssl-with-bazel/src/crypto/x509/x509spki.cc +91 -0
  2433. data/third_party/boringssl-with-bazel/src/crypto/x509/x_algor.cc +107 -0
  2434. data/third_party/boringssl-with-bazel/src/crypto/x509/x_all.cc +318 -0
  2435. data/third_party/boringssl-with-bazel/src/crypto/x509/x_attrib.cc +55 -0
  2436. data/third_party/boringssl-with-bazel/src/crypto/x509/x_crl.cc +342 -0
  2437. data/third_party/boringssl-with-bazel/src/crypto/x509/x_exten.cc +36 -0
  2438. data/third_party/boringssl-with-bazel/src/crypto/x509/x_name.cc +492 -0
  2439. data/third_party/boringssl-with-bazel/src/crypto/x509/x_pubkey.cc +170 -0
  2440. data/third_party/boringssl-with-bazel/src/crypto/x509/x_req.cc +74 -0
  2441. data/third_party/boringssl-with-bazel/src/crypto/x509/x_sig.cc +51 -0
  2442. data/third_party/boringssl-with-bazel/src/crypto/x509/x_spki.cc +34 -0
  2443. data/third_party/boringssl-with-bazel/src/crypto/x509/x_val.cc +28 -0
  2444. data/third_party/boringssl-with-bazel/src/crypto/x509/x_x509.cc +506 -0
  2445. data/third_party/boringssl-with-bazel/src/crypto/x509/x_x509a.cc +169 -0
  2446. data/third_party/boringssl-with-bazel/src/gen/crypto/err_data.cc +1529 -0
  2447. data/third_party/boringssl-with-bazel/src/include/openssl/aead.h +13 -13
  2448. data/third_party/boringssl-with-bazel/src/include/openssl/aes.h +13 -47
  2449. data/third_party/boringssl-with-bazel/src/include/openssl/arm_arch.h +13 -51
  2450. data/third_party/boringssl-with-bazel/src/include/openssl/asm_base.h +14 -14
  2451. data/third_party/boringssl-with-bazel/src/include/openssl/asn1.h +37 -63
  2452. data/third_party/boringssl-with-bazel/src/include/openssl/asn1_mac.h +13 -13
  2453. data/third_party/boringssl-with-bazel/src/include/openssl/asn1t.h +248 -328
  2454. data/third_party/boringssl-with-bazel/src/include/openssl/base.h +24 -55
  2455. data/third_party/boringssl-with-bazel/src/include/openssl/base64.h +13 -55
  2456. data/third_party/boringssl-with-bazel/src/include/openssl/bcm_public.h +82 -0
  2457. data/third_party/boringssl-with-bazel/src/include/openssl/bio.h +21 -61
  2458. data/third_party/boringssl-with-bazel/src/include/openssl/blake2.h +13 -13
  2459. data/third_party/boringssl-with-bazel/src/include/openssl/blowfish.h +13 -55
  2460. data/third_party/boringssl-with-bazel/src/include/openssl/bn.h +28 -130
  2461. data/third_party/boringssl-with-bazel/src/include/openssl/buf.h +13 -55
  2462. data/third_party/boringssl-with-bazel/src/include/openssl/buffer.h +13 -13
  2463. data/third_party/boringssl-with-bazel/src/include/openssl/bytestring.h +31 -16
  2464. data/third_party/boringssl-with-bazel/src/include/openssl/cast.h +13 -55
  2465. data/third_party/boringssl-with-bazel/src/include/openssl/chacha.h +13 -13
  2466. data/third_party/boringssl-with-bazel/src/include/openssl/cipher.h +31 -59
  2467. data/third_party/boringssl-with-bazel/src/include/openssl/cmac.h +13 -13
  2468. data/third_party/boringssl-with-bazel/src/include/openssl/conf.h +13 -55
  2469. data/third_party/boringssl-with-bazel/src/include/openssl/cpu.h +13 -13
  2470. data/third_party/boringssl-with-bazel/src/include/openssl/crypto.h +34 -25
  2471. data/third_party/boringssl-with-bazel/src/include/openssl/ctrdrbg.h +13 -13
  2472. data/third_party/boringssl-with-bazel/src/include/openssl/curve25519.h +13 -13
  2473. data/third_party/boringssl-with-bazel/src/include/openssl/des.h +13 -55
  2474. data/third_party/boringssl-with-bazel/src/include/openssl/dh.h +17 -55
  2475. data/third_party/boringssl-with-bazel/src/include/openssl/digest.h +19 -56
  2476. data/third_party/boringssl-with-bazel/src/include/openssl/dsa.h +17 -58
  2477. data/third_party/boringssl-with-bazel/src/include/openssl/dtls1.h +13 -13
  2478. data/third_party/boringssl-with-bazel/src/include/openssl/e_os2.h +13 -13
  2479. data/third_party/boringssl-with-bazel/src/include/openssl/ec.h +14 -66
  2480. data/third_party/boringssl-with-bazel/src/include/openssl/ec_key.h +31 -72
  2481. data/third_party/boringssl-with-bazel/src/include/openssl/ecdh.h +14 -65
  2482. data/third_party/boringssl-with-bazel/src/include/openssl/ecdsa.h +13 -51
  2483. data/third_party/boringssl-with-bazel/src/include/openssl/engine.h +13 -13
  2484. data/third_party/boringssl-with-bazel/src/include/openssl/err.h +13 -107
  2485. data/third_party/boringssl-with-bazel/src/include/openssl/evp.h +14 -56
  2486. data/third_party/boringssl-with-bazel/src/include/openssl/evp_errors.h +13 -55
  2487. data/third_party/boringssl-with-bazel/src/include/openssl/ex_data.h +13 -107
  2488. data/third_party/boringssl-with-bazel/src/include/openssl/experimental/kyber.h +23 -13
  2489. data/third_party/boringssl-with-bazel/src/include/openssl/hkdf.h +13 -13
  2490. data/third_party/boringssl-with-bazel/src/include/openssl/hmac.h +13 -55
  2491. data/third_party/boringssl-with-bazel/src/include/openssl/hpke.h +21 -19
  2492. data/third_party/boringssl-with-bazel/src/include/openssl/hrss.h +13 -13
  2493. data/third_party/boringssl-with-bazel/src/include/openssl/is_boringssl.h +13 -13
  2494. data/third_party/boringssl-with-bazel/src/include/openssl/kdf.h +13 -13
  2495. data/third_party/boringssl-with-bazel/src/include/openssl/lhash.h +13 -55
  2496. data/third_party/boringssl-with-bazel/src/include/openssl/md4.h +13 -55
  2497. data/third_party/boringssl-with-bazel/src/include/openssl/md5.h +13 -55
  2498. data/third_party/boringssl-with-bazel/src/include/openssl/mem.h +13 -55
  2499. data/third_party/boringssl-with-bazel/src/include/openssl/mldsa.h +130 -0
  2500. data/third_party/boringssl-with-bazel/src/include/openssl/mlkem.h +222 -0
  2501. data/third_party/boringssl-with-bazel/src/include/openssl/nid.h +30 -69
  2502. data/third_party/boringssl-with-bazel/src/include/openssl/obj.h +13 -55
  2503. data/third_party/boringssl-with-bazel/src/include/openssl/obj_mac.h +13 -13
  2504. data/third_party/boringssl-with-bazel/src/include/openssl/objects.h +13 -13
  2505. data/third_party/boringssl-with-bazel/src/include/openssl/opensslconf.h +13 -13
  2506. data/third_party/boringssl-with-bazel/src/include/openssl/opensslv.h +13 -13
  2507. data/third_party/boringssl-with-bazel/src/include/openssl/ossl_typ.h +13 -13
  2508. data/third_party/boringssl-with-bazel/src/include/openssl/pem.h +25 -64
  2509. data/third_party/boringssl-with-bazel/src/include/openssl/pkcs12.h +13 -13
  2510. data/third_party/boringssl-with-bazel/src/include/openssl/pkcs7.h +13 -13
  2511. data/third_party/boringssl-with-bazel/src/include/openssl/pkcs8.h +13 -55
  2512. data/third_party/boringssl-with-bazel/src/include/openssl/poly1305.h +13 -13
  2513. data/third_party/boringssl-with-bazel/src/include/openssl/pool.h +13 -13
  2514. data/third_party/boringssl-with-bazel/src/include/openssl/posix_time.h +13 -13
  2515. data/third_party/boringssl-with-bazel/src/include/openssl/rand.h +13 -13
  2516. data/third_party/boringssl-with-bazel/src/include/openssl/rc4.h +13 -55
  2517. data/third_party/boringssl-with-bazel/src/include/openssl/ripemd.h +13 -55
  2518. data/third_party/boringssl-with-bazel/src/include/openssl/rsa.h +23 -63
  2519. data/third_party/boringssl-with-bazel/src/include/openssl/safestack.h +13 -13
  2520. data/third_party/boringssl-with-bazel/src/include/openssl/service_indicator.h +15 -15
  2521. data/third_party/boringssl-with-bazel/src/include/openssl/sha.h +15 -95
  2522. data/third_party/boringssl-with-bazel/src/include/openssl/siphash.h +13 -13
  2523. data/third_party/boringssl-with-bazel/src/include/openssl/slhdsa.h +174 -0
  2524. data/third_party/boringssl-with-bazel/src/include/openssl/span.h +60 -32
  2525. data/third_party/boringssl-with-bazel/src/include/openssl/srtp.h +13 -13
  2526. data/third_party/boringssl-with-bazel/src/include/openssl/ssl.h +465 -317
  2527. data/third_party/boringssl-with-bazel/src/include/openssl/ssl3.h +15 -114
  2528. data/third_party/boringssl-with-bazel/src/include/openssl/stack.h +13 -55
  2529. data/third_party/boringssl-with-bazel/src/include/openssl/target.h +23 -13
  2530. data/third_party/boringssl-with-bazel/src/include/openssl/thread.h +15 -57
  2531. data/third_party/boringssl-with-bazel/src/include/openssl/time.h +13 -13
  2532. data/third_party/boringssl-with-bazel/src/include/openssl/tls1.h +27 -156
  2533. data/third_party/boringssl-with-bazel/src/include/openssl/trust_token.h +15 -15
  2534. data/third_party/boringssl-with-bazel/src/include/openssl/type_check.h +13 -55
  2535. data/third_party/boringssl-with-bazel/src/include/openssl/x509.h +14 -84
  2536. data/third_party/boringssl-with-bazel/src/include/openssl/x509_vfy.h +13 -13
  2537. data/third_party/boringssl-with-bazel/src/include/openssl/x509v3.h +13 -13
  2538. data/third_party/boringssl-with-bazel/src/include/openssl/x509v3_errors.h +13 -53
  2539. data/third_party/boringssl-with-bazel/src/ssl/bio_ssl.cc +15 -14
  2540. data/third_party/boringssl-with-bazel/src/ssl/d1_both.cc +684 -441
  2541. data/third_party/boringssl-with-bazel/src/ssl/d1_lib.cc +129 -168
  2542. data/third_party/boringssl-with-bazel/src/ssl/d1_pkt.cc +177 -127
  2543. data/third_party/boringssl-with-bazel/src/ssl/d1_srtp.cc +21 -127
  2544. data/third_party/boringssl-with-bazel/src/ssl/dtls_method.cc +112 -97
  2545. data/third_party/boringssl-with-bazel/src/ssl/dtls_record.cc +456 -222
  2546. data/third_party/boringssl-with-bazel/src/ssl/encrypted_client_hello.cc +54 -47
  2547. data/third_party/boringssl-with-bazel/src/ssl/extensions.cc +701 -491
  2548. data/third_party/boringssl-with-bazel/src/ssl/handoff.cc +66 -73
  2549. data/third_party/boringssl-with-bazel/src/ssl/handshake.cc +61 -153
  2550. data/third_party/boringssl-with-bazel/src/ssl/handshake_client.cc +234 -335
  2551. data/third_party/boringssl-with-bazel/src/ssl/handshake_server.cc +104 -216
  2552. data/third_party/boringssl-with-bazel/src/ssl/internal.h +1009 -504
  2553. data/third_party/boringssl-with-bazel/src/ssl/s3_both.cc +87 -169
  2554. data/third_party/boringssl-with-bazel/src/ssl/s3_lib.cc +29 -159
  2555. data/third_party/boringssl-with-bazel/src/ssl/s3_pkt.cc +39 -113
  2556. data/third_party/boringssl-with-bazel/src/ssl/ssl_aead_ctx.cc +103 -111
  2557. data/third_party/boringssl-with-bazel/src/ssl/ssl_asn1.cc +52 -145
  2558. data/third_party/boringssl-with-bazel/src/ssl/ssl_buffer.cc +22 -24
  2559. data/third_party/boringssl-with-bazel/src/ssl/ssl_cert.cc +117 -157
  2560. data/third_party/boringssl-with-bazel/src/ssl/ssl_cipher.cc +229 -365
  2561. data/third_party/boringssl-with-bazel/src/ssl/ssl_credential.cc +216 -31
  2562. data/third_party/boringssl-with-bazel/src/ssl/ssl_file.cc +13 -109
  2563. data/third_party/boringssl-with-bazel/src/ssl/ssl_key_share.cc +128 -32
  2564. data/third_party/boringssl-with-bazel/src/ssl/ssl_lib.cc +244 -360
  2565. data/third_party/boringssl-with-bazel/src/ssl/ssl_privkey.cc +97 -103
  2566. data/third_party/boringssl-with-bazel/src/ssl/ssl_session.cc +101 -236
  2567. data/third_party/boringssl-with-bazel/src/ssl/ssl_stat.cc +17 -91
  2568. data/third_party/boringssl-with-bazel/src/ssl/ssl_transcript.cc +109 -157
  2569. data/third_party/boringssl-with-bazel/src/ssl/ssl_versions.cc +48 -28
  2570. data/third_party/boringssl-with-bazel/src/ssl/ssl_x509.cc +66 -195
  2571. data/third_party/boringssl-with-bazel/src/ssl/t1_enc.cc +45 -176
  2572. data/third_party/boringssl-with-bazel/src/ssl/tls13_both.cc +60 -43
  2573. data/third_party/boringssl-with-bazel/src/ssl/tls13_client.cc +152 -86
  2574. data/third_party/boringssl-with-bazel/src/ssl/tls13_enc.cc +296 -163
  2575. data/third_party/boringssl-with-bazel/src/ssl/tls13_server.cc +247 -108
  2576. data/third_party/boringssl-with-bazel/src/ssl/tls_method.cc +64 -117
  2577. data/third_party/boringssl-with-bazel/src/ssl/tls_record.cc +55 -157
  2578. data/third_party/boringssl-with-bazel/src/third_party/fiat/curve25519_32.h +6 -0
  2579. data/third_party/boringssl-with-bazel/src/third_party/fiat/curve25519_64.h +6 -0
  2580. data/third_party/boringssl-with-bazel/src/third_party/fiat/curve25519_64_adx.h +4 -1
  2581. data/third_party/boringssl-with-bazel/src/third_party/fiat/p256_32.h +1 -1
  2582. data/third_party/boringssl-with-bazel/src/third_party/fiat/p256_64.h +3 -0
  2583. data/third_party/upb/upb/base/string_view.h +1 -1
  2584. data/third_party/upb/upb/json/decode.c +60 -13
  2585. data/third_party/upb/upb/json/decode.h +26 -3
  2586. data/third_party/upb/upb/json/encode.c +2 -2
  2587. data/third_party/upb/upb/lex/round_trip.c +10 -0
  2588. data/third_party/upb/upb/mem/arena.c +80 -4
  2589. data/third_party/upb/upb/mem/arena.h +20 -9
  2590. data/third_party/upb/upb/mem/arena.hpp +5 -1
  2591. data/third_party/upb/upb/mem/internal/arena.h +11 -8
  2592. data/third_party/upb/upb/message/accessors.c +6 -7
  2593. data/third_party/upb/upb/message/accessors.h +186 -376
  2594. data/third_party/upb/upb/message/array.c +26 -3
  2595. data/third_party/upb/upb/message/array.h +17 -9
  2596. data/third_party/upb/upb/message/compat.c +5 -5
  2597. data/third_party/upb/upb/message/compat.h +3 -3
  2598. data/third_party/upb/upb/message/copy.c +23 -20
  2599. data/third_party/upb/upb/message/internal/accessors.h +617 -55
  2600. data/third_party/upb/upb/message/internal/array.h +23 -15
  2601. data/third_party/upb/upb/message/internal/compare_unknown.c +289 -0
  2602. data/third_party/upb/upb/message/internal/compare_unknown.h +49 -0
  2603. data/third_party/upb/upb/message/internal/extension.c +12 -12
  2604. data/third_party/upb/upb/message/internal/extension.h +9 -12
  2605. data/third_party/upb/upb/message/internal/map.h +15 -0
  2606. data/third_party/upb/upb/message/internal/map_sorter.h +4 -5
  2607. data/third_party/upb/upb/message/internal/message.c +22 -6
  2608. data/third_party/upb/upb/message/internal/message.h +11 -0
  2609. data/third_party/upb/upb/message/internal/tagged_ptr.h +5 -5
  2610. data/third_party/upb/upb/message/internal/types.h +41 -1
  2611. data/third_party/upb/upb/message/map.c +25 -0
  2612. data/third_party/upb/upb/message/map.h +11 -7
  2613. data/third_party/upb/upb/message/merge.c +38 -0
  2614. data/third_party/upb/upb/message/merge.h +26 -0
  2615. data/third_party/upb/upb/message/message.c +83 -4
  2616. data/third_party/upb/upb/message/message.h +16 -1
  2617. data/third_party/upb/upb/message/tagged_ptr.h +4 -8
  2618. data/third_party/upb/upb/message/value.h +26 -0
  2619. data/third_party/upb/upb/mini_descriptor/build_enum.c +3 -3
  2620. data/third_party/upb/upb/mini_descriptor/build_enum.h +6 -14
  2621. data/third_party/upb/upb/mini_descriptor/decode.c +19 -3
  2622. data/third_party/upb/upb/mini_descriptor/link.c +23 -21
  2623. data/third_party/upb/upb/mini_table/enum.h +2 -4
  2624. data/third_party/upb/upb/mini_table/extension.h +4 -12
  2625. data/third_party/upb/upb/mini_table/extension_registry.c +18 -0
  2626. data/third_party/upb/upb/mini_table/extension_registry.h +17 -0
  2627. data/third_party/upb/upb/mini_table/field.h +12 -38
  2628. data/third_party/upb/upb/mini_table/file.h +6 -19
  2629. data/third_party/upb/upb/mini_table/internal/enum.h +1 -1
  2630. data/third_party/upb/upb/mini_table/internal/extension.h +18 -9
  2631. data/third_party/upb/upb/mini_table/internal/field.h +23 -23
  2632. data/third_party/upb/upb/mini_table/internal/file.h +7 -7
  2633. data/third_party/upb/upb/mini_table/internal/message.c +21 -1
  2634. data/third_party/upb/upb/mini_table/internal/message.h +80 -36
  2635. data/third_party/upb/upb/mini_table/internal/sub.h +9 -4
  2636. data/third_party/upb/upb/mini_table/message.h +23 -22
  2637. data/third_party/upb/upb/mini_table/sub.h +4 -12
  2638. data/third_party/upb/upb/port/def.inc +108 -12
  2639. data/third_party/upb/upb/port/undef.inc +8 -1
  2640. data/third_party/upb/upb/reflection/common.h +1 -11
  2641. data/third_party/upb/upb/reflection/def.hpp +35 -0
  2642. data/third_party/upb/upb/reflection/def_pool.h +2 -2
  2643. data/third_party/upb/upb/reflection/descriptor_bootstrap.h +19 -0
  2644. data/third_party/upb/upb/reflection/enum_def.c +5 -1
  2645. data/third_party/upb/upb/reflection/enum_def.h +1 -0
  2646. data/third_party/upb/upb/reflection/enum_value_def.c +3 -8
  2647. data/third_party/upb/upb/reflection/field_def.c +72 -46
  2648. data/third_party/upb/upb/reflection/field_def.h +4 -0
  2649. data/third_party/upb/upb/reflection/file_def.c +30 -4
  2650. data/third_party/upb/upb/reflection/file_def.h +3 -0
  2651. data/third_party/upb/upb/reflection/internal/upb_edition_defaults.h +1 -1
  2652. data/third_party/upb/upb/reflection/message.c +26 -9
  2653. data/third_party/upb/upb/reflection/message.h +2 -2
  2654. data/third_party/upb/upb/reflection/message_def.c +14 -9
  2655. data/third_party/upb/upb/reflection/method_def.h +8 -7
  2656. data/third_party/upb/upb/reflection/service_def.h +6 -5
  2657. data/third_party/upb/upb/text/encode.c +53 -389
  2658. data/third_party/upb/upb/text/encode.h +1 -11
  2659. data/third_party/upb/upb/text/internal/encode.c +180 -0
  2660. data/third_party/upb/upb/text/internal/encode.h +240 -0
  2661. data/third_party/upb/upb/text/options.h +22 -0
  2662. data/third_party/upb/upb/wire/decode.c +160 -94
  2663. data/third_party/upb/upb/wire/decode.h +15 -2
  2664. data/third_party/upb/upb/wire/encode.c +89 -48
  2665. data/third_party/upb/upb/wire/encode.h +12 -1
  2666. data/third_party/upb/upb/wire/eps_copy_input_stream.h +3 -3
  2667. data/third_party/upb/upb/wire/internal/decode_fast.c +28 -29
  2668. data/third_party/upb/upb/wire/internal/reader.h +3 -3
  2669. data/third_party/upb/upb/wire/reader.c +1 -2
  2670. data/third_party/upb/upb/wire/reader.h +4 -8
  2671. metadata +642 -545
  2672. data/src/core/client_channel/config_selector.cc +0 -60
  2673. data/src/core/ext/gcp/metadata_query.cc +0 -137
  2674. data/src/core/ext/gcp/metadata_query.h +0 -87
  2675. data/src/core/ext/transport/chttp2/transport/http_trace.cc +0 -19
  2676. data/src/core/ext/transport/chttp2/transport/http_trace.h +0 -24
  2677. data/src/core/ext/transport/chttp2/transport/max_concurrent_streams_policy.cc +0 -45
  2678. data/src/core/ext/transport/chttp2/transport/max_concurrent_streams_policy.h +0 -67
  2679. data/src/core/ext/transport/inproc/inproc_plugin.cc +0 -23
  2680. data/src/core/ext/upb-gen/envoy/config/trace/v3/opencensus.upb.h +0 -419
  2681. data/src/core/ext/upb-gen/envoy/config/trace/v3/opencensus.upb_minitable.c +0 -81
  2682. data/src/core/ext/upb-gen/envoy/config/trace/v3/opencensus.upb_minitable.h +0 -30
  2683. data/src/core/ext/upb-gen/opencensus/proto/trace/v1/trace_config.upb.h +0 -400
  2684. data/src/core/ext/upb-gen/opencensus/proto/trace/v1/trace_config.upb_minitable.c +0 -106
  2685. data/src/core/ext/upb-gen/opencensus/proto/trace/v1/trace_config.upb_minitable.h +0 -33
  2686. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/opencensus.upbdefs.c +0 -104
  2687. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/opencensus.upbdefs.h +0 -32
  2688. data/src/core/ext/upbdefs-gen/opencensus/proto/trace/v1/trace_config.upbdefs.c +0 -66
  2689. data/src/core/ext/upbdefs-gen/opencensus/proto/trace/v1/trace_config.upbdefs.h +0 -47
  2690. data/src/core/handshaker/security/tsi_error.cc +0 -31
  2691. data/src/core/handshaker/security/tsi_error.h +0 -30
  2692. data/src/core/lib/avl/avl.h +0 -325
  2693. data/src/core/lib/backoff/backoff.cc +0 -47
  2694. data/src/core/lib/backoff/backoff.h +0 -89
  2695. data/src/core/lib/backoff/random_early_detection.cc +0 -33
  2696. data/src/core/lib/backoff/random_early_detection.h +0 -62
  2697. data/src/core/lib/channel/call_tracer.cc +0 -364
  2698. data/src/core/lib/channel/call_tracer.h +0 -226
  2699. data/src/core/lib/channel/channel_stack_trace.cc +0 -19
  2700. data/src/core/lib/channel/channel_stack_trace.h +0 -24
  2701. data/src/core/lib/channel/context.h +0 -105
  2702. data/src/core/lib/channel/metrics.cc +0 -334
  2703. data/src/core/lib/channel/metrics.h +0 -365
  2704. data/src/core/lib/channel/tcp_tracer.h +0 -144
  2705. data/src/core/lib/config/config_vars.cc +0 -154
  2706. data/src/core/lib/config/config_vars.h +0 -131
  2707. data/src/core/lib/config/config_vars_non_generated.cc +0 -49
  2708. data/src/core/lib/config/core_configuration.cc +0 -112
  2709. data/src/core/lib/config/core_configuration.h +0 -244
  2710. data/src/core/lib/config/load_config.cc +0 -79
  2711. data/src/core/lib/config/load_config.h +0 -55
  2712. data/src/core/lib/debug/event_log.cc +0 -88
  2713. data/src/core/lib/debug/event_log.h +0 -81
  2714. data/src/core/lib/debug/histogram_view.cc +0 -69
  2715. data/src/core/lib/debug/histogram_view.h +0 -37
  2716. data/src/core/lib/debug/stats.cc +0 -68
  2717. data/src/core/lib/debug/stats.h +0 -64
  2718. data/src/core/lib/debug/stats_data.cc +0 -752
  2719. data/src/core/lib/debug/stats_data.h +0 -579
  2720. data/src/core/lib/event_engine/trace.cc +0 -25
  2721. data/src/core/lib/event_engine/trace.h +0 -48
  2722. data/src/core/lib/gpr/alloc.cc +0 -73
  2723. data/src/core/lib/gpr/alloc.h +0 -28
  2724. data/src/core/lib/gpr/android/log.cc +0 -79
  2725. data/src/core/lib/gpr/atm.cc +0 -35
  2726. data/src/core/lib/gpr/iphone/cpu.cc +0 -44
  2727. data/src/core/lib/gpr/linux/cpu.cc +0 -87
  2728. data/src/core/lib/gpr/linux/log.cc +0 -114
  2729. data/src/core/lib/gpr/log.cc +0 -166
  2730. data/src/core/lib/gpr/msys/tmpfile.cc +0 -59
  2731. data/src/core/lib/gpr/posix/cpu.cc +0 -84
  2732. data/src/core/lib/gpr/posix/log.cc +0 -111
  2733. data/src/core/lib/gpr/posix/string.cc +0 -72
  2734. data/src/core/lib/gpr/posix/sync.cc +0 -161
  2735. data/src/core/lib/gpr/posix/time.cc +0 -125
  2736. data/src/core/lib/gpr/posix/tmpfile.cc +0 -73
  2737. data/src/core/lib/gpr/spinlock.h +0 -53
  2738. data/src/core/lib/gpr/string.cc +0 -344
  2739. data/src/core/lib/gpr/string.h +0 -112
  2740. data/src/core/lib/gpr/sync.cc +0 -126
  2741. data/src/core/lib/gpr/sync_abseil.cc +0 -110
  2742. data/src/core/lib/gpr/time.cc +0 -271
  2743. data/src/core/lib/gpr/time_precise.cc +0 -168
  2744. data/src/core/lib/gpr/time_precise.h +0 -69
  2745. data/src/core/lib/gpr/tmpfile.h +0 -32
  2746. data/src/core/lib/gpr/useful.h +0 -184
  2747. data/src/core/lib/gpr/windows/cpu.cc +0 -35
  2748. data/src/core/lib/gpr/windows/log.cc +0 -116
  2749. data/src/core/lib/gpr/windows/string.cc +0 -69
  2750. data/src/core/lib/gpr/windows/string_util.cc +0 -55
  2751. data/src/core/lib/gpr/windows/sync.cc +0 -124
  2752. data/src/core/lib/gpr/windows/time.cc +0 -108
  2753. data/src/core/lib/gpr/windows/tmpfile.cc +0 -68
  2754. data/src/core/lib/gprpp/atomic_utils.h +0 -47
  2755. data/src/core/lib/gprpp/bitset.h +0 -225
  2756. data/src/core/lib/gprpp/chunked_vector.h +0 -258
  2757. data/src/core/lib/gprpp/construct_destruct.h +0 -40
  2758. data/src/core/lib/gprpp/cpp_impl_of.h +0 -49
  2759. data/src/core/lib/gprpp/crash.cc +0 -42
  2760. data/src/core/lib/gprpp/crash.h +0 -37
  2761. data/src/core/lib/gprpp/debug_location.h +0 -99
  2762. data/src/core/lib/gprpp/directory_reader.h +0 -48
  2763. data/src/core/lib/gprpp/down_cast.h +0 -49
  2764. data/src/core/lib/gprpp/dual_ref_counted.h +0 -365
  2765. data/src/core/lib/gprpp/env.h +0 -53
  2766. data/src/core/lib/gprpp/examine_stack.cc +0 -43
  2767. data/src/core/lib/gprpp/examine_stack.h +0 -45
  2768. data/src/core/lib/gprpp/fork.cc +0 -241
  2769. data/src/core/lib/gprpp/fork.h +0 -98
  2770. data/src/core/lib/gprpp/host_port.cc +0 -116
  2771. data/src/core/lib/gprpp/host_port.h +0 -57
  2772. data/src/core/lib/gprpp/if_list.h +0 -4530
  2773. data/src/core/lib/gprpp/linux/env.cc +0 -62
  2774. data/src/core/lib/gprpp/load_file.cc +0 -77
  2775. data/src/core/lib/gprpp/load_file.h +0 -34
  2776. data/src/core/lib/gprpp/manual_constructor.h +0 -146
  2777. data/src/core/lib/gprpp/match.h +0 -75
  2778. data/src/core/lib/gprpp/memory.h +0 -52
  2779. data/src/core/lib/gprpp/mpscq.cc +0 -108
  2780. data/src/core/lib/gprpp/mpscq.h +0 -100
  2781. data/src/core/lib/gprpp/no_destruct.h +0 -95
  2782. data/src/core/lib/gprpp/notification.h +0 -67
  2783. data/src/core/lib/gprpp/orphanable.h +0 -153
  2784. data/src/core/lib/gprpp/overload.h +0 -59
  2785. data/src/core/lib/gprpp/packed_table.h +0 -40
  2786. data/src/core/lib/gprpp/per_cpu.cc +0 -34
  2787. data/src/core/lib/gprpp/per_cpu.h +0 -103
  2788. data/src/core/lib/gprpp/posix/directory_reader.cc +0 -82
  2789. data/src/core/lib/gprpp/posix/env.cc +0 -47
  2790. data/src/core/lib/gprpp/posix/stat.cc +0 -56
  2791. data/src/core/lib/gprpp/posix/thd.cc +0 -247
  2792. data/src/core/lib/gprpp/ref_counted.h +0 -395
  2793. data/src/core/lib/gprpp/ref_counted_ptr.h +0 -445
  2794. data/src/core/lib/gprpp/ref_counted_string.cc +0 -43
  2795. data/src/core/lib/gprpp/ref_counted_string.h +0 -161
  2796. data/src/core/lib/gprpp/single_set_ptr.h +0 -88
  2797. data/src/core/lib/gprpp/sorted_pack.h +0 -89
  2798. data/src/core/lib/gprpp/stat.h +0 -36
  2799. data/src/core/lib/gprpp/status_helper.cc +0 -453
  2800. data/src/core/lib/gprpp/status_helper.h +0 -190
  2801. data/src/core/lib/gprpp/strerror.cc +0 -41
  2802. data/src/core/lib/gprpp/strerror.h +0 -29
  2803. data/src/core/lib/gprpp/sync.h +0 -200
  2804. data/src/core/lib/gprpp/table.h +0 -452
  2805. data/src/core/lib/gprpp/tchar.cc +0 -49
  2806. data/src/core/lib/gprpp/tchar.h +0 -33
  2807. data/src/core/lib/gprpp/thd.h +0 -195
  2808. data/src/core/lib/gprpp/time.cc +0 -242
  2809. data/src/core/lib/gprpp/time.h +0 -384
  2810. data/src/core/lib/gprpp/time_averaged_stats.cc +0 -60
  2811. data/src/core/lib/gprpp/time_averaged_stats.h +0 -79
  2812. data/src/core/lib/gprpp/time_util.cc +0 -82
  2813. data/src/core/lib/gprpp/time_util.h +0 -41
  2814. data/src/core/lib/gprpp/type_list.h +0 -32
  2815. data/src/core/lib/gprpp/unique_type_name.h +0 -104
  2816. data/src/core/lib/gprpp/uuid_v4.cc +0 -37
  2817. data/src/core/lib/gprpp/uuid_v4.h +0 -36
  2818. data/src/core/lib/gprpp/validation_errors.cc +0 -65
  2819. data/src/core/lib/gprpp/validation_errors.h +0 -134
  2820. data/src/core/lib/gprpp/windows/directory_reader.cc +0 -81
  2821. data/src/core/lib/gprpp/windows/env.cc +0 -56
  2822. data/src/core/lib/gprpp/windows/stat.cc +0 -52
  2823. data/src/core/lib/gprpp/windows/thd.cc +0 -184
  2824. data/src/core/lib/gprpp/work_serializer.cc +0 -558
  2825. data/src/core/lib/gprpp/work_serializer.h +0 -106
  2826. data/src/core/lib/gprpp/xxhash_inline.h +0 -29
  2827. data/src/core/lib/http/format_request.cc +0 -136
  2828. data/src/core/lib/http/format_request.h +0 -37
  2829. data/src/core/lib/http/httpcli.cc +0 -392
  2830. data/src/core/lib/http/httpcli.h +0 -267
  2831. data/src/core/lib/http/httpcli_security_connector.cc +0 -213
  2832. data/src/core/lib/http/httpcli_ssl_credentials.h +0 -38
  2833. data/src/core/lib/http/parser.cc +0 -451
  2834. data/src/core/lib/http/parser.h +0 -129
  2835. data/src/core/lib/iomgr/ev_windows.cc +0 -30
  2836. data/src/core/lib/iomgr/gethostname.h +0 -26
  2837. data/src/core/lib/iomgr/gethostname_fallback.cc +0 -30
  2838. data/src/core/lib/iomgr/gethostname_host_name_max.cc +0 -40
  2839. data/src/core/lib/iomgr/gethostname_sysconf.cc +0 -40
  2840. data/src/core/lib/iomgr/grpc_if_nametoindex.h +0 -30
  2841. data/src/core/lib/iomgr/grpc_if_nametoindex_posix.cc +0 -43
  2842. data/src/core/lib/iomgr/grpc_if_nametoindex_unsupported.cc +0 -39
  2843. data/src/core/lib/json/json.h +0 -29
  2844. data/src/core/lib/json/json_args.h +0 -34
  2845. data/src/core/lib/json/json_channel_args.h +0 -42
  2846. data/src/core/lib/json/json_object_loader.cc +0 -215
  2847. data/src/core/lib/json/json_object_loader.h +0 -645
  2848. data/src/core/lib/json/json_reader.cc +0 -956
  2849. data/src/core/lib/json/json_reader.h +0 -34
  2850. data/src/core/lib/json/json_util.cc +0 -101
  2851. data/src/core/lib/json/json_util.h +0 -164
  2852. data/src/core/lib/json/json_writer.cc +0 -339
  2853. data/src/core/lib/json/json_writer.h +0 -33
  2854. data/src/core/lib/matchers/matchers.cc +0 -330
  2855. data/src/core/lib/matchers/matchers.h +0 -163
  2856. data/src/core/lib/promise/trace.cc +0 -20
  2857. data/src/core/lib/promise/trace.h +0 -24
  2858. data/src/core/lib/resource_quota/trace.cc +0 -19
  2859. data/src/core/lib/resource_quota/trace.h +0 -24
  2860. data/src/core/lib/slice/slice_refcount.cc +0 -20
  2861. data/src/core/lib/surface/api_trace.cc +0 -25
  2862. data/src/core/lib/surface/api_trace.h +0 -52
  2863. data/src/core/lib/surface/call_trace.h +0 -24
  2864. data/src/core/lib/surface/wait_for_cq_end_op.cc +0 -75
  2865. data/src/core/lib/surface/wait_for_cq_end_op.h +0 -72
  2866. data/src/core/lib/transport/batch_builder.cc +0 -172
  2867. data/src/core/lib/transport/batch_builder.h +0 -474
  2868. data/src/core/lib/uri/uri_parser.cc +0 -372
  2869. data/src/core/lib/uri/uri_parser.h +0 -101
  2870. data/src/core/resolver/binder/binder_resolver.cc +0 -154
  2871. data/src/core/resolver/xds/xds_resolver_trace.cc +0 -25
  2872. data/src/core/resolver/xds/xds_resolver_trace.h +0 -30
  2873. data/src/core/xds/grpc/upb_utils.h +0 -45
  2874. data/src/core/xds/grpc/xds_http_filters.cc +0 -116
  2875. data/src/core/xds/grpc/xds_http_filters.h +0 -182
  2876. data/src/core/xds/xds_client/xds_client_stats.cc +0 -174
  2877. data/src/core/xds/xds_client/xds_client_stats.h +0 -258
  2878. data/third_party/abseil-cpp/absl/strings/internal/has_absl_stringify.h +0 -44
  2879. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_bitstr.c +0 -284
  2880. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_bool.c +0 -95
  2881. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_d2i_fp.c +0 -89
  2882. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_dup.c +0 -84
  2883. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_gentm.c +0 -151
  2884. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_i2d_fp.c +0 -85
  2885. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_int.c +0 -465
  2886. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_mbstr.c +0 -279
  2887. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_object.c +0 -235
  2888. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_octet.c +0 -74
  2889. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_strex.c +0 -457
  2890. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_strnid.c +0 -245
  2891. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_time.c +0 -259
  2892. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_type.c +0 -214
  2893. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_utctm.c +0 -183
  2894. data/third_party/boringssl-with-bazel/src/crypto/asn1/asn1_lib.c +0 -397
  2895. data/third_party/boringssl-with-bazel/src/crypto/asn1/asn1_par.c +0 -103
  2896. data/third_party/boringssl-with-bazel/src/crypto/asn1/asn_pack.c +0 -98
  2897. data/third_party/boringssl-with-bazel/src/crypto/asn1/f_int.c +0 -105
  2898. data/third_party/boringssl-with-bazel/src/crypto/asn1/f_string.c +0 -94
  2899. data/third_party/boringssl-with-bazel/src/crypto/asn1/posix_time.c +0 -241
  2900. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_dec.c +0 -973
  2901. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_enc.c +0 -708
  2902. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_fre.c +0 -212
  2903. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_new.c +0 -317
  2904. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_typ.c +0 -126
  2905. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_utl.c +0 -268
  2906. data/third_party/boringssl-with-bazel/src/crypto/base64/base64.c +0 -475
  2907. data/third_party/boringssl-with-bazel/src/crypto/bio/bio.c +0 -726
  2908. data/third_party/boringssl-with-bazel/src/crypto/bio/bio_mem.c +0 -309
  2909. data/third_party/boringssl-with-bazel/src/crypto/bio/connect.c +0 -544
  2910. data/third_party/boringssl-with-bazel/src/crypto/bio/errno.c +0 -92
  2911. data/third_party/boringssl-with-bazel/src/crypto/bio/fd.c +0 -235
  2912. data/third_party/boringssl-with-bazel/src/crypto/bio/file.c +0 -334
  2913. data/third_party/boringssl-with-bazel/src/crypto/bio/hexdump.c +0 -192
  2914. data/third_party/boringssl-with-bazel/src/crypto/bio/pair.c +0 -480
  2915. data/third_party/boringssl-with-bazel/src/crypto/bio/printf.c +0 -102
  2916. data/third_party/boringssl-with-bazel/src/crypto/bio/socket.c +0 -189
  2917. data/third_party/boringssl-with-bazel/src/crypto/bio/socket_helper.c +0 -133
  2918. data/third_party/boringssl-with-bazel/src/crypto/blake2/blake2.c +0 -169
  2919. data/third_party/boringssl-with-bazel/src/crypto/bn_extra/bn_asn1.c +0 -57
  2920. data/third_party/boringssl-with-bazel/src/crypto/bn_extra/convert.c +0 -465
  2921. data/third_party/boringssl-with-bazel/src/crypto/buf/buf.c +0 -158
  2922. data/third_party/boringssl-with-bazel/src/crypto/bytestring/asn1_compat.c +0 -53
  2923. data/third_party/boringssl-with-bazel/src/crypto/bytestring/ber.c +0 -266
  2924. data/third_party/boringssl-with-bazel/src/crypto/bytestring/cbb.c +0 -718
  2925. data/third_party/boringssl-with-bazel/src/crypto/bytestring/cbs.c +0 -913
  2926. data/third_party/boringssl-with-bazel/src/crypto/bytestring/unicode.c +0 -156
  2927. data/third_party/boringssl-with-bazel/src/crypto/chacha/chacha.c +0 -224
  2928. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/cipher_extra.c +0 -127
  2929. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/derive_key.c +0 -152
  2930. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_aesctrhmac.c +0 -284
  2931. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_aesgcmsiv.c +0 -841
  2932. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_chacha20poly1305.c +0 -341
  2933. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_des.c +0 -228
  2934. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_null.c +0 -90
  2935. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_rc2.c +0 -455
  2936. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_rc4.c +0 -94
  2937. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_tls.c +0 -598
  2938. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/internal.h +0 -237
  2939. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/tls_cbc.c +0 -514
  2940. data/third_party/boringssl-with-bazel/src/crypto/conf/conf.c +0 -647
  2941. data/third_party/boringssl-with-bazel/src/crypto/conf/conf_def.h +0 -122
  2942. data/third_party/boringssl-with-bazel/src/crypto/cpu_aarch64_apple.c +0 -75
  2943. data/third_party/boringssl-with-bazel/src/crypto/cpu_aarch64_fuchsia.c +0 -55
  2944. data/third_party/boringssl-with-bazel/src/crypto/cpu_aarch64_linux.c +0 -62
  2945. data/third_party/boringssl-with-bazel/src/crypto/cpu_aarch64_openbsd.c +0 -61
  2946. data/third_party/boringssl-with-bazel/src/crypto/cpu_aarch64_sysreg.c +0 -93
  2947. data/third_party/boringssl-with-bazel/src/crypto/cpu_aarch64_win.c +0 -41
  2948. data/third_party/boringssl-with-bazel/src/crypto/cpu_arm_freebsd.c +0 -54
  2949. data/third_party/boringssl-with-bazel/src/crypto/cpu_arm_linux.c +0 -148
  2950. data/third_party/boringssl-with-bazel/src/crypto/cpu_intel.c +0 -292
  2951. data/third_party/boringssl-with-bazel/src/crypto/crypto.c +0 -242
  2952. data/third_party/boringssl-with-bazel/src/crypto/curve25519/curve25519.c +0 -2157
  2953. data/third_party/boringssl-with-bazel/src/crypto/curve25519/curve25519_64_adx.c +0 -18
  2954. data/third_party/boringssl-with-bazel/src/crypto/curve25519/spake25519.c +0 -523
  2955. data/third_party/boringssl-with-bazel/src/crypto/des/des.c +0 -871
  2956. data/third_party/boringssl-with-bazel/src/crypto/dh_extra/dh_asn1.c +0 -165
  2957. data/third_party/boringssl-with-bazel/src/crypto/dh_extra/params.c +0 -480
  2958. data/third_party/boringssl-with-bazel/src/crypto/digest_extra/digest_extra.c +0 -266
  2959. data/third_party/boringssl-with-bazel/src/crypto/dsa/dsa.c +0 -990
  2960. data/third_party/boringssl-with-bazel/src/crypto/dsa/dsa_asn1.c +0 -421
  2961. data/third_party/boringssl-with-bazel/src/crypto/ec_extra/ec_asn1.c +0 -572
  2962. data/third_party/boringssl-with-bazel/src/crypto/ec_extra/ec_derive.c +0 -96
  2963. data/third_party/boringssl-with-bazel/src/crypto/ec_extra/hash_to_curve.c +0 -508
  2964. data/third_party/boringssl-with-bazel/src/crypto/ec_extra/internal.h +0 -78
  2965. data/third_party/boringssl-with-bazel/src/crypto/ecdh_extra/ecdh_extra.c +0 -124
  2966. data/third_party/boringssl-with-bazel/src/crypto/ecdsa_extra/ecdsa_asn1.c +0 -265
  2967. data/third_party/boringssl-with-bazel/src/crypto/engine/engine.c +0 -91
  2968. data/third_party/boringssl-with-bazel/src/crypto/err/err.c +0 -903
  2969. data/third_party/boringssl-with-bazel/src/crypto/evp/evp.c +0 -430
  2970. data/third_party/boringssl-with-bazel/src/crypto/evp/evp_asn1.c +0 -547
  2971. data/third_party/boringssl-with-bazel/src/crypto/evp/evp_ctx.c +0 -483
  2972. data/third_party/boringssl-with-bazel/src/crypto/evp/p_dh.c +0 -137
  2973. data/third_party/boringssl-with-bazel/src/crypto/evp/p_dh_asn1.c +0 -120
  2974. data/third_party/boringssl-with-bazel/src/crypto/evp/p_dsa_asn1.c +0 -338
  2975. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ec.c +0 -274
  2976. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ec_asn1.c +0 -332
  2977. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ed25519.c +0 -100
  2978. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ed25519_asn1.c +0 -224
  2979. data/third_party/boringssl-with-bazel/src/crypto/evp/p_hkdf.c +0 -232
  2980. data/third_party/boringssl-with-bazel/src/crypto/evp/p_rsa.c +0 -646
  2981. data/third_party/boringssl-with-bazel/src/crypto/evp/p_rsa_asn1.c +0 -241
  2982. data/third_party/boringssl-with-bazel/src/crypto/evp/p_x25519.c +0 -106
  2983. data/third_party/boringssl-with-bazel/src/crypto/evp/p_x25519_asn1.c +0 -236
  2984. data/third_party/boringssl-with-bazel/src/crypto/evp/pbkdf.c +0 -146
  2985. data/third_party/boringssl-with-bazel/src/crypto/evp/print.c +0 -381
  2986. data/third_party/boringssl-with-bazel/src/crypto/evp/scrypt.c +0 -209
  2987. data/third_party/boringssl-with-bazel/src/crypto/evp/sign.c +0 -156
  2988. data/third_party/boringssl-with-bazel/src/crypto/ex_data.c +0 -236
  2989. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/aes.c +0 -106
  2990. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/aes_nohw.c +0 -1281
  2991. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/key_wrap.c +0 -242
  2992. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/mode_wrappers.c +0 -124
  2993. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bcm.c +0 -275
  2994. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/add.c +0 -310
  2995. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/asm/x86_64-gcc.c +0 -541
  2996. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/bn.c +0 -428
  2997. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/bytes.c +0 -267
  2998. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/cmp.c +0 -201
  2999. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/ctx.c +0 -234
  3000. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/div.c +0 -909
  3001. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/div_extra.c +0 -87
  3002. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/exponentiation.c +0 -1276
  3003. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/gcd.c +0 -397
  3004. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/gcd_extra.c +0 -331
  3005. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/generic.c +0 -624
  3006. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/jacobi.c +0 -146
  3007. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/montgomery.c +0 -532
  3008. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/montgomery_inv.c +0 -222
  3009. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/mul.c +0 -744
  3010. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/prime.c +0 -1077
  3011. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/random.c +0 -356
  3012. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/rsaz_exp.c +0 -137
  3013. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/shift.c +0 -363
  3014. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/sqrt.c +0 -499
  3015. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/aead.c +0 -287
  3016. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/cipher.c +0 -717
  3017. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/e_aes.c +0 -1463
  3018. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/e_aesccm.c +0 -446
  3019. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cmac/cmac.c +0 -322
  3020. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/dh/check.c +0 -245
  3021. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/dh/dh.c +0 -489
  3022. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digest/digest.c +0 -288
  3023. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digest/digests.c +0 -304
  3024. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digestsign/digestsign.c +0 -267
  3025. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/ec.c +0 -1043
  3026. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/ec_key.c +0 -557
  3027. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/ec_montgomery.c +0 -491
  3028. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/felem.c +0 -104
  3029. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/oct.c +0 -359
  3030. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p224-64.c +0 -1163
  3031. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p256-nistz.c +0 -637
  3032. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p256.c +0 -749
  3033. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/scalar.c +0 -173
  3034. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/simple.c +0 -336
  3035. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/simple_mul.c +0 -269
  3036. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/util.c +0 -255
  3037. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/wnaf.c +0 -264
  3038. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ecdh/ecdh.c +0 -130
  3039. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ecdsa/ecdsa.c +0 -372
  3040. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/fips_shared_support.c +0 -32
  3041. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/hkdf/hkdf.c +0 -112
  3042. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/hmac/hmac.c +0 -256
  3043. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/md4/md4.c +0 -240
  3044. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/md5/internal.h +0 -37
  3045. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/md5/md5.c +0 -284
  3046. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/cbc.c +0 -164
  3047. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/cfb.c +0 -200
  3048. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/ctr.c +0 -196
  3049. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/gcm.c +0 -743
  3050. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/gcm_nohw.c +0 -302
  3051. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/internal.h +0 -428
  3052. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/ofb.c +0 -87
  3053. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/polyval.c +0 -90
  3054. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/ctrdrbg.c +0 -220
  3055. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/fork_detect.c +0 -197
  3056. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/fork_detect.h +0 -68
  3057. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/getrandom_fillin.h +0 -64
  3058. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/rand.c +0 -493
  3059. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/urandom.c +0 -328
  3060. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/blinding.c +0 -241
  3061. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/padding.c +0 -423
  3062. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/rsa.c +0 -1038
  3063. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/rsa_impl.c +0 -1351
  3064. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/self_check/fips.c +0 -119
  3065. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/self_check/self_check.c +0 -1064
  3066. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/service_indicator/service_indicator.c +0 -328
  3067. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/sha1.c +0 -439
  3068. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/sha256.c +0 -359
  3069. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/sha512.c +0 -537
  3070. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/tls/kdf.c +0 -218
  3071. data/third_party/boringssl-with-bazel/src/crypto/hpke/hpke.c +0 -801
  3072. data/third_party/boringssl-with-bazel/src/crypto/hrss/hrss.c +0 -2234
  3073. data/third_party/boringssl-with-bazel/src/crypto/keccak/internal.h +0 -70
  3074. data/third_party/boringssl-with-bazel/src/crypto/keccak/keccak.c +0 -279
  3075. data/third_party/boringssl-with-bazel/src/crypto/kyber/kyber.c +0 -844
  3076. data/third_party/boringssl-with-bazel/src/crypto/lhash/lhash.c +0 -350
  3077. data/third_party/boringssl-with-bazel/src/crypto/mem.c +0 -609
  3078. data/third_party/boringssl-with-bazel/src/crypto/obj/obj.c +0 -564
  3079. data/third_party/boringssl-with-bazel/src/crypto/obj/obj_xref.c +0 -122
  3080. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_all.c +0 -243
  3081. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_info.c +0 -294
  3082. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_lib.c +0 -790
  3083. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_oth.c +0 -87
  3084. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_pk8.c +0 -251
  3085. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_pkey.c +0 -183
  3086. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_x509.c +0 -64
  3087. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_xaux.c +0 -64
  3088. data/third_party/boringssl-with-bazel/src/crypto/pkcs7/pkcs7.c +0 -193
  3089. data/third_party/boringssl-with-bazel/src/crypto/pkcs7/pkcs7_x509.c +0 -523
  3090. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/p5_pbev2.c +0 -316
  3091. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/pkcs8.c +0 -527
  3092. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/pkcs8_x509.c +0 -1352
  3093. data/third_party/boringssl-with-bazel/src/crypto/poly1305/poly1305.c +0 -314
  3094. data/third_party/boringssl-with-bazel/src/crypto/poly1305/poly1305_arm.c +0 -308
  3095. data/third_party/boringssl-with-bazel/src/crypto/poly1305/poly1305_vec.c +0 -847
  3096. data/third_party/boringssl-with-bazel/src/crypto/pool/pool.c +0 -261
  3097. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/deterministic.c +0 -57
  3098. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/forkunsafe.c +0 -44
  3099. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/getentropy.c +0 -52
  3100. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/ios.c +0 -34
  3101. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/passive.c +0 -158
  3102. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/rand_extra.c +0 -74
  3103. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/trusty.c +0 -38
  3104. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/windows.c +0 -95
  3105. data/third_party/boringssl-with-bazel/src/crypto/rc4/rc4.c +0 -98
  3106. data/third_party/boringssl-with-bazel/src/crypto/refcount.c +0 -59
  3107. data/third_party/boringssl-with-bazel/src/crypto/rsa_extra/internal.h +0 -77
  3108. data/third_party/boringssl-with-bazel/src/crypto/rsa_extra/rsa_asn1.c +0 -324
  3109. data/third_party/boringssl-with-bazel/src/crypto/rsa_extra/rsa_crypt.c +0 -570
  3110. data/third_party/boringssl-with-bazel/src/crypto/rsa_extra/rsa_print.c +0 -22
  3111. data/third_party/boringssl-with-bazel/src/crypto/siphash/siphash.c +0 -79
  3112. data/third_party/boringssl-with-bazel/src/crypto/spx/address.c +0 -101
  3113. data/third_party/boringssl-with-bazel/src/crypto/spx/address.h +0 -50
  3114. data/third_party/boringssl-with-bazel/src/crypto/spx/fors.c +0 -133
  3115. data/third_party/boringssl-with-bazel/src/crypto/spx/fors.h +0 -54
  3116. data/third_party/boringssl-with-bazel/src/crypto/spx/merkle.c +0 -150
  3117. data/third_party/boringssl-with-bazel/src/crypto/spx/merkle.h +0 -61
  3118. data/third_party/boringssl-with-bazel/src/crypto/spx/params.h +0 -71
  3119. data/third_party/boringssl-with-bazel/src/crypto/spx/spx.c +0 -140
  3120. data/third_party/boringssl-with-bazel/src/crypto/spx/spx_util.c +0 -53
  3121. data/third_party/boringssl-with-bazel/src/crypto/spx/spx_util.h +0 -44
  3122. data/third_party/boringssl-with-bazel/src/crypto/spx/thash.c +0 -136
  3123. data/third_party/boringssl-with-bazel/src/crypto/spx/thash.h +0 -70
  3124. data/third_party/boringssl-with-bazel/src/crypto/spx/wots.c +0 -135
  3125. data/third_party/boringssl-with-bazel/src/crypto/spx/wots.h +0 -45
  3126. data/third_party/boringssl-with-bazel/src/crypto/stack/stack.c +0 -534
  3127. data/third_party/boringssl-with-bazel/src/crypto/thread.c +0 -110
  3128. data/third_party/boringssl-with-bazel/src/crypto/thread_none.c +0 -51
  3129. data/third_party/boringssl-with-bazel/src/crypto/thread_pthread.c +0 -150
  3130. data/third_party/boringssl-with-bazel/src/crypto/thread_win.c +0 -236
  3131. data/third_party/boringssl-with-bazel/src/crypto/trust_token/pmbtoken.c +0 -1668
  3132. data/third_party/boringssl-with-bazel/src/crypto/trust_token/trust_token.c +0 -687
  3133. data/third_party/boringssl-with-bazel/src/crypto/trust_token/voprf.c +0 -1267
  3134. data/third_party/boringssl-with-bazel/src/crypto/x509/a_digest.c +0 -94
  3135. data/third_party/boringssl-with-bazel/src/crypto/x509/a_sign.c +0 -136
  3136. data/third_party/boringssl-with-bazel/src/crypto/x509/a_verify.c +0 -116
  3137. data/third_party/boringssl-with-bazel/src/crypto/x509/algorithm.c +0 -178
  3138. data/third_party/boringssl-with-bazel/src/crypto/x509/asn1_gen.c +0 -585
  3139. data/third_party/boringssl-with-bazel/src/crypto/x509/by_dir.c +0 -400
  3140. data/third_party/boringssl-with-bazel/src/crypto/x509/by_file.c +0 -269
  3141. data/third_party/boringssl-with-bazel/src/crypto/x509/i2d_pr.c +0 -79
  3142. data/third_party/boringssl-with-bazel/src/crypto/x509/name_print.c +0 -227
  3143. data/third_party/boringssl-with-bazel/src/crypto/x509/policy.c +0 -786
  3144. data/third_party/boringssl-with-bazel/src/crypto/x509/rsa_pss.c +0 -401
  3145. data/third_party/boringssl-with-bazel/src/crypto/x509/t_crl.c +0 -145
  3146. data/third_party/boringssl-with-bazel/src/crypto/x509/t_req.c +0 -245
  3147. data/third_party/boringssl-with-bazel/src/crypto/x509/t_x509.c +0 -329
  3148. data/third_party/boringssl-with-bazel/src/crypto/x509/t_x509a.c +0 -121
  3149. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_akey.c +0 -221
  3150. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_akeya.c +0 -73
  3151. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_alt.c +0 -634
  3152. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_bcons.c +0 -135
  3153. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_bitst.c +0 -141
  3154. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_conf.c +0 -416
  3155. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_cpols.c +0 -482
  3156. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_crld.c +0 -598
  3157. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_enum.c +0 -112
  3158. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_extku.c +0 -154
  3159. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_genn.c +0 -270
  3160. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_ia5.c +0 -122
  3161. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_info.c +0 -211
  3162. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_int.c +0 -121
  3163. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_lib.c +0 -344
  3164. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_ncons.c +0 -555
  3165. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_ocsp.c +0 -81
  3166. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_pcons.c +0 -142
  3167. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_pmaps.c +0 -150
  3168. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_prn.c +0 -224
  3169. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_purp.c +0 -624
  3170. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_skey.c +0 -170
  3171. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_utl.c +0 -1357
  3172. data/third_party/boringssl-with-bazel/src/crypto/x509/x509.c +0 -89
  3173. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_att.c +0 -227
  3174. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_cmp.c +0 -280
  3175. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_d2.c +0 -108
  3176. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_def.c +0 -86
  3177. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_ext.c +0 -181
  3178. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_lu.c +0 -609
  3179. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_obj.c +0 -206
  3180. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_req.c +0 -299
  3181. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_set.c +0 -240
  3182. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_trs.c +0 -160
  3183. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_txt.c +0 -189
  3184. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_v3.c +0 -291
  3185. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_vfy.c +0 -1648
  3186. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_vpm.c +0 -440
  3187. data/third_party/boringssl-with-bazel/src/crypto/x509/x509cset.c +0 -277
  3188. data/third_party/boringssl-with-bazel/src/crypto/x509/x509name.c +0 -407
  3189. data/third_party/boringssl-with-bazel/src/crypto/x509/x509rset.c +0 -109
  3190. data/third_party/boringssl-with-bazel/src/crypto/x509/x509spki.c +0 -133
  3191. data/third_party/boringssl-with-bazel/src/crypto/x509/x_algor.c +0 -149
  3192. data/third_party/boringssl-with-bazel/src/crypto/x509/x_all.c +0 -356
  3193. data/third_party/boringssl-with-bazel/src/crypto/x509/x_attrib.c +0 -97
  3194. data/third_party/boringssl-with-bazel/src/crypto/x509/x_crl.c +0 -384
  3195. data/third_party/boringssl-with-bazel/src/crypto/x509/x_exten.c +0 -78
  3196. data/third_party/boringssl-with-bazel/src/crypto/x509/x_name.c +0 -527
  3197. data/third_party/boringssl-with-bazel/src/crypto/x509/x_pubkey.c +0 -210
  3198. data/third_party/boringssl-with-bazel/src/crypto/x509/x_req.c +0 -116
  3199. data/third_party/boringssl-with-bazel/src/crypto/x509/x_sig.c +0 -93
  3200. data/third_party/boringssl-with-bazel/src/crypto/x509/x_spki.c +0 -79
  3201. data/third_party/boringssl-with-bazel/src/crypto/x509/x_val.c +0 -70
  3202. data/third_party/boringssl-with-bazel/src/crypto/x509/x_x509.c +0 -544
  3203. data/third_party/boringssl-with-bazel/src/crypto/x509/x_x509a.c +0 -209
  3204. data/third_party/boringssl-with-bazel/src/gen/crypto/err_data.c +0 -1514
  3205. data/third_party/boringssl-with-bazel/src/include/openssl/experimental/spx.h +0 -90
@@ -14,23 +14,32 @@
14
14
  // limitations under the License.
15
15
  //
16
16
 
17
- #include <grpc/support/port_platform.h>
18
-
19
17
  #include "src/core/client_channel/client_channel_filter.h"
20
18
 
19
+ #include <grpc/event_engine/event_engine.h>
20
+ #include <grpc/impl/channel_arg_names.h>
21
+ #include <grpc/slice.h>
22
+ #include <grpc/status.h>
23
+ #include <grpc/support/json.h>
24
+ #include <grpc/support/port_platform.h>
25
+ #include <grpc/support/string_util.h>
26
+ #include <grpc/support/time.h>
21
27
  #include <inttypes.h>
22
28
  #include <limits.h>
23
29
 
24
30
  #include <algorithm>
25
31
  #include <functional>
26
32
  #include <new>
33
+ #include <optional>
27
34
  #include <set>
28
35
  #include <type_traits>
29
36
  #include <utility>
37
+ #include <variant>
30
38
  #include <vector>
31
39
 
32
40
  #include "absl/cleanup/cleanup.h"
33
41
  #include "absl/log/check.h"
42
+ #include "absl/log/log.h"
34
43
  #include "absl/status/status.h"
35
44
  #include "absl/status/statusor.h"
36
45
  #include "absl/strings/cord.h"
@@ -38,18 +47,6 @@
38
47
  #include "absl/strings/str_cat.h"
39
48
  #include "absl/strings/str_join.h"
40
49
  #include "absl/strings/string_view.h"
41
- #include "absl/types/optional.h"
42
- #include "absl/types/variant.h"
43
-
44
- #include <grpc/event_engine/event_engine.h>
45
- #include <grpc/impl/channel_arg_names.h>
46
- #include <grpc/slice.h>
47
- #include <grpc/status.h>
48
- #include <grpc/support/json.h>
49
- #include <grpc/support/log.h>
50
- #include <grpc/support/string_util.h>
51
- #include <grpc/support/time.h>
52
-
53
50
  #include "src/core/channelz/channel_trace.h"
54
51
  #include "src/core/client_channel/backup_poller.h"
55
52
  #include "src/core/client_channel/client_channel_internal.h"
@@ -57,30 +54,23 @@
57
54
  #include "src/core/client_channel/config_selector.h"
58
55
  #include "src/core/client_channel/dynamic_filters.h"
59
56
  #include "src/core/client_channel/global_subchannel_pool.h"
57
+ #include "src/core/client_channel/lb_metadata.h"
60
58
  #include "src/core/client_channel/local_subchannel_pool.h"
61
59
  #include "src/core/client_channel/retry_filter.h"
62
60
  #include "src/core/client_channel/subchannel.h"
63
61
  #include "src/core/client_channel/subchannel_interface_internal.h"
62
+ #include "src/core/config/core_configuration.h"
64
63
  #include "src/core/handshaker/proxy_mapper_registry.h"
64
+ #include "src/core/lib/address_utils/sockaddr_utils.h"
65
65
  #include "src/core/lib/channel/channel_args.h"
66
66
  #include "src/core/lib/channel/channel_stack.h"
67
67
  #include "src/core/lib/channel/status_util.h"
68
- #include "src/core/lib/config/core_configuration.h"
69
68
  #include "src/core/lib/debug/trace.h"
70
69
  #include "src/core/lib/experiments/experiments.h"
71
- #include "src/core/lib/gpr/useful.h"
72
- #include "src/core/lib/gprpp/crash.h"
73
- #include "src/core/lib/gprpp/debug_location.h"
74
- #include "src/core/lib/gprpp/manual_constructor.h"
75
- #include "src/core/lib/gprpp/status_helper.h"
76
- #include "src/core/lib/gprpp/sync.h"
77
- #include "src/core/lib/gprpp/unique_type_name.h"
78
- #include "src/core/lib/gprpp/work_serializer.h"
79
70
  #include "src/core/lib/iomgr/exec_ctx.h"
80
71
  #include "src/core/lib/iomgr/polling_entity.h"
81
72
  #include "src/core/lib/iomgr/pollset_set.h"
82
73
  #include "src/core/lib/iomgr/resolved_address.h"
83
- #include "src/core/lib/json/json.h"
84
74
  #include "src/core/lib/promise/cancel_callback.h"
85
75
  #include "src/core/lib/promise/context.h"
86
76
  #include "src/core/lib/promise/latch.h"
@@ -104,6 +94,15 @@
104
94
  #include "src/core/resolver/resolver_registry.h"
105
95
  #include "src/core/service_config/service_config_call_data.h"
106
96
  #include "src/core/service_config/service_config_impl.h"
97
+ #include "src/core/util/crash.h"
98
+ #include "src/core/util/debug_location.h"
99
+ #include "src/core/util/json/json.h"
100
+ #include "src/core/util/manual_constructor.h"
101
+ #include "src/core/util/status_helper.h"
102
+ #include "src/core/util/sync.h"
103
+ #include "src/core/util/unique_type_name.h"
104
+ #include "src/core/util/useful.h"
105
+ #include "src/core/util/work_serializer.h"
107
106
 
108
107
  //
109
108
  // Client channel filter
@@ -113,10 +112,6 @@ namespace grpc_core {
113
112
 
114
113
  using internal::ClientChannelMethodParsedConfig;
115
114
 
116
- TraceFlag grpc_client_channel_trace(false, "client_channel");
117
- TraceFlag grpc_client_channel_call_trace(false, "client_channel_call");
118
- TraceFlag grpc_client_channel_lb_call_trace(false, "client_channel_lb_call");
119
-
120
115
  //
121
116
  // ClientChannelFilter::CallData definition
122
117
  //
@@ -144,14 +139,14 @@ class ClientChannelFilter::CallData {
144
139
  // Checks whether a resolver result is available. The following
145
140
  // outcomes are possible:
146
141
  // - No resolver result is available yet. The call will be queued and
147
- // absl::nullopt will be returned. Later, when a resolver result
142
+ // std::nullopt will be returned. Later, when a resolver result
148
143
  // becomes available, RetryCheckResolutionLocked() will be called.
149
144
  // - The resolver has returned a transient failure. If the call is
150
145
  // not wait_for_ready, a non-OK status will be returned. (If the
151
146
  // call *is* wait_for_ready, it will be queued instead.)
152
147
  // - There is a valid resolver result. The service config will be
153
148
  // stored in the call context and an OK status will be returned.
154
- absl::optional<absl::Status> CheckResolution(bool was_queued);
149
+ std::optional<absl::Status> CheckResolution(bool was_queued);
155
150
 
156
151
  private:
157
152
  // Accessors for data stored in the subclass.
@@ -159,7 +154,6 @@ class ClientChannelFilter::CallData {
159
154
  virtual Arena* arena() const = 0;
160
155
  virtual grpc_polling_entity* pollent() = 0;
161
156
  virtual grpc_metadata_batch* send_initial_metadata() = 0;
162
- virtual grpc_call_context_element* call_context() const = 0;
163
157
 
164
158
  // Helper function for CheckResolution(). Returns true if the call
165
159
  // can continue (i.e., there is a valid resolution result, or there is
@@ -222,9 +216,6 @@ class ClientChannelFilter::FilterBasedCallData final
222
216
  return pending_batches_[0]
223
217
  ->payload->send_initial_metadata.send_initial_metadata;
224
218
  }
225
- grpc_call_context_element* call_context() const override {
226
- return call_context_;
227
- }
228
219
 
229
220
  // Returns the index into pending_batches_ to be used for batch.
230
221
  static size_t GetBatchIndex(grpc_transport_stream_op_batch* batch);
@@ -269,8 +260,7 @@ class ClientChannelFilter::FilterBasedCallData final
269
260
  void ResetDeadline(Duration timeout) override {
270
261
  const Timestamp per_method_deadline =
271
262
  Timestamp::FromCycleCounterRoundUp(call_start_time_) + timeout;
272
- static_cast<Call*>(call_context_[GRPC_CONTEXT_CALL].value)
273
- ->UpdateDeadline(per_method_deadline);
263
+ arena_->GetContext<Call>()->UpdateDeadline(per_method_deadline);
274
264
  }
275
265
 
276
266
  void CreateDynamicCall();
@@ -279,7 +269,6 @@ class ClientChannelFilter::FilterBasedCallData final
279
269
  void* arg, grpc_error_handle error);
280
270
 
281
271
  grpc_slice path_; // Request path.
282
- grpc_call_context_element* call_context_;
283
272
  gpr_cycle_counter call_start_time_;
284
273
  Timestamp deadline_;
285
274
 
@@ -310,122 +299,12 @@ class ClientChannelFilter::FilterBasedCallData final
310
299
  grpc_error_handle cancel_error_;
311
300
  };
312
301
 
313
- class ClientChannelFilter::PromiseBasedCallData final
314
- : public ClientChannelFilter::CallData {
315
- public:
316
- explicit PromiseBasedCallData(ClientChannelFilter* chand) : chand_(chand) {}
317
-
318
- ~PromiseBasedCallData() override {
319
- if (was_queued_ && client_initial_metadata_ != nullptr) {
320
- MutexLock lock(&chand_->resolution_mu_);
321
- RemoveCallFromResolverQueuedCallsLocked();
322
- chand_->resolver_queued_calls_.erase(this);
323
- }
324
- }
325
-
326
- ArenaPromise<absl::StatusOr<CallArgs>> MakeNameResolutionPromise(
327
- CallArgs call_args) {
328
- pollent_ = NowOrNever(call_args.polling_entity->WaitAndCopy()).value();
329
- client_initial_metadata_ = std::move(call_args.client_initial_metadata);
330
- // If we're still in IDLE, we need to start resolving.
331
- if (GPR_UNLIKELY(chand_->CheckConnectivityState(false) ==
332
- GRPC_CHANNEL_IDLE)) {
333
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_call_trace)) {
334
- gpr_log(GPR_INFO, "chand=%p calld=%p: %striggering exit idle", chand_,
335
- this, GetContext<Activity>()->DebugTag().c_str());
336
- }
337
- // Bounce into the control plane work serializer to start resolving.
338
- GRPC_CHANNEL_STACK_REF(chand_->owning_stack_, "ExitIdle");
339
- chand_->work_serializer_->Run(
340
- [chand = chand_]()
341
- ABSL_EXCLUSIVE_LOCKS_REQUIRED(*chand_->work_serializer_) {
342
- chand->CheckConnectivityState(/*try_to_connect=*/true);
343
- GRPC_CHANNEL_STACK_UNREF(chand->owning_stack_, "ExitIdle");
344
- },
345
- DEBUG_LOCATION);
346
- }
347
- return [this, call_args = std::move(
348
- call_args)]() mutable -> Poll<absl::StatusOr<CallArgs>> {
349
- auto result = CheckResolution(was_queued_);
350
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_call_trace)) {
351
- gpr_log(GPR_INFO, "chand=%p calld=%p: %sCheckResolution returns %s",
352
- chand_, this, GetContext<Activity>()->DebugTag().c_str(),
353
- result.has_value() ? result->ToString().c_str() : "Pending");
354
- }
355
- if (!result.has_value()) return Pending{};
356
- if (!result->ok()) return *result;
357
- call_args.client_initial_metadata = std::move(client_initial_metadata_);
358
- return std::move(call_args);
359
- };
360
- }
361
-
362
- private:
363
- ClientChannelFilter* chand() const override { return chand_; }
364
- Arena* arena() const override { return GetContext<Arena>(); }
365
- grpc_polling_entity* pollent() override { return &pollent_; }
366
- grpc_metadata_batch* send_initial_metadata() override {
367
- return client_initial_metadata_.get();
368
- }
369
- grpc_call_context_element* call_context() const override {
370
- return GetContext<grpc_call_context_element>();
371
- }
372
-
373
- void OnAddToQueueLocked() override
374
- ABSL_EXCLUSIVE_LOCKS_REQUIRED(&ClientChannelFilter::resolution_mu_) {
375
- waker_ = GetContext<Activity>()->MakeNonOwningWaker();
376
- was_queued_ = true;
377
- }
378
-
379
- void RetryCheckResolutionLocked() ABSL_EXCLUSIVE_LOCKS_REQUIRED(
380
- &ClientChannelFilter::resolution_mu_) override {
381
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_call_trace)) {
382
- gpr_log(GPR_INFO, "chand=%p calld=%p: RetryCheckResolutionLocked(): %s",
383
- chand_, this, waker_.ActivityDebugTag().c_str());
384
- }
385
- waker_.WakeupAsync();
386
- }
387
-
388
- void ResetDeadline(Duration timeout) override {
389
- Call* call = GetContext<Call>();
390
- CallContext* call_context = GetContext<CallContext>();
391
- const Timestamp per_method_deadline =
392
- Timestamp::FromCycleCounterRoundUp(call_context->call_start_time()) +
393
- timeout;
394
- call->UpdateDeadline(per_method_deadline);
395
- }
396
-
397
- ClientChannelFilter* chand_;
398
- grpc_polling_entity pollent_;
399
- ClientMetadataHandle client_initial_metadata_;
400
- bool was_queued_ = false;
401
- Waker waker_ ABSL_GUARDED_BY(&ClientChannelFilter::resolution_mu_);
402
- };
403
-
404
302
  //
405
303
  // Filter vtable
406
304
  //
407
305
 
408
- const grpc_channel_filter ClientChannelFilter::kFilterVtableWithPromises = {
409
- ClientChannelFilter::FilterBasedCallData::StartTransportStreamOpBatch,
410
- ClientChannelFilter::MakeCallPromise,
411
- /* init_call: */ nullptr,
412
- ClientChannelFilter::StartTransportOp,
413
- sizeof(ClientChannelFilter::FilterBasedCallData),
414
- ClientChannelFilter::FilterBasedCallData::Init,
415
- ClientChannelFilter::FilterBasedCallData::SetPollent,
416
- ClientChannelFilter::FilterBasedCallData::Destroy,
417
- sizeof(ClientChannelFilter),
418
- ClientChannelFilter::Init,
419
- grpc_channel_stack_no_post_init,
420
- ClientChannelFilter::Destroy,
421
- ClientChannelFilter::GetChannelInfo,
422
- "client-channel",
423
- };
424
-
425
- const grpc_channel_filter ClientChannelFilter::kFilterVtableWithoutPromises = {
306
+ const grpc_channel_filter ClientChannelFilter::kFilter = {
426
307
  ClientChannelFilter::FilterBasedCallData::StartTransportStreamOpBatch,
427
- nullptr,
428
- /* init_call: */ nullptr,
429
308
  ClientChannelFilter::StartTransportOp,
430
309
  sizeof(ClientChannelFilter::FilterBasedCallData),
431
310
  ClientChannelFilter::FilterBasedCallData::Init,
@@ -436,7 +315,7 @@ const grpc_channel_filter ClientChannelFilter::kFilterVtableWithoutPromises = {
436
315
  grpc_channel_stack_no_post_init,
437
316
  ClientChannelFilter::Destroy,
438
317
  ClientChannelFilter::GetChannelInfo,
439
- "client-channel",
318
+ GRPC_UNIQUE_TYPE_NAME_HERE("client-channel"),
440
319
  };
441
320
 
442
321
  //
@@ -445,10 +324,9 @@ const grpc_channel_filter ClientChannelFilter::kFilterVtableWithoutPromises = {
445
324
 
446
325
  namespace {
447
326
 
448
- ClientChannelServiceConfigCallData* GetServiceConfigCallData(
449
- grpc_call_context_element* context) {
450
- return static_cast<ClientChannelServiceConfigCallData*>(
451
- context[GRPC_CONTEXT_SERVICE_CONFIG_CALL_DATA].value);
327
+ ClientChannelServiceConfigCallData* GetServiceConfigCallData(Arena* arena) {
328
+ return DownCast<ClientChannelServiceConfigCallData*>(
329
+ arena->GetContext<ServiceConfigCallData>());
452
330
  }
453
331
 
454
332
  class DynamicTerminationFilter final {
@@ -476,19 +354,6 @@ class DynamicTerminationFilter final {
476
354
  static void GetChannelInfo(grpc_channel_element* /*elem*/,
477
355
  const grpc_channel_info* /*info*/) {}
478
356
 
479
- static ArenaPromise<ServerMetadataHandle> MakeCallPromise(
480
- grpc_channel_element* elem, CallArgs call_args, NextPromiseFactory) {
481
- auto* chand = static_cast<DynamicTerminationFilter*>(elem->channel_data);
482
- return chand->chand_->CreateLoadBalancedCallPromise(
483
- std::move(call_args),
484
- []() {
485
- auto* service_config_call_data =
486
- GetServiceConfigCallData(GetContext<grpc_call_context_element>());
487
- service_config_call_data->Commit();
488
- },
489
- /*is_transparent_retry=*/false);
490
- }
491
-
492
357
  private:
493
358
  explicit DynamicTerminationFilter(const ChannelArgs& args)
494
359
  : chand_(args.GetObject<ClientChannelFilter>()) {}
@@ -532,21 +397,18 @@ class DynamicTerminationFilter::CallData final {
532
397
  auto* calld = static_cast<CallData*>(elem->call_data);
533
398
  auto* chand = static_cast<DynamicTerminationFilter*>(elem->channel_data);
534
399
  ClientChannelFilter* client_channel = chand->chand_;
535
- grpc_call_element_args args = {calld->owning_call_, nullptr,
536
- calld->call_context_, calld->path_,
537
- /*start_time=*/0, calld->deadline_,
538
- calld->arena_, calld->call_combiner_};
539
- auto* service_config_call_data =
540
- GetServiceConfigCallData(calld->call_context_);
400
+ grpc_call_element_args args = {calld->owning_call_, nullptr,
401
+ calld->path_,
402
+ /*start_time=*/0, calld->deadline_,
403
+ calld->arena_, calld->call_combiner_};
404
+ auto* service_config_call_data = GetServiceConfigCallData(calld->arena_);
541
405
  calld->lb_call_ = client_channel->CreateLoadBalancedCall(
542
406
  args, pollent, nullptr,
543
407
  [service_config_call_data]() { service_config_call_data->Commit(); },
544
408
  /*is_transparent_retry=*/false);
545
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_call_trace)) {
546
- gpr_log(GPR_INFO,
547
- "chand=%p dynamic_termination_calld=%p: create lb_call=%p", chand,
548
- client_channel, calld->lb_call_.get());
549
- }
409
+ GRPC_TRACE_LOG(client_channel_call, INFO)
410
+ << "chand=" << chand << " dynamic_termination_calld=" << client_channel
411
+ << ": create lb_call=" << calld->lb_call_.get();
550
412
  }
551
413
 
552
414
  private:
@@ -555,8 +417,7 @@ class DynamicTerminationFilter::CallData final {
555
417
  deadline_(args.deadline),
556
418
  arena_(args.arena),
557
419
  owning_call_(args.call_stack),
558
- call_combiner_(args.call_combiner),
559
- call_context_(args.context) {}
420
+ call_combiner_(args.call_combiner) {}
560
421
 
561
422
  ~CallData() { CSliceUnref(path_); }
562
423
 
@@ -565,15 +426,12 @@ class DynamicTerminationFilter::CallData final {
565
426
  Arena* arena_;
566
427
  grpc_call_stack* owning_call_;
567
428
  CallCombiner* call_combiner_;
568
- grpc_call_context_element* call_context_;
569
429
 
570
430
  OrphanablePtr<ClientChannelFilter::FilterBasedLoadBalancedCall> lb_call_;
571
431
  };
572
432
 
573
433
  const grpc_channel_filter DynamicTerminationFilter::kFilterVtable = {
574
434
  DynamicTerminationFilter::CallData::StartTransportStreamOpBatch,
575
- DynamicTerminationFilter::MakeCallPromise,
576
- /* init_call: */ nullptr,
577
435
  DynamicTerminationFilter::StartTransportOp,
578
436
  sizeof(DynamicTerminationFilter::CallData),
579
437
  DynamicTerminationFilter::CallData::Init,
@@ -584,7 +442,7 @@ const grpc_channel_filter DynamicTerminationFilter::kFilterVtable = {
584
442
  grpc_channel_stack_no_post_init,
585
443
  DynamicTerminationFilter::Destroy,
586
444
  DynamicTerminationFilter::GetChannelInfo,
587
- "dynamic_filter_termination",
445
+ GRPC_UNIQUE_TYPE_NAME_HERE("dynamic_filter_termination"),
588
446
  };
589
447
 
590
448
  } // namespace
@@ -601,9 +459,8 @@ class ClientChannelFilter::ResolverResultHandler final
601
459
  }
602
460
 
603
461
  ~ResolverResultHandler() override {
604
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_trace)) {
605
- gpr_log(GPR_INFO, "chand=%p: resolver shutdown complete", chand_);
606
- }
462
+ GRPC_TRACE_LOG(client_channel, INFO)
463
+ << "chand=" << chand_ << ": resolver shutdown complete";
607
464
  GRPC_CHANNEL_STACK_UNREF(chand_->owning_stack_, "ResolverResultHandler");
608
465
  }
609
466
 
@@ -633,16 +490,14 @@ class ClientChannelFilter::SubchannelWrapper final
633
490
  public:
634
491
  SubchannelWrapper(ClientChannelFilter* chand,
635
492
  RefCountedPtr<Subchannel> subchannel)
636
- : SubchannelInterface(GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_trace)
493
+ : SubchannelInterface(GRPC_TRACE_FLAG_ENABLED(client_channel)
637
494
  ? "SubchannelWrapper"
638
495
  : nullptr),
639
496
  chand_(chand),
640
497
  subchannel_(std::move(subchannel)) {
641
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_trace)) {
642
- gpr_log(GPR_INFO,
643
- "chand=%p: creating subchannel wrapper %p for subchannel %p",
644
- chand, this, subchannel_.get());
645
- }
498
+ GRPC_TRACE_LOG(client_channel, INFO)
499
+ << "chand=" << chand << ": creating subchannel wrapper " << this
500
+ << " for subchannel " << subchannel_.get();
646
501
  GRPC_CHANNEL_STACK_REF(chand_->owning_stack_, "SubchannelWrapper");
647
502
  #ifndef NDEBUG
648
503
  DCHECK(chand_->work_serializer_->RunningInWorkSerializer());
@@ -663,12 +518,19 @@ class ClientChannelFilter::SubchannelWrapper final
663
518
  }
664
519
 
665
520
  ~SubchannelWrapper() override {
666
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_trace)) {
667
- gpr_log(GPR_INFO,
668
- "chand=%p: destroying subchannel wrapper %p for subchannel %p",
669
- chand_, this, subchannel_.get());
670
- }
671
- if (!IsWorkSerializerDispatchEnabled()) {
521
+ GRPC_TRACE_LOG(client_channel, INFO)
522
+ << "chand=" << chand_ << ": destroying subchannel wrapper " << this
523
+ << "for subchannel " << subchannel_.get();
524
+ GRPC_CHANNEL_STACK_UNREF(chand_->owning_stack_, "SubchannelWrapper");
525
+ }
526
+
527
+ void Orphaned() override {
528
+ // Make sure we clean up the channel's subchannel maps inside the
529
+ // WorkSerializer.
530
+ // Ref held by callback.
531
+ WeakRef(DEBUG_LOCATION, "subchannel map cleanup").release();
532
+ chand_->work_serializer_->Run([this]() ABSL_EXCLUSIVE_LOCKS_REQUIRED(
533
+ *chand_->work_serializer_) {
672
534
  chand_->subchannel_wrappers_.erase(this);
673
535
  if (chand_->channelz_node_ != nullptr) {
674
536
  auto* subchannel_node = subchannel_->channelz_node();
@@ -683,36 +545,8 @@ class ClientChannelFilter::SubchannelWrapper final
683
545
  }
684
546
  }
685
547
  }
686
- }
687
- GRPC_CHANNEL_STACK_UNREF(chand_->owning_stack_, "SubchannelWrapper");
688
- }
689
-
690
- void Orphaned() override {
691
- if (!IsWorkSerializerDispatchEnabled()) return;
692
- // Make sure we clean up the channel's subchannel maps inside the
693
- // WorkSerializer.
694
- // Ref held by callback.
695
- WeakRef(DEBUG_LOCATION, "subchannel map cleanup").release();
696
- chand_->work_serializer_->Run(
697
- [this]() ABSL_EXCLUSIVE_LOCKS_REQUIRED(*chand_->work_serializer_) {
698
- chand_->subchannel_wrappers_.erase(this);
699
- if (chand_->channelz_node_ != nullptr) {
700
- auto* subchannel_node = subchannel_->channelz_node();
701
- if (subchannel_node != nullptr) {
702
- auto it =
703
- chand_->subchannel_refcount_map_.find(subchannel_.get());
704
- CHECK(it != chand_->subchannel_refcount_map_.end());
705
- --it->second;
706
- if (it->second == 0) {
707
- chand_->channelz_node_->RemoveChildSubchannel(
708
- subchannel_node->uuid());
709
- chand_->subchannel_refcount_map_.erase(it);
710
- }
711
- }
712
- }
713
- WeakUnref(DEBUG_LOCATION, "subchannel map cleanup");
714
- },
715
- DEBUG_LOCATION);
548
+ WeakUnref(DEBUG_LOCATION, "subchannel map cleanup");
549
+ });
716
550
  }
717
551
 
718
552
  void WatchConnectivityState(
@@ -761,6 +595,8 @@ class ClientChannelFilter::SubchannelWrapper final
761
595
  subchannel_->ThrottleKeepaliveTime(new_keepalive_time);
762
596
  }
763
597
 
598
+ std::string address() const override { return subchannel_->address(); }
599
+
764
600
  private:
765
601
  // This wrapper provides a bridge between the internal Subchannel API
766
602
  // and the SubchannelInterface API that we expose to LB policies.
@@ -773,7 +609,7 @@ class ClientChannelFilter::SubchannelWrapper final
773
609
  //
774
610
  // This class handles things like hopping into the WorkSerializer
775
611
  // before passing notifications to the LB policy and propagating
776
- // keepalive information betwen subchannels.
612
+ // keepalive information between subchannels.
777
613
  class WatcherWrapper final
778
614
  : public Subchannel::ConnectivityStateWatcherInterface {
779
615
  public:
@@ -784,36 +620,24 @@ class ClientChannelFilter::SubchannelWrapper final
784
620
  : watcher_(std::move(watcher)), parent_(std::move(parent)) {}
785
621
 
786
622
  ~WatcherWrapper() override {
787
- if (!IsWorkSerializerDispatchEnabled()) {
788
- auto* parent = parent_.release(); // ref owned by lambda
789
- parent->chand_->work_serializer_->Run(
790
- [parent]() ABSL_EXCLUSIVE_LOCKS_REQUIRED(
791
- *parent_->chand_->work_serializer_) {
792
- parent->Unref(DEBUG_LOCATION, "WatcherWrapper");
793
- },
794
- DEBUG_LOCATION);
795
- return;
796
- }
797
623
  parent_.reset(DEBUG_LOCATION, "WatcherWrapper");
798
624
  }
799
625
 
800
626
  void OnConnectivityStateChange(
801
627
  RefCountedPtr<ConnectivityStateWatcherInterface> self,
802
628
  grpc_connectivity_state state, const absl::Status& status) override {
803
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_trace)) {
804
- gpr_log(GPR_INFO,
805
- "chand=%p: connectivity change for subchannel wrapper %p "
806
- "subchannel %p; hopping into work_serializer",
807
- parent_->chand_, parent_.get(), parent_->subchannel_.get());
808
- }
629
+ GRPC_TRACE_LOG(client_channel, INFO)
630
+ << "chand=" << parent_->chand_
631
+ << ": connectivity change for subchannel wrapper " << parent_.get()
632
+ << " subchannel " << parent_->subchannel_.get()
633
+ << "hopping into work_serializer";
809
634
  self.release(); // Held by callback.
810
635
  parent_->chand_->work_serializer_->Run(
811
636
  [this, state, status]() ABSL_EXCLUSIVE_LOCKS_REQUIRED(
812
637
  *parent_->chand_->work_serializer_) {
813
638
  ApplyUpdateInControlPlaneWorkSerializer(state, status);
814
639
  Unref();
815
- },
816
- DEBUG_LOCATION);
640
+ });
817
641
  }
818
642
 
819
643
  grpc_pollset_set* interested_parties() override {
@@ -824,27 +648,24 @@ class ClientChannelFilter::SubchannelWrapper final
824
648
  void ApplyUpdateInControlPlaneWorkSerializer(grpc_connectivity_state state,
825
649
  const absl::Status& status)
826
650
  ABSL_EXCLUSIVE_LOCKS_REQUIRED(*parent_->chand_->work_serializer_) {
827
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_trace)) {
828
- gpr_log(GPR_INFO,
829
- "chand=%p: processing connectivity change in work serializer "
830
- "for subchannel wrapper %p subchannel %p watcher=%p "
831
- "state=%s status=%s",
832
- parent_->chand_, parent_.get(), parent_->subchannel_.get(),
833
- watcher_.get(), ConnectivityStateName(state),
834
- status.ToString().c_str());
835
- }
836
- absl::optional<absl::Cord> keepalive_throttling =
837
- status.GetPayload(kKeepaliveThrottlingKey);
651
+ GRPC_TRACE_LOG(client_channel, INFO)
652
+ << "chand=" << parent_->chand_
653
+ << ": processing connectivity change in work serializer for "
654
+ "subchannel wrapper "
655
+ << parent_.get() << " subchannel " << parent_->subchannel_.get()
656
+ << " watcher=" << watcher_.get()
657
+ << " state=" << ConnectivityStateName(state) << " status=" << status;
658
+ auto keepalive_throttling = status.GetPayload(kKeepaliveThrottlingKey);
838
659
  if (keepalive_throttling.has_value()) {
839
660
  int new_keepalive_time = -1;
840
661
  if (absl::SimpleAtoi(std::string(keepalive_throttling.value()),
841
662
  &new_keepalive_time)) {
842
663
  if (new_keepalive_time > parent_->chand_->keepalive_time_) {
843
664
  parent_->chand_->keepalive_time_ = new_keepalive_time;
844
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_trace)) {
845
- gpr_log(GPR_INFO, "chand=%p: throttling keepalive time to %d",
846
- parent_->chand_, parent_->chand_->keepalive_time_);
847
- }
665
+ GRPC_TRACE_LOG(client_channel, INFO)
666
+ << "chand=" << parent_->chand_
667
+ << ": throttling keepalive time to "
668
+ << parent_->chand_->keepalive_time_;
848
669
  // Propagate the new keepalive time to all subchannels. This is so
849
670
  // that new transports created by any subchannel (and not just the
850
671
  // subchannel that received the GOAWAY), use the new keepalive time.
@@ -854,9 +675,9 @@ class ClientChannelFilter::SubchannelWrapper final
854
675
  }
855
676
  }
856
677
  } else {
857
- gpr_log(GPR_ERROR, "chand=%p: Illegal keepalive throttling value %s",
858
- parent_->chand_,
859
- std::string(keepalive_throttling.value()).c_str());
678
+ LOG(ERROR) << "chand=" << parent_->chand_
679
+ << ": Illegal keepalive throttling value "
680
+ << std::string(keepalive_throttling.value());
860
681
  }
861
682
  }
862
683
  // Propagate status only in state TF.
@@ -935,8 +756,7 @@ ClientChannelFilter::ExternalConnectivityWatcher::ExternalConnectivityWatcher(
935
756
  [this]() ABSL_EXCLUSIVE_LOCKS_REQUIRED(*chand_->work_serializer_) {
936
757
  // The ref is passed to AddWatcherLocked().
937
758
  AddWatcherLocked();
938
- },
939
- DEBUG_LOCATION);
759
+ });
940
760
  }
941
761
 
942
762
  ClientChannelFilter::ExternalConnectivityWatcher::
@@ -989,8 +809,7 @@ void ClientChannelFilter::ExternalConnectivityWatcher::Notify(
989
809
  [this]() ABSL_EXCLUSIVE_LOCKS_REQUIRED(*chand_->work_serializer_) {
990
810
  RemoveWatcherLocked();
991
811
  Unref(DEBUG_LOCATION, "RemoveWatcherLocked()");
992
- },
993
- DEBUG_LOCATION);
812
+ });
994
813
  }
995
814
  }
996
815
 
@@ -1009,8 +828,7 @@ void ClientChannelFilter::ExternalConnectivityWatcher::Cancel() {
1009
828
  [this]() ABSL_EXCLUSIVE_LOCKS_REQUIRED(*chand_->work_serializer_) {
1010
829
  RemoveWatcherLocked();
1011
830
  Unref(DEBUG_LOCATION, "RemoveWatcherLocked()");
1012
- },
1013
- DEBUG_LOCATION);
831
+ });
1014
832
  }
1015
833
 
1016
834
  void ClientChannelFilter::ExternalConnectivityWatcher::AddWatcherLocked() {
@@ -1040,8 +858,7 @@ class ClientChannelFilter::ConnectivityWatcherAdder final {
1040
858
  chand_->work_serializer_->Run(
1041
859
  [this]() ABSL_EXCLUSIVE_LOCKS_REQUIRED(*chand_->work_serializer_) {
1042
860
  AddWatcherLocked();
1043
- },
1044
- DEBUG_LOCATION);
861
+ });
1045
862
  }
1046
863
 
1047
864
  private:
@@ -1070,8 +887,7 @@ class ClientChannelFilter::ConnectivityWatcherRemover final {
1070
887
  chand_->work_serializer_->Run(
1071
888
  [this]() ABSL_EXCLUSIVE_LOCKS_REQUIRED(*chand_->work_serializer_) {
1072
889
  RemoveWatcherLocked();
1073
- },
1074
- DEBUG_LOCATION);
890
+ });
1075
891
  }
1076
892
 
1077
893
  private:
@@ -1109,7 +925,7 @@ class ClientChannelFilter::ClientChannelControlHelper final
1109
925
  const ChannelArgs& args) override
1110
926
  ABSL_EXCLUSIVE_LOCKS_REQUIRED(*chand_->work_serializer_) {
1111
927
  if (chand_->resolver_ == nullptr) return nullptr; // Shutting down.
1112
- ChannelArgs subchannel_args = ClientChannelFilter::MakeSubchannelArgs(
928
+ ChannelArgs subchannel_args = Subchannel::MakeSubchannelArgs(
1113
929
  args, per_address_args, chand_->subchannel_pool_,
1114
930
  chand_->default_authority_);
1115
931
  // Create subchannel.
@@ -1127,14 +943,13 @@ class ClientChannelFilter::ClientChannelControlHelper final
1127
943
  RefCountedPtr<LoadBalancingPolicy::SubchannelPicker> picker)
1128
944
  override ABSL_EXCLUSIVE_LOCKS_REQUIRED(*chand_->work_serializer_) {
1129
945
  if (chand_->resolver_ == nullptr) return; // Shutting down.
1130
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_trace)) {
1131
- const char* extra = chand_->disconnect_error_.ok()
1132
- ? ""
1133
- : " (ignoring -- channel shutting down)";
1134
- gpr_log(GPR_INFO, "chand=%p: update: state=%s status=(%s) picker=%p%s",
1135
- chand_, ConnectivityStateName(state), status.ToString().c_str(),
1136
- picker.get(), extra);
1137
- }
946
+ GRPC_TRACE_LOG(client_channel, INFO)
947
+ << "chand=" << chand_
948
+ << ": update: state=" << ConnectivityStateName(state) << " status=("
949
+ << status << ") picker=" << picker.get()
950
+ << (chand_->disconnect_error_.ok()
951
+ ? ""
952
+ : " (ignoring -- channel shutting down)");
1138
953
  // Do update only if not shutting down.
1139
954
  if (chand_->disconnect_error_.ok()) {
1140
955
  chand_->UpdateStateAndPickerLocked(state, status, "helper",
@@ -1145,9 +960,8 @@ class ClientChannelFilter::ClientChannelControlHelper final
1145
960
  void RequestReresolution() override
1146
961
  ABSL_EXCLUSIVE_LOCKS_REQUIRED(*chand_->work_serializer_) {
1147
962
  if (chand_->resolver_ == nullptr) return; // Shutting down.
1148
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_trace)) {
1149
- gpr_log(GPR_INFO, "chand=%p: started name re-resolving", chand_);
1150
- }
963
+ GRPC_TRACE_LOG(client_channel, INFO)
964
+ << "chand=" << chand_ << ": started name re-resolving";
1151
965
  chand_->resolver_->RequestReresolutionLocked();
1152
966
  }
1153
967
 
@@ -1203,8 +1017,7 @@ class ClientChannelFilter::ClientChannelControlHelper final
1203
1017
  grpc_error_handle ClientChannelFilter::Init(grpc_channel_element* elem,
1204
1018
  grpc_channel_element_args* args) {
1205
1019
  CHECK(args->is_last);
1206
- CHECK(elem->filter == &kFilterVtableWithPromises ||
1207
- elem->filter == &kFilterVtableWithoutPromises);
1020
+ CHECK(elem->filter == &kFilter);
1208
1021
  grpc_error_handle error;
1209
1022
  new (elem->channel_data) ClientChannelFilter(args, &error);
1210
1023
  return error;
@@ -1240,10 +1053,9 @@ ClientChannelFilter::ClientChannelFilter(grpc_channel_element_args* args,
1240
1053
  std::make_shared<WorkSerializer>(*args->channel_stack->event_engine)),
1241
1054
  state_tracker_("client_channel", GRPC_CHANNEL_IDLE),
1242
1055
  subchannel_pool_(GetSubchannelPool(channel_args_)) {
1243
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_trace)) {
1244
- gpr_log(GPR_INFO, "chand=%p: creating client_channel for channel stack %p",
1245
- this, owning_stack_);
1246
- }
1056
+ GRPC_TRACE_LOG(client_channel, INFO)
1057
+ << "chand=" << this << ": creating client_channel for channel stack "
1058
+ << owning_stack_;
1247
1059
  // Start backup polling.
1248
1060
  grpc_client_channel_start_backup_polling(interested_parties_);
1249
1061
  // Check client channel factory.
@@ -1254,7 +1066,7 @@ ClientChannelFilter::ClientChannelFilter(grpc_channel_element_args* args,
1254
1066
  }
1255
1067
  // Get default service config. If none is specified via the client API,
1256
1068
  // we use an empty config.
1257
- absl::optional<absl::string_view> service_config_json =
1069
+ std::optional<absl::string_view> service_config_json =
1258
1070
  channel_args_.GetString(GRPC_ARG_SERVICE_CONFIG);
1259
1071
  if (!service_config_json.has_value()) service_config_json = "{}";
1260
1072
  *error = absl::OkStatus();
@@ -1266,7 +1078,7 @@ ClientChannelFilter::ClientChannelFilter(grpc_channel_element_args* args,
1266
1078
  }
1267
1079
  default_service_config_ = std::move(*service_config);
1268
1080
  // Get URI to resolve, using proxy mapper if needed.
1269
- absl::optional<std::string> target_uri =
1081
+ std::optional<std::string> target_uri =
1270
1082
  channel_args_.GetOwnedString(GRPC_ARG_SERVER_URI);
1271
1083
  if (!target_uri.has_value()) {
1272
1084
  *error = GRPC_ERROR_CREATE(
@@ -1298,7 +1110,7 @@ ClientChannelFilter::ClientChannelFilter(grpc_channel_element_args* args,
1298
1110
  keepalive_time_ = -1; // unset
1299
1111
  }
1300
1112
  // Set default authority.
1301
- absl::optional<std::string> default_authority =
1113
+ std::optional<std::string> default_authority =
1302
1114
  channel_args_.GetOwnedString(GRPC_ARG_DEFAULT_AUTHORITY);
1303
1115
  if (!default_authority.has_value()) {
1304
1116
  default_authority_ =
@@ -1312,30 +1124,14 @@ ClientChannelFilter::ClientChannelFilter(grpc_channel_element_args* args,
1312
1124
  }
1313
1125
 
1314
1126
  ClientChannelFilter::~ClientChannelFilter() {
1315
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_trace)) {
1316
- gpr_log(GPR_INFO, "chand=%p: destroying channel", this);
1317
- }
1127
+ GRPC_TRACE_LOG(client_channel, INFO)
1128
+ << "chand=" << this << ": destroying channel";
1318
1129
  DestroyResolverAndLbPolicyLocked();
1319
1130
  // Stop backup polling.
1320
1131
  grpc_client_channel_stop_backup_polling(interested_parties_);
1321
1132
  grpc_pollset_set_destroy(interested_parties_);
1322
1133
  }
1323
1134
 
1324
- ArenaPromise<ServerMetadataHandle> ClientChannelFilter::MakeCallPromise(
1325
- grpc_channel_element* elem, CallArgs call_args, NextPromiseFactory) {
1326
- auto* chand = static_cast<ClientChannelFilter*>(elem->channel_data);
1327
- // TODO(roth): Is this the right lifetime story for calld?
1328
- auto* calld = GetContext<Arena>()->ManagedNew<PromiseBasedCallData>(chand);
1329
- return TrySeq(
1330
- // Name resolution.
1331
- calld->MakeNameResolutionPromise(std::move(call_args)),
1332
- // Dynamic filter stack.
1333
- [calld](CallArgs call_args) mutable {
1334
- return calld->dynamic_filters()->channel_stack()->MakeClientCallPromise(
1335
- std::move(call_args));
1336
- });
1337
- }
1338
-
1339
1135
  OrphanablePtr<ClientChannelFilter::FilterBasedLoadBalancedCall>
1340
1136
  ClientChannelFilter::CreateLoadBalancedCall(
1341
1137
  const grpc_call_element_args& args, grpc_polling_entity* pollent,
@@ -1348,42 +1144,6 @@ ClientChannelFilter::CreateLoadBalancedCall(
1348
1144
  std::move(on_commit), is_transparent_retry));
1349
1145
  }
1350
1146
 
1351
- ArenaPromise<ServerMetadataHandle>
1352
- ClientChannelFilter::CreateLoadBalancedCallPromise(
1353
- CallArgs call_args, absl::AnyInvocable<void()> on_commit,
1354
- bool is_transparent_retry) {
1355
- OrphanablePtr<PromiseBasedLoadBalancedCall> lb_call(
1356
- GetContext<Arena>()->New<PromiseBasedLoadBalancedCall>(
1357
- this, std::move(on_commit), is_transparent_retry));
1358
- auto* call_ptr = lb_call.get();
1359
- return call_ptr->MakeCallPromise(std::move(call_args), std::move(lb_call));
1360
- }
1361
-
1362
- ChannelArgs ClientChannelFilter::MakeSubchannelArgs(
1363
- const ChannelArgs& channel_args, const ChannelArgs& address_args,
1364
- const RefCountedPtr<SubchannelPoolInterface>& subchannel_pool,
1365
- const std::string& channel_default_authority) {
1366
- // Note that we start with the channel-level args and then apply the
1367
- // per-address args, so that if a value is present in both, the one
1368
- // in the channel-level args is used. This is particularly important
1369
- // for the GRPC_ARG_DEFAULT_AUTHORITY arg, which we want to allow
1370
- // resolvers to set on a per-address basis only if the application
1371
- // did not explicitly set it at the channel level.
1372
- return channel_args.UnionWith(address_args)
1373
- .SetObject(subchannel_pool)
1374
- // If we haven't already set the default authority arg (i.e., it
1375
- // was not explicitly set by the application nor overridden by
1376
- // the resolver), add it from the channel's default.
1377
- .SetIfUnset(GRPC_ARG_DEFAULT_AUTHORITY, channel_default_authority)
1378
- // Remove channel args that should not affect subchannel
1379
- // uniqueness.
1380
- .Remove(GRPC_ARG_HEALTH_CHECK_SERVICE_NAME)
1381
- .Remove(GRPC_ARG_INHIBIT_HEALTH_CHECKING)
1382
- .Remove(GRPC_ARG_CHANNELZ_CHANNEL_NODE)
1383
- // Remove all keys with the no-subchannel prefix.
1384
- .RemoveAllKeysWithPrefix(GRPC_ARG_NO_SUBCHANNEL_PREFIX);
1385
- }
1386
-
1387
1147
  void ClientChannelFilter::ReprocessQueuedResolverCalls() {
1388
1148
  for (CallData* calld : resolver_queued_calls_) {
1389
1149
  calld->RemoveCallFromResolverQueuedCallsLocked();
@@ -1403,7 +1163,7 @@ RefCountedPtr<LoadBalancingPolicy::Config> ChooseLbPolicy(
1403
1163
  }
1404
1164
  // Try the deprecated LB policy name from the service config.
1405
1165
  // If not, try the setting from channel args.
1406
- absl::optional<absl::string_view> policy_name;
1166
+ std::optional<absl::string_view> policy_name;
1407
1167
  if (!parsed_service_config->parsed_deprecated_lb_policy().empty()) {
1408
1168
  policy_name = parsed_service_config->parsed_deprecated_lb_policy();
1409
1169
  } else {
@@ -1415,15 +1175,13 @@ RefCountedPtr<LoadBalancingPolicy::Config> ChooseLbPolicy(
1415
1175
  .LoadBalancingPolicyExists(*policy_name, &requires_config) ||
1416
1176
  requires_config)) {
1417
1177
  if (requires_config) {
1418
- gpr_log(GPR_ERROR,
1419
- "LB policy: %s passed through channel_args must not "
1420
- "require a config. Using pick_first instead.",
1421
- std::string(*policy_name).c_str());
1178
+ LOG(ERROR) << "LB policy: " << *policy_name
1179
+ << " passed through channel_args must not "
1180
+ "require a config. Using pick_first instead.";
1422
1181
  } else {
1423
- gpr_log(GPR_ERROR,
1424
- "LB policy: %s passed through channel_args does not exist. "
1425
- "Using pick_first instead.",
1426
- std::string(*policy_name).c_str());
1182
+ LOG(ERROR) << "LB policy: " << *policy_name
1183
+ << " passed through channel_args does not exist. "
1184
+ "Using pick_first instead.";
1427
1185
  }
1428
1186
  policy_name = "pick_first";
1429
1187
  }
@@ -1457,9 +1215,8 @@ void ClientChannelFilter::OnResolverResultChangedLocked(
1457
1215
  Resolver::Result result) {
1458
1216
  // Handle race conditions.
1459
1217
  if (resolver_ == nullptr) return;
1460
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_trace)) {
1461
- gpr_log(GPR_INFO, "chand=%p: got resolver result", this);
1462
- }
1218
+ GRPC_TRACE_LOG(client_channel, INFO)
1219
+ << "chand=" << this << ": got resolver result";
1463
1220
  // Grab resolver result health callback.
1464
1221
  auto resolver_callback = std::move(result.result_health_callback);
1465
1222
  absl::Status resolver_result_status;
@@ -1493,19 +1250,16 @@ void ClientChannelFilter::OnResolverResultChangedLocked(
1493
1250
  RefCountedPtr<ServiceConfig> service_config;
1494
1251
  RefCountedPtr<ConfigSelector> config_selector;
1495
1252
  if (!result.service_config.ok()) {
1496
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_trace)) {
1497
- gpr_log(GPR_INFO, "chand=%p: resolver returned service config error: %s",
1498
- this, result.service_config.status().ToString().c_str());
1499
- }
1253
+ GRPC_TRACE_LOG(client_channel, INFO)
1254
+ << "chand=" << this << ": resolver returned service config error: "
1255
+ << result.service_config.status();
1500
1256
  // If the service config was invalid, then fallback to the
1501
1257
  // previously returned service config.
1502
1258
  if (saved_service_config_ != nullptr) {
1503
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_trace)) {
1504
- gpr_log(GPR_INFO,
1505
- "chand=%p: resolver returned invalid service config. "
1506
- "Continuing to use previous service config.",
1507
- this);
1508
- }
1259
+ GRPC_TRACE_LOG(client_channel, INFO)
1260
+ << "chand=" << this
1261
+ << ": resolver returned invalid service config. "
1262
+ "Continuing to use previous service config.";
1509
1263
  service_config = saved_service_config_;
1510
1264
  config_selector = saved_config_selector_;
1511
1265
  } else {
@@ -1519,18 +1273,20 @@ void ClientChannelFilter::OnResolverResultChangedLocked(
1519
1273
  }
1520
1274
  } else if (*result.service_config == nullptr) {
1521
1275
  // Resolver did not return any service config.
1522
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_trace)) {
1523
- gpr_log(GPR_INFO,
1524
- "chand=%p: resolver returned no service config. Using default "
1525
- "service config for channel.",
1526
- this);
1527
- }
1276
+ GRPC_TRACE_LOG(client_channel, INFO)
1277
+ << "chand=" << this
1278
+ << ": resolver returned no service config. Using default service "
1279
+ "config for channel.";
1528
1280
  service_config = default_service_config_;
1529
1281
  } else {
1530
1282
  // Use ServiceConfig and ConfigSelector returned by resolver.
1531
1283
  service_config = std::move(*result.service_config);
1532
1284
  config_selector = result.args.GetObjectRef<ConfigSelector>();
1533
1285
  }
1286
+ // Remove the config selector from channel args so that we're not holding
1287
+ // unnecessary refs that cause it to be destroyed somewhere other than in the
1288
+ // WorkSerializer.
1289
+ result.args = result.args.Remove(GRPC_ARG_CONFIG_SELECTOR);
1534
1290
  // Note: The only case in which service_config is null here is if the resolver
1535
1291
  // returned a service config error and we don't have a previous service
1536
1292
  // config to fall back to.
@@ -1556,10 +1312,12 @@ void ClientChannelFilter::OnResolverResultChangedLocked(
1556
1312
  UpdateServiceConfigInControlPlaneLocked(
1557
1313
  std::move(service_config), std::move(config_selector),
1558
1314
  std::string(lb_policy_config->name()));
1559
- } else if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_trace)) {
1560
- gpr_log(GPR_INFO, "chand=%p: service config not changed", this);
1315
+ } else {
1316
+ GRPC_TRACE_LOG(client_channel, INFO)
1317
+ << "chand=" << this << ": service config not changed";
1561
1318
  }
1562
1319
  // Create or update LB policy, as needed.
1320
+ ChannelArgs new_args = result.args;
1563
1321
  resolver_result_status = CreateOrUpdateLbPolicyLocked(
1564
1322
  std::move(lb_policy_config),
1565
1323
  parsed_service_config->health_check_service_name(), std::move(result));
@@ -1568,7 +1326,7 @@ void ClientChannelFilter::OnResolverResultChangedLocked(
1568
1326
  // This needs to happen after the LB policy has been updated, since
1569
1327
  // the ConfigSelector may need the LB policy to know about new
1570
1328
  // destinations before it can send RPCs to those destinations.
1571
- UpdateServiceConfigInDataPlaneLocked();
1329
+ UpdateServiceConfigInDataPlaneLocked(new_args);
1572
1330
  // TODO(ncteisen): might be worth somehow including a snippet of the
1573
1331
  // config in the trace, at the risk of bloating the trace logs.
1574
1332
  trace_strings.push_back("Service config changed");
@@ -1591,10 +1349,8 @@ void ClientChannelFilter::OnResolverResultChangedLocked(
1591
1349
 
1592
1350
  void ClientChannelFilter::OnResolverErrorLocked(absl::Status status) {
1593
1351
  if (resolver_ == nullptr) return;
1594
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_trace)) {
1595
- gpr_log(GPR_INFO, "chand=%p: resolver transient failure: %s", this,
1596
- status.ToString().c_str());
1597
- }
1352
+ GRPC_TRACE_LOG(client_channel, INFO)
1353
+ << "chand=" << this << ": resolver transient failure: " << status;
1598
1354
  // If we already have an LB policy from a previous resolution
1599
1355
  // result, then we continue to let it set the connectivity state.
1600
1356
  // Otherwise, we go into TRANSIENT_FAILURE.
@@ -1614,7 +1370,7 @@ void ClientChannelFilter::OnResolverErrorLocked(absl::Status status) {
1614
1370
 
1615
1371
  absl::Status ClientChannelFilter::CreateOrUpdateLbPolicyLocked(
1616
1372
  RefCountedPtr<LoadBalancingPolicy::Config> lb_policy_config,
1617
- const absl::optional<std::string>& health_check_service_name,
1373
+ const std::optional<std::string>& health_check_service_name,
1618
1374
  Resolver::Result result) {
1619
1375
  // Construct update.
1620
1376
  LoadBalancingPolicy::UpdateArgs update_args;
@@ -1626,10 +1382,7 @@ absl::Status ClientChannelFilter::CreateOrUpdateLbPolicyLocked(
1626
1382
  }
1627
1383
  update_args.config = std::move(lb_policy_config);
1628
1384
  update_args.resolution_note = std::move(result.resolution_note);
1629
- // Remove the config selector from channel args so that we're not holding
1630
- // unnecessary refs that cause it to be destroyed somewhere other than in the
1631
- // WorkSerializer.
1632
- update_args.args = result.args.Remove(GRPC_ARG_CONFIG_SELECTOR);
1385
+ update_args.args = std::move(result.args);
1633
1386
  // Add health check service name to channel args.
1634
1387
  if (health_check_service_name.has_value()) {
1635
1388
  update_args.args = update_args.args.Set(GRPC_ARG_HEALTH_CHECK_SERVICE_NAME,
@@ -1640,10 +1393,8 @@ absl::Status ClientChannelFilter::CreateOrUpdateLbPolicyLocked(
1640
1393
  lb_policy_ = CreateLbPolicyLocked(update_args.args);
1641
1394
  }
1642
1395
  // Update the policy.
1643
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_trace)) {
1644
- gpr_log(GPR_INFO, "chand=%p: Updating child policy %p", this,
1645
- lb_policy_.get());
1646
- }
1396
+ GRPC_TRACE_LOG(client_channel, INFO)
1397
+ << "chand=" << this << ": Updating child policy " << lb_policy_.get();
1647
1398
  return lb_policy_->UpdateLocked(std::move(update_args));
1648
1399
  }
1649
1400
 
@@ -1665,11 +1416,9 @@ OrphanablePtr<LoadBalancingPolicy> ClientChannelFilter::CreateLbPolicyLocked(
1665
1416
  lb_policy_args.args = args;
1666
1417
  OrphanablePtr<LoadBalancingPolicy> lb_policy =
1667
1418
  MakeOrphanable<ChildPolicyHandler>(std::move(lb_policy_args),
1668
- &grpc_client_channel_trace);
1669
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_trace)) {
1670
- gpr_log(GPR_INFO, "chand=%p: created new LB policy %p", this,
1671
- lb_policy.get());
1672
- }
1419
+ &client_channel_trace);
1420
+ GRPC_TRACE_LOG(client_channel, INFO)
1421
+ << "chand=" << this << ": created new LB policy " << lb_policy.get();
1673
1422
  grpc_pollset_set_add_pollset_set(lb_policy->interested_parties(),
1674
1423
  interested_parties_);
1675
1424
  return lb_policy;
@@ -1679,10 +1428,9 @@ void ClientChannelFilter::UpdateServiceConfigInControlPlaneLocked(
1679
1428
  RefCountedPtr<ServiceConfig> service_config,
1680
1429
  RefCountedPtr<ConfigSelector> config_selector, std::string lb_policy_name) {
1681
1430
  std::string service_config_json(service_config->json_string());
1682
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_trace)) {
1683
- gpr_log(GPR_INFO, "chand=%p: using service config: \"%s\"", this,
1684
- service_config_json.c_str());
1685
- }
1431
+ GRPC_TRACE_LOG(client_channel, INFO)
1432
+ << "chand=" << this << ": using service config: \"" << service_config_json
1433
+ << "\"";
1686
1434
  // Save service config.
1687
1435
  saved_service_config_ = std::move(service_config);
1688
1436
  // Swap out the data used by GetChannelInfo().
@@ -1693,27 +1441,26 @@ void ClientChannelFilter::UpdateServiceConfigInControlPlaneLocked(
1693
1441
  }
1694
1442
  // Save config selector.
1695
1443
  saved_config_selector_ = std::move(config_selector);
1696
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_trace)) {
1697
- gpr_log(GPR_INFO, "chand=%p: using ConfigSelector %p", this,
1698
- saved_config_selector_.get());
1699
- }
1444
+ GRPC_TRACE_LOG(client_channel, INFO)
1445
+ << "chand=" << this << ": using ConfigSelector "
1446
+ << saved_config_selector_.get();
1700
1447
  }
1701
1448
 
1702
- void ClientChannelFilter::UpdateServiceConfigInDataPlaneLocked() {
1449
+ void ClientChannelFilter::UpdateServiceConfigInDataPlaneLocked(
1450
+ const ChannelArgs& args) {
1703
1451
  // Grab ref to service config.
1704
1452
  RefCountedPtr<ServiceConfig> service_config = saved_service_config_;
1705
1453
  // Grab ref to config selector. Use default if resolver didn't supply one.
1706
1454
  RefCountedPtr<ConfigSelector> config_selector = saved_config_selector_;
1707
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_trace)) {
1708
- gpr_log(GPR_INFO, "chand=%p: switching to ConfigSelector %p", this,
1709
- saved_config_selector_.get());
1710
- }
1455
+ GRPC_TRACE_LOG(client_channel, INFO)
1456
+ << "chand=" << this << ": switching to ConfigSelector "
1457
+ << saved_config_selector_.get();
1711
1458
  if (config_selector == nullptr) {
1712
1459
  config_selector =
1713
1460
  MakeRefCounted<DefaultConfigSelector>(saved_service_config_);
1714
1461
  }
1715
- ChannelArgs new_args =
1716
- channel_args_.SetObject(this).SetObject(service_config);
1462
+ // Modify channel args.
1463
+ ChannelArgs new_args = args.SetObject(this).SetObject(service_config);
1717
1464
  bool enable_retries =
1718
1465
  !new_args.WantMinimalStack() &&
1719
1466
  new_args.GetBool(GRPC_ARG_ENABLE_RETRIES).value_or(true);
@@ -1725,9 +1472,11 @@ void ClientChannelFilter::UpdateServiceConfigInDataPlaneLocked() {
1725
1472
  } else {
1726
1473
  filters.push_back(&DynamicTerminationFilter::kFilterVtable);
1727
1474
  }
1728
- RefCountedPtr<DynamicFilters> dynamic_filters =
1729
- DynamicFilters::Create(new_args, std::move(filters));
1475
+ auto new_blackboard = MakeRefCounted<Blackboard>();
1476
+ RefCountedPtr<DynamicFilters> dynamic_filters = DynamicFilters::Create(
1477
+ new_args, std::move(filters), blackboard_.get(), new_blackboard.get());
1730
1478
  CHECK(dynamic_filters != nullptr);
1479
+ blackboard_ = std::move(new_blackboard);
1731
1480
  // Grab data plane lock to update service config.
1732
1481
  //
1733
1482
  // We defer unreffing the old values (and deallocating memory) until
@@ -1749,10 +1498,9 @@ void ClientChannelFilter::UpdateServiceConfigInDataPlaneLocked() {
1749
1498
  }
1750
1499
 
1751
1500
  void ClientChannelFilter::CreateResolverLocked() {
1752
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_trace)) {
1753
- gpr_log(GPR_INFO, "chand=%p: starting name resolution for %s", this,
1754
- uri_to_resolve_.c_str());
1755
- }
1501
+ GRPC_TRACE_LOG(client_channel, INFO)
1502
+ << "chand=" << this << ": starting name resolution for "
1503
+ << uri_to_resolve_;
1756
1504
  resolver_ = CoreConfiguration::Get().resolver_registry().CreateResolver(
1757
1505
  uri_to_resolve_, channel_args_, interested_parties_, work_serializer_,
1758
1506
  std::make_unique<ResolverResultHandler>(this));
@@ -1762,17 +1510,14 @@ void ClientChannelFilter::CreateResolverLocked() {
1762
1510
  UpdateStateLocked(GRPC_CHANNEL_CONNECTING, absl::Status(),
1763
1511
  "started resolving");
1764
1512
  resolver_->StartLocked();
1765
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_trace)) {
1766
- gpr_log(GPR_INFO, "chand=%p: created resolver=%p", this, resolver_.get());
1767
- }
1513
+ GRPC_TRACE_LOG(client_channel, INFO)
1514
+ << "chand=" << this << ": created resolver=" << resolver_.get();
1768
1515
  }
1769
1516
 
1770
1517
  void ClientChannelFilter::DestroyResolverAndLbPolicyLocked() {
1771
1518
  if (resolver_ != nullptr) {
1772
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_trace)) {
1773
- gpr_log(GPR_INFO, "chand=%p: shutting down resolver=%p", this,
1774
- resolver_.get());
1775
- }
1519
+ GRPC_TRACE_LOG(client_channel, INFO)
1520
+ << "chand=" << this << ": shutting down resolver=" << resolver_.get();
1776
1521
  resolver_.reset();
1777
1522
  // Clear resolution state.
1778
1523
  saved_service_config_.reset();
@@ -1792,10 +1537,9 @@ void ClientChannelFilter::DestroyResolverAndLbPolicyLocked() {
1792
1537
  }
1793
1538
  // Clear LB policy if set.
1794
1539
  if (lb_policy_ != nullptr) {
1795
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_trace)) {
1796
- gpr_log(GPR_INFO, "chand=%p: shutting down lb_policy=%p", this,
1797
- lb_policy_.get());
1798
- }
1540
+ GRPC_TRACE_LOG(client_channel, INFO)
1541
+ << "chand=" << this
1542
+ << ": shutting down lb_policy=" << lb_policy_.get();
1799
1543
  grpc_pollset_set_del_pollset_set(lb_policy_->interested_parties(),
1800
1544
  interested_parties_);
1801
1545
  lb_policy_.reset();
@@ -1841,7 +1585,7 @@ void ClientChannelFilter::UpdateStateAndPickerLocked(
1841
1585
 
1842
1586
  namespace {
1843
1587
 
1844
- // TODO(roth): Remove this in favor of the gprpp Match() function once
1588
+ // TODO(roth): Remove this in favor of src/core/util/match.h once
1845
1589
  // we can do that without breaking lock annotations.
1846
1590
  template <typename T>
1847
1591
  T HandlePickResult(
@@ -1851,22 +1595,22 @@ T HandlePickResult(
1851
1595
  std::function<T(LoadBalancingPolicy::PickResult::Fail*)> fail_func,
1852
1596
  std::function<T(LoadBalancingPolicy::PickResult::Drop*)> drop_func) {
1853
1597
  auto* complete_pick =
1854
- absl::get_if<LoadBalancingPolicy::PickResult::Complete>(&result->result);
1598
+ std::get_if<LoadBalancingPolicy::PickResult::Complete>(&result->result);
1855
1599
  if (complete_pick != nullptr) {
1856
1600
  return complete_func(complete_pick);
1857
1601
  }
1858
1602
  auto* queue_pick =
1859
- absl::get_if<LoadBalancingPolicy::PickResult::Queue>(&result->result);
1603
+ std::get_if<LoadBalancingPolicy::PickResult::Queue>(&result->result);
1860
1604
  if (queue_pick != nullptr) {
1861
1605
  return queue_func(queue_pick);
1862
1606
  }
1863
1607
  auto* fail_pick =
1864
- absl::get_if<LoadBalancingPolicy::PickResult::Fail>(&result->result);
1608
+ std::get_if<LoadBalancingPolicy::PickResult::Fail>(&result->result);
1865
1609
  if (fail_pick != nullptr) {
1866
1610
  return fail_func(fail_pick);
1867
1611
  }
1868
1612
  auto* drop_pick =
1869
- absl::get_if<LoadBalancingPolicy::PickResult::Drop>(&result->result);
1613
+ std::get_if<LoadBalancingPolicy::PickResult::Drop>(&result->result);
1870
1614
  CHECK_NE(drop_pick, nullptr);
1871
1615
  return drop_func(drop_pick);
1872
1616
  }
@@ -1941,10 +1685,9 @@ void ClientChannelFilter::StartTransportOpLocked(grpc_transport_op* op) {
1941
1685
  }
1942
1686
  // Disconnect or enter IDLE.
1943
1687
  if (!op->disconnect_with_error.ok()) {
1944
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_trace)) {
1945
- gpr_log(GPR_INFO, "chand=%p: disconnect_with_error: %s", this,
1946
- StatusToString(op->disconnect_with_error).c_str());
1947
- }
1688
+ GRPC_TRACE_LOG(client_channel, INFO)
1689
+ << "chand=" << this << ": disconnect_with_error: "
1690
+ << StatusToString(op->disconnect_with_error);
1948
1691
  DestroyResolverAndLbPolicyLocked();
1949
1692
  intptr_t value;
1950
1693
  if (grpc_error_get_int(op->disconnect_with_error,
@@ -1989,8 +1732,7 @@ void ClientChannelFilter::StartTransportOp(grpc_channel_element* elem,
1989
1732
  chand->work_serializer_->Run(
1990
1733
  [chand, op]() ABSL_EXCLUSIVE_LOCKS_REQUIRED(*chand->work_serializer_) {
1991
1734
  chand->StartTransportOpLocked(op);
1992
- },
1993
- DEBUG_LOCATION);
1735
+ });
1994
1736
  }
1995
1737
 
1996
1738
  void ClientChannelFilter::GetChannelInfo(grpc_channel_element* elem,
@@ -2027,8 +1769,7 @@ grpc_connectivity_state ClientChannelFilter::CheckConnectivityState(
2027
1769
  if (out == GRPC_CHANNEL_IDLE && try_to_connect) {
2028
1770
  GRPC_CHANNEL_STACK_REF(owning_stack_, "TryToConnect");
2029
1771
  work_serializer_->Run([this]() ABSL_EXCLUSIVE_LOCKS_REQUIRED(
2030
- *work_serializer_) { TryToConnectLocked(); },
2031
- DEBUG_LOCATION);
1772
+ *work_serializer_) { TryToConnectLocked(); });
2032
1773
  }
2033
1774
  return out;
2034
1775
  }
@@ -2049,11 +1790,9 @@ void ClientChannelFilter::RemoveConnectivityWatcher(
2049
1790
  //
2050
1791
 
2051
1792
  void ClientChannelFilter::CallData::RemoveCallFromResolverQueuedCallsLocked() {
2052
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_call_trace)) {
2053
- gpr_log(GPR_INFO,
2054
- "chand=%p calld=%p: removing from resolver queued picks list",
2055
- chand(), this);
2056
- }
1793
+ GRPC_TRACE_LOG(client_channel_call, INFO)
1794
+ << "chand=" << chand() << " calld=" << this
1795
+ << ": removing from resolver queued picks list";
2057
1796
  // Remove call's pollent from channel's interested_parties.
2058
1797
  grpc_polling_entity_del_from_pollset_set(pollent(),
2059
1798
  chand()->interested_parties_);
@@ -2064,12 +1803,10 @@ void ClientChannelFilter::CallData::RemoveCallFromResolverQueuedCallsLocked() {
2064
1803
  }
2065
1804
 
2066
1805
  void ClientChannelFilter::CallData::AddCallToResolverQueuedCallsLocked() {
2067
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_call_trace)) {
2068
- gpr_log(
2069
- GPR_INFO,
2070
- "chand=%p calld=%p: adding to resolver queued picks list; pollent=%s",
2071
- chand(), this, grpc_polling_entity_string(pollent()).c_str());
2072
- }
1806
+ GRPC_TRACE_LOG(client_channel_call, INFO)
1807
+ << "chand=" << chand() << " calld=" << this
1808
+ << ": adding to resolver queued picks list; pollent="
1809
+ << grpc_polling_entity_string(pollent());
2073
1810
  // Add call's pollent to channel's interested_parties, so that I/O
2074
1811
  // can be done under the call's CQ.
2075
1812
  grpc_polling_entity_add_to_pollset_set(pollent(),
@@ -2081,10 +1818,9 @@ void ClientChannelFilter::CallData::AddCallToResolverQueuedCallsLocked() {
2081
1818
 
2082
1819
  grpc_error_handle ClientChannelFilter::CallData::ApplyServiceConfigToCallLocked(
2083
1820
  const absl::StatusOr<RefCountedPtr<ConfigSelector>>& config_selector) {
2084
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_call_trace)) {
2085
- gpr_log(GPR_INFO, "chand=%p calld=%p: applying service config to call",
2086
- chand(), this);
2087
- }
1821
+ GRPC_TRACE_LOG(client_channel_call, INFO)
1822
+ << "chand=" << chand() << " calld=" << this
1823
+ << ": applying service config to call";
2088
1824
  if (!config_selector.ok()) return config_selector.status();
2089
1825
  // Create a ClientChannelServiceConfigCallData for the call. This stores
2090
1826
  // a ref to the ServiceConfig and caches the right set of parsed configs
@@ -2092,7 +1828,7 @@ grpc_error_handle ClientChannelFilter::CallData::ApplyServiceConfigToCallLocked(
2092
1828
  // itself in the call context, so that it can be accessed by filters
2093
1829
  // below us in the stack, and it will be cleaned up when the call ends.
2094
1830
  auto* service_config_call_data =
2095
- arena()->New<ClientChannelServiceConfigCallData>(arena(), call_context());
1831
+ arena()->New<ClientChannelServiceConfigCallData>(arena());
2096
1832
  // Use the ConfigSelector to determine the config for the call.
2097
1833
  absl::Status call_config_status =
2098
1834
  (*config_selector)
@@ -2124,7 +1860,7 @@ grpc_error_handle ClientChannelFilter::CallData::ApplyServiceConfigToCallLocked(
2124
1860
  return absl::OkStatus();
2125
1861
  }
2126
1862
 
2127
- absl::optional<absl::Status> ClientChannelFilter::CallData::CheckResolution(
1863
+ std::optional<absl::Status> ClientChannelFilter::CallData::CheckResolution(
2128
1864
  bool was_queued) {
2129
1865
  // Check if we have a resolver result to use.
2130
1866
  absl::StatusOr<RefCountedPtr<ConfigSelector>> config_selector;
@@ -2134,32 +1870,21 @@ absl::optional<absl::Status> ClientChannelFilter::CallData::CheckResolution(
2134
1870
  // If no result is available, queue the call.
2135
1871
  if (!result_ready) {
2136
1872
  AddCallToResolverQueuedCallsLocked();
2137
- return absl::nullopt;
1873
+ return std::nullopt;
2138
1874
  }
2139
1875
  }
2140
1876
  // We have a result. Apply service config to call.
2141
1877
  grpc_error_handle error = ApplyServiceConfigToCallLocked(config_selector);
2142
- // ConfigSelector must be unreffed inside the WorkSerializer.
2143
- if (!IsWorkSerializerDispatchEnabled() && config_selector.ok()) {
2144
- chand()->work_serializer_->Run(
2145
- [config_selector = std::move(*config_selector)]() mutable {
2146
- config_selector.reset();
2147
- },
2148
- DEBUG_LOCATION);
2149
- }
2150
1878
  // Handle errors.
2151
1879
  if (!error.ok()) {
2152
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_call_trace)) {
2153
- gpr_log(GPR_INFO,
2154
- "chand=%p calld=%p: error applying config to call: error=%s",
2155
- chand(), this, StatusToString(error).c_str());
2156
- }
1880
+ GRPC_TRACE_LOG(client_channel_call, INFO)
1881
+ << "chand=" << chand() << " calld=" << this
1882
+ << ": error applying config to call: error=" << StatusToString(error);
2157
1883
  return error;
2158
1884
  }
2159
1885
  // If the call was queued, add trace annotation.
2160
1886
  if (was_queued) {
2161
- auto* call_tracer = static_cast<CallTracerAnnotationInterface*>(
2162
- call_context()[GRPC_CONTEXT_CALL_TRACER_ANNOTATION_INTERFACE].value);
1887
+ auto* call_tracer = arena()->GetContext<CallTracerAnnotationInterface>();
2163
1888
  if (call_tracer != nullptr) {
2164
1889
  call_tracer->RecordAnnotation("Delayed name resolution complete.");
2165
1890
  }
@@ -2177,20 +1902,18 @@ bool ClientChannelFilter::CallData::CheckResolutionLocked(
2177
1902
  absl::Status resolver_error = chand()->resolver_transient_failure_error_;
2178
1903
  if (!resolver_error.ok() &&
2179
1904
  !send_initial_metadata()->GetOrCreatePointer(WaitForReady())->value) {
2180
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_call_trace)) {
2181
- gpr_log(GPR_INFO, "chand=%p calld=%p: resolution failed, failing call",
2182
- chand(), this);
2183
- }
1905
+ GRPC_TRACE_LOG(client_channel_call, INFO)
1906
+ << "chand=" << chand() << " calld=" << this
1907
+ << ": resolution failed, failing call";
2184
1908
  *config_selector = absl_status_to_grpc_error(resolver_error);
2185
1909
  return true;
2186
1910
  }
2187
1911
  // Either the resolver has not yet returned a result, or it has
2188
1912
  // returned transient failure but the call is wait_for_ready. In
2189
1913
  // either case, queue the call.
2190
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_call_trace)) {
2191
- gpr_log(GPR_INFO, "chand=%p calld=%p: no resolver result yet", chand(),
2192
- this);
2193
- }
1914
+ GRPC_TRACE_LOG(client_channel_call, INFO)
1915
+ << "chand=" << chand() << " calld=" << this
1916
+ << ": no resolver result yet";
2194
1917
  return false;
2195
1918
  }
2196
1919
  // Result found.
@@ -2206,16 +1929,14 @@ bool ClientChannelFilter::CallData::CheckResolutionLocked(
2206
1929
  ClientChannelFilter::FilterBasedCallData::FilterBasedCallData(
2207
1930
  grpc_call_element* elem, const grpc_call_element_args& args)
2208
1931
  : path_(CSliceRef(args.path)),
2209
- call_context_(args.context),
2210
1932
  call_start_time_(args.start_time),
2211
1933
  deadline_(args.deadline),
2212
1934
  arena_(args.arena),
2213
1935
  elem_(elem),
2214
1936
  owning_call_(args.call_stack),
2215
1937
  call_combiner_(args.call_combiner) {
2216
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_call_trace)) {
2217
- gpr_log(GPR_INFO, "chand=%p calld=%p: created call", chand(), this);
2218
- }
1938
+ GRPC_TRACE_LOG(client_channel_call, INFO)
1939
+ << "chand=" << chand() << " calld=" << this << ": created call";
2219
1940
  }
2220
1941
 
2221
1942
  ClientChannelFilter::FilterBasedCallData::~FilterBasedCallData() {
@@ -2251,10 +1972,11 @@ void ClientChannelFilter::FilterBasedCallData::StartTransportStreamOpBatch(
2251
1972
  grpc_call_element* elem, grpc_transport_stream_op_batch* batch) {
2252
1973
  auto* calld = static_cast<FilterBasedCallData*>(elem->call_data);
2253
1974
  auto* chand = static_cast<ClientChannelFilter*>(elem->channel_data);
2254
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_call_trace) &&
2255
- !GRPC_TRACE_FLAG_ENABLED(grpc_trace_channel)) {
2256
- gpr_log(GPR_INFO, "chand=%p calld=%p: batch started from above: %s", chand,
2257
- calld, grpc_transport_stream_op_batch_string(batch, false).c_str());
1975
+ if (GRPC_TRACE_FLAG_ENABLED(client_channel_call) &&
1976
+ !GRPC_TRACE_FLAG_ENABLED(channel)) {
1977
+ LOG(INFO) << "chand=" << chand << " calld=" << calld
1978
+ << ": batch started from above: "
1979
+ << grpc_transport_stream_op_batch_string(batch, false);
2258
1980
  }
2259
1981
  // Intercept recv_trailing_metadata to commit the call, in case we wind up
2260
1982
  // failing the call before we get down to the retry or LB call layer.
@@ -2271,10 +1993,9 @@ void ClientChannelFilter::FilterBasedCallData::StartTransportStreamOpBatch(
2271
1993
  // Note that once we have done so, we do not need to acquire the channel's
2272
1994
  // resolution mutex, which is more efficient (especially for streaming calls).
2273
1995
  if (calld->dynamic_call_ != nullptr) {
2274
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_call_trace)) {
2275
- gpr_log(GPR_INFO, "chand=%p calld=%p: starting batch on dynamic_call=%p",
2276
- chand, calld, calld->dynamic_call_.get());
2277
- }
1996
+ GRPC_TRACE_LOG(client_channel_call, INFO)
1997
+ << "chand=" << chand << " calld=" << calld
1998
+ << ": starting batch on dynamic_call=" << calld->dynamic_call_.get();
2278
1999
  calld->dynamic_call_->StartTransportStreamOpBatch(batch);
2279
2000
  return;
2280
2001
  }
@@ -2282,10 +2003,10 @@ void ClientChannelFilter::FilterBasedCallData::StartTransportStreamOpBatch(
2282
2003
  //
2283
2004
  // If we've previously been cancelled, immediately fail any new batches.
2284
2005
  if (GPR_UNLIKELY(!calld->cancel_error_.ok())) {
2285
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_call_trace)) {
2286
- gpr_log(GPR_INFO, "chand=%p calld=%p: failing batch with error: %s",
2287
- chand, calld, StatusToString(calld->cancel_error_).c_str());
2288
- }
2006
+ GRPC_TRACE_LOG(client_channel_call, INFO)
2007
+ << "chand=" << chand << " calld=" << calld
2008
+ << ": failing batch with error: "
2009
+ << StatusToString(calld->cancel_error_);
2289
2010
  // Note: This will release the call combiner.
2290
2011
  grpc_transport_stream_op_batch_finish_with_failure(
2291
2012
  batch, calld->cancel_error_, calld->call_combiner());
@@ -2299,10 +2020,9 @@ void ClientChannelFilter::FilterBasedCallData::StartTransportStreamOpBatch(
2299
2020
  // is in the past when the call starts), we can return the right
2300
2021
  // error to the caller when the first batch does get passed down.
2301
2022
  calld->cancel_error_ = batch->payload->cancel_stream.cancel_error;
2302
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_call_trace)) {
2303
- gpr_log(GPR_INFO, "chand=%p calld=%p: recording cancel_error=%s", chand,
2304
- calld, StatusToString(calld->cancel_error_).c_str());
2305
- }
2023
+ GRPC_TRACE_LOG(client_channel_call, INFO)
2024
+ << "chand=" << chand << " calld=" << calld
2025
+ << ": recording cancel_error=" << StatusToString(calld->cancel_error_);
2306
2026
  // Fail all pending batches.
2307
2027
  calld->PendingBatchesFail(calld->cancel_error_, NoYieldCallCombiner);
2308
2028
  // Note: This will release the call combiner.
@@ -2316,36 +2036,29 @@ void ClientChannelFilter::FilterBasedCallData::StartTransportStreamOpBatch(
2316
2036
  // channel's resolution mutex to apply the service config to the call,
2317
2037
  // after which we will create a dynamic call.
2318
2038
  if (GPR_LIKELY(batch->send_initial_metadata)) {
2319
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_call_trace)) {
2320
- gpr_log(GPR_INFO,
2321
- "chand=%p calld=%p: grabbing resolution mutex to apply service "
2322
- "config",
2323
- chand, calld);
2324
- }
2039
+ GRPC_TRACE_LOG(client_channel_call, INFO)
2040
+ << "chand=" << chand << " calld=" << calld
2041
+ << ": grabbing resolution mutex to apply service ";
2325
2042
  // If we're still in IDLE, we need to start resolving.
2326
2043
  if (GPR_UNLIKELY(chand->CheckConnectivityState(false) ==
2327
2044
  GRPC_CHANNEL_IDLE)) {
2328
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_call_trace)) {
2329
- gpr_log(GPR_INFO, "chand=%p calld=%p: triggering exit idle", chand,
2330
- calld);
2331
- }
2045
+ GRPC_TRACE_LOG(client_channel_call, INFO)
2046
+ << "chand=" << chand << " calld=" << calld
2047
+ << ": triggering exit idle";
2332
2048
  // Bounce into the control plane work serializer to start resolving.
2333
2049
  GRPC_CHANNEL_STACK_REF(chand->owning_stack_, "ExitIdle");
2334
2050
  chand->work_serializer_->Run(
2335
2051
  [chand]() ABSL_EXCLUSIVE_LOCKS_REQUIRED(*chand->work_serializer_) {
2336
2052
  chand->CheckConnectivityState(/*try_to_connect=*/true);
2337
2053
  GRPC_CHANNEL_STACK_UNREF(chand->owning_stack_, "ExitIdle");
2338
- },
2339
- DEBUG_LOCATION);
2054
+ });
2340
2055
  }
2341
2056
  calld->TryCheckResolution(/*was_queued=*/false);
2342
2057
  } else {
2343
2058
  // For all other batches, release the call combiner.
2344
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_call_trace)) {
2345
- gpr_log(GPR_INFO,
2346
- "chand=%p calld=%p: saved batch, yielding call combiner", chand,
2347
- calld);
2348
- }
2059
+ GRPC_TRACE_LOG(client_channel_call, INFO)
2060
+ << "chand=" << chand << " calld=" << calld
2061
+ << ": saved batch, yielding call combiner";
2349
2062
  GRPC_CALL_COMBINER_STOP(calld->call_combiner(),
2350
2063
  "batch does not include send_initial_metadata");
2351
2064
  }
@@ -2374,11 +2087,9 @@ size_t ClientChannelFilter::FilterBasedCallData::GetBatchIndex(
2374
2087
  void ClientChannelFilter::FilterBasedCallData::PendingBatchesAdd(
2375
2088
  grpc_transport_stream_op_batch* batch) {
2376
2089
  const size_t idx = GetBatchIndex(batch);
2377
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_call_trace)) {
2378
- gpr_log(GPR_INFO,
2379
- "chand=%p calld=%p: adding pending batch at index %" PRIuPTR,
2380
- chand(), this, idx);
2381
- }
2090
+ GRPC_TRACE_LOG(client_channel_call, INFO)
2091
+ << "chand=" << chand() << " calld=" << this
2092
+ << ": adding pending batch at index " << idx;
2382
2093
  grpc_transport_stream_op_batch*& pending = pending_batches_[idx];
2383
2094
  CHECK_EQ(pending, nullptr);
2384
2095
  pending = batch;
@@ -2401,14 +2112,13 @@ void ClientChannelFilter::FilterBasedCallData::PendingBatchesFail(
2401
2112
  grpc_error_handle error,
2402
2113
  YieldCallCombinerPredicate yield_call_combiner_predicate) {
2403
2114
  CHECK(!error.ok());
2404
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_call_trace)) {
2115
+ if (GRPC_TRACE_FLAG_ENABLED(client_channel_call)) {
2405
2116
  size_t num_batches = 0;
2406
2117
  for (size_t i = 0; i < GPR_ARRAY_SIZE(pending_batches_); ++i) {
2407
2118
  if (pending_batches_[i] != nullptr) ++num_batches;
2408
2119
  }
2409
- gpr_log(GPR_INFO,
2410
- "chand=%p calld=%p: failing %" PRIuPTR " pending batches: %s",
2411
- chand(), this, num_batches, StatusToString(error).c_str());
2120
+ LOG(INFO) << "chand=" << chand() << " calld=" << this << ": failing "
2121
+ << num_batches << " pending batches: " << StatusToString(error);
2412
2122
  }
2413
2123
  CallCombinerClosureList closures;
2414
2124
  for (size_t i = 0; i < GPR_ARRAY_SIZE(pending_batches_); ++i) {
@@ -2444,15 +2154,14 @@ void ClientChannelFilter::FilterBasedCallData::ResumePendingBatchInCallCombiner(
2444
2154
  // This is called via the call combiner, so access to calld is synchronized.
2445
2155
  void ClientChannelFilter::FilterBasedCallData::PendingBatchesResume() {
2446
2156
  // Retries not enabled; send down batches as-is.
2447
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_call_trace)) {
2157
+ if (GRPC_TRACE_FLAG_ENABLED(client_channel_call)) {
2448
2158
  size_t num_batches = 0;
2449
2159
  for (size_t i = 0; i < GPR_ARRAY_SIZE(pending_batches_); ++i) {
2450
2160
  if (pending_batches_[i] != nullptr) ++num_batches;
2451
2161
  }
2452
- gpr_log(GPR_INFO,
2453
- "chand=%p calld=%p: starting %" PRIuPTR
2454
- " pending batches on dynamic_call=%p",
2455
- chand(), this, num_batches, dynamic_call_.get());
2162
+ LOG(INFO) << "chand=" << chand() << " calld=" << this << ": starting "
2163
+ << num_batches
2164
+ << " pending batches on dynamic_call=" << dynamic_call_.get();
2456
2165
  }
2457
2166
  CallCombinerClosureList closures;
2458
2167
  for (size_t i = 0; i < GPR_ARRAY_SIZE(pending_batches_); ++i) {
@@ -2490,13 +2199,13 @@ class ClientChannelFilter::FilterBasedCallData::ResolverQueuedCallCanceller
2490
2199
  auto* chand = calld->chand();
2491
2200
  {
2492
2201
  MutexLock lock(&chand->resolution_mu_);
2493
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_call_trace)) {
2494
- gpr_log(GPR_INFO,
2495
- "chand=%p calld=%p: cancelling resolver queued pick: "
2496
- "error=%s self=%p calld->resolver_pick_canceller=%p",
2497
- chand, calld, StatusToString(error).c_str(), self,
2498
- calld->resolver_call_canceller_);
2499
- }
2202
+ GRPC_TRACE_LOG(client_channel_call, INFO)
2203
+ << "chand=" << chand << " calld=" << calld
2204
+ << ": cancelling resolver queued pick: "
2205
+ "error="
2206
+ << StatusToString(error) << " self=" << self
2207
+ << " calld->resolver_pick_canceller="
2208
+ << calld->resolver_call_canceller_;
2500
2209
  if (calld->resolver_call_canceller_ == self && !error.ok()) {
2501
2210
  // Remove pick from list of queued picks.
2502
2211
  calld->RemoveCallFromResolverQueuedCallsLocked();
@@ -2537,31 +2246,25 @@ void ClientChannelFilter::FilterBasedCallData::RetryCheckResolutionLocked() {
2537
2246
  // Do an async callback to resume call processing, so that we're not
2538
2247
  // doing it while holding the channel's resolution mutex.
2539
2248
  chand()->owning_stack_->EventEngine()->Run([this]() {
2540
- ApplicationCallbackExecCtx application_exec_ctx;
2541
2249
  ExecCtx exec_ctx;
2542
2250
  TryCheckResolution(/*was_queued=*/true);
2543
2251
  });
2544
2252
  }
2545
2253
 
2546
2254
  void ClientChannelFilter::FilterBasedCallData::CreateDynamicCall() {
2547
- DynamicFilters::Call::Args args = {dynamic_filters(), pollent_, path_,
2548
- call_start_time_, deadline_, arena(),
2549
- call_context_, call_combiner()};
2255
+ DynamicFilters::Call::Args args = {dynamic_filters(), pollent_, path_,
2256
+ call_start_time_, deadline_, arena(),
2257
+ call_combiner()};
2550
2258
  grpc_error_handle error;
2551
2259
  DynamicFilters* channel_stack = args.channel_stack.get();
2552
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_call_trace)) {
2553
- gpr_log(
2554
- GPR_INFO,
2555
- "chand=%p calld=%p: creating dynamic call stack on channel_stack=%p",
2556
- chand(), this, channel_stack);
2557
- }
2260
+ GRPC_TRACE_LOG(client_channel_call, INFO)
2261
+ << "chand=" << chand() << " calld=" << this
2262
+ << ": creating dynamic call stack on channel_stack=" << channel_stack;
2558
2263
  dynamic_call_ = channel_stack->CreateCall(std::move(args), &error);
2559
2264
  if (!error.ok()) {
2560
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_call_trace)) {
2561
- gpr_log(GPR_INFO,
2562
- "chand=%p calld=%p: failed to create dynamic call: error=%s",
2563
- chand(), this, StatusToString(error).c_str());
2564
- }
2265
+ GRPC_TRACE_LOG(client_channel_call, INFO)
2266
+ << "chand=" << chand() << " calld=" << this
2267
+ << ": failed to create dynamic call: error=" << StatusToString(error);
2565
2268
  PendingBatchesFail(error, YieldCallCombiner);
2566
2269
  return;
2567
2270
  }
@@ -2573,15 +2276,11 @@ void ClientChannelFilter::FilterBasedCallData::
2573
2276
  void* arg, grpc_error_handle error) {
2574
2277
  auto* calld = static_cast<FilterBasedCallData*>(arg);
2575
2278
  auto* chand = calld->chand();
2576
- auto* service_config_call_data =
2577
- GetServiceConfigCallData(calld->call_context());
2578
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_call_trace)) {
2579
- gpr_log(GPR_INFO,
2580
- "chand=%p calld=%p: got recv_trailing_metadata_ready: error=%s "
2581
- "service_config_call_data=%p",
2582
- chand, calld, StatusToString(error).c_str(),
2583
- service_config_call_data);
2584
- }
2279
+ auto* service_config_call_data = GetServiceConfigCallData(calld->arena());
2280
+ GRPC_TRACE_LOG(client_channel_call, INFO)
2281
+ << "chand=" << chand << " calld=" << calld
2282
+ << ": got recv_trailing_metadata_ready: error=" << StatusToString(error)
2283
+ << " service_config_call_data=" << service_config_call_data;
2585
2284
  if (service_config_call_data != nullptr) {
2586
2285
  service_config_call_data->Commit();
2587
2286
  }
@@ -2599,7 +2298,7 @@ class ClientChannelFilter::LoadBalancedCall::LbCallState final
2599
2298
  public:
2600
2299
  explicit LbCallState(LoadBalancedCall* lb_call) : lb_call_(lb_call) {}
2601
2300
 
2602
- void* Alloc(size_t size) override { return lb_call_->arena()->Alloc(size); }
2301
+ void* Alloc(size_t size) override { return lb_call_->arena_->Alloc(size); }
2603
2302
 
2604
2303
  // Internal API to allow first-party LB policies to access per-call
2605
2304
  // attributes set by the ConfigSelector.
@@ -2612,81 +2311,6 @@ class ClientChannelFilter::LoadBalancedCall::LbCallState final
2612
2311
  LoadBalancedCall* lb_call_;
2613
2312
  };
2614
2313
 
2615
- //
2616
- // ClientChannelFilter::LoadBalancedCall::Metadata
2617
- //
2618
-
2619
- class ClientChannelFilter::LoadBalancedCall::Metadata final
2620
- : public LoadBalancingPolicy::MetadataInterface {
2621
- public:
2622
- explicit Metadata(grpc_metadata_batch* batch) : batch_(batch) {}
2623
-
2624
- void Add(absl::string_view key, absl::string_view value) override {
2625
- if (batch_ == nullptr) return;
2626
- // Gross, egregious hack to support legacy grpclb behavior.
2627
- // TODO(ctiller): Use a promise context for this once that plumbing is done.
2628
- if (key == GrpcLbClientStatsMetadata::key()) {
2629
- batch_->Set(
2630
- GrpcLbClientStatsMetadata(),
2631
- const_cast<GrpcLbClientStats*>(
2632
- reinterpret_cast<const GrpcLbClientStats*>(value.data())));
2633
- return;
2634
- }
2635
- batch_->Append(key, Slice::FromStaticString(value),
2636
- [key](absl::string_view error, const Slice& value) {
2637
- gpr_log(GPR_ERROR, "%s",
2638
- absl::StrCat(error, " key:", key,
2639
- " value:", value.as_string_view())
2640
- .c_str());
2641
- });
2642
- }
2643
-
2644
- std::vector<std::pair<std::string, std::string>> TestOnlyCopyToVector()
2645
- override {
2646
- if (batch_ == nullptr) return {};
2647
- Encoder encoder;
2648
- batch_->Encode(&encoder);
2649
- return encoder.Take();
2650
- }
2651
-
2652
- absl::optional<absl::string_view> Lookup(absl::string_view key,
2653
- std::string* buffer) const override {
2654
- if (batch_ == nullptr) return absl::nullopt;
2655
- return batch_->GetStringValue(key, buffer);
2656
- }
2657
-
2658
- private:
2659
- class Encoder final {
2660
- public:
2661
- void Encode(const Slice& key, const Slice& value) {
2662
- out_.emplace_back(std::string(key.as_string_view()),
2663
- std::string(value.as_string_view()));
2664
- }
2665
-
2666
- template <class Which>
2667
- void Encode(Which, const typename Which::ValueType& value) {
2668
- auto value_slice = Which::Encode(value);
2669
- out_.emplace_back(std::string(Which::key()),
2670
- std::string(value_slice.as_string_view()));
2671
- }
2672
-
2673
- void Encode(GrpcTimeoutMetadata,
2674
- const typename GrpcTimeoutMetadata::ValueType&) {}
2675
- void Encode(HttpPathMetadata, const Slice&) {}
2676
- void Encode(HttpMethodMetadata,
2677
- const typename HttpMethodMetadata::ValueType&) {}
2678
-
2679
- std::vector<std::pair<std::string, std::string>> Take() {
2680
- return std::move(out_);
2681
- }
2682
-
2683
- private:
2684
- std::vector<std::pair<std::string, std::string>> out_;
2685
- };
2686
-
2687
- grpc_metadata_batch* batch_;
2688
- };
2689
-
2690
2314
  //
2691
2315
  // ClientChannelFilter::LoadBalancedCall::LbCallState
2692
2316
  //
@@ -2694,8 +2318,7 @@ class ClientChannelFilter::LoadBalancedCall::Metadata final
2694
2318
  ServiceConfigCallData::CallAttributeInterface*
2695
2319
  ClientChannelFilter::LoadBalancedCall::LbCallState::GetCallAttribute(
2696
2320
  UniqueTypeName type) const {
2697
- auto* service_config_call_data =
2698
- GetServiceConfigCallData(lb_call_->call_context_);
2321
+ auto* service_config_call_data = GetServiceConfigCallData(lb_call_->arena_);
2699
2322
  return service_config_call_data->GetCallAttribute(type);
2700
2323
  }
2701
2324
 
@@ -2721,7 +2344,7 @@ class ClientChannelFilter::LoadBalancedCall::BackendMetricAccessor final
2721
2344
  recv_trailing_metadata_ != nullptr) {
2722
2345
  if (const auto* md = recv_trailing_metadata_->get_pointer(
2723
2346
  EndpointLoadMetricsBinMetadata())) {
2724
- BackendMetricAllocator allocator(lb_call_->arena());
2347
+ BackendMetricAllocator allocator(lb_call_->arena_);
2725
2348
  lb_call_->backend_metric_data_ =
2726
2349
  ParseBackendMetricData(md->as_string_view(), &allocator);
2727
2350
  }
@@ -2756,31 +2379,31 @@ class ClientChannelFilter::LoadBalancedCall::BackendMetricAccessor final
2756
2379
 
2757
2380
  namespace {
2758
2381
 
2759
- void CreateCallAttemptTracer(grpc_call_context_element* context,
2760
- bool is_transparent_retry) {
2761
- auto* call_tracer = static_cast<ClientCallTracer*>(
2762
- context[GRPC_CONTEXT_CALL_TRACER_ANNOTATION_INTERFACE].value);
2763
- if (call_tracer == nullptr) return;
2382
+ ClientCallTracer::CallAttemptTracer* CreateCallAttemptTracer(
2383
+ Arena* arena, bool is_transparent_retry) {
2384
+ auto* call_tracer = DownCast<ClientCallTracer*>(
2385
+ arena->GetContext<CallTracerAnnotationInterface>());
2386
+ if (call_tracer == nullptr) return nullptr;
2764
2387
  auto* tracer = call_tracer->StartNewAttempt(is_transparent_retry);
2765
- context[GRPC_CONTEXT_CALL_TRACER].value = tracer;
2388
+ arena->SetContext<CallTracerInterface>(tracer);
2389
+ return tracer;
2766
2390
  }
2767
2391
 
2768
2392
  } // namespace
2769
2393
 
2770
2394
  ClientChannelFilter::LoadBalancedCall::LoadBalancedCall(
2771
- ClientChannelFilter* chand, grpc_call_context_element* call_context,
2395
+ ClientChannelFilter* chand, Arena* arena,
2772
2396
  absl::AnyInvocable<void()> on_commit, bool is_transparent_retry)
2773
- : InternallyRefCounted(
2774
- GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_lb_call_trace)
2775
- ? "LoadBalancedCall"
2776
- : nullptr),
2397
+ : InternallyRefCounted(GRPC_TRACE_FLAG_ENABLED(client_channel_lb_call)
2398
+ ? "LoadBalancedCall"
2399
+ : nullptr),
2777
2400
  chand_(chand),
2401
+ call_attempt_tracer_(
2402
+ CreateCallAttemptTracer(arena, is_transparent_retry)),
2778
2403
  on_commit_(std::move(on_commit)),
2779
- call_context_(call_context) {
2780
- CreateCallAttemptTracer(call_context, is_transparent_retry);
2781
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_lb_call_trace)) {
2782
- gpr_log(GPR_INFO, "chand=%p lb_call=%p: created", chand_, this);
2783
- }
2404
+ arena_(arena) {
2405
+ GRPC_TRACE_LOG(client_channel_lb_call, INFO)
2406
+ << "chand=" << chand_ << " lb_call=" << this << ": created";
2784
2407
  }
2785
2408
 
2786
2409
  ClientChannelFilter::LoadBalancedCall::~LoadBalancedCall() {
@@ -2801,7 +2424,7 @@ void ClientChannelFilter::LoadBalancedCall::RecordCallCompletion(
2801
2424
  // If the LB policy requested a callback for trailing metadata, invoke
2802
2425
  // the callback.
2803
2426
  if (lb_subchannel_call_tracker_ != nullptr) {
2804
- Metadata trailing_metadata(recv_trailing_metadata);
2427
+ LbMetadata trailing_metadata(recv_trailing_metadata);
2805
2428
  BackendMetricAccessor backend_metric_accessor(this, recv_trailing_metadata);
2806
2429
  LoadBalancingPolicy::SubchannelCallTrackerInterface::FinishArgs args = {
2807
2430
  peer_address, status, &trailing_metadata, &backend_metric_accessor};
@@ -2821,24 +2444,22 @@ void ClientChannelFilter::LoadBalancedCall::RecordLatency() {
2821
2444
 
2822
2445
  void ClientChannelFilter::LoadBalancedCall::
2823
2446
  RemoveCallFromLbQueuedCallsLocked() {
2824
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_lb_call_trace)) {
2825
- gpr_log(GPR_INFO, "chand=%p lb_call=%p: removing from queued picks list",
2826
- chand_, this);
2827
- }
2447
+ GRPC_TRACE_LOG(client_channel_lb_call, INFO)
2448
+ << "chand=" << chand_ << " lb_call=" << this
2449
+ << ": removing from queued picks list";
2828
2450
  // Remove pollset_set linkage.
2829
2451
  grpc_polling_entity_del_from_pollset_set(pollent(),
2830
2452
  chand_->interested_parties_);
2831
2453
  // Note: There's no need to actually remove the call from the queue
2832
- // here, beacuse that will be done in either
2454
+ // here, because that will be done in either
2833
2455
  // LbQueuedCallCanceller::CancelLocked() or
2834
2456
  // in ClientChannelFilter::UpdateStateAndPickerLocked().
2835
2457
  }
2836
2458
 
2837
2459
  void ClientChannelFilter::LoadBalancedCall::AddCallToLbQueuedCallsLocked() {
2838
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_lb_call_trace)) {
2839
- gpr_log(GPR_INFO, "chand=%p lb_call=%p: adding to queued picks list",
2840
- chand_, this);
2841
- }
2460
+ GRPC_TRACE_LOG(client_channel_lb_call, INFO)
2461
+ << "chand=" << chand_ << " lb_call=" << this
2462
+ << ": adding to queued picks list";
2842
2463
  // Add call's pollent to channel's interested_parties, so that I/O
2843
2464
  // can be done under the call's CQ.
2844
2465
  grpc_polling_entity_add_to_pollset_set(pollent(),
@@ -2848,84 +2469,48 @@ void ClientChannelFilter::LoadBalancedCall::AddCallToLbQueuedCallsLocked() {
2848
2469
  OnAddToQueueLocked();
2849
2470
  }
2850
2471
 
2851
- absl::optional<absl::Status>
2472
+ std::optional<absl::Status>
2852
2473
  ClientChannelFilter::LoadBalancedCall::PickSubchannel(bool was_queued) {
2853
- // We may accumulate multiple pickers here, because if a picker says
2854
- // to queue the call, we check again to see if the picker has been
2855
- // updated before we queue it.
2856
- // We need to unref pickers in the WorkSerializer.
2857
- std::vector<RefCountedPtr<LoadBalancingPolicy::SubchannelPicker>> pickers;
2858
- auto cleanup = absl::MakeCleanup([&]() {
2859
- if (IsWorkSerializerDispatchEnabled()) return;
2860
- chand_->work_serializer_->Run(
2861
- [pickers = std::move(pickers)]() mutable {
2862
- for (auto& picker : pickers) {
2863
- picker.reset(DEBUG_LOCATION, "PickSubchannel");
2864
- }
2865
- },
2866
- DEBUG_LOCATION);
2867
- });
2868
- absl::AnyInvocable<void(RefCountedPtr<LoadBalancingPolicy::SubchannelPicker>)>
2869
- set_picker;
2870
- if (!IsWorkSerializerDispatchEnabled()) {
2871
- set_picker =
2872
- [&](RefCountedPtr<LoadBalancingPolicy::SubchannelPicker> picker) {
2873
- pickers.emplace_back(std::move(picker));
2874
- };
2875
- } else {
2876
- pickers.emplace_back();
2877
- set_picker =
2878
- [&](RefCountedPtr<LoadBalancingPolicy::SubchannelPicker> picker) {
2879
- pickers[0] = std::move(picker);
2880
- };
2881
- }
2882
- // Grab mutex and take a ref to the picker.
2883
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_lb_call_trace)) {
2884
- gpr_log(GPR_INFO, "chand=%p lb_call=%p: grabbing LB mutex to get picker",
2885
- chand_, this);
2886
- }
2887
2474
  RefCountedPtr<LoadBalancingPolicy::SubchannelPicker> picker;
2475
+ // Grab mutex and take a ref to the picker.
2476
+ GRPC_TRACE_LOG(client_channel_lb_call, INFO)
2477
+ << "chand=" << chand_ << " lb_call=" << this
2478
+ << ": grabbing LB mutex to get picker";
2888
2479
  {
2889
2480
  MutexLock lock(&chand_->lb_mu_);
2890
- set_picker(chand_->picker_);
2481
+ picker = chand_->picker_;
2891
2482
  }
2892
2483
  while (true) {
2893
2484
  // TODO(roth): Fix race condition in channel_idle filter and any
2894
2485
  // other possible causes of this.
2895
- if (pickers.back() == nullptr) {
2896
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_lb_call_trace)) {
2897
- gpr_log(GPR_ERROR, "chand=%p lb_call=%p: picker is null, failing call",
2898
- chand_, this);
2899
- }
2486
+ if (picker == nullptr) {
2487
+ GRPC_TRACE_LOG(client_channel_lb_call, INFO)
2488
+ << "chand=" << chand_ << " lb_call=" << this
2489
+ << ": picker is null, failing call";
2900
2490
  return absl::InternalError("picker is null -- shouldn't happen");
2901
2491
  }
2902
2492
  // Do pick.
2903
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_lb_call_trace)) {
2904
- gpr_log(GPR_INFO, "chand=%p lb_call=%p: performing pick with picker=%p",
2905
- chand_, this, pickers.back().get());
2906
- }
2493
+ GRPC_TRACE_LOG(client_channel_lb_call, INFO)
2494
+ << "chand=" << chand_ << " lb_call=" << this
2495
+ << ": performing pick with picker=" << picker.get();
2907
2496
  grpc_error_handle error;
2908
- bool pick_complete = PickSubchannelImpl(pickers.back().get(), &error);
2497
+ bool pick_complete = PickSubchannelImpl(picker.get(), &error);
2909
2498
  if (!pick_complete) {
2910
2499
  RefCountedPtr<LoadBalancingPolicy::SubchannelPicker> old_picker;
2911
2500
  MutexLock lock(&chand_->lb_mu_);
2912
2501
  // If picker has been swapped out since we grabbed it, try again.
2913
- if (pickers.back() != chand_->picker_) {
2914
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_lb_call_trace)) {
2915
- gpr_log(GPR_INFO,
2916
- "chand=%p lb_call=%p: pick not complete, but picker changed",
2917
- chand_, this);
2918
- }
2919
- if (IsWorkSerializerDispatchEnabled()) {
2920
- // Don't unref until after we release the mutex.
2921
- old_picker = std::move(pickers.back());
2922
- }
2923
- set_picker(chand_->picker_);
2502
+ if (picker != chand_->picker_) {
2503
+ GRPC_TRACE_LOG(client_channel_lb_call, INFO)
2504
+ << "chand=" << chand_ << " lb_call=" << this
2505
+ << ": pick not complete, but picker changed";
2506
+ // Don't unref until after we release the mutex.
2507
+ old_picker = std::move(picker);
2508
+ picker = chand_->picker_;
2924
2509
  continue;
2925
2510
  }
2926
2511
  // Otherwise queue the pick to try again later when we get a new picker.
2927
2512
  AddCallToLbQueuedCallsLocked();
2928
- return absl::nullopt;
2513
+ return std::nullopt;
2929
2514
  }
2930
2515
  // Pick is complete.
2931
2516
  // If it was queued, add a trace annotation.
@@ -2934,11 +2519,9 @@ ClientChannelFilter::LoadBalancedCall::PickSubchannel(bool was_queued) {
2934
2519
  }
2935
2520
  // If the pick failed, fail the call.
2936
2521
  if (!error.ok()) {
2937
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_lb_call_trace)) {
2938
- gpr_log(GPR_INFO,
2939
- "chand=%p lb_call=%p: failed to pick subchannel: error=%s",
2940
- chand_, this, StatusToString(error).c_str());
2941
- }
2522
+ GRPC_TRACE_LOG(client_channel_lb_call, INFO)
2523
+ << "chand=" << chand_ << " lb_call=" << this
2524
+ << ": failed to pick subchannel: error=" << StatusToString(error);
2942
2525
  return error;
2943
2526
  }
2944
2527
  // Pick succeeded.
@@ -2957,18 +2540,17 @@ bool ClientChannelFilter::LoadBalancedCall::PickSubchannelImpl(
2957
2540
  pick_args.path = path->as_string_view();
2958
2541
  LbCallState lb_call_state(this);
2959
2542
  pick_args.call_state = &lb_call_state;
2960
- Metadata initial_metadata(send_initial_metadata());
2543
+ LbMetadata initial_metadata(send_initial_metadata());
2961
2544
  pick_args.initial_metadata = &initial_metadata;
2962
2545
  auto result = picker->Pick(pick_args);
2963
2546
  return HandlePickResult<bool>(
2964
2547
  &result,
2965
2548
  // CompletePick
2966
2549
  [this](LoadBalancingPolicy::PickResult::Complete* complete_pick) {
2967
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_lb_call_trace)) {
2968
- gpr_log(GPR_INFO,
2969
- "chand=%p lb_call=%p: LB pick succeeded: subchannel=%p",
2970
- chand_, this, complete_pick->subchannel.get());
2971
- }
2550
+ GRPC_TRACE_LOG(client_channel_lb_call, INFO)
2551
+ << "chand=" << chand_ << " lb_call=" << this
2552
+ << ": LB pick succeeded: subchannel="
2553
+ << complete_pick->subchannel.get();
2972
2554
  CHECK(complete_pick->subchannel != nullptr);
2973
2555
  // Grab a ref to the connected subchannel while we're still
2974
2556
  // holding the data plane mutex.
@@ -2980,12 +2562,10 @@ bool ClientChannelFilter::LoadBalancedCall::PickSubchannelImpl(
2980
2562
  // yet seen that change and given us a new picker), then just
2981
2563
  // queue the pick. We'll try again as soon as we get a new picker.
2982
2564
  if (connected_subchannel_ == nullptr) {
2983
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_lb_call_trace)) {
2984
- gpr_log(GPR_INFO,
2985
- "chand=%p lb_call=%p: subchannel returned by LB picker "
2986
- "has no connected subchannel; queueing pick",
2987
- chand_, this);
2988
- }
2565
+ GRPC_TRACE_LOG(client_channel_lb_call, INFO)
2566
+ << "chand=" << chand_ << " lb_call=" << this
2567
+ << ": subchannel returned by LB picker "
2568
+ "has no connected subchannel; queueing pick";
2989
2569
  return false;
2990
2570
  }
2991
2571
  lb_subchannel_call_tracker_ =
@@ -2993,22 +2573,24 @@ bool ClientChannelFilter::LoadBalancedCall::PickSubchannelImpl(
2993
2573
  if (lb_subchannel_call_tracker_ != nullptr) {
2994
2574
  lb_subchannel_call_tracker_->Start();
2995
2575
  }
2576
+ // Handle metadata mutations.
2577
+ MetadataMutationHandler::Apply(complete_pick->metadata_mutations,
2578
+ send_initial_metadata());
2579
+ MaybeOverrideAuthority(std::move(complete_pick->authority_override),
2580
+ send_initial_metadata());
2996
2581
  return true;
2997
2582
  },
2998
2583
  // QueuePick
2999
2584
  [this](LoadBalancingPolicy::PickResult::Queue* /*queue_pick*/) {
3000
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_lb_call_trace)) {
3001
- gpr_log(GPR_INFO, "chand=%p lb_call=%p: LB pick queued", chand_,
3002
- this);
3003
- }
2585
+ GRPC_TRACE_LOG(client_channel_lb_call, INFO)
2586
+ << "chand=" << chand_ << " lb_call=" << this << ": LB pick queued";
3004
2587
  return false;
3005
2588
  },
3006
2589
  // FailPick
3007
2590
  [this, &error](LoadBalancingPolicy::PickResult::Fail* fail_pick) {
3008
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_lb_call_trace)) {
3009
- gpr_log(GPR_INFO, "chand=%p lb_call=%p: LB pick failed: %s", chand_,
3010
- this, fail_pick->status.ToString().c_str());
3011
- }
2591
+ GRPC_TRACE_LOG(client_channel_lb_call, INFO)
2592
+ << "chand=" << chand_ << " lb_call=" << this
2593
+ << ": LB pick failed: " << fail_pick->status;
3012
2594
  // If wait_for_ready is false, then the error indicates the RPC
3013
2595
  // attempt's final status.
3014
2596
  if (!send_initial_metadata()
@@ -3024,10 +2606,9 @@ bool ClientChannelFilter::LoadBalancedCall::PickSubchannelImpl(
3024
2606
  },
3025
2607
  // DropPick
3026
2608
  [this, &error](LoadBalancingPolicy::PickResult::Drop* drop_pick) {
3027
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_lb_call_trace)) {
3028
- gpr_log(GPR_INFO, "chand=%p lb_call=%p: LB pick dropped: %s", chand_,
3029
- this, drop_pick->status.ToString().c_str());
3030
- }
2609
+ GRPC_TRACE_LOG(client_channel_lb_call, INFO)
2610
+ << "chand=" << chand_ << " lb_call=" << this
2611
+ << ": LB pick dropped: " << drop_pick->status;
3031
2612
  *error = grpc_error_set_int(
3032
2613
  absl_status_to_grpc_error(MaybeRewriteIllegalStatusCode(
3033
2614
  std::move(drop_pick->status), "LB drop")),
@@ -3044,9 +2625,8 @@ ClientChannelFilter::FilterBasedLoadBalancedCall::FilterBasedLoadBalancedCall(
3044
2625
  ClientChannelFilter* chand, const grpc_call_element_args& args,
3045
2626
  grpc_polling_entity* pollent, grpc_closure* on_call_destruction_complete,
3046
2627
  absl::AnyInvocable<void()> on_commit, bool is_transparent_retry)
3047
- : LoadBalancedCall(chand, args.context, std::move(on_commit),
2628
+ : LoadBalancedCall(chand, args.arena, std::move(on_commit),
3048
2629
  is_transparent_retry),
3049
- arena_(args.arena),
3050
2630
  owning_call_(args.call_stack),
3051
2631
  call_combiner_(args.call_combiner),
3052
2632
  pollent_(pollent),
@@ -3094,11 +2674,9 @@ size_t ClientChannelFilter::FilterBasedLoadBalancedCall::GetBatchIndex(
3094
2674
  void ClientChannelFilter::FilterBasedLoadBalancedCall::PendingBatchesAdd(
3095
2675
  grpc_transport_stream_op_batch* batch) {
3096
2676
  const size_t idx = GetBatchIndex(batch);
3097
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_lb_call_trace)) {
3098
- gpr_log(GPR_INFO,
3099
- "chand=%p lb_call=%p: adding pending batch at index %" PRIuPTR,
3100
- chand(), this, idx);
3101
- }
2677
+ GRPC_TRACE_LOG(client_channel_lb_call, INFO)
2678
+ << "chand=" << chand() << " lb_call=" << this
2679
+ << ": adding pending batch at index " << idx;
3102
2680
  CHECK_EQ(pending_batches_[idx], nullptr);
3103
2681
  pending_batches_[idx] = batch;
3104
2682
  }
@@ -3121,14 +2699,13 @@ void ClientChannelFilter::FilterBasedLoadBalancedCall::PendingBatchesFail(
3121
2699
  YieldCallCombinerPredicate yield_call_combiner_predicate) {
3122
2700
  CHECK(!error.ok());
3123
2701
  failure_error_ = error;
3124
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_lb_call_trace)) {
2702
+ if (GRPC_TRACE_FLAG_ENABLED(client_channel_lb_call)) {
3125
2703
  size_t num_batches = 0;
3126
2704
  for (size_t i = 0; i < GPR_ARRAY_SIZE(pending_batches_); ++i) {
3127
2705
  if (pending_batches_[i] != nullptr) ++num_batches;
3128
2706
  }
3129
- gpr_log(GPR_INFO,
3130
- "chand=%p lb_call=%p: failing %" PRIuPTR " pending batches: %s",
3131
- chand(), this, num_batches, StatusToString(error).c_str());
2707
+ LOG(INFO) << "chand=" << chand() << " lb_call=" << this << ": failing "
2708
+ << num_batches << " pending batches: " << StatusToString(error);
3132
2709
  }
3133
2710
  CallCombinerClosureList closures;
3134
2711
  for (size_t i = 0; i < GPR_ARRAY_SIZE(pending_batches_); ++i) {
@@ -3163,15 +2740,14 @@ void ClientChannelFilter::FilterBasedLoadBalancedCall::
3163
2740
 
3164
2741
  // This is called via the call combiner, so access to calld is synchronized.
3165
2742
  void ClientChannelFilter::FilterBasedLoadBalancedCall::PendingBatchesResume() {
3166
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_lb_call_trace)) {
2743
+ if (GRPC_TRACE_FLAG_ENABLED(client_channel_lb_call)) {
3167
2744
  size_t num_batches = 0;
3168
2745
  for (size_t i = 0; i < GPR_ARRAY_SIZE(pending_batches_); ++i) {
3169
2746
  if (pending_batches_[i] != nullptr) ++num_batches;
3170
2747
  }
3171
- gpr_log(GPR_INFO,
3172
- "chand=%p lb_call=%p: starting %" PRIuPTR
3173
- " pending batches on subchannel_call=%p",
3174
- chand(), this, num_batches, subchannel_call_.get());
2748
+ LOG(INFO) << "chand=" << chand() << " lb_call=" << this << ": starting "
2749
+ << num_batches << " pending batches on subchannel_call="
2750
+ << subchannel_call_.get();
3175
2751
  }
3176
2752
  CallCombinerClosureList closures;
3177
2753
  for (size_t i = 0; i < GPR_ARRAY_SIZE(pending_batches_); ++i) {
@@ -3192,14 +2768,12 @@ void ClientChannelFilter::FilterBasedLoadBalancedCall::PendingBatchesResume() {
3192
2768
 
3193
2769
  void ClientChannelFilter::FilterBasedLoadBalancedCall::
3194
2770
  StartTransportStreamOpBatch(grpc_transport_stream_op_batch* batch) {
3195
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_lb_call_trace) ||
3196
- GRPC_TRACE_FLAG_ENABLED(grpc_trace_channel)) {
3197
- gpr_log(GPR_INFO,
3198
- "chand=%p lb_call=%p: batch started from above: %s, "
3199
- "call_attempt_tracer()=%p",
3200
- chand(), this,
3201
- grpc_transport_stream_op_batch_string(batch, false).c_str(),
3202
- call_attempt_tracer());
2771
+ if (GRPC_TRACE_FLAG_ENABLED(client_channel_lb_call) ||
2772
+ GRPC_TRACE_FLAG_ENABLED(channel)) {
2773
+ LOG(INFO) << "chand=" << chand() << " lb_call=" << this
2774
+ << ": batch started from above: "
2775
+ << grpc_transport_stream_op_batch_string(batch, false)
2776
+ << ", call_attempt_tracer()=" << call_attempt_tracer();
3203
2777
  }
3204
2778
  // Handle call tracing.
3205
2779
  if (call_attempt_tracer() != nullptr) {
@@ -3247,11 +2821,9 @@ void ClientChannelFilter::FilterBasedLoadBalancedCall::
3247
2821
  // the channel's data plane mutex, which is more efficient (especially for
3248
2822
  // streaming calls).
3249
2823
  if (subchannel_call_ != nullptr) {
3250
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_lb_call_trace)) {
3251
- gpr_log(GPR_INFO,
3252
- "chand=%p lb_call=%p: starting batch on subchannel_call=%p",
3253
- chand(), this, subchannel_call_.get());
3254
- }
2824
+ GRPC_TRACE_LOG(client_channel_lb_call, INFO)
2825
+ << "chand=" << chand() << " lb_call=" << this
2826
+ << ": starting batch on subchannel_call=" << subchannel_call_.get();
3255
2827
  subchannel_call_->StartTransportStreamOpBatch(batch);
3256
2828
  return;
3257
2829
  }
@@ -3259,10 +2831,9 @@ void ClientChannelFilter::FilterBasedLoadBalancedCall::
3259
2831
  //
3260
2832
  // If we've previously been cancelled, immediately fail any new batches.
3261
2833
  if (GPR_UNLIKELY(!cancel_error_.ok())) {
3262
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_lb_call_trace)) {
3263
- gpr_log(GPR_INFO, "chand=%p lb_call=%p: failing batch with error: %s",
3264
- chand(), this, StatusToString(cancel_error_).c_str());
3265
- }
2834
+ GRPC_TRACE_LOG(client_channel_lb_call, INFO)
2835
+ << "chand=" << chand() << " lb_call=" << this
2836
+ << ": failing batch with error: " << StatusToString(cancel_error_);
3266
2837
  // Note: This will release the call combiner.
3267
2838
  grpc_transport_stream_op_batch_finish_with_failure(batch, cancel_error_,
3268
2839
  call_combiner_);
@@ -3276,10 +2847,9 @@ void ClientChannelFilter::FilterBasedLoadBalancedCall::
3276
2847
  // is in the past when the call starts), we can return the right
3277
2848
  // error to the caller when the first batch does get passed down.
3278
2849
  cancel_error_ = batch->payload->cancel_stream.cancel_error;
3279
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_lb_call_trace)) {
3280
- gpr_log(GPR_INFO, "chand=%p lb_call=%p: recording cancel_error=%s",
3281
- chand(), this, StatusToString(cancel_error_).c_str());
3282
- }
2850
+ GRPC_TRACE_LOG(client_channel_lb_call, INFO)
2851
+ << "chand=" << chand() << " lb_call=" << this
2852
+ << ": recording cancel_error=" << StatusToString(cancel_error_).c_str();
3283
2853
  // Fail all pending batches.
3284
2854
  PendingBatchesFail(cancel_error_, NoYieldCallCombiner);
3285
2855
  // Note: This will release the call combiner.
@@ -3295,11 +2865,9 @@ void ClientChannelFilter::FilterBasedLoadBalancedCall::
3295
2865
  TryPick(/*was_queued=*/false);
3296
2866
  } else {
3297
2867
  // For all other batches, release the call combiner.
3298
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_lb_call_trace)) {
3299
- gpr_log(GPR_INFO,
3300
- "chand=%p lb_call=%p: saved batch, yielding call combiner",
3301
- chand(), this);
3302
- }
2868
+ GRPC_TRACE_LOG(client_channel_lb_call, INFO)
2869
+ << "chand=" << chand() << " lb_call=" << this
2870
+ << ": saved batch, yielding call combiner";
3303
2871
  GRPC_CALL_COMBINER_STOP(call_combiner_,
3304
2872
  "batch does not include send_initial_metadata");
3305
2873
  }
@@ -3308,11 +2876,9 @@ void ClientChannelFilter::FilterBasedLoadBalancedCall::
3308
2876
  void ClientChannelFilter::FilterBasedLoadBalancedCall::RecvInitialMetadataReady(
3309
2877
  void* arg, grpc_error_handle error) {
3310
2878
  auto* self = static_cast<FilterBasedLoadBalancedCall*>(arg);
3311
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_lb_call_trace)) {
3312
- gpr_log(GPR_INFO,
3313
- "chand=%p lb_call=%p: got recv_initial_metadata_ready: error=%s",
3314
- self->chand(), self, StatusToString(error).c_str());
3315
- }
2879
+ GRPC_TRACE_LOG(client_channel_lb_call, INFO)
2880
+ << "chand=" << self->chand() << " lb_call=" << self
2881
+ << ": got recv_initial_metadata_ready: error=" << StatusToString(error);
3316
2882
  if (error.ok()) {
3317
2883
  // recv_initial_metadata_flags is not populated for clients
3318
2884
  self->call_attempt_tracer()->RecordReceivedInitialMetadata(
@@ -3327,15 +2893,12 @@ void ClientChannelFilter::FilterBasedLoadBalancedCall::RecvInitialMetadataReady(
3327
2893
  void ClientChannelFilter::FilterBasedLoadBalancedCall::
3328
2894
  RecvTrailingMetadataReady(void* arg, grpc_error_handle error) {
3329
2895
  auto* self = static_cast<FilterBasedLoadBalancedCall*>(arg);
3330
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_lb_call_trace)) {
3331
- gpr_log(GPR_INFO,
3332
- "chand=%p lb_call=%p: got recv_trailing_metadata_ready: error=%s "
3333
- "call_attempt_tracer()=%p lb_subchannel_call_tracker_=%p "
3334
- "failure_error_=%s",
3335
- self->chand(), self, StatusToString(error).c_str(),
3336
- self->call_attempt_tracer(), self->lb_subchannel_call_tracker(),
3337
- StatusToString(self->failure_error_).c_str());
3338
- }
2896
+ GRPC_TRACE_LOG(client_channel_lb_call, INFO)
2897
+ << "chand=" << self->chand() << " lb_call=" << self
2898
+ << ": got recv_trailing_metadata_ready: error=" << StatusToString(error)
2899
+ << " call_attempt_tracer()=" << self->call_attempt_tracer()
2900
+ << " lb_subchannel_call_tracker_=" << self->lb_subchannel_call_tracker()
2901
+ << " failure_error_=" << StatusToString(self->failure_error_);
3339
2902
  // Check if we have a tracer or an LB callback to invoke.
3340
2903
  if (self->call_attempt_tracer() != nullptr ||
3341
2904
  self->lb_subchannel_call_tracker() != nullptr) {
@@ -3346,10 +2909,7 @@ void ClientChannelFilter::FilterBasedLoadBalancedCall::
3346
2909
  grpc_status_code code;
3347
2910
  std::string message;
3348
2911
  grpc_error_get_status(
3349
- error,
3350
- static_cast<Call*>(self->call_context()[GRPC_CONTEXT_CALL].value)
3351
- ->deadline(),
3352
- &code, &message,
2912
+ error, self->arena()->GetContext<Call>()->deadline(), &code, &message,
3353
2913
  /*http_error=*/nullptr, /*error_string=*/nullptr);
3354
2914
  status = absl::Status(static_cast<absl::StatusCode>(code), message);
3355
2915
  } else {
@@ -3406,13 +2966,11 @@ class ClientChannelFilter::FilterBasedLoadBalancedCall::LbQueuedCallCanceller
3406
2966
  auto* chand = lb_call->chand();
3407
2967
  {
3408
2968
  MutexLock lock(&chand->lb_mu_);
3409
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_lb_call_trace)) {
3410
- gpr_log(GPR_INFO,
3411
- "chand=%p lb_call=%p: cancelling queued pick: "
3412
- "error=%s self=%p calld->pick_canceller=%p",
3413
- chand, lb_call, StatusToString(error).c_str(), self,
3414
- lb_call->lb_call_canceller_);
3415
- }
2969
+ GRPC_TRACE_LOG(client_channel_lb_call, INFO)
2970
+ << "chand=" << chand << " lb_call=" << lb_call
2971
+ << ": cancelling queued pick: error=" << StatusToString(error)
2972
+ << " self=" << self
2973
+ << " calld->pick_canceller=" << lb_call->lb_call_canceller_;
3416
2974
  if (lb_call->lb_call_canceller_ == self && !error.ok()) {
3417
2975
  lb_call->Commit();
3418
2976
  // Remove pick from list of queued picks.
@@ -3488,18 +3046,16 @@ void ClientChannelFilter::FilterBasedLoadBalancedCall::CreateSubchannelCall() {
3488
3046
  CHECK_NE(path, nullptr);
3489
3047
  SubchannelCall::Args call_args = {
3490
3048
  connected_subchannel()->Ref(), pollent_, path->Ref(), /*start_time=*/0,
3491
- static_cast<Call*>(call_context()[GRPC_CONTEXT_CALL].value)->deadline(),
3492
- arena_,
3049
+ arena()->GetContext<Call>()->deadline(),
3493
3050
  // TODO(roth): When we implement hedging support, we will probably
3494
- // need to use a separate call context for each subchannel call.
3495
- call_context(), call_combiner_};
3051
+ // need to use a separate call arena for each subchannel call.
3052
+ arena(), call_combiner_};
3496
3053
  grpc_error_handle error;
3497
3054
  subchannel_call_ = SubchannelCall::Create(std::move(call_args), &error);
3498
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_lb_call_trace)) {
3499
- gpr_log(GPR_INFO,
3500
- "chand=%p lb_call=%p: create subchannel_call=%p: error=%s", chand(),
3501
- this, subchannel_call_.get(), StatusToString(error).c_str());
3502
- }
3055
+ GRPC_TRACE_LOG(client_channel_lb_call, INFO)
3056
+ << "chand=" << chand() << " lb_call=" << this
3057
+ << ": create subchannel_call=" << subchannel_call_.get()
3058
+ << ": error=" << StatusToString(error);
3503
3059
  if (on_call_destruction_complete_ != nullptr) {
3504
3060
  subchannel_call_->SetAfterCallStackDestroy(on_call_destruction_complete_);
3505
3061
  on_call_destruction_complete_ = nullptr;
@@ -3511,150 +3067,4 @@ void ClientChannelFilter::FilterBasedLoadBalancedCall::CreateSubchannelCall() {
3511
3067
  }
3512
3068
  }
3513
3069
 
3514
- //
3515
- // ClientChannelFilter::PromiseBasedLoadBalancedCall
3516
- //
3517
-
3518
- ClientChannelFilter::PromiseBasedLoadBalancedCall::PromiseBasedLoadBalancedCall(
3519
- ClientChannelFilter* chand, absl::AnyInvocable<void()> on_commit,
3520
- bool is_transparent_retry)
3521
- : LoadBalancedCall(chand, GetContext<grpc_call_context_element>(),
3522
- std::move(on_commit), is_transparent_retry) {}
3523
-
3524
- ArenaPromise<ServerMetadataHandle>
3525
- ClientChannelFilter::PromiseBasedLoadBalancedCall::MakeCallPromise(
3526
- CallArgs call_args, OrphanablePtr<PromiseBasedLoadBalancedCall> lb_call) {
3527
- pollent_ = NowOrNever(call_args.polling_entity->WaitAndCopy()).value();
3528
- // Record ops in tracer.
3529
- if (call_attempt_tracer() != nullptr) {
3530
- call_attempt_tracer()->RecordSendInitialMetadata(
3531
- call_args.client_initial_metadata.get());
3532
- // TODO(ctiller): Find a way to do this without registering a no-op mapper.
3533
- call_args.client_to_server_messages->InterceptAndMapWithHalfClose(
3534
- [](MessageHandle message) { return message; }, // No-op.
3535
- [this]() {
3536
- // TODO(roth): Change CallTracer API to not pass metadata
3537
- // batch to this method, since the batch is always empty.
3538
- grpc_metadata_batch metadata;
3539
- call_attempt_tracer()->RecordSendTrailingMetadata(&metadata);
3540
- });
3541
- }
3542
- // Extract peer name from server initial metadata.
3543
- call_args.server_initial_metadata->InterceptAndMap(
3544
- [self = lb_call->RefAsSubclass<PromiseBasedLoadBalancedCall>()](
3545
- ServerMetadataHandle metadata) {
3546
- if (self->call_attempt_tracer() != nullptr) {
3547
- self->call_attempt_tracer()->RecordReceivedInitialMetadata(
3548
- metadata.get());
3549
- }
3550
- Slice* peer_string = metadata->get_pointer(PeerString());
3551
- if (peer_string != nullptr) self->peer_string_ = peer_string->Ref();
3552
- return metadata;
3553
- });
3554
- client_initial_metadata_ = std::move(call_args.client_initial_metadata);
3555
- return OnCancel(
3556
- Map(TrySeq(
3557
- // LB pick.
3558
- [this]() -> Poll<absl::Status> {
3559
- auto result = PickSubchannel(was_queued_);
3560
- if (GRPC_TRACE_FLAG_ENABLED(
3561
- grpc_client_channel_lb_call_trace)) {
3562
- gpr_log(GPR_INFO,
3563
- "chand=%p lb_call=%p: %sPickSubchannel() returns %s",
3564
- chand(), this,
3565
- GetContext<Activity>()->DebugTag().c_str(),
3566
- result.has_value() ? result->ToString().c_str()
3567
- : "Pending");
3568
- }
3569
- if (result == absl::nullopt) return Pending{};
3570
- return std::move(*result);
3571
- },
3572
- [this, call_args = std::move(call_args)]() mutable
3573
- -> ArenaPromise<ServerMetadataHandle> {
3574
- call_args.client_initial_metadata =
3575
- std::move(client_initial_metadata_);
3576
- return connected_subchannel()->MakeCallPromise(
3577
- std::move(call_args));
3578
- }),
3579
- // Record call completion.
3580
- [this](ServerMetadataHandle metadata) {
3581
- if (call_attempt_tracer() != nullptr ||
3582
- lb_subchannel_call_tracker() != nullptr) {
3583
- absl::Status status;
3584
- grpc_status_code code = metadata->get(GrpcStatusMetadata())
3585
- .value_or(GRPC_STATUS_UNKNOWN);
3586
- if (code != GRPC_STATUS_OK) {
3587
- absl::string_view message;
3588
- if (const auto* grpc_message =
3589
- metadata->get_pointer(GrpcMessageMetadata())) {
3590
- message = grpc_message->as_string_view();
3591
- }
3592
- status =
3593
- absl::Status(static_cast<absl::StatusCode>(code), message);
3594
- }
3595
- RecordCallCompletion(status, metadata.get(),
3596
- &GetContext<CallContext>()
3597
- ->call_stats()
3598
- ->transport_stream_stats,
3599
- peer_string_.as_string_view());
3600
- }
3601
- RecordLatency();
3602
- return metadata;
3603
- }),
3604
- [lb_call = std::move(lb_call)]() {
3605
- // If the waker is pending, then we need to remove ourself from
3606
- // the list of queued LB calls.
3607
- if (!lb_call->waker_.is_unwakeable()) {
3608
- MutexLock lock(&lb_call->chand()->lb_mu_);
3609
- lb_call->Commit();
3610
- // Remove pick from list of queued picks.
3611
- lb_call->RemoveCallFromLbQueuedCallsLocked();
3612
- // Remove from queued picks list.
3613
- lb_call->chand()->lb_queued_calls_.erase(lb_call.get());
3614
- }
3615
- // TODO(ctiller): We don't have access to the call's actual status
3616
- // here, so we just assume CANCELLED. We could change this to use
3617
- // CallFinalization instead of OnCancel() so that we can get the
3618
- // actual status. But we should also have access to the trailing
3619
- // metadata, which we don't have in either case. Ultimately, we
3620
- // need a better story for code that needs to run at the end of a
3621
- // call in both cancellation and non-cancellation cases that needs
3622
- // access to server trailing metadata and the call's real status.
3623
- if (lb_call->call_attempt_tracer() != nullptr) {
3624
- lb_call->call_attempt_tracer()->RecordCancel(
3625
- absl::CancelledError("call cancelled"));
3626
- }
3627
- if (lb_call->call_attempt_tracer() != nullptr ||
3628
- lb_call->lb_subchannel_call_tracker() != nullptr) {
3629
- // If we were cancelled without recording call completion, then
3630
- // record call completion here, as best we can. We assume status
3631
- // CANCELLED in this case.
3632
- lb_call->RecordCallCompletion(absl::CancelledError("call cancelled"),
3633
- nullptr, nullptr, "");
3634
- }
3635
- });
3636
- }
3637
-
3638
- Arena* ClientChannelFilter::PromiseBasedLoadBalancedCall::arena() const {
3639
- return GetContext<Arena>();
3640
- }
3641
-
3642
- grpc_metadata_batch*
3643
- ClientChannelFilter::PromiseBasedLoadBalancedCall::send_initial_metadata()
3644
- const {
3645
- return client_initial_metadata_.get();
3646
- }
3647
-
3648
- void ClientChannelFilter::PromiseBasedLoadBalancedCall::OnAddToQueueLocked() {
3649
- waker_ = GetContext<Activity>()->MakeNonOwningWaker();
3650
- was_queued_ = true;
3651
- }
3652
-
3653
- void ClientChannelFilter::PromiseBasedLoadBalancedCall::RetryPickLocked() {
3654
- if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_lb_call_trace)) {
3655
- gpr_log(GPR_INFO, "chand=%p lb_call=%p: RetryPickLocked()", chand(), this);
3656
- }
3657
- waker_.WakeupAsync();
3658
- }
3659
-
3660
3070
  } // namespace grpc_core