grpc 1.48.0-x86_64-linux → 1.49.0.pre1-x86_64-linux

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


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

Files changed (721) hide show
  1. checksums.yaml +4 -4
  2. data/Makefile +104 -41
  3. data/include/grpc/event_engine/event_engine.h +19 -16
  4. data/include/grpc/impl/codegen/grpc_types.h +3 -8
  5. data/include/grpc/impl/codegen/port_platform.h +0 -8
  6. data/src/core/ext/filters/channel_idle/channel_idle_filter.cc +3 -3
  7. data/src/core/ext/filters/channel_idle/channel_idle_filter.h +2 -2
  8. data/src/core/ext/filters/client_channel/client_channel.cc +117 -200
  9. data/src/core/ext/filters/client_channel/client_channel.h +15 -8
  10. data/src/core/ext/filters/client_channel/client_channel_factory.cc +0 -29
  11. data/src/core/ext/filters/client_channel/client_channel_factory.h +2 -10
  12. data/src/core/ext/filters/client_channel/client_channel_plugin.cc +1 -1
  13. data/src/core/ext/filters/client_channel/config_selector.h +12 -4
  14. data/src/core/ext/filters/client_channel/connector.h +4 -5
  15. data/src/core/ext/filters/client_channel/http_proxy.cc +53 -65
  16. data/src/core/ext/filters/client_channel/http_proxy.h +12 -9
  17. data/src/core/ext/filters/client_channel/lb_policy/child_policy_handler.cc +14 -12
  18. data/src/core/ext/filters/client_channel/lb_policy/child_policy_handler.h +6 -6
  19. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb.cc +100 -124
  20. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_balancer_addresses.cc +12 -3
  21. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_balancer_addresses.h +5 -1
  22. data/src/core/ext/filters/client_channel/lb_policy/grpclb/load_balancer_api.cc +1 -0
  23. data/src/core/ext/filters/client_channel/lb_policy/grpclb/load_balancer_api.h +1 -2
  24. data/src/core/ext/filters/client_channel/lb_policy/oob_backend_metric.h +1 -1
  25. data/src/core/ext/filters/client_channel/lb_policy/outlier_detection/outlier_detection.cc +169 -63
  26. data/src/core/ext/filters/client_channel/lb_policy/outlier_detection/outlier_detection.h +25 -1
  27. data/src/core/ext/filters/client_channel/lb_policy/pick_first/pick_first.cc +15 -19
  28. data/src/core/ext/filters/client_channel/lb_policy/priority/priority.cc +66 -78
  29. data/src/core/ext/filters/client_channel/lb_policy/ring_hash/ring_hash.cc +44 -44
  30. data/src/core/ext/filters/client_channel/lb_policy/ring_hash/ring_hash.h +6 -5
  31. data/src/core/ext/filters/client_channel/lb_policy/rls/rls.cc +65 -77
  32. data/src/core/ext/filters/client_channel/lb_policy/round_robin/round_robin.cc +15 -14
  33. data/src/core/ext/filters/client_channel/lb_policy/subchannel_list.h +19 -14
  34. data/src/core/ext/filters/client_channel/lb_policy/weighted_target/weighted_target.cc +60 -67
  35. data/src/core/ext/filters/client_channel/lb_policy/xds/cds.cc +40 -49
  36. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_impl.cc +81 -97
  37. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_manager.cc +53 -61
  38. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_resolver.cc +171 -102
  39. data/src/core/ext/filters/client_channel/proxy_mapper.h +13 -14
  40. data/src/core/ext/filters/client_channel/proxy_mapper_registry.cc +19 -16
  41. data/src/core/ext/filters/client_channel/proxy_mapper_registry.h +8 -7
  42. data/src/core/ext/filters/client_channel/resolver/binder/binder_resolver.cc +4 -8
  43. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/dns_resolver_ares.cc +431 -145
  44. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.cc +170 -99
  45. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.h +20 -7
  46. data/src/core/ext/filters/client_channel/resolver/dns/native/dns_resolver.cc +17 -15
  47. data/src/core/ext/filters/client_channel/resolver/fake/fake_resolver.cc +7 -17
  48. data/src/core/ext/filters/client_channel/resolver/fake/fake_resolver.h +11 -0
  49. data/src/core/ext/filters/client_channel/resolver/google_c2p/google_c2p_resolver.cc +13 -14
  50. data/src/core/ext/filters/client_channel/resolver/polling_resolver.cc +3 -4
  51. data/src/core/ext/filters/client_channel/resolver/polling_resolver.h +5 -6
  52. data/src/core/ext/filters/client_channel/resolver/sockaddr/sockaddr_resolver.cc +4 -13
  53. data/src/core/ext/filters/client_channel/resolver/xds/xds_resolver.cc +162 -165
  54. data/src/core/ext/filters/client_channel/resolver_result_parsing.cc +37 -30
  55. data/src/core/ext/filters/client_channel/resolver_result_parsing.h +7 -10
  56. data/src/core/ext/filters/client_channel/retry_filter.cc +0 -7
  57. data/src/core/ext/filters/client_channel/retry_service_config.cc +30 -19
  58. data/src/core/ext/filters/client_channel/retry_service_config.h +6 -9
  59. data/src/core/ext/filters/client_channel/service_config_channel_arg_filter.cc +6 -7
  60. data/src/core/ext/filters/client_channel/subchannel.cc +49 -89
  61. data/src/core/ext/filters/client_channel/subchannel.h +8 -8
  62. data/src/core/ext/filters/client_channel/subchannel_interface_internal.h +1 -1
  63. data/src/core/ext/filters/client_channel/subchannel_pool_interface.cc +6 -76
  64. data/src/core/ext/filters/client_channel/subchannel_pool_interface.h +16 -25
  65. data/src/core/ext/filters/client_channel/subchannel_stream_client.cc +3 -4
  66. data/src/core/ext/filters/deadline/deadline_filter.cc +6 -6
  67. data/src/core/ext/filters/deadline/deadline_filter.h +2 -3
  68. data/src/core/ext/filters/fault_injection/fault_injection_filter.cc +1 -3
  69. data/src/core/ext/filters/fault_injection/fault_injection_filter.h +1 -1
  70. data/src/core/ext/filters/fault_injection/service_config_parser.cc +17 -12
  71. data/src/core/ext/filters/fault_injection/service_config_parser.h +4 -5
  72. data/src/core/ext/filters/http/client/http_client_filter.cc +2 -3
  73. data/src/core/ext/filters/http/client/http_client_filter.h +1 -1
  74. data/src/core/ext/filters/http/client_authority_filter.cc +1 -2
  75. data/src/core/ext/filters/http/client_authority_filter.h +1 -1
  76. data/src/core/ext/filters/http/server/http_server_filter.cc +2 -3
  77. data/src/core/ext/filters/http/server/http_server_filter.h +1 -1
  78. data/src/core/ext/filters/message_size/message_size_filter.cc +13 -7
  79. data/src/core/ext/filters/message_size/message_size_filter.h +3 -6
  80. data/src/core/ext/filters/rbac/rbac_service_config_parser.cc +16 -12
  81. data/src/core/ext/filters/rbac/rbac_service_config_parser.h +4 -6
  82. data/src/core/ext/filters/server_config_selector/server_config_selector.h +5 -0
  83. data/src/core/ext/filters/server_config_selector/server_config_selector_filter.cc +3 -5
  84. data/src/core/ext/transport/chttp2/client/chttp2_connector.cc +35 -62
  85. data/src/core/ext/transport/chttp2/server/chttp2_server.cc +62 -89
  86. data/src/core/ext/transport/chttp2/server/chttp2_server.h +4 -6
  87. data/src/core/ext/transport/chttp2/transport/chttp2_transport.cc +130 -165
  88. data/src/core/ext/transport/chttp2/transport/chttp2_transport.h +3 -2
  89. data/src/core/ext/transport/chttp2/transport/flow_control.cc +67 -2
  90. data/src/core/ext/transport/chttp2/transport/flow_control.h +1 -0
  91. data/src/core/ext/transport/chttp2/transport/hpack_constants.h +7 -1
  92. data/src/core/ext/transport/chttp2/transport/hpack_encoder.cc +25 -8
  93. data/src/core/ext/transport/chttp2/transport/hpack_encoder.h +4 -0
  94. data/src/core/ext/transport/chttp2/transport/hpack_encoder_table.cc +0 -1
  95. data/src/core/ext/transport/chttp2/transport/hpack_encoder_table.h +8 -2
  96. data/src/core/ext/transport/chttp2/transport/hpack_parser.cc +2 -10
  97. data/src/core/ext/transport/chttp2/transport/internal.h +2 -1
  98. data/src/core/ext/transport/inproc/inproc_transport.cc +40 -74
  99. data/src/core/ext/upb-generated/envoy/admin/v3/certs.upb.c +5 -5
  100. data/src/core/ext/upb-generated/envoy/admin/v3/certs.upb.h +30 -10
  101. data/src/core/ext/upb-generated/envoy/admin/v3/clusters.upb.c +4 -4
  102. data/src/core/ext/upb-generated/envoy/admin/v3/clusters.upb.h +24 -8
  103. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump.upb.c +8 -327
  104. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump.upb.h +83 -1723
  105. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump_shared.upb.c +352 -0
  106. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump_shared.upb.h +1768 -0
  107. data/src/core/ext/upb-generated/envoy/admin/v3/init_dump.upb.c +2 -2
  108. data/src/core/ext/upb-generated/envoy/admin/v3/init_dump.upb.h +12 -4
  109. data/src/core/ext/upb-generated/envoy/admin/v3/listeners.upb.c +6 -4
  110. data/src/core/ext/upb-generated/envoy/admin/v3/listeners.upb.h +33 -4
  111. data/src/core/ext/upb-generated/envoy/admin/v3/memory.upb.c +1 -1
  112. data/src/core/ext/upb-generated/envoy/admin/v3/memory.upb.h +6 -2
  113. data/src/core/ext/upb-generated/envoy/admin/v3/metrics.upb.c +1 -1
  114. data/src/core/ext/upb-generated/envoy/admin/v3/metrics.upb.h +6 -2
  115. data/src/core/ext/upb-generated/envoy/admin/v3/mutex_stats.upb.h +6 -2
  116. data/src/core/ext/upb-generated/envoy/admin/v3/server_info.upb.h +12 -4
  117. data/src/core/ext/upb-generated/envoy/admin/v3/tap.upb.c +1 -1
  118. data/src/core/ext/upb-generated/envoy/admin/v3/tap.upb.h +6 -2
  119. data/src/core/ext/upb-generated/envoy/annotations/resource.upb.c +1 -1
  120. data/src/core/ext/upb-generated/envoy/annotations/resource.upb.h +7 -3
  121. data/src/core/ext/upb-generated/envoy/config/accesslog/v3/accesslog.upb.c +14 -14
  122. data/src/core/ext/upb-generated/envoy/config/accesslog/v3/accesslog.upb.h +90 -30
  123. data/src/core/ext/upb-generated/envoy/config/bootstrap/v3/bootstrap.upb.c +21 -19
  124. data/src/core/ext/upb-generated/envoy/config/bootstrap/v3/bootstrap.upb.h +124 -34
  125. data/src/core/ext/upb-generated/envoy/config/cluster/v3/circuit_breaker.upb.c +3 -3
  126. data/src/core/ext/upb-generated/envoy/config/cluster/v3/circuit_breaker.upb.h +18 -6
  127. data/src/core/ext/upb-generated/envoy/config/cluster/v3/cluster.upb.c +23 -22
  128. data/src/core/ext/upb-generated/envoy/config/cluster/v3/cluster.upb.h +153 -48
  129. data/src/core/ext/upb-generated/envoy/config/cluster/v3/filter.upb.c +1 -1
  130. data/src/core/ext/upb-generated/envoy/config/cluster/v3/filter.upb.h +6 -2
  131. data/src/core/ext/upb-generated/envoy/config/cluster/v3/outlier_detection.upb.c +1 -1
  132. data/src/core/ext/upb-generated/envoy/config/cluster/v3/outlier_detection.upb.h +6 -2
  133. data/src/core/ext/upb-generated/envoy/config/common/matcher/v3/matcher.upb.c +11 -11
  134. data/src/core/ext/upb-generated/envoy/config/common/matcher/v3/matcher.upb.h +84 -28
  135. data/src/core/ext/upb-generated/envoy/config/core/v3/address.upb.c +7 -7
  136. data/src/core/ext/upb-generated/envoy/config/core/v3/address.upb.h +42 -14
  137. data/src/core/ext/upb-generated/envoy/config/core/v3/backoff.upb.c +1 -1
  138. data/src/core/ext/upb-generated/envoy/config/core/v3/backoff.upb.h +6 -2
  139. data/src/core/ext/upb-generated/envoy/config/core/v3/base.upb.c +25 -23
  140. data/src/core/ext/upb-generated/envoy/config/core/v3/base.upb.h +156 -48
  141. data/src/core/ext/upb-generated/envoy/config/core/v3/config_source.upb.c +7 -7
  142. data/src/core/ext/upb-generated/envoy/config/core/v3/config_source.upb.h +42 -14
  143. data/src/core/ext/upb-generated/envoy/config/core/v3/event_service_config.upb.c +1 -1
  144. data/src/core/ext/upb-generated/envoy/config/core/v3/event_service_config.upb.h +6 -2
  145. data/src/core/ext/upb-generated/envoy/config/core/v3/extension.upb.c +1 -1
  146. data/src/core/ext/upb-generated/envoy/config/core/v3/extension.upb.h +6 -2
  147. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_method_list.upb.c +2 -2
  148. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_method_list.upb.h +12 -4
  149. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_service.upb.c +12 -12
  150. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_service.upb.h +78 -26
  151. data/src/core/ext/upb-generated/envoy/config/core/v3/health_check.upb.c +9 -9
  152. data/src/core/ext/upb-generated/envoy/config/core/v3/health_check.upb.h +54 -18
  153. data/src/core/ext/upb-generated/envoy/config/core/v3/http_uri.upb.c +1 -1
  154. data/src/core/ext/upb-generated/envoy/config/core/v3/http_uri.upb.h +6 -2
  155. data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.c +21 -20
  156. data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.h +117 -44
  157. data/src/core/ext/upb-generated/envoy/config/core/v3/proxy_protocol.upb.c +1 -1
  158. data/src/core/ext/upb-generated/envoy/config/core/v3/proxy_protocol.upb.h +6 -2
  159. data/src/core/ext/upb-generated/envoy/config/core/v3/resolver.upb.c +2 -2
  160. data/src/core/ext/upb-generated/envoy/config/core/v3/resolver.upb.h +12 -4
  161. data/src/core/ext/upb-generated/envoy/config/core/v3/socket_option.upb.h +6 -2
  162. data/src/core/ext/upb-generated/envoy/config/core/v3/substitution_format_string.upb.c +1 -1
  163. data/src/core/ext/upb-generated/envoy/config/core/v3/substitution_format_string.upb.h +6 -2
  164. data/src/core/ext/upb-generated/envoy/config/core/v3/udp_socket_config.upb.c +1 -1
  165. data/src/core/ext/upb-generated/envoy/config/core/v3/udp_socket_config.upb.h +6 -2
  166. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint.upb.c +3 -3
  167. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint.upb.h +18 -6
  168. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint_components.upb.c +5 -5
  169. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint_components.upb.h +36 -12
  170. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/load_report.upb.c +3 -3
  171. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/load_report.upb.h +30 -10
  172. data/src/core/ext/upb-generated/envoy/config/listener/v3/api_listener.upb.c +1 -1
  173. data/src/core/ext/upb-generated/envoy/config/listener/v3/api_listener.upb.h +6 -2
  174. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener.upb.c +37 -13
  175. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener.upb.h +170 -15
  176. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener_components.upb.c +5 -5
  177. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener_components.upb.h +42 -14
  178. data/src/core/ext/upb-generated/envoy/config/listener/v3/quic_config.upb.c +1 -1
  179. data/src/core/ext/upb-generated/envoy/config/listener/v3/quic_config.upb.h +6 -2
  180. data/src/core/ext/upb-generated/envoy/config/listener/v3/udp_listener_config.upb.c +7 -4
  181. data/src/core/ext/upb-generated/envoy/config/listener/v3/udp_listener_config.upb.h +36 -4
  182. data/src/core/ext/upb-generated/envoy/config/metrics/v3/metrics_service.upb.c +1 -1
  183. data/src/core/ext/upb-generated/envoy/config/metrics/v3/metrics_service.upb.h +6 -2
  184. data/src/core/ext/upb-generated/envoy/config/metrics/v3/stats.upb.c +6 -6
  185. data/src/core/ext/upb-generated/envoy/config/metrics/v3/stats.upb.h +48 -16
  186. data/src/core/ext/upb-generated/envoy/config/overload/v3/overload.upb.c +8 -8
  187. data/src/core/ext/upb-generated/envoy/config/overload/v3/overload.upb.h +54 -18
  188. data/src/core/ext/upb-generated/envoy/config/rbac/v3/rbac.upb.c +21 -9
  189. data/src/core/ext/upb-generated/envoy/config/rbac/v3/rbac.upb.h +100 -14
  190. data/src/core/ext/upb-generated/envoy/config/route/v3/route.upb.c +7 -22
  191. data/src/core/ext/upb-generated/envoy/config/route/v3/route.upb.h +36 -77
  192. data/src/core/ext/upb-generated/envoy/config/route/v3/route_components.upb.c +121 -76
  193. data/src/core/ext/upb-generated/envoy/config/route/v3/route_components.upb.h +647 -163
  194. data/src/core/ext/upb-generated/envoy/config/route/v3/scoped_route.upb.c +3 -3
  195. data/src/core/ext/upb-generated/envoy/config/route/v3/scoped_route.upb.h +18 -6
  196. data/src/core/ext/upb-generated/envoy/config/tap/v3/common.upb.c +34 -15
  197. data/src/core/ext/upb-generated/envoy/config/tap/v3/common.upb.h +161 -22
  198. data/src/core/ext/upb-generated/envoy/config/trace/v3/datadog.upb.c +1 -1
  199. data/src/core/ext/upb-generated/envoy/config/trace/v3/datadog.upb.h +6 -2
  200. data/src/core/ext/upb-generated/envoy/config/trace/v3/dynamic_ot.upb.c +1 -1
  201. data/src/core/ext/upb-generated/envoy/config/trace/v3/dynamic_ot.upb.h +6 -2
  202. data/src/core/ext/upb-generated/envoy/config/trace/v3/http_tracer.upb.c +2 -2
  203. data/src/core/ext/upb-generated/envoy/config/trace/v3/http_tracer.upb.h +12 -4
  204. data/src/core/ext/upb-generated/envoy/config/trace/v3/lightstep.upb.c +1 -1
  205. data/src/core/ext/upb-generated/envoy/config/trace/v3/lightstep.upb.h +6 -2
  206. data/src/core/ext/upb-generated/envoy/config/trace/v3/opencensus.upb.c +1 -1
  207. data/src/core/ext/upb-generated/envoy/config/trace/v3/opencensus.upb.h +6 -2
  208. data/src/core/ext/upb-generated/envoy/config/trace/v3/opentelemetry.upb.c +46 -0
  209. data/src/core/ext/upb-generated/envoy/config/trace/v3/opentelemetry.upb.h +98 -0
  210. data/src/core/ext/upb-generated/envoy/config/trace/v3/service.upb.c +1 -1
  211. data/src/core/ext/upb-generated/envoy/config/trace/v3/service.upb.h +6 -2
  212. data/src/core/ext/upb-generated/envoy/config/trace/v3/skywalking.upb.c +2 -2
  213. data/src/core/ext/upb-generated/envoy/config/trace/v3/skywalking.upb.h +12 -4
  214. data/src/core/ext/upb-generated/envoy/config/trace/v3/trace.upb.c +1 -0
  215. data/src/core/ext/upb-generated/envoy/config/trace/v3/trace.upb.h +1 -0
  216. data/src/core/ext/upb-generated/envoy/config/trace/v3/xray.upb.c +2 -2
  217. data/src/core/ext/upb-generated/envoy/config/trace/v3/xray.upb.h +12 -4
  218. data/src/core/ext/upb-generated/envoy/config/trace/v3/zipkin.upb.c +1 -1
  219. data/src/core/ext/upb-generated/envoy/config/trace/v3/zipkin.upb.h +6 -2
  220. data/src/core/ext/upb-generated/envoy/extensions/clusters/aggregate/v3/cluster.upb.c +1 -1
  221. data/src/core/ext/upb-generated/envoy/extensions/clusters/aggregate/v3/cluster.upb.h +6 -2
  222. data/src/core/ext/upb-generated/envoy/extensions/filters/common/fault/v3/fault.upb.c +2 -2
  223. data/src/core/ext/upb-generated/envoy/extensions/filters/common/fault/v3/fault.upb.h +30 -10
  224. data/src/core/ext/upb-generated/envoy/extensions/filters/http/fault/v3/fault.upb.c +2 -2
  225. data/src/core/ext/upb-generated/envoy/extensions/filters/http/fault/v3/fault.upb.h +18 -6
  226. data/src/core/ext/upb-generated/envoy/extensions/filters/http/rbac/v3/rbac.upb.c +11 -4
  227. data/src/core/ext/upb-generated/envoy/extensions/filters/http/rbac/v3/rbac.upb.h +58 -4
  228. data/src/core/ext/upb-generated/envoy/extensions/filters/http/router/v3/router.upb.c +1 -1
  229. data/src/core/ext/upb-generated/envoy/extensions/filters/http/router/v3/router.upb.h +6 -2
  230. data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.c +35 -27
  231. data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.h +177 -52
  232. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/ring_hash/v3/ring_hash.upb.h +6 -2
  233. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/wrr_locality/v3/wrr_locality.upb.c +1 -1
  234. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/wrr_locality/v3/wrr_locality.upb.h +6 -2
  235. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/common.upb.c +10 -8
  236. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/common.upb.h +66 -14
  237. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/secret.upb.c +3 -3
  238. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/secret.upb.h +18 -6
  239. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls.upb.c +5 -5
  240. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls.upb.h +42 -14
  241. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upb.c +2 -2
  242. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upb.h +12 -4
  243. data/src/core/ext/upb-generated/envoy/service/discovery/v3/ads.upb.c +1 -1
  244. data/src/core/ext/upb-generated/envoy/service/discovery/v3/ads.upb.h +6 -2
  245. data/src/core/ext/upb-generated/envoy/service/discovery/v3/discovery.upb.c +131 -16
  246. data/src/core/ext/upb-generated/envoy/service/discovery/v3/discovery.upb.h +632 -12
  247. data/src/core/ext/upb-generated/envoy/service/load_stats/v3/lrs.upb.c +2 -2
  248. data/src/core/ext/upb-generated/envoy/service/load_stats/v3/lrs.upb.h +12 -4
  249. data/src/core/ext/upb-generated/envoy/service/status/v3/csds.upb.c +5 -5
  250. data/src/core/ext/upb-generated/envoy/service/status/v3/csds.upb.h +30 -10
  251. data/src/core/ext/upb-generated/envoy/type/http/v3/cookie.upb.c +1 -1
  252. data/src/core/ext/upb-generated/envoy/type/http/v3/cookie.upb.h +6 -2
  253. data/src/core/ext/upb-generated/envoy/type/http/v3/path_transformation.upb.c +4 -4
  254. data/src/core/ext/upb-generated/envoy/type/http/v3/path_transformation.upb.h +24 -8
  255. data/src/core/ext/upb-generated/envoy/type/matcher/v3/http_inputs.upb.c +4 -4
  256. data/src/core/ext/upb-generated/envoy/type/matcher/v3/http_inputs.upb.h +24 -8
  257. data/src/core/ext/upb-generated/envoy/type/matcher/v3/metadata.upb.c +2 -2
  258. data/src/core/ext/upb-generated/envoy/type/matcher/v3/metadata.upb.h +12 -4
  259. data/src/core/ext/upb-generated/envoy/type/matcher/v3/node.upb.c +1 -1
  260. data/src/core/ext/upb-generated/envoy/type/matcher/v3/node.upb.h +6 -2
  261. data/src/core/ext/upb-generated/envoy/type/matcher/v3/number.upb.c +1 -1
  262. data/src/core/ext/upb-generated/envoy/type/matcher/v3/number.upb.h +6 -2
  263. data/src/core/ext/upb-generated/envoy/type/matcher/v3/path.upb.c +1 -1
  264. data/src/core/ext/upb-generated/envoy/type/matcher/v3/path.upb.h +6 -2
  265. data/src/core/ext/upb-generated/envoy/type/matcher/v3/regex.upb.c +3 -3
  266. data/src/core/ext/upb-generated/envoy/type/matcher/v3/regex.upb.h +18 -6
  267. data/src/core/ext/upb-generated/envoy/type/matcher/v3/string.upb.c +1 -1
  268. data/src/core/ext/upb-generated/envoy/type/matcher/v3/string.upb.h +12 -4
  269. data/src/core/ext/upb-generated/envoy/type/matcher/v3/struct.upb.c +2 -2
  270. data/src/core/ext/upb-generated/envoy/type/matcher/v3/struct.upb.h +12 -4
  271. data/src/core/ext/upb-generated/envoy/type/matcher/v3/value.upb.c +3 -3
  272. data/src/core/ext/upb-generated/envoy/type/matcher/v3/value.upb.h +18 -6
  273. data/src/core/ext/upb-generated/envoy/type/metadata/v3/metadata.upb.c +7 -7
  274. data/src/core/ext/upb-generated/envoy/type/metadata/v3/metadata.upb.h +42 -14
  275. data/src/core/ext/upb-generated/envoy/type/tracing/v3/custom_tag.upb.c +5 -5
  276. data/src/core/ext/upb-generated/envoy/type/tracing/v3/custom_tag.upb.h +30 -10
  277. data/src/core/ext/upb-generated/envoy/type/v3/hash_policy.upb.c +3 -3
  278. data/src/core/ext/upb-generated/envoy/type/v3/hash_policy.upb.h +18 -6
  279. data/src/core/ext/upb-generated/envoy/type/v3/http_status.upb.c +1 -1
  280. data/src/core/ext/upb-generated/envoy/type/v3/http_status.upb.h +6 -2
  281. data/src/core/ext/upb-generated/envoy/type/v3/percent.upb.h +12 -4
  282. data/src/core/ext/upb-generated/envoy/type/v3/range.upb.c +2 -2
  283. data/src/core/ext/upb-generated/envoy/type/v3/range.upb.h +18 -6
  284. data/src/core/ext/upb-generated/envoy/type/v3/ratelimit_strategy.upb.c +63 -0
  285. data/src/core/ext/upb-generated/envoy/type/v3/ratelimit_strategy.upb.h +202 -0
  286. data/src/core/ext/upb-generated/envoy/type/v3/semantic_version.upb.c +1 -1
  287. data/src/core/ext/upb-generated/envoy/type/v3/semantic_version.upb.h +6 -2
  288. data/src/core/ext/upb-generated/envoy/type/v3/token_bucket.upb.h +6 -2
  289. data/src/core/ext/upb-generated/google/api/annotations.upb.h +1 -1
  290. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/checked.upb.c +11 -11
  291. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/checked.upb.h +66 -22
  292. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/syntax.upb.c +9 -9
  293. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/syntax.upb.h +72 -24
  294. data/src/core/ext/upb-generated/google/api/http.upb.c +3 -3
  295. data/src/core/ext/upb-generated/google/api/http.upb.h +18 -6
  296. data/src/core/ext/upb-generated/google/api/httpbody.upb.c +1 -1
  297. data/src/core/ext/upb-generated/google/api/httpbody.upb.h +6 -2
  298. data/src/core/ext/upb-generated/google/protobuf/any.upb.c +1 -1
  299. data/src/core/ext/upb-generated/google/protobuf/any.upb.h +6 -2
  300. data/src/core/ext/upb-generated/google/protobuf/descriptor.upb.c +44 -43
  301. data/src/core/ext/upb-generated/google/protobuf/descriptor.upb.h +177 -55
  302. data/src/core/ext/upb-generated/google/protobuf/duration.upb.c +1 -1
  303. data/src/core/ext/upb-generated/google/protobuf/duration.upb.h +6 -2
  304. data/src/core/ext/upb-generated/google/protobuf/empty.upb.c +1 -1
  305. data/src/core/ext/upb-generated/google/protobuf/empty.upb.h +6 -2
  306. data/src/core/ext/upb-generated/google/protobuf/struct.upb.c +2 -2
  307. data/src/core/ext/upb-generated/google/protobuf/struct.upb.h +18 -6
  308. data/src/core/ext/upb-generated/google/protobuf/timestamp.upb.c +1 -1
  309. data/src/core/ext/upb-generated/google/protobuf/timestamp.upb.h +6 -2
  310. data/src/core/ext/upb-generated/google/protobuf/wrappers.upb.c +6 -6
  311. data/src/core/ext/upb-generated/google/protobuf/wrappers.upb.h +54 -18
  312. data/src/core/ext/upb-generated/google/rpc/status.upb.c +1 -1
  313. data/src/core/ext/upb-generated/google/rpc/status.upb.h +6 -2
  314. data/src/core/ext/upb-generated/opencensus/proto/trace/v1/trace_config.upb.c +2 -2
  315. data/src/core/ext/upb-generated/opencensus/proto/trace/v1/trace_config.upb.h +24 -8
  316. data/src/core/ext/upb-generated/src/proto/grpc/gcp/altscontext.upb.h +6 -2
  317. data/src/core/ext/upb-generated/src/proto/grpc/gcp/handshaker.upb.c +7 -7
  318. data/src/core/ext/upb-generated/src/proto/grpc/gcp/handshaker.upb.h +60 -20
  319. data/src/core/ext/upb-generated/src/proto/grpc/gcp/transport_security_common.upb.c +1 -1
  320. data/src/core/ext/upb-generated/src/proto/grpc/gcp/transport_security_common.upb.h +12 -4
  321. data/src/core/ext/upb-generated/src/proto/grpc/health/v1/health.upb.c +2 -2
  322. data/src/core/ext/upb-generated/src/proto/grpc/health/v1/health.upb.h +12 -4
  323. data/src/core/ext/upb-generated/src/proto/grpc/lb/v1/load_balancer.upb.c +6 -6
  324. data/src/core/ext/upb-generated/src/proto/grpc/lb/v1/load_balancer.upb.h +54 -18
  325. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls.upb.c +2 -2
  326. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls.upb.h +12 -4
  327. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls_config.upb.c +7 -7
  328. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls_config.upb.h +42 -14
  329. data/src/core/ext/upb-generated/udpa/annotations/migrate.upb.c +3 -3
  330. data/src/core/ext/upb-generated/udpa/annotations/migrate.upb.h +23 -11
  331. data/src/core/ext/upb-generated/udpa/annotations/security.upb.c +1 -1
  332. data/src/core/ext/upb-generated/udpa/annotations/security.upb.h +7 -3
  333. data/src/core/ext/upb-generated/udpa/annotations/status.upb.h +7 -3
  334. data/src/core/ext/upb-generated/udpa/annotations/versioning.upb.c +1 -1
  335. data/src/core/ext/upb-generated/udpa/annotations/versioning.upb.h +7 -3
  336. data/src/core/ext/upb-generated/validate/validate.upb.c +22 -22
  337. data/src/core/ext/upb-generated/validate/validate.upb.h +139 -47
  338. data/src/core/ext/upb-generated/xds/annotations/v3/migrate.upb.c +3 -3
  339. data/src/core/ext/upb-generated/xds/annotations/v3/migrate.upb.h +23 -11
  340. data/src/core/ext/upb-generated/xds/annotations/v3/security.upb.c +1 -1
  341. data/src/core/ext/upb-generated/xds/annotations/v3/security.upb.h +7 -3
  342. data/src/core/ext/upb-generated/xds/annotations/v3/status.upb.c +3 -3
  343. data/src/core/ext/upb-generated/xds/annotations/v3/status.upb.h +27 -11
  344. data/src/core/ext/upb-generated/xds/annotations/v3/versioning.upb.c +1 -1
  345. data/src/core/ext/upb-generated/xds/annotations/v3/versioning.upb.h +7 -3
  346. data/src/core/ext/upb-generated/xds/core/v3/authority.upb.c +1 -1
  347. data/src/core/ext/upb-generated/xds/core/v3/authority.upb.h +6 -2
  348. data/src/core/ext/upb-generated/xds/core/v3/collection_entry.upb.c +2 -2
  349. data/src/core/ext/upb-generated/xds/core/v3/collection_entry.upb.h +12 -4
  350. data/src/core/ext/upb-generated/xds/core/v3/context_params.upb.c +1 -1
  351. data/src/core/ext/upb-generated/xds/core/v3/context_params.upb.h +6 -2
  352. data/src/core/ext/upb-generated/xds/core/v3/extension.upb.c +1 -1
  353. data/src/core/ext/upb-generated/xds/core/v3/extension.upb.h +6 -2
  354. data/src/core/ext/upb-generated/xds/core/v3/resource.upb.c +1 -1
  355. data/src/core/ext/upb-generated/xds/core/v3/resource.upb.h +6 -2
  356. data/src/core/ext/upb-generated/xds/core/v3/resource_locator.upb.c +1 -1
  357. data/src/core/ext/upb-generated/xds/core/v3/resource_locator.upb.h +12 -4
  358. data/src/core/ext/upb-generated/xds/core/v3/resource_name.upb.c +1 -1
  359. data/src/core/ext/upb-generated/xds/core/v3/resource_name.upb.h +6 -2
  360. data/src/core/ext/upb-generated/xds/data/orca/v3/orca_load_report.upb.h +6 -2
  361. data/src/core/ext/upb-generated/xds/service/orca/v3/orca.upb.c +1 -1
  362. data/src/core/ext/upb-generated/xds/service/orca/v3/orca.upb.h +6 -2
  363. data/src/core/ext/upb-generated/xds/type/matcher/v3/matcher.upb.c +6 -6
  364. data/src/core/ext/upb-generated/xds/type/matcher/v3/matcher.upb.h +54 -18
  365. data/src/core/ext/upb-generated/xds/type/matcher/v3/regex.upb.c +2 -2
  366. data/src/core/ext/upb-generated/xds/type/matcher/v3/regex.upb.h +12 -4
  367. data/src/core/ext/upb-generated/xds/type/matcher/v3/string.upb.c +1 -1
  368. data/src/core/ext/upb-generated/xds/type/matcher/v3/string.upb.h +12 -4
  369. data/src/core/ext/upb-generated/xds/type/v3/typed_struct.upb.c +1 -1
  370. data/src/core/ext/upb-generated/xds/type/v3/typed_struct.upb.h +6 -2
  371. data/src/core/ext/upbdefs-generated/envoy/admin/v3/config_dump.upbdefs.c +67 -274
  372. data/src/core/ext/upbdefs-generated/envoy/admin/v3/config_dump.upbdefs.h +0 -85
  373. data/src/core/ext/upbdefs-generated/envoy/admin/v3/config_dump_shared.upbdefs.c +256 -0
  374. data/src/core/ext/upbdefs-generated/envoy/admin/v3/config_dump_shared.upbdefs.h +115 -0
  375. data/src/core/ext/upbdefs-generated/envoy/admin/v3/listeners.upbdefs.c +14 -11
  376. data/src/core/ext/upbdefs-generated/envoy/config/accesslog/v3/accesslog.upbdefs.c +107 -107
  377. data/src/core/ext/upbdefs-generated/envoy/config/bootstrap/v3/bootstrap.upbdefs.c +191 -187
  378. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/cluster.upbdefs.c +156 -154
  379. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/base.upbdefs.c +186 -183
  380. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/protocol.upbdefs.c +136 -134
  381. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/substitution_format_string.upbdefs.c +16 -16
  382. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener.upbdefs.c +162 -139
  383. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener.upbdefs.h +5 -0
  384. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/udp_listener_config.upbdefs.c +39 -31
  385. data/src/core/ext/upbdefs-generated/envoy/config/rbac/v3/rbac.upbdefs.c +12 -8
  386. data/src/core/ext/upbdefs-generated/envoy/config/rbac/v3/rbac.upbdefs.h +5 -0
  387. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route.upbdefs.c +72 -75
  388. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route.upbdefs.h +0 -5
  389. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route_components.upbdefs.c +713 -670
  390. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route_components.upbdefs.h +10 -0
  391. data/src/core/ext/upbdefs-generated/envoy/config/tap/v3/common.upbdefs.c +150 -139
  392. data/src/core/ext/upbdefs-generated/envoy/config/tap/v3/common.upbdefs.h +5 -0
  393. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/opentelemetry.upbdefs.c +47 -0
  394. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/opentelemetry.upbdefs.h +35 -0
  395. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/trace.upbdefs.c +16 -12
  396. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/rbac/v3/rbac.upbdefs.c +46 -25
  397. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.c +477 -466
  398. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.c +21 -18
  399. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/discovery.upbdefs.c +153 -84
  400. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/discovery.upbdefs.h +35 -0
  401. data/src/core/ext/upbdefs-generated/envoy/service/status/v3/csds.upbdefs.c +113 -113
  402. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/regex.upbdefs.c +29 -28
  403. data/src/core/ext/upbdefs-generated/envoy/type/v3/ratelimit_strategy.upbdefs.c +69 -0
  404. data/src/core/ext/upbdefs-generated/envoy/type/v3/ratelimit_strategy.upbdefs.h +40 -0
  405. data/src/core/ext/upbdefs-generated/google/protobuf/descriptor.upbdefs.c +92 -90
  406. data/src/core/ext/xds/upb_utils.h +0 -21
  407. data/src/core/ext/xds/xds_api.cc +53 -86
  408. data/src/core/ext/xds/xds_api.h +19 -28
  409. data/src/core/ext/xds/xds_bootstrap.cc +39 -52
  410. data/src/core/ext/xds/xds_bootstrap.h +28 -8
  411. data/src/core/ext/xds/xds_certificate_provider.h +9 -0
  412. data/src/core/ext/xds/xds_channel_stack_modifier.cc +6 -4
  413. data/src/core/ext/xds/xds_channel_stack_modifier.h +8 -0
  414. data/src/core/ext/xds/xds_client.cc +555 -1214
  415. data/src/core/ext/xds/xds_client.h +16 -44
  416. data/src/core/ext/xds/xds_client_grpc.cc +291 -0
  417. data/src/core/ext/xds/xds_client_grpc.h +102 -0
  418. data/src/core/ext/xds/xds_cluster.cc +92 -103
  419. data/src/core/ext/xds/xds_cluster.h +6 -5
  420. data/src/core/ext/xds/xds_cluster_specifier_plugin.cc +10 -14
  421. data/src/core/ext/xds/xds_cluster_specifier_plugin.h +1 -0
  422. data/src/core/ext/xds/xds_common_types.cc +134 -110
  423. data/src/core/ext/xds/xds_common_types.h +6 -7
  424. data/src/core/ext/xds/xds_endpoint.cc +80 -80
  425. data/src/core/ext/xds/xds_endpoint.h +4 -4
  426. data/src/core/ext/xds/xds_http_fault_filter.cc +4 -11
  427. data/src/core/ext/xds/xds_http_fault_filter.h +3 -3
  428. data/src/core/ext/xds/xds_http_filters.h +3 -3
  429. data/src/core/ext/xds/xds_http_rbac_filter.cc +39 -58
  430. data/src/core/ext/xds/xds_http_rbac_filter.h +3 -3
  431. data/src/core/ext/xds/xds_lb_policy_registry.cc +17 -20
  432. data/src/core/ext/xds/xds_lb_policy_registry.h +4 -4
  433. data/src/core/ext/xds/xds_listener.cc +329 -299
  434. data/src/core/ext/xds/xds_listener.h +4 -4
  435. data/src/core/ext/xds/xds_resource_type.h +13 -2
  436. data/src/core/ext/xds/xds_route_config.cc +180 -177
  437. data/src/core/ext/xds/xds_route_config.h +31 -17
  438. data/src/core/ext/xds/xds_routing.cc +3 -6
  439. data/src/core/ext/xds/xds_routing.h +7 -9
  440. data/src/core/ext/xds/xds_server_config_fetcher.cc +76 -81
  441. data/src/core/ext/xds/xds_transport.h +86 -0
  442. data/src/core/ext/xds/xds_transport_grpc.cc +349 -0
  443. data/src/core/ext/xds/xds_transport_grpc.h +135 -0
  444. data/src/core/lib/address_utils/parse_address.cc +19 -17
  445. data/src/core/lib/address_utils/parse_address.h +8 -5
  446. data/src/core/lib/avl/avl.h +47 -25
  447. data/src/core/lib/channel/call_tracer.h +1 -1
  448. data/src/core/lib/channel/channel_args.cc +88 -19
  449. data/src/core/lib/channel/channel_args.h +113 -62
  450. data/src/core/lib/channel/channel_stack.cc +0 -1
  451. data/src/core/lib/channel/channel_stack_builder.cc +3 -3
  452. data/src/core/lib/channel/channel_stack_builder.h +2 -2
  453. data/src/core/lib/channel/channel_stack_builder_impl.cc +2 -4
  454. data/src/core/lib/channel/channelz.cc +27 -37
  455. data/src/core/lib/channel/channelz.h +9 -0
  456. data/src/core/lib/channel/promise_based_filter.h +0 -1
  457. data/src/core/lib/config/core_configuration.h +48 -35
  458. data/src/core/lib/debug/stats.cc +12 -15
  459. data/src/core/lib/debug/stats.h +11 -3
  460. data/src/core/lib/event_engine/{event_engine.cc → default_event_engine.cc} +9 -5
  461. data/src/core/lib/event_engine/{event_engine_factory.h → default_event_engine.h} +4 -8
  462. data/src/core/lib/event_engine/default_event_engine_factory.cc +20 -3
  463. data/src/core/lib/event_engine/default_event_engine_factory.h +33 -0
  464. data/src/core/lib/event_engine/executor/executor.h +38 -0
  465. data/src/core/lib/event_engine/executor/threaded_executor.cc +36 -0
  466. data/src/core/lib/event_engine/executor/threaded_executor.h +44 -0
  467. data/src/core/lib/event_engine/forkable.cc +98 -0
  468. data/src/core/lib/event_engine/forkable.h +61 -0
  469. data/src/core/lib/event_engine/poller.h +54 -0
  470. data/src/core/lib/event_engine/{iomgr_engine/iomgr_engine.cc → posix_engine/posix_engine.cc} +30 -47
  471. data/src/core/lib/event_engine/{iomgr_engine/iomgr_engine.h → posix_engine/posix_engine.h} +27 -28
  472. data/src/core/lib/event_engine/{iomgr_engine → posix_engine}/timer.cc +4 -5
  473. data/src/core/lib/event_engine/{iomgr_engine → posix_engine}/timer.h +8 -8
  474. data/src/core/lib/event_engine/{iomgr_engine → posix_engine}/timer_heap.cc +4 -4
  475. data/src/core/lib/event_engine/{iomgr_engine → posix_engine}/timer_heap.h +5 -5
  476. data/src/core/lib/event_engine/{iomgr_engine → posix_engine}/timer_manager.cc +46 -10
  477. data/src/core/lib/event_engine/{iomgr_engine → posix_engine}/timer_manager.h +17 -8
  478. data/src/core/lib/event_engine/promise.h +11 -2
  479. data/src/core/lib/event_engine/socket_notifier.h +55 -0
  480. data/src/core/lib/event_engine/{iomgr_engine/thread_pool.cc → thread_pool.cc} +49 -14
  481. data/src/core/lib/event_engine/{iomgr_engine/thread_pool.h → thread_pool.h} +21 -10
  482. data/src/core/lib/event_engine/utils.cc +49 -0
  483. data/src/core/lib/event_engine/utils.h +40 -0
  484. data/src/core/lib/event_engine/windows/iocp.cc +149 -0
  485. data/src/core/lib/event_engine/windows/iocp.h +68 -0
  486. data/src/core/lib/event_engine/windows/win_socket.cc +196 -0
  487. data/src/core/lib/event_engine/windows/win_socket.h +120 -0
  488. data/src/core/lib/event_engine/windows/windows_engine.cc +159 -0
  489. data/src/core/lib/event_engine/windows/windows_engine.h +120 -0
  490. data/src/core/lib/gpr/time.cc +11 -9
  491. data/src/core/lib/gpr/useful.h +29 -0
  492. data/src/core/lib/gprpp/bitset.h +3 -13
  493. data/src/core/lib/gprpp/debug_location.h +39 -7
  494. data/src/core/lib/gprpp/manual_constructor.h +0 -1
  495. data/src/core/lib/gprpp/no_destruct.h +94 -0
  496. data/src/core/lib/gprpp/ref_counted_ptr.h +0 -1
  497. data/src/core/lib/gprpp/status_helper.cc +1 -0
  498. data/src/core/lib/gprpp/table.h +0 -1
  499. data/src/core/lib/{event_engine/iomgr_engine → gprpp}/time_averaged_stats.cc +3 -5
  500. data/src/core/lib/{event_engine/iomgr_engine → gprpp}/time_averaged_stats.h +5 -7
  501. data/src/core/lib/{iomgr → gprpp}/work_serializer.cc +34 -18
  502. data/src/core/lib/{iomgr → gprpp}/work_serializer.h +21 -27
  503. data/src/core/lib/http/httpcli.cc +12 -24
  504. data/src/core/lib/http/httpcli_security_connector.cc +11 -11
  505. data/src/core/lib/iomgr/call_combiner.cc +0 -26
  506. data/src/core/lib/iomgr/closure.h +0 -9
  507. data/src/core/lib/iomgr/combiner.cc +0 -20
  508. data/src/core/lib/iomgr/endpoint_pair_posix.cc +2 -1
  509. data/src/core/lib/iomgr/error.cc +0 -773
  510. data/src/core/lib/iomgr/error.h +0 -145
  511. data/src/core/lib/iomgr/error_cfstream.cc +0 -5
  512. data/src/core/lib/iomgr/ev_poll_posix.cc +17 -9
  513. data/src/core/lib/iomgr/exec_ctx.cc +0 -12
  514. data/src/core/lib/iomgr/executor.cc +0 -10
  515. data/src/core/lib/iomgr/executor.h +0 -3
  516. data/src/core/lib/iomgr/lockfree_event.cc +0 -17
  517. data/src/core/lib/iomgr/port.h +3 -0
  518. data/src/core/lib/iomgr/resolve_address.h +29 -6
  519. data/src/core/lib/iomgr/resolve_address_posix.cc +38 -8
  520. data/src/core/lib/iomgr/resolve_address_posix.h +19 -5
  521. data/src/core/lib/iomgr/resolve_address_windows.cc +40 -10
  522. data/src/core/lib/iomgr/resolve_address_windows.h +19 -5
  523. data/src/core/lib/iomgr/socket_windows.h +0 -2
  524. data/src/core/lib/iomgr/tcp_posix.cc +118 -6
  525. data/src/core/lib/iomgr/timer_generic.cc +6 -8
  526. data/src/core/lib/json/json.h +19 -22
  527. data/src/core/lib/json/json_args.h +34 -0
  528. data/src/core/lib/json/json_object_loader.cc +233 -0
  529. data/src/core/lib/json/json_object_loader.h +618 -0
  530. data/src/core/lib/json/json_reader.cc +86 -62
  531. data/src/core/lib/json/json_util.cc +8 -36
  532. data/src/core/{ext/filters/client_channel → lib/load_balancing}/lb_policy.cc +3 -44
  533. data/src/core/{ext/filters/client_channel → lib/load_balancing}/lb_policy.h +15 -24
  534. data/src/core/lib/load_balancing/lb_policy_factory.h +49 -0
  535. data/src/core/{ext/filters/client_channel → lib/load_balancing}/lb_policy_registry.cc +49 -72
  536. data/src/core/{ext/filters/client_channel → lib/load_balancing}/lb_policy_registry.h +27 -27
  537. data/src/core/{ext/filters/client_channel → lib/load_balancing}/subchannel_interface.h +6 -6
  538. data/src/core/lib/promise/activity.h +56 -8
  539. data/src/core/lib/promise/arena_promise.h +84 -81
  540. data/src/core/lib/promise/context.h +0 -1
  541. data/src/core/lib/promise/detail/basic_seq.h +43 -23
  542. data/src/core/lib/promise/detail/promise_factory.h +0 -1
  543. data/src/core/lib/promise/map.h +0 -1
  544. data/src/core/lib/promise/seq.h +25 -4
  545. data/src/core/lib/promise/sleep.cc +38 -42
  546. data/src/core/lib/promise/sleep.h +27 -24
  547. data/src/core/lib/promise/try_seq.h +26 -6
  548. data/src/core/lib/resolver/resolver.cc +0 -47
  549. data/src/core/lib/resolver/resolver.h +2 -12
  550. data/src/core/lib/resolver/resolver_factory.h +2 -3
  551. data/src/core/lib/resolver/resolver_registry.cc +1 -1
  552. data/src/core/lib/resolver/resolver_registry.h +2 -3
  553. data/src/core/lib/resolver/server_address.cc +11 -15
  554. data/src/core/lib/resolver/server_address.h +4 -8
  555. data/src/core/lib/resource_quota/api.cc +1 -1
  556. data/src/core/lib/resource_quota/arena.cc +21 -1
  557. data/src/core/lib/resource_quota/arena.h +24 -2
  558. data/src/core/lib/resource_quota/memory_quota.cc +157 -17
  559. data/src/core/lib/resource_quota/memory_quota.h +98 -17
  560. data/src/core/lib/resource_quota/periodic_update.cc +79 -0
  561. data/src/core/lib/resource_quota/periodic_update.h +71 -0
  562. data/src/core/lib/security/authorization/evaluate_args.cc +10 -7
  563. data/src/core/lib/security/authorization/grpc_server_authz_filter.cc +1 -2
  564. data/src/core/lib/security/authorization/grpc_server_authz_filter.h +1 -1
  565. data/src/core/lib/security/authorization/matchers.cc +13 -10
  566. data/src/core/lib/security/authorization/rbac_policy.cc +0 -1
  567. data/src/core/lib/security/credentials/alts/alts_credentials.cc +2 -3
  568. data/src/core/lib/security/credentials/alts/alts_credentials.h +3 -4
  569. data/src/core/lib/security/credentials/composite/composite_credentials.cc +3 -7
  570. data/src/core/lib/security/credentials/composite/composite_credentials.h +2 -4
  571. data/src/core/lib/security/credentials/credentials.h +16 -12
  572. data/src/core/lib/security/credentials/external/aws_external_account_credentials.cc +18 -11
  573. data/src/core/lib/security/credentials/external/external_account_credentials.cc +32 -23
  574. data/src/core/lib/security/credentials/external/file_external_account_credentials.cc +5 -6
  575. data/src/core/lib/security/credentials/external/url_external_account_credentials.cc +4 -6
  576. data/src/core/lib/security/credentials/fake/fake_credentials.cc +3 -12
  577. data/src/core/lib/security/credentials/fake/fake_credentials.h +0 -4
  578. data/src/core/lib/security/credentials/google_default/google_default_credentials.cc +29 -26
  579. data/src/core/lib/security/credentials/google_default/google_default_credentials.h +1 -3
  580. data/src/core/lib/security/credentials/iam/iam_credentials.cc +0 -1
  581. data/src/core/lib/security/credentials/insecure/insecure_credentials.cc +3 -3
  582. data/src/core/lib/security/credentials/insecure/insecure_credentials.h +3 -4
  583. data/src/core/lib/security/credentials/jwt/json_token.cc +12 -3
  584. data/src/core/lib/security/credentials/jwt/jwt_credentials.cc +4 -8
  585. data/src/core/lib/security/credentials/jwt/jwt_verifier.cc +11 -13
  586. data/src/core/lib/security/credentials/local/local_credentials.cc +3 -4
  587. data/src/core/lib/security/credentials/local/local_credentials.h +3 -4
  588. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.cc +17 -18
  589. data/src/core/lib/security/credentials/plugin/plugin_credentials.cc +0 -1
  590. data/src/core/lib/security/credentials/ssl/ssl_credentials.cc +13 -21
  591. data/src/core/lib/security/credentials/ssl/ssl_credentials.h +3 -4
  592. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.h +6 -0
  593. data/src/core/lib/security/credentials/tls/tls_credentials.cc +13 -25
  594. data/src/core/lib/security/credentials/tls/tls_credentials.h +3 -4
  595. data/src/core/lib/security/credentials/xds/xds_credentials.cc +13 -30
  596. data/src/core/lib/security/credentials/xds/xds_credentials.h +3 -3
  597. data/src/core/lib/security/security_connector/alts/alts_security_connector.cc +10 -18
  598. data/src/core/lib/security/security_connector/fake/fake_security_connector.cc +26 -38
  599. data/src/core/lib/security/security_connector/fake/fake_security_connector.h +2 -2
  600. data/src/core/lib/security/security_connector/insecure/insecure_security_connector.cc +5 -5
  601. data/src/core/lib/security/security_connector/insecure/insecure_security_connector.h +6 -5
  602. data/src/core/lib/security/security_connector/local/local_security_connector.cc +13 -11
  603. data/src/core/lib/security/security_connector/local/local_security_connector.h +2 -2
  604. data/src/core/lib/security/security_connector/security_connector.h +5 -3
  605. data/src/core/lib/security/security_connector/ssl/ssl_security_connector.cc +5 -4
  606. data/src/core/lib/security/security_connector/tls/tls_security_connector.cc +5 -5
  607. data/src/core/lib/security/security_connector/tls/tls_security_connector.h +5 -5
  608. data/src/core/lib/security/transport/auth_filters.h +1 -1
  609. data/src/core/lib/security/transport/client_auth_filter.cc +3 -4
  610. data/src/core/lib/security/transport/security_handshaker.cc +32 -44
  611. data/src/core/lib/security/transport/security_handshaker.h +2 -1
  612. data/src/core/lib/service_config/service_config.h +11 -0
  613. data/src/core/lib/service_config/service_config_impl.cc +98 -97
  614. data/src/core/lib/service_config/service_config_impl.h +11 -13
  615. data/src/core/lib/service_config/service_config_parser.cc +26 -27
  616. data/src/core/lib/service_config/service_config_parser.h +10 -22
  617. data/src/core/lib/slice/percent_encoding.cc +4 -13
  618. data/src/core/lib/slice/slice.cc +10 -4
  619. data/src/core/lib/surface/call.cc +8 -2
  620. data/src/core/lib/surface/channel.cc +6 -6
  621. data/src/core/lib/surface/channel.h +1 -1
  622. data/src/core/lib/surface/completion_queue.cc +0 -2
  623. data/src/core/lib/surface/completion_queue.h +0 -3
  624. data/src/core/lib/surface/init.cc +2 -6
  625. data/src/core/lib/surface/lame_client.cc +2 -3
  626. data/src/core/lib/surface/lame_client.h +1 -1
  627. data/src/core/lib/surface/server.cc +7 -12
  628. data/src/core/lib/surface/server.h +7 -7
  629. data/src/core/lib/surface/validate_metadata.cc +4 -14
  630. data/src/core/lib/surface/version.cc +2 -2
  631. data/src/core/lib/transport/connectivity_state.cc +0 -1
  632. data/src/core/lib/transport/connectivity_state.h +1 -1
  633. data/src/core/lib/transport/error_utils.cc +0 -36
  634. data/src/core/lib/transport/handshaker.cc +7 -9
  635. data/src/core/lib/transport/handshaker.h +4 -5
  636. data/src/core/lib/transport/handshaker_factory.h +2 -3
  637. data/src/core/lib/transport/handshaker_registry.cc +2 -1
  638. data/src/core/lib/transport/handshaker_registry.h +2 -4
  639. data/src/core/lib/transport/http_connect_handshaker.cc +16 -16
  640. data/src/core/lib/transport/metadata_batch.cc +5 -0
  641. data/src/core/lib/transport/metadata_batch.h +52 -7
  642. data/src/core/lib/transport/parsed_metadata.h +0 -1
  643. data/src/core/lib/transport/tcp_connect_handshaker.cc +12 -18
  644. data/src/core/lib/transport/transport.h +0 -7
  645. data/src/core/tsi/alts/handshaker/alts_handshaker_client.cc +40 -21
  646. data/src/core/tsi/alts/handshaker/alts_handshaker_client.h +1 -1
  647. data/src/core/tsi/alts/handshaker/alts_tsi_handshaker.cc +14 -7
  648. data/src/core/tsi/alts/handshaker/alts_tsi_handshaker_private.h +1 -1
  649. data/src/core/tsi/fake_transport_security.cc +53 -30
  650. data/src/core/tsi/local_transport_security.cc +9 -5
  651. data/src/core/tsi/ssl/session_cache/ssl_session_cache.h +10 -1
  652. data/src/core/tsi/ssl_transport_security.cc +47 -23
  653. data/src/core/tsi/transport_security.cc +18 -6
  654. data/src/core/tsi/transport_security.h +2 -1
  655. data/src/core/tsi/transport_security_interface.h +17 -5
  656. data/src/ruby/ext/grpc/extconf.rb +2 -0
  657. data/src/ruby/ext/grpc/rb_loader.c +6 -2
  658. data/src/ruby/lib/grpc/2.5/grpc_c.so +0 -0
  659. data/src/ruby/lib/grpc/2.6/grpc_c.so +0 -0
  660. data/src/ruby/lib/grpc/2.7/grpc_c.so +0 -0
  661. data/src/ruby/lib/grpc/3.0/grpc_c.so +0 -0
  662. data/src/ruby/lib/grpc/3.1/grpc_c.so +0 -0
  663. data/src/ruby/lib/grpc/grpc_c.so +0 -0
  664. data/src/ruby/lib/grpc/version.rb +1 -1
  665. data/src/ruby/pb/src/proto/grpc/testing/messages_pb.rb +4 -0
  666. data/third_party/abseil-cpp/absl/functional/any_invocable.h +313 -0
  667. data/third_party/abseil-cpp/absl/functional/internal/any_invocable.h +857 -0
  668. data/third_party/upb/third_party/utf8_range/utf8_range.h +1 -1
  669. data/third_party/upb/upb/arena.c +277 -0
  670. data/third_party/upb/upb/arena.h +225 -0
  671. data/third_party/upb/upb/array.c +114 -0
  672. data/third_party/upb/upb/array.h +83 -0
  673. data/third_party/upb/upb/collections.h +36 -0
  674. data/third_party/upb/upb/decode.c +161 -65
  675. data/third_party/upb/upb/decode.h +1 -0
  676. data/third_party/upb/upb/decode_fast.c +1 -1
  677. data/third_party/upb/upb/def.c +10 -2
  678. data/third_party/upb/upb/def.h +8 -1
  679. data/third_party/upb/upb/def.hpp +7 -4
  680. data/third_party/upb/upb/encode.c +29 -20
  681. data/third_party/upb/upb/encode.h +16 -6
  682. data/third_party/upb/upb/extension_registry.c +93 -0
  683. data/third_party/upb/upb/extension_registry.h +84 -0
  684. data/third_party/upb/upb/{decode_internal.h → internal/decode.h} +5 -5
  685. data/third_party/upb/upb/internal/table.h +385 -0
  686. data/third_party/upb/upb/{upb_internal.h → internal/upb.h} +3 -3
  687. data/third_party/upb/upb/internal/vsnprintf_compat.h +52 -0
  688. data/third_party/upb/upb/json_decode.c +1512 -0
  689. data/third_party/upb/upb/json_decode.h +47 -0
  690. data/third_party/upb/upb/json_encode.c +7 -3
  691. data/third_party/upb/upb/json_encode.h +6 -3
  692. data/third_party/upb/upb/map.c +108 -0
  693. data/third_party/upb/upb/map.h +117 -0
  694. data/third_party/upb/upb/message_value.h +66 -0
  695. data/third_party/upb/upb/mini_table.c +1147 -0
  696. data/third_party/upb/upb/mini_table.h +189 -0
  697. data/third_party/upb/upb/mini_table.hpp +112 -0
  698. data/third_party/upb/upb/msg.c +2 -62
  699. data/third_party/upb/upb/msg.h +2 -45
  700. data/third_party/upb/upb/msg_internal.h +28 -22
  701. data/third_party/upb/upb/port_def.inc +2 -1
  702. data/third_party/upb/upb/port_undef.inc +1 -0
  703. data/third_party/upb/upb/reflection.c +2 -159
  704. data/third_party/upb/upb/reflection.h +2 -112
  705. data/third_party/upb/upb/status.c +86 -0
  706. data/third_party/upb/upb/status.h +66 -0
  707. data/third_party/upb/upb/table.c +2 -2
  708. data/third_party/upb/upb/table_internal.h +3 -352
  709. data/third_party/upb/upb/text_encode.c +3 -2
  710. data/third_party/upb/upb/upb.c +4 -290
  711. data/third_party/upb/upb/upb.h +7 -196
  712. metadata +90 -38
  713. data/src/core/ext/filters/client_channel/lb_policy_factory.h +0 -50
  714. data/src/core/lib/iomgr/error_internal.h +0 -66
  715. data/src/core/lib/iomgr/executor/mpmcqueue.cc +0 -182
  716. data/src/core/lib/iomgr/executor/mpmcqueue.h +0 -171
  717. data/src/core/lib/iomgr/executor/threadpool.cc +0 -136
  718. data/src/core/lib/iomgr/executor/threadpool.h +0 -150
  719. data/src/core/lib/iomgr/time_averaged_stats.cc +0 -64
  720. data/src/core/lib/iomgr/time_averaged_stats.h +0 -72
  721. data/src/core/lib/promise/detail/switch.h +0 -1455
@@ -17,7 +17,6 @@
17
17
 
18
18
  #include <grpc/support/port_platform.h>
19
19
 
20
- #include <type_traits>
21
20
  #include <utility>
22
21
 
23
22
  #include "absl/meta/type_traits.h"
@@ -25,6 +24,7 @@
25
24
  #include "absl/status/statusor.h"
26
25
 
27
26
  #include "src/core/lib/promise/detail/basic_seq.h"
27
+ #include "src/core/lib/promise/detail/promise_like.h"
28
28
  #include "src/core/lib/promise/detail/status.h"
29
29
  #include "src/core/lib/promise/poll.h"
30
30
 
@@ -116,6 +116,26 @@ using TrySeqTraits = TrySeqTraitsWithSfinae<T>;
116
116
  template <typename... Fs>
117
117
  using TrySeq = BasicSeq<TrySeqTraits, Fs...>;
118
118
 
119
+ template <typename I, typename F, typename Arg>
120
+ struct TrySeqIterTraits {
121
+ using Iter = I;
122
+ using Factory = F;
123
+ using Argument = Arg;
124
+ using IterValue = decltype(*std::declval<Iter>());
125
+ using StateCreated = decltype(std::declval<F>()(std::declval<IterValue>(),
126
+ std::declval<Arg>()));
127
+ using State = PromiseLike<StateCreated>;
128
+ using Wrapped = typename State::Result;
129
+
130
+ using Traits = TrySeqTraits<Wrapped>;
131
+ };
132
+
133
+ template <typename Iter, typename Factory, typename Argument>
134
+ struct TrySeqIterResultTraits {
135
+ using IterTraits = TrySeqIterTraits<Iter, Factory, Argument>;
136
+ using Result = BasicSeqIter<IterTraits>;
137
+ };
138
+
119
139
  } // namespace promise_detail
120
140
 
121
141
  // Try a sequence of operations.
@@ -144,12 +164,12 @@ promise_detail::TrySeq<Functors...> TrySeq(Functors... functors) {
144
164
  // }
145
165
  // return argument;
146
166
  template <typename Iter, typename Factory, typename Argument>
147
- promise_detail::BasicSeqIter<promise_detail::TrySeqTraits, Factory, Argument,
148
- Iter>
167
+ typename promise_detail::TrySeqIterResultTraits<Iter, Factory, Argument>::Result
149
168
  TrySeqIter(Iter begin, Iter end, Argument argument, Factory factory) {
150
- return promise_detail::BasicSeqIter<promise_detail::TrySeqTraits, Factory,
151
- Argument, Iter>(
152
- begin, end, std::move(factory), std::move(argument));
169
+ using Result =
170
+ typename promise_detail::TrySeqIterResultTraits<Iter, Factory,
171
+ Argument>::Result;
172
+ return Result(begin, end, std::move(factory), std::move(argument));
153
173
  }
154
174
 
155
175
  } // namespace grpc_core
@@ -20,11 +20,6 @@
20
20
 
21
21
  #include "src/core/lib/resolver/resolver.h"
22
22
 
23
- #include <algorithm>
24
- #include <utility>
25
-
26
- #include "src/core/lib/channel/channel_args.h"
27
-
28
23
  grpc_core::DebugOnlyTraceFlag grpc_trace_resolver_refcount(false,
29
24
  "resolver_refcount");
30
25
 
@@ -39,46 +34,4 @@ Resolver::Resolver()
39
34
  ? "Resolver"
40
35
  : nullptr) {}
41
36
 
42
- //
43
- // Resolver::Result
44
- //
45
-
46
- Resolver::Result::~Result() { grpc_channel_args_destroy(args); }
47
-
48
- Resolver::Result::Result(const Result& other)
49
- : addresses(other.addresses),
50
- service_config(other.service_config),
51
- resolution_note(other.resolution_note),
52
- args(grpc_channel_args_copy(other.args)) {}
53
-
54
- Resolver::Result::Result(Result&& other) noexcept
55
- : addresses(std::move(other.addresses)),
56
- service_config(std::move(other.service_config)),
57
- resolution_note(std::move(other.resolution_note)),
58
- // TODO(roth): Use std::move() once channel args is converted to C++.
59
- args(other.args) {
60
- other.args = nullptr;
61
- }
62
-
63
- Resolver::Result& Resolver::Result::operator=(const Result& other) {
64
- if (&other == this) return *this;
65
- addresses = other.addresses;
66
- service_config = other.service_config;
67
- resolution_note = other.resolution_note;
68
- grpc_channel_args_destroy(args);
69
- args = grpc_channel_args_copy(other.args);
70
- return *this;
71
- }
72
-
73
- Resolver::Result& Resolver::Result::operator=(Result&& other) noexcept {
74
- addresses = std::move(other.addresses);
75
- service_config = std::move(other.service_config);
76
- resolution_note = std::move(other.resolution_note);
77
- // TODO(roth): Use std::move() once channel args is converted to C++.
78
- grpc_channel_args_destroy(args);
79
- args = other.args;
80
- other.args = nullptr;
81
- return *this;
82
- }
83
-
84
37
  } // namespace grpc_core
@@ -23,8 +23,7 @@
23
23
 
24
24
  #include "absl/status/statusor.h"
25
25
 
26
- #include <grpc/impl/codegen/grpc_types.h>
27
-
26
+ #include "src/core/lib/channel/channel_args.h"
28
27
  #include "src/core/lib/debug/trace.h"
29
28
  #include "src/core/lib/gprpp/orphanable.h"
30
29
  #include "src/core/lib/gprpp/ref_counted_ptr.h"
@@ -67,16 +66,7 @@ class Resolver : public InternallyRefCounted<Resolver> {
67
66
  std::string resolution_note;
68
67
  // TODO(roth): Before making this a public API, figure out a way to
69
68
  // avoid exposing channel args this way.
70
- const grpc_channel_args* args = nullptr;
71
-
72
- // TODO(roth): Remove everything below once grpc_channel_args is
73
- // converted to a copyable and movable C++ object.
74
- Result() = default;
75
- ~Result();
76
- Result(const Result& other);
77
- Result(Result&& other) noexcept;
78
- Result& operator=(const Result& other);
79
- Result& operator=(Result&& other) noexcept;
69
+ ChannelArgs args;
80
70
  };
81
71
 
82
72
  /// A proxy object used by the resolver to return results to the
@@ -25,8 +25,7 @@
25
25
  #include "absl/strings/string_view.h"
26
26
  #include "absl/strings/strip.h"
27
27
 
28
- #include <grpc/impl/codegen/grpc_types.h>
29
-
28
+ #include "src/core/lib/channel/channel_args.h"
30
29
  #include "src/core/lib/gprpp/orphanable.h"
31
30
  #include "src/core/lib/iomgr/iomgr_fwd.h"
32
31
  #include "src/core/lib/resolver/resolver.h"
@@ -42,7 +41,7 @@ struct ResolverArgs {
42
41
  /// The parsed URI to resolve.
43
42
  URI uri;
44
43
  /// Channel args to be included in resolver results.
45
- const grpc_channel_args* args = nullptr;
44
+ ChannelArgs args;
46
45
  /// Used to drive I/O in the name resolution process.
47
46
  grpc_pollset_set* pollset_set = nullptr;
48
47
  /// The work_serializer under which all resolver calls will be run.
@@ -71,7 +71,7 @@ bool ResolverRegistry::IsValidTarget(absl::string_view target) const {
71
71
  }
72
72
 
73
73
  OrphanablePtr<Resolver> ResolverRegistry::CreateResolver(
74
- absl::string_view target, const grpc_channel_args* args,
74
+ absl::string_view target, const ChannelArgs& args,
75
75
  grpc_pollset_set* pollset_set,
76
76
  std::shared_ptr<WorkSerializer> work_serializer,
77
77
  std::unique_ptr<Resolver::ResultHandler> result_handler) const {
@@ -26,8 +26,7 @@
26
26
 
27
27
  #include "absl/strings/string_view.h"
28
28
 
29
- #include <grpc/impl/codegen/grpc_types.h>
30
-
29
+ #include "src/core/lib/channel/channel_args.h"
31
30
  #include "src/core/lib/gprpp/orphanable.h"
32
31
  #include "src/core/lib/iomgr/iomgr_fwd.h"
33
32
  #include "src/core/lib/resolver/resolver.h"
@@ -93,7 +92,7 @@ class ResolverRegistry {
93
92
  /// which all resolver calls will be run. \a result_handler is used to return
94
93
  /// results from the resolver.
95
94
  OrphanablePtr<Resolver> CreateResolver(
96
- absl::string_view target, const grpc_channel_args* args,
95
+ absl::string_view target, const ChannelArgs& args,
97
96
  grpc_pollset_set* pollset_set,
98
97
  std::shared_ptr<WorkSerializer> work_serializer,
99
98
  std::unique_ptr<Resolver::ResultHandler> result_handler) const;
@@ -35,6 +35,7 @@
35
35
  #include "absl/strings/str_join.h"
36
36
 
37
37
  #include "src/core/lib/address_utils/sockaddr_utils.h"
38
+ #include "src/core/lib/channel/channel_args.h"
38
39
 
39
40
  // IWYU pragma: no_include <sys/socket.h>
40
41
 
@@ -51,12 +52,12 @@ const char* ServerAddressWeightAttribute::kServerAddressWeightAttributeKey =
51
52
  //
52
53
 
53
54
  ServerAddress::ServerAddress(
54
- const grpc_resolved_address& address, grpc_channel_args* args,
55
+ const grpc_resolved_address& address, const ChannelArgs& args,
55
56
  std::map<const char*, std::unique_ptr<AttributeInterface>> attributes)
56
57
  : address_(address), args_(args), attributes_(std::move(attributes)) {}
57
58
 
58
59
  ServerAddress::ServerAddress(
59
- const void* address, size_t address_len, grpc_channel_args* args,
60
+ const void* address, size_t address_len, const ChannelArgs& args,
60
61
  std::map<const char*, std::unique_ptr<AttributeInterface>> attributes)
61
62
  : args_(args), attributes_(std::move(attributes)) {
62
63
  memcpy(address_.addr, address, address_len);
@@ -64,7 +65,7 @@ ServerAddress::ServerAddress(
64
65
  }
65
66
 
66
67
  ServerAddress::ServerAddress(const ServerAddress& other)
67
- : address_(other.address_), args_(grpc_channel_args_copy(other.args_)) {
68
+ : address_(other.address_), args_(other.args_) {
68
69
  for (const auto& p : other.attributes_) {
69
70
  attributes_[p.first] = p.second->Copy();
70
71
  }
@@ -74,8 +75,7 @@ ServerAddress& ServerAddress::operator=(const ServerAddress& other) {
74
75
  return *this;
75
76
  }
76
77
  address_ = other.address_;
77
- grpc_channel_args_destroy(args_);
78
- args_ = grpc_channel_args_copy(other.args_);
78
+ args_ = other.args_;
79
79
  attributes_.clear();
80
80
  for (const auto& p : other.attributes_) {
81
81
  attributes_[p.first] = p.second->Copy();
@@ -85,16 +85,12 @@ ServerAddress& ServerAddress::operator=(const ServerAddress& other) {
85
85
 
86
86
  ServerAddress::ServerAddress(ServerAddress&& other) noexcept
87
87
  : address_(other.address_),
88
- args_(other.args_),
89
- attributes_(std::move(other.attributes_)) {
90
- other.args_ = nullptr;
91
- }
88
+ args_(std::move(other.args_)),
89
+ attributes_(std::move(other.attributes_)) {}
92
90
 
93
91
  ServerAddress& ServerAddress::operator=(ServerAddress&& other) noexcept {
94
92
  address_ = other.address_;
95
- grpc_channel_args_destroy(args_);
96
- args_ = other.args_;
97
- other.args_ = nullptr;
93
+ args_ = std::move(other.args_);
98
94
  attributes_ = std::move(other.attributes_);
99
95
  return *this;
100
96
  }
@@ -133,7 +129,7 @@ int ServerAddress::Cmp(const ServerAddress& other) const {
133
129
  if (address_.len < other.address_.len) return -1;
134
130
  int retval = memcmp(address_.addr, other.address_.addr, address_.len);
135
131
  if (retval != 0) return retval;
136
- retval = grpc_channel_args_compare(args_, other.args_);
132
+ retval = QsortCompare(args_, other.args_);
137
133
  if (retval != 0) return retval;
138
134
  return CompareAttributes(attributes_, other.attributes_);
139
135
  }
@@ -163,8 +159,8 @@ std::string ServerAddress::ToString() const {
163
159
  std::vector<std::string> parts = {
164
160
  addr_str.ok() ? addr_str.value() : addr_str.status().ToString(),
165
161
  };
166
- if (args_ != nullptr) {
167
- parts.emplace_back(absl::StrCat("args=", grpc_channel_args_string(args_)));
162
+ if (args_ != ChannelArgs()) {
163
+ parts.emplace_back(absl::StrCat("args=", args_.ToString()));
168
164
  }
169
165
  if (!attributes_.empty()) {
170
166
  std::vector<std::string> attrs;
@@ -31,8 +31,6 @@
31
31
 
32
32
  #include "absl/memory/memory.h"
33
33
 
34
- #include <grpc/impl/codegen/grpc_types.h>
35
-
36
34
  #include "src/core/lib/channel/channel_args.h"
37
35
  #include "src/core/lib/gpr/useful.h"
38
36
  #include "src/core/lib/iomgr/resolved_address.h"
@@ -70,16 +68,14 @@ class ServerAddress {
70
68
  };
71
69
 
72
70
  // Takes ownership of args.
73
- ServerAddress(const grpc_resolved_address& address, grpc_channel_args* args,
71
+ ServerAddress(const grpc_resolved_address& address, const ChannelArgs& args,
74
72
  std::map<const char*, std::unique_ptr<AttributeInterface>>
75
73
  attributes = {});
76
74
  ServerAddress(const void* address, size_t address_len,
77
- grpc_channel_args* args,
75
+ const ChannelArgs& args,
78
76
  std::map<const char*, std::unique_ptr<AttributeInterface>>
79
77
  attributes = {});
80
78
 
81
- ~ServerAddress() { grpc_channel_args_destroy(args_); }
82
-
83
79
  // Copyable.
84
80
  ServerAddress(const ServerAddress& other);
85
81
  ServerAddress& operator=(const ServerAddress& other);
@@ -93,7 +89,7 @@ class ServerAddress {
93
89
  int Cmp(const ServerAddress& other) const;
94
90
 
95
91
  const grpc_resolved_address& address() const { return address_; }
96
- const grpc_channel_args* args() const { return args_; }
92
+ const ChannelArgs& args() const { return args_; }
97
93
 
98
94
  const AttributeInterface* GetAttribute(const char* key) const;
99
95
 
@@ -109,7 +105,7 @@ class ServerAddress {
109
105
 
110
106
  private:
111
107
  grpc_resolved_address address_;
112
- grpc_channel_args* args_;
108
+ ChannelArgs args_;
113
109
  std::map<const char*, std::unique_ptr<AttributeInterface>> attributes_;
114
110
  };
115
111
 
@@ -44,7 +44,7 @@ ResourceQuotaRefPtr ResourceQuotaFromChannelArgs(
44
44
  ->Ref();
45
45
  }
46
46
 
47
- ChannelArgs EnsureResourceQuotaInChannelArgs(ChannelArgs args) {
47
+ ChannelArgs EnsureResourceQuotaInChannelArgs(const ChannelArgs& args) {
48
48
  if (args.GetObject<ResourceQuota>() != nullptr) return args;
49
49
  // If there's no existing quota, add it to the default one - shared between
50
50
  // all channel args declared thusly. This prevents us from accidentally not
@@ -20,8 +20,11 @@
20
20
 
21
21
  #include "src/core/lib/resource_quota/arena.h"
22
22
 
23
+ #include <atomic>
23
24
  #include <new>
24
25
 
26
+ #include "absl/utility/utility.h"
27
+
25
28
  #include <grpc/support/alloc.h>
26
29
 
27
30
  #include "src/core/lib/gpr/alloc.h"
@@ -49,7 +52,7 @@ Arena::~Arena() {
49
52
  Zone* z = last_zone_;
50
53
  while (z) {
51
54
  Zone* prev_z = z->prev;
52
- z->~Zone();
55
+ Destruct(z);
53
56
  gpr_free_aligned(z);
54
57
  z = prev_z;
55
58
  }
@@ -71,6 +74,16 @@ std::pair<Arena*, void*> Arena::CreateWithAlloc(
71
74
  }
72
75
 
73
76
  size_t Arena::Destroy() {
77
+ ManagedNewObject* p;
78
+ // Outer loop: clear the managed new object list.
79
+ // We do this repeatedly in case a destructor ends up allocating something.
80
+ while ((p = managed_new_head_.exchange(nullptr, std::memory_order_relaxed)) !=
81
+ nullptr) {
82
+ // Inner loop: destruct a batch of objects.
83
+ while (p != nullptr) {
84
+ Destruct(absl::exchange(p, p->next));
85
+ }
86
+ }
74
87
  size_t size = total_used_.load(std::memory_order_relaxed);
75
88
  memory_allocator_->Release(total_allocated_.load(std::memory_order_relaxed));
76
89
  this->~Arena();
@@ -98,4 +111,11 @@ void* Arena::AllocZone(size_t size) {
98
111
  return reinterpret_cast<char*>(z) + zone_base_size;
99
112
  }
100
113
 
114
+ void Arena::ManagedNewObject::Link(std::atomic<ManagedNewObject*>* head) {
115
+ next = head->load(std::memory_order_relaxed);
116
+ while (!head->compare_exchange_weak(next, this, std::memory_order_acq_rel,
117
+ std::memory_order_relaxed)) {
118
+ }
119
+ }
120
+
101
121
  } // namespace grpc_core
@@ -31,12 +31,12 @@
31
31
 
32
32
  #include <atomic>
33
33
  #include <memory>
34
- #include <new>
35
34
  #include <utility>
36
35
 
37
36
  #include <grpc/event_engine/memory_allocator.h>
38
37
 
39
38
  #include "src/core/lib/gpr/alloc.h"
39
+ #include "src/core/lib/gprpp/construct_destruct.h"
40
40
  #include "src/core/lib/promise/context.h"
41
41
  #include "src/core/lib/resource_quota/memory_quota.h"
42
42
 
@@ -76,15 +76,36 @@ class Arena {
76
76
  template <typename T, typename... Args>
77
77
  T* New(Args&&... args) {
78
78
  T* t = static_cast<T*>(Alloc(sizeof(T)));
79
- new (t) T(std::forward<Args>(args)...);
79
+ Construct(t, std::forward<Args>(args)...);
80
80
  return t;
81
81
  }
82
82
 
83
+ // Like New, but has the arena call p->~T() at arena destruction time.
84
+ template <typename T, typename... Args>
85
+ T* ManagedNew(Args&&... args) {
86
+ auto* p = New<ManagedNewImpl<T>>(std::forward<Args>(args)...);
87
+ p->Link(&managed_new_head_);
88
+ return &p->t;
89
+ }
90
+
83
91
  private:
84
92
  struct Zone {
85
93
  Zone* prev;
86
94
  };
87
95
 
96
+ struct ManagedNewObject {
97
+ ManagedNewObject* next = nullptr;
98
+ void Link(std::atomic<ManagedNewObject*>* head);
99
+ virtual ~ManagedNewObject() = default;
100
+ };
101
+
102
+ template <typename T>
103
+ struct ManagedNewImpl : public ManagedNewObject {
104
+ T t;
105
+ template <typename... Args>
106
+ explicit ManagedNewImpl(Args&&... args) : t(std::forward<Args>(args)...) {}
107
+ };
108
+
88
109
  // Initialize an arena.
89
110
  // Parameters:
90
111
  // initial_size: The initial size of the whole arena in bytes. These bytes
@@ -118,6 +139,7 @@ class Arena {
118
139
  // and (2) the allocated memory. The arena itself maintains a pointer to the
119
140
  // last zone; the zone list is reverse-walked during arena destruction only.
120
141
  std::atomic<Zone*> last_zone_{nullptr};
142
+ std::atomic<ManagedNewObject*> managed_new_head_{nullptr};
121
143
  // The backing memory quota
122
144
  MemoryAllocator* const memory_allocator_;
123
145
  };
@@ -21,7 +21,6 @@
21
21
  #include <algorithm>
22
22
  #include <atomic>
23
23
  #include <tuple>
24
- #include <type_traits>
25
24
 
26
25
  #include "absl/status/status.h"
27
26
  #include "absl/strings/str_cat.h"
@@ -29,6 +28,7 @@
29
28
 
30
29
  #include "src/core/lib/debug/trace.h"
31
30
  #include "src/core/lib/gpr/useful.h"
31
+ #include "src/core/lib/gprpp/global_config_env.h"
32
32
  #include "src/core/lib/gprpp/mpscq.h"
33
33
  #include "src/core/lib/promise/exec_ctx_wakeup_scheduler.h"
34
34
  #include "src/core/lib/promise/loop.h"
@@ -37,6 +37,18 @@
37
37
  #include "src/core/lib/promise/seq.h"
38
38
  #include "src/core/lib/resource_quota/trace.h"
39
39
 
40
+ GPR_GLOBAL_CONFIG_DEFINE_BOOL(grpc_experimental_smooth_memory_presure, false,
41
+ "smooth the value of memory pressure over time");
42
+ GPR_GLOBAL_CONFIG_DEFINE_BOOL(
43
+ grpc_experimental_enable_periodic_resource_quota_reclamation, false,
44
+ "Enable experimental feature to reclaim resource quota periodically");
45
+ GPR_GLOBAL_CONFIG_DEFINE_INT32(
46
+ grpc_experimental_max_quota_buffer_size, 1024 * 1024,
47
+ "Maximum size for one memory allocators buffer size against a quota");
48
+ GPR_GLOBAL_CONFIG_DEFINE_INT32(
49
+ grpc_experimental_resource_quota_set_point, 95,
50
+ "Ask the resource quota to target this percentage of total quota usage.");
51
+
40
52
  namespace grpc_core {
41
53
 
42
54
  // Maximum number of bytes an allocator will request from a quota in one step.
@@ -207,11 +219,10 @@ absl::optional<size_t> GrpcMemoryAllocatorImpl::TryReserve(
207
219
  // Scale the request down according to memory pressure if we have that
208
220
  // flexibility.
209
221
  if (scaled_size_over_min != 0) {
210
- const auto pressure_and_max_recommended_allocation_size =
211
- memory_quota_->InstantaneousPressureAndMaxRecommendedAllocationSize();
212
- double pressure = pressure_and_max_recommended_allocation_size.first;
222
+ const auto pressure_info = memory_quota_->GetPressureInfo();
223
+ double pressure = pressure_info.pressure_control_value;
213
224
  size_t max_recommended_allocation_size =
214
- pressure_and_max_recommended_allocation_size.second;
225
+ pressure_info.max_recommended_allocation_size;
215
226
  // Reduce allocation size proportional to the pressure > 80% usage.
216
227
  if (pressure > 0.8) {
217
228
  scaled_size_over_min =
@@ -249,11 +260,16 @@ absl::optional<size_t> GrpcMemoryAllocatorImpl::TryReserve(
249
260
 
250
261
  void GrpcMemoryAllocatorImpl::MaybeDonateBack() {
251
262
  size_t free = free_bytes_.load(std::memory_order_relaxed);
252
- const size_t kReduceToSize = kMaxQuotaBufferSize / 2;
253
- while (true) {
254
- if (free <= kReduceToSize) return;
255
- size_t ret = free - kReduceToSize;
256
- if (free_bytes_.compare_exchange_weak(free, kReduceToSize,
263
+ while (free > 0) {
264
+ size_t ret = 0;
265
+ if (max_quota_buffer_size() > 0 && free > max_quota_buffer_size() / 2) {
266
+ ret = std::max(ret, free - max_quota_buffer_size() / 2);
267
+ }
268
+ if (periodic_donate_back()) {
269
+ ret = std::max(ret, free > 8192 ? free / 2 : free);
270
+ }
271
+ const size_t new_free = free - ret;
272
+ if (free_bytes_.compare_exchange_weak(free, new_free,
257
273
  std::memory_order_acq_rel,
258
274
  std::memory_order_acquire)) {
259
275
  if (GRPC_TRACE_FLAG_ENABLED(grpc_resource_quota_trace)) {
@@ -446,19 +462,143 @@ void BasicMemoryQuota::Return(size_t amount) {
446
462
  free_bytes_.fetch_add(amount, std::memory_order_relaxed);
447
463
  }
448
464
 
449
- std::pair<double, size_t>
450
- BasicMemoryQuota::InstantaneousPressureAndMaxRecommendedAllocationSize() const {
465
+ BasicMemoryQuota::PressureInfo BasicMemoryQuota::GetPressureInfo() {
466
+ static const bool kSmoothMemoryPressure =
467
+ GPR_GLOBAL_CONFIG_GET(grpc_experimental_smooth_memory_presure);
451
468
  double free = free_bytes_.load();
452
469
  if (free < 0) free = 0;
453
470
  size_t quota_size = quota_size_.load();
454
471
  double size = quota_size;
455
- if (size < 1) return std::make_pair(1.0, 1);
456
- double pressure = (size - free) / size;
457
- if (pressure < 0.0) pressure = 0.0;
458
- if (pressure > 1.0) pressure = 1.0;
459
- return std::make_pair(pressure, quota_size / 16);
472
+ if (size < 1) return PressureInfo{1, 1, 1};
473
+ PressureInfo pressure_info;
474
+ pressure_info.instantaneous_pressure = std::max(0.0, (size - free) / size);
475
+ if (kSmoothMemoryPressure) {
476
+ pressure_info.pressure_control_value =
477
+ pressure_tracker_.AddSampleAndGetControlValue(
478
+ pressure_info.instantaneous_pressure);
479
+ } else {
480
+ pressure_info.pressure_control_value =
481
+ std::min(pressure_info.instantaneous_pressure, 1.0);
482
+ }
483
+ pressure_info.max_recommended_allocation_size = quota_size / 16;
484
+ return pressure_info;
485
+ }
486
+
487
+ //
488
+ // PressureTracker
489
+ //
490
+
491
+ namespace memory_quota_detail {
492
+
493
+ double PressureController::Update(double error) {
494
+ bool is_low = error < 0;
495
+ bool was_low = absl::exchange(last_was_low_, is_low);
496
+ double new_control; // leave unset to compiler can note bad branches
497
+ if (is_low && was_low) {
498
+ // Memory pressure is too low this round, and was last round too.
499
+ // If we have reached the min reporting value last time, then we will report
500
+ // the same value again this time and can start to increase the ticks_same_
501
+ // counter.
502
+ if (last_control_ == min_) {
503
+ ticks_same_++;
504
+ if (ticks_same_ >= max_ticks_same_) {
505
+ // If it's been the same for too long, reduce the min reported value
506
+ // down towards zero.
507
+ min_ /= 2.0;
508
+ ticks_same_ = 0;
509
+ }
510
+ }
511
+ // Target the min reporting value.
512
+ new_control = min_;
513
+ } else if (!is_low && !was_low) {
514
+ // Memory pressure is high, and was high previously.
515
+ ticks_same_++;
516
+ if (ticks_same_ >= max_ticks_same_) {
517
+ // It's been high for too long, increase the max reporting value up
518
+ // towards 1.0.
519
+ max_ = (1.0 + max_) / 2.0;
520
+ ticks_same_ = 0;
521
+ }
522
+ // Target the max reporting value.
523
+ new_control = max_;
524
+ } else if (is_low) {
525
+ // Memory pressure is low, but was high last round.
526
+ // Target the min reporting value, but first update it to be closer to the
527
+ // current max (that we've been reporting lately).
528
+ // In this way the min will gradually climb towards the max as we find a
529
+ // stable point.
530
+ // If this is too high, then we'll eventually move it back towards zero.
531
+ ticks_same_ = 0;
532
+ min_ = (min_ + max_) / 2.0;
533
+ new_control = min_;
534
+ } else {
535
+ // Memory pressure is high, but was low last round.
536
+ // Target the max reporting value, but first update it to be closer to the
537
+ // last reported value.
538
+ // The first switchover will have last_control_ being 0, and max_ being 2,
539
+ // so we'll immediately choose 1.0 which will tend to really slow down
540
+ // progress.
541
+ // If we end up targetting too low, we'll eventually move it back towards
542
+ // 1.0 after max_ticks_same_ ticks.
543
+ ticks_same_ = 0;
544
+ max_ = (last_control_ + max_) / 2.0;
545
+ new_control = max_;
546
+ }
547
+ // If the control value is decreasing we do it slowly. This avoids rapid
548
+ // oscillations.
549
+ // (If we want a control value that's higher than the last one we snap
550
+ // immediately because it's likely that memory pressure is growing unchecked).
551
+ if (new_control < last_control_) {
552
+ new_control =
553
+ std::max(new_control, last_control_ - max_reduction_per_tick_ / 1000.0);
554
+ }
555
+ last_control_ = new_control;
556
+ return new_control;
557
+ }
558
+
559
+ std::string PressureController::DebugString() const {
560
+ return absl::StrCat(last_was_low_ ? "low" : "high", " min=", min_,
561
+ " max=", max_, " ticks=", ticks_same_,
562
+ " last_control=", last_control_);
460
563
  }
461
564
 
565
+ double PressureTracker::AddSampleAndGetControlValue(double sample) {
566
+ static const double kSetPoint =
567
+ GPR_GLOBAL_CONFIG_GET(grpc_experimental_resource_quota_set_point) / 100.0;
568
+
569
+ double max_so_far = max_this_round_.load(std::memory_order_relaxed);
570
+ if (sample > max_so_far) {
571
+ max_this_round_.compare_exchange_weak(max_so_far, sample,
572
+ std::memory_order_relaxed,
573
+ std::memory_order_relaxed);
574
+ }
575
+ // If memory pressure is almost done, immediately hit the brakes and report
576
+ // full memory usage.
577
+ if (sample >= 0.99) {
578
+ report_.store(1.0, std::memory_order_relaxed);
579
+ }
580
+ update_.Tick([&](Duration) {
581
+ // Reset the round tracker with the new sample.
582
+ const double current_estimate =
583
+ max_this_round_.exchange(sample, std::memory_order_relaxed);
584
+ double report;
585
+ if (current_estimate > 0.99) {
586
+ // Under very high memory pressure we... just max things out.
587
+ report = controller_.Update(1e99);
588
+ } else {
589
+ report = controller_.Update(current_estimate - kSetPoint);
590
+ }
591
+ if (GRPC_TRACE_FLAG_ENABLED(grpc_resource_quota_trace)) {
592
+ gpr_log(GPR_INFO, "RQ: pressure:%lf report:%lf controller:%s",
593
+ current_estimate, report, controller_.DebugString().c_str());
594
+ }
595
+ report_.store(report, std::memory_order_relaxed);
596
+ });
597
+ return report_.load(std::memory_order_relaxed);
598
+ }
599
+
600
+ } // namespace memory_quota_detail
601
+
462
602
  //
463
603
  // MemoryQuota
464
604
  //