grpc 1.63.0 → 1.66.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (1652) hide show
  1. checksums.yaml +4 -4
  2. data/Makefile +116 -104
  3. data/include/grpc/credentials.h +1222 -0
  4. data/include/grpc/event_engine/event_engine.h +27 -6
  5. data/include/grpc/event_engine/extensible.h +3 -0
  6. data/include/grpc/event_engine/memory_request.h +18 -0
  7. data/include/grpc/grpc.h +7 -0
  8. data/include/grpc/grpc_crl_provider.h +1 -0
  9. data/include/grpc/grpc_security.h +0 -1171
  10. data/include/grpc/impl/channel_arg_names.h +7 -6
  11. data/include/grpc/module.modulemap +2 -0
  12. data/include/grpc/passive_listener.h +62 -0
  13. data/include/grpc/support/log.h +7 -35
  14. data/include/grpc/support/metrics.h +14 -3
  15. data/include/grpc/support/port_platform.h +25 -0
  16. data/src/core/{lib/channel → channelz}/channel_trace.cc +57 -63
  17. data/src/core/{lib/channel → channelz}/channel_trace.h +22 -20
  18. data/src/core/{lib/channel → channelz}/channelz.cc +71 -9
  19. data/src/core/{lib/channel → channelz}/channelz.h +52 -13
  20. data/src/core/{lib/channel → channelz}/channelz_registry.cc +11 -9
  21. data/src/core/{lib/channel → channelz}/channelz_registry.h +6 -6
  22. data/src/core/client_channel/backup_poller.cc +4 -5
  23. data/src/core/client_channel/client_channel.cc +1419 -0
  24. data/src/core/client_channel/client_channel.h +243 -0
  25. data/src/core/client_channel/client_channel_filter.cc +349 -872
  26. data/src/core/client_channel/client_channel_filter.h +13 -68
  27. data/src/core/client_channel/client_channel_internal.h +25 -7
  28. data/src/core/client_channel/client_channel_plugin.cc +1 -14
  29. data/src/core/client_channel/client_channel_service_config.h +4 -4
  30. data/src/core/client_channel/config_selector.h +22 -18
  31. data/src/core/client_channel/connector.h +1 -1
  32. data/src/core/client_channel/direct_channel.cc +83 -0
  33. data/src/core/client_channel/direct_channel.h +101 -0
  34. data/src/core/client_channel/dynamic_filters.cc +9 -6
  35. data/src/core/client_channel/dynamic_filters.h +1 -3
  36. data/src/core/client_channel/lb_metadata.cc +120 -0
  37. data/src/core/client_channel/lb_metadata.h +56 -0
  38. data/src/core/client_channel/load_balanced_call_destination.cc +274 -0
  39. data/src/core/client_channel/load_balanced_call_destination.h +49 -0
  40. data/src/core/client_channel/local_subchannel_pool.cc +5 -3
  41. data/src/core/client_channel/retry_filter.cc +4 -11
  42. data/src/core/client_channel/retry_filter.h +5 -9
  43. data/src/core/client_channel/retry_filter_legacy_call_data.cc +234 -261
  44. data/src/core/client_channel/retry_filter_legacy_call_data.h +0 -2
  45. data/src/core/client_channel/retry_service_config.cc +4 -5
  46. data/src/core/client_channel/retry_service_config.h +3 -3
  47. data/src/core/client_channel/subchannel.cc +284 -156
  48. data/src/core/client_channel/subchannel.h +31 -25
  49. data/src/core/client_channel/subchannel_pool_interface.cc +0 -2
  50. data/src/core/client_channel/subchannel_pool_interface.h +2 -4
  51. data/src/core/client_channel/subchannel_stream_client.cc +41 -52
  52. data/src/core/client_channel/subchannel_stream_client.h +2 -4
  53. data/src/core/ext/filters/backend_metrics/backend_metric_filter.cc +17 -20
  54. data/src/core/ext/filters/backend_metrics/backend_metric_filter.h +5 -2
  55. data/src/core/ext/filters/backend_metrics/backend_metric_provider.h +7 -0
  56. data/src/core/ext/filters/census/grpc_context.cc +6 -8
  57. data/src/core/ext/filters/channel_idle/legacy_channel_idle_filter.cc +28 -28
  58. data/src/core/ext/filters/channel_idle/legacy_channel_idle_filter.h +16 -11
  59. data/src/core/ext/filters/fault_injection/fault_injection_filter.cc +15 -21
  60. data/src/core/ext/filters/fault_injection/fault_injection_filter.h +7 -4
  61. data/src/core/ext/filters/fault_injection/fault_injection_service_config_parser.h +3 -3
  62. data/src/core/ext/filters/http/client/http_client_filter.cc +7 -5
  63. data/src/core/ext/filters/http/client/http_client_filter.h +8 -5
  64. data/src/core/ext/filters/http/client_authority_filter.cc +6 -5
  65. data/src/core/ext/filters/http/client_authority_filter.h +8 -4
  66. data/src/core/ext/filters/http/message_compress/compression_filter.cc +35 -42
  67. data/src/core/ext/filters/http/message_compress/compression_filter.h +15 -8
  68. data/src/core/ext/filters/http/server/http_server_filter.cc +8 -8
  69. data/src/core/ext/filters/http/server/http_server_filter.h +8 -5
  70. data/src/core/ext/filters/message_size/message_size_filter.cc +27 -41
  71. data/src/core/ext/filters/message_size/message_size_filter.h +18 -12
  72. data/src/core/ext/filters/rbac/rbac_filter.cc +14 -12
  73. data/src/core/ext/filters/rbac/rbac_filter.h +8 -5
  74. data/src/core/ext/filters/rbac/rbac_service_config_parser.cc +2 -2
  75. data/src/core/ext/filters/rbac/rbac_service_config_parser.h +1 -1
  76. data/src/core/ext/filters/stateful_session/stateful_session_filter.cc +15 -20
  77. data/src/core/ext/filters/stateful_session/stateful_session_filter.h +6 -2
  78. data/src/core/ext/filters/stateful_session/stateful_session_service_config_parser.h +3 -3
  79. data/src/core/ext/transport/chttp2/alpn/alpn.cc +5 -4
  80. data/src/core/ext/transport/chttp2/alpn/alpn.h +2 -2
  81. data/src/core/ext/transport/chttp2/client/chttp2_connector.cc +68 -96
  82. data/src/core/ext/transport/chttp2/client/chttp2_connector.h +3 -9
  83. data/src/core/ext/transport/chttp2/server/chttp2_server.cc +307 -254
  84. data/src/core/ext/transport/chttp2/server/chttp2_server.h +36 -3
  85. data/src/core/ext/transport/chttp2/transport/bin_decoder.cc +23 -35
  86. data/src/core/ext/transport/chttp2/transport/bin_decoder.h +1 -2
  87. data/src/core/ext/transport/chttp2/transport/bin_encoder.cc +8 -7
  88. data/src/core/ext/transport/chttp2/transport/bin_encoder.h +1 -2
  89. data/src/core/ext/transport/chttp2/transport/chttp2_transport.cc +367 -321
  90. data/src/core/ext/transport/chttp2/transport/chttp2_transport.h +12 -13
  91. data/src/core/ext/transport/chttp2/transport/context_list_entry.h +3 -3
  92. data/src/core/ext/transport/chttp2/transport/decode_huff.cc +2 -2
  93. data/src/core/ext/transport/chttp2/transport/decode_huff.h +2 -2
  94. data/src/core/ext/transport/chttp2/transport/flow_control.cc +9 -11
  95. data/src/core/ext/transport/chttp2/transport/flow_control.h +4 -6
  96. data/src/core/ext/transport/chttp2/transport/frame.cc +4 -4
  97. data/src/core/ext/transport/chttp2/transport/frame.h +2 -2
  98. data/src/core/ext/transport/chttp2/transport/frame_data.cc +6 -10
  99. data/src/core/ext/transport/chttp2/transport/frame_data.h +3 -3
  100. data/src/core/ext/transport/chttp2/transport/frame_goaway.cc +5 -5
  101. data/src/core/ext/transport/chttp2/transport/frame_goaway.h +1 -2
  102. data/src/core/ext/transport/chttp2/transport/frame_ping.cc +14 -17
  103. data/src/core/ext/transport/chttp2/transport/frame_ping.h +1 -2
  104. data/src/core/ext/transport/chttp2/transport/frame_rst_stream.cc +16 -15
  105. data/src/core/ext/transport/chttp2/transport/frame_rst_stream.h +6 -5
  106. data/src/core/ext/transport/chttp2/transport/frame_settings.cc +18 -16
  107. data/src/core/ext/transport/chttp2/transport/frame_settings.h +1 -2
  108. data/src/core/ext/transport/chttp2/transport/frame_window_update.cc +11 -7
  109. data/src/core/ext/transport/chttp2/transport/frame_window_update.h +4 -3
  110. data/src/core/ext/transport/chttp2/transport/hpack_constants.h +2 -2
  111. data/src/core/ext/transport/chttp2/transport/hpack_encoder.cc +13 -12
  112. data/src/core/ext/transport/chttp2/transport/hpack_encoder.h +14 -9
  113. data/src/core/ext/transport/chttp2/transport/hpack_encoder_table.cc +10 -9
  114. data/src/core/ext/transport/chttp2/transport/hpack_encoder_table.h +2 -2
  115. data/src/core/ext/transport/chttp2/transport/hpack_parse_result.cc +4 -3
  116. data/src/core/ext/transport/chttp2/transport/hpack_parse_result.h +3 -3
  117. data/src/core/ext/transport/chttp2/transport/hpack_parser.cc +75 -68
  118. data/src/core/ext/transport/chttp2/transport/hpack_parser.h +4 -3
  119. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.cc +8 -13
  120. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.h +2 -2
  121. data/src/core/ext/transport/chttp2/transport/http2_settings.cc +3 -3
  122. data/src/core/ext/transport/chttp2/transport/http2_settings.h +3 -3
  123. data/src/core/ext/transport/chttp2/transport/huffsyms.cc +2 -2
  124. data/src/core/ext/transport/chttp2/transport/internal.h +79 -26
  125. data/src/core/ext/transport/chttp2/transport/max_concurrent_streams_policy.cc +4 -3
  126. data/src/core/ext/transport/chttp2/transport/max_concurrent_streams_policy.h +2 -2
  127. data/src/core/ext/transport/chttp2/transport/parsing.cc +87 -97
  128. data/src/core/ext/transport/chttp2/transport/ping_abuse_policy.cc +1 -2
  129. data/src/core/ext/transport/chttp2/transport/ping_abuse_policy.h +2 -2
  130. data/src/core/ext/transport/chttp2/transport/ping_callbacks.cc +3 -5
  131. data/src/core/ext/transport/chttp2/transport/ping_callbacks.h +1 -4
  132. data/src/core/ext/transport/chttp2/transport/ping_rate_policy.cc +30 -15
  133. data/src/core/ext/transport/chttp2/transport/ping_rate_policy.h +7 -6
  134. data/src/core/ext/transport/chttp2/transport/stream_lists.cc +17 -18
  135. data/src/core/ext/transport/chttp2/transport/varint.cc +2 -2
  136. data/src/core/ext/transport/chttp2/transport/varint.h +4 -3
  137. data/src/core/ext/transport/chttp2/transport/write_size_policy.cc +4 -3
  138. data/src/core/ext/transport/chttp2/transport/write_size_policy.h +2 -2
  139. data/src/core/ext/transport/chttp2/transport/writing.cc +164 -126
  140. data/src/core/ext/transport/inproc/inproc_transport.cc +152 -69
  141. data/src/core/ext/transport/inproc/inproc_transport.h +2 -5
  142. data/src/core/ext/transport/inproc/legacy_inproc_transport.cc +116 -116
  143. data/src/core/ext/transport/inproc/legacy_inproc_transport.h +1 -4
  144. data/src/core/ext/upb-gen/envoy/admin/v3/certs.upb.h +11 -11
  145. data/src/core/ext/upb-gen/envoy/admin/v3/certs.upb_minitable.c +15 -0
  146. data/src/core/ext/upb-gen/envoy/admin/v3/clusters.upb.h +23 -23
  147. data/src/core/ext/upb-gen/envoy/admin/v3/clusters.upb_minitable.c +12 -0
  148. data/src/core/ext/upb-gen/envoy/admin/v3/config_dump.upb.h +11 -11
  149. data/src/core/ext/upb-gen/envoy/admin/v3/config_dump.upb_minitable.c +15 -0
  150. data/src/core/ext/upb-gen/envoy/admin/v3/config_dump_shared.upb.h +50 -50
  151. data/src/core/ext/upb-gen/envoy/admin/v3/config_dump_shared.upb_minitable.c +57 -0
  152. data/src/core/ext/upb-gen/envoy/admin/v3/init_dump.upb.h +1 -1
  153. data/src/core/ext/upb-gen/envoy/admin/v3/init_dump.upb_minitable.c +6 -0
  154. data/src/core/ext/upb-gen/envoy/admin/v3/listeners.upb.h +2 -2
  155. data/src/core/ext/upb-gen/envoy/admin/v3/listeners.upb_minitable.c +6 -0
  156. data/src/core/ext/upb-gen/envoy/admin/v3/memory.upb.h +6 -6
  157. data/src/core/ext/upb-gen/envoy/admin/v3/memory.upb_minitable.c +3 -0
  158. data/src/core/ext/upb-gen/envoy/admin/v3/metrics.upb.h +3 -3
  159. data/src/core/ext/upb-gen/envoy/admin/v3/metrics.upb_minitable.c +3 -0
  160. data/src/core/ext/upb-gen/envoy/admin/v3/mutex_stats.upb.h +3 -3
  161. data/src/core/ext/upb-gen/envoy/admin/v3/mutex_stats.upb_minitable.c +3 -0
  162. data/src/core/ext/upb-gen/envoy/admin/v3/server_info.upb.h +110 -78
  163. data/src/core/ext/upb-gen/envoy/admin/v3/server_info.upb_minitable.c +23 -15
  164. data/src/core/ext/upb-gen/envoy/admin/v3/tap.upb.h +2 -2
  165. data/src/core/ext/upb-gen/envoy/admin/v3/tap.upb_minitable.c +3 -0
  166. data/src/core/ext/upb-gen/envoy/annotations/deprecation.upb.h +4 -4
  167. data/src/core/ext/upb-gen/envoy/annotations/resource.upb.h +11 -2
  168. data/src/core/ext/upb-gen/envoy/annotations/resource.upb_minitable.c +3 -0
  169. data/src/core/ext/upb-gen/envoy/config/accesslog/v3/accesslog.upb.h +30 -30
  170. data/src/core/ext/upb-gen/envoy/config/accesslog/v3/accesslog.upb_minitable.c +48 -0
  171. data/src/core/ext/upb-gen/envoy/config/bootstrap/v3/bootstrap.upb.h +361 -250
  172. data/src/core/ext/upb-gen/envoy/config/bootstrap/v3/bootstrap.upb_minitable.c +139 -48
  173. data/src/core/ext/upb-gen/envoy/config/bootstrap/v3/bootstrap.upb_minitable.h +1 -0
  174. data/src/core/ext/upb-gen/envoy/config/cluster/v3/circuit_breaker.upb.h +10 -10
  175. data/src/core/ext/upb-gen/envoy/config/cluster/v3/circuit_breaker.upb_minitable.c +9 -0
  176. data/src/core/ext/upb-gen/envoy/config/cluster/v3/cluster.upb.h +314 -137
  177. data/src/core/ext/upb-gen/envoy/config/cluster/v3/cluster.upb_minitable.c +120 -22
  178. data/src/core/ext/upb-gen/envoy/config/cluster/v3/cluster.upb_minitable.h +1 -0
  179. data/src/core/ext/upb-gen/envoy/config/cluster/v3/filter.upb.h +3 -3
  180. data/src/core/ext/upb-gen/envoy/config/cluster/v3/filter.upb_minitable.c +3 -0
  181. data/src/core/ext/upb-gen/envoy/config/cluster/v3/outlier_detection.upb.h +115 -23
  182. data/src/core/ext/upb-gen/envoy/config/cluster/v3/outlier_detection.upb_minitable.c +27 -3
  183. data/src/core/ext/upb-gen/envoy/config/common/matcher/v3/matcher.upb.h +31 -31
  184. data/src/core/ext/upb-gen/envoy/config/common/matcher/v3/matcher.upb_minitable.c +45 -0
  185. data/src/core/ext/upb-gen/envoy/config/core/v3/address.upb.h +23 -23
  186. data/src/core/ext/upb-gen/envoy/config/core/v3/address.upb_minitable.c +24 -0
  187. data/src/core/ext/upb-gen/envoy/config/core/v3/backoff.upb.h +2 -2
  188. data/src/core/ext/upb-gen/envoy/config/core/v3/backoff.upb_minitable.c +3 -0
  189. data/src/core/ext/upb-gen/envoy/config/core/v3/base.upb.h +646 -68
  190. data/src/core/ext/upb-gen/envoy/config/core/v3/base.upb_minitable.c +230 -16
  191. data/src/core/ext/upb-gen/envoy/config/core/v3/base.upb_minitable.h +5 -0
  192. data/src/core/ext/upb-gen/envoy/config/core/v3/config_source.upb.h +21 -21
  193. data/src/core/ext/upb-gen/envoy/config/core/v3/config_source.upb_minitable.c +21 -0
  194. data/src/core/ext/upb-gen/envoy/config/core/v3/event_service_config.upb.h +1 -1
  195. data/src/core/ext/upb-gen/envoy/config/core/v3/event_service_config.upb_minitable.c +3 -0
  196. data/src/core/ext/upb-gen/envoy/config/core/v3/extension.upb.h +2 -2
  197. data/src/core/ext/upb-gen/envoy/config/core/v3/extension.upb_minitable.c +3 -0
  198. data/src/core/ext/upb-gen/envoy/config/core/v3/grpc_method_list.upb.h +1 -1
  199. data/src/core/ext/upb-gen/envoy/config/core/v3/grpc_method_list.upb_minitable.c +6 -0
  200. data/src/core/ext/upb-gen/envoy/config/core/v3/grpc_service.upb.h +130 -58
  201. data/src/core/ext/upb-gen/envoy/config/core/v3/grpc_service.upb_minitable.c +63 -12
  202. data/src/core/ext/upb-gen/envoy/config/core/v3/health_check.upb.h +104 -58
  203. data/src/core/ext/upb-gen/envoy/config/core/v3/health_check.upb_minitable.c +42 -11
  204. data/src/core/ext/upb-gen/envoy/config/core/v3/http_service.upb.h +1 -1
  205. data/src/core/ext/upb-gen/envoy/config/core/v3/http_service.upb_minitable.c +3 -0
  206. data/src/core/ext/upb-gen/envoy/config/core/v3/http_uri.upb.h +3 -3
  207. data/src/core/ext/upb-gen/envoy/config/core/v3/http_uri.upb_minitable.c +3 -0
  208. data/src/core/ext/upb-gen/envoy/config/core/v3/protocol.upb.h +132 -72
  209. data/src/core/ext/upb-gen/envoy/config/core/v3/protocol.upb_minitable.c +65 -11
  210. data/src/core/ext/upb-gen/envoy/config/core/v3/proxy_protocol.upb.h +3 -3
  211. data/src/core/ext/upb-gen/envoy/config/core/v3/proxy_protocol.upb_minitable.c +6 -0
  212. data/src/core/ext/upb-gen/envoy/config/core/v3/resolver.upb.h +3 -3
  213. data/src/core/ext/upb-gen/envoy/config/core/v3/resolver.upb_minitable.c +6 -0
  214. data/src/core/ext/upb-gen/envoy/config/core/v3/socket_option.upb.h +6 -6
  215. data/src/core/ext/upb-gen/envoy/config/core/v3/socket_option.upb_minitable.c +6 -0
  216. data/src/core/ext/upb-gen/envoy/config/core/v3/substitution_format_string.upb.h +7 -7
  217. data/src/core/ext/upb-gen/envoy/config/core/v3/substitution_format_string.upb_minitable.c +6 -0
  218. data/src/core/ext/upb-gen/envoy/config/core/v3/udp_socket_config.upb.h +2 -2
  219. data/src/core/ext/upb-gen/envoy/config/core/v3/udp_socket_config.upb_minitable.c +3 -0
  220. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/endpoint.upb.h +7 -7
  221. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/endpoint.upb_minitable.c +12 -0
  222. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/endpoint_components.upb.h +58 -30
  223. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/endpoint_components.upb_minitable.c +30 -7
  224. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/load_report.upb.h +237 -33
  225. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/load_report.upb_minitable.c +58 -12
  226. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/load_report.upb_minitable.h +1 -0
  227. data/src/core/ext/upb-gen/envoy/config/listener/v3/api_listener.upb.h +1 -1
  228. data/src/core/ext/upb-gen/envoy/config/listener/v3/api_listener.upb_minitable.c +3 -0
  229. data/src/core/ext/upb-gen/envoy/config/listener/v3/listener.upb.h +59 -43
  230. data/src/core/ext/upb-gen/envoy/config/listener/v3/listener.upb_minitable.c +37 -6
  231. data/src/core/ext/upb-gen/envoy/config/listener/v3/listener_components.upb.h +25 -25
  232. data/src/core/ext/upb-gen/envoy/config/listener/v3/listener_components.upb_minitable.c +21 -0
  233. data/src/core/ext/upb-gen/envoy/config/listener/v3/quic_config.upb.h +66 -9
  234. data/src/core/ext/upb-gen/envoy/config/listener/v3/quic_config.upb_minitable.c +10 -3
  235. data/src/core/ext/upb-gen/envoy/config/listener/v3/udp_listener_config.upb.h +3 -3
  236. data/src/core/ext/upb-gen/envoy/config/listener/v3/udp_listener_config.upb_minitable.c +6 -0
  237. data/src/core/ext/upb-gen/envoy/config/metrics/v3/metrics_service.upb.h +5 -5
  238. data/src/core/ext/upb-gen/envoy/config/metrics/v3/metrics_service.upb_minitable.c +3 -0
  239. data/src/core/ext/upb-gen/envoy/config/metrics/v3/stats.upb.h +18 -18
  240. data/src/core/ext/upb-gen/envoy/config/metrics/v3/stats.upb_minitable.c +24 -0
  241. data/src/core/ext/upb-gen/envoy/config/overload/v3/overload.upb.h +17 -17
  242. data/src/core/ext/upb-gen/envoy/config/overload/v3/overload.upb_minitable.c +30 -0
  243. data/src/core/ext/upb-gen/envoy/config/rbac/v3/rbac.upb.h +63 -34
  244. data/src/core/ext/upb-gen/envoy/config/rbac/v3/rbac.upb_minitable.c +39 -4
  245. data/src/core/ext/upb-gen/envoy/config/route/v3/route.upb.h +9 -9
  246. data/src/core/ext/upb-gen/envoy/config/route/v3/route.upb_minitable.c +9 -0
  247. data/src/core/ext/upb-gen/envoy/config/route/v3/route_components.upb.h +273 -229
  248. data/src/core/ext/upb-gen/envoy/config/route/v3/route_components.upb_minitable.c +191 -14
  249. data/src/core/ext/upb-gen/envoy/config/route/v3/scoped_route.upb.h +6 -6
  250. data/src/core/ext/upb-gen/envoy/config/route/v3/scoped_route.upb_minitable.c +9 -0
  251. data/src/core/ext/upb-gen/envoy/config/tap/v3/common.upb.h +31 -31
  252. data/src/core/ext/upb-gen/envoy/config/tap/v3/common.upb_minitable.c +36 -0
  253. data/src/core/ext/upb-gen/envoy/config/trace/v3/datadog.upb.h +109 -12
  254. data/src/core/ext/upb-gen/envoy/config/trace/v3/datadog.upb_minitable.c +38 -11
  255. data/src/core/ext/upb-gen/envoy/config/trace/v3/datadog.upb_minitable.h +1 -0
  256. data/src/core/ext/upb-gen/envoy/config/trace/v3/dynamic_ot.upb.h +2 -2
  257. data/src/core/ext/upb-gen/envoy/config/trace/v3/dynamic_ot.upb_minitable.c +3 -0
  258. data/src/core/ext/upb-gen/envoy/config/trace/v3/http_tracer.upb.h +3 -3
  259. data/src/core/ext/upb-gen/envoy/config/trace/v3/http_tracer.upb_minitable.c +6 -0
  260. data/src/core/ext/upb-gen/envoy/config/trace/v3/lightstep.upb.h +3 -3
  261. data/src/core/ext/upb-gen/envoy/config/trace/v3/lightstep.upb_minitable.c +3 -0
  262. data/src/core/ext/upb-gen/envoy/config/trace/v3/opencensus.upb.h +11 -11
  263. data/src/core/ext/upb-gen/envoy/config/trace/v3/opencensus.upb_minitable.c +3 -0
  264. data/src/core/ext/upb-gen/envoy/config/trace/v3/opentelemetry.upb.h +4 -4
  265. data/src/core/ext/upb-gen/envoy/config/trace/v3/opentelemetry.upb_minitable.c +3 -0
  266. data/src/core/ext/upb-gen/envoy/config/trace/v3/service.upb.h +1 -1
  267. data/src/core/ext/upb-gen/envoy/config/trace/v3/service.upb_minitable.c +3 -0
  268. data/src/core/ext/upb-gen/envoy/config/trace/v3/skywalking.upb.h +6 -6
  269. data/src/core/ext/upb-gen/envoy/config/trace/v3/skywalking.upb_minitable.c +6 -0
  270. data/src/core/ext/upb-gen/envoy/config/trace/v3/xray.upb.h +6 -6
  271. data/src/core/ext/upb-gen/envoy/config/trace/v3/xray.upb_minitable.c +6 -0
  272. data/src/core/ext/upb-gen/envoy/config/trace/v3/zipkin.upb.h +7 -7
  273. data/src/core/ext/upb-gen/envoy/config/trace/v3/zipkin.upb_minitable.c +3 -0
  274. data/src/core/ext/upb-gen/envoy/data/accesslog/v3/accesslog.upb.h +114 -98
  275. data/src/core/ext/upb-gen/envoy/data/accesslog/v3/accesslog.upb_minitable.c +52 -3
  276. data/src/core/ext/upb-gen/envoy/extensions/clusters/aggregate/v3/cluster.upb_minitable.c +3 -0
  277. data/src/core/ext/upb-gen/envoy/extensions/filters/common/fault/v3/fault.upb.h +7 -7
  278. data/src/core/ext/upb-gen/envoy/extensions/filters/common/fault/v3/fault.upb_minitable.c +15 -0
  279. data/src/core/ext/upb-gen/envoy/extensions/filters/http/fault/v3/fault.upb.h +18 -18
  280. data/src/core/ext/upb-gen/envoy/extensions/filters/http/fault/v3/fault.upb_minitable.c +9 -0
  281. data/src/core/ext/upb-gen/envoy/extensions/filters/http/rbac/v3/rbac.upb.h +41 -9
  282. data/src/core/ext/upb-gen/envoy/extensions/filters/http/rbac/v3/rbac.upb_minitable.c +15 -3
  283. data/src/core/ext/upb-gen/envoy/extensions/filters/http/router/v3/router.upb.h +8 -8
  284. data/src/core/ext/upb-gen/envoy/extensions/filters/http/router/v3/router.upb_minitable.c +6 -0
  285. data/src/core/ext/upb-gen/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upb.h +4 -4
  286. data/src/core/ext/upb-gen/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upb_minitable.c +6 -0
  287. data/src/core/ext/upb-gen/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.h +146 -130
  288. data/src/core/ext/upb-gen/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb_minitable.c +74 -10
  289. data/src/core/ext/upb-gen/envoy/extensions/http/stateful_session/cookie/v3/cookie.upb.h +1 -1
  290. data/src/core/ext/upb-gen/envoy/extensions/http/stateful_session/cookie/v3/cookie.upb_minitable.c +3 -0
  291. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/client_side_weighted_round_robin/v3/client_side_weighted_round_robin.upb.h +6 -6
  292. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/client_side_weighted_round_robin/v3/client_side_weighted_round_robin.upb_minitable.c +3 -0
  293. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/common/v3/common.upb.h +10 -10
  294. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/common/v3/common.upb_minitable.c +15 -0
  295. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/pick_first/v3/pick_first.upb.h +1 -1
  296. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/pick_first/v3/pick_first.upb_minitable.c +3 -0
  297. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/ring_hash/v3/ring_hash.upb.h +7 -7
  298. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/ring_hash/v3/ring_hash.upb_minitable.c +3 -0
  299. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/wrr_locality/v3/wrr_locality.upb.h +1 -1
  300. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/wrr_locality/v3/wrr_locality.upb_minitable.c +3 -0
  301. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/common.upb.h +111 -27
  302. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/common.upb_minitable.c +43 -7
  303. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/common.upb_minitable.h +1 -0
  304. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/secret.upb.h +8 -8
  305. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/secret.upb_minitable.c +9 -0
  306. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/tls.upb.h +35 -35
  307. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/tls.upb_minitable.c +21 -0
  308. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upb.h +2 -2
  309. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upb_minitable.c +6 -0
  310. data/src/core/ext/upb-gen/envoy/extensions/upstreams/http/v3/http_protocol_options.upb.h +16 -16
  311. data/src/core/ext/upb-gen/envoy/extensions/upstreams/http/v3/http_protocol_options.upb_minitable.c +12 -0
  312. data/src/core/ext/upb-gen/envoy/service/discovery/v3/ads.upb_minitable.c +3 -0
  313. data/src/core/ext/upb-gen/envoy/service/discovery/v3/discovery.upb.h +36 -36
  314. data/src/core/ext/upb-gen/envoy/service/discovery/v3/discovery.upb_minitable.c +42 -0
  315. data/src/core/ext/upb-gen/envoy/service/load_stats/v3/lrs.upb.h +4 -4
  316. data/src/core/ext/upb-gen/envoy/service/load_stats/v3/lrs.upb_minitable.c +6 -0
  317. data/src/core/ext/upb-gen/envoy/service/status/v3/csds.upb.h +20 -20
  318. data/src/core/ext/upb-gen/envoy/service/status/v3/csds.upb_minitable.c +15 -0
  319. data/src/core/ext/upb-gen/envoy/type/http/v3/cookie.upb.h +3 -3
  320. data/src/core/ext/upb-gen/envoy/type/http/v3/cookie.upb_minitable.c +3 -0
  321. data/src/core/ext/upb-gen/envoy/type/http/v3/path_transformation.upb.h +2 -2
  322. data/src/core/ext/upb-gen/envoy/type/http/v3/path_transformation.upb_minitable.c +12 -0
  323. data/src/core/ext/upb-gen/envoy/type/matcher/v3/filter_state.upb.h +2 -2
  324. data/src/core/ext/upb-gen/envoy/type/matcher/v3/filter_state.upb_minitable.c +3 -0
  325. data/src/core/ext/upb-gen/envoy/type/matcher/v3/http_inputs.upb.h +5 -5
  326. data/src/core/ext/upb-gen/envoy/type/matcher/v3/http_inputs.upb_minitable.c +15 -0
  327. data/src/core/ext/upb-gen/envoy/type/matcher/v3/metadata.upb.h +4 -4
  328. data/src/core/ext/upb-gen/envoy/type/matcher/v3/metadata.upb_minitable.c +6 -0
  329. data/src/core/ext/upb-gen/envoy/type/matcher/v3/node.upb.h +1 -1
  330. data/src/core/ext/upb-gen/envoy/type/matcher/v3/node.upb_minitable.c +3 -0
  331. data/src/core/ext/upb-gen/envoy/type/matcher/v3/number.upb.h +2 -2
  332. data/src/core/ext/upb-gen/envoy/type/matcher/v3/number.upb_minitable.c +3 -0
  333. data/src/core/ext/upb-gen/envoy/type/matcher/v3/path.upb.h +1 -1
  334. data/src/core/ext/upb-gen/envoy/type/matcher/v3/path.upb_minitable.c +3 -0
  335. data/src/core/ext/upb-gen/envoy/type/matcher/v3/regex.upb.h +5 -5
  336. data/src/core/ext/upb-gen/envoy/type/matcher/v3/regex.upb_minitable.c +9 -0
  337. data/src/core/ext/upb-gen/envoy/type/matcher/v3/status_code_input.upb_minitable.c +6 -0
  338. data/src/core/ext/upb-gen/envoy/type/matcher/v3/string.upb.h +37 -6
  339. data/src/core/ext/upb-gen/envoy/type/matcher/v3/string.upb_minitable.c +20 -3
  340. data/src/core/ext/upb-gen/envoy/type/matcher/v3/struct.upb.h +2 -2
  341. data/src/core/ext/upb-gen/envoy/type/matcher/v3/struct.upb_minitable.c +6 -0
  342. data/src/core/ext/upb-gen/envoy/type/matcher/v3/value.upb.h +8 -8
  343. data/src/core/ext/upb-gen/envoy/type/matcher/v3/value.upb_minitable.c +12 -0
  344. data/src/core/ext/upb-gen/envoy/type/metadata/v3/metadata.upb.h +6 -6
  345. data/src/core/ext/upb-gen/envoy/type/metadata/v3/metadata.upb_minitable.c +21 -0
  346. data/src/core/ext/upb-gen/envoy/type/tracing/v3/custom_tag.upb.h +13 -13
  347. data/src/core/ext/upb-gen/envoy/type/tracing/v3/custom_tag.upb_minitable.c +15 -0
  348. data/src/core/ext/upb-gen/envoy/type/v3/hash_policy.upb.h +3 -3
  349. data/src/core/ext/upb-gen/envoy/type/v3/hash_policy.upb_minitable.c +9 -0
  350. data/src/core/ext/upb-gen/envoy/type/v3/http_status.upb.h +1 -1
  351. data/src/core/ext/upb-gen/envoy/type/v3/http_status.upb_minitable.c +3 -0
  352. data/src/core/ext/upb-gen/envoy/type/v3/percent.upb.h +3 -3
  353. data/src/core/ext/upb-gen/envoy/type/v3/percent.upb_minitable.c +6 -0
  354. data/src/core/ext/upb-gen/envoy/type/v3/range.upb.h +6 -6
  355. data/src/core/ext/upb-gen/envoy/type/v3/range.upb_minitable.c +9 -0
  356. data/src/core/ext/upb-gen/envoy/type/v3/ratelimit_strategy.upb.h +5 -5
  357. data/src/core/ext/upb-gen/envoy/type/v3/ratelimit_strategy.upb_minitable.c +6 -0
  358. data/src/core/ext/upb-gen/envoy/type/v3/semantic_version.upb.h +3 -3
  359. data/src/core/ext/upb-gen/envoy/type/v3/semantic_version.upb_minitable.c +3 -0
  360. data/src/core/ext/upb-gen/envoy/type/v3/token_bucket.upb.h +3 -3
  361. data/src/core/ext/upb-gen/envoy/type/v3/token_bucket.upb_minitable.c +3 -0
  362. data/src/core/ext/upb-gen/google/api/annotations.upb.h +10 -1
  363. data/src/core/ext/upb-gen/google/api/expr/v1alpha1/checked.upb.h +32 -32
  364. data/src/core/ext/upb-gen/google/api/expr/v1alpha1/checked.upb_minitable.c +39 -0
  365. data/src/core/ext/upb-gen/google/api/expr/v1alpha1/syntax.upb.h +43 -43
  366. data/src/core/ext/upb-gen/google/api/expr/v1alpha1/syntax.upb_minitable.c +42 -0
  367. data/src/core/ext/upb-gen/google/api/http.upb.h +12 -12
  368. data/src/core/ext/upb-gen/google/api/http.upb_minitable.c +9 -0
  369. data/src/core/ext/upb-gen/google/api/httpbody.upb.h +2 -2
  370. data/src/core/ext/upb-gen/google/api/httpbody.upb_minitable.c +3 -0
  371. data/src/core/ext/upb-gen/google/protobuf/any.upb.h +2 -2
  372. data/src/core/ext/upb-gen/google/protobuf/any.upb_minitable.c +3 -0
  373. data/src/core/ext/upb-gen/google/protobuf/descriptor.upb.h +381 -177
  374. data/src/core/ext/upb-gen/google/protobuf/descriptor.upb_minitable.c +148 -22
  375. data/src/core/ext/upb-gen/google/protobuf/descriptor.upb_minitable.h +1 -0
  376. data/src/core/ext/upb-gen/google/protobuf/duration.upb.h +2 -2
  377. data/src/core/ext/upb-gen/google/protobuf/duration.upb_minitable.c +3 -0
  378. data/src/core/ext/upb-gen/google/protobuf/empty.upb_minitable.c +3 -0
  379. data/src/core/ext/upb-gen/google/protobuf/struct.upb.h +6 -6
  380. data/src/core/ext/upb-gen/google/protobuf/struct.upb_minitable.c +12 -0
  381. data/src/core/ext/upb-gen/google/protobuf/timestamp.upb.h +2 -2
  382. data/src/core/ext/upb-gen/google/protobuf/timestamp.upb_minitable.c +3 -0
  383. data/src/core/ext/upb-gen/google/protobuf/wrappers.upb.h +9 -9
  384. data/src/core/ext/upb-gen/google/protobuf/wrappers.upb_minitable.c +27 -0
  385. data/src/core/ext/upb-gen/google/rpc/status.upb.h +2 -2
  386. data/src/core/ext/upb-gen/google/rpc/status.upb_minitable.c +3 -0
  387. data/src/core/ext/upb-gen/opencensus/proto/trace/v1/trace_config.upb.h +10 -10
  388. data/src/core/ext/upb-gen/opencensus/proto/trace/v1/trace_config.upb_minitable.c +12 -0
  389. data/src/core/ext/upb-gen/src/proto/grpc/gcp/altscontext.upb.h +6 -6
  390. data/src/core/ext/upb-gen/src/proto/grpc/gcp/altscontext.upb_minitable.c +6 -0
  391. data/src/core/ext/upb-gen/src/proto/grpc/gcp/handshaker.upb.h +35 -35
  392. data/src/core/ext/upb-gen/src/proto/grpc/gcp/handshaker.upb_minitable.c +36 -0
  393. data/src/core/ext/upb-gen/src/proto/grpc/gcp/transport_security_common.upb.h +4 -4
  394. data/src/core/ext/upb-gen/src/proto/grpc/gcp/transport_security_common.upb_minitable.c +6 -0
  395. data/src/core/ext/upb-gen/src/proto/grpc/health/v1/health.upb.h +2 -2
  396. data/src/core/ext/upb-gen/src/proto/grpc/health/v1/health.upb_minitable.c +6 -0
  397. data/src/core/ext/upb-gen/src/proto/grpc/lb/v1/load_balancer.upb.h +18 -18
  398. data/src/core/ext/upb-gen/src/proto/grpc/lb/v1/load_balancer.upb_minitable.c +27 -0
  399. data/src/core/ext/upb-gen/src/proto/grpc/lookup/v1/rls.upb.h +4 -4
  400. data/src/core/ext/upb-gen/src/proto/grpc/lookup/v1/rls.upb_minitable.c +9 -0
  401. data/src/core/ext/upb-gen/src/proto/grpc/lookup/v1/rls_config.upb.h +15 -15
  402. data/src/core/ext/upb-gen/src/proto/grpc/lookup/v1/rls_config.upb_minitable.c +27 -0
  403. data/src/core/ext/upb-gen/udpa/annotations/migrate.upb.h +54 -9
  404. data/src/core/ext/upb-gen/udpa/annotations/migrate.upb_minitable.c +9 -0
  405. data/src/core/ext/upb-gen/udpa/annotations/security.upb.h +12 -3
  406. data/src/core/ext/upb-gen/udpa/annotations/security.upb_minitable.c +3 -0
  407. data/src/core/ext/upb-gen/udpa/annotations/sensitive.upb.h +1 -1
  408. data/src/core/ext/upb-gen/udpa/annotations/status.upb.h +12 -3
  409. data/src/core/ext/upb-gen/udpa/annotations/status.upb_minitable.c +3 -0
  410. data/src/core/ext/upb-gen/udpa/annotations/versioning.upb.h +11 -2
  411. data/src/core/ext/upb-gen/udpa/annotations/versioning.upb_minitable.c +3 -0
  412. data/src/core/ext/upb-gen/validate/validate.upb.h +175 -166
  413. data/src/core/ext/upb-gen/validate/validate.upb_minitable.c +69 -0
  414. data/src/core/ext/upb-gen/xds/annotations/v3/migrate.upb.h +54 -9
  415. data/src/core/ext/upb-gen/xds/annotations/v3/migrate.upb_minitable.c +9 -0
  416. data/src/core/ext/upb-gen/xds/annotations/v3/security.upb.h +12 -3
  417. data/src/core/ext/upb-gen/xds/annotations/v3/security.upb_minitable.c +3 -0
  418. data/src/core/ext/upb-gen/xds/annotations/v3/sensitive.upb.h +1 -1
  419. data/src/core/ext/upb-gen/xds/annotations/v3/status.upb.h +35 -8
  420. data/src/core/ext/upb-gen/xds/annotations/v3/status.upb_minitable.c +12 -0
  421. data/src/core/ext/upb-gen/xds/annotations/v3/versioning.upb.h +11 -2
  422. data/src/core/ext/upb-gen/xds/annotations/v3/versioning.upb_minitable.c +3 -0
  423. data/src/core/ext/upb-gen/xds/core/v3/authority.upb.h +1 -1
  424. data/src/core/ext/upb-gen/xds/core/v3/authority.upb_minitable.c +3 -0
  425. data/src/core/ext/upb-gen/xds/core/v3/cidr.upb.h +2 -2
  426. data/src/core/ext/upb-gen/xds/core/v3/cidr.upb_minitable.c +3 -0
  427. data/src/core/ext/upb-gen/xds/core/v3/collection_entry.upb.h +5 -5
  428. data/src/core/ext/upb-gen/xds/core/v3/collection_entry.upb_minitable.c +6 -0
  429. data/src/core/ext/upb-gen/xds/core/v3/context_params.upb_minitable.c +6 -0
  430. data/src/core/ext/upb-gen/xds/core/v3/extension.upb.h +2 -2
  431. data/src/core/ext/upb-gen/xds/core/v3/extension.upb_minitable.c +3 -0
  432. data/src/core/ext/upb-gen/xds/core/v3/resource.upb.h +3 -3
  433. data/src/core/ext/upb-gen/xds/core/v3/resource.upb_minitable.c +3 -0
  434. data/src/core/ext/upb-gen/xds/core/v3/resource_locator.upb.h +7 -7
  435. data/src/core/ext/upb-gen/xds/core/v3/resource_locator.upb_minitable.c +6 -0
  436. data/src/core/ext/upb-gen/xds/core/v3/resource_name.upb.h +4 -4
  437. data/src/core/ext/upb-gen/xds/core/v3/resource_name.upb_minitable.c +3 -0
  438. data/src/core/ext/upb-gen/xds/data/orca/v3/orca_load_report.upb.h +6 -6
  439. data/src/core/ext/upb-gen/xds/data/orca/v3/orca_load_report.upb_minitable.c +12 -0
  440. data/src/core/ext/upb-gen/xds/service/orca/v3/orca.upb.h +1 -1
  441. data/src/core/ext/upb-gen/xds/service/orca/v3/orca.upb_minitable.c +3 -0
  442. data/src/core/ext/upb-gen/xds/type/matcher/v3/cel.upb.h +2 -2
  443. data/src/core/ext/upb-gen/xds/type/matcher/v3/cel.upb_minitable.c +3 -0
  444. data/src/core/ext/upb-gen/xds/type/matcher/v3/domain.upb.h +1 -1
  445. data/src/core/ext/upb-gen/xds/type/matcher/v3/domain.upb_minitable.c +6 -0
  446. data/src/core/ext/upb-gen/xds/type/matcher/v3/http_inputs.upb_minitable.c +3 -0
  447. data/src/core/ext/upb-gen/xds/type/matcher/v3/ip.upb.h +2 -2
  448. data/src/core/ext/upb-gen/xds/type/matcher/v3/ip.upb_minitable.c +6 -0
  449. data/src/core/ext/upb-gen/xds/type/matcher/v3/matcher.upb.h +18 -18
  450. data/src/core/ext/upb-gen/xds/type/matcher/v3/matcher.upb_minitable.c +30 -0
  451. data/src/core/ext/upb-gen/xds/type/matcher/v3/range.upb.h +3 -3
  452. data/src/core/ext/upb-gen/xds/type/matcher/v3/range.upb_minitable.c +18 -0
  453. data/src/core/ext/upb-gen/xds/type/matcher/v3/regex.upb.h +2 -2
  454. data/src/core/ext/upb-gen/xds/type/matcher/v3/regex.upb_minitable.c +6 -0
  455. data/src/core/ext/upb-gen/xds/type/matcher/v3/string.upb.h +6 -6
  456. data/src/core/ext/upb-gen/xds/type/matcher/v3/string.upb_minitable.c +6 -0
  457. data/src/core/ext/upb-gen/xds/type/v3/cel.upb.h +4 -4
  458. data/src/core/ext/upb-gen/xds/type/v3/cel.upb_minitable.c +6 -0
  459. data/src/core/ext/upb-gen/xds/type/v3/range.upb.h +6 -6
  460. data/src/core/ext/upb-gen/xds/type/v3/range.upb_minitable.c +9 -0
  461. data/src/core/ext/upb-gen/xds/type/v3/typed_struct.upb.h +2 -2
  462. data/src/core/ext/upb-gen/xds/type/v3/typed_struct.upb_minitable.c +3 -0
  463. data/src/core/ext/upbdefs-gen/envoy/admin/v3/server_info.upbdefs.c +86 -81
  464. data/src/core/ext/upbdefs-gen/envoy/config/accesslog/v3/accesslog.upbdefs.c +61 -60
  465. data/src/core/ext/upbdefs-gen/envoy/config/bootstrap/v3/bootstrap.upbdefs.c +221 -210
  466. data/src/core/ext/upbdefs-gen/envoy/config/bootstrap/v3/bootstrap.upbdefs.h +5 -0
  467. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/cluster.upbdefs.c +317 -297
  468. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/cluster.upbdefs.h +5 -0
  469. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/outlier_detection.upbdefs.c +114 -105
  470. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/base.upbdefs.c +185 -140
  471. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/base.upbdefs.h +25 -0
  472. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/config_source.upbdefs.c +10 -11
  473. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/grpc_service.upbdefs.c +173 -164
  474. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/health_check.upbdefs.c +197 -187
  475. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/protocol.upbdefs.c +229 -222
  476. data/src/core/ext/upbdefs-gen/envoy/config/endpoint/v3/endpoint_components.upbdefs.c +39 -36
  477. data/src/core/ext/upbdefs-gen/envoy/config/endpoint/v3/load_report.upbdefs.c +122 -93
  478. data/src/core/ext/upbdefs-gen/envoy/config/endpoint/v3/load_report.upbdefs.h +5 -0
  479. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/listener.upbdefs.c +41 -39
  480. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/quic_config.upbdefs.c +20 -12
  481. data/src/core/ext/upbdefs-gen/envoy/config/rbac/v3/rbac.upbdefs.c +69 -65
  482. data/src/core/ext/upbdefs-gen/envoy/config/route/v3/route_components.upbdefs.c +611 -604
  483. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/datadog.upbdefs.c +30 -20
  484. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/datadog.upbdefs.h +5 -0
  485. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/dynamic_ot.upbdefs.c +18 -17
  486. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/opencensus.upbdefs.c +62 -59
  487. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/zipkin.upbdefs.c +21 -20
  488. data/src/core/ext/upbdefs-gen/envoy/data/accesslog/v3/accesslog.upbdefs.c +145 -142
  489. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/rbac/v3/rbac.upbdefs.c +36 -33
  490. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.c +290 -288
  491. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.c +82 -75
  492. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.h +5 -0
  493. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/string.upbdefs.c +39 -33
  494. data/src/core/ext/upbdefs-gen/google/protobuf/descriptor.upbdefs.c +281 -256
  495. data/src/core/ext/upbdefs-gen/google/protobuf/descriptor.upbdefs.h +5 -0
  496. data/src/core/{lib/transport → handshaker/endpoint_info}/endpoint_info_handshaker.cc +15 -13
  497. data/src/core/{lib/transport → handshaker/endpoint_info}/endpoint_info_handshaker.h +3 -3
  498. data/src/core/handshaker/handshaker.cc +210 -0
  499. data/src/core/{lib/transport → handshaker}/handshaker.h +55 -48
  500. data/src/core/{lib/transport → handshaker}/handshaker_factory.h +19 -3
  501. data/src/core/{lib/transport → handshaker}/handshaker_registry.cc +3 -3
  502. data/src/core/{lib/transport → handshaker}/handshaker_registry.h +6 -6
  503. data/src/core/{lib/transport → handshaker/http_connect}/http_connect_handshaker.cc +112 -156
  504. data/src/core/{lib/transport → handshaker/http_connect}/http_connect_handshaker.h +3 -3
  505. data/src/core/{client_channel → handshaker/http_connect}/http_proxy_mapper.cc +29 -34
  506. data/src/core/{client_channel → handshaker/http_connect}/http_proxy_mapper.h +6 -6
  507. data/src/core/{lib/handshaker → handshaker}/proxy_mapper.h +5 -5
  508. data/src/core/{lib/handshaker → handshaker}/proxy_mapper_registry.cc +3 -3
  509. data/src/core/{lib/handshaker → handshaker}/proxy_mapper_registry.h +6 -6
  510. data/src/core/{lib/security/transport → handshaker/security}/secure_endpoint.cc +87 -72
  511. data/src/core/{lib/security/transport → handshaker/security}/secure_endpoint.h +9 -10
  512. data/src/core/{lib/security/transport → handshaker/security}/security_handshaker.cc +125 -161
  513. data/src/core/{lib/security/transport → handshaker/security}/security_handshaker.h +5 -6
  514. data/src/core/{lib/transport → handshaker/tcp_connect}/tcp_connect_handshaker.cc +45 -57
  515. data/src/core/{lib/transport → handshaker/tcp_connect}/tcp_connect_handshaker.h +3 -3
  516. data/src/core/lib/address_utils/parse_address.cc +30 -40
  517. data/src/core/lib/address_utils/parse_address.h +2 -2
  518. data/src/core/lib/address_utils/sockaddr_utils.cc +20 -15
  519. data/src/core/lib/address_utils/sockaddr_utils.h +2 -2
  520. data/src/core/lib/avl/avl.h +3 -3
  521. data/src/core/lib/backoff/backoff.cc +2 -2
  522. data/src/core/lib/backoff/backoff.h +2 -2
  523. data/src/core/lib/backoff/random_early_detection.cc +2 -2
  524. data/src/core/lib/backoff/random_early_detection.h +2 -2
  525. data/src/core/lib/channel/call_finalization.h +2 -2
  526. data/src/core/lib/channel/channel_args.cc +17 -21
  527. data/src/core/lib/channel/channel_args.h +25 -10
  528. data/src/core/lib/channel/channel_args_preconditioning.cc +2 -2
  529. data/src/core/lib/channel/channel_args_preconditioning.h +1 -2
  530. data/src/core/lib/channel/channel_stack.cc +16 -78
  531. data/src/core/lib/channel/channel_stack.h +11 -46
  532. data/src/core/lib/channel/channel_stack_builder.cc +2 -2
  533. data/src/core/lib/channel/channel_stack_builder.h +2 -7
  534. data/src/core/lib/channel/channel_stack_builder_impl.cc +1 -150
  535. data/src/core/lib/channel/channel_stack_builder_impl.h +2 -4
  536. data/src/core/lib/channel/connected_channel.cc +41 -695
  537. data/src/core/lib/channel/promise_based_filter.cc +230 -266
  538. data/src/core/lib/channel/promise_based_filter.h +224 -548
  539. data/src/core/lib/channel/status_util.cc +3 -3
  540. data/src/core/lib/channel/status_util.h +1 -2
  541. data/src/core/lib/compression/compression.cc +5 -6
  542. data/src/core/lib/compression/compression_internal.cc +3 -3
  543. data/src/core/lib/compression/compression_internal.h +1 -2
  544. data/src/core/lib/compression/message_compress.cc +15 -14
  545. data/src/core/lib/compression/message_compress.h +1 -2
  546. data/src/core/lib/config/config_vars.cc +6 -18
  547. data/src/core/lib/config/config_vars.h +3 -13
  548. data/src/core/lib/config/config_vars_non_generated.cc +2 -2
  549. data/src/core/lib/config/core_configuration.cc +9 -8
  550. data/src/core/lib/config/core_configuration.h +8 -8
  551. data/src/core/lib/config/load_config.cc +4 -4
  552. data/src/core/lib/config/load_config.h +2 -2
  553. data/src/core/lib/debug/event_log.cc +3 -3
  554. data/src/core/lib/debug/event_log.h +3 -3
  555. data/src/core/lib/debug/trace.cc +45 -63
  556. data/src/core/lib/debug/trace.h +2 -97
  557. data/src/core/lib/debug/trace_flags.cc +257 -0
  558. data/src/core/lib/debug/trace_flags.h +134 -0
  559. data/src/core/lib/debug/trace_impl.h +119 -0
  560. data/src/core/lib/event_engine/ares_resolver.cc +70 -26
  561. data/src/core/lib/event_engine/ares_resolver.h +15 -10
  562. data/src/core/lib/event_engine/cf_engine/cf_engine.cc +14 -13
  563. data/src/core/lib/event_engine/cf_engine/cfstream_endpoint.cc +32 -31
  564. data/src/core/lib/event_engine/cf_engine/dns_service_resolver.cc +19 -24
  565. data/src/core/lib/event_engine/cf_engine/dns_service_resolver.h +2 -1
  566. data/src/core/lib/event_engine/channel_args_endpoint_config.cc +1 -2
  567. data/src/core/lib/event_engine/channel_args_endpoint_config.h +1 -2
  568. data/src/core/lib/event_engine/common_closures.h +1 -2
  569. data/src/core/lib/event_engine/default_event_engine.cc +7 -9
  570. data/src/core/lib/event_engine/default_event_engine.h +1 -2
  571. data/src/core/lib/event_engine/default_event_engine_factory.cc +1 -2
  572. data/src/core/lib/event_engine/default_event_engine_factory.h +1 -2
  573. data/src/core/lib/event_engine/event_engine.cc +35 -5
  574. data/src/core/lib/event_engine/event_engine_context.h +5 -4
  575. data/src/core/lib/event_engine/extensions/can_track_errors.h +2 -2
  576. data/src/core/lib/event_engine/extensions/chaotic_good_extension.h +2 -2
  577. data/src/core/lib/event_engine/extensions/supports_fd.h +8 -2
  578. data/src/core/lib/event_engine/extensions/tcp_trace.h +43 -0
  579. data/src/core/lib/event_engine/forkable.cc +11 -11
  580. data/src/core/lib/event_engine/forkable.h +1 -13
  581. data/src/core/lib/event_engine/grpc_polled_fd.h +1 -2
  582. data/src/core/lib/event_engine/handle_containers.h +1 -2
  583. data/src/core/lib/event_engine/memory_allocator_factory.h +1 -2
  584. data/src/core/lib/event_engine/poller.h +1 -2
  585. data/src/core/lib/event_engine/posix.h +1 -2
  586. data/src/core/lib/event_engine/posix_engine/ev_epoll1_linux.cc +19 -19
  587. data/src/core/lib/event_engine/posix_engine/ev_epoll1_linux.h +1 -2
  588. data/src/core/lib/event_engine/posix_engine/ev_poll_posix.cc +11 -11
  589. data/src/core/lib/event_engine/posix_engine/ev_poll_posix.h +1 -2
  590. data/src/core/lib/event_engine/posix_engine/event_poller.h +1 -2
  591. data/src/core/lib/event_engine/posix_engine/event_poller_posix_default.cc +2 -2
  592. data/src/core/lib/event_engine/posix_engine/event_poller_posix_default.h +2 -2
  593. data/src/core/lib/event_engine/posix_engine/grpc_polled_fd_posix.h +1 -2
  594. data/src/core/lib/event_engine/posix_engine/internal_errqueue.cc +5 -5
  595. data/src/core/lib/event_engine/posix_engine/internal_errqueue.h +2 -2
  596. data/src/core/lib/event_engine/posix_engine/lockfree_event.cc +3 -3
  597. data/src/core/lib/event_engine/posix_engine/lockfree_event.h +2 -2
  598. data/src/core/lib/event_engine/posix_engine/native_posix_dns_resolver.cc +1 -1
  599. data/src/core/lib/event_engine/posix_engine/native_posix_dns_resolver.h +2 -2
  600. data/src/core/lib/event_engine/posix_engine/posix_endpoint.cc +75 -88
  601. data/src/core/lib/event_engine/posix_engine/posix_endpoint.h +14 -13
  602. data/src/core/lib/event_engine/posix_engine/posix_engine.cc +41 -38
  603. data/src/core/lib/event_engine/posix_engine/posix_engine.h +3 -2
  604. data/src/core/lib/event_engine/posix_engine/posix_engine_closure.h +1 -2
  605. data/src/core/lib/event_engine/posix_engine/posix_engine_listener.cc +20 -21
  606. data/src/core/lib/event_engine/posix_engine/posix_engine_listener.h +1 -2
  607. data/src/core/lib/event_engine/posix_engine/posix_engine_listener_utils.cc +24 -28
  608. data/src/core/lib/event_engine/posix_engine/posix_engine_listener_utils.h +1 -2
  609. data/src/core/lib/event_engine/posix_engine/tcp_socket_utils.cc +39 -30
  610. data/src/core/lib/event_engine/posix_engine/tcp_socket_utils.h +5 -3
  611. data/src/core/lib/event_engine/posix_engine/timer.cc +2 -3
  612. data/src/core/lib/event_engine/posix_engine/timer.h +1 -2
  613. data/src/core/lib/event_engine/posix_engine/timer_heap.cc +2 -2
  614. data/src/core/lib/event_engine/posix_engine/timer_heap.h +2 -2
  615. data/src/core/lib/event_engine/posix_engine/timer_manager.cc +16 -19
  616. data/src/core/lib/event_engine/posix_engine/timer_manager.h +1 -2
  617. data/src/core/lib/event_engine/posix_engine/traced_buffer_list.cc +3 -3
  618. data/src/core/lib/event_engine/posix_engine/traced_buffer_list.h +1 -2
  619. data/src/core/lib/event_engine/posix_engine/wakeup_fd_eventfd.cc +2 -2
  620. data/src/core/lib/event_engine/posix_engine/wakeup_fd_eventfd.h +2 -2
  621. data/src/core/lib/event_engine/posix_engine/wakeup_fd_pipe.cc +2 -2
  622. data/src/core/lib/event_engine/posix_engine/wakeup_fd_pipe.h +2 -2
  623. data/src/core/lib/event_engine/posix_engine/wakeup_fd_posix.h +2 -2
  624. data/src/core/lib/event_engine/posix_engine/wakeup_fd_posix_default.cc +2 -2
  625. data/src/core/lib/event_engine/posix_engine/wakeup_fd_posix_default.h +2 -2
  626. data/src/core/lib/event_engine/query_extensions.h +3 -2
  627. data/src/core/lib/event_engine/ref_counted_dns_resolver_interface.h +1 -2
  628. data/src/core/lib/event_engine/resolved_address.cc +5 -4
  629. data/src/core/lib/event_engine/resolved_address_internal.h +1 -2
  630. data/src/core/lib/event_engine/shim.cc +3 -3
  631. data/src/core/lib/event_engine/slice.cc +4 -3
  632. data/src/core/lib/event_engine/slice_buffer.cc +1 -2
  633. data/src/core/lib/event_engine/tcp_socket_utils.cc +18 -16
  634. data/src/core/lib/event_engine/tcp_socket_utils.h +1 -2
  635. data/src/core/lib/event_engine/thread_local.cc +2 -2
  636. data/src/core/lib/event_engine/thread_local.h +1 -1
  637. data/src/core/lib/event_engine/thread_pool/thread_count.cc +4 -4
  638. data/src/core/lib/event_engine/thread_pool/thread_count.h +2 -3
  639. data/src/core/lib/event_engine/thread_pool/thread_pool.h +1 -2
  640. data/src/core/lib/event_engine/thread_pool/thread_pool_factory.cc +2 -2
  641. data/src/core/lib/event_engine/thread_pool/work_stealing_thread_pool.cc +35 -38
  642. data/src/core/lib/event_engine/thread_pool/work_stealing_thread_pool.h +4 -8
  643. data/src/core/lib/event_engine/thready_event_engine/thready_event_engine.cc +48 -21
  644. data/src/core/lib/event_engine/thready_event_engine/thready_event_engine.h +5 -5
  645. data/src/core/lib/event_engine/time_util.cc +1 -2
  646. data/src/core/lib/event_engine/time_util.h +1 -2
  647. data/src/core/lib/event_engine/utils.cc +1 -2
  648. data/src/core/lib/event_engine/utils.h +1 -2
  649. data/src/core/lib/event_engine/windows/grpc_polled_fd_windows.cc +31 -30
  650. data/src/core/lib/event_engine/windows/iocp.cc +20 -17
  651. data/src/core/lib/event_engine/windows/iocp.h +1 -1
  652. data/src/core/lib/event_engine/windows/win_socket.cc +46 -34
  653. data/src/core/lib/event_engine/windows/win_socket.h +4 -5
  654. data/src/core/lib/event_engine/windows/windows_endpoint.cc +34 -33
  655. data/src/core/lib/event_engine/windows/windows_engine.cc +237 -127
  656. data/src/core/lib/event_engine/windows/windows_engine.h +136 -25
  657. data/src/core/lib/event_engine/windows/windows_listener.cc +27 -40
  658. data/src/core/lib/event_engine/work_queue/basic_work_queue.cc +2 -2
  659. data/src/core/lib/event_engine/work_queue/basic_work_queue.h +1 -2
  660. data/src/core/lib/event_engine/work_queue/work_queue.h +1 -2
  661. data/src/core/lib/experiments/config.cc +49 -21
  662. data/src/core/lib/experiments/config.h +57 -3
  663. data/src/core/lib/experiments/experiments.cc +72 -209
  664. data/src/core/lib/experiments/experiments.h +64 -97
  665. data/src/core/lib/gprpp/atomic_utils.h +2 -2
  666. data/src/core/lib/gprpp/bitset.h +4 -4
  667. data/src/core/lib/gprpp/chunked_vector.h +6 -5
  668. data/src/core/lib/gprpp/construct_destruct.h +4 -4
  669. data/src/core/lib/gprpp/crash.cc +3 -5
  670. data/src/core/lib/gprpp/crash.h +2 -2
  671. data/src/core/lib/gprpp/debug_location.h +9 -2
  672. data/src/core/lib/gprpp/directory_reader.h +2 -2
  673. data/src/core/lib/gprpp/down_cast.h +5 -5
  674. data/src/core/lib/gprpp/dual_ref_counted.h +54 -41
  675. data/src/core/lib/gprpp/dump_args.cc +54 -0
  676. data/src/core/lib/gprpp/dump_args.h +117 -0
  677. data/src/core/lib/gprpp/env.h +2 -2
  678. data/src/core/lib/gprpp/examine_stack.cc +2 -2
  679. data/src/core/lib/gprpp/examine_stack.h +2 -2
  680. data/src/core/lib/gprpp/fork.cc +1 -2
  681. data/src/core/lib/gprpp/fork.h +2 -2
  682. data/src/core/lib/gprpp/glob.cc +70 -0
  683. data/src/core/lib/gprpp/glob.h +29 -0
  684. data/src/core/lib/gprpp/host_port.cc +6 -4
  685. data/src/core/lib/gprpp/host_port.h +2 -2
  686. data/src/core/lib/gprpp/linux/env.cc +2 -2
  687. data/src/core/lib/gprpp/load_file.cc +1 -2
  688. data/src/core/lib/gprpp/load_file.h +2 -2
  689. data/src/core/lib/gprpp/manual_constructor.h +2 -2
  690. data/src/core/lib/gprpp/match.h +2 -2
  691. data/src/core/lib/gprpp/memory.h +1 -2
  692. data/src/core/lib/gprpp/mpscq.cc +2 -2
  693. data/src/core/lib/gprpp/mpscq.h +5 -4
  694. data/src/core/lib/gprpp/no_destruct.h +2 -2
  695. data/src/core/lib/gprpp/notification.h +2 -2
  696. data/src/core/lib/gprpp/orphanable.h +2 -2
  697. data/src/core/lib/gprpp/overload.h +2 -2
  698. data/src/core/lib/gprpp/per_cpu.cc +2 -3
  699. data/src/core/lib/gprpp/per_cpu.h +1 -2
  700. data/src/core/lib/gprpp/posix/directory_reader.cc +2 -2
  701. data/src/core/lib/gprpp/posix/stat.cc +8 -7
  702. data/src/core/lib/gprpp/posix/thd.cc +18 -19
  703. data/src/core/lib/gprpp/ref_counted.h +35 -26
  704. data/src/core/lib/gprpp/ref_counted_ptr.h +2 -2
  705. data/src/core/lib/gprpp/ref_counted_string.cc +1 -2
  706. data/src/core/lib/gprpp/ref_counted_string.h +2 -2
  707. data/src/core/lib/gprpp/single_set_ptr.h +9 -6
  708. data/src/core/lib/gprpp/sorted_pack.h +2 -2
  709. data/src/core/lib/gprpp/stat.h +2 -2
  710. data/src/core/lib/gprpp/status_helper.cc +15 -34
  711. data/src/core/lib/gprpp/status_helper.h +5 -33
  712. data/src/core/lib/gprpp/strerror.cc +2 -2
  713. data/src/core/lib/gprpp/strerror.h +2 -2
  714. data/src/core/lib/gprpp/sync.h +5 -5
  715. data/src/core/lib/gprpp/table.h +25 -17
  716. data/src/core/lib/gprpp/tchar.cc +2 -2
  717. data/src/core/lib/gprpp/thd.h +7 -7
  718. data/src/core/lib/gprpp/time.cc +9 -10
  719. data/src/core/lib/gprpp/time.h +16 -21
  720. data/src/core/lib/gprpp/time_averaged_stats.cc +2 -2
  721. data/src/core/lib/gprpp/time_util.cc +5 -4
  722. data/src/core/lib/gprpp/time_util.h +1 -2
  723. data/src/core/lib/gprpp/unique_type_name.h +31 -11
  724. data/src/core/lib/gprpp/uuid_v4.cc +2 -2
  725. data/src/core/lib/gprpp/uuid_v4.h +2 -2
  726. data/src/core/lib/gprpp/validation_errors.cc +12 -3
  727. data/src/core/lib/gprpp/validation_errors.h +13 -2
  728. data/src/core/lib/gprpp/windows/stat.cc +6 -5
  729. data/src/core/lib/gprpp/windows/thd.cc +7 -4
  730. data/src/core/lib/gprpp/work_serializer.cc +75 -79
  731. data/src/core/lib/gprpp/work_serializer.h +1 -2
  732. data/src/core/lib/iomgr/buffer_list.cc +5 -4
  733. data/src/core/lib/iomgr/buffer_list.h +1 -2
  734. data/src/core/lib/iomgr/call_combiner.cc +42 -66
  735. data/src/core/lib/iomgr/call_combiner.h +9 -10
  736. data/src/core/lib/iomgr/cfstream_handle.cc +14 -16
  737. data/src/core/lib/iomgr/closure.cc +2 -2
  738. data/src/core/lib/iomgr/closure.h +11 -12
  739. data/src/core/lib/iomgr/combiner.cc +37 -47
  740. data/src/core/lib/iomgr/combiner.h +1 -4
  741. data/src/core/lib/iomgr/endpoint.cc +1 -7
  742. data/src/core/lib/iomgr/endpoint.h +3 -4
  743. data/src/core/lib/iomgr/endpoint_cfstream.cc +47 -71
  744. data/src/core/lib/iomgr/endpoint_pair_posix.cc +6 -5
  745. data/src/core/lib/iomgr/endpoint_pair_windows.cc +15 -15
  746. data/src/core/lib/iomgr/error.cc +19 -27
  747. data/src/core/lib/iomgr/error.h +4 -4
  748. data/src/core/lib/iomgr/ev_apple.cc +3 -5
  749. data/src/core/lib/iomgr/ev_epoll1_linux.cc +87 -92
  750. data/src/core/lib/iomgr/ev_poll_posix.cc +61 -52
  751. data/src/core/lib/iomgr/ev_posix.cc +12 -13
  752. data/src/core/lib/iomgr/ev_posix.h +13 -10
  753. data/src/core/lib/iomgr/event_engine_shims/closure.cc +9 -10
  754. data/src/core/lib/iomgr/event_engine_shims/closure.h +1 -2
  755. data/src/core/lib/iomgr/event_engine_shims/endpoint.cc +26 -42
  756. data/src/core/lib/iomgr/event_engine_shims/endpoint.h +1 -2
  757. data/src/core/lib/iomgr/event_engine_shims/tcp_client.cc +8 -12
  758. data/src/core/lib/iomgr/event_engine_shims/tcp_client.h +1 -2
  759. data/src/core/lib/iomgr/exec_ctx.cc +13 -13
  760. data/src/core/lib/iomgr/exec_ctx.h +7 -5
  761. data/src/core/lib/iomgr/executor.cc +20 -27
  762. data/src/core/lib/iomgr/executor.h +1 -1
  763. data/src/core/lib/iomgr/fork_posix.cc +8 -10
  764. data/src/core/lib/iomgr/fork_windows.cc +3 -1
  765. data/src/core/lib/iomgr/grpc_if_nametoindex.h +2 -2
  766. data/src/core/lib/iomgr/grpc_if_nametoindex_posix.cc +2 -3
  767. data/src/core/lib/iomgr/grpc_if_nametoindex_unsupported.cc +3 -5
  768. data/src/core/lib/iomgr/internal_errqueue.cc +5 -4
  769. data/src/core/lib/iomgr/iocp_windows.cc +13 -9
  770. data/src/core/lib/iomgr/iocp_windows.h +0 -1
  771. data/src/core/lib/iomgr/iomgr.cc +14 -19
  772. data/src/core/lib/iomgr/iomgr.h +2 -2
  773. data/src/core/lib/iomgr/iomgr_internal.cc +2 -2
  774. data/src/core/lib/iomgr/iomgr_internal.h +2 -2
  775. data/src/core/lib/iomgr/iomgr_windows.cc +4 -2
  776. data/src/core/lib/iomgr/lockfree_event.cc +13 -17
  777. data/src/core/lib/iomgr/lockfree_event.h +1 -2
  778. data/src/core/lib/iomgr/polling_entity.cc +5 -5
  779. data/src/core/lib/iomgr/pollset.cc +2 -2
  780. data/src/core/lib/iomgr/pollset.h +0 -3
  781. data/src/core/lib/iomgr/pollset_set.cc +2 -2
  782. data/src/core/lib/iomgr/pollset_set_windows.cc +2 -2
  783. data/src/core/lib/iomgr/pollset_windows.cc +0 -2
  784. data/src/core/lib/iomgr/pollset_windows.h +0 -1
  785. data/src/core/lib/iomgr/python_util.h +1 -2
  786. data/src/core/lib/iomgr/resolve_address.cc +1 -2
  787. data/src/core/lib/iomgr/resolve_address.h +1 -2
  788. data/src/core/lib/iomgr/resolve_address_impl.h +2 -2
  789. data/src/core/lib/iomgr/resolve_address_posix.cc +7 -14
  790. data/src/core/lib/iomgr/resolve_address_posix.h +2 -2
  791. data/src/core/lib/iomgr/resolve_address_windows.cc +1 -1
  792. data/src/core/lib/iomgr/resolve_address_windows.h +2 -2
  793. data/src/core/lib/iomgr/resolved_address.h +2 -2
  794. data/src/core/lib/iomgr/sockaddr_utils_posix.cc +3 -1
  795. data/src/core/lib/iomgr/socket_factory_posix.cc +1 -1
  796. data/src/core/lib/iomgr/socket_factory_posix.h +1 -2
  797. data/src/core/lib/iomgr/socket_mutator.cc +2 -3
  798. data/src/core/lib/iomgr/socket_mutator.h +1 -2
  799. data/src/core/lib/iomgr/socket_utils.h +2 -2
  800. data/src/core/lib/iomgr/socket_utils_common_posix.cc +41 -46
  801. data/src/core/lib/iomgr/socket_utils_posix.cc +2 -2
  802. data/src/core/lib/iomgr/socket_utils_posix.h +1 -2
  803. data/src/core/lib/iomgr/socket_windows.cc +8 -9
  804. data/src/core/lib/iomgr/tcp_client.cc +2 -2
  805. data/src/core/lib/iomgr/tcp_client.h +1 -2
  806. data/src/core/lib/iomgr/tcp_client_cfstream.cc +11 -12
  807. data/src/core/lib/iomgr/tcp_client_posix.cc +20 -26
  808. data/src/core/lib/iomgr/tcp_client_windows.cc +9 -9
  809. data/src/core/lib/iomgr/tcp_posix.cc +129 -159
  810. data/src/core/lib/iomgr/tcp_posix.h +0 -2
  811. data/src/core/lib/iomgr/tcp_server.cc +2 -2
  812. data/src/core/lib/iomgr/tcp_server.h +1 -2
  813. data/src/core/lib/iomgr/tcp_server_posix.cc +55 -67
  814. data/src/core/lib/iomgr/tcp_server_utils_posix.h +2 -2
  815. data/src/core/lib/iomgr/tcp_server_utils_posix_common.cc +10 -12
  816. data/src/core/lib/iomgr/tcp_server_utils_posix_ifaddrs.cc +9 -8
  817. data/src/core/lib/iomgr/tcp_server_windows.cc +25 -30
  818. data/src/core/lib/iomgr/tcp_windows.cc +41 -59
  819. data/src/core/lib/iomgr/timer.cc +2 -2
  820. data/src/core/lib/iomgr/timer.h +1 -2
  821. data/src/core/lib/iomgr/timer_generic.cc +72 -84
  822. data/src/core/lib/iomgr/timer_generic.h +0 -1
  823. data/src/core/lib/iomgr/timer_heap.cc +2 -3
  824. data/src/core/lib/iomgr/timer_manager.cc +25 -39
  825. data/src/core/lib/iomgr/timer_manager.h +2 -2
  826. data/src/core/lib/iomgr/unix_sockets_posix.cc +3 -2
  827. data/src/core/lib/iomgr/unix_sockets_posix.h +1 -2
  828. data/src/core/lib/iomgr/unix_sockets_posix_noop.cc +3 -1
  829. data/src/core/lib/iomgr/vsock.cc +3 -3
  830. data/src/core/lib/iomgr/vsock.h +1 -2
  831. data/src/core/lib/iomgr/wakeup_fd_pipe.cc +3 -3
  832. data/src/core/lib/matchers/matchers.cc +2 -2
  833. data/src/core/lib/matchers/matchers.h +2 -2
  834. data/src/core/lib/promise/activity.cc +4 -3
  835. data/src/core/lib/promise/activity.h +47 -13
  836. data/src/core/lib/promise/all_ok.h +17 -10
  837. data/src/core/lib/promise/arena_promise.h +2 -2
  838. data/src/core/lib/promise/cancel_callback.h +34 -6
  839. data/src/core/lib/promise/context.h +18 -7
  840. data/src/core/lib/promise/detail/basic_seq.h +1 -2
  841. data/src/core/lib/promise/detail/join_state.h +555 -759
  842. data/src/core/lib/promise/detail/promise_factory.h +46 -29
  843. data/src/core/lib/promise/detail/promise_like.h +29 -13
  844. data/src/core/lib/promise/detail/seq_state.h +1388 -1794
  845. data/src/core/lib/promise/detail/status.h +38 -16
  846. data/src/core/lib/promise/exec_ctx_wakeup_scheduler.h +2 -2
  847. data/src/core/lib/promise/for_each.h +101 -35
  848. data/src/core/lib/promise/if.h +21 -17
  849. data/src/core/lib/promise/interceptor_list.h +21 -23
  850. data/src/core/lib/promise/latch.h +26 -31
  851. data/src/core/lib/promise/loop.h +15 -10
  852. data/src/core/lib/promise/map.h +27 -9
  853. data/src/core/lib/promise/observable.h +182 -0
  854. data/src/core/lib/promise/party.cc +94 -76
  855. data/src/core/lib/promise/party.h +83 -102
  856. data/src/core/lib/promise/pipe.h +33 -53
  857. data/src/core/lib/promise/poll.h +105 -38
  858. data/src/core/lib/promise/prioritized_race.h +2 -2
  859. data/src/core/lib/promise/promise.h +14 -7
  860. data/src/core/lib/promise/race.h +12 -7
  861. data/src/core/lib/promise/seq.h +53 -38
  862. data/src/core/lib/promise/sleep.cc +1 -2
  863. data/src/core/lib/promise/sleep.h +1 -2
  864. data/src/core/lib/promise/status_flag.h +153 -52
  865. data/src/core/lib/promise/try_join.h +38 -21
  866. data/src/core/lib/promise/try_seq.h +87 -49
  867. data/src/core/lib/resource_quota/api.cc +1 -2
  868. data/src/core/lib/resource_quota/api.h +1 -2
  869. data/src/core/lib/resource_quota/arena.cc +63 -85
  870. data/src/core/lib/resource_quota/arena.h +141 -213
  871. data/src/core/lib/resource_quota/connection_quota.cc +8 -9
  872. data/src/core/lib/resource_quota/connection_quota.h +2 -2
  873. data/src/core/lib/resource_quota/memory_quota.cc +34 -36
  874. data/src/core/lib/resource_quota/memory_quota.h +9 -9
  875. data/src/core/lib/resource_quota/periodic_update.cc +6 -5
  876. data/src/core/lib/resource_quota/periodic_update.h +2 -2
  877. data/src/core/lib/resource_quota/resource_quota.cc +2 -2
  878. data/src/core/lib/resource_quota/resource_quota.h +2 -3
  879. data/src/core/lib/resource_quota/thread_quota.cc +4 -3
  880. data/src/core/lib/resource_quota/thread_quota.h +2 -2
  881. data/src/core/lib/security/authorization/audit_logging.cc +6 -6
  882. data/src/core/lib/security/authorization/audit_logging.h +1 -2
  883. data/src/core/lib/security/authorization/authorization_engine.h +2 -2
  884. data/src/core/lib/security/authorization/authorization_policy_provider.h +2 -3
  885. data/src/core/lib/security/authorization/authorization_policy_provider_vtable.cc +2 -3
  886. data/src/core/lib/security/authorization/evaluate_args.cc +8 -11
  887. data/src/core/lib/security/authorization/evaluate_args.h +1 -2
  888. data/src/core/lib/security/authorization/grpc_authorization_engine.cc +4 -3
  889. data/src/core/lib/security/authorization/grpc_authorization_engine.h +1 -2
  890. data/src/core/lib/security/authorization/grpc_server_authz_filter.cc +22 -28
  891. data/src/core/lib/security/authorization/grpc_server_authz_filter.h +10 -8
  892. data/src/core/lib/security/authorization/matchers.cc +4 -5
  893. data/src/core/lib/security/authorization/matchers.h +2 -2
  894. data/src/core/lib/security/authorization/rbac_policy.cc +2 -2
  895. data/src/core/lib/security/authorization/rbac_policy.h +1 -2
  896. data/src/core/lib/security/authorization/stdout_logger.cc +4 -3
  897. data/src/core/lib/security/authorization/stdout_logger.h +1 -2
  898. data/src/core/lib/security/certificate_provider/certificate_provider_factory.h +4 -4
  899. data/src/core/lib/security/certificate_provider/certificate_provider_registry.cc +6 -6
  900. data/src/core/lib/security/certificate_provider/certificate_provider_registry.h +2 -2
  901. data/src/core/lib/security/context/security_context.cc +48 -44
  902. data/src/core/lib/security/context/security_context.h +33 -10
  903. data/src/core/lib/security/credentials/alts/alts_credentials.cc +1 -2
  904. data/src/core/lib/security/credentials/alts/alts_credentials.h +3 -3
  905. data/src/core/lib/security/credentials/alts/check_gcp_environment.cc +4 -3
  906. data/src/core/lib/security/credentials/alts/check_gcp_environment_no_op.cc +2 -3
  907. data/src/core/lib/security/credentials/alts/grpc_alts_credentials_client_options.cc +5 -6
  908. data/src/core/lib/security/credentials/alts/grpc_alts_credentials_options.cc +4 -5
  909. data/src/core/lib/security/credentials/alts/grpc_alts_credentials_options.h +2 -2
  910. data/src/core/lib/security/credentials/alts/grpc_alts_credentials_server_options.cc +1 -2
  911. data/src/core/lib/security/credentials/call_creds_util.cc +3 -3
  912. data/src/core/lib/security/credentials/call_creds_util.h +2 -2
  913. data/src/core/lib/security/credentials/channel_creds_registry.h +4 -4
  914. data/src/core/lib/security/credentials/channel_creds_registry_init.cc +7 -5
  915. data/src/core/lib/security/credentials/composite/composite_credentials.cc +16 -17
  916. data/src/core/lib/security/credentials/composite/composite_credentials.h +3 -3
  917. data/src/core/lib/security/credentials/credentials.cc +21 -18
  918. data/src/core/lib/security/credentials/credentials.h +5 -4
  919. data/src/core/lib/security/credentials/external/aws_external_account_credentials.cc +9 -8
  920. data/src/core/lib/security/credentials/external/aws_external_account_credentials.h +4 -4
  921. data/src/core/lib/security/credentials/external/aws_request_signer.cc +2 -2
  922. data/src/core/lib/security/credentials/external/aws_request_signer.h +2 -2
  923. data/src/core/lib/security/credentials/external/external_account_credentials.cc +16 -17
  924. data/src/core/lib/security/credentials/external/external_account_credentials.h +5 -5
  925. data/src/core/lib/security/credentials/external/file_external_account_credentials.cc +3 -4
  926. data/src/core/lib/security/credentials/external/file_external_account_credentials.h +2 -2
  927. data/src/core/lib/security/credentials/external/url_external_account_credentials.cc +8 -7
  928. data/src/core/lib/security/credentials/external/url_external_account_credentials.h +3 -3
  929. data/src/core/lib/security/credentials/fake/fake_credentials.cc +2 -2
  930. data/src/core/lib/security/credentials/fake/fake_credentials.h +3 -3
  931. data/src/core/lib/security/credentials/google_default/credentials_generic.cc +4 -5
  932. data/src/core/lib/security/credentials/google_default/google_default_credentials.cc +21 -21
  933. data/src/core/lib/security/credentials/google_default/google_default_credentials.h +3 -3
  934. data/src/core/lib/security/credentials/iam/iam_credentials.cc +8 -10
  935. data/src/core/lib/security/credentials/iam/iam_credentials.h +3 -3
  936. data/src/core/lib/security/credentials/insecure/insecure_credentials.cc +2 -2
  937. data/src/core/lib/security/credentials/insecure/insecure_credentials.h +2 -2
  938. data/src/core/lib/security/credentials/jwt/json_token.cc +19 -19
  939. data/src/core/lib/security/credentials/jwt/json_token.h +2 -3
  940. data/src/core/lib/security/credentials/jwt/jwt_credentials.cc +18 -22
  941. data/src/core/lib/security/credentials/jwt/jwt_credentials.h +3 -3
  942. data/src/core/lib/security/credentials/jwt/jwt_verifier.cc +65 -69
  943. data/src/core/lib/security/credentials/jwt/jwt_verifier.h +2 -3
  944. data/src/core/lib/security/credentials/local/local_credentials.cc +1 -2
  945. data/src/core/lib/security/credentials/local/local_credentials.h +3 -3
  946. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.cc +40 -42
  947. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.h +6 -6
  948. data/src/core/lib/security/credentials/plugin/plugin_credentials.cc +20 -28
  949. data/src/core/lib/security/credentials/plugin/plugin_credentials.h +3 -5
  950. data/src/core/lib/security/credentials/ssl/ssl_credentials.cc +44 -54
  951. data/src/core/lib/security/credentials/ssl/ssl_credentials.h +6 -4
  952. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_distributor.cc +26 -25
  953. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_distributor.h +2 -2
  954. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_match.cc +2 -2
  955. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.cc +30 -39
  956. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.h +4 -4
  957. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_verifier.cc +5 -6
  958. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_verifier.h +5 -4
  959. data/src/core/lib/security/credentials/tls/grpc_tls_credentials_options.cc +25 -26
  960. data/src/core/lib/security/credentials/tls/grpc_tls_credentials_options.h +1 -0
  961. data/src/core/lib/security/credentials/tls/grpc_tls_crl_provider.cc +5 -7
  962. data/src/core/lib/security/credentials/tls/grpc_tls_crl_provider.h +1 -2
  963. data/src/core/lib/security/credentials/tls/tls_credentials.cc +15 -18
  964. data/src/core/lib/security/credentials/tls/tls_credentials.h +2 -2
  965. data/src/core/lib/security/credentials/tls/tls_utils.cc +5 -6
  966. data/src/core/lib/security/credentials/tls/tls_utils.h +1 -2
  967. data/src/core/lib/security/credentials/xds/xds_credentials.cc +20 -16
  968. data/src/core/lib/security/credentials/xds/xds_credentials.h +3 -3
  969. data/src/core/lib/security/security_connector/alts/alts_security_connector.cc +27 -30
  970. data/src/core/lib/security/security_connector/alts/alts_security_connector.h +2 -2
  971. data/src/core/lib/security/security_connector/fake/fake_security_connector.cc +20 -17
  972. data/src/core/lib/security/security_connector/fake/fake_security_connector.h +2 -2
  973. data/src/core/lib/security/security_connector/insecure/insecure_security_connector.cc +6 -5
  974. data/src/core/lib/security/security_connector/insecure/insecure_security_connector.h +3 -3
  975. data/src/core/lib/security/security_connector/load_system_roots.h +1 -2
  976. data/src/core/lib/security/security_connector/load_system_roots_supported.cc +8 -8
  977. data/src/core/lib/security/security_connector/load_system_roots_supported.h +1 -2
  978. data/src/core/lib/security/security_connector/load_system_roots_windows.cc +1 -1
  979. data/src/core/lib/security/security_connector/local/local_security_connector.cc +19 -23
  980. data/src/core/lib/security/security_connector/local/local_security_connector.h +2 -2
  981. data/src/core/lib/security/security_connector/security_connector.cc +11 -13
  982. data/src/core/lib/security/security_connector/security_connector.h +4 -6
  983. data/src/core/lib/security/security_connector/ssl/ssl_security_connector.cc +23 -25
  984. data/src/core/lib/security/security_connector/ssl/ssl_security_connector.h +2 -2
  985. data/src/core/lib/security/security_connector/ssl_utils.cc +32 -30
  986. data/src/core/lib/security/security_connector/ssl_utils.h +1 -2
  987. data/src/core/lib/security/security_connector/tls/tls_security_connector.cc +42 -53
  988. data/src/core/lib/security/security_connector/tls/tls_security_connector.h +3 -3
  989. data/src/core/lib/security/transport/auth_filters.h +18 -13
  990. data/src/core/lib/security/transport/client_auth_filter.cc +14 -20
  991. data/src/core/lib/security/transport/server_auth_filter.cc +18 -24
  992. data/src/core/lib/security/util/json_util.cc +1 -2
  993. data/src/core/lib/security/util/json_util.h +1 -1
  994. data/src/core/lib/slice/percent_encoding.cc +4 -3
  995. data/src/core/lib/slice/slice.cc +11 -10
  996. data/src/core/lib/slice/slice.h +5 -5
  997. data/src/core/lib/slice/slice_buffer.cc +15 -14
  998. data/src/core/lib/slice/slice_buffer.h +1 -2
  999. data/src/core/lib/slice/slice_internal.h +3 -3
  1000. data/src/core/lib/slice/slice_refcount.h +7 -12
  1001. data/src/core/lib/slice/slice_string_helpers.cc +3 -3
  1002. data/src/core/lib/slice/slice_string_helpers.h +1 -2
  1003. data/src/core/lib/surface/byte_buffer.cc +1 -2
  1004. data/src/core/lib/surface/byte_buffer_reader.cc +4 -3
  1005. data/src/core/lib/surface/call.cc +179 -3962
  1006. data/src/core/lib/surface/call.h +172 -94
  1007. data/src/core/lib/surface/call_details.cc +5 -5
  1008. data/src/core/lib/surface/call_log_batch.cc +6 -8
  1009. data/src/core/lib/surface/call_test_only.h +1 -2
  1010. data/src/core/lib/surface/call_utils.cc +274 -0
  1011. data/src/core/lib/surface/call_utils.h +449 -0
  1012. data/src/core/lib/surface/channel.cc +48 -44
  1013. data/src/core/lib/surface/channel.h +12 -10
  1014. data/src/core/lib/surface/channel_create.cc +31 -13
  1015. data/src/core/lib/surface/channel_create.h +5 -4
  1016. data/src/core/lib/surface/channel_init.cc +271 -266
  1017. data/src/core/lib/surface/channel_init.h +178 -116
  1018. data/src/core/lib/surface/channel_stack_type.cc +2 -2
  1019. data/src/core/lib/surface/client_call.cc +430 -0
  1020. data/src/core/lib/surface/client_call.h +180 -0
  1021. data/src/core/lib/surface/completion_queue.cc +88 -107
  1022. data/src/core/lib/surface/completion_queue.h +1 -10
  1023. data/src/core/lib/surface/completion_queue_factory.cc +9 -8
  1024. data/src/core/lib/surface/completion_queue_factory.h +1 -2
  1025. data/src/core/lib/surface/event_string.cc +2 -2
  1026. data/src/core/lib/surface/event_string.h +1 -2
  1027. data/src/core/lib/surface/filter_stack_call.cc +1158 -0
  1028. data/src/core/lib/surface/filter_stack_call.h +369 -0
  1029. data/src/core/lib/surface/init.cc +33 -15
  1030. data/src/core/lib/surface/init_internally.cc +2 -2
  1031. data/src/core/lib/surface/lame_client.cc +11 -15
  1032. data/src/core/lib/surface/lame_client.h +8 -11
  1033. data/src/core/lib/surface/legacy_channel.cc +60 -45
  1034. data/src/core/lib/surface/legacy_channel.h +11 -21
  1035. data/src/core/lib/surface/metadata_array.cc +5 -5
  1036. data/src/core/lib/surface/server_call.cc +224 -0
  1037. data/src/core/lib/surface/server_call.h +169 -0
  1038. data/src/core/lib/surface/validate_metadata.cc +1 -2
  1039. data/src/core/lib/surface/validate_metadata.h +3 -3
  1040. data/src/core/lib/surface/version.cc +3 -4
  1041. data/src/core/lib/transport/bdp_estimator.cc +14 -16
  1042. data/src/core/lib/transport/bdp_estimator.h +11 -13
  1043. data/src/core/lib/transport/{call_size_estimator.cc → call_arena_allocator.cc} +3 -3
  1044. data/src/core/lib/transport/{call_size_estimator.h → call_arena_allocator.h} +31 -6
  1045. data/src/core/lib/transport/call_destination.h +76 -0
  1046. data/src/core/lib/transport/call_filters.cc +100 -314
  1047. data/src/core/lib/transport/call_filters.h +459 -726
  1048. data/src/core/lib/transport/call_final_info.cc +2 -2
  1049. data/src/core/lib/transport/call_final_info.h +1 -2
  1050. data/src/core/lib/transport/call_spine.cc +104 -79
  1051. data/src/core/lib/transport/call_spine.h +215 -242
  1052. data/src/core/lib/transport/call_state.cc +39 -0
  1053. data/src/core/lib/transport/call_state.h +957 -0
  1054. data/src/core/lib/transport/connectivity_state.cc +37 -37
  1055. data/src/core/lib/transport/connectivity_state.h +1 -4
  1056. data/src/core/lib/transport/error_utils.cc +1 -2
  1057. data/src/core/lib/transport/error_utils.h +1 -2
  1058. data/src/core/lib/transport/interception_chain.cc +147 -0
  1059. data/src/core/lib/transport/interception_chain.h +244 -0
  1060. data/src/core/lib/transport/message.cc +1 -2
  1061. data/src/core/lib/transport/metadata.cc +29 -5
  1062. data/src/core/lib/transport/metadata.h +37 -2
  1063. data/src/core/lib/transport/metadata_batch.cc +2 -2
  1064. data/src/core/lib/transport/metadata_batch.h +48 -5
  1065. data/src/core/lib/transport/metadata_compression_traits.h +2 -2
  1066. data/src/core/lib/transport/metadata_info.cc +2 -2
  1067. data/src/core/lib/transport/metadata_info.h +1 -1
  1068. data/src/core/lib/transport/parsed_metadata.cc +2 -2
  1069. data/src/core/lib/transport/parsed_metadata.h +1 -2
  1070. data/src/core/lib/transport/simple_slice_based_metadata.h +2 -2
  1071. data/src/core/lib/transport/status_conversion.cc +2 -2
  1072. data/src/core/lib/transport/status_conversion.h +1 -2
  1073. data/src/core/lib/transport/timeout_encoding.cc +5 -5
  1074. data/src/core/lib/transport/timeout_encoding.h +2 -2
  1075. data/src/core/lib/transport/transport.cc +4 -8
  1076. data/src/core/lib/transport/transport.h +89 -79
  1077. data/src/core/lib/transport/transport_op_string.cc +1 -2
  1078. data/src/core/lib/uri/uri_parser.cc +3 -3
  1079. data/src/core/lib/uri/uri_parser.h +2 -2
  1080. data/src/core/load_balancing/address_filtering.cc +2 -2
  1081. data/src/core/load_balancing/address_filtering.h +2 -2
  1082. data/src/core/load_balancing/backend_metric_data.h +2 -2
  1083. data/src/core/load_balancing/backend_metric_parser.cc +2 -2
  1084. data/src/core/load_balancing/backend_metric_parser.h +2 -2
  1085. data/src/core/load_balancing/child_policy_handler.cc +38 -41
  1086. data/src/core/load_balancing/child_policy_handler.h +2 -2
  1087. data/src/core/load_balancing/delegating_helper.h +2 -3
  1088. data/src/core/load_balancing/endpoint_list.cc +11 -13
  1089. data/src/core/load_balancing/endpoint_list.h +16 -10
  1090. data/src/core/load_balancing/grpclb/client_load_reporting_filter.cc +30 -32
  1091. data/src/core/load_balancing/grpclb/client_load_reporting_filter.h +23 -8
  1092. data/src/core/load_balancing/grpclb/grpclb.cc +160 -176
  1093. data/src/core/load_balancing/grpclb/grpclb_balancer_addresses.cc +3 -3
  1094. data/src/core/load_balancing/grpclb/grpclb_balancer_addresses.h +1 -2
  1095. data/src/core/load_balancing/grpclb/grpclb_client_stats.cc +1 -2
  1096. data/src/core/load_balancing/grpclb/grpclb_client_stats.h +1 -2
  1097. data/src/core/load_balancing/grpclb/load_balancer_api.cc +4 -6
  1098. data/src/core/load_balancing/grpclb/load_balancer_api.h +2 -3
  1099. data/src/core/load_balancing/health_check_client.cc +47 -57
  1100. data/src/core/load_balancing/health_check_client.h +2 -2
  1101. data/src/core/load_balancing/health_check_client_internal.h +1 -2
  1102. data/src/core/load_balancing/lb_policy.cc +7 -10
  1103. data/src/core/load_balancing/lb_policy.h +62 -27
  1104. data/src/core/load_balancing/lb_policy_factory.h +3 -3
  1105. data/src/core/load_balancing/lb_policy_registry.cc +5 -6
  1106. data/src/core/load_balancing/lb_policy_registry.h +3 -3
  1107. data/src/core/load_balancing/oob_backend_metric.cc +10 -13
  1108. data/src/core/load_balancing/oob_backend_metric.h +2 -2
  1109. data/src/core/load_balancing/oob_backend_metric_internal.h +1 -2
  1110. data/src/core/load_balancing/outlier_detection/outlier_detection.cc +122 -142
  1111. data/src/core/load_balancing/outlier_detection/outlier_detection.h +5 -5
  1112. data/src/core/load_balancing/pick_first/pick_first.cc +1212 -251
  1113. data/src/core/load_balancing/priority/priority.cc +104 -112
  1114. data/src/core/load_balancing/ring_hash/ring_hash.cc +79 -70
  1115. data/src/core/load_balancing/ring_hash/ring_hash.h +5 -5
  1116. data/src/core/load_balancing/rls/rls.cc +331 -282
  1117. data/src/core/load_balancing/round_robin/round_robin.cc +82 -73
  1118. data/src/core/load_balancing/subchannel_interface.h +5 -2
  1119. data/src/core/load_balancing/weighted_round_robin/static_stride_scheduler.cc +4 -4
  1120. data/src/core/load_balancing/weighted_round_robin/static_stride_scheduler.h +2 -2
  1121. data/src/core/load_balancing/weighted_round_robin/weighted_round_robin.cc +154 -132
  1122. data/src/core/load_balancing/weighted_target/weighted_target.cc +76 -87
  1123. data/src/core/load_balancing/weighted_target/weighted_target.h +1 -1
  1124. data/src/core/load_balancing/xds/cds.cc +47 -50
  1125. data/src/core/load_balancing/xds/xds_cluster_impl.cc +128 -103
  1126. data/src/core/load_balancing/xds/xds_cluster_manager.cc +48 -65
  1127. data/src/core/load_balancing/xds/xds_override_host.cc +114 -138
  1128. data/src/core/load_balancing/xds/xds_override_host.h +5 -5
  1129. data/src/core/load_balancing/xds/xds_wrr_locality.cc +31 -33
  1130. data/src/core/plugin_registry/grpc_plugin_registry.cc +11 -10
  1131. data/src/core/plugin_registry/grpc_plugin_registry_extra.cc +1 -2
  1132. data/src/core/resolver/binder/binder_resolver.cc +7 -6
  1133. data/src/core/resolver/dns/c_ares/dns_resolver_ares.cc +17 -8
  1134. data/src/core/resolver/dns/c_ares/dns_resolver_ares.h +2 -2
  1135. data/src/core/resolver/dns/c_ares/grpc_ares_ev_driver.h +3 -3
  1136. data/src/core/resolver/dns/c_ares/grpc_ares_ev_driver_posix.cc +4 -3
  1137. data/src/core/resolver/dns/c_ares/grpc_ares_ev_driver_windows.cc +36 -35
  1138. data/src/core/resolver/dns/c_ares/grpc_ares_wrapper.cc +33 -50
  1139. data/src/core/resolver/dns/c_ares/grpc_ares_wrapper.h +7 -12
  1140. data/src/core/resolver/dns/c_ares/grpc_ares_wrapper_posix.cc +1 -1
  1141. data/src/core/resolver/dns/c_ares/grpc_ares_wrapper_windows.cc +2 -2
  1142. data/src/core/resolver/dns/dns_resolver_plugin.cc +10 -10
  1143. data/src/core/resolver/dns/event_engine/event_engine_client_channel_resolver.cc +12 -18
  1144. data/src/core/resolver/dns/event_engine/event_engine_client_channel_resolver.h +3 -3
  1145. data/src/core/resolver/dns/event_engine/service_config_helper.cc +7 -7
  1146. data/src/core/resolver/dns/event_engine/service_config_helper.h +2 -2
  1147. data/src/core/resolver/dns/native/dns_resolver.cc +17 -20
  1148. data/src/core/resolver/endpoint_addresses.cc +5 -5
  1149. data/src/core/resolver/endpoint_addresses.h +5 -2
  1150. data/src/core/resolver/fake/fake_resolver.cc +5 -5
  1151. data/src/core/resolver/fake/fake_resolver.h +2 -3
  1152. data/src/core/resolver/google_c2p/google_c2p_resolver.cc +22 -23
  1153. data/src/core/resolver/polling_resolver.cc +35 -40
  1154. data/src/core/resolver/polling_resolver.h +1 -2
  1155. data/src/core/resolver/resolver.cc +3 -7
  1156. data/src/core/resolver/resolver.h +2 -7
  1157. data/src/core/resolver/resolver_factory.h +3 -3
  1158. data/src/core/resolver/resolver_registry.cc +11 -13
  1159. data/src/core/resolver/resolver_registry.h +3 -3
  1160. data/src/core/resolver/sockaddr/sockaddr_resolver.cc +5 -6
  1161. data/src/core/resolver/xds/xds_dependency_manager.cc +94 -84
  1162. data/src/core/resolver/xds/xds_dependency_manager.h +11 -7
  1163. data/src/core/resolver/xds/xds_resolver.cc +103 -83
  1164. data/src/core/resolver/xds/xds_resolver_attributes.h +7 -3
  1165. data/src/core/{lib/surface → server}/server.cc +376 -498
  1166. data/src/core/{lib/surface → server}/server.h +43 -26
  1167. data/src/core/{lib/channel → server}/server_call_tracer_filter.cc +19 -22
  1168. data/src/core/{lib/channel → server}/server_call_tracer_filter.h +3 -3
  1169. data/src/core/{ext/filters/server_config_selector → server}/server_config_selector.h +6 -6
  1170. data/src/core/{ext/filters/server_config_selector → server}/server_config_selector_filter.cc +45 -42
  1171. data/src/core/{ext/filters/server_config_selector → server}/server_config_selector_filter.h +3 -3
  1172. data/src/core/{lib/surface → server}/server_interface.h +6 -4
  1173. data/src/core/{ext/xds → server}/xds_channel_stack_modifier.cc +5 -5
  1174. data/src/core/{ext/xds → server}/xds_channel_stack_modifier.h +5 -6
  1175. data/src/core/{ext/xds → server}/xds_server_config_fetcher.cc +64 -70
  1176. data/src/core/service_config/service_config.h +2 -3
  1177. data/src/core/service_config/service_config_call_data.h +17 -14
  1178. data/src/core/service_config/service_config_channel_arg_filter.cc +15 -13
  1179. data/src/core/service_config/service_config_impl.cc +7 -7
  1180. data/src/core/service_config/service_config_impl.h +4 -4
  1181. data/src/core/service_config/service_config_parser.cc +4 -8
  1182. data/src/core/service_config/service_config_parser.h +3 -3
  1183. data/src/core/{lib/channel → telemetry}/call_tracer.cc +59 -35
  1184. data/src/core/{lib/channel → telemetry}/call_tracer.h +48 -11
  1185. data/src/core/{lib/debug → telemetry}/histogram_view.cc +2 -2
  1186. data/src/core/{lib/debug → telemetry}/histogram_view.h +5 -5
  1187. data/src/core/telemetry/metrics.cc +178 -0
  1188. data/src/core/telemetry/metrics.h +567 -0
  1189. data/src/core/{lib/debug → telemetry}/stats.cc +3 -3
  1190. data/src/core/{lib/debug → telemetry}/stats.h +7 -7
  1191. data/src/core/{lib/debug → telemetry}/stats_data.cc +3 -3
  1192. data/src/core/{lib/debug → telemetry}/stats_data.h +6 -6
  1193. data/src/core/{lib/channel → telemetry}/tcp_tracer.h +5 -5
  1194. data/src/core/tsi/alts/crypt/aes_gcm.cc +1 -2
  1195. data/src/core/tsi/alts/crypt/gsec.cc +1 -2
  1196. data/src/core/tsi/alts/crypt/gsec.h +1 -2
  1197. data/src/core/tsi/alts/frame_protector/alts_counter.cc +1 -2
  1198. data/src/core/tsi/alts/frame_protector/alts_counter.h +1 -2
  1199. data/src/core/tsi/alts/frame_protector/alts_crypter.cc +1 -2
  1200. data/src/core/tsi/alts/frame_protector/alts_crypter.h +1 -2
  1201. data/src/core/tsi/alts/frame_protector/alts_frame_protector.cc +13 -15
  1202. data/src/core/tsi/alts/frame_protector/alts_frame_protector.h +2 -2
  1203. data/src/core/tsi/alts/frame_protector/alts_record_protocol_crypter_common.cc +1 -2
  1204. data/src/core/tsi/alts/frame_protector/alts_record_protocol_crypter_common.h +1 -2
  1205. data/src/core/tsi/alts/frame_protector/alts_seal_privacy_integrity_crypter.cc +1 -2
  1206. data/src/core/tsi/alts/frame_protector/alts_unseal_privacy_integrity_crypter.cc +1 -2
  1207. data/src/core/tsi/alts/frame_protector/frame_handler.cc +9 -9
  1208. data/src/core/tsi/alts/frame_protector/frame_handler.h +2 -2
  1209. data/src/core/tsi/alts/handshaker/alts_handshaker_client.cc +69 -72
  1210. data/src/core/tsi/alts/handshaker/alts_handshaker_client.h +1 -2
  1211. data/src/core/tsi/alts/handshaker/alts_shared_resource.cc +5 -4
  1212. data/src/core/tsi/alts/handshaker/alts_shared_resource.h +1 -2
  1213. data/src/core/tsi/alts/handshaker/alts_tsi_handshaker.cc +59 -61
  1214. data/src/core/tsi/alts/handshaker/alts_tsi_handshaker.h +1 -2
  1215. data/src/core/tsi/alts/handshaker/alts_tsi_utils.cc +7 -5
  1216. data/src/core/tsi/alts/handshaker/alts_tsi_utils.h +1 -2
  1217. data/src/core/tsi/alts/handshaker/transport_security_common_api.cc +17 -24
  1218. data/src/core/tsi/alts/handshaker/transport_security_common_api.h +1 -2
  1219. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_integrity_only_record_protocol.cc +16 -16
  1220. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_integrity_only_record_protocol.h +2 -2
  1221. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_privacy_integrity_record_protocol.cc +12 -13
  1222. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_privacy_integrity_record_protocol.h +2 -2
  1223. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_record_protocol.h +1 -2
  1224. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_record_protocol_common.cc +15 -11
  1225. data/src/core/tsi/alts/zero_copy_frame_protector/alts_iovec_record_protocol.cc +1 -2
  1226. data/src/core/tsi/alts/zero_copy_frame_protector/alts_iovec_record_protocol.h +2 -2
  1227. data/src/core/tsi/alts/zero_copy_frame_protector/alts_zero_copy_grpc_protector.cc +12 -13
  1228. data/src/core/tsi/alts/zero_copy_frame_protector/alts_zero_copy_grpc_protector.h +2 -2
  1229. data/src/core/tsi/fake_transport_security.cc +28 -29
  1230. data/src/core/tsi/local_transport_security.cc +7 -7
  1231. data/src/core/tsi/local_transport_security.h +1 -2
  1232. data/src/core/tsi/ssl/key_logging/ssl_key_logging.cc +11 -12
  1233. data/src/core/tsi/ssl/key_logging/ssl_key_logging.h +1 -2
  1234. data/src/core/tsi/ssl/session_cache/ssl_session.h +1 -2
  1235. data/src/core/tsi/ssl/session_cache/ssl_session_cache.cc +15 -14
  1236. data/src/core/tsi/ssl/session_cache/ssl_session_cache.h +1 -2
  1237. data/src/core/tsi/ssl/session_cache/ssl_session_openssl.cc +3 -4
  1238. data/src/core/tsi/ssl_transport_security.cc +128 -117
  1239. data/src/core/tsi/ssl_transport_security.h +1 -2
  1240. data/src/core/tsi/ssl_transport_security_utils.cc +87 -31
  1241. data/src/core/tsi/ssl_transport_security_utils.h +12 -2
  1242. data/src/core/tsi/ssl_types.h +2 -2
  1243. data/src/core/tsi/transport_security.cc +1 -6
  1244. data/src/core/tsi/transport_security.h +2 -4
  1245. data/src/core/tsi/transport_security_grpc.cc +2 -2
  1246. data/src/core/tsi/transport_security_grpc.h +1 -2
  1247. data/src/core/tsi/transport_security_interface.h +2 -6
  1248. data/src/core/{lib/gpr → util}/alloc.cc +3 -1
  1249. data/src/core/{lib/gpr → util}/alloc.h +3 -3
  1250. data/src/core/{lib/gpr → util}/android/log.cc +0 -31
  1251. data/src/core/{lib/gpr → util}/atm.cc +1 -1
  1252. data/src/core/{ext/gcp/metadata_query.cc → util/gcp_metadata_query.cc} +26 -26
  1253. data/src/core/{ext/gcp/metadata_query.h → util/gcp_metadata_query.h} +9 -9
  1254. data/src/core/{lib/http → util/http_client}/format_request.cc +2 -2
  1255. data/src/core/{lib/http → util/http_client}/format_request.h +4 -4
  1256. data/src/core/{lib/http → util/http_client}/httpcli.cc +31 -44
  1257. data/src/core/{lib/http → util/http_client}/httpcli.h +8 -9
  1258. data/src/core/{lib/http → util/http_client}/httpcli_security_connector.cc +10 -10
  1259. data/src/core/{lib/http → util/http_client}/httpcli_ssl_credentials.h +3 -3
  1260. data/src/core/{lib/http → util/http_client}/parser.cc +9 -10
  1261. data/src/core/{lib/http → util/http_client}/parser.h +3 -5
  1262. data/src/core/{lib → util}/json/json.h +3 -3
  1263. data/src/core/{lib → util}/json/json_args.h +3 -3
  1264. data/src/core/{lib → util}/json/json_channel_args.h +4 -4
  1265. data/src/core/{lib → util}/json/json_object_loader.cc +1 -1
  1266. data/src/core/{lib → util}/json/json_object_loader.h +5 -5
  1267. data/src/core/{lib → util}/json/json_reader.cc +4 -3
  1268. data/src/core/{lib → util}/json/json_reader.h +4 -4
  1269. data/src/core/{lib → util}/json/json_util.cc +3 -3
  1270. data/src/core/{lib → util}/json/json_util.h +4 -4
  1271. data/src/core/{lib → util}/json/json_writer.cc +1 -1
  1272. data/src/core/{lib → util}/json/json_writer.h +4 -4
  1273. data/src/core/util/latent_see.cc +113 -0
  1274. data/src/core/util/latent_see.h +214 -0
  1275. data/src/core/{lib/gpr → util}/linux/cpu.cc +8 -7
  1276. data/src/core/{lib/gpr → util}/linux/log.cc +0 -45
  1277. data/src/core/util/log.cc +149 -0
  1278. data/src/core/{lib/gpr → util}/msys/tmpfile.cc +2 -2
  1279. data/src/core/{lib/gpr → util}/posix/cpu.cc +4 -3
  1280. data/src/core/{lib/gpr → util}/posix/log.cc +0 -42
  1281. data/src/core/{lib/gpr → util}/posix/sync.cc +25 -23
  1282. data/src/core/{lib/gpr → util}/posix/time.cc +10 -7
  1283. data/src/core/{lib/gpr → util}/posix/tmpfile.cc +10 -8
  1284. data/src/core/{lib/gpr → util}/spinlock.h +3 -3
  1285. data/src/core/{lib/gpr → util}/string.cc +2 -2
  1286. data/src/core/{lib/gpr → util}/string.h +3 -3
  1287. data/src/core/{lib/gpr → util}/sync.cc +5 -3
  1288. data/src/core/{lib/gpr → util}/time.cc +10 -8
  1289. data/src/core/{lib/gpr → util}/time_precise.cc +5 -4
  1290. data/src/core/{lib/gpr → util}/time_precise.h +3 -3
  1291. data/src/core/{lib/gpr → util}/tmpfile.h +3 -3
  1292. data/src/core/{ext/xds → util}/upb_utils.h +3 -5
  1293. data/src/core/{lib/gpr → util}/useful.h +42 -47
  1294. data/src/core/{lib/gpr → util}/windows/log.cc +1 -44
  1295. data/src/core/{lib/gpr → util}/windows/string.cc +1 -1
  1296. data/src/core/{lib/gpr → util}/windows/string_util.cc +1 -1
  1297. data/src/core/{lib/gpr → util}/windows/sync.cc +3 -1
  1298. data/src/core/{lib/gpr → util}/windows/time.cc +5 -2
  1299. data/src/core/{lib/gpr → util}/windows/tmpfile.cc +1 -1
  1300. data/src/core/{ext/xds → xds/grpc}/certificate_provider_store.cc +5 -6
  1301. data/src/core/{ext/xds → xds/grpc}/certificate_provider_store.h +8 -9
  1302. data/src/core/{ext/xds → xds/grpc}/file_watcher_certificate_provider_factory.cc +5 -6
  1303. data/src/core/{ext/xds → xds/grpc}/file_watcher_certificate_provider_factory.h +7 -8
  1304. data/src/core/{ext/xds → xds/grpc}/xds_audit_logger_registry.cc +5 -4
  1305. data/src/core/{ext/xds → xds/grpc}/xds_audit_logger_registry.h +7 -7
  1306. data/src/core/{ext/xds → xds/grpc}/xds_bootstrap_grpc.cc +7 -133
  1307. data/src/core/{ext/xds → xds/grpc}/xds_bootstrap_grpc.h +15 -40
  1308. data/src/core/{ext/xds → xds/grpc}/xds_certificate_provider.cc +7 -6
  1309. data/src/core/{ext/xds → xds/grpc}/xds_certificate_provider.h +8 -7
  1310. data/src/core/{ext/xds → xds/grpc}/xds_client_grpc.cc +63 -47
  1311. data/src/core/{ext/xds → xds/grpc}/xds_client_grpc.h +10 -11
  1312. data/src/core/xds/grpc/xds_cluster.cc +80 -0
  1313. data/src/core/{ext/xds → xds/grpc}/xds_cluster.h +11 -47
  1314. data/src/core/{ext/xds/xds_cluster.cc → xds/grpc/xds_cluster_parser.cc} +22 -87
  1315. data/src/core/xds/grpc/xds_cluster_parser.h +57 -0
  1316. data/src/core/{ext/xds → xds/grpc}/xds_cluster_specifier_plugin.cc +6 -6
  1317. data/src/core/{ext/xds → xds/grpc}/xds_cluster_specifier_plugin.h +7 -7
  1318. data/src/core/xds/grpc/xds_common_types.cc +104 -0
  1319. data/src/core/{ext/xds → xds/grpc}/xds_common_types.h +11 -28
  1320. data/src/core/{ext/xds/xds_common_types.cc → xds/grpc/xds_common_types_parser.cc} +44 -86
  1321. data/src/core/xds/grpc/xds_common_types_parser.h +54 -0
  1322. data/src/core/xds/grpc/xds_endpoint.cc +97 -0
  1323. data/src/core/{ext/xds → xds/grpc}/xds_endpoint.h +7 -31
  1324. data/src/core/{ext/xds/xds_endpoint.cc → xds/grpc/xds_endpoint_parser.cc} +30 -108
  1325. data/src/core/xds/grpc/xds_endpoint_parser.h +48 -0
  1326. data/src/core/{ext/xds → xds/grpc}/xds_health_status.cc +1 -3
  1327. data/src/core/{ext/xds → xds/grpc}/xds_health_status.h +3 -5
  1328. data/src/core/{ext/xds → xds/grpc}/xds_http_fault_filter.cc +11 -7
  1329. data/src/core/{ext/xds → xds/grpc}/xds_http_fault_filter.h +9 -8
  1330. data/src/core/{ext/xds/xds_http_filters.h → xds/grpc/xds_http_filter.h} +10 -67
  1331. data/src/core/{ext/xds/xds_http_filters.cc → xds/grpc/xds_http_filter_registry.cc} +9 -9
  1332. data/src/core/xds/grpc/xds_http_filter_registry.h +98 -0
  1333. data/src/core/{ext/xds → xds/grpc}/xds_http_rbac_filter.cc +13 -10
  1334. data/src/core/{ext/xds → xds/grpc}/xds_http_rbac_filter.h +9 -8
  1335. data/src/core/{ext/xds → xds/grpc}/xds_http_stateful_session_filter.cc +13 -8
  1336. data/src/core/{ext/xds → xds/grpc}/xds_http_stateful_session_filter.h +9 -8
  1337. data/src/core/{ext/xds → xds/grpc}/xds_lb_policy_registry.cc +7 -9
  1338. data/src/core/{ext/xds → xds/grpc}/xds_lb_policy_registry.h +7 -7
  1339. data/src/core/xds/grpc/xds_listener.cc +176 -0
  1340. data/src/core/{ext/xds → xds/grpc}/xds_listener.h +9 -41
  1341. data/src/core/{ext/xds/xds_listener.cc → xds/grpc/xds_listener_parser.cc} +52 -197
  1342. data/src/core/xds/grpc/xds_listener_parser.h +60 -0
  1343. data/src/core/xds/grpc/xds_route_config.cc +282 -0
  1344. data/src/core/{ext/xds → xds/grpc}/xds_route_config.h +12 -44
  1345. data/src/core/{ext/xds/xds_route_config.cc → xds/grpc/xds_route_config_parser.cc} +55 -284
  1346. data/src/core/xds/grpc/xds_route_config_parser.h +80 -0
  1347. data/src/core/{ext/xds → xds/grpc}/xds_routing.cc +6 -6
  1348. data/src/core/{ext/xds → xds/grpc}/xds_routing.h +8 -8
  1349. data/src/core/xds/grpc/xds_server_grpc.cc +161 -0
  1350. data/src/core/xds/grpc/xds_server_grpc.h +63 -0
  1351. data/src/core/{ext/xds → xds/grpc}/xds_transport_grpc.cc +19 -20
  1352. data/src/core/{ext/xds → xds/grpc}/xds_transport_grpc.h +7 -8
  1353. data/src/core/{ext/xds → xds/xds_client}/xds_api.cc +18 -23
  1354. data/src/core/{ext/xds → xds/xds_client}/xds_api.h +7 -7
  1355. data/src/core/{ext/xds → xds/xds_client}/xds_bootstrap.cc +4 -4
  1356. data/src/core/{ext/xds → xds/xds_client}/xds_bootstrap.h +6 -6
  1357. data/src/core/{ext/xds → xds/xds_client}/xds_channel_args.h +3 -3
  1358. data/src/core/{ext/xds → xds/xds_client}/xds_client.cc +203 -238
  1359. data/src/core/{ext/xds → xds/xds_client}/xds_client.h +10 -14
  1360. data/src/core/{ext/xds → xds/xds_client}/xds_client_stats.cc +29 -31
  1361. data/src/core/{ext/xds → xds/xds_client}/xds_client_stats.h +8 -8
  1362. data/src/core/{ext/xds → xds/xds_client}/xds_metrics.h +7 -5
  1363. data/src/core/{ext/xds → xds/xds_client}/xds_resource_type.h +6 -6
  1364. data/src/core/{ext/xds → xds/xds_client}/xds_resource_type_impl.h +7 -7
  1365. data/src/core/{ext/xds → xds/xds_client}/xds_transport.h +6 -6
  1366. data/src/ruby/bin/math_pb.rb +1 -22
  1367. data/src/ruby/ext/grpc/rb_call.c +10 -3
  1368. data/src/ruby/ext/grpc/rb_call_credentials.c +2 -1
  1369. data/src/ruby/ext/grpc/rb_call_credentials.h +1 -0
  1370. data/src/ruby/ext/grpc/rb_channel.c +15 -14
  1371. data/src/ruby/ext/grpc/rb_channel_args.c +1 -1
  1372. data/src/ruby/ext/grpc/rb_channel_credentials.c +1 -0
  1373. data/src/ruby/ext/grpc/rb_completion_queue.c +15 -32
  1374. data/src/ruby/ext/grpc/rb_completion_queue.h +7 -1
  1375. data/src/ruby/ext/grpc/rb_compression_options.c +3 -3
  1376. data/src/ruby/ext/grpc/rb_event_thread.c +2 -2
  1377. data/src/ruby/ext/grpc/rb_grpc.c +5 -5
  1378. data/src/ruby/ext/grpc/rb_grpc.h +8 -0
  1379. data/src/ruby/ext/grpc/rb_grpc_imports.generated.c +130 -134
  1380. data/src/ruby/ext/grpc/rb_grpc_imports.generated.h +198 -203
  1381. data/src/ruby/ext/grpc/rb_server.c +40 -22
  1382. data/src/ruby/ext/grpc/rb_server_credentials.c +1 -0
  1383. data/src/ruby/ext/grpc/rb_server_credentials.h +1 -0
  1384. data/src/ruby/ext/grpc/rb_xds_channel_credentials.c +1 -0
  1385. data/src/ruby/ext/grpc/rb_xds_server_credentials.c +1 -0
  1386. data/src/ruby/ext/grpc/rb_xds_server_credentials.h +1 -0
  1387. data/src/ruby/lib/grpc/logconfig.rb +13 -0
  1388. data/src/ruby/lib/grpc/version.rb +1 -1
  1389. data/src/ruby/pb/grpc/health/v1/health_pb.rb +1 -22
  1390. data/src/ruby/pb/grpc/testing/duplicate/echo_duplicate_services_pb.rb +5 -5
  1391. data/src/ruby/pb/grpc/testing/metrics_pb.rb +10 -19
  1392. data/src/ruby/pb/grpc/testing/metrics_services_pb.rb +5 -5
  1393. data/src/ruby/pb/src/proto/grpc/testing/empty_pb.rb +1 -22
  1394. data/src/ruby/pb/src/proto/grpc/testing/messages_pb.rb +1 -22
  1395. data/src/ruby/pb/src/proto/grpc/testing/test_pb.rb +1 -22
  1396. data/src/ruby/spec/logconfig_spec.rb +30 -0
  1397. data/third_party/abseil-cpp/absl/log/check.h +209 -0
  1398. data/third_party/abseil-cpp/absl/log/internal/check_impl.h +150 -0
  1399. data/third_party/abseil-cpp/absl/log/internal/check_op.cc +118 -0
  1400. data/third_party/abseil-cpp/absl/log/internal/check_op.h +420 -0
  1401. data/third_party/boringssl-with-bazel/src/crypto/base64/base64.c +4 -0
  1402. data/third_party/boringssl-with-bazel/src/crypto/bio/bio.c +13 -18
  1403. data/third_party/boringssl-with-bazel/src/crypto/bio/file.c +25 -10
  1404. data/third_party/boringssl-with-bazel/src/crypto/bytestring/cbs.c +3 -18
  1405. data/third_party/boringssl-with-bazel/src/crypto/bytestring/unicode.c +3 -2
  1406. data/third_party/boringssl-with-bazel/src/crypto/chacha/chacha.c +1 -1
  1407. data/third_party/boringssl-with-bazel/src/crypto/chacha/internal.h +19 -15
  1408. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_chacha20poly1305.c +7 -0
  1409. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_des.c +48 -66
  1410. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_null.c +7 -3
  1411. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_rc2.c +20 -28
  1412. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_rc4.c +9 -4
  1413. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/tls_cbc.c +2 -2
  1414. data/third_party/boringssl-with-bazel/src/crypto/conf/conf.c +66 -41
  1415. data/third_party/boringssl-with-bazel/src/crypto/cpu_arm_linux.c +4 -1
  1416. data/third_party/boringssl-with-bazel/src/crypto/cpu_intel.c +0 -15
  1417. data/third_party/boringssl-with-bazel/src/crypto/crypto.c +7 -61
  1418. data/third_party/boringssl-with-bazel/src/crypto/curve25519/curve25519.c +7 -7
  1419. data/third_party/boringssl-with-bazel/src/crypto/digest_extra/digest_extra.c +1 -0
  1420. data/third_party/boringssl-with-bazel/src/crypto/dilithium/dilithium.c +1539 -0
  1421. data/third_party/boringssl-with-bazel/src/crypto/dilithium/internal.h +58 -0
  1422. data/third_party/boringssl-with-bazel/src/crypto/dsa/dsa.c +36 -20
  1423. data/third_party/boringssl-with-bazel/src/crypto/dsa/dsa_asn1.c +3 -4
  1424. data/third_party/boringssl-with-bazel/src/crypto/dsa/internal.h +2 -0
  1425. data/third_party/boringssl-with-bazel/src/crypto/err/err.c +81 -60
  1426. data/third_party/boringssl-with-bazel/src/crypto/evp/evp.c +41 -120
  1427. data/third_party/boringssl-with-bazel/src/crypto/evp/evp_asn1.c +13 -13
  1428. data/third_party/boringssl-with-bazel/src/crypto/evp/internal.h +7 -0
  1429. data/third_party/boringssl-with-bazel/src/crypto/evp/p_dh.c +137 -0
  1430. data/third_party/boringssl-with-bazel/src/crypto/evp/p_dh_asn1.c +120 -0
  1431. data/third_party/boringssl-with-bazel/src/crypto/evp/p_dsa_asn1.c +30 -0
  1432. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ec.c +3 -4
  1433. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ec_asn1.c +30 -0
  1434. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ed25519.c +1 -4
  1435. data/third_party/boringssl-with-bazel/src/crypto/evp/p_rsa_asn1.c +30 -0
  1436. data/third_party/boringssl-with-bazel/src/crypto/evp/p_x25519.c +1 -4
  1437. data/third_party/boringssl-with-bazel/src/crypto/ex_data.c +6 -7
  1438. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/aes.c +21 -0
  1439. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/internal.h +31 -7
  1440. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bcm.c +5 -2
  1441. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/bytes.c +1 -1
  1442. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/div.c +3 -3
  1443. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/div_extra.c +1 -1
  1444. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/exponentiation.c +46 -2
  1445. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/gcd_extra.c +8 -5
  1446. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/internal.h +33 -23
  1447. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/montgomery_inv.c +1 -1
  1448. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/mul.c +2 -2
  1449. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/prime.c +14 -7
  1450. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/random.c +2 -1
  1451. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/internal.h +0 -3
  1452. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/ec_key.c +11 -7
  1453. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p256-nistz.c +5 -0
  1454. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/scalar.c +5 -1
  1455. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/fips_shared_support.c +3 -6
  1456. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/fork_detect.h +2 -1
  1457. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/rsa.c +11 -11
  1458. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/rsa_impl.c +22 -8
  1459. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/self_check/fips.c +6 -4
  1460. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/service_indicator/service_indicator.c +3 -6
  1461. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/internal.h +78 -29
  1462. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/sha1.c +4 -4
  1463. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/sha256.c +3 -3
  1464. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/sha512.c +10 -4
  1465. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/tls/kdf.c +7 -0
  1466. data/third_party/boringssl-with-bazel/src/crypto/hpke/hpke.c +2 -0
  1467. data/third_party/boringssl-with-bazel/src/crypto/internal.h +62 -27
  1468. data/third_party/boringssl-with-bazel/src/crypto/kyber/internal.h +1 -1
  1469. data/third_party/boringssl-with-bazel/src/crypto/kyber/kyber.c +2 -1
  1470. data/third_party/boringssl-with-bazel/src/crypto/mem.c +18 -9
  1471. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_lib.c +18 -17
  1472. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_pk8.c +44 -41
  1473. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_pkey.c +13 -12
  1474. data/third_party/boringssl-with-bazel/src/crypto/spx/spx.c +7 -6
  1475. data/third_party/boringssl-with-bazel/src/crypto/x509/by_dir.c +26 -33
  1476. data/third_party/boringssl-with-bazel/src/crypto/x509/by_file.c +1 -1
  1477. data/third_party/boringssl-with-bazel/src/crypto/x509/internal.h +4 -5
  1478. data/third_party/boringssl-with-bazel/src/crypto/x509/rsa_pss.c +5 -1
  1479. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_cpols.c +9 -4
  1480. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_crld.c +2 -2
  1481. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_info.c +1 -1
  1482. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_lib.c +2 -0
  1483. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_utl.c +49 -16
  1484. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_lu.c +0 -10
  1485. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_trs.c +21 -25
  1486. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_vfy.c +8 -25
  1487. data/third_party/boringssl-with-bazel/src/crypto/x509/x_algor.c +2 -2
  1488. data/third_party/boringssl-with-bazel/src/crypto/x509/x_x509.c +1 -6
  1489. data/third_party/boringssl-with-bazel/{err_data.c → src/gen/crypto/err_data.c} +487 -485
  1490. data/third_party/boringssl-with-bazel/src/include/openssl/base.h +9 -1
  1491. data/third_party/boringssl-with-bazel/src/include/openssl/bio.h +85 -42
  1492. data/third_party/boringssl-with-bazel/src/include/openssl/bytestring.h +12 -4
  1493. data/third_party/boringssl-with-bazel/src/include/openssl/crypto.h +10 -11
  1494. data/third_party/boringssl-with-bazel/src/include/openssl/dh.h +17 -1
  1495. data/third_party/boringssl-with-bazel/src/include/openssl/dsa.h +10 -3
  1496. data/third_party/boringssl-with-bazel/src/include/openssl/err.h +13 -0
  1497. data/third_party/boringssl-with-bazel/src/include/openssl/evp.h +25 -14
  1498. data/third_party/boringssl-with-bazel/src/include/openssl/evp_errors.h +1 -0
  1499. data/third_party/boringssl-with-bazel/src/include/openssl/ex_data.h +15 -3
  1500. data/third_party/boringssl-with-bazel/src/include/openssl/experimental/dilithium.h +131 -0
  1501. data/third_party/boringssl-with-bazel/src/include/openssl/{kyber.h → experimental/kyber.h} +10 -0
  1502. data/third_party/boringssl-with-bazel/src/{crypto/spx/internal.h → include/openssl/experimental/spx.h} +24 -13
  1503. data/third_party/boringssl-with-bazel/src/include/openssl/obj.h +2 -2
  1504. data/third_party/boringssl-with-bazel/src/include/openssl/pem.h +63 -53
  1505. data/third_party/boringssl-with-bazel/src/include/openssl/rand.h +19 -10
  1506. data/third_party/boringssl-with-bazel/src/include/openssl/span.h +26 -12
  1507. data/third_party/boringssl-with-bazel/src/include/openssl/ssl.h +358 -102
  1508. data/third_party/boringssl-with-bazel/src/include/openssl/stack.h +10 -3
  1509. data/third_party/boringssl-with-bazel/src/include/openssl/target.h +13 -10
  1510. data/third_party/boringssl-with-bazel/src/include/openssl/tls1.h +2 -2
  1511. data/third_party/boringssl-with-bazel/src/include/openssl/x509.h +2931 -2453
  1512. data/third_party/boringssl-with-bazel/src/ssl/d1_both.cc +6 -8
  1513. data/third_party/boringssl-with-bazel/src/ssl/d1_pkt.cc +4 -4
  1514. data/third_party/boringssl-with-bazel/src/ssl/dtls_method.cc +1 -1
  1515. data/third_party/boringssl-with-bazel/src/ssl/dtls_record.cc +19 -18
  1516. data/third_party/boringssl-with-bazel/src/ssl/encrypted_client_hello.cc +3 -9
  1517. data/third_party/boringssl-with-bazel/src/ssl/extensions.cc +64 -58
  1518. data/third_party/boringssl-with-bazel/src/ssl/handoff.cc +1 -1
  1519. data/third_party/boringssl-with-bazel/src/ssl/handshake.cc +17 -7
  1520. data/third_party/boringssl-with-bazel/src/ssl/handshake_client.cc +69 -16
  1521. data/third_party/boringssl-with-bazel/src/ssl/handshake_server.cc +145 -114
  1522. data/third_party/boringssl-with-bazel/src/ssl/internal.h +243 -189
  1523. data/third_party/boringssl-with-bazel/src/ssl/s3_both.cc +1 -1
  1524. data/third_party/boringssl-with-bazel/src/ssl/s3_lib.cc +0 -1
  1525. data/third_party/boringssl-with-bazel/src/ssl/ssl_cert.cc +59 -385
  1526. data/third_party/boringssl-with-bazel/src/ssl/ssl_cipher.cc +21 -19
  1527. data/third_party/boringssl-with-bazel/src/ssl/ssl_credential.cc +423 -0
  1528. data/third_party/boringssl-with-bazel/src/ssl/ssl_file.cc +2 -2
  1529. data/third_party/boringssl-with-bazel/src/ssl/ssl_key_share.cc +2 -1
  1530. data/third_party/boringssl-with-bazel/src/ssl/ssl_lib.cc +108 -81
  1531. data/third_party/boringssl-with-bazel/src/ssl/ssl_privkey.cc +116 -93
  1532. data/third_party/boringssl-with-bazel/src/ssl/ssl_session.cc +6 -14
  1533. data/third_party/boringssl-with-bazel/src/ssl/ssl_versions.cc +1 -1
  1534. data/third_party/boringssl-with-bazel/src/ssl/ssl_x509.cc +48 -116
  1535. data/third_party/boringssl-with-bazel/src/ssl/tls13_both.cc +21 -27
  1536. data/third_party/boringssl-with-bazel/src/ssl/tls13_client.cc +36 -3
  1537. data/third_party/boringssl-with-bazel/src/ssl/tls13_server.cc +53 -18
  1538. data/third_party/boringssl-with-bazel/src/ssl/tls_record.cc +1 -1
  1539. data/third_party/upb/upb/base/string_view.h +1 -1
  1540. data/third_party/upb/upb/json/decode.c +1 -0
  1541. data/third_party/upb/upb/mem/arena.c +67 -2
  1542. data/third_party/upb/upb/mem/arena.h +11 -9
  1543. data/third_party/upb/upb/mem/internal/arena.h +11 -8
  1544. data/third_party/upb/upb/message/accessors.c +6 -5
  1545. data/third_party/upb/upb/message/accessors.h +49 -38
  1546. data/third_party/upb/upb/message/array.c +26 -3
  1547. data/third_party/upb/upb/message/array.h +17 -9
  1548. data/third_party/upb/upb/message/compat.c +5 -5
  1549. data/third_party/upb/upb/message/compat.h +3 -3
  1550. data/third_party/upb/upb/message/copy.c +12 -13
  1551. data/third_party/upb/upb/message/internal/accessors.h +45 -35
  1552. data/third_party/upb/upb/message/internal/array.h +23 -15
  1553. data/third_party/upb/upb/message/internal/compare_unknown.c +289 -0
  1554. data/third_party/upb/upb/message/internal/compare_unknown.h +49 -0
  1555. data/third_party/upb/upb/message/internal/extension.c +11 -12
  1556. data/third_party/upb/upb/message/internal/extension.h +9 -12
  1557. data/third_party/upb/upb/message/internal/map.h +15 -0
  1558. data/third_party/upb/upb/message/internal/map_sorter.h +4 -5
  1559. data/third_party/upb/upb/message/internal/message.c +20 -3
  1560. data/third_party/upb/upb/message/internal/message.h +10 -0
  1561. data/third_party/upb/upb/message/internal/tagged_ptr.h +5 -5
  1562. data/third_party/upb/upb/message/internal/types.h +41 -1
  1563. data/third_party/upb/upb/message/map.c +25 -0
  1564. data/third_party/upb/upb/message/map.h +11 -7
  1565. data/third_party/upb/upb/message/message.c +83 -4
  1566. data/third_party/upb/upb/message/message.h +20 -1
  1567. data/third_party/upb/upb/message/tagged_ptr.h +4 -8
  1568. data/third_party/upb/upb/mini_descriptor/build_enum.c +3 -3
  1569. data/third_party/upb/upb/mini_descriptor/build_enum.h +6 -14
  1570. data/third_party/upb/upb/mini_descriptor/decode.c +12 -1
  1571. data/third_party/upb/upb/mini_descriptor/link.c +16 -18
  1572. data/third_party/upb/upb/mini_table/enum.h +2 -4
  1573. data/third_party/upb/upb/mini_table/extension.h +4 -12
  1574. data/third_party/upb/upb/mini_table/field.h +12 -38
  1575. data/third_party/upb/upb/mini_table/file.h +6 -19
  1576. data/third_party/upb/upb/mini_table/internal/enum.h +1 -1
  1577. data/third_party/upb/upb/mini_table/internal/extension.h +9 -9
  1578. data/third_party/upb/upb/mini_table/internal/field.h +23 -23
  1579. data/third_party/upb/upb/mini_table/internal/file.h +7 -7
  1580. data/third_party/upb/upb/mini_table/internal/message.h +51 -27
  1581. data/third_party/upb/upb/mini_table/internal/sub.h +4 -4
  1582. data/third_party/upb/upb/mini_table/message.h +13 -22
  1583. data/third_party/upb/upb/mini_table/sub.h +4 -12
  1584. data/third_party/upb/upb/port/def.inc +12 -6
  1585. data/third_party/upb/upb/port/undef.inc +1 -1
  1586. data/third_party/upb/upb/reflection/def.hpp +27 -0
  1587. data/third_party/upb/upb/reflection/def_pool.h +2 -2
  1588. data/third_party/upb/upb/reflection/enum_def.c +5 -1
  1589. data/third_party/upb/upb/reflection/enum_def.h +1 -0
  1590. data/third_party/upb/upb/reflection/enum_value_def.c +3 -8
  1591. data/third_party/upb/upb/reflection/field_def.c +61 -24
  1592. data/third_party/upb/upb/reflection/field_def.h +3 -0
  1593. data/third_party/upb/upb/reflection/file_def.c +30 -4
  1594. data/third_party/upb/upb/reflection/file_def.h +3 -0
  1595. data/third_party/upb/upb/reflection/internal/upb_edition_defaults.h +1 -1
  1596. data/third_party/upb/upb/reflection/message.c +19 -7
  1597. data/third_party/upb/upb/reflection/message_def.c +14 -9
  1598. data/third_party/upb/upb/reflection/method_def.h +8 -7
  1599. data/third_party/upb/upb/reflection/service_def.h +6 -5
  1600. data/third_party/upb/upb/text/encode.c +10 -3
  1601. data/third_party/upb/upb/wire/decode.c +91 -57
  1602. data/third_party/upb/upb/wire/decode.h +11 -1
  1603. data/third_party/upb/upb/wire/encode.c +48 -30
  1604. data/third_party/upb/upb/wire/encode.h +9 -1
  1605. data/third_party/upb/upb/wire/eps_copy_input_stream.h +3 -3
  1606. data/third_party/upb/upb/wire/internal/decode_fast.c +25 -29
  1607. data/third_party/upb/upb/wire/internal/reader.h +3 -3
  1608. data/third_party/upb/upb/wire/reader.c +1 -2
  1609. data/third_party/upb/upb/wire/reader.h +4 -8
  1610. metadata +233 -200
  1611. data/src/core/client_channel/client_channel_channelz.cc +0 -93
  1612. data/src/core/client_channel/client_channel_channelz.h +0 -85
  1613. data/src/core/client_channel/config_selector.cc +0 -60
  1614. data/src/core/ext/filters/deadline/deadline_filter.cc +0 -407
  1615. data/src/core/ext/filters/deadline/deadline_filter.h +0 -85
  1616. data/src/core/ext/transport/chttp2/transport/http_trace.cc +0 -19
  1617. data/src/core/ext/transport/chttp2/transport/http_trace.h +0 -24
  1618. data/src/core/ext/transport/inproc/inproc_plugin.cc +0 -23
  1619. data/src/core/lib/channel/channel_stack_trace.cc +0 -19
  1620. data/src/core/lib/channel/channel_stack_trace.h +0 -24
  1621. data/src/core/lib/channel/context.h +0 -77
  1622. data/src/core/lib/channel/metrics.cc +0 -396
  1623. data/src/core/lib/channel/metrics.h +0 -406
  1624. data/src/core/lib/event_engine/trace.cc +0 -25
  1625. data/src/core/lib/event_engine/trace.h +0 -49
  1626. data/src/core/lib/gpr/log.cc +0 -166
  1627. data/src/core/lib/gpr/log_internal.h +0 -55
  1628. data/src/core/lib/iomgr/ev_windows.cc +0 -30
  1629. data/src/core/lib/promise/trace.cc +0 -20
  1630. data/src/core/lib/promise/trace.h +0 -24
  1631. data/src/core/lib/resource_quota/trace.cc +0 -19
  1632. data/src/core/lib/resource_quota/trace.h +0 -24
  1633. data/src/core/lib/security/transport/tsi_error.cc +0 -31
  1634. data/src/core/lib/security/transport/tsi_error.h +0 -30
  1635. data/src/core/lib/slice/slice_refcount.cc +0 -20
  1636. data/src/core/lib/surface/api_trace.cc +0 -25
  1637. data/src/core/lib/surface/api_trace.h +0 -53
  1638. data/src/core/lib/surface/call_trace.h +0 -24
  1639. data/src/core/lib/surface/wait_for_cq_end_op.cc +0 -75
  1640. data/src/core/lib/surface/wait_for_cq_end_op.h +0 -72
  1641. data/src/core/lib/transport/batch_builder.cc +0 -170
  1642. data/src/core/lib/transport/batch_builder.h +0 -476
  1643. data/src/core/lib/transport/handshaker.cc +0 -229
  1644. data/src/core/resolver/xds/xds_resolver_trace.cc +0 -25
  1645. data/src/core/resolver/xds/xds_resolver_trace.h +0 -30
  1646. data/third_party/boringssl-with-bazel/src/crypto/conf/conf_def.h +0 -122
  1647. data/third_party/boringssl-with-bazel/src/include/openssl/pki/certificate.h +0 -83
  1648. data/third_party/boringssl-with-bazel/src/include/openssl/pki/signature_verify_cache.h +0 -41
  1649. /data/src/core/{lib/gpr → util}/iphone/cpu.cc +0 -0
  1650. /data/src/core/{lib/gpr → util}/posix/string.cc +0 -0
  1651. /data/src/core/{lib/gpr → util}/sync_abseil.cc +0 -0
  1652. /data/src/core/{lib/gpr → util}/windows/cpu.cc +0 -0
@@ -14,8 +14,6 @@
14
14
  // limitations under the License.
15
15
  //
16
16
 
17
- #include <grpc/support/port_platform.h>
18
-
19
17
  #include "src/core/ext/transport/chttp2/transport/chttp2_transport.h"
20
18
 
21
19
  #include <inttypes.h>
@@ -36,6 +34,8 @@
36
34
  #include "absl/base/attributes.h"
37
35
  #include "absl/container/flat_hash_map.h"
38
36
  #include "absl/hash/hash.h"
37
+ #include "absl/log/check.h"
38
+ #include "absl/log/log.h"
39
39
  #include "absl/meta/type_traits.h"
40
40
  #include "absl/random/random.h"
41
41
  #include "absl/status/status.h"
@@ -53,7 +53,7 @@
53
53
  #include <grpc/slice_buffer.h>
54
54
  #include <grpc/status.h>
55
55
  #include <grpc/support/alloc.h>
56
- #include <grpc/support/log.h>
56
+ #include <grpc/support/port_platform.h>
57
57
  #include <grpc/support/time.h>
58
58
 
59
59
  #include "src/core/ext/transport/chttp2/transport/context_list_entry.h"
@@ -63,7 +63,6 @@
63
63
  #include "src/core/ext/transport/chttp2/transport/frame_rst_stream.h"
64
64
  #include "src/core/ext/transport/chttp2/transport/hpack_encoder.h"
65
65
  #include "src/core/ext/transport/chttp2/transport/http2_settings.h"
66
- #include "src/core/ext/transport/chttp2/transport/http_trace.h"
67
66
  #include "src/core/ext/transport/chttp2/transport/internal.h"
68
67
  #include "src/core/ext/transport/chttp2/transport/legacy_frame.h"
69
68
  #include "src/core/ext/transport/chttp2/transport/max_concurrent_streams_policy.h"
@@ -72,24 +71,22 @@
72
71
  #include "src/core/ext/transport/chttp2/transport/ping_rate_policy.h"
73
72
  #include "src/core/ext/transport/chttp2/transport/varint.h"
74
73
  #include "src/core/ext/transport/chttp2/transport/write_size_policy.h"
75
- #include "src/core/lib/channel/call_tracer.h"
76
74
  #include "src/core/lib/channel/channel_args.h"
77
- #include "src/core/lib/channel/context.h"
78
- #include "src/core/lib/channel/tcp_tracer.h"
79
- #include "src/core/lib/debug/stats.h"
80
- #include "src/core/lib/debug/stats_data.h"
75
+ #include "src/core/lib/config/config_vars.h"
76
+ #include "src/core/lib/event_engine/extensions/tcp_trace.h"
77
+ #include "src/core/lib/event_engine/query_extensions.h"
81
78
  #include "src/core/lib/experiments/experiments.h"
82
- #include "src/core/lib/gpr/string.h"
83
- #include "src/core/lib/gpr/useful.h"
84
79
  #include "src/core/lib/gprpp/bitset.h"
85
80
  #include "src/core/lib/gprpp/crash.h"
86
81
  #include "src/core/lib/gprpp/debug_location.h"
87
82
  #include "src/core/lib/gprpp/ref_counted.h"
88
83
  #include "src/core/lib/gprpp/status_helper.h"
89
84
  #include "src/core/lib/gprpp/time.h"
90
- #include "src/core/lib/http/parser.h"
91
85
  #include "src/core/lib/iomgr/combiner.h"
86
+ #include "src/core/lib/iomgr/endpoint.h"
92
87
  #include "src/core/lib/iomgr/error.h"
88
+ #include "src/core/lib/iomgr/ev_posix.h"
89
+ #include "src/core/lib/iomgr/event_engine_shims/endpoint.h"
93
90
  #include "src/core/lib/iomgr/exec_ctx.h"
94
91
  #include "src/core/lib/iomgr/iomgr_fwd.h"
95
92
  #include "src/core/lib/iomgr/port.h"
@@ -97,7 +94,6 @@
97
94
  #include "src/core/lib/resource_quota/arena.h"
98
95
  #include "src/core/lib/resource_quota/memory_quota.h"
99
96
  #include "src/core/lib/resource_quota/resource_quota.h"
100
- #include "src/core/lib/resource_quota/trace.h"
101
97
  #include "src/core/lib/slice/slice.h"
102
98
  #include "src/core/lib/slice/slice_buffer.h"
103
99
  #include "src/core/lib/slice/slice_internal.h"
@@ -109,10 +105,13 @@
109
105
  #include "src/core/lib/transport/metadata_info.h"
110
106
  #include "src/core/lib/transport/status_conversion.h"
111
107
  #include "src/core/lib/transport/transport.h"
112
-
113
- #ifdef GRPC_POSIX_SOCKET_TCP
114
- #include "src/core/lib/iomgr/ev_posix.h"
115
- #endif
108
+ #include "src/core/telemetry/call_tracer.h"
109
+ #include "src/core/telemetry/stats.h"
110
+ #include "src/core/telemetry/stats_data.h"
111
+ #include "src/core/telemetry/tcp_tracer.h"
112
+ #include "src/core/util/http_client/parser.h"
113
+ #include "src/core/util/string.h"
114
+ #include "src/core/util/useful.h"
116
115
 
117
116
  #define DEFAULT_CONNECTION_WINDOW_TARGET (1024 * 1024)
118
117
  #define MAX_WINDOW 0x7fffffffu
@@ -142,9 +141,6 @@ static bool g_default_server_keepalive_permit_without_calls = false;
142
141
  #define GRPC_ARG_HTTP_TARPIT_MAX_DURATION_MS "grpc.http.tarpit_max_duration_ms"
143
142
 
144
143
  #define MAX_CLIENT_STREAM_ID 0x7fffffffu
145
- grpc_core::TraceFlag grpc_keepalive_trace(false, "http_keepalive");
146
- grpc_core::DebugOnlyTraceFlag grpc_trace_chttp2_refcount(false,
147
- "chttp2_refcount");
148
144
 
149
145
  // forward declarations of various callbacks that we'll build closures around
150
146
  static void write_action_begin_locked(
@@ -228,14 +224,13 @@ namespace {
228
224
 
229
225
  using TaskHandle = ::grpc_event_engine::experimental::EventEngine::TaskHandle;
230
226
 
231
- grpc_core::CallTracerInterface* CallTracerIfSampled(grpc_chttp2_stream* s) {
232
- if (s->context == nullptr || !grpc_core::IsTraceRecordCallopsEnabled()) {
227
+ grpc_core::CallTracerAnnotationInterface* CallTracerIfSampled(
228
+ grpc_chttp2_stream* s) {
229
+ if (!grpc_core::IsTraceRecordCallopsEnabled()) {
233
230
  return nullptr;
234
231
  }
235
- auto* call_tracer = static_cast<grpc_core::CallTracerInterface*>(
236
- static_cast<grpc_call_context_element*>(
237
- s->context)[GRPC_CONTEXT_CALL_TRACER_ANNOTATION_INTERFACE]
238
- .value);
232
+ auto* call_tracer =
233
+ s->arena->GetContext<grpc_core::CallTracerAnnotationInterface>();
239
234
  if (call_tracer == nullptr || !call_tracer->IsSampled()) {
240
235
  return nullptr;
241
236
  }
@@ -244,13 +239,11 @@ grpc_core::CallTracerInterface* CallTracerIfSampled(grpc_chttp2_stream* s) {
244
239
 
245
240
  std::shared_ptr<grpc_core::TcpTracerInterface> TcpTracerIfSampled(
246
241
  grpc_chttp2_stream* s) {
247
- if (s->context == nullptr || !grpc_core::IsTraceRecordCallopsEnabled()) {
242
+ if (!grpc_core::IsTraceRecordCallopsEnabled()) {
248
243
  return nullptr;
249
244
  }
250
- auto* call_attempt_tracer = static_cast<grpc_core::CallTracerInterface*>(
251
- static_cast<grpc_call_context_element*>(
252
- s->context)[GRPC_CONTEXT_CALL_TRACER]
253
- .value);
245
+ auto* call_attempt_tracer =
246
+ s->arena->GetContext<grpc_core::CallTracerInterface>();
254
247
  if (call_attempt_tracer == nullptr || !call_attempt_tracer->IsSampled()) {
255
248
  return nullptr;
256
249
  }
@@ -264,6 +257,7 @@ grpc_core::CopyContextFn g_get_copied_context_fn = nullptr;
264
257
  namespace grpc_core {
265
258
 
266
259
  namespace {
260
+
267
261
  // Initialize a grpc_closure \a c to call \a Fn with \a t and \a error. Holds
268
262
  // the passed in reference to \a t until it's moved into Fn.
269
263
  template <void (*Fn)(RefCountedPtr<grpc_chttp2_transport>, grpc_error_handle)>
@@ -279,13 +273,12 @@ grpc_closure* InitTransportClosure(RefCountedPtr<grpc_chttp2_transport> t,
279
273
  t.release(), nullptr);
280
274
  return c;
281
275
  }
282
- } // namespace
283
276
 
284
- namespace {
285
277
  TestOnlyGlobalHttp2TransportInitCallback test_only_init_callback = nullptr;
286
278
  TestOnlyGlobalHttp2TransportDestructCallback test_only_destruct_callback =
287
279
  nullptr;
288
280
  bool test_only_disable_transient_failure_state_notification = false;
281
+
289
282
  } // namespace
290
283
 
291
284
  void TestOnlySetGlobalHttp2TransportInitCallback(
@@ -368,6 +361,34 @@ std::string HttpAnnotation::ToString() const {
368
361
  return s;
369
362
  }
370
363
 
364
+ void Chttp2CallTracerWrapper::RecordIncomingBytes(
365
+ const CallTracerInterface::TransportByteSize& transport_byte_size) {
366
+ // Update legacy API.
367
+ stream_->stats.incoming.framing_bytes += transport_byte_size.framing_bytes;
368
+ stream_->stats.incoming.data_bytes += transport_byte_size.data_bytes;
369
+ stream_->stats.incoming.header_bytes += transport_byte_size.header_bytes;
370
+ // Update new API.
371
+ if (!IsCallTracerInTransportEnabled()) return;
372
+ auto* call_tracer = stream_->arena->GetContext<CallTracerInterface>();
373
+ if (call_tracer != nullptr) {
374
+ call_tracer->RecordIncomingBytes(transport_byte_size);
375
+ }
376
+ }
377
+
378
+ void Chttp2CallTracerWrapper::RecordOutgoingBytes(
379
+ const CallTracerInterface::TransportByteSize& transport_byte_size) {
380
+ // Update legacy API.
381
+ stream_->stats.outgoing.framing_bytes += transport_byte_size.framing_bytes;
382
+ stream_->stats.outgoing.data_bytes += transport_byte_size.data_bytes;
383
+ stream_->stats.outgoing.header_bytes +=
384
+ transport_byte_size.header_bytes; // Update new API.
385
+ if (!IsCallTracerInTransportEnabled()) return;
386
+ auto* call_tracer = stream_->arena->GetContext<CallTracerInterface>();
387
+ if (call_tracer != nullptr) {
388
+ call_tracer->RecordOutgoingBytes(transport_byte_size);
389
+ }
390
+ }
391
+
371
392
  } // namespace grpc_core
372
393
 
373
394
  //
@@ -385,27 +406,25 @@ grpc_chttp2_transport::~grpc_chttp2_transport() {
385
406
  channelz_socket.reset();
386
407
  }
387
408
 
388
- grpc_endpoint_destroy(ep);
389
-
390
409
  grpc_slice_buffer_destroy(&qbuf);
391
410
 
392
411
  grpc_error_handle error = GRPC_ERROR_CREATE("Transport destroyed");
393
412
  // ContextList::Execute follows semantics of a callback function and does not
394
413
  // take a ref on error
395
- if (cl != nullptr) {
396
- grpc_core::ForEachContextListEntryExecute(cl, nullptr, error);
414
+ if (context_list != nullptr) {
415
+ grpc_core::ForEachContextListEntryExecute(context_list, nullptr, error);
397
416
  }
398
- cl = nullptr;
417
+ context_list = nullptr;
399
418
 
400
419
  grpc_slice_buffer_destroy(&read_buffer);
401
420
  grpc_chttp2_goaway_parser_destroy(&goaway_parser);
402
421
 
403
422
  for (i = 0; i < STREAM_LIST_COUNT; i++) {
404
- GPR_ASSERT(lists[i].head == nullptr);
405
- GPR_ASSERT(lists[i].tail == nullptr);
423
+ CHECK_EQ(lists[i].head, nullptr);
424
+ CHECK_EQ(lists[i].tail, nullptr);
406
425
  }
407
426
 
408
- GPR_ASSERT(stream_map.empty());
427
+ CHECK(stream_map.empty());
409
428
  GRPC_COMBINER_UNREF(combiner, "chttp2_transport");
410
429
 
411
430
  while (write_cb_pool) {
@@ -427,9 +446,9 @@ static void read_channel_args(grpc_chttp2_transport* t,
427
446
  channel_args.GetInt(GRPC_ARG_HTTP2_INITIAL_SEQUENCE_NUMBER).value_or(-1);
428
447
  if (initial_sequence_number > 0) {
429
448
  if ((t->next_stream_id & 1) != (initial_sequence_number & 1)) {
430
- gpr_log(GPR_ERROR, "%s: low bit must be %d on %s",
431
- GRPC_ARG_HTTP2_INITIAL_SEQUENCE_NUMBER, t->next_stream_id & 1,
432
- is_client ? "client" : "server");
449
+ LOG(ERROR) << GRPC_ARG_HTTP2_INITIAL_SEQUENCE_NUMBER
450
+ << ": low bit must be " << (t->next_stream_id & 1) << " on "
451
+ << (is_client ? "client" : "server");
433
452
  } else {
434
453
  t->next_stream_id = static_cast<uint32_t>(initial_sequence_number);
435
454
  }
@@ -465,15 +484,11 @@ static void read_channel_args(grpc_chttp2_transport* t,
465
484
  if (t->is_client) {
466
485
  t->keepalive_permit_without_calls =
467
486
  channel_args.GetBool(GRPC_ARG_KEEPALIVE_PERMIT_WITHOUT_CALLS)
468
- .value_or(grpc_core::IsKeepaliveFixEnabled()
469
- ? g_default_client_keepalive_permit_without_calls
470
- : false);
487
+ .value_or(g_default_client_keepalive_permit_without_calls);
471
488
  } else {
472
489
  t->keepalive_permit_without_calls =
473
490
  channel_args.GetBool(GRPC_ARG_KEEPALIVE_PERMIT_WITHOUT_CALLS)
474
- .value_or(grpc_core::IsKeepaliveServerFixEnabled()
475
- ? g_default_server_keepalive_permit_without_calls
476
- : false);
491
+ .value_or(g_default_server_keepalive_permit_without_calls);
477
492
  }
478
493
 
479
494
  t->settings_timeout =
@@ -502,7 +517,7 @@ static void read_channel_args(grpc_chttp2_transport* t,
502
517
  .value_or(GRPC_ENABLE_CHANNELZ_DEFAULT)) {
503
518
  t->channelz_socket =
504
519
  grpc_core::MakeRefCounted<grpc_core::channelz::SocketNode>(
505
- std::string(grpc_endpoint_get_local_address(t->ep)),
520
+ std::string(grpc_endpoint_get_local_address(t->ep.get())),
506
521
  std::string(t->peer_string.as_string_view()),
507
522
  absl::StrCat(t->GetTransportName(), " ",
508
523
  t->peer_string.as_string_view()),
@@ -535,8 +550,8 @@ static void read_channel_args(grpc_chttp2_transport* t,
535
550
  t->max_concurrent_streams_policy.SetTarget(value);
536
551
  }
537
552
  } else if (channel_args.Contains(GRPC_ARG_MAX_CONCURRENT_STREAMS)) {
538
- gpr_log(GPR_DEBUG, "%s is not available on clients",
539
- GRPC_ARG_MAX_CONCURRENT_STREAMS);
553
+ VLOG(2) << GRPC_ARG_MAX_CONCURRENT_STREAMS
554
+ << " is not available on clients";
540
555
  }
541
556
  value =
542
557
  channel_args.GetInt(GRPC_ARG_HTTP2_HPACK_TABLE_SIZE_DECODER).value_or(-1);
@@ -576,7 +591,7 @@ static void read_channel_args(grpc_chttp2_transport* t,
576
591
  static void init_keepalive_pings_if_enabled_locked(
577
592
  grpc_core::RefCountedPtr<grpc_chttp2_transport> t,
578
593
  GRPC_UNUSED grpc_error_handle error) {
579
- GPR_DEBUG_ASSERT(error.ok());
594
+ DCHECK(error.ok());
580
595
  if (t->keepalive_time != grpc_core::Duration::Infinity()) {
581
596
  t->keepalive_state = GRPC_CHTTP2_KEEPALIVE_STATE_WAITING;
582
597
  t->keepalive_ping_timer_handle =
@@ -592,17 +607,15 @@ static void init_keepalive_pings_if_enabled_locked(
592
607
  }
593
608
  }
594
609
 
610
+ using grpc_event_engine::experimental::QueryExtension;
611
+ using grpc_event_engine::experimental::TcpTraceExtension;
612
+
595
613
  grpc_chttp2_transport::grpc_chttp2_transport(
596
- const grpc_core::ChannelArgs& channel_args, grpc_endpoint* ep,
597
- bool is_client)
598
- : grpc_core::RefCounted<grpc_chttp2_transport,
599
- grpc_core::NonPolymorphicRefCount>(
600
- GRPC_TRACE_FLAG_ENABLED(grpc_trace_chttp2_refcount)
601
- ? "chttp2_refcount"
602
- : nullptr),
603
- ep(ep),
614
+ const grpc_core::ChannelArgs& channel_args,
615
+ grpc_core::OrphanablePtr<grpc_endpoint> endpoint, bool is_client)
616
+ : ep(std::move(endpoint)),
604
617
  peer_string(
605
- grpc_core::Slice::FromCopiedString(grpc_endpoint_get_peer(ep))),
618
+ grpc_core::Slice::FromCopiedString(grpc_endpoint_get_peer(ep.get()))),
606
619
  memory_owner(channel_args.GetObject<grpc_core::ResourceQuota>()
607
620
  ->memory_quota()
608
621
  ->CreateMemoryOwner()),
@@ -623,9 +636,21 @@ grpc_chttp2_transport::grpc_chttp2_transport(
623
636
  &memory_owner),
624
637
  deframe_state(is_client ? GRPC_DTS_FH_0 : GRPC_DTS_CLIENT_PREFIX_0),
625
638
  is_client(is_client) {
626
- cl = new grpc_core::ContextList();
627
- GPR_ASSERT(strlen(GRPC_CHTTP2_CLIENT_CONNECT_STRING) ==
628
- GRPC_CHTTP2_CLIENT_CONNECT_STRLEN);
639
+ context_list = new grpc_core::ContextList();
640
+
641
+ if (channel_args.GetBool(GRPC_ARG_TCP_TRACING_ENABLED).value_or(false) &&
642
+ grpc_event_engine::experimental::grpc_is_event_engine_endpoint(
643
+ ep.get())) {
644
+ auto epte = QueryExtension<TcpTraceExtension>(
645
+ grpc_event_engine::experimental::grpc_get_wrapped_event_engine_endpoint(
646
+ ep.get()));
647
+ if (epte != nullptr) {
648
+ epte->InitializeAndReturnTcpTracer();
649
+ }
650
+ }
651
+
652
+ CHECK(strlen(GRPC_CHTTP2_CLIENT_CONNECT_STRING) ==
653
+ GRPC_CHTTP2_CLIENT_CONNECT_STRLEN);
629
654
 
630
655
  grpc_slice_buffer_init(&read_buffer);
631
656
  if (is_client) {
@@ -714,7 +739,7 @@ static void close_transport_locked(grpc_chttp2_transport* t,
714
739
  grpc_error_add_child(t->close_transport_on_writes_finished, error);
715
740
  return;
716
741
  }
717
- GPR_ASSERT(!error.ok());
742
+ CHECK(!error.ok());
718
743
  t->closed_with_error = error;
719
744
  connectivity_state_set(t, GRPC_CHANNEL_SHUTDOWN, absl::Status(),
720
745
  "close_transport");
@@ -758,10 +783,21 @@ static void close_transport_locked(grpc_chttp2_transport* t,
758
783
  while (grpc_chttp2_list_pop_writable_stream(t, &s)) {
759
784
  GRPC_CHTTP2_STREAM_UNREF(s, "chttp2_writing:close");
760
785
  }
761
- GPR_ASSERT(t->write_state == GRPC_CHTTP2_WRITE_STATE_IDLE);
762
- grpc_endpoint_shutdown(t->ep, error);
786
+ CHECK(t->write_state == GRPC_CHTTP2_WRITE_STATE_IDLE);
787
+ if (t->interested_parties_until_recv_settings != nullptr) {
788
+ grpc_endpoint_delete_from_pollset_set(
789
+ t->ep.get(), t->interested_parties_until_recv_settings);
790
+ t->interested_parties_until_recv_settings = nullptr;
791
+ }
792
+ grpc_core::MutexLock lock(&t->ep_destroy_mu);
793
+ t->ep.reset();
763
794
  }
764
795
  if (t->notify_on_receive_settings != nullptr) {
796
+ if (t->interested_parties_until_recv_settings != nullptr) {
797
+ grpc_endpoint_delete_from_pollset_set(
798
+ t->ep.get(), t->interested_parties_until_recv_settings);
799
+ t->interested_parties_until_recv_settings = nullptr;
800
+ }
765
801
  grpc_core::ExecCtx::Run(DEBUG_LOCATION, t->notify_on_receive_settings,
766
802
  error);
767
803
  t->notify_on_receive_settings = nullptr;
@@ -790,7 +826,8 @@ void grpc_chttp2_stream_unref(grpc_chttp2_stream* s) {
790
826
 
791
827
  grpc_chttp2_stream::grpc_chttp2_stream(grpc_chttp2_transport* t,
792
828
  grpc_stream_refcount* refcount,
793
- const void* server_data)
829
+ const void* server_data,
830
+ grpc_core::Arena* arena)
794
831
  : t(t->Ref()),
795
832
  refcount([refcount]() {
796
833
  // We reserve one 'active stream' that's dropped when the stream is
@@ -804,14 +841,15 @@ grpc_chttp2_stream::grpc_chttp2_stream(grpc_chttp2_transport* t,
804
841
  #endif
805
842
  return refcount;
806
843
  }()),
807
- flow_control(&t->flow_control) {
844
+ arena(arena),
845
+ flow_control(&t->flow_control),
846
+ call_tracer_wrapper(this) {
808
847
  t->streams_allocated.fetch_add(1, std::memory_order_relaxed);
809
848
  if (server_data) {
810
849
  id = static_cast<uint32_t>(reinterpret_cast<uintptr_t>(server_data));
811
- if (grpc_http_trace.enabled()) {
812
- gpr_log(GPR_DEBUG, "HTTP:%p/%p creating accept stream %d [from %p]", t,
813
- this, id, server_data);
814
- }
850
+ GRPC_TRACE_VLOG(http, 2)
851
+ << "HTTP:" << t << "/" << this << " creating accept stream " << id
852
+ << " [from " << server_data << "]";
815
853
  *t->accepting_stream = this;
816
854
  t->stream_map.emplace(id, this);
817
855
  post_destructive_reclaimer(t);
@@ -834,9 +872,9 @@ grpc_chttp2_stream::~grpc_chttp2_stream() {
834
872
  }
835
873
  }
836
874
 
837
- GPR_ASSERT((write_closed && read_closed) || id == 0);
875
+ CHECK((write_closed && read_closed) || id == 0);
838
876
  if (id != 0) {
839
- GPR_ASSERT(t->stream_map.count(id) == 0);
877
+ CHECK_EQ(t->stream_map.count(id), 0u);
840
878
  }
841
879
 
842
880
  grpc_slice_buffer_destroy(&frame_storage);
@@ -849,11 +887,11 @@ grpc_chttp2_stream::~grpc_chttp2_stream() {
849
887
  }
850
888
  }
851
889
 
852
- GPR_ASSERT(send_initial_metadata_finished == nullptr);
853
- GPR_ASSERT(send_trailing_metadata_finished == nullptr);
854
- GPR_ASSERT(recv_initial_metadata_ready == nullptr);
855
- GPR_ASSERT(recv_message_ready == nullptr);
856
- GPR_ASSERT(recv_trailing_metadata_finished == nullptr);
890
+ CHECK_EQ(send_initial_metadata_finished, nullptr);
891
+ CHECK_EQ(send_trailing_metadata_finished, nullptr);
892
+ CHECK_EQ(recv_initial_metadata_ready, nullptr);
893
+ CHECK_EQ(recv_message_ready, nullptr);
894
+ CHECK_EQ(recv_trailing_metadata_finished, nullptr);
857
895
  grpc_slice_buffer_destroy(&flow_controlled_buffer);
858
896
  grpc_core::ExecCtx::Run(DEBUG_LOCATION, destroy_stream_arg, absl::OkStatus());
859
897
  }
@@ -861,8 +899,8 @@ grpc_chttp2_stream::~grpc_chttp2_stream() {
861
899
  void grpc_chttp2_transport::InitStream(grpc_stream* gs,
862
900
  grpc_stream_refcount* refcount,
863
901
  const void* server_data,
864
- grpc_core::Arena*) {
865
- new (gs) grpc_chttp2_stream(this, refcount, server_data);
902
+ grpc_core::Arena* arena) {
903
+ new (gs) grpc_chttp2_stream(this, refcount, server_data, arena);
866
904
  }
867
905
 
868
906
  static void destroy_stream_locked(void* sp, grpc_error_handle /*error*/) {
@@ -886,7 +924,7 @@ grpc_chttp2_stream* grpc_chttp2_parsing_accept_stream(grpc_chttp2_transport* t,
886
924
  return nullptr;
887
925
  }
888
926
  grpc_chttp2_stream* accepting = nullptr;
889
- GPR_ASSERT(t->accepting_stream == nullptr);
927
+ CHECK_EQ(t->accepting_stream, nullptr);
890
928
  t->accepting_stream = &accepting;
891
929
  t->accept_stream_cb(t->accept_stream_cb_user_data, t,
892
930
  reinterpret_cast<void*>(id));
@@ -912,11 +950,11 @@ static const char* write_state_name(grpc_chttp2_write_state st) {
912
950
 
913
951
  static void set_write_state(grpc_chttp2_transport* t,
914
952
  grpc_chttp2_write_state st, const char* reason) {
915
- GRPC_CHTTP2_IF_TRACING(
916
- gpr_log(GPR_INFO, "W:%p %s [%s] state %s -> %s [%s]", t,
917
- t->is_client ? "CLIENT" : "SERVER",
918
- std::string(t->peer_string.as_string_view()).c_str(),
919
- write_state_name(t->write_state), write_state_name(st), reason));
953
+ GRPC_TRACE_LOG(http, INFO)
954
+ << "W:" << t << " " << (t->is_client ? "CLIENT" : "SERVER") << " ["
955
+ << t->peer_string.as_string_view() << "] state "
956
+ << write_state_name(t->write_state) << " -> " << write_state_name(st)
957
+ << " [" << reason << "]";
920
958
  t->write_state = st;
921
959
  // If the state is being reset back to idle, it means a write was just
922
960
  // finished. Make sure all the run_after_write closures are scheduled.
@@ -988,7 +1026,7 @@ static const char* begin_writing_desc(bool partial) {
988
1026
  static void write_action_begin_locked(
989
1027
  grpc_core::RefCountedPtr<grpc_chttp2_transport> t,
990
1028
  grpc_error_handle /*error_ignored*/) {
991
- GPR_ASSERT(t->write_state != GRPC_CHTTP2_WRITE_STATE_IDLE);
1029
+ CHECK(t->write_state != GRPC_CHTTP2_WRITE_STATE_IDLE);
992
1030
  grpc_chttp2_begin_write_result r;
993
1031
  if (!t->closed_with_error.ok()) {
994
1032
  r.writing = false;
@@ -1002,15 +1040,14 @@ static void write_action_begin_locked(
1002
1040
  begin_writing_desc(r.partial));
1003
1041
  write_action(t.get());
1004
1042
  if (t->reading_paused_on_pending_induced_frames) {
1005
- GPR_ASSERT(t->num_pending_induced_frames == 0);
1043
+ CHECK_EQ(t->num_pending_induced_frames, 0u);
1006
1044
  // We had paused reading, because we had many induced frames (SETTINGS
1007
1045
  // ACK, PINGS ACK and RST_STREAMS) pending in t->qbuf. Now that we have
1008
1046
  // been able to flush qbuf, we can resume reading.
1009
- GRPC_CHTTP2_IF_TRACING(gpr_log(
1010
- GPR_INFO,
1011
- "transport %p : Resuming reading after being paused due to too "
1012
- "many unwritten SETTINGS ACK, PINGS ACK and RST_STREAM frames",
1013
- t.get()));
1047
+ GRPC_TRACE_LOG(http, INFO)
1048
+ << "transport " << t.get()
1049
+ << " : Resuming reading after being paused due to too many unwritten "
1050
+ "SETTINGS ACK, PINGS ACK and RST_STREAM frames";
1014
1051
  t->reading_paused_on_pending_induced_frames = false;
1015
1052
  continue_read_action_locked(std::move(t));
1016
1053
  }
@@ -1021,13 +1058,13 @@ static void write_action_begin_locked(
1021
1058
  }
1022
1059
 
1023
1060
  static void write_action(grpc_chttp2_transport* t) {
1024
- void* cl = t->cl;
1025
- if (!t->cl->empty()) {
1061
+ void* cl = t->context_list;
1062
+ if (!t->context_list->empty()) {
1026
1063
  // Transfer the ownership of the context list to the endpoint and create and
1027
1064
  // associate a new context list with the transport.
1028
1065
  // The old context list is stored in the cl local variable which is passed
1029
1066
  // to the endpoint. Its upto the endpoint to manage its lifetime.
1030
- t->cl = new grpc_core::ContextList();
1067
+ t->context_list = new grpc_core::ContextList();
1031
1068
  } else {
1032
1069
  // t->cl is Empty. There is nothing to trace in this endpoint_write. set cl
1033
1070
  // to nullptr.
@@ -1042,12 +1079,11 @@ static void write_action(grpc_chttp2_transport* t) {
1042
1079
  if (max_frame_size == 0) {
1043
1080
  max_frame_size = INT_MAX;
1044
1081
  }
1045
- if (GRPC_TRACE_FLAG_ENABLED(grpc_ping_trace)) {
1046
- gpr_log(GPR_INFO, "%s[%p]: Write %" PRIdPTR " bytes",
1047
- t->is_client ? "CLIENT" : "SERVER", t, t->outbuf.Length());
1048
- }
1082
+ GRPC_TRACE_LOG(http2_ping, INFO)
1083
+ << (t->is_client ? "CLIENT" : "SERVER") << "[" << t << "]: Write "
1084
+ << t->outbuf.Length() << " bytes";
1049
1085
  t->write_size_policy.BeginWrite(t->outbuf.Length());
1050
- grpc_endpoint_write(t->ep, t->outbuf.c_slice_buffer(),
1086
+ grpc_endpoint_write(t->ep.get(), t->outbuf.c_slice_buffer(),
1051
1087
  grpc_core::InitTransportClosure<write_action_end>(
1052
1088
  t->Ref(), &t->write_action_end_locked),
1053
1089
  cl, max_frame_size);
@@ -1056,10 +1092,8 @@ static void write_action(grpc_chttp2_transport* t) {
1056
1092
  static void write_action_end(grpc_core::RefCountedPtr<grpc_chttp2_transport> t,
1057
1093
  grpc_error_handle error) {
1058
1094
  auto* tp = t.get();
1059
- if (GRPC_TRACE_FLAG_ENABLED(grpc_ping_trace)) {
1060
- gpr_log(GPR_INFO, "%s[%p]: Finish write",
1061
- t->is_client ? "CLIENT" : "SERVER", t.get());
1062
- }
1095
+ GRPC_TRACE_LOG(http2_ping, INFO) << (t->is_client ? "CLIENT" : "SERVER")
1096
+ << "[" << t.get() << "]: Finish write";
1063
1097
  tp->combiner->Run(grpc_core::InitTransportClosure<write_action_end_locked>(
1064
1098
  std::move(t), &tp->write_action_end_locked),
1065
1099
  error);
@@ -1129,29 +1163,26 @@ void grpc_chttp2_add_incoming_goaway(grpc_chttp2_transport* t,
1129
1163
  uint32_t goaway_error,
1130
1164
  uint32_t last_stream_id,
1131
1165
  absl::string_view goaway_text) {
1132
- t->goaway_error = grpc_error_set_str(
1166
+ t->goaway_error = grpc_error_set_int(
1133
1167
  grpc_error_set_int(
1134
- grpc_error_set_int(
1135
- grpc_core::StatusCreate(
1136
- absl::StatusCode::kUnavailable,
1137
- absl::StrFormat(
1138
- "GOAWAY received; Error code: %u; Debug Text: %s",
1139
- goaway_error, goaway_text),
1140
- DEBUG_LOCATION, {}),
1141
- grpc_core::StatusIntProperty::kHttp2Error,
1142
- static_cast<intptr_t>(goaway_error)),
1143
- grpc_core::StatusIntProperty::kRpcStatus, GRPC_STATUS_UNAVAILABLE),
1144
- grpc_core::StatusStrProperty::kRawBytes, goaway_text);
1145
-
1146
- GRPC_CHTTP2_IF_TRACING(
1147
- gpr_log(GPR_INFO, "transport %p got goaway with last stream id %d", t,
1148
- last_stream_id));
1168
+ grpc_core::StatusCreate(
1169
+ absl::StatusCode::kUnavailable,
1170
+ absl::StrFormat("GOAWAY received; Error code: %u; Debug Text: %s",
1171
+ goaway_error, goaway_text),
1172
+ DEBUG_LOCATION, {}),
1173
+ grpc_core::StatusIntProperty::kHttp2Error,
1174
+ static_cast<intptr_t>(goaway_error)),
1175
+ grpc_core::StatusIntProperty::kRpcStatus, GRPC_STATUS_UNAVAILABLE);
1176
+
1177
+ GRPC_TRACE_LOG(http, INFO)
1178
+ << "transport " << t << " got goaway with last stream id "
1179
+ << last_stream_id;
1149
1180
  // We want to log this irrespective of whether http tracing is enabled if we
1150
1181
  // received a GOAWAY with a non NO_ERROR code.
1151
1182
  if (goaway_error != GRPC_HTTP2_NO_ERROR) {
1152
- gpr_log(GPR_INFO, "%s: Got goaway [%d] err=%s",
1153
- std::string(t->peer_string.as_string_view()).c_str(), goaway_error,
1154
- grpc_core::StatusToString(t->goaway_error).c_str());
1183
+ LOG(INFO) << t->peer_string.as_string_view() << ": Got goaway ["
1184
+ << goaway_error
1185
+ << "] err=" << grpc_core::StatusToString(t->goaway_error);
1155
1186
  }
1156
1187
  if (t->is_client) {
1157
1188
  cancel_unstarted_streams(t, t->goaway_error, false);
@@ -1177,12 +1208,11 @@ void grpc_chttp2_add_incoming_goaway(grpc_chttp2_transport* t,
1177
1208
  if (GPR_UNLIKELY(t->is_client &&
1178
1209
  goaway_error == GRPC_HTTP2_ENHANCE_YOUR_CALM &&
1179
1210
  goaway_text == "too_many_pings")) {
1180
- gpr_log(GPR_ERROR,
1181
- "%s: Received a GOAWAY with error code ENHANCE_YOUR_CALM and debug "
1182
- "data equal to \"too_many_pings\". Current keepalive time (before "
1183
- "throttling): %s",
1184
- std::string(t->peer_string.as_string_view()).c_str(),
1185
- t->keepalive_time.ToString().c_str());
1211
+ LOG(ERROR) << t->peer_string.as_string_view()
1212
+ << ": Received a GOAWAY with error code ENHANCE_YOUR_CALM and "
1213
+ "debug data equal to \"too_many_pings\". Current keepalive "
1214
+ "time (before throttling): "
1215
+ << t->keepalive_time.ToString();
1186
1216
  constexpr int max_keepalive_time_millis =
1187
1217
  INT_MAX / KEEPALIVE_TIME_BACKOFF_MULTIPLIER;
1188
1218
  int64_t throttled_keepalive_time =
@@ -1214,12 +1244,12 @@ static void maybe_start_some_streams(grpc_chttp2_transport* t) {
1214
1244
  t->stream_map.size() < t->settings.peer().max_concurrent_streams() &&
1215
1245
  grpc_chttp2_list_pop_waiting_for_concurrency(t, &s)) {
1216
1246
  // safe since we can't (legally) be parsing this stream yet
1217
- GRPC_CHTTP2_IF_TRACING(gpr_log(
1218
- GPR_INFO,
1219
- "HTTP:%s: Transport %p allocating new grpc_chttp2_stream %p to id %d",
1220
- t->is_client ? "CLI" : "SVR", t, s, t->next_stream_id));
1247
+ GRPC_TRACE_LOG(http, INFO)
1248
+ << "HTTP:" << (t->is_client ? "CLI" : "SVR") << ": Transport " << t
1249
+ << " allocating new grpc_chttp2_stream " << s << " to id "
1250
+ << t->next_stream_id;
1221
1251
 
1222
- GPR_ASSERT(s->id == 0);
1252
+ CHECK_EQ(s->id, 0u);
1223
1253
  s->id = t->next_stream_id;
1224
1254
  t->next_stream_id += 2;
1225
1255
 
@@ -1279,18 +1309,14 @@ void grpc_chttp2_complete_closure_step(grpc_chttp2_transport* t,
1279
1309
  return;
1280
1310
  }
1281
1311
  closure->next_data.scratch -= CLOSURE_BARRIER_FIRST_REF_BIT;
1282
- if (GRPC_TRACE_FLAG_ENABLED(grpc_http_trace)) {
1283
- gpr_log(
1284
- GPR_INFO,
1285
- "complete_closure_step: t=%p %p refs=%d flags=0x%04x desc=%s err=%s "
1286
- "write_state=%s whence=%s:%d",
1287
- t, closure,
1288
- static_cast<int>(closure->next_data.scratch /
1289
- CLOSURE_BARRIER_FIRST_REF_BIT),
1290
- static_cast<int>(closure->next_data.scratch %
1291
- CLOSURE_BARRIER_FIRST_REF_BIT),
1292
- desc, grpc_core::StatusToString(error).c_str(),
1293
- write_state_name(t->write_state), whence.file(), whence.line());
1312
+ if (GRPC_TRACE_FLAG_ENABLED(http)) {
1313
+ LOG(INFO) << "complete_closure_step: t=" << t << " " << closure << " refs="
1314
+ << (closure->next_data.scratch / CLOSURE_BARRIER_FIRST_REF_BIT)
1315
+ << " flags="
1316
+ << (closure->next_data.scratch % CLOSURE_BARRIER_FIRST_REF_BIT)
1317
+ << " desc=" << desc << " err=" << grpc_core::StatusToString(error)
1318
+ << " write_state=" << write_state_name(t->write_state)
1319
+ << " whence=" << whence.file() << ":" << whence.line();
1294
1320
  }
1295
1321
 
1296
1322
  if (!error.ok()) {
@@ -1299,12 +1325,10 @@ void grpc_chttp2_complete_closure_step(grpc_chttp2_transport* t,
1299
1325
  if (cl_err.ok()) {
1300
1326
  cl_err = GRPC_ERROR_CREATE(absl::StrCat(
1301
1327
  "Error in HTTP transport completing operation: ", desc,
1302
- " write_state=", write_state_name(t->write_state), " refs=",
1303
- closure->next_data.scratch / CLOSURE_BARRIER_FIRST_REF_BIT, " flags=",
1304
- closure->next_data.scratch % CLOSURE_BARRIER_FIRST_REF_BIT));
1305
- cl_err = grpc_error_set_str(cl_err,
1306
- grpc_core::StatusStrProperty::kTargetAddress,
1307
- std::string(t->peer_string.as_string_view()));
1328
+ " write_state=", write_state_name(t->write_state),
1329
+ " refs=", closure->next_data.scratch / CLOSURE_BARRIER_FIRST_REF_BIT,
1330
+ " flags=", closure->next_data.scratch % CLOSURE_BARRIER_FIRST_REF_BIT,
1331
+ " peer_address=", t->peer_string.as_string_view()));
1308
1332
  }
1309
1333
  cl_err = grpc_error_add_child(cl_err, error);
1310
1334
  closure->error_data.error = grpc_core::internal::StatusAllocHeapPtr(cl_err);
@@ -1331,11 +1355,11 @@ static bool contains_non_ok_status(grpc_metadata_batch* batch) {
1331
1355
 
1332
1356
  static void log_metadata(const grpc_metadata_batch* md_batch, uint32_t id,
1333
1357
  bool is_client, bool is_initial) {
1334
- gpr_log(GPR_INFO, "--metadata--");
1358
+ VLOG(2) << "--metadata--";
1335
1359
  const std::string prefix = absl::StrCat(
1336
1360
  "HTTP:", id, is_initial ? ":HDR" : ":TRL", is_client ? ":CLI:" : ":SVR:");
1337
1361
  md_batch->Log([&prefix](absl::string_view key, absl::string_view value) {
1338
- gpr_log(GPR_INFO, "%s", absl::StrCat(prefix, key, ": ", value).c_str());
1362
+ VLOG(2) << prefix << key << ": " << value;
1339
1363
  });
1340
1364
  }
1341
1365
 
@@ -1348,15 +1372,15 @@ static void perform_stream_op_locked(void* stream_op,
1348
1372
  grpc_transport_stream_op_batch_payload* op_payload = op->payload;
1349
1373
  grpc_chttp2_transport* t = s->t.get();
1350
1374
 
1351
- s->context = op->payload->context;
1352
1375
  s->traced = op->is_traced;
1353
- s->call_tracer = CallTracerIfSampled(s);
1376
+ if (!grpc_core::IsCallTracerInTransportEnabled()) {
1377
+ s->call_tracer = CallTracerIfSampled(s);
1378
+ }
1354
1379
  s->tcp_tracer = TcpTracerIfSampled(s);
1355
- if (GRPC_TRACE_FLAG_ENABLED(grpc_http_trace)) {
1356
- gpr_log(GPR_INFO,
1357
- "perform_stream_op_locked[s=%p; op=%p]: %s; on_complete = %p", s,
1358
- op, grpc_transport_stream_op_batch_string(op, false).c_str(),
1359
- op->on_complete);
1380
+ if (GRPC_TRACE_FLAG_ENABLED(http)) {
1381
+ LOG(INFO) << "perform_stream_op_locked[s=" << s << "; op=" << op
1382
+ << "]: " << grpc_transport_stream_op_batch_string(op, false)
1383
+ << "; on_complete = " << op->on_complete;
1360
1384
  if (op->send_initial_metadata) {
1361
1385
  log_metadata(op_payload->send_initial_metadata.send_initial_metadata,
1362
1386
  s->id, t->is_client, true);
@@ -1382,17 +1406,29 @@ static void perform_stream_op_locked(void* stream_op,
1382
1406
  }
1383
1407
 
1384
1408
  if (op->send_initial_metadata) {
1385
- if (s->call_tracer) {
1386
- s->call_tracer->RecordAnnotation(
1387
- grpc_core::HttpAnnotation(grpc_core::HttpAnnotation::Type::kStart,
1388
- gpr_now(GPR_CLOCK_REALTIME))
1389
- .Add(s->t->flow_control.stats())
1390
- .Add(s->flow_control.stats()));
1409
+ if (!grpc_core::IsCallTracerInTransportEnabled()) {
1410
+ if (s->call_tracer != nullptr) {
1411
+ s->call_tracer->RecordAnnotation(
1412
+ grpc_core::HttpAnnotation(grpc_core::HttpAnnotation::Type::kStart,
1413
+ gpr_now(GPR_CLOCK_REALTIME))
1414
+ .Add(s->t->flow_control.stats())
1415
+ .Add(s->flow_control.stats()));
1416
+ }
1417
+ } else if (grpc_core::IsTraceRecordCallopsEnabled()) {
1418
+ auto* call_tracer =
1419
+ s->arena->GetContext<grpc_core::CallTracerInterface>();
1420
+ if (call_tracer != nullptr && call_tracer->IsSampled()) {
1421
+ call_tracer->RecordAnnotation(
1422
+ grpc_core::HttpAnnotation(grpc_core::HttpAnnotation::Type::kStart,
1423
+ gpr_now(GPR_CLOCK_REALTIME))
1424
+ .Add(s->t->flow_control.stats())
1425
+ .Add(s->flow_control.stats()));
1426
+ }
1391
1427
  }
1392
1428
  if (t->is_client && t->channelz_socket != nullptr) {
1393
1429
  t->channelz_socket->RecordStreamStartedFromLocal();
1394
1430
  }
1395
- GPR_ASSERT(s->send_initial_metadata_finished == nullptr);
1431
+ CHECK_EQ(s->send_initial_metadata_finished, nullptr);
1396
1432
  on_complete->next_data.scratch |= t->closure_barrier_may_cover_write;
1397
1433
 
1398
1434
  s->send_initial_metadata_finished = add_closure_barrier(on_complete);
@@ -1410,7 +1446,7 @@ static void perform_stream_op_locked(void* stream_op,
1410
1446
  if (!s->write_closed) {
1411
1447
  if (t->is_client) {
1412
1448
  if (t->closed_with_error.ok()) {
1413
- GPR_ASSERT(s->id == 0);
1449
+ CHECK_EQ(s->id, 0u);
1414
1450
  grpc_chttp2_list_add_waiting_for_concurrency(t, s);
1415
1451
  maybe_start_some_streams(t);
1416
1452
  } else {
@@ -1427,7 +1463,7 @@ static void perform_stream_op_locked(void* stream_op,
1427
1463
  false);
1428
1464
  }
1429
1465
  } else {
1430
- GPR_ASSERT(s->id != 0);
1466
+ CHECK_NE(s->id, 0u);
1431
1467
  grpc_chttp2_mark_stream_writable(t, s);
1432
1468
  if (!(op->send_message &&
1433
1469
  (op->payload->send_message.flags & GRPC_WRITE_BUFFER_HINT))) {
@@ -1471,11 +1507,8 @@ static void perform_stream_op_locked(void* stream_op,
1471
1507
  frame_hdr[3] = static_cast<uint8_t>(len >> 8);
1472
1508
  frame_hdr[4] = static_cast<uint8_t>(len);
1473
1509
 
1474
- if (grpc_core::IsHttp2StatsFixEnabled()) {
1475
- s->stats.outgoing.framing_bytes += GRPC_HEADER_SIZE_IN_BYTES;
1476
- s->stats.outgoing.data_bytes +=
1477
- op_payload->send_message.send_message->Length();
1478
- }
1510
+ s->call_tracer_wrapper.RecordOutgoingBytes(
1511
+ {GRPC_HEADER_SIZE_IN_BYTES, len, 0});
1479
1512
  s->next_message_end_offset =
1480
1513
  s->flow_controlled_bytes_written +
1481
1514
  static_cast<int64_t>(s->flow_controlled_buffer.length) +
@@ -1528,7 +1561,7 @@ static void perform_stream_op_locked(void* stream_op,
1528
1561
  }
1529
1562
 
1530
1563
  if (op->send_trailing_metadata) {
1531
- GPR_ASSERT(s->send_trailing_metadata_finished == nullptr);
1564
+ CHECK_EQ(s->send_trailing_metadata_finished, nullptr);
1532
1565
  on_complete->next_data.scratch |= t->closure_barrier_may_cover_write;
1533
1566
  s->send_trailing_metadata_finished = add_closure_barrier(on_complete);
1534
1567
  s->send_trailing_metadata =
@@ -1558,7 +1591,7 @@ static void perform_stream_op_locked(void* stream_op,
1558
1591
  }
1559
1592
 
1560
1593
  if (op->recv_initial_metadata) {
1561
- GPR_ASSERT(s->recv_initial_metadata_ready == nullptr);
1594
+ CHECK_EQ(s->recv_initial_metadata_ready, nullptr);
1562
1595
  s->recv_initial_metadata_ready =
1563
1596
  op_payload->recv_initial_metadata.recv_initial_metadata_ready;
1564
1597
  s->recv_initial_metadata =
@@ -1572,7 +1605,7 @@ static void perform_stream_op_locked(void* stream_op,
1572
1605
  }
1573
1606
 
1574
1607
  if (op->recv_message) {
1575
- GPR_ASSERT(s->recv_message_ready == nullptr);
1608
+ CHECK_EQ(s->recv_message_ready, nullptr);
1576
1609
  s->recv_message_ready = op_payload->recv_message.recv_message_ready;
1577
1610
  s->recv_message = op_payload->recv_message.recv_message;
1578
1611
  s->recv_message->emplace();
@@ -1583,9 +1616,9 @@ static void perform_stream_op_locked(void* stream_op,
1583
1616
  }
1584
1617
 
1585
1618
  if (op->recv_trailing_metadata) {
1586
- GPR_ASSERT(s->collecting_stats == nullptr);
1619
+ CHECK_EQ(s->collecting_stats, nullptr);
1587
1620
  s->collecting_stats = op_payload->recv_trailing_metadata.collect_stats;
1588
- GPR_ASSERT(s->recv_trailing_metadata_finished == nullptr);
1621
+ CHECK_EQ(s->recv_trailing_metadata_finished, nullptr);
1589
1622
  s->recv_trailing_metadata_finished =
1590
1623
  op_payload->recv_trailing_metadata.recv_trailing_metadata_ready;
1591
1624
  s->recv_trailing_metadata =
@@ -1608,20 +1641,20 @@ void grpc_chttp2_transport::PerformStreamOp(
1608
1641
 
1609
1642
  if (!is_client) {
1610
1643
  if (op->send_initial_metadata) {
1611
- GPR_ASSERT(!op->payload->send_initial_metadata.send_initial_metadata
1612
- ->get(grpc_core::GrpcTimeoutMetadata())
1613
- .has_value());
1644
+ CHECK(!op->payload->send_initial_metadata.send_initial_metadata
1645
+ ->get(grpc_core::GrpcTimeoutMetadata())
1646
+ .has_value());
1614
1647
  }
1615
1648
  if (op->send_trailing_metadata) {
1616
- GPR_ASSERT(!op->payload->send_trailing_metadata.send_trailing_metadata
1617
- ->get(grpc_core::GrpcTimeoutMetadata())
1618
- .has_value());
1649
+ CHECK(!op->payload->send_trailing_metadata.send_trailing_metadata
1650
+ ->get(grpc_core::GrpcTimeoutMetadata())
1651
+ .has_value());
1619
1652
  }
1620
1653
  }
1621
1654
 
1622
- if (GRPC_TRACE_FLAG_ENABLED(grpc_http_trace)) {
1623
- gpr_log(GPR_INFO, "perform_stream_op[s=%p; op=%p]: %s", s, op,
1624
- grpc_transport_stream_op_batch_string(op, false).c_str());
1655
+ if (GRPC_TRACE_FLAG_ENABLED(http)) {
1656
+ LOG(INFO) << "perform_stream_op[s=" << s << "; op=" << op
1657
+ << "]: " << grpc_transport_stream_op_batch_string(op, false);
1625
1658
  }
1626
1659
 
1627
1660
  GRPC_CHTTP2_STREAM_REF(s, "perform_stream_op");
@@ -1632,8 +1665,8 @@ void grpc_chttp2_transport::PerformStreamOp(
1632
1665
  }
1633
1666
 
1634
1667
  static void cancel_pings(grpc_chttp2_transport* t, grpc_error_handle error) {
1635
- GRPC_CHTTP2_IF_TRACING(gpr_log(GPR_INFO, "%p CANCEL PINGS: %s", t,
1636
- grpc_core::StatusToString(error).c_str()));
1668
+ GRPC_TRACE_LOG(http, INFO)
1669
+ << t << " CANCEL PINGS: " << grpc_core::StatusToString(error);
1637
1670
  // callback remaining pings: they're not allowed to call into the transport,
1638
1671
  // and maybe they hold resources that need to be freed
1639
1672
  t->ping_callbacks.CancelAll(t->event_engine.get());
@@ -1707,8 +1740,8 @@ void grpc_chttp2_retry_initiate_ping(
1707
1740
  static void retry_initiate_ping_locked(
1708
1741
  grpc_core::RefCountedPtr<grpc_chttp2_transport> t,
1709
1742
  GRPC_UNUSED grpc_error_handle error) {
1710
- GPR_DEBUG_ASSERT(error.ok());
1711
- GPR_ASSERT(t->delayed_ping_timer_handle != TaskHandle::kInvalid);
1743
+ DCHECK(error.ok());
1744
+ CHECK(t->delayed_ping_timer_handle != TaskHandle::kInvalid);
1712
1745
  t->delayed_ping_timer_handle = TaskHandle::kInvalid;
1713
1746
  grpc_chttp2_initiate_write(t.get(),
1714
1747
  GRPC_CHTTP2_INITIATE_WRITE_RETRY_SEND_PING);
@@ -1716,8 +1749,8 @@ static void retry_initiate_ping_locked(
1716
1749
 
1717
1750
  void grpc_chttp2_ack_ping(grpc_chttp2_transport* t, uint64_t id) {
1718
1751
  if (!t->ping_callbacks.AckPing(id, t->event_engine.get())) {
1719
- gpr_log(GPR_DEBUG, "Unknown ping response from %s: %" PRIx64,
1720
- std::string(t->peer_string.as_string_view()).c_str(), id);
1752
+ VLOG(2) << "Unknown ping response from " << t->peer_string.as_string_view()
1753
+ << ": " << id;
1721
1754
  return;
1722
1755
  }
1723
1756
  if (t->ping_callbacks.ping_requested()) {
@@ -1729,8 +1762,8 @@ void grpc_chttp2_keepalive_timeout(
1729
1762
  grpc_core::RefCountedPtr<grpc_chttp2_transport> t) {
1730
1763
  t->combiner->Run(
1731
1764
  grpc_core::NewClosure([t](grpc_error_handle) {
1732
- gpr_log(GPR_INFO, "%s: Keepalive timeout. Closing transport.",
1733
- std::string(t->peer_string.as_string_view()).c_str());
1765
+ GRPC_TRACE_LOG(http, INFO) << t->peer_string.as_string_view()
1766
+ << ": Keepalive timeout. Closing transport.";
1734
1767
  send_goaway(
1735
1768
  t.get(),
1736
1769
  grpc_error_set_int(GRPC_ERROR_CREATE("keepalive_timeout"),
@@ -1750,8 +1783,8 @@ void grpc_chttp2_ping_timeout(
1750
1783
  grpc_core::RefCountedPtr<grpc_chttp2_transport> t) {
1751
1784
  t->combiner->Run(
1752
1785
  grpc_core::NewClosure([t](grpc_error_handle) {
1753
- gpr_log(GPR_INFO, "%s: Ping timeout. Closing transport.",
1754
- std::string(t->peer_string.as_string_view()).c_str());
1786
+ GRPC_TRACE_LOG(http, INFO) << t->peer_string.as_string_view()
1787
+ << ": Ping timeout. Closing transport.";
1755
1788
  send_goaway(
1756
1789
  t.get(),
1757
1790
  grpc_error_set_int(GRPC_ERROR_CREATE("ping_timeout"),
@@ -1771,8 +1804,8 @@ void grpc_chttp2_settings_timeout(
1771
1804
  grpc_core::RefCountedPtr<grpc_chttp2_transport> t) {
1772
1805
  t->combiner->Run(
1773
1806
  grpc_core::NewClosure([t](grpc_error_handle) {
1774
- gpr_log(GPR_INFO, "%s: Settings timeout. Closing transport.",
1775
- std::string(t->peer_string.as_string_view()).c_str());
1807
+ GRPC_TRACE_LOG(http, INFO) << t->peer_string.as_string_view()
1808
+ << ": Settings timeout. Closing transport.";
1776
1809
  send_goaway(
1777
1810
  t.get(),
1778
1811
  grpc_error_set_int(GRPC_ERROR_CREATE("settings_timeout"),
@@ -1822,22 +1855,21 @@ class GracefulGoaway : public grpc_core::RefCounted<GracefulGoaway> {
1822
1855
  return;
1823
1856
  }
1824
1857
  if (t_->destroying || !t_->closed_with_error.ok()) {
1825
- GRPC_CHTTP2_IF_TRACING(
1826
- gpr_log(GPR_INFO,
1827
- "transport:%p %s peer:%s Transport already shutting down. "
1828
- "Graceful GOAWAY abandoned.",
1829
- t_.get(), t_->is_client ? "CLIENT" : "SERVER",
1830
- std::string(t_->peer_string.as_string_view()).c_str()));
1858
+ GRPC_TRACE_LOG(http, INFO) << "transport:" << t_.get() << " "
1859
+ << (t_->is_client ? "CLIENT" : "SERVER")
1860
+ << " peer:" << t_->peer_string.as_string_view()
1861
+ << " Transport already shutting down. "
1862
+ "Graceful GOAWAY abandoned.";
1831
1863
  return;
1832
1864
  }
1833
1865
  // Ping completed. Send final goaway.
1834
- GRPC_CHTTP2_IF_TRACING(
1835
- gpr_log(GPR_INFO,
1836
- "transport:%p %s peer:%s Graceful shutdown: Ping received. "
1837
- "Sending final GOAWAY with stream_id:%d",
1838
- t_.get(), t_->is_client ? "CLIENT" : "SERVER",
1839
- std::string(t_->peer_string.as_string_view()).c_str(),
1840
- t_->last_new_stream_id));
1866
+ GRPC_TRACE_LOG(http, INFO)
1867
+ << "transport:" << t_.get() << " "
1868
+ << (t_->is_client ? "CLIENT" : "SERVER")
1869
+ << " peer:" << std::string(t_->peer_string.as_string_view())
1870
+ << " Graceful shutdown: Ping received. "
1871
+ "Sending final GOAWAY with stream_id:"
1872
+ << t_->last_new_stream_id;
1841
1873
  t_->sent_goaway_state = GRPC_CHTTP2_FINAL_GOAWAY_SEND_SCHEDULED;
1842
1874
  grpc_chttp2_goaway_append(t_->last_new_stream_id, 0, grpc_empty_slice(),
1843
1875
  &t_->qbuf);
@@ -1881,10 +1913,10 @@ static void send_goaway(grpc_chttp2_transport* t, grpc_error_handle error,
1881
1913
  } else if (t->sent_goaway_state == GRPC_CHTTP2_NO_GOAWAY_SEND ||
1882
1914
  t->sent_goaway_state == GRPC_CHTTP2_GRACEFUL_GOAWAY) {
1883
1915
  // We want to log this irrespective of whether http tracing is enabled
1884
- gpr_log(GPR_DEBUG, "%s %s: Sending goaway last_new_stream_id=%d err=%s",
1885
- std::string(t->peer_string.as_string_view()).c_str(),
1886
- t->is_client ? "CLIENT" : "SERVER", t->last_new_stream_id,
1887
- grpc_core::StatusToString(error).c_str());
1916
+ VLOG(2) << t->peer_string.as_string_view() << " "
1917
+ << (t->is_client ? "CLIENT" : "SERVER")
1918
+ << ": Sending goaway last_new_stream_id=" << t->last_new_stream_id
1919
+ << " err=" << grpc_core::StatusToString(error);
1888
1920
  t->sent_goaway_state = GRPC_CHTTP2_FINAL_GOAWAY_SEND_SCHEDULED;
1889
1921
  grpc_chttp2_goaway_append(
1890
1922
  t->last_new_stream_id, static_cast<uint32_t>(http_error),
@@ -1932,11 +1964,15 @@ static void perform_transport_op_locked(void* stream_op,
1932
1964
  }
1933
1965
 
1934
1966
  if (op->bind_pollset) {
1935
- grpc_endpoint_add_to_pollset(t->ep, op->bind_pollset);
1967
+ if (t->ep != nullptr) {
1968
+ grpc_endpoint_add_to_pollset(t->ep.get(), op->bind_pollset);
1969
+ }
1936
1970
  }
1937
1971
 
1938
1972
  if (op->bind_pollset_set) {
1939
- grpc_endpoint_add_to_pollset_set(t->ep, op->bind_pollset_set);
1973
+ if (t->ep != nullptr) {
1974
+ grpc_endpoint_add_to_pollset_set(t->ep.get(), op->bind_pollset_set);
1975
+ }
1940
1976
  }
1941
1977
 
1942
1978
  if (op->send_ping.on_initiate != nullptr || op->send_ping.on_ack != nullptr) {
@@ -1963,9 +1999,9 @@ static void perform_transport_op_locked(void* stream_op,
1963
1999
  }
1964
2000
 
1965
2001
  void grpc_chttp2_transport::PerformOp(grpc_transport_op* op) {
1966
- if (GRPC_TRACE_FLAG_ENABLED(grpc_http_trace)) {
1967
- gpr_log(GPR_INFO, "perform_transport_op[t=%p]: %s", this,
1968
- grpc_transport_op_string(op).c_str());
2002
+ if (GRPC_TRACE_FLAG_ENABLED(http)) {
2003
+ LOG(INFO) << "perform_transport_op[t=" << this
2004
+ << "]: " << grpc_transport_op_string(op);
1969
2005
  }
1970
2006
  op->handler_private.extra_arg = this;
1971
2007
  Ref().release()->combiner->Run(
@@ -2016,11 +2052,10 @@ void grpc_chttp2_maybe_complete_recv_message(grpc_chttp2_transport* t,
2016
2052
  // Lambda is immediately invoked as a big scoped section that can be
2017
2053
  // exited out of at any point by returning.
2018
2054
  [&]() {
2019
- if (grpc_http_trace.enabled()) {
2020
- gpr_log(GPR_DEBUG,
2021
- "maybe_complete_recv_message %p final_metadata_requested=%d "
2022
- "seen_error=%d",
2023
- s, s->final_metadata_requested, s->seen_error);
2055
+ if (GRPC_TRACE_FLAG_ENABLED(http)) {
2056
+ VLOG(2) << "maybe_complete_recv_message " << s
2057
+ << " final_metadata_requested=" << s->final_metadata_requested
2058
+ << " seen_error=" << s->seen_error;
2024
2059
  }
2025
2060
  if (s->final_metadata_requested && s->seen_error) {
2026
2061
  grpc_slice_buffer_reset_and_unref(&s->frame_storage);
@@ -2028,15 +2063,14 @@ void grpc_chttp2_maybe_complete_recv_message(grpc_chttp2_transport* t,
2028
2063
  } else {
2029
2064
  if (s->frame_storage.length != 0) {
2030
2065
  while (true) {
2031
- GPR_ASSERT(s->frame_storage.length > 0);
2066
+ CHECK_GT(s->frame_storage.length, 0u);
2032
2067
  int64_t min_progress_size;
2033
2068
  auto r = grpc_deframe_unprocessed_incoming_frames(
2034
2069
  s, &min_progress_size, &**s->recv_message, s->recv_message_flags);
2035
- if (grpc_http_trace.enabled()) {
2036
- gpr_log(GPR_DEBUG, "Deframe data frame: %s",
2037
- grpc_core::PollToString(r, [](absl::Status r) {
2038
- return r.ToString();
2039
- }).c_str());
2070
+ if (GRPC_TRACE_FLAG_ENABLED(http)) {
2071
+ VLOG(2) << "Deframe data frame: "
2072
+ << grpc_core::PollToString(
2073
+ r, [](absl::Status r) { return r.ToString(); });
2040
2074
  }
2041
2075
  if (r.pending()) {
2042
2076
  if (s->read_closed) {
@@ -2088,13 +2122,12 @@ void grpc_chttp2_maybe_complete_recv_message(grpc_chttp2_transport* t,
2088
2122
  void grpc_chttp2_maybe_complete_recv_trailing_metadata(grpc_chttp2_transport* t,
2089
2123
  grpc_chttp2_stream* s) {
2090
2124
  grpc_chttp2_maybe_complete_recv_message(t, s);
2091
- if (grpc_http_trace.enabled()) {
2092
- gpr_log(GPR_DEBUG,
2093
- "maybe_complete_recv_trailing_metadata cli=%d s=%p closure=%p "
2094
- "read_closed=%d "
2095
- "write_closed=%d %" PRIdPTR,
2096
- t->is_client, s, s->recv_trailing_metadata_finished, s->read_closed,
2097
- s->write_closed, s->frame_storage.length);
2125
+ if (GRPC_TRACE_FLAG_ENABLED(http)) {
2126
+ VLOG(2) << "maybe_complete_recv_trailing_metadata cli=" << t->is_client
2127
+ << " s=" << s << " closure=" << s->recv_trailing_metadata_finished
2128
+ << " read_closed=" << s->read_closed
2129
+ << " write_closed=" << s->write_closed << " "
2130
+ << s->frame_storage.length;
2098
2131
  }
2099
2132
  if (s->recv_trailing_metadata_finished != nullptr && s->read_closed &&
2100
2133
  s->write_closed) {
@@ -2114,7 +2147,7 @@ void grpc_chttp2_maybe_complete_recv_trailing_metadata(grpc_chttp2_transport* t,
2114
2147
  static grpc_chttp2_transport::RemovedStreamHandle remove_stream(
2115
2148
  grpc_chttp2_transport* t, uint32_t id, grpc_error_handle error) {
2116
2149
  grpc_chttp2_stream* s = t->stream_map.extract(id).mapped();
2117
- GPR_DEBUG_ASSERT(s);
2150
+ DCHECK(s);
2118
2151
  if (t->incoming_stream == s) {
2119
2152
  t->incoming_stream = nullptr;
2120
2153
  grpc_chttp2_parsing_become_skip_parser(t);
@@ -2299,13 +2332,14 @@ grpc_chttp2_transport::RemovedStreamHandle grpc_chttp2_mark_stream_closed(
2299
2332
  grpc_chttp2_transport* t, grpc_chttp2_stream* s, int close_reads,
2300
2333
  int close_writes, grpc_error_handle error) {
2301
2334
  grpc_chttp2_transport::RemovedStreamHandle rsh;
2302
- if (grpc_http_trace.enabled()) {
2303
- gpr_log(
2304
- GPR_DEBUG, "MARK_STREAM_CLOSED: t=%p s=%p(id=%d) %s [%s]", t, s, s->id,
2305
- (close_reads && close_writes)
2306
- ? "read+write"
2307
- : (close_reads ? "read" : (close_writes ? "write" : "nothing??")),
2308
- grpc_core::StatusToString(error).c_str());
2335
+ if (GRPC_TRACE_FLAG_ENABLED(http)) {
2336
+ VLOG(2) << "MARK_STREAM_CLOSED: t=" << t << " s=" << s << "(id=" << s->id
2337
+ << ") "
2338
+ << ((close_reads && close_writes)
2339
+ ? "read+write"
2340
+ : (close_reads ? "read"
2341
+ : (close_writes ? "write" : "nothing??")))
2342
+ << " [" << grpc_core::StatusToString(error) << "]";
2309
2343
  }
2310
2344
  if (s->read_closed && s->write_closed) {
2311
2345
  // already closed, but we should still fake the status if needed.
@@ -2366,7 +2400,8 @@ static void close_from_api(grpc_chttp2_transport* t, grpc_chttp2_stream* s,
2366
2400
  grpc_error_get_status(error, s->deadline, &grpc_status, &message, nullptr,
2367
2401
  nullptr);
2368
2402
 
2369
- GPR_ASSERT(grpc_status >= 0 && (int)grpc_status < 100);
2403
+ CHECK_GE(grpc_status, 0);
2404
+ CHECK_LT((int)grpc_status, 100);
2370
2405
 
2371
2406
  auto remove_stream_handle = grpc_chttp2_mark_stream_closed(t, s, 1, 1, error);
2372
2407
  grpc_core::MaybeTarpit(
@@ -2407,7 +2442,7 @@ static void close_from_api(grpc_chttp2_transport* t, grpc_chttp2_stream* s,
2407
2442
  *p++ = '2';
2408
2443
  *p++ = '0';
2409
2444
  *p++ = '0';
2410
- GPR_ASSERT(p == GRPC_SLICE_END_PTR(http_status_hdr));
2445
+ CHECK(p == GRPC_SLICE_END_PTR(http_status_hdr));
2411
2446
  len += static_cast<uint32_t> GRPC_SLICE_LENGTH(http_status_hdr);
2412
2447
 
2413
2448
  content_type_hdr = GRPC_SLICE_MALLOC(31);
@@ -2443,7 +2478,7 @@ static void close_from_api(grpc_chttp2_transport* t, grpc_chttp2_stream* s,
2443
2478
  *p++ = 'r';
2444
2479
  *p++ = 'p';
2445
2480
  *p++ = 'c';
2446
- GPR_ASSERT(p == GRPC_SLICE_END_PTR(content_type_hdr));
2481
+ CHECK(p == GRPC_SLICE_END_PTR(content_type_hdr));
2447
2482
  len += static_cast<uint32_t> GRPC_SLICE_LENGTH(content_type_hdr);
2448
2483
  }
2449
2484
 
@@ -2470,11 +2505,11 @@ static void close_from_api(grpc_chttp2_transport* t, grpc_chttp2_stream* s,
2470
2505
  *p++ = static_cast<uint8_t>('0' + (grpc_status / 10));
2471
2506
  *p++ = static_cast<uint8_t>('0' + (grpc_status % 10));
2472
2507
  }
2473
- GPR_ASSERT(p == GRPC_SLICE_END_PTR(status_hdr));
2508
+ CHECK(p == GRPC_SLICE_END_PTR(status_hdr));
2474
2509
  len += static_cast<uint32_t> GRPC_SLICE_LENGTH(status_hdr);
2475
2510
 
2476
2511
  size_t msg_len = message.length();
2477
- GPR_ASSERT(msg_len <= UINT32_MAX);
2512
+ CHECK(msg_len <= UINT32_MAX);
2478
2513
  grpc_core::VarintWriter<1> msg_len_writer(
2479
2514
  static_cast<uint32_t>(msg_len));
2480
2515
  message_pfx = GRPC_SLICE_MALLOC(14 + msg_len_writer.length());
@@ -2495,7 +2530,7 @@ static void close_from_api(grpc_chttp2_transport* t, grpc_chttp2_stream* s,
2495
2530
  *p++ = 'e';
2496
2531
  msg_len_writer.Write(0, p);
2497
2532
  p += msg_len_writer.length();
2498
- GPR_ASSERT(p == GRPC_SLICE_END_PTR(message_pfx));
2533
+ CHECK(p == GRPC_SLICE_END_PTR(message_pfx));
2499
2534
  len += static_cast<uint32_t> GRPC_SLICE_LENGTH(message_pfx);
2500
2535
  len += static_cast<uint32_t>(msg_len);
2501
2536
 
@@ -2511,7 +2546,7 @@ static void close_from_api(grpc_chttp2_transport* t, grpc_chttp2_stream* s,
2511
2546
  *p++ = static_cast<uint8_t>(id >> 16);
2512
2547
  *p++ = static_cast<uint8_t>(id >> 8);
2513
2548
  *p++ = static_cast<uint8_t>(id);
2514
- GPR_ASSERT(p == GRPC_SLICE_END_PTR(hdr));
2549
+ CHECK(p == GRPC_SLICE_END_PTR(hdr));
2515
2550
 
2516
2551
  grpc_slice_buffer_add(&t->qbuf, hdr);
2517
2552
  if (!sent_initial_metadata) {
@@ -2618,9 +2653,9 @@ static grpc_error_handle try_http_parsing(grpc_chttp2_transport* t) {
2618
2653
  if (parse_error.ok() &&
2619
2654
  (parse_error = grpc_http_parser_eof(&parser)) == absl::OkStatus()) {
2620
2655
  error = grpc_error_set_int(
2621
- grpc_error_set_int(
2622
- GRPC_ERROR_CREATE("Trying to connect an http1.x server"),
2623
- grpc_core::StatusIntProperty::kHttpStatus, response.status),
2656
+ GRPC_ERROR_CREATE(
2657
+ absl::StrCat("Trying to connect an http1.x server (HTTP status ",
2658
+ response.status, ")")),
2624
2659
  grpc_core::StatusIntProperty::kRpcStatus,
2625
2660
  grpc_http2_status_to_grpc_status(response.status));
2626
2661
  }
@@ -2712,11 +2747,10 @@ static void read_action_parse_loop_locked(
2712
2747
  if (keep_reading) {
2713
2748
  if (t->num_pending_induced_frames >= DEFAULT_MAX_PENDING_INDUCED_FRAMES) {
2714
2749
  t->reading_paused_on_pending_induced_frames = true;
2715
- GRPC_CHTTP2_IF_TRACING(
2716
- gpr_log(GPR_INFO,
2717
- "transport %p : Pausing reading due to too "
2718
- "many unwritten SETTINGS ACK and RST_STREAM frames",
2719
- t.get()));
2750
+ GRPC_TRACE_LOG(http, INFO)
2751
+ << "transport " << t.get()
2752
+ << " : Pausing reading due to too many unwritten "
2753
+ "SETTINGS ACK and RST_STREAM frames";
2720
2754
  } else {
2721
2755
  continue_read_action_locked(std::move(t));
2722
2756
  }
@@ -2729,11 +2763,10 @@ static void read_action_locked(
2729
2763
  // got an incoming read, cancel any pending keepalive timers
2730
2764
  t->keepalive_incoming_data_wanted = false;
2731
2765
  if (t->keepalive_ping_timeout_handle != TaskHandle::kInvalid) {
2732
- if (GRPC_TRACE_FLAG_ENABLED(grpc_ping_trace) ||
2733
- GRPC_TRACE_FLAG_ENABLED(grpc_keepalive_trace)) {
2734
- gpr_log(GPR_INFO,
2735
- "%s[%p]: Clear keepalive timer because data was received",
2736
- t->is_client ? "CLIENT" : "SERVER", t.get());
2766
+ if (GRPC_TRACE_FLAG_ENABLED(http2_ping) ||
2767
+ GRPC_TRACE_FLAG_ENABLED(http_keepalive)) {
2768
+ LOG(INFO) << (t->is_client ? "CLIENT" : "SERVER") << "[" << t.get()
2769
+ << "]: Clear keepalive timer because data was received";
2737
2770
  }
2738
2771
  t->event_engine->Cancel(
2739
2772
  std::exchange(t->keepalive_ping_timeout_handle, TaskHandle::kInvalid));
@@ -2752,7 +2785,7 @@ static void continue_read_action_locked(
2752
2785
  grpc_core::RefCountedPtr<grpc_chttp2_transport> t) {
2753
2786
  const bool urgent = !t->goaway_error.ok();
2754
2787
  auto* tp = t.get();
2755
- grpc_endpoint_read(tp->ep, &tp->read_buffer,
2788
+ grpc_endpoint_read(tp->ep.get(), &tp->read_buffer,
2756
2789
  grpc_core::InitTransportClosure<read_action>(
2757
2790
  std::move(t), &tp->read_action_locked),
2758
2791
  urgent, grpc_chttp2_min_read_progress_size(tp));
@@ -2783,10 +2816,9 @@ static void start_bdp_ping(grpc_core::RefCountedPtr<grpc_chttp2_transport> t,
2783
2816
  static void start_bdp_ping_locked(
2784
2817
  grpc_core::RefCountedPtr<grpc_chttp2_transport> t,
2785
2818
  grpc_error_handle error) {
2786
- if (GRPC_TRACE_FLAG_ENABLED(grpc_http_trace)) {
2787
- gpr_log(GPR_INFO, "%s: Start BDP ping err=%s",
2788
- std::string(t->peer_string.as_string_view()).c_str(),
2789
- grpc_core::StatusToString(error).c_str());
2819
+ if (GRPC_TRACE_FLAG_ENABLED(http)) {
2820
+ LOG(INFO) << t->peer_string.as_string_view()
2821
+ << ": Start BDP ping err=" << grpc_core::StatusToString(error);
2790
2822
  }
2791
2823
  if (!error.ok() || !t->closed_with_error.ok()) {
2792
2824
  return;
@@ -2810,10 +2842,9 @@ static void finish_bdp_ping(grpc_core::RefCountedPtr<grpc_chttp2_transport> t,
2810
2842
  static void finish_bdp_ping_locked(
2811
2843
  grpc_core::RefCountedPtr<grpc_chttp2_transport> t,
2812
2844
  grpc_error_handle error) {
2813
- if (GRPC_TRACE_FLAG_ENABLED(grpc_http_trace)) {
2814
- gpr_log(GPR_INFO, "%s: Complete BDP ping err=%s",
2815
- std::string(t->peer_string.as_string_view()).c_str(),
2816
- grpc_core::StatusToString(error).c_str());
2845
+ if (GRPC_TRACE_FLAG_ENABLED(http)) {
2846
+ LOG(INFO) << t->peer_string.as_string_view()
2847
+ << ": Complete BDP ping err=" << grpc_core::StatusToString(error);
2817
2848
  }
2818
2849
  if (!error.ok() || !t->closed_with_error.ok()) {
2819
2850
  return;
@@ -2829,7 +2860,7 @@ static void finish_bdp_ping_locked(
2829
2860
  t->flow_control.bdp_estimator()->CompletePing();
2830
2861
  grpc_chttp2_act_on_flowctl_action(t->flow_control.PeriodicUpdate(), t.get(),
2831
2862
  nullptr);
2832
- GPR_ASSERT(t->next_bdp_ping_timer_handle == TaskHandle::kInvalid);
2863
+ CHECK(t->next_bdp_ping_timer_handle == TaskHandle::kInvalid);
2833
2864
  t->next_bdp_ping_timer_handle =
2834
2865
  t->event_engine->RunAfter(next_ping - grpc_core::Timestamp::Now(), [t] {
2835
2866
  grpc_core::ApplicationCallbackExecCtx callback_exec_ctx;
@@ -2848,7 +2879,7 @@ static void next_bdp_ping_timer_expired(grpc_chttp2_transport* t) {
2848
2879
  static void next_bdp_ping_timer_expired_locked(
2849
2880
  grpc_core::RefCountedPtr<grpc_chttp2_transport> t,
2850
2881
  GRPC_UNUSED grpc_error_handle error) {
2851
- GPR_DEBUG_ASSERT(error.ok());
2882
+ DCHECK(error.ok());
2852
2883
  t->next_bdp_ping_timer_handle = TaskHandle::kInvalid;
2853
2884
  if (t->flow_control.bdp_estimator()->accumulator() == 0) {
2854
2885
  // Block the bdp ping till we receive more data.
@@ -2916,9 +2947,9 @@ static void init_keepalive_ping(
2916
2947
  static void init_keepalive_ping_locked(
2917
2948
  grpc_core::RefCountedPtr<grpc_chttp2_transport> t,
2918
2949
  GRPC_UNUSED grpc_error_handle error) {
2919
- GPR_DEBUG_ASSERT(error.ok());
2920
- GPR_ASSERT(t->keepalive_state == GRPC_CHTTP2_KEEPALIVE_STATE_WAITING);
2921
- GPR_ASSERT(t->keepalive_ping_timer_handle != TaskHandle::kInvalid);
2950
+ DCHECK(error.ok());
2951
+ CHECK(t->keepalive_state == GRPC_CHTTP2_KEEPALIVE_STATE_WAITING);
2952
+ CHECK(t->keepalive_ping_timer_handle != TaskHandle::kInvalid);
2922
2953
  t->keepalive_ping_timer_handle = TaskHandle::kInvalid;
2923
2954
  if (t->destroying || !t->closed_with_error.ok()) {
2924
2955
  t->keepalive_state = GRPC_CHTTP2_KEEPALIVE_STATE_DYING;
@@ -2954,13 +2985,13 @@ static void finish_keepalive_ping_locked(
2954
2985
  grpc_error_handle error) {
2955
2986
  if (t->keepalive_state == GRPC_CHTTP2_KEEPALIVE_STATE_PINGING) {
2956
2987
  if (error.ok()) {
2957
- if (GRPC_TRACE_FLAG_ENABLED(grpc_http_trace) ||
2958
- GRPC_TRACE_FLAG_ENABLED(grpc_keepalive_trace)) {
2959
- gpr_log(GPR_INFO, "%s: Finish keepalive ping",
2960
- std::string(t->peer_string.as_string_view()).c_str());
2988
+ if (GRPC_TRACE_FLAG_ENABLED(http) ||
2989
+ GRPC_TRACE_FLAG_ENABLED(http_keepalive)) {
2990
+ LOG(INFO) << t->peer_string.as_string_view()
2991
+ << ": Finish keepalive ping";
2961
2992
  }
2962
2993
  t->keepalive_state = GRPC_CHTTP2_KEEPALIVE_STATE_WAITING;
2963
- GPR_ASSERT(t->keepalive_ping_timer_handle == TaskHandle::kInvalid);
2994
+ CHECK(t->keepalive_ping_timer_handle == TaskHandle::kInvalid);
2964
2995
  t->keepalive_ping_timer_handle =
2965
2996
  t->event_engine->RunAfter(t->keepalive_time, [t] {
2966
2997
  grpc_core::ApplicationCallbackExecCtx callback_exec_ctx;
@@ -2976,10 +3007,10 @@ static void maybe_reset_keepalive_ping_timer_locked(grpc_chttp2_transport* t) {
2976
3007
  t->event_engine->Cancel(t->keepalive_ping_timer_handle)) {
2977
3008
  // Cancel succeeds, resets the keepalive ping timer. Note that we don't
2978
3009
  // need to Ref or Unref here since we still hold the Ref.
2979
- if (GRPC_TRACE_FLAG_ENABLED(grpc_http_trace) ||
2980
- GRPC_TRACE_FLAG_ENABLED(grpc_keepalive_trace)) {
2981
- gpr_log(GPR_INFO, "%s: Keepalive ping cancelled. Resetting timer.",
2982
- std::string(t->peer_string.as_string_view()).c_str());
3010
+ if (GRPC_TRACE_FLAG_ENABLED(http) ||
3011
+ GRPC_TRACE_FLAG_ENABLED(http_keepalive)) {
3012
+ LOG(INFO) << t->peer_string.as_string_view()
3013
+ << ": Keepalive ping cancelled. Resetting timer.";
2983
3014
  }
2984
3015
  t->keepalive_ping_timer_handle =
2985
3016
  t->event_engine->RunAfter(t->keepalive_time, [t = t->Ref()]() mutable {
@@ -2998,9 +3029,9 @@ static void connectivity_state_set(grpc_chttp2_transport* t,
2998
3029
  grpc_connectivity_state state,
2999
3030
  const absl::Status& status,
3000
3031
  const char* reason) {
3001
- GRPC_CHTTP2_IF_TRACING(gpr_log(
3002
- GPR_INFO, "transport %p set connectivity_state=%d; status=%s; reason=%s",
3003
- t, state, status.ToString().c_str(), reason));
3032
+ GRPC_TRACE_LOG(http, INFO)
3033
+ << "transport " << t << " set connectivity_state=" << state
3034
+ << "; status=" << status.ToString() << "; reason=" << reason;
3004
3035
  t->state_tracker.SetState(state, status, reason);
3005
3036
  }
3006
3037
 
@@ -3010,12 +3041,22 @@ static void connectivity_state_set(grpc_chttp2_transport* t,
3010
3041
 
3011
3042
  void grpc_chttp2_transport::SetPollset(grpc_stream* /*gs*/,
3012
3043
  grpc_pollset* pollset) {
3013
- grpc_endpoint_add_to_pollset(ep, pollset);
3044
+ // We don't want the overhead of acquiring the mutex unless we're
3045
+ // using the "poll" polling engine, which is the only one that
3046
+ // actually uses pollsets.
3047
+ if (strcmp(grpc_get_poll_strategy_name(), "poll") != 0) return;
3048
+ grpc_core::MutexLock lock(&ep_destroy_mu);
3049
+ if (ep != nullptr) grpc_endpoint_add_to_pollset(ep.get(), pollset);
3014
3050
  }
3015
3051
 
3016
3052
  void grpc_chttp2_transport::SetPollsetSet(grpc_stream* /*gs*/,
3017
3053
  grpc_pollset_set* pollset_set) {
3018
- grpc_endpoint_add_to_pollset_set(ep, pollset_set);
3054
+ // We don't want the overhead of acquiring the mutex unless we're
3055
+ // using the "poll" polling engine, which is the only one that
3056
+ // actually uses pollsets.
3057
+ if (strcmp(grpc_get_poll_strategy_name(), "poll") != 0) return;
3058
+ grpc_core::MutexLock lock(&ep_destroy_mu);
3059
+ if (ep != nullptr) grpc_endpoint_add_to_pollset_set(ep.get(), pollset_set);
3019
3060
  }
3020
3061
 
3021
3062
  //
@@ -3066,21 +3107,19 @@ static void benign_reclaimer_locked(
3066
3107
  if (error.ok() && t->stream_map.empty()) {
3067
3108
  // Channel with no active streams: send a goaway to try and make it
3068
3109
  // disconnect cleanly
3069
- if (GRPC_TRACE_FLAG_ENABLED(grpc_resource_quota_trace)) {
3070
- gpr_log(GPR_INFO, "HTTP2: %s - send goaway to free memory",
3071
- std::string(t->peer_string.as_string_view()).c_str());
3110
+ if (GRPC_TRACE_FLAG_ENABLED(resource_quota)) {
3111
+ LOG(INFO) << "HTTP2: " << t->peer_string.as_string_view()
3112
+ << " - send goaway to free memory";
3072
3113
  }
3073
3114
  send_goaway(t.get(),
3074
3115
  grpc_error_set_int(GRPC_ERROR_CREATE("Buffers full"),
3075
3116
  grpc_core::StatusIntProperty::kHttp2Error,
3076
3117
  GRPC_HTTP2_ENHANCE_YOUR_CALM),
3077
3118
  /*immediate_disconnect_hint=*/true);
3078
- } else if (error.ok() && GRPC_TRACE_FLAG_ENABLED(grpc_resource_quota_trace)) {
3079
- gpr_log(GPR_INFO,
3080
- "HTTP2: %s - skip benign reclamation, there are still %" PRIdPTR
3081
- " streams",
3082
- std::string(t->peer_string.as_string_view()).c_str(),
3083
- t->stream_map.size());
3119
+ } else if (error.ok() && GRPC_TRACE_FLAG_ENABLED(resource_quota)) {
3120
+ LOG(INFO) << "HTTP2: " << t->peer_string.as_string_view()
3121
+ << " - skip benign reclamation, there are still "
3122
+ << t->stream_map.size() << " streams";
3084
3123
  }
3085
3124
  t->benign_reclaimer_registered = false;
3086
3125
  if (error != absl::CancelledError()) {
@@ -3095,9 +3134,9 @@ static void destructive_reclaimer_locked(
3095
3134
  if (error.ok() && !t->stream_map.empty()) {
3096
3135
  // As stream_map is a hash map, this selects effectively a random stream.
3097
3136
  grpc_chttp2_stream* s = t->stream_map.begin()->second;
3098
- if (GRPC_TRACE_FLAG_ENABLED(grpc_resource_quota_trace)) {
3099
- gpr_log(GPR_INFO, "HTTP2: %s - abandon stream id %d",
3100
- std::string(t->peer_string.as_string_view()).c_str(), s->id);
3137
+ if (GRPC_TRACE_FLAG_ENABLED(resource_quota)) {
3138
+ LOG(INFO) << "HTTP2: " << t->peer_string.as_string_view()
3139
+ << " - abandon stream id " << s->id;
3101
3140
  }
3102
3141
  grpc_chttp2_cancel_stream(
3103
3142
  t.get(), s,
@@ -3173,8 +3212,6 @@ const char* grpc_chttp2_initiate_write_reason_string(
3173
3212
  GPR_UNREACHABLE_CODE(return "unknown");
3174
3213
  }
3175
3214
 
3176
- grpc_endpoint* grpc_chttp2_transport::GetEndpoint() { return ep; }
3177
-
3178
3215
  size_t grpc_chttp2_transport::SizeOfStream() const {
3179
3216
  return sizeof(grpc_chttp2_stream);
3180
3217
  }
@@ -3196,25 +3233,32 @@ grpc_chttp2_transport_get_socket_node(grpc_core::Transport* transport) {
3196
3233
  }
3197
3234
 
3198
3235
  grpc_core::Transport* grpc_create_chttp2_transport(
3199
- const grpc_core::ChannelArgs& channel_args, grpc_endpoint* ep,
3200
- bool is_client) {
3201
- return new grpc_chttp2_transport(channel_args, ep, is_client);
3236
+ const grpc_core::ChannelArgs& channel_args,
3237
+ grpc_core::OrphanablePtr<grpc_endpoint> ep, bool is_client) {
3238
+ return new grpc_chttp2_transport(channel_args, std::move(ep), is_client);
3202
3239
  }
3203
3240
 
3204
3241
  void grpc_chttp2_transport_start_reading(
3205
3242
  grpc_core::Transport* transport, grpc_slice_buffer* read_buffer,
3206
- grpc_closure* notify_on_receive_settings, grpc_closure* notify_on_close) {
3243
+ grpc_closure* notify_on_receive_settings,
3244
+ grpc_pollset_set* interested_parties_until_recv_settings,
3245
+ grpc_closure* notify_on_close) {
3207
3246
  auto t = reinterpret_cast<grpc_chttp2_transport*>(transport)->Ref();
3208
3247
  if (read_buffer != nullptr) {
3209
3248
  grpc_slice_buffer_move_into(read_buffer, &t->read_buffer);
3210
- gpr_free(read_buffer);
3211
3249
  }
3212
3250
  auto* tp = t.get();
3213
3251
  tp->combiner->Run(
3214
3252
  grpc_core::NewClosure([t = std::move(t), notify_on_receive_settings,
3253
+ interested_parties_until_recv_settings,
3215
3254
  notify_on_close](grpc_error_handle) mutable {
3216
3255
  if (!t->closed_with_error.ok()) {
3217
3256
  if (notify_on_receive_settings != nullptr) {
3257
+ if (t->ep != nullptr &&
3258
+ interested_parties_until_recv_settings != nullptr) {
3259
+ grpc_endpoint_delete_from_pollset_set(
3260
+ t->ep.get(), interested_parties_until_recv_settings);
3261
+ }
3218
3262
  grpc_core::ExecCtx::Run(DEBUG_LOCATION, notify_on_receive_settings,
3219
3263
  t->closed_with_error);
3220
3264
  }
@@ -3224,6 +3268,8 @@ void grpc_chttp2_transport_start_reading(
3224
3268
  }
3225
3269
  return;
3226
3270
  }
3271
+ t->interested_parties_until_recv_settings =
3272
+ interested_parties_until_recv_settings;
3227
3273
  t->notify_on_receive_settings = notify_on_receive_settings;
3228
3274
  t->notify_on_close = notify_on_close;
3229
3275
  read_action_locked(std::move(t), absl::OkStatus());