grpc 1.54.3 → 1.58.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (1696) hide show
  1. checksums.yaml +4 -4
  2. data/Makefile +642 -322
  3. data/include/grpc/event_engine/event_engine.h +26 -36
  4. data/include/grpc/event_engine/memory_allocator.h +2 -2
  5. data/include/grpc/grpc_audit_logging.h +96 -0
  6. data/include/grpc/grpc_security.h +19 -0
  7. data/include/grpc/impl/channel_arg_names.h +371 -0
  8. data/include/grpc/impl/grpc_types.h +1 -348
  9. data/include/grpc/module.modulemap +3 -0
  10. data/include/grpc/support/json.h +218 -0
  11. data/include/grpc/support/port_platform.h +29 -23
  12. data/src/core/ext/filters/backend_metrics/backend_metric_filter.cc +7 -2
  13. data/src/core/ext/filters/channel_idle/channel_idle_filter.cc +2 -1
  14. data/src/core/ext/filters/client_channel/backend_metric.cc +4 -1
  15. data/src/core/ext/filters/client_channel/channel_connectivity.cc +4 -4
  16. data/src/core/ext/filters/client_channel/client_channel.cc +145 -125
  17. data/src/core/ext/filters/client_channel/client_channel.h +24 -16
  18. data/src/core/ext/filters/client_channel/client_channel_channelz.cc +20 -19
  19. data/src/core/ext/filters/client_channel/client_channel_internal.h +22 -59
  20. data/src/core/ext/filters/client_channel/client_channel_service_config.cc +2 -2
  21. data/src/core/ext/filters/client_channel/config_selector.h +9 -36
  22. data/src/core/ext/filters/client_channel/dynamic_filters.h +3 -3
  23. data/src/core/ext/filters/client_channel/http_proxy.cc +40 -2
  24. data/src/core/ext/filters/client_channel/lb_policy/address_filtering.cc +27 -53
  25. data/src/core/ext/filters/client_channel/lb_policy/address_filtering.h +23 -9
  26. data/src/core/ext/filters/client_channel/lb_policy/backend_metric_data.h +3 -0
  27. data/src/core/ext/filters/client_channel/lb_policy/child_policy_handler.cc +25 -35
  28. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb.cc +86 -138
  29. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_balancer_addresses.cc +2 -1
  30. data/src/core/ext/filters/client_channel/lb_policy/grpclb/load_balancer_api.cc +5 -4
  31. data/src/core/ext/filters/client_channel/lb_policy/grpclb/load_balancer_api.h +4 -2
  32. data/src/core/ext/filters/client_channel/lb_policy/health_check_client.cc +480 -0
  33. data/src/core/ext/filters/client_channel/lb_policy/health_check_client.h +52 -0
  34. data/src/core/ext/filters/client_channel/lb_policy/health_check_client_internal.h +202 -0
  35. data/src/core/ext/filters/client_channel/lb_policy/oob_backend_metric.cc +6 -9
  36. data/src/core/ext/filters/client_channel/lb_policy/oob_backend_metric_internal.h +2 -0
  37. data/src/core/ext/filters/client_channel/lb_policy/outlier_detection/outlier_detection.cc +136 -78
  38. data/src/core/ext/filters/client_channel/lb_policy/outlier_detection/outlier_detection.h +9 -2
  39. data/src/core/ext/filters/client_channel/lb_policy/pick_first/pick_first.cc +168 -104
  40. data/src/core/ext/filters/client_channel/lb_policy/pick_first/pick_first.h +20 -0
  41. data/src/core/ext/filters/client_channel/lb_policy/priority/priority.cc +16 -45
  42. data/src/core/ext/filters/client_channel/lb_policy/ring_hash/ring_hash.cc +22 -14
  43. data/src/core/ext/filters/client_channel/lb_policy/ring_hash/ring_hash.h +18 -1
  44. data/src/core/ext/filters/client_channel/lb_policy/rls/rls.cc +73 -129
  45. data/src/core/ext/filters/client_channel/lb_policy/round_robin/round_robin.cc +7 -5
  46. data/src/core/ext/filters/client_channel/lb_policy/subchannel_list.h +57 -22
  47. data/src/core/ext/filters/client_channel/lb_policy/weighted_round_robin/static_stride_scheduler.cc +76 -6
  48. data/src/core/ext/filters/client_channel/lb_policy/weighted_round_robin/weighted_round_robin.cc +54 -45
  49. data/src/core/ext/filters/client_channel/lb_policy/weighted_target/weighted_target.cc +19 -54
  50. data/src/core/ext/filters/client_channel/lb_policy/xds/cds.cc +57 -116
  51. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_channel_args.h +8 -0
  52. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_impl.cc +35 -86
  53. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_manager.cc +23 -69
  54. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_resolver.cc +70 -141
  55. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_override_host.cc +26 -65
  56. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_wrr_locality.cc +28 -96
  57. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/dns_resolver_ares.cc +21 -123
  58. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/dns_resolver_ares.h +30 -0
  59. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver_posix.cc +102 -11
  60. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.cc +44 -37
  61. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.h +4 -1
  62. data/src/core/ext/filters/client_channel/resolver/dns/dns_resolver_plugin.cc +66 -0
  63. data/src/core/ext/filters/client_channel/resolver/dns/dns_resolver_plugin.h +27 -0
  64. data/src/core/ext/filters/client_channel/resolver/dns/event_engine/event_engine_client_channel_resolver.cc +586 -0
  65. data/src/core/ext/filters/client_channel/resolver/dns/event_engine/event_engine_client_channel_resolver.h +35 -0
  66. data/src/core/ext/filters/client_channel/resolver/dns/event_engine/service_config_helper.cc +97 -0
  67. data/src/core/ext/filters/client_channel/resolver/dns/event_engine/service_config_helper.h +32 -0
  68. data/src/core/ext/filters/client_channel/resolver/dns/native/dns_resolver.cc +3 -14
  69. data/src/core/ext/filters/client_channel/resolver/dns/native/dns_resolver.h +24 -0
  70. data/src/core/ext/filters/client_channel/resolver/google_c2p/google_c2p_resolver.cc +30 -28
  71. data/src/core/ext/filters/client_channel/resolver/polling_resolver.cc +10 -4
  72. data/src/core/ext/filters/client_channel/resolver/polling_resolver.h +1 -0
  73. data/src/core/ext/filters/client_channel/resolver/sockaddr/sockaddr_resolver.cc +25 -13
  74. data/src/core/ext/filters/client_channel/resolver/xds/xds_resolver.cc +420 -275
  75. data/src/core/ext/filters/client_channel/resolver/xds/xds_resolver.h +32 -1
  76. data/src/core/ext/filters/client_channel/retry_filter.cc +39 -2530
  77. data/src/core/ext/filters/client_channel/retry_filter.h +92 -1
  78. data/src/core/ext/filters/client_channel/retry_filter_legacy_call_data.cc +2052 -0
  79. data/src/core/ext/filters/client_channel/retry_filter_legacy_call_data.h +442 -0
  80. data/src/core/ext/filters/client_channel/retry_service_config.cc +10 -9
  81. data/src/core/ext/filters/client_channel/service_config_channel_arg_filter.cc +40 -90
  82. data/src/core/ext/filters/client_channel/subchannel.cc +17 -199
  83. data/src/core/ext/filters/client_channel/subchannel.h +14 -48
  84. data/src/core/ext/filters/client_channel/subchannel_interface_internal.h +3 -0
  85. data/src/core/ext/filters/deadline/deadline_filter.cc +1 -1
  86. data/src/core/ext/filters/fault_injection/fault_injection_service_config_parser.cc +1 -1
  87. data/src/core/ext/filters/http/client/http_client_filter.cc +1 -0
  88. data/src/core/ext/filters/http/client_authority_filter.cc +1 -1
  89. data/src/core/ext/filters/http/message_compress/compression_filter.cc +8 -7
  90. data/src/core/ext/filters/http/server/http_server_filter.cc +1 -1
  91. data/src/core/ext/filters/message_size/message_size_filter.cc +1 -0
  92. data/src/core/ext/filters/rbac/rbac_filter.cc +40 -111
  93. data/src/core/ext/filters/rbac/rbac_filter.h +12 -30
  94. data/src/core/ext/filters/rbac/rbac_service_config_parser.cc +162 -72
  95. data/src/core/ext/filters/server_config_selector/server_config_selector_filter.cc +6 -8
  96. data/src/core/ext/filters/stateful_session/stateful_session_filter.cc +164 -88
  97. data/src/core/ext/filters/stateful_session/stateful_session_filter.h +16 -7
  98. data/src/core/ext/transport/chttp2/client/chttp2_connector.cc +1 -0
  99. data/src/core/ext/transport/chttp2/server/chttp2_server.cc +15 -16
  100. data/src/core/ext/transport/chttp2/transport/chttp2_transport.cc +541 -542
  101. data/src/core/ext/transport/chttp2/transport/chttp2_transport.h +21 -0
  102. data/src/core/ext/transport/chttp2/transport/context_list_entry.h +70 -0
  103. data/src/core/ext/transport/chttp2/transport/decode_huff.cc +6569 -174
  104. data/src/core/ext/transport/chttp2/transport/decode_huff.h +2278 -441
  105. data/src/core/ext/transport/chttp2/transport/flow_control.cc +46 -95
  106. data/src/core/ext/transport/chttp2/transport/frame_ping.cc +7 -27
  107. data/src/core/ext/transport/chttp2/transport/frame_ping.h +0 -3
  108. data/src/core/ext/transport/chttp2/transport/hpack_encoder.h +1 -0
  109. data/src/core/ext/transport/chttp2/transport/hpack_parse_result.cc +176 -0
  110. data/src/core/ext/transport/chttp2/transport/hpack_parse_result.h +326 -0
  111. data/src/core/ext/transport/chttp2/transport/hpack_parser.cc +631 -547
  112. data/src/core/ext/transport/chttp2/transport/hpack_parser.h +157 -11
  113. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.cc +48 -33
  114. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.h +19 -5
  115. data/src/core/ext/transport/chttp2/transport/internal.h +42 -80
  116. data/src/core/ext/transport/chttp2/transport/parsing.cc +43 -22
  117. data/src/core/ext/transport/chttp2/transport/ping_abuse_policy.cc +80 -0
  118. data/src/core/ext/transport/chttp2/transport/ping_abuse_policy.h +55 -0
  119. data/src/core/ext/transport/chttp2/transport/ping_rate_policy.cc +98 -0
  120. data/src/core/ext/transport/chttp2/transport/ping_rate_policy.h +73 -0
  121. data/src/core/ext/transport/chttp2/transport/writing.cc +96 -94
  122. data/src/core/ext/transport/inproc/inproc_transport.cc +1 -0
  123. data/src/core/ext/upb-generated/envoy/admin/v3/certs.upb.c +87 -52
  124. data/src/core/ext/upb-generated/envoy/admin/v3/certs.upb.h +414 -181
  125. data/src/core/ext/upb-generated/envoy/admin/v3/clusters.upb.c +121 -60
  126. data/src/core/ext/upb-generated/envoy/admin/v3/clusters.upb.h +481 -224
  127. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump.upb.c +90 -55
  128. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump.upb.h +415 -188
  129. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump_shared.upb.c +357 -210
  130. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump_shared.upb.h +1572 -729
  131. data/src/core/ext/upb-generated/envoy/admin/v3/init_dump.upb.c +30 -17
  132. data/src/core/ext/upb-generated/envoy/admin/v3/init_dump.upb.h +144 -47
  133. data/src/core/ext/upb-generated/envoy/admin/v3/listeners.upb.c +34 -21
  134. data/src/core/ext/upb-generated/envoy/admin/v3/listeners.upb.h +160 -62
  135. data/src/core/ext/upb-generated/envoy/admin/v3/memory.upb.c +27 -14
  136. data/src/core/ext/upb-generated/envoy/admin/v3/memory.upb.h +78 -38
  137. data/src/core/ext/upb-generated/envoy/admin/v3/metrics.upb.c +20 -11
  138. data/src/core/ext/upb-generated/envoy/admin/v3/metrics.upb.h +48 -26
  139. data/src/core/ext/upb-generated/envoy/admin/v3/mutex_stats.upb.c +20 -11
  140. data/src/core/ext/upb-generated/envoy/admin/v3/mutex_stats.upb.h +48 -26
  141. data/src/core/ext/upb-generated/envoy/admin/v3/server_info.upb.c +109 -62
  142. data/src/core/ext/upb-generated/envoy/admin/v3/server_info.upb.h +566 -244
  143. data/src/core/ext/upb-generated/envoy/admin/v3/tap.upb.c +21 -12
  144. data/src/core/ext/upb-generated/envoy/admin/v3/tap.upb.h +45 -30
  145. data/src/core/ext/upb-generated/envoy/annotations/deprecation.upb.c +22 -19
  146. data/src/core/ext/upb-generated/envoy/annotations/deprecation.upb.h +82 -29
  147. data/src/core/ext/upb-generated/envoy/annotations/resource.upb.c +23 -16
  148. data/src/core/ext/upb-generated/envoy/annotations/resource.upb.h +45 -30
  149. data/src/core/ext/upb-generated/envoy/config/accesslog/v3/accesslog.upb.c +255 -147
  150. data/src/core/ext/upb-generated/envoy/config/accesslog/v3/accesslog.upb.h +876 -404
  151. data/src/core/ext/upb-generated/envoy/config/bootstrap/v3/bootstrap.upb.c +417 -264
  152. data/src/core/ext/upb-generated/envoy/config/bootstrap/v3/bootstrap.upb.h +1839 -899
  153. data/src/core/ext/upb-generated/envoy/config/cluster/v3/circuit_breaker.upb.c +74 -41
  154. data/src/core/ext/upb-generated/envoy/config/cluster/v3/circuit_breaker.upb.h +286 -148
  155. data/src/core/ext/upb-generated/envoy/config/cluster/v3/cluster.upb.c +531 -334
  156. data/src/core/ext/upb-generated/envoy/config/cluster/v3/cluster.upb.h +2017 -1131
  157. data/src/core/ext/upb-generated/envoy/config/cluster/v3/filter.upb.c +21 -12
  158. data/src/core/ext/upb-generated/envoy/config/cluster/v3/filter.upb.h +45 -30
  159. data/src/core/ext/upb-generated/envoy/config/cluster/v3/outlier_detection.upb.c +89 -52
  160. data/src/core/ext/upb-generated/envoy/config/cluster/v3/outlier_detection.upb.h +347 -232
  161. data/src/core/ext/upb-generated/envoy/config/common/matcher/v3/matcher.upb.c +264 -165
  162. data/src/core/ext/upb-generated/envoy/config/common/matcher/v3/matcher.upb.h +888 -476
  163. data/src/core/ext/upb-generated/envoy/config/core/v3/address.upb.c +139 -80
  164. data/src/core/ext/upb-generated/envoy/config/core/v3/address.upb.h +527 -274
  165. data/src/core/ext/upb-generated/envoy/config/core/v3/backoff.upb.c +22 -13
  166. data/src/core/ext/upb-generated/envoy/config/core/v3/backoff.upb.h +50 -36
  167. data/src/core/ext/upb-generated/envoy/config/core/v3/base.upb.c +380 -221
  168. data/src/core/ext/upb-generated/envoy/config/core/v3/base.upb.h +1168 -611
  169. data/src/core/ext/upb-generated/envoy/config/core/v3/config_source.upb.c +157 -92
  170. data/src/core/ext/upb-generated/envoy/config/core/v3/config_source.upb.h +627 -292
  171. data/src/core/ext/upb-generated/envoy/config/core/v3/event_service_config.upb.c +18 -11
  172. data/src/core/ext/upb-generated/envoy/config/core/v3/event_service_config.upb.h +37 -26
  173. data/src/core/ext/upb-generated/envoy/config/core/v3/extension.upb.c +21 -12
  174. data/src/core/ext/upb-generated/envoy/config/core/v3/extension.upb.h +45 -30
  175. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_method_list.upb.c +30 -17
  176. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_method_list.upb.h +144 -47
  177. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_service.upb.c +279 -167
  178. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_service.upb.h +818 -440
  179. data/src/core/ext/upb-generated/envoy/config/core/v3/health_check.upb.c +232 -137
  180. data/src/core/ext/upb-generated/envoy/config/core/v3/health_check.upb.h +1164 -500
  181. data/src/core/ext/upb-generated/envoy/config/core/v3/http_uri.upb.c +22 -13
  182. data/src/core/ext/upb-generated/envoy/config/core/v3/http_uri.upb.h +60 -37
  183. data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.c +369 -211
  184. data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.h +1114 -646
  185. data/src/core/ext/upb-generated/envoy/config/core/v3/proxy_protocol.upb.c +33 -18
  186. data/src/core/ext/upb-generated/envoy/config/core/v3/proxy_protocol.upb.h +117 -51
  187. data/src/core/ext/upb-generated/envoy/config/core/v3/resolver.upb.c +34 -19
  188. data/src/core/ext/upb-generated/envoy/config/core/v3/resolver.upb.h +118 -56
  189. data/src/core/ext/upb-generated/envoy/config/core/v3/socket_option.upb.c +38 -21
  190. data/src/core/ext/upb-generated/envoy/config/core/v3/socket_option.upb.h +148 -64
  191. data/src/core/ext/upb-generated/envoy/config/core/v3/substitution_format_string.upb.c +31 -18
  192. data/src/core/ext/upb-generated/envoy/config/core/v3/substitution_format_string.upb.h +143 -65
  193. data/src/core/ext/upb-generated/envoy/config/core/v3/udp_socket_config.upb.c +22 -13
  194. data/src/core/ext/upb-generated/envoy/config/core/v3/udp_socket_config.upb.h +51 -37
  195. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint.upb.c +78 -43
  196. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint.upb.h +265 -127
  197. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint_components.upb.c +145 -88
  198. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint_components.upb.h +438 -241
  199. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/load_report.upb.c +115 -62
  200. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/load_report.upb.h +559 -227
  201. data/src/core/ext/upb-generated/envoy/config/listener/v3/api_listener.upb.c +18 -11
  202. data/src/core/ext/upb-generated/envoy/config/listener/v3/api_listener.upb.h +35 -26
  203. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener.upb.c +175 -118
  204. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener.upb.h +857 -442
  205. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener_components.upb.c +172 -95
  206. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener_components.upb.h +864 -374
  207. data/src/core/ext/upb-generated/envoy/config/listener/v3/quic_config.upb.c +48 -27
  208. data/src/core/ext/upb-generated/envoy/config/listener/v3/quic_config.upb.h +159 -110
  209. data/src/core/ext/upb-generated/envoy/config/listener/v3/udp_listener_config.upb.c +39 -18
  210. data/src/core/ext/upb-generated/envoy/config/listener/v3/udp_listener_config.upb.h +74 -56
  211. data/src/core/ext/upb-generated/envoy/config/metrics/v3/metrics_service.upb.c +29 -15
  212. data/src/core/ext/upb-generated/envoy/config/metrics/v3/metrics_service.upb.h +92 -45
  213. data/src/core/ext/upb-generated/envoy/config/metrics/v3/stats.upb.c +131 -74
  214. data/src/core/ext/upb-generated/envoy/config/metrics/v3/stats.upb.h +489 -249
  215. data/src/core/ext/upb-generated/envoy/config/overload/v3/overload.upb.c +163 -84
  216. data/src/core/ext/upb-generated/envoy/config/overload/v3/overload.upb.h +680 -240
  217. data/src/core/ext/upb-generated/envoy/config/rbac/v3/rbac.upb.c +248 -139
  218. data/src/core/ext/upb-generated/envoy/config/rbac/v3/rbac.upb.h +933 -433
  219. data/src/core/ext/upb-generated/envoy/config/route/v3/route.upb.c +80 -49
  220. data/src/core/ext/upb-generated/envoy/config/route/v3/route.upb.h +616 -201
  221. data/src/core/ext/upb-generated/envoy/config/route/v3/route_components.upb.c +1283 -776
  222. data/src/core/ext/upb-generated/envoy/config/route/v3/route_components.upb.h +5422 -2519
  223. data/src/core/ext/upb-generated/envoy/config/route/v3/scoped_route.upb.c +49 -28
  224. data/src/core/ext/upb-generated/envoy/config/route/v3/scoped_route.upb.h +164 -84
  225. data/src/core/ext/upb-generated/envoy/config/tap/v3/common.upb.c +228 -141
  226. data/src/core/ext/upb-generated/envoy/config/tap/v3/common.upb.h +738 -399
  227. data/src/core/ext/upb-generated/envoy/config/trace/v3/datadog.upb.c +20 -11
  228. data/src/core/ext/upb-generated/envoy/config/trace/v3/datadog.upb.h +48 -26
  229. data/src/core/ext/upb-generated/envoy/config/trace/v3/dynamic_ot.upb.c +21 -12
  230. data/src/core/ext/upb-generated/envoy/config/trace/v3/dynamic_ot.upb.h +45 -30
  231. data/src/core/ext/upb-generated/envoy/config/trace/v3/http_tracer.upb.c +32 -19
  232. data/src/core/ext/upb-generated/envoy/config/trace/v3/http_tracer.upb.h +70 -49
  233. data/src/core/ext/upb-generated/envoy/config/trace/v3/lightstep.upb.c +27 -14
  234. data/src/core/ext/upb-generated/envoy/config/trace/v3/lightstep.upb.h +110 -43
  235. data/src/core/ext/upb-generated/envoy/config/trace/v3/opencensus.upb.c +46 -25
  236. data/src/core/ext/upb-generated/envoy/config/trace/v3/opencensus.upb.h +259 -100
  237. data/src/core/ext/upb-generated/envoy/config/trace/v3/opentelemetry.upb.c +21 -12
  238. data/src/core/ext/upb-generated/envoy/config/trace/v3/opentelemetry.upb.h +45 -30
  239. data/src/core/ext/upb-generated/envoy/config/trace/v3/service.upb.c +18 -11
  240. data/src/core/ext/upb-generated/envoy/config/trace/v3/service.upb.h +35 -26
  241. data/src/core/ext/upb-generated/envoy/config/trace/v3/skywalking.upb.c +42 -23
  242. data/src/core/ext/upb-generated/envoy/config/trace/v3/skywalking.upb.h +108 -70
  243. data/src/core/ext/upb-generated/envoy/config/trace/v3/trace.upb.c +7 -4
  244. data/src/core/ext/upb-generated/envoy/config/trace/v3/trace.upb.h +21 -16
  245. data/src/core/ext/upb-generated/envoy/config/trace/v3/xray.upb.c +43 -24
  246. data/src/core/ext/upb-generated/envoy/config/trace/v3/xray.upb.h +110 -75
  247. data/src/core/ext/upb-generated/envoy/config/trace/v3/zipkin.upb.c +30 -17
  248. data/src/core/ext/upb-generated/envoy/config/trace/v3/zipkin.upb.h +95 -50
  249. data/src/core/ext/upb-generated/envoy/data/accesslog/v3/accesslog.upb.c +558 -0
  250. data/src/core/ext/upb-generated/envoy/data/accesslog/v3/accesslog.upb.h +2710 -0
  251. data/src/core/ext/upb-generated/envoy/extensions/clusters/aggregate/v3/cluster.upb.c +16 -9
  252. data/src/core/ext/upb-generated/envoy/extensions/clusters/aggregate/v3/cluster.upb.h +73 -23
  253. data/src/core/ext/upb-generated/envoy/extensions/filters/common/fault/v3/fault.upb.c +60 -37
  254. data/src/core/ext/upb-generated/envoy/extensions/filters/common/fault/v3/fault.upb.h +150 -108
  255. data/src/core/ext/upb-generated/envoy/extensions/filters/http/fault/v3/fault.upb.c +93 -43
  256. data/src/core/ext/upb-generated/envoy/extensions/filters/http/fault/v3/fault.upb.h +386 -167
  257. data/src/core/ext/upb-generated/envoy/extensions/filters/http/rbac/v3/rbac.upb.c +44 -25
  258. data/src/core/ext/upb-generated/envoy/extensions/filters/http/rbac/v3/rbac.upb.h +114 -80
  259. data/src/core/ext/upb-generated/envoy/extensions/filters/http/router/v3/router.upb.c +68 -22
  260. data/src/core/ext/upb-generated/envoy/extensions/filters/http/router/v3/router.upb.h +355 -82
  261. data/src/core/ext/upb-generated/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upb.c +32 -19
  262. data/src/core/ext/upb-generated/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upb.h +73 -51
  263. data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.c +504 -300
  264. data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.h +2243 -1075
  265. data/src/core/ext/upb-generated/envoy/extensions/http/stateful_session/cookie/v3/cookie.upb.c +18 -11
  266. data/src/core/ext/upb-generated/envoy/extensions/http/stateful_session/cookie/v3/cookie.upb.h +35 -26
  267. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/client_side_weighted_round_robin/v3/client_side_weighted_round_robin.upb.c +35 -21
  268. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/client_side_weighted_round_robin/v3/client_side_weighted_round_robin.upb.h +112 -78
  269. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/common/v3/common.upb.c +72 -45
  270. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/common/v3/common.upb.h +193 -138
  271. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/pick_first/v3/pick_first.upb.c +47 -0
  272. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/pick_first/v3/pick_first.upb.h +93 -0
  273. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/ring_hash/v3/ring_hash.upb.c +34 -21
  274. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/ring_hash/v3/ring_hash.upb.h +119 -78
  275. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/wrr_locality/v3/wrr_locality.upb.c +18 -11
  276. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/wrr_locality/v3/wrr_locality.upb.h +35 -26
  277. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/cert.upb.c +7 -4
  278. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/cert.upb.h +15 -10
  279. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/common.upb.c +184 -96
  280. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/common.upb.h +907 -360
  281. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/secret.upb.c +56 -33
  282. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/secret.upb.h +150 -101
  283. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls.upb.c +188 -111
  284. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls.upb.h +816 -419
  285. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upb.c +32 -19
  286. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upb.h +109 -53
  287. data/src/core/ext/upb-generated/envoy/service/discovery/v3/ads.upb.c +10 -7
  288. data/src/core/ext/upb-generated/envoy/service/discovery/v3/ads.upb.h +18 -14
  289. data/src/core/ext/upb-generated/envoy/service/discovery/v3/discovery.upb.c +300 -177
  290. data/src/core/ext/upb-generated/envoy/service/discovery/v3/discovery.upb.h +1284 -522
  291. data/src/core/ext/upb-generated/envoy/service/load_stats/v3/lrs.upb.c +42 -23
  292. data/src/core/ext/upb-generated/envoy/service/load_stats/v3/lrs.upb.h +188 -75
  293. data/src/core/ext/upb-generated/envoy/service/status/v3/csds.upb.c +130 -83
  294. data/src/core/ext/upb-generated/envoy/service/status/v3/csds.upb.h +510 -238
  295. data/src/core/ext/upb-generated/envoy/type/http/v3/cookie.upb.c +22 -13
  296. data/src/core/ext/upb-generated/envoy/type/http/v3/cookie.upb.h +55 -34
  297. data/src/core/ext/upb-generated/envoy/type/http/v3/path_transformation.upb.c +39 -26
  298. data/src/core/ext/upb-generated/envoy/type/http/v3/path_transformation.upb.h +124 -68
  299. data/src/core/ext/upb-generated/envoy/type/matcher/v3/filter_state.upb.c +21 -12
  300. data/src/core/ext/upb-generated/envoy/type/matcher/v3/filter_state.upb.h +47 -30
  301. data/src/core/ext/upb-generated/envoy/type/matcher/v3/http_inputs.upb.c +52 -29
  302. data/src/core/ext/upb-generated/envoy/type/matcher/v3/http_inputs.upb.h +92 -62
  303. data/src/core/ext/upb-generated/envoy/type/matcher/v3/metadata.upb.c +37 -20
  304. data/src/core/ext/upb-generated/envoy/type/matcher/v3/metadata.upb.h +133 -63
  305. data/src/core/ext/upb-generated/envoy/type/matcher/v3/node.upb.c +22 -13
  306. data/src/core/ext/upb-generated/envoy/type/matcher/v3/node.upb.h +91 -40
  307. data/src/core/ext/upb-generated/envoy/type/matcher/v3/number.upb.c +21 -12
  308. data/src/core/ext/upb-generated/envoy/type/matcher/v3/number.upb.h +50 -32
  309. data/src/core/ext/upb-generated/envoy/type/matcher/v3/path.upb.c +18 -11
  310. data/src/core/ext/upb-generated/envoy/type/matcher/v3/path.upb.h +37 -26
  311. data/src/core/ext/upb-generated/envoy/type/matcher/v3/regex.upb.c +46 -27
  312. data/src/core/ext/upb-generated/envoy/type/matcher/v3/regex.upb.h +101 -70
  313. data/src/core/ext/upb-generated/envoy/type/matcher/v3/status_code_input.upb.c +13 -10
  314. data/src/core/ext/upb-generated/envoy/type/matcher/v3/status_code_input.upb.h +25 -22
  315. data/src/core/ext/upb-generated/envoy/type/matcher/v3/string.upb.c +40 -23
  316. data/src/core/ext/upb-generated/envoy/type/matcher/v3/string.upb.h +161 -75
  317. data/src/core/ext/upb-generated/envoy/type/matcher/v3/struct.upb.c +31 -18
  318. data/src/core/ext/upb-generated/envoy/type/matcher/v3/struct.upb.h +114 -56
  319. data/src/core/ext/upb-generated/envoy/type/matcher/v3/value.upb.c +46 -29
  320. data/src/core/ext/upb-generated/envoy/type/matcher/v3/value.upb.h +139 -91
  321. data/src/core/ext/upb-generated/envoy/type/metadata/v3/metadata.upb.c +65 -42
  322. data/src/core/ext/upb-generated/envoy/type/metadata/v3/metadata.upb.h +200 -121
  323. data/src/core/ext/upb-generated/envoy/type/tracing/v3/custom_tag.upb.c +80 -45
  324. data/src/core/ext/upb-generated/envoy/type/tracing/v3/custom_tag.upb.h +208 -131
  325. data/src/core/ext/upb-generated/envoy/type/v3/hash_policy.upb.c +34 -21
  326. data/src/core/ext/upb-generated/envoy/type/v3/hash_policy.upb.h +74 -53
  327. data/src/core/ext/upb-generated/envoy/type/v3/http.upb.c +7 -4
  328. data/src/core/ext/upb-generated/envoy/type/v3/http.upb.h +13 -8
  329. data/src/core/ext/upb-generated/envoy/type/v3/http_status.upb.c +16 -9
  330. data/src/core/ext/upb-generated/envoy/type/v3/http_status.upb.h +28 -18
  331. data/src/core/ext/upb-generated/envoy/type/v3/percent.upb.c +28 -15
  332. data/src/core/ext/upb-generated/envoy/type/v3/percent.upb.h +55 -34
  333. data/src/core/ext/upb-generated/envoy/type/v3/range.upb.c +43 -22
  334. data/src/core/ext/upb-generated/envoy/type/v3/range.upb.h +91 -53
  335. data/src/core/ext/upb-generated/envoy/type/v3/ratelimit_strategy.upb.c +35 -20
  336. data/src/core/ext/upb-generated/envoy/type/v3/ratelimit_strategy.upb.h +92 -57
  337. data/src/core/ext/upb-generated/envoy/type/v3/ratelimit_unit.upb.c +7 -4
  338. data/src/core/ext/upb-generated/envoy/type/v3/ratelimit_unit.upb.h +13 -8
  339. data/src/core/ext/upb-generated/envoy/type/v3/semantic_version.upb.c +20 -11
  340. data/src/core/ext/upb-generated/envoy/type/v3/semantic_version.upb.h +48 -26
  341. data/src/core/ext/upb-generated/envoy/type/v3/token_bucket.upb.c +23 -14
  342. data/src/core/ext/upb-generated/envoy/type/v3/token_bucket.upb.h +61 -41
  343. data/src/core/ext/upb-generated/google/api/annotations.upb.c +14 -11
  344. data/src/core/ext/upb-generated/google/api/annotations.upb.h +30 -20
  345. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/checked.upb.c +255 -154
  346. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/checked.upb.h +934 -450
  347. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/syntax.upb.c +299 -180
  348. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/syntax.upb.h +946 -483
  349. data/src/core/ext/upb-generated/google/api/http.upb.c +68 -35
  350. data/src/core/ext/upb-generated/google/api/http.upb.h +284 -120
  351. data/src/core/ext/upb-generated/google/api/httpbody.upb.c +22 -13
  352. data/src/core/ext/upb-generated/google/api/httpbody.upb.h +95 -37
  353. data/src/core/ext/upb-generated/google/protobuf/any.upb.c +19 -10
  354. data/src/core/ext/upb-generated/google/protobuf/any.upb.h +38 -22
  355. data/src/core/ext/upb-generated/google/protobuf/descriptor.upb.c +1018 -424
  356. data/src/core/ext/upb-generated/google/protobuf/descriptor.upb.h +3851 -1412
  357. data/src/core/ext/upb-generated/google/protobuf/duration.upb.c +19 -10
  358. data/src/core/ext/upb-generated/google/protobuf/duration.upb.h +38 -22
  359. data/src/core/ext/upb-generated/google/protobuf/empty.upb.c +10 -7
  360. data/src/core/ext/upb-generated/google/protobuf/empty.upb.h +18 -14
  361. data/src/core/ext/upb-generated/google/protobuf/struct.upb.c +62 -39
  362. data/src/core/ext/upb-generated/google/protobuf/struct.upb.h +207 -102
  363. data/src/core/ext/upb-generated/google/protobuf/timestamp.upb.c +19 -10
  364. data/src/core/ext/upb-generated/google/protobuf/timestamp.upb.h +38 -22
  365. data/src/core/ext/upb-generated/google/protobuf/wrappers.upb.c +90 -51
  366. data/src/core/ext/upb-generated/google/protobuf/wrappers.upb.h +157 -107
  367. data/src/core/ext/upb-generated/google/rpc/status.upb.c +22 -13
  368. data/src/core/ext/upb-generated/google/rpc/status.upb.h +95 -37
  369. data/src/core/ext/upb-generated/opencensus/proto/trace/v1/trace_config.upb.c +59 -34
  370. data/src/core/ext/upb-generated/opencensus/proto/trace/v1/trace_config.upb.h +154 -92
  371. data/src/core/ext/upb-generated/src/proto/grpc/gcp/altscontext.upb.c +43 -24
  372. data/src/core/ext/upb-generated/src/proto/grpc/gcp/altscontext.upb.h +118 -60
  373. data/src/core/ext/upb-generated/src/proto/grpc/gcp/handshaker.upb.c +250 -145
  374. data/src/core/ext/upb-generated/src/proto/grpc/gcp/handshaker.upb.h +919 -415
  375. data/src/core/ext/upb-generated/src/proto/grpc/gcp/transport_security_common.upb.c +34 -19
  376. data/src/core/ext/upb-generated/src/proto/grpc/gcp/transport_security_common.upb.h +76 -51
  377. data/src/core/ext/upb-generated/src/proto/grpc/health/v1/health.upb.c +25 -14
  378. data/src/core/ext/upb-generated/src/proto/grpc/health/v1/health.upb.h +45 -30
  379. data/src/core/ext/upb-generated/src/proto/grpc/lb/v1/load_balancer.upb.c +144 -81
  380. data/src/core/ext/upb-generated/src/proto/grpc/lb/v1/load_balancer.upb.h +405 -217
  381. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls.upb.c +51 -26
  382. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls.upb.h +153 -61
  383. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls_config.upb.c +173 -102
  384. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls_config.upb.h +855 -298
  385. data/src/core/ext/upb-generated/udpa/annotations/migrate.upb.c +68 -49
  386. data/src/core/ext/upb-generated/udpa/annotations/migrate.upb.h +155 -104
  387. data/src/core/ext/upb-generated/udpa/annotations/security.upb.c +26 -17
  388. data/src/core/ext/upb-generated/udpa/annotations/security.upb.h +55 -34
  389. data/src/core/ext/upb-generated/udpa/annotations/sensitive.upb.c +12 -9
  390. data/src/core/ext/upb-generated/udpa/annotations/sensitive.upb.h +31 -14
  391. data/src/core/ext/upb-generated/udpa/annotations/status.upb.c +26 -17
  392. data/src/core/ext/upb-generated/udpa/annotations/status.upb.h +55 -34
  393. data/src/core/ext/upb-generated/udpa/annotations/versioning.upb.c +23 -16
  394. data/src/core/ext/upb-generated/udpa/annotations/versioning.upb.h +45 -30
  395. data/src/core/ext/upb-generated/validate/validate.upb.c +845 -455
  396. data/src/core/ext/upb-generated/validate/validate.upb.h +4347 -1908
  397. data/src/core/ext/upb-generated/xds/annotations/v3/migrate.upb.c +68 -49
  398. data/src/core/ext/upb-generated/xds/annotations/v3/migrate.upb.h +155 -104
  399. data/src/core/ext/upb-generated/xds/annotations/v3/security.upb.c +26 -17
  400. data/src/core/ext/upb-generated/xds/annotations/v3/security.upb.h +55 -34
  401. data/src/core/ext/upb-generated/xds/annotations/v3/sensitive.upb.c +12 -9
  402. data/src/core/ext/upb-generated/xds/annotations/v3/sensitive.upb.h +31 -14
  403. data/src/core/ext/upb-generated/xds/annotations/v3/status.upb.c +65 -44
  404. data/src/core/ext/upb-generated/xds/annotations/v3/status.upb.h +137 -91
  405. data/src/core/ext/upb-generated/xds/annotations/v3/versioning.upb.c +23 -16
  406. data/src/core/ext/upb-generated/xds/annotations/v3/versioning.upb.h +45 -30
  407. data/src/core/ext/upb-generated/xds/core/v3/authority.upb.c +16 -9
  408. data/src/core/ext/upb-generated/xds/core/v3/authority.upb.h +28 -18
  409. data/src/core/ext/upb-generated/xds/core/v3/cidr.upb.c +21 -12
  410. data/src/core/ext/upb-generated/xds/core/v3/cidr.upb.h +45 -30
  411. data/src/core/ext/upb-generated/xds/core/v3/collection_entry.upb.c +37 -22
  412. data/src/core/ext/upb-generated/xds/core/v3/collection_entry.upb.h +96 -63
  413. data/src/core/ext/upb-generated/xds/core/v3/context_params.upb.c +26 -17
  414. data/src/core/ext/upb-generated/xds/core/v3/context_params.upb.h +52 -29
  415. data/src/core/ext/upb-generated/xds/core/v3/extension.upb.c +21 -12
  416. data/src/core/ext/upb-generated/xds/core/v3/extension.upb.h +45 -30
  417. data/src/core/ext/upb-generated/xds/core/v3/resource.upb.c +23 -14
  418. data/src/core/ext/upb-generated/xds/core/v3/resource.upb.h +62 -42
  419. data/src/core/ext/upb-generated/xds/core/v3/resource_locator.upb.c +44 -25
  420. data/src/core/ext/upb-generated/xds/core/v3/resource_locator.upb.h +169 -79
  421. data/src/core/ext/upb-generated/xds/core/v3/resource_name.upb.c +27 -14
  422. data/src/core/ext/upb-generated/xds/core/v3/resource_name.upb.h +65 -38
  423. data/src/core/ext/upb-generated/xds/data/orca/v3/orca_load_report.upb.c +78 -38
  424. data/src/core/ext/upb-generated/xds/data/orca/v3/orca_load_report.upb.h +182 -76
  425. data/src/core/ext/upb-generated/xds/service/orca/v3/orca.upb.c +21 -12
  426. data/src/core/ext/upb-generated/xds/service/orca/v3/orca.upb.h +89 -34
  427. data/src/core/ext/upb-generated/xds/type/matcher/v3/cel.upb.c +18 -11
  428. data/src/core/ext/upb-generated/xds/type/matcher/v3/cel.upb.h +35 -26
  429. data/src/core/ext/upb-generated/xds/type/matcher/v3/domain.upb.c +32 -19
  430. data/src/core/ext/upb-generated/xds/type/matcher/v3/domain.upb.h +150 -54
  431. data/src/core/ext/upb-generated/xds/type/matcher/v3/http_inputs.upb.c +10 -7
  432. data/src/core/ext/upb-generated/xds/type/matcher/v3/http_inputs.upb.h +18 -14
  433. data/src/core/ext/upb-generated/xds/type/matcher/v3/ip.upb.c +34 -21
  434. data/src/core/ext/upb-generated/xds/type/matcher/v3/ip.upb.h +161 -63
  435. data/src/core/ext/upb-generated/xds/type/matcher/v3/matcher.upb.c +162 -101
  436. data/src/core/ext/upb-generated/xds/type/matcher/v3/matcher.upb.h +501 -293
  437. data/src/core/ext/upb-generated/xds/type/matcher/v3/range.upb.c +85 -52
  438. data/src/core/ext/upb-generated/xds/type/matcher/v3/range.upb.h +430 -164
  439. data/src/core/ext/upb-generated/xds/type/matcher/v3/regex.upb.c +24 -15
  440. data/src/core/ext/upb-generated/xds/type/matcher/v3/regex.upb.h +53 -37
  441. data/src/core/ext/upb-generated/xds/type/matcher/v3/string.upb.c +40 -23
  442. data/src/core/ext/upb-generated/xds/type/matcher/v3/string.upb.h +161 -75
  443. data/src/core/ext/upb-generated/xds/type/v3/cel.upb.c +37 -22
  444. data/src/core/ext/upb-generated/xds/type/v3/cel.upb.h +92 -66
  445. data/src/core/ext/upb-generated/xds/type/v3/range.upb.c +43 -22
  446. data/src/core/ext/upb-generated/xds/type/v3/range.upb.h +91 -53
  447. data/src/core/ext/upb-generated/xds/type/v3/typed_struct.upb.c +21 -12
  448. data/src/core/ext/upb-generated/xds/type/v3/typed_struct.upb.h +45 -30
  449. data/src/core/ext/upbdefs-generated/envoy/admin/v3/certs.upbdefs.c +1 -1
  450. data/src/core/ext/upbdefs-generated/envoy/admin/v3/certs.upbdefs.h +6 -5
  451. data/src/core/ext/upbdefs-generated/envoy/admin/v3/clusters.upbdefs.c +1 -1
  452. data/src/core/ext/upbdefs-generated/envoy/admin/v3/clusters.upbdefs.h +6 -5
  453. data/src/core/ext/upbdefs-generated/envoy/admin/v3/config_dump.upbdefs.c +1 -1
  454. data/src/core/ext/upbdefs-generated/envoy/admin/v3/config_dump.upbdefs.h +6 -5
  455. data/src/core/ext/upbdefs-generated/envoy/admin/v3/config_dump_shared.upbdefs.c +1 -1
  456. data/src/core/ext/upbdefs-generated/envoy/admin/v3/config_dump_shared.upbdefs.h +6 -5
  457. data/src/core/ext/upbdefs-generated/envoy/admin/v3/init_dump.upbdefs.c +1 -1
  458. data/src/core/ext/upbdefs-generated/envoy/admin/v3/init_dump.upbdefs.h +6 -5
  459. data/src/core/ext/upbdefs-generated/envoy/admin/v3/listeners.upbdefs.c +1 -1
  460. data/src/core/ext/upbdefs-generated/envoy/admin/v3/listeners.upbdefs.h +6 -5
  461. data/src/core/ext/upbdefs-generated/envoy/admin/v3/memory.upbdefs.c +1 -1
  462. data/src/core/ext/upbdefs-generated/envoy/admin/v3/memory.upbdefs.h +6 -5
  463. data/src/core/ext/upbdefs-generated/envoy/admin/v3/metrics.upbdefs.c +1 -1
  464. data/src/core/ext/upbdefs-generated/envoy/admin/v3/metrics.upbdefs.h +6 -5
  465. data/src/core/ext/upbdefs-generated/envoy/admin/v3/mutex_stats.upbdefs.c +1 -1
  466. data/src/core/ext/upbdefs-generated/envoy/admin/v3/mutex_stats.upbdefs.h +6 -5
  467. data/src/core/ext/upbdefs-generated/envoy/admin/v3/server_info.upbdefs.c +1 -1
  468. data/src/core/ext/upbdefs-generated/envoy/admin/v3/server_info.upbdefs.h +6 -5
  469. data/src/core/ext/upbdefs-generated/envoy/admin/v3/tap.upbdefs.c +1 -1
  470. data/src/core/ext/upbdefs-generated/envoy/admin/v3/tap.upbdefs.h +6 -5
  471. data/src/core/ext/upbdefs-generated/envoy/annotations/deprecation.upbdefs.c +1 -1
  472. data/src/core/ext/upbdefs-generated/envoy/annotations/deprecation.upbdefs.h +6 -5
  473. data/src/core/ext/upbdefs-generated/envoy/annotations/resource.upbdefs.c +1 -1
  474. data/src/core/ext/upbdefs-generated/envoy/annotations/resource.upbdefs.h +6 -5
  475. data/src/core/ext/upbdefs-generated/envoy/config/accesslog/v3/accesslog.upbdefs.c +89 -77
  476. data/src/core/ext/upbdefs-generated/envoy/config/accesslog/v3/accesslog.upbdefs.h +11 -5
  477. data/src/core/ext/upbdefs-generated/envoy/config/bootstrap/v3/bootstrap.upbdefs.c +252 -253
  478. data/src/core/ext/upbdefs-generated/envoy/config/bootstrap/v3/bootstrap.upbdefs.h +6 -5
  479. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/circuit_breaker.upbdefs.c +1 -1
  480. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/circuit_breaker.upbdefs.h +6 -5
  481. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/cluster.upbdefs.c +1 -1
  482. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/cluster.upbdefs.h +6 -5
  483. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/filter.upbdefs.c +1 -1
  484. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/filter.upbdefs.h +6 -5
  485. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/outlier_detection.upbdefs.c +1 -1
  486. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/outlier_detection.upbdefs.h +6 -5
  487. data/src/core/ext/upbdefs-generated/envoy/config/common/matcher/v3/matcher.upbdefs.c +1 -1
  488. data/src/core/ext/upbdefs-generated/envoy/config/common/matcher/v3/matcher.upbdefs.h +6 -5
  489. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/address.upbdefs.c +1 -1
  490. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/address.upbdefs.h +6 -5
  491. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/backoff.upbdefs.c +1 -1
  492. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/backoff.upbdefs.h +6 -5
  493. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/base.upbdefs.c +1 -1
  494. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/base.upbdefs.h +6 -5
  495. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/config_source.upbdefs.c +1 -1
  496. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/config_source.upbdefs.h +6 -5
  497. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/event_service_config.upbdefs.c +1 -1
  498. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/event_service_config.upbdefs.h +6 -5
  499. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/extension.upbdefs.c +1 -1
  500. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/extension.upbdefs.h +6 -5
  501. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/grpc_method_list.upbdefs.c +1 -1
  502. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/grpc_method_list.upbdefs.h +6 -5
  503. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/grpc_service.upbdefs.c +163 -161
  504. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/grpc_service.upbdefs.h +6 -5
  505. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/health_check.upbdefs.c +130 -119
  506. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/health_check.upbdefs.h +6 -5
  507. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/http_uri.upbdefs.c +1 -1
  508. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/http_uri.upbdefs.h +6 -5
  509. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/protocol.upbdefs.c +142 -136
  510. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/protocol.upbdefs.h +6 -5
  511. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/proxy_protocol.upbdefs.c +1 -1
  512. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/proxy_protocol.upbdefs.h +6 -5
  513. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/resolver.upbdefs.c +1 -1
  514. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/resolver.upbdefs.h +6 -5
  515. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/socket_option.upbdefs.c +1 -1
  516. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/socket_option.upbdefs.h +6 -5
  517. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/substitution_format_string.upbdefs.c +1 -1
  518. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/substitution_format_string.upbdefs.h +6 -5
  519. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/udp_socket_config.upbdefs.c +1 -1
  520. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/udp_socket_config.upbdefs.h +6 -5
  521. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint.upbdefs.c +1 -1
  522. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint.upbdefs.h +6 -5
  523. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint_components.upbdefs.c +1 -1
  524. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint_components.upbdefs.h +6 -5
  525. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/load_report.upbdefs.c +1 -1
  526. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/load_report.upbdefs.h +6 -5
  527. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/api_listener.upbdefs.c +1 -1
  528. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/api_listener.upbdefs.h +6 -5
  529. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener.upbdefs.c +1 -1
  530. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener.upbdefs.h +6 -5
  531. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener_components.upbdefs.c +1 -1
  532. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener_components.upbdefs.h +6 -5
  533. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/quic_config.upbdefs.c +1 -1
  534. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/quic_config.upbdefs.h +6 -5
  535. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/udp_listener_config.upbdefs.c +1 -1
  536. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/udp_listener_config.upbdefs.h +6 -5
  537. data/src/core/ext/upbdefs-generated/envoy/config/metrics/v3/metrics_service.upbdefs.c +20 -13
  538. data/src/core/ext/upbdefs-generated/envoy/config/metrics/v3/metrics_service.upbdefs.h +6 -5
  539. data/src/core/ext/upbdefs-generated/envoy/config/metrics/v3/stats.upbdefs.c +1 -1
  540. data/src/core/ext/upbdefs-generated/envoy/config/metrics/v3/stats.upbdefs.h +6 -5
  541. data/src/core/ext/upbdefs-generated/envoy/config/overload/v3/overload.upbdefs.c +39 -31
  542. data/src/core/ext/upbdefs-generated/envoy/config/overload/v3/overload.upbdefs.h +11 -5
  543. data/src/core/ext/upbdefs-generated/envoy/config/rbac/v3/rbac.upbdefs.c +134 -128
  544. data/src/core/ext/upbdefs-generated/envoy/config/rbac/v3/rbac.upbdefs.h +11 -5
  545. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route.upbdefs.c +1 -1
  546. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route.upbdefs.h +6 -5
  547. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route_components.upbdefs.c +1 -1
  548. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route_components.upbdefs.h +6 -5
  549. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/scoped_route.upbdefs.c +1 -1
  550. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/scoped_route.upbdefs.h +6 -5
  551. data/src/core/ext/upbdefs-generated/envoy/config/tap/v3/common.upbdefs.c +1 -1
  552. data/src/core/ext/upbdefs-generated/envoy/config/tap/v3/common.upbdefs.h +6 -5
  553. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/datadog.upbdefs.c +1 -1
  554. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/datadog.upbdefs.h +6 -5
  555. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/dynamic_ot.upbdefs.c +1 -1
  556. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/dynamic_ot.upbdefs.h +6 -5
  557. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/http_tracer.upbdefs.c +1 -1
  558. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/http_tracer.upbdefs.h +6 -5
  559. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/lightstep.upbdefs.c +1 -1
  560. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/lightstep.upbdefs.h +6 -5
  561. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/opencensus.upbdefs.c +1 -1
  562. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/opencensus.upbdefs.h +6 -5
  563. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/opentelemetry.upbdefs.c +1 -1
  564. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/opentelemetry.upbdefs.h +6 -5
  565. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/service.upbdefs.c +1 -1
  566. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/service.upbdefs.h +6 -5
  567. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/skywalking.upbdefs.c +1 -1
  568. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/skywalking.upbdefs.h +6 -5
  569. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/trace.upbdefs.c +1 -1
  570. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/trace.upbdefs.h +6 -5
  571. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/xray.upbdefs.c +1 -1
  572. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/xray.upbdefs.h +6 -5
  573. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/zipkin.upbdefs.c +1 -1
  574. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/zipkin.upbdefs.h +6 -5
  575. data/src/core/ext/upbdefs-generated/envoy/data/accesslog/v3/accesslog.upbdefs.c +402 -0
  576. data/src/core/ext/upbdefs-generated/envoy/data/accesslog/v3/accesslog.upbdefs.h +111 -0
  577. data/src/core/ext/upbdefs-generated/envoy/extensions/clusters/aggregate/v3/cluster.upbdefs.c +1 -1
  578. data/src/core/ext/upbdefs-generated/envoy/extensions/clusters/aggregate/v3/cluster.upbdefs.h +6 -5
  579. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/common/fault/v3/fault.upbdefs.c +1 -1
  580. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/common/fault/v3/fault.upbdefs.h +6 -5
  581. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/fault/v3/fault.upbdefs.c +81 -75
  582. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/fault/v3/fault.upbdefs.h +6 -5
  583. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/rbac/v3/rbac.upbdefs.c +1 -1
  584. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/rbac/v3/rbac.upbdefs.h +6 -5
  585. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/router/v3/router.upbdefs.c +64 -48
  586. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/router/v3/router.upbdefs.h +11 -5
  587. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upbdefs.c +1 -1
  588. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upbdefs.h +6 -5
  589. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.c +495 -470
  590. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.h +11 -5
  591. data/src/core/ext/upbdefs-generated/envoy/extensions/http/stateful_session/cookie/v3/cookie.upbdefs.c +1 -1
  592. data/src/core/ext/upbdefs-generated/envoy/extensions/http/stateful_session/cookie/v3/cookie.upbdefs.h +6 -5
  593. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/cert.upbdefs.c +1 -1
  594. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/cert.upbdefs.h +6 -5
  595. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.c +138 -136
  596. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.h +6 -5
  597. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/secret.upbdefs.c +1 -1
  598. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/secret.upbdefs.h +6 -5
  599. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls.upbdefs.c +1 -1
  600. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls.upbdefs.h +6 -5
  601. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upbdefs.c +1 -1
  602. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upbdefs.h +6 -5
  603. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/ads.upbdefs.c +1 -1
  604. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/ads.upbdefs.h +6 -5
  605. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/discovery.upbdefs.c +1 -1
  606. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/discovery.upbdefs.h +6 -5
  607. data/src/core/ext/upbdefs-generated/envoy/service/load_stats/v3/lrs.upbdefs.c +1 -1
  608. data/src/core/ext/upbdefs-generated/envoy/service/load_stats/v3/lrs.upbdefs.h +6 -5
  609. data/src/core/ext/upbdefs-generated/envoy/service/status/v3/csds.upbdefs.c +12 -13
  610. data/src/core/ext/upbdefs-generated/envoy/service/status/v3/csds.upbdefs.h +6 -5
  611. data/src/core/ext/upbdefs-generated/envoy/type/http/v3/cookie.upbdefs.c +1 -1
  612. data/src/core/ext/upbdefs-generated/envoy/type/http/v3/cookie.upbdefs.h +6 -5
  613. data/src/core/ext/upbdefs-generated/envoy/type/http/v3/path_transformation.upbdefs.c +1 -1
  614. data/src/core/ext/upbdefs-generated/envoy/type/http/v3/path_transformation.upbdefs.h +6 -5
  615. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/filter_state.upbdefs.c +1 -1
  616. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/filter_state.upbdefs.h +6 -5
  617. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/http_inputs.upbdefs.c +1 -1
  618. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/http_inputs.upbdefs.h +6 -5
  619. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/metadata.upbdefs.c +1 -1
  620. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/metadata.upbdefs.h +6 -5
  621. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/node.upbdefs.c +1 -1
  622. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/node.upbdefs.h +6 -5
  623. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/number.upbdefs.c +1 -1
  624. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/number.upbdefs.h +6 -5
  625. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/path.upbdefs.c +1 -1
  626. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/path.upbdefs.h +6 -5
  627. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/regex.upbdefs.c +30 -30
  628. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/regex.upbdefs.h +6 -5
  629. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/status_code_input.upbdefs.c +1 -1
  630. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/status_code_input.upbdefs.h +6 -5
  631. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/string.upbdefs.c +1 -1
  632. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/string.upbdefs.h +6 -5
  633. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/struct.upbdefs.c +1 -1
  634. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/struct.upbdefs.h +6 -5
  635. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/value.upbdefs.c +1 -1
  636. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/value.upbdefs.h +6 -5
  637. data/src/core/ext/upbdefs-generated/envoy/type/metadata/v3/metadata.upbdefs.c +1 -1
  638. data/src/core/ext/upbdefs-generated/envoy/type/metadata/v3/metadata.upbdefs.h +6 -5
  639. data/src/core/ext/upbdefs-generated/envoy/type/tracing/v3/custom_tag.upbdefs.c +1 -1
  640. data/src/core/ext/upbdefs-generated/envoy/type/tracing/v3/custom_tag.upbdefs.h +6 -5
  641. data/src/core/ext/upbdefs-generated/envoy/type/v3/hash_policy.upbdefs.c +1 -1
  642. data/src/core/ext/upbdefs-generated/envoy/type/v3/hash_policy.upbdefs.h +6 -5
  643. data/src/core/ext/upbdefs-generated/envoy/type/v3/http.upbdefs.c +1 -1
  644. data/src/core/ext/upbdefs-generated/envoy/type/v3/http.upbdefs.h +6 -5
  645. data/src/core/ext/upbdefs-generated/envoy/type/v3/http_status.upbdefs.c +1 -1
  646. data/src/core/ext/upbdefs-generated/envoy/type/v3/http_status.upbdefs.h +6 -5
  647. data/src/core/ext/upbdefs-generated/envoy/type/v3/percent.upbdefs.c +1 -1
  648. data/src/core/ext/upbdefs-generated/envoy/type/v3/percent.upbdefs.h +6 -5
  649. data/src/core/ext/upbdefs-generated/envoy/type/v3/range.upbdefs.c +1 -1
  650. data/src/core/ext/upbdefs-generated/envoy/type/v3/range.upbdefs.h +6 -5
  651. data/src/core/ext/upbdefs-generated/envoy/type/v3/ratelimit_strategy.upbdefs.c +1 -1
  652. data/src/core/ext/upbdefs-generated/envoy/type/v3/ratelimit_strategy.upbdefs.h +6 -5
  653. data/src/core/ext/upbdefs-generated/envoy/type/v3/ratelimit_unit.upbdefs.c +1 -1
  654. data/src/core/ext/upbdefs-generated/envoy/type/v3/ratelimit_unit.upbdefs.h +6 -5
  655. data/src/core/ext/upbdefs-generated/envoy/type/v3/semantic_version.upbdefs.c +1 -1
  656. data/src/core/ext/upbdefs-generated/envoy/type/v3/semantic_version.upbdefs.h +6 -5
  657. data/src/core/ext/upbdefs-generated/envoy/type/v3/token_bucket.upbdefs.c +1 -1
  658. data/src/core/ext/upbdefs-generated/envoy/type/v3/token_bucket.upbdefs.h +6 -5
  659. data/src/core/ext/upbdefs-generated/google/api/annotations.upbdefs.c +1 -1
  660. data/src/core/ext/upbdefs-generated/google/api/annotations.upbdefs.h +6 -5
  661. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/checked.upbdefs.c +1 -1
  662. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/checked.upbdefs.h +6 -5
  663. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/syntax.upbdefs.c +1 -1
  664. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/syntax.upbdefs.h +6 -5
  665. data/src/core/ext/upbdefs-generated/google/api/http.upbdefs.c +1 -1
  666. data/src/core/ext/upbdefs-generated/google/api/http.upbdefs.h +6 -5
  667. data/src/core/ext/upbdefs-generated/google/api/httpbody.upbdefs.c +1 -1
  668. data/src/core/ext/upbdefs-generated/google/api/httpbody.upbdefs.h +6 -5
  669. data/src/core/ext/upbdefs-generated/google/protobuf/any.upbdefs.c +1 -1
  670. data/src/core/ext/upbdefs-generated/google/protobuf/any.upbdefs.h +6 -5
  671. data/src/core/ext/upbdefs-generated/google/protobuf/descriptor.upbdefs.c +329 -273
  672. data/src/core/ext/upbdefs-generated/google/protobuf/descriptor.upbdefs.h +11 -5
  673. data/src/core/ext/upbdefs-generated/google/protobuf/duration.upbdefs.c +1 -1
  674. data/src/core/ext/upbdefs-generated/google/protobuf/duration.upbdefs.h +6 -5
  675. data/src/core/ext/upbdefs-generated/google/protobuf/empty.upbdefs.c +1 -1
  676. data/src/core/ext/upbdefs-generated/google/protobuf/empty.upbdefs.h +6 -5
  677. data/src/core/ext/upbdefs-generated/google/protobuf/struct.upbdefs.c +1 -1
  678. data/src/core/ext/upbdefs-generated/google/protobuf/struct.upbdefs.h +6 -5
  679. data/src/core/ext/upbdefs-generated/google/protobuf/timestamp.upbdefs.c +1 -1
  680. data/src/core/ext/upbdefs-generated/google/protobuf/timestamp.upbdefs.h +6 -5
  681. data/src/core/ext/upbdefs-generated/google/protobuf/wrappers.upbdefs.c +1 -1
  682. data/src/core/ext/upbdefs-generated/google/protobuf/wrappers.upbdefs.h +6 -5
  683. data/src/core/ext/upbdefs-generated/google/rpc/status.upbdefs.c +1 -1
  684. data/src/core/ext/upbdefs-generated/google/rpc/status.upbdefs.h +6 -5
  685. data/src/core/ext/upbdefs-generated/opencensus/proto/trace/v1/trace_config.upbdefs.c +1 -1
  686. data/src/core/ext/upbdefs-generated/opencensus/proto/trace/v1/trace_config.upbdefs.h +6 -5
  687. data/src/core/ext/upbdefs-generated/src/proto/grpc/lookup/v1/rls_config.upbdefs.c +1 -1
  688. data/src/core/ext/upbdefs-generated/src/proto/grpc/lookup/v1/rls_config.upbdefs.h +6 -5
  689. data/src/core/ext/upbdefs-generated/udpa/annotations/migrate.upbdefs.c +1 -1
  690. data/src/core/ext/upbdefs-generated/udpa/annotations/migrate.upbdefs.h +6 -5
  691. data/src/core/ext/upbdefs-generated/udpa/annotations/security.upbdefs.c +1 -1
  692. data/src/core/ext/upbdefs-generated/udpa/annotations/security.upbdefs.h +6 -5
  693. data/src/core/ext/upbdefs-generated/udpa/annotations/sensitive.upbdefs.c +1 -1
  694. data/src/core/ext/upbdefs-generated/udpa/annotations/sensitive.upbdefs.h +6 -5
  695. data/src/core/ext/upbdefs-generated/udpa/annotations/status.upbdefs.c +1 -1
  696. data/src/core/ext/upbdefs-generated/udpa/annotations/status.upbdefs.h +6 -5
  697. data/src/core/ext/upbdefs-generated/udpa/annotations/versioning.upbdefs.c +1 -1
  698. data/src/core/ext/upbdefs-generated/udpa/annotations/versioning.upbdefs.h +6 -5
  699. data/src/core/ext/upbdefs-generated/validate/validate.upbdefs.c +1 -1
  700. data/src/core/ext/upbdefs-generated/validate/validate.upbdefs.h +6 -5
  701. data/src/core/ext/upbdefs-generated/xds/annotations/v3/migrate.upbdefs.c +1 -1
  702. data/src/core/ext/upbdefs-generated/xds/annotations/v3/migrate.upbdefs.h +6 -5
  703. data/src/core/ext/upbdefs-generated/xds/annotations/v3/security.upbdefs.c +1 -1
  704. data/src/core/ext/upbdefs-generated/xds/annotations/v3/security.upbdefs.h +6 -5
  705. data/src/core/ext/upbdefs-generated/xds/annotations/v3/sensitive.upbdefs.c +1 -1
  706. data/src/core/ext/upbdefs-generated/xds/annotations/v3/sensitive.upbdefs.h +6 -5
  707. data/src/core/ext/upbdefs-generated/xds/annotations/v3/status.upbdefs.c +1 -1
  708. data/src/core/ext/upbdefs-generated/xds/annotations/v3/status.upbdefs.h +6 -5
  709. data/src/core/ext/upbdefs-generated/xds/annotations/v3/versioning.upbdefs.c +1 -1
  710. data/src/core/ext/upbdefs-generated/xds/annotations/v3/versioning.upbdefs.h +6 -5
  711. data/src/core/ext/upbdefs-generated/xds/core/v3/authority.upbdefs.c +1 -1
  712. data/src/core/ext/upbdefs-generated/xds/core/v3/authority.upbdefs.h +6 -5
  713. data/src/core/ext/upbdefs-generated/xds/core/v3/cidr.upbdefs.c +1 -1
  714. data/src/core/ext/upbdefs-generated/xds/core/v3/cidr.upbdefs.h +6 -5
  715. data/src/core/ext/upbdefs-generated/xds/core/v3/collection_entry.upbdefs.c +1 -1
  716. data/src/core/ext/upbdefs-generated/xds/core/v3/collection_entry.upbdefs.h +6 -5
  717. data/src/core/ext/upbdefs-generated/xds/core/v3/context_params.upbdefs.c +1 -1
  718. data/src/core/ext/upbdefs-generated/xds/core/v3/context_params.upbdefs.h +6 -5
  719. data/src/core/ext/upbdefs-generated/xds/core/v3/extension.upbdefs.c +1 -1
  720. data/src/core/ext/upbdefs-generated/xds/core/v3/extension.upbdefs.h +6 -5
  721. data/src/core/ext/upbdefs-generated/xds/core/v3/resource.upbdefs.c +1 -1
  722. data/src/core/ext/upbdefs-generated/xds/core/v3/resource.upbdefs.h +6 -5
  723. data/src/core/ext/upbdefs-generated/xds/core/v3/resource_locator.upbdefs.c +1 -1
  724. data/src/core/ext/upbdefs-generated/xds/core/v3/resource_locator.upbdefs.h +6 -5
  725. data/src/core/ext/upbdefs-generated/xds/core/v3/resource_name.upbdefs.c +1 -1
  726. data/src/core/ext/upbdefs-generated/xds/core/v3/resource_name.upbdefs.h +6 -5
  727. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/cel.upbdefs.c +1 -1
  728. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/cel.upbdefs.h +6 -5
  729. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/domain.upbdefs.c +1 -1
  730. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/domain.upbdefs.h +6 -5
  731. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/http_inputs.upbdefs.c +1 -1
  732. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/http_inputs.upbdefs.h +6 -5
  733. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/ip.upbdefs.c +1 -1
  734. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/ip.upbdefs.h +6 -5
  735. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/matcher.upbdefs.c +1 -1
  736. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/matcher.upbdefs.h +6 -5
  737. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/range.upbdefs.c +1 -1
  738. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/range.upbdefs.h +6 -5
  739. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/regex.upbdefs.c +1 -1
  740. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/regex.upbdefs.h +6 -5
  741. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/string.upbdefs.c +1 -1
  742. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/string.upbdefs.h +6 -5
  743. data/src/core/ext/upbdefs-generated/xds/type/v3/cel.upbdefs.c +1 -1
  744. data/src/core/ext/upbdefs-generated/xds/type/v3/cel.upbdefs.h +6 -5
  745. data/src/core/ext/upbdefs-generated/xds/type/v3/range.upbdefs.c +1 -1
  746. data/src/core/ext/upbdefs-generated/xds/type/v3/range.upbdefs.h +6 -5
  747. data/src/core/ext/upbdefs-generated/xds/type/v3/typed_struct.upbdefs.c +1 -1
  748. data/src/core/ext/upbdefs-generated/xds/type/v3/typed_struct.upbdefs.h +6 -5
  749. data/src/core/ext/xds/certificate_provider_store.cc +8 -13
  750. data/src/core/ext/xds/certificate_provider_store.h +1 -1
  751. data/src/core/ext/xds/file_watcher_certificate_provider_factory.cc +30 -42
  752. data/src/core/ext/xds/file_watcher_certificate_provider_factory.h +14 -9
  753. data/src/core/ext/xds/upb_utils.h +1 -1
  754. data/src/core/ext/xds/xds_api.cc +41 -18
  755. data/src/core/ext/xds/xds_api.h +5 -4
  756. data/src/core/ext/xds/xds_audit_logger_registry.cc +122 -0
  757. data/src/core/ext/xds/xds_audit_logger_registry.h +68 -0
  758. data/src/core/ext/xds/xds_bootstrap.cc +3 -3
  759. data/src/core/ext/xds/xds_bootstrap_grpc.cc +65 -50
  760. data/src/core/ext/xds/xds_bootstrap_grpc.h +10 -13
  761. data/src/core/ext/xds/xds_client.cc +29 -7
  762. data/src/core/ext/xds/xds_client.h +1 -1
  763. data/src/core/ext/xds/xds_client_grpc.cc +12 -6
  764. data/src/core/ext/xds/xds_client_grpc.h +16 -2
  765. data/src/core/ext/xds/xds_client_stats.h +11 -1
  766. data/src/core/ext/xds/xds_cluster.cc +70 -67
  767. data/src/core/ext/xds/xds_cluster.h +1 -2
  768. data/src/core/ext/xds/xds_cluster_specifier_plugin.cc +15 -11
  769. data/src/core/ext/xds/xds_cluster_specifier_plugin.h +2 -2
  770. data/src/core/ext/xds/xds_common_types.cc +8 -5
  771. data/src/core/ext/xds/xds_endpoint.cc +9 -9
  772. data/src/core/ext/xds/xds_endpoint.h +1 -1
  773. data/src/core/ext/xds/xds_health_status.cc +0 -17
  774. data/src/core/ext/xds/xds_health_status.h +5 -25
  775. data/src/core/ext/xds/xds_http_fault_filter.cc +16 -14
  776. data/src/core/ext/xds/xds_http_fault_filter.h +1 -1
  777. data/src/core/ext/xds/xds_http_filters.h +3 -2
  778. data/src/core/ext/xds/xds_http_rbac_filter.cc +152 -72
  779. data/src/core/ext/xds/xds_http_rbac_filter.h +1 -1
  780. data/src/core/ext/xds/xds_http_stateful_session_filter.cc +15 -12
  781. data/src/core/ext/xds/xds_http_stateful_session_filter.h +1 -1
  782. data/src/core/ext/xds/xds_lb_policy_registry.cc +60 -36
  783. data/src/core/ext/xds/xds_listener.cc +11 -4
  784. data/src/core/ext/xds/xds_listener.h +1 -1
  785. data/src/core/ext/xds/xds_resource_type.h +2 -2
  786. data/src/core/ext/xds/xds_route_config.cc +52 -8
  787. data/src/core/ext/xds/xds_route_config.h +1 -1
  788. data/src/core/ext/xds/xds_transport_grpc.cc +2 -1
  789. data/src/core/lib/address_utils/parse_address.cc +63 -1
  790. data/src/core/lib/address_utils/parse_address.h +8 -0
  791. data/src/core/lib/address_utils/sockaddr_utils.cc +46 -1
  792. data/src/core/lib/address_utils/sockaddr_utils.h +2 -2
  793. data/src/core/lib/avl/avl.h +15 -173
  794. data/src/core/lib/backoff/random_early_detection.h +5 -0
  795. data/src/core/lib/channel/call_tracer.cc +289 -0
  796. data/src/core/lib/channel/call_tracer.h +35 -0
  797. data/src/core/lib/channel/channel_args.cc +120 -46
  798. data/src/core/lib/channel/channel_args.h +52 -4
  799. data/src/core/lib/channel/channel_trace.cc +16 -12
  800. data/src/core/lib/channel/channelz.cc +163 -135
  801. data/src/core/lib/channel/channelz.h +42 -35
  802. data/src/core/lib/channel/channelz_registry.cc +24 -20
  803. data/src/core/lib/channel/connected_channel.cc +103 -35
  804. data/src/core/lib/channel/promise_based_filter.cc +6 -13
  805. data/src/core/lib/channel/promise_based_filter.h +3 -0
  806. data/src/core/lib/compression/compression_internal.cc +8 -7
  807. data/src/core/lib/config/config_vars.cc +20 -18
  808. data/src/core/lib/config/config_vars.h +4 -4
  809. data/src/core/lib/config/load_config.cc +13 -0
  810. data/src/core/lib/config/load_config.h +6 -0
  811. data/src/core/lib/debug/event_log.h +1 -1
  812. data/src/core/lib/debug/stats_data.cc +93 -21
  813. data/src/core/lib/debug/stats_data.h +42 -1
  814. data/src/core/lib/debug/trace.cc +31 -56
  815. data/src/core/lib/debug/trace.h +14 -4
  816. data/src/core/lib/event_engine/ares_resolver.cc +712 -0
  817. data/src/core/lib/event_engine/ares_resolver.h +150 -0
  818. data/src/core/lib/event_engine/cf_engine/cf_engine.cc +218 -0
  819. data/src/core/lib/event_engine/cf_engine/cf_engine.h +86 -0
  820. data/src/core/lib/event_engine/cf_engine/cfstream_endpoint.cc +354 -0
  821. data/src/core/lib/event_engine/cf_engine/cfstream_endpoint.h +146 -0
  822. data/src/core/lib/event_engine/cf_engine/cftype_unique_ref.h +79 -0
  823. data/src/core/lib/event_engine/cf_engine/dns_service_resolver.cc +229 -0
  824. data/src/core/lib/event_engine/cf_engine/dns_service_resolver.h +117 -0
  825. data/src/core/lib/event_engine/default_event_engine.cc +13 -1
  826. data/src/core/lib/event_engine/default_event_engine_factory.cc +14 -2
  827. data/src/core/lib/event_engine/event_engine.cc +0 -12
  828. data/src/core/lib/event_engine/forkable.cc +62 -43
  829. data/src/core/lib/event_engine/forkable.h +15 -0
  830. data/src/core/lib/event_engine/grpc_polled_fd.h +73 -0
  831. data/src/core/lib/event_engine/handle_containers.h +0 -4
  832. data/src/core/lib/event_engine/poller.h +2 -2
  833. data/src/core/lib/event_engine/posix.h +4 -0
  834. data/src/core/lib/event_engine/posix_engine/ev_epoll1_linux.cc +5 -7
  835. data/src/core/lib/event_engine/posix_engine/ev_poll_posix.cc +29 -9
  836. data/src/core/lib/event_engine/posix_engine/ev_poll_posix.h +10 -1
  837. data/src/core/lib/event_engine/posix_engine/grpc_polled_fd_posix.h +197 -0
  838. data/src/core/lib/event_engine/posix_engine/lockfree_event.cc +7 -18
  839. data/src/core/lib/event_engine/posix_engine/posix_endpoint.cc +28 -14
  840. data/src/core/lib/event_engine/posix_engine/posix_endpoint.h +12 -1
  841. data/src/core/lib/event_engine/posix_engine/posix_engine.cc +90 -47
  842. data/src/core/lib/event_engine/posix_engine/posix_engine.h +21 -14
  843. data/src/core/lib/event_engine/posix_engine/posix_engine_listener.cc +41 -31
  844. data/src/core/lib/event_engine/posix_engine/posix_engine_listener.h +9 -8
  845. data/src/core/lib/event_engine/posix_engine/posix_engine_listener_utils.cc +4 -2
  846. data/src/core/lib/event_engine/posix_engine/tcp_socket_utils.cc +49 -3
  847. data/src/core/lib/event_engine/posix_engine/tcp_socket_utils.h +9 -0
  848. data/src/core/lib/event_engine/posix_engine/timer.h +10 -37
  849. data/src/core/lib/event_engine/posix_engine/timer_manager.h +1 -1
  850. data/src/core/lib/event_engine/posix_engine/traced_buffer_list.cc +2 -0
  851. data/src/core/lib/event_engine/shim.cc +9 -1
  852. data/src/core/lib/event_engine/tcp_socket_utils.cc +67 -7
  853. data/src/core/lib/event_engine/tcp_socket_utils.h +3 -0
  854. data/src/core/lib/event_engine/{thread_pool.cc → thread_pool/original_thread_pool.cc} +28 -25
  855. data/src/core/lib/event_engine/{thread_pool.h → thread_pool/original_thread_pool.h} +11 -15
  856. data/src/core/lib/event_engine/thread_pool/thread_count.cc +58 -0
  857. data/src/core/lib/event_engine/thread_pool/thread_count.h +161 -0
  858. data/src/core/lib/event_engine/{executor/executor.h → thread_pool/thread_pool.h} +21 -9
  859. data/src/core/lib/event_engine/thread_pool/thread_pool_factory.cc +47 -0
  860. data/src/core/lib/event_engine/thread_pool/work_stealing_thread_pool.cc +517 -0
  861. data/src/core/lib/event_engine/thread_pool/work_stealing_thread_pool.h +223 -0
  862. data/src/core/lib/event_engine/thready_event_engine/thready_event_engine.cc +157 -0
  863. data/src/core/lib/event_engine/thready_event_engine/thready_event_engine.h +104 -0
  864. data/src/core/lib/event_engine/trace.cc +1 -0
  865. data/src/core/lib/event_engine/trace.h +6 -0
  866. data/src/core/lib/event_engine/windows/iocp.cc +4 -3
  867. data/src/core/lib/event_engine/windows/iocp.h +3 -3
  868. data/src/core/lib/event_engine/windows/win_socket.cc +6 -6
  869. data/src/core/lib/event_engine/windows/win_socket.h +4 -4
  870. data/src/core/lib/event_engine/windows/windows_endpoint.cc +60 -59
  871. data/src/core/lib/event_engine/windows/windows_endpoint.h +17 -13
  872. data/src/core/lib/event_engine/windows/windows_engine.cc +21 -18
  873. data/src/core/lib/event_engine/windows/windows_engine.h +14 -18
  874. data/src/core/lib/event_engine/windows/windows_listener.cc +3 -3
  875. data/src/core/lib/event_engine/windows/windows_listener.h +3 -2
  876. data/src/core/lib/event_engine/work_queue/basic_work_queue.cc +63 -0
  877. data/src/core/lib/event_engine/work_queue/basic_work_queue.h +71 -0
  878. data/src/core/lib/event_engine/work_queue/work_queue.h +62 -0
  879. data/src/core/lib/experiments/config.cc +112 -29
  880. data/src/core/lib/experiments/config.h +33 -5
  881. data/src/core/lib/experiments/experiments.cc +226 -61
  882. data/src/core/lib/experiments/experiments.h +95 -29
  883. data/src/core/lib/gpr/log_internal.h +55 -0
  884. data/src/core/lib/gpr/posix/time.cc +5 -0
  885. data/src/core/lib/gprpp/crash.cc +10 -0
  886. data/src/core/lib/gprpp/crash.h +3 -0
  887. data/src/core/lib/gprpp/dual_ref_counted.h +9 -9
  888. data/src/core/lib/gprpp/fork.cc +8 -9
  889. data/src/core/lib/gprpp/fork.h +6 -5
  890. data/src/core/lib/gprpp/if_list.h +4530 -0
  891. data/src/core/lib/gprpp/orphanable.h +3 -3
  892. data/src/core/lib/gprpp/per_cpu.cc +33 -0
  893. data/src/core/lib/gprpp/per_cpu.h +29 -6
  894. data/src/core/lib/gprpp/ref_counted.h +9 -7
  895. data/src/core/lib/gprpp/ref_counted_string.cc +44 -0
  896. data/src/core/lib/gprpp/ref_counted_string.h +146 -0
  897. data/src/core/lib/gprpp/sorted_pack.h +3 -12
  898. data/src/core/lib/gprpp/status_helper.cc +2 -2
  899. data/src/core/lib/gprpp/status_helper.h +16 -15
  900. data/src/core/lib/gprpp/time.cc +1 -0
  901. data/src/core/lib/gprpp/time.h +13 -1
  902. data/src/core/lib/gprpp/type_list.h +32 -0
  903. data/src/core/lib/gprpp/validation_errors.cc +8 -3
  904. data/src/core/lib/gprpp/validation_errors.h +16 -9
  905. data/src/core/lib/gprpp/work_serializer.cc +36 -0
  906. data/src/core/lib/gprpp/work_serializer.h +5 -0
  907. data/src/core/lib/http/httpcli.h +6 -9
  908. data/src/core/lib/http/httpcli_security_connector.cc +1 -0
  909. data/src/core/lib/iomgr/buffer_list.cc +2 -0
  910. data/src/core/lib/iomgr/buffer_list.h +0 -1
  911. data/src/core/lib/iomgr/cfstream_handle.cc +1 -1
  912. data/src/core/lib/iomgr/endpoint_cfstream.cc +10 -8
  913. data/src/core/lib/iomgr/error.cc +32 -2
  914. data/src/core/lib/iomgr/error.h +9 -10
  915. data/src/core/lib/iomgr/ev_apple.cc +12 -12
  916. data/src/core/lib/iomgr/ev_epoll1_linux.cc +15 -10
  917. data/src/core/lib/iomgr/ev_poll_posix.cc +6 -5
  918. data/src/core/lib/iomgr/event_engine_shims/endpoint.cc +22 -23
  919. data/src/core/lib/iomgr/exec_ctx.h +11 -0
  920. data/src/core/lib/iomgr/iocp_windows.cc +24 -3
  921. data/src/core/lib/iomgr/iocp_windows.h +11 -0
  922. data/src/core/lib/iomgr/iomgr_posix_cfstream.cc +1 -1
  923. data/src/core/lib/iomgr/pollset.h +4 -5
  924. data/src/core/lib/iomgr/port.h +10 -0
  925. data/src/core/lib/iomgr/resolve_address.cc +13 -1
  926. data/src/core/lib/iomgr/resolve_address.h +17 -3
  927. data/src/core/lib/iomgr/sockaddr_posix.h +7 -0
  928. data/src/core/lib/iomgr/socket_utils_common_posix.cc +33 -2
  929. data/src/core/lib/iomgr/socket_utils_posix.cc +5 -0
  930. data/src/core/lib/iomgr/socket_utils_posix.h +9 -0
  931. data/src/core/lib/iomgr/socket_windows.cc +61 -7
  932. data/src/core/lib/iomgr/socket_windows.h +9 -2
  933. data/src/core/lib/iomgr/tcp_client_cfstream.cc +14 -3
  934. data/src/core/lib/iomgr/tcp_client_posix.cc +8 -1
  935. data/src/core/lib/iomgr/tcp_posix.cc +24 -7
  936. data/src/core/lib/iomgr/tcp_server_posix.cc +145 -106
  937. data/src/core/lib/iomgr/tcp_server_utils_posix.h +1 -1
  938. data/src/core/lib/iomgr/tcp_server_utils_posix_common.cc +5 -2
  939. data/src/core/lib/iomgr/tcp_server_windows.cc +1 -1
  940. data/src/core/lib/iomgr/tcp_windows.cc +1 -3
  941. data/src/core/lib/iomgr/timer_generic.cc +17 -16
  942. data/src/core/lib/iomgr/vsock.cc +59 -0
  943. data/src/core/lib/iomgr/vsock.h +38 -0
  944. data/src/core/lib/iomgr/wakeup_fd_posix.h +3 -6
  945. data/src/core/lib/json/json.h +2 -218
  946. data/src/core/lib/json/json_object_loader.cc +24 -25
  947. data/src/core/lib/json/json_object_loader.h +30 -18
  948. data/src/core/lib/json/json_reader.cc +69 -42
  949. data/src/core/lib/json/json_reader.h +34 -0
  950. data/src/core/lib/json/json_util.cc +10 -15
  951. data/src/core/lib/json/json_util.h +5 -4
  952. data/src/core/lib/json/json_writer.cc +24 -25
  953. data/src/core/lib/json/json_writer.h +33 -0
  954. data/src/core/lib/load_balancing/delegating_helper.h +115 -0
  955. data/src/core/lib/load_balancing/lb_policy.h +33 -0
  956. data/src/core/lib/load_balancing/lb_policy_registry.cc +9 -8
  957. data/src/core/lib/load_balancing/subchannel_interface.h +6 -0
  958. data/src/core/lib/matchers/matchers.cc +3 -4
  959. data/src/core/lib/matchers/matchers.h +2 -1
  960. data/src/core/lib/promise/activity.cc +5 -0
  961. data/src/core/lib/promise/activity.h +10 -0
  962. data/src/core/lib/promise/detail/basic_seq.h +1 -372
  963. data/src/core/lib/promise/detail/promise_factory.h +1 -1
  964. data/src/core/lib/promise/detail/seq_state.h +2076 -0
  965. data/src/core/lib/promise/party.cc +31 -13
  966. data/src/core/lib/promise/party.h +12 -3
  967. data/src/core/lib/promise/pipe.h +16 -2
  968. data/src/core/lib/promise/prioritized_race.h +95 -0
  969. data/src/core/lib/promise/seq.h +19 -2
  970. data/src/core/lib/promise/sleep.cc +2 -1
  971. data/src/core/lib/promise/sleep.h +5 -10
  972. data/src/core/lib/promise/try_seq.h +34 -2
  973. data/src/core/lib/resolver/resolver_factory.h +3 -2
  974. data/src/core/lib/resolver/server_address.cc +9 -102
  975. data/src/core/lib/resolver/server_address.h +10 -70
  976. data/src/core/lib/resource_quota/api.cc +1 -0
  977. data/src/core/lib/resource_quota/arena.cc +2 -0
  978. data/src/core/lib/resource_quota/arena.h +42 -8
  979. data/src/core/lib/resource_quota/memory_quota.cc +7 -8
  980. data/src/core/lib/resource_quota/memory_quota.h +2 -3
  981. data/src/core/lib/resource_quota/resource_quota.h +1 -0
  982. data/src/core/lib/security/authorization/audit_logging.cc +98 -0
  983. data/src/core/lib/security/authorization/audit_logging.h +73 -0
  984. data/src/core/lib/security/authorization/authorization_policy_provider.h +1 -1
  985. data/src/core/lib/security/authorization/grpc_authorization_engine.cc +47 -2
  986. data/src/core/lib/security/authorization/grpc_authorization_engine.h +18 -1
  987. data/src/core/lib/security/authorization/rbac_policy.cc +36 -4
  988. data/src/core/lib/security/authorization/rbac_policy.h +19 -2
  989. data/src/core/lib/security/authorization/stdout_logger.cc +75 -0
  990. data/src/core/lib/security/authorization/stdout_logger.h +61 -0
  991. data/src/core/lib/security/certificate_provider/certificate_provider_factory.h +8 -4
  992. data/src/core/lib/security/certificate_provider/certificate_provider_registry.cc +8 -18
  993. data/src/core/lib/security/certificate_provider/certificate_provider_registry.h +14 -8
  994. data/src/core/lib/security/credentials/channel_creds_registry.h +51 -27
  995. data/src/core/lib/security/credentials/channel_creds_registry_init.cc +169 -9
  996. data/src/core/lib/security/credentials/composite/composite_credentials.cc +1 -1
  997. data/src/core/lib/security/credentials/composite/composite_credentials.h +3 -1
  998. data/src/core/lib/security/credentials/external/aws_external_account_credentials.cc +54 -49
  999. data/src/core/lib/security/credentials/external/aws_request_signer.cc +8 -0
  1000. data/src/core/lib/security/credentials/external/external_account_credentials.cc +104 -65
  1001. data/src/core/lib/security/credentials/external/external_account_credentials.h +6 -0
  1002. data/src/core/lib/security/credentials/external/file_external_account_credentials.cc +23 -21
  1003. data/src/core/lib/security/credentials/external/url_external_account_credentials.cc +29 -27
  1004. data/src/core/lib/security/credentials/fake/fake_credentials.cc +30 -38
  1005. data/src/core/lib/security/credentials/fake/fake_credentials.h +28 -0
  1006. data/src/core/lib/security/credentials/google_default/google_default_credentials.cc +6 -2
  1007. data/src/core/lib/security/credentials/jwt/json_token.cc +36 -16
  1008. data/src/core/lib/security/credentials/jwt/json_token.h +4 -0
  1009. data/src/core/lib/security/credentials/jwt/jwt_credentials.cc +10 -5
  1010. data/src/core/lib/security/credentials/jwt/jwt_verifier.cc +82 -38
  1011. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.cc +18 -16
  1012. data/src/core/lib/security/credentials/ssl/ssl_credentials.cc +1 -0
  1013. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.cc +4 -0
  1014. data/src/core/lib/security/credentials/tls/grpc_tls_credentials_options.cc +8 -0
  1015. data/src/core/lib/security/credentials/tls/grpc_tls_credentials_options.h +5 -1
  1016. data/src/core/lib/security/credentials/tls/tls_credentials.cc +2 -1
  1017. data/src/core/lib/security/credentials/tls/tls_credentials.h +3 -1
  1018. data/src/core/lib/security/credentials/xds/xds_credentials.cc +1 -0
  1019. data/src/core/lib/security/security_connector/alts/alts_security_connector.cc +2 -5
  1020. data/src/core/lib/security/security_connector/fake/fake_security_connector.cc +1 -0
  1021. data/src/core/lib/security/security_connector/ssl_utils.cc +3 -1
  1022. data/src/core/lib/security/security_connector/ssl_utils.h +1 -1
  1023. data/src/core/lib/security/security_connector/tls/tls_security_connector.cc +1 -1
  1024. data/src/core/lib/security/transport/client_auth_filter.cc +8 -5
  1025. data/src/core/lib/security/transport/security_handshaker.cc +1 -0
  1026. data/src/core/lib/security/transport/server_auth_filter.cc +2 -0
  1027. data/src/core/lib/security/util/json_util.cc +6 -5
  1028. data/src/core/lib/service_config/service_config_call_data.h +54 -20
  1029. data/src/core/lib/service_config/service_config_impl.cc +13 -6
  1030. data/src/core/lib/slice/slice.h +18 -0
  1031. data/src/core/lib/surface/call.cc +159 -73
  1032. data/src/core/lib/surface/call.h +1 -5
  1033. data/src/core/lib/surface/channel.cc +1 -0
  1034. data/src/core/lib/surface/completion_queue.cc +18 -3
  1035. data/src/core/lib/surface/init.cc +1 -0
  1036. data/src/core/lib/surface/server.cc +106 -75
  1037. data/src/core/lib/surface/server.h +1 -15
  1038. data/src/core/lib/surface/validate_metadata.cc +37 -22
  1039. data/src/core/lib/surface/validate_metadata.h +13 -3
  1040. data/src/core/lib/surface/version.cc +2 -2
  1041. data/src/core/lib/transport/batch_builder.cc +15 -12
  1042. data/src/core/lib/transport/batch_builder.h +48 -36
  1043. data/src/core/lib/transport/metadata_batch.cc +7 -7
  1044. data/src/core/lib/transport/metadata_batch.h +88 -107
  1045. data/src/core/lib/transport/metadata_compression_traits.h +67 -0
  1046. data/src/core/lib/transport/parsed_metadata.h +34 -20
  1047. data/src/core/lib/transport/simple_slice_based_metadata.h +55 -0
  1048. data/src/core/lib/transport/transport.h +3 -0
  1049. data/src/core/plugin_registry/grpc_plugin_registry.cc +2 -6
  1050. data/src/core/plugin_registry/grpc_plugin_registry_extra.cc +2 -0
  1051. data/src/core/tsi/alts/crypt/aes_gcm.cc +27 -2
  1052. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_record_protocol_common.cc +4 -6
  1053. data/src/core/tsi/alts/zero_copy_frame_protector/alts_zero_copy_grpc_protector.cc +1 -2
  1054. data/src/core/tsi/ssl_transport_security.cc +44 -9
  1055. data/src/core/tsi/ssl_transport_security.h +13 -1
  1056. data/src/ruby/bin/math_pb.rb +24 -18
  1057. data/src/ruby/ext/grpc/extconf.rb +27 -27
  1058. data/src/ruby/ext/grpc/rb_call.c +62 -39
  1059. data/src/ruby/ext/grpc/rb_call_credentials.c +0 -1
  1060. data/src/ruby/ext/grpc/rb_channel.c +109 -84
  1061. data/src/ruby/ext/grpc/rb_channel.h +1 -0
  1062. data/src/ruby/ext/grpc/rb_channel_args.c +16 -2
  1063. data/src/ruby/ext/grpc/rb_channel_args.h +4 -0
  1064. data/src/ruby/ext/grpc/rb_channel_credentials.c +0 -1
  1065. data/src/ruby/ext/grpc/rb_compression_options.c +0 -1
  1066. data/src/ruby/ext/grpc/rb_event_thread.c +22 -6
  1067. data/src/ruby/ext/grpc/rb_event_thread.h +1 -0
  1068. data/src/ruby/ext/grpc/rb_grpc.c +192 -30
  1069. data/src/ruby/ext/grpc/rb_grpc.h +8 -2
  1070. data/src/ruby/ext/grpc/rb_grpc_imports.generated.c +2 -0
  1071. data/src/ruby/ext/grpc/rb_grpc_imports.generated.h +3 -0
  1072. data/src/ruby/ext/grpc/rb_server.c +62 -45
  1073. data/src/ruby/ext/grpc/rb_server_credentials.c +0 -1
  1074. data/src/ruby/ext/grpc/rb_xds_channel_credentials.c +0 -1
  1075. data/src/ruby/ext/grpc/rb_xds_server_credentials.c +0 -1
  1076. data/src/ruby/lib/grpc/generic/active_call.rb +9 -14
  1077. data/src/ruby/lib/grpc/generic/bidi_call.rb +2 -0
  1078. data/src/ruby/lib/grpc/version.rb +1 -1
  1079. data/src/ruby/pb/grpc/health/v1/health_pb.rb +24 -13
  1080. data/src/ruby/pb/src/proto/grpc/testing/empty_pb.rb +24 -3
  1081. data/src/ruby/pb/src/proto/grpc/testing/messages_pb.rb +25 -111
  1082. data/src/ruby/pb/src/proto/grpc/testing/test_pb.rb +25 -2
  1083. data/src/ruby/pb/test/client.rb +16 -0
  1084. data/src/ruby/spec/generic/rpc_server_spec.rb +3 -3
  1085. data/third_party/abseil-cpp/absl/algorithm/container.h +3 -2
  1086. data/third_party/abseil-cpp/absl/base/attributes.h +58 -5
  1087. data/third_party/abseil-cpp/absl/base/call_once.h +1 -1
  1088. data/third_party/abseil-cpp/absl/base/casts.h +8 -8
  1089. data/third_party/abseil-cpp/absl/base/config.h +89 -106
  1090. data/third_party/abseil-cpp/absl/base/dynamic_annotations.h +26 -1
  1091. data/third_party/abseil-cpp/absl/base/internal/direct_mmap.h +2 -2
  1092. data/third_party/abseil-cpp/absl/base/internal/low_level_alloc.cc +50 -39
  1093. data/third_party/abseil-cpp/absl/base/internal/low_level_alloc.h +2 -1
  1094. data/third_party/abseil-cpp/absl/base/internal/prefetch.h +17 -18
  1095. data/third_party/abseil-cpp/absl/base/internal/raw_logging.cc +32 -3
  1096. data/third_party/abseil-cpp/absl/base/internal/raw_logging.h +24 -4
  1097. data/third_party/abseil-cpp/absl/base/internal/sysinfo.cc +31 -73
  1098. data/third_party/abseil-cpp/absl/base/internal/thread_identity.cc +9 -8
  1099. data/third_party/abseil-cpp/absl/base/internal/thread_identity.h +11 -11
  1100. data/third_party/abseil-cpp/absl/base/internal/throw_delegate.cc +23 -32
  1101. data/third_party/abseil-cpp/absl/base/internal/unscaledcycleclock.cc +2 -3
  1102. data/third_party/abseil-cpp/absl/base/options.h +1 -1
  1103. data/third_party/abseil-cpp/absl/base/policy_checks.h +3 -3
  1104. data/third_party/abseil-cpp/absl/base/prefetch.h +198 -0
  1105. data/third_party/abseil-cpp/absl/container/fixed_array.h +54 -29
  1106. data/third_party/abseil-cpp/absl/container/flat_hash_map.h +5 -1
  1107. data/third_party/abseil-cpp/absl/container/flat_hash_set.h +6 -2
  1108. data/third_party/abseil-cpp/absl/container/inlined_vector.h +167 -79
  1109. data/third_party/abseil-cpp/absl/container/internal/common_policy_traits.h +1 -1
  1110. data/third_party/abseil-cpp/absl/container/internal/compressed_tuple.h +3 -21
  1111. data/third_party/abseil-cpp/absl/container/internal/container_memory.h +1 -1
  1112. data/third_party/abseil-cpp/absl/container/internal/hash_function_defaults.h +46 -0
  1113. data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler.cc +2 -0
  1114. data/third_party/abseil-cpp/absl/container/internal/inlined_vector.h +85 -26
  1115. data/third_party/abseil-cpp/absl/container/internal/raw_hash_map.h +35 -18
  1116. data/third_party/abseil-cpp/absl/container/internal/raw_hash_set.cc +70 -29
  1117. data/third_party/abseil-cpp/absl/container/internal/raw_hash_set.h +437 -236
  1118. data/third_party/abseil-cpp/absl/crc/crc32c.h +8 -1
  1119. data/third_party/abseil-cpp/absl/crc/internal/cpu_detect.cc +14 -8
  1120. data/third_party/abseil-cpp/absl/crc/internal/crc.cc +4 -35
  1121. data/third_party/abseil-cpp/absl/crc/internal/crc.h +2 -10
  1122. data/third_party/abseil-cpp/absl/crc/internal/crc32_x86_arm_combined_simd.h +1 -1
  1123. data/third_party/abseil-cpp/absl/crc/internal/crc_cord_state.cc +1 -1
  1124. data/third_party/abseil-cpp/absl/crc/internal/crc_cord_state.h +4 -4
  1125. data/third_party/abseil-cpp/absl/crc/internal/crc_internal.h +8 -10
  1126. data/third_party/abseil-cpp/absl/crc/internal/crc_memcpy_x86_64.cc +17 -19
  1127. data/third_party/abseil-cpp/absl/crc/internal/crc_x86_arm_combined.cc +8 -8
  1128. data/third_party/abseil-cpp/absl/debugging/internal/elf_mem_image.h +2 -1
  1129. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_aarch64-inl.inc +59 -23
  1130. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_powerpc-inl.inc +1 -1
  1131. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_x86-inl.inc +1 -1
  1132. data/third_party/abseil-cpp/absl/debugging/internal/symbolize.h +1 -1
  1133. data/third_party/abseil-cpp/absl/debugging/symbolize_elf.inc +43 -19
  1134. data/third_party/abseil-cpp/absl/debugging/symbolize_emscripten.inc +3 -0
  1135. data/third_party/abseil-cpp/absl/flags/commandlineflag.h +1 -1
  1136. data/third_party/abseil-cpp/absl/flags/internal/commandlineflag.cc +1 -1
  1137. data/third_party/abseil-cpp/absl/flags/internal/flag.cc +2 -2
  1138. data/third_party/abseil-cpp/absl/flags/internal/flag.h +16 -15
  1139. data/third_party/abseil-cpp/absl/flags/internal/flag_msvc.inc +1 -1
  1140. data/third_party/abseil-cpp/absl/flags/marshalling.cc +43 -2
  1141. data/third_party/abseil-cpp/absl/flags/marshalling.h +5 -0
  1142. data/third_party/abseil-cpp/absl/functional/any_invocable.h +9 -1
  1143. data/third_party/abseil-cpp/absl/functional/bind_front.h +1 -1
  1144. data/third_party/abseil-cpp/absl/functional/function_ref.h +3 -3
  1145. data/third_party/abseil-cpp/absl/functional/internal/any_invocable.h +37 -24
  1146. data/third_party/abseil-cpp/absl/functional/internal/function_ref.h +19 -9
  1147. data/third_party/abseil-cpp/absl/hash/hash.h +7 -4
  1148. data/third_party/abseil-cpp/absl/hash/internal/hash.h +38 -15
  1149. data/third_party/abseil-cpp/absl/hash/internal/low_level_hash.cc +6 -0
  1150. data/third_party/abseil-cpp/absl/meta/type_traits.h +48 -373
  1151. data/third_party/abseil-cpp/absl/numeric/bits.h +4 -4
  1152. data/third_party/abseil-cpp/absl/numeric/int128.cc +20 -8
  1153. data/third_party/abseil-cpp/absl/numeric/int128.h +36 -39
  1154. data/third_party/abseil-cpp/absl/numeric/int128_have_intrinsic.inc +0 -3
  1155. data/third_party/abseil-cpp/absl/numeric/int128_no_intrinsic.inc +47 -30
  1156. data/third_party/abseil-cpp/absl/random/internal/fast_uniform_bits.h +4 -3
  1157. data/third_party/abseil-cpp/absl/random/internal/generate_real.h +1 -1
  1158. data/third_party/abseil-cpp/absl/random/internal/platform.h +1 -1
  1159. data/third_party/abseil-cpp/absl/random/internal/randen_detect.cc +4 -0
  1160. data/third_party/abseil-cpp/absl/random/internal/randen_engine.h +1 -1
  1161. data/third_party/abseil-cpp/absl/random/internal/randen_hwaes.cc +1 -1
  1162. data/third_party/abseil-cpp/absl/random/internal/uniform_helper.h +1 -1
  1163. data/third_party/abseil-cpp/absl/status/internal/status_internal.h +4 -0
  1164. data/third_party/abseil-cpp/absl/status/internal/statusor_internal.h +12 -24
  1165. data/third_party/abseil-cpp/absl/status/status.cc +11 -7
  1166. data/third_party/abseil-cpp/absl/status/status.h +11 -2
  1167. data/third_party/abseil-cpp/absl/status/statusor.h +22 -8
  1168. data/third_party/abseil-cpp/absl/strings/ascii.cc +54 -6
  1169. data/third_party/abseil-cpp/absl/strings/charconv.cc +21 -4
  1170. data/third_party/abseil-cpp/absl/strings/charconv.h +2 -2
  1171. data/third_party/abseil-cpp/absl/strings/cord.cc +1 -2
  1172. data/third_party/abseil-cpp/absl/strings/cord.h +32 -5
  1173. data/third_party/abseil-cpp/absl/strings/cord_analysis.cc +23 -1
  1174. data/third_party/abseil-cpp/absl/strings/cord_analysis.h +18 -0
  1175. data/third_party/abseil-cpp/absl/strings/cord_buffer.h +2 -5
  1176. data/third_party/abseil-cpp/absl/strings/escaping.cc +10 -32
  1177. data/third_party/abseil-cpp/absl/strings/escaping.h +1 -1
  1178. data/third_party/abseil-cpp/absl/strings/internal/charconv_bigint.cc +2 -4
  1179. data/third_party/abseil-cpp/absl/strings/internal/charconv_bigint.h +3 -3
  1180. data/third_party/abseil-cpp/absl/strings/internal/cord_internal.cc +0 -1
  1181. data/third_party/abseil-cpp/absl/strings/internal/cord_internal.h +15 -13
  1182. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree.cc +13 -4
  1183. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree.h +8 -0
  1184. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_consume.cc +5 -3
  1185. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_consume.h +4 -7
  1186. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_flat.h +8 -0
  1187. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_ring.h +2 -2
  1188. data/third_party/abseil-cpp/absl/strings/internal/cordz_handle.cc +46 -20
  1189. data/third_party/abseil-cpp/absl/strings/internal/cordz_handle.h +1 -34
  1190. data/third_party/abseil-cpp/absl/strings/internal/cordz_info.cc +2 -1
  1191. data/third_party/abseil-cpp/absl/strings/internal/escaping.cc +23 -0
  1192. data/third_party/abseil-cpp/absl/strings/internal/escaping.h +1 -0
  1193. data/third_party/abseil-cpp/absl/strings/internal/memutil.cc +2 -77
  1194. data/third_party/abseil-cpp/absl/strings/internal/memutil.h +4 -112
  1195. data/third_party/abseil-cpp/absl/strings/internal/stl_type_traits.h +1 -1
  1196. data/third_party/abseil-cpp/absl/strings/internal/str_format/arg.cc +10 -31
  1197. data/third_party/abseil-cpp/absl/strings/internal/str_format/arg.h +8 -8
  1198. data/third_party/abseil-cpp/absl/strings/internal/str_format/bind.h +5 -20
  1199. data/third_party/abseil-cpp/absl/strings/internal/str_format/constexpr_parser.h +1 -0
  1200. data/third_party/abseil-cpp/absl/strings/internal/str_format/extension.h +1 -1
  1201. data/third_party/abseil-cpp/absl/strings/internal/str_format/float_conversion.cc +9 -9
  1202. data/third_party/abseil-cpp/absl/strings/internal/str_split_internal.h +56 -6
  1203. data/third_party/abseil-cpp/absl/strings/match.cc +87 -0
  1204. data/third_party/abseil-cpp/absl/strings/match.h +19 -0
  1205. data/third_party/abseil-cpp/absl/strings/numbers.cc +154 -122
  1206. data/third_party/abseil-cpp/absl/strings/numbers.h +1 -6
  1207. data/third_party/abseil-cpp/absl/strings/str_cat.cc +7 -50
  1208. data/third_party/abseil-cpp/absl/strings/str_cat.h +83 -15
  1209. data/third_party/abseil-cpp/absl/strings/str_format.h +6 -3
  1210. data/third_party/abseil-cpp/absl/strings/str_split.cc +9 -6
  1211. data/third_party/abseil-cpp/absl/strings/string_view.cc +26 -4
  1212. data/third_party/abseil-cpp/absl/synchronization/internal/create_thread_identity.cc +5 -0
  1213. data/third_party/abseil-cpp/absl/synchronization/internal/futex.h +63 -43
  1214. data/third_party/abseil-cpp/absl/synchronization/internal/futex_waiter.cc +111 -0
  1215. data/third_party/abseil-cpp/absl/synchronization/internal/futex_waiter.h +63 -0
  1216. data/third_party/abseil-cpp/absl/synchronization/internal/graphcycles.cc +11 -7
  1217. data/third_party/abseil-cpp/absl/synchronization/internal/kernel_timeout.cc +225 -0
  1218. data/third_party/abseil-cpp/absl/synchronization/internal/kernel_timeout.h +122 -114
  1219. data/third_party/abseil-cpp/absl/synchronization/internal/per_thread_sem.cc +12 -8
  1220. data/third_party/abseil-cpp/absl/synchronization/internal/per_thread_sem.h +10 -1
  1221. data/third_party/abseil-cpp/absl/synchronization/internal/pthread_waiter.cc +167 -0
  1222. data/third_party/abseil-cpp/absl/synchronization/internal/pthread_waiter.h +60 -0
  1223. data/third_party/abseil-cpp/absl/synchronization/internal/sem_waiter.cc +122 -0
  1224. data/third_party/abseil-cpp/absl/synchronization/internal/sem_waiter.h +65 -0
  1225. data/third_party/abseil-cpp/absl/synchronization/internal/stdcpp_waiter.cc +91 -0
  1226. data/third_party/abseil-cpp/absl/synchronization/internal/stdcpp_waiter.h +56 -0
  1227. data/third_party/abseil-cpp/absl/synchronization/internal/waiter.h +19 -113
  1228. data/third_party/abseil-cpp/absl/synchronization/internal/waiter_base.cc +42 -0
  1229. data/third_party/abseil-cpp/absl/synchronization/internal/waiter_base.h +90 -0
  1230. data/third_party/abseil-cpp/absl/synchronization/internal/win32_waiter.cc +151 -0
  1231. data/third_party/abseil-cpp/absl/synchronization/internal/win32_waiter.h +70 -0
  1232. data/third_party/abseil-cpp/absl/synchronization/mutex.cc +407 -411
  1233. data/third_party/abseil-cpp/absl/synchronization/mutex.h +152 -118
  1234. data/third_party/abseil-cpp/absl/time/clock.cc +6 -7
  1235. data/third_party/abseil-cpp/absl/time/duration.cc +24 -26
  1236. data/third_party/abseil-cpp/absl/time/internal/cctz/include/cctz/time_zone.h +1 -0
  1237. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_fixed.cc +1 -1
  1238. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_format.cc +3 -3
  1239. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_if.cc +8 -6
  1240. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_if.h +6 -3
  1241. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_impl.cc +4 -2
  1242. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_impl.h +4 -0
  1243. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_info.cc +322 -295
  1244. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_info.h +8 -17
  1245. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_libc.cc +51 -33
  1246. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_libc.h +7 -2
  1247. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_lookup.cc +128 -2
  1248. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_posix.h +1 -1
  1249. data/third_party/abseil-cpp/absl/time/internal/cctz/src/tzfile.h +5 -1
  1250. data/third_party/abseil-cpp/absl/time/internal/cctz/src/zone_info_source.cc +34 -34
  1251. data/third_party/abseil-cpp/absl/time/time.cc +9 -2
  1252. data/third_party/abseil-cpp/absl/time/time.h +115 -15
  1253. data/third_party/abseil-cpp/absl/types/internal/optional.h +0 -52
  1254. data/third_party/abseil-cpp/absl/types/internal/span.h +2 -2
  1255. data/third_party/abseil-cpp/absl/types/internal/variant.h +2 -2
  1256. data/third_party/abseil-cpp/absl/types/optional.h +15 -13
  1257. data/third_party/abseil-cpp/absl/types/span.h +1 -2
  1258. data/third_party/boringssl-with-bazel/err_data.c +554 -553
  1259. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_gentm.c +7 -3
  1260. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_mbstr.c +9 -8
  1261. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_strex.c +7 -7
  1262. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_strnid.c +6 -6
  1263. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_time.c +34 -1
  1264. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_utctm.c +11 -4
  1265. data/third_party/boringssl-with-bazel/src/crypto/asn1/internal.h +3 -3
  1266. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_dec.c +10 -6
  1267. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_enc.c +7 -4
  1268. data/third_party/boringssl-with-bazel/src/crypto/bio/bio.c +9 -7
  1269. data/third_party/boringssl-with-bazel/src/crypto/bio/bio_mem.c +40 -55
  1270. data/third_party/boringssl-with-bazel/src/crypto/bio/connect.c +7 -7
  1271. data/third_party/boringssl-with-bazel/src/crypto/bio/errno.c +92 -0
  1272. data/third_party/boringssl-with-bazel/src/crypto/bio/fd.c +14 -54
  1273. data/third_party/boringssl-with-bazel/src/crypto/bio/file.c +23 -22
  1274. data/third_party/boringssl-with-bazel/src/crypto/bio/internal.h +16 -6
  1275. data/third_party/boringssl-with-bazel/src/crypto/bio/pair.c +4 -2
  1276. data/third_party/boringssl-with-bazel/src/crypto/bio/socket.c +4 -4
  1277. data/third_party/boringssl-with-bazel/src/crypto/bio/socket_helper.c +11 -2
  1278. data/third_party/boringssl-with-bazel/src/crypto/blake2/blake2.c +31 -22
  1279. data/third_party/boringssl-with-bazel/src/crypto/bytestring/cbs.c +1 -1
  1280. data/third_party/boringssl-with-bazel/src/crypto/chacha/chacha.c +19 -1
  1281. data/third_party/boringssl-with-bazel/src/crypto/chacha/internal.h +8 -1
  1282. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_tls.c +29 -26
  1283. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/internal.h +8 -0
  1284. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/tls_cbc.c +189 -13
  1285. data/third_party/boringssl-with-bazel/src/crypto/conf/conf.c +31 -192
  1286. data/third_party/boringssl-with-bazel/src/crypto/conf/conf_def.h +3 -7
  1287. data/third_party/boringssl-with-bazel/src/crypto/conf/internal.h +8 -0
  1288. data/third_party/boringssl-with-bazel/src/crypto/cpu_aarch64_apple.c +3 -2
  1289. data/third_party/boringssl-with-bazel/src/crypto/cpu_aarch64_fuchsia.c +0 -1
  1290. data/third_party/boringssl-with-bazel/src/crypto/cpu_aarch64_linux.c +0 -2
  1291. data/third_party/boringssl-with-bazel/src/crypto/{cpu_aarch64_freebsd.c → cpu_aarch64_openbsd.c} +23 -24
  1292. data/third_party/boringssl-with-bazel/src/crypto/cpu_aarch64_sysreg.c +93 -0
  1293. data/third_party/boringssl-with-bazel/src/crypto/cpu_aarch64_win.c +1 -1
  1294. data/third_party/boringssl-with-bazel/src/crypto/cpu_arm_freebsd.c +0 -1
  1295. data/third_party/boringssl-with-bazel/src/crypto/cpu_arm_linux.c +0 -2
  1296. data/third_party/boringssl-with-bazel/src/crypto/curve25519/curve25519.c +55 -50
  1297. data/third_party/boringssl-with-bazel/src/crypto/{cpu_arm.c → curve25519/curve25519_64_adx.c} +4 -24
  1298. data/third_party/boringssl-with-bazel/src/crypto/curve25519/curve25519_tables.h +2834 -7442
  1299. data/third_party/boringssl-with-bazel/src/crypto/curve25519/internal.h +26 -8
  1300. data/third_party/boringssl-with-bazel/src/crypto/dh_extra/dh_asn1.c +4 -0
  1301. data/third_party/boringssl-with-bazel/src/crypto/dh_extra/params.c +5 -0
  1302. data/third_party/boringssl-with-bazel/src/crypto/dsa/dsa.c +4 -0
  1303. data/third_party/boringssl-with-bazel/src/crypto/dsa/internal.h +20 -0
  1304. data/third_party/boringssl-with-bazel/src/crypto/ec_extra/ec_asn1.c +110 -72
  1305. data/third_party/boringssl-with-bazel/src/crypto/ec_extra/ec_derive.c +4 -3
  1306. data/third_party/boringssl-with-bazel/src/crypto/ec_extra/hash_to_curve.c +42 -34
  1307. data/third_party/boringssl-with-bazel/src/crypto/ec_extra/internal.h +17 -11
  1308. data/third_party/boringssl-with-bazel/src/crypto/ecdh_extra/ecdh_extra.c +1 -1
  1309. data/third_party/boringssl-with-bazel/src/crypto/err/err.c +23 -21
  1310. data/third_party/boringssl-with-bazel/src/crypto/evp/evp.c +35 -12
  1311. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ec.c +2 -4
  1312. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ec_asn1.c +3 -7
  1313. data/third_party/boringssl-with-bazel/src/crypto/evp/p_rsa.c +1 -1
  1314. data/third_party/boringssl-with-bazel/src/crypto/evp/pbkdf.c +3 -3
  1315. data/third_party/boringssl-with-bazel/src/crypto/evp/print.c +7 -6
  1316. data/third_party/boringssl-with-bazel/src/crypto/ex_data.c +34 -72
  1317. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bcm.c +2 -1
  1318. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/div.c +12 -5
  1319. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/gcd.c +5 -6
  1320. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/internal.h +12 -6
  1321. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/montgomery.c +17 -18
  1322. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/montgomery_inv.c +51 -15
  1323. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/rsaz_exp.c +7 -7
  1324. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/delocate.h +5 -6
  1325. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/dh/check.c +37 -8
  1326. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/dh/dh.c +41 -19
  1327. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/dh/internal.h +9 -0
  1328. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/builtin_curves.h +277 -0
  1329. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/ec.c +204 -428
  1330. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/ec_key.c +4 -4
  1331. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/ec_montgomery.c +31 -64
  1332. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/felem.c +17 -13
  1333. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/internal.h +105 -143
  1334. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/oct.c +19 -19
  1335. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p224-64.c +16 -18
  1336. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p256-nistz.c +27 -30
  1337. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p256.c +23 -26
  1338. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p256_table.h +1 -1
  1339. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/scalar.c +24 -24
  1340. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/simple.c +21 -37
  1341. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/simple_mul.c +31 -31
  1342. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/wnaf.c +16 -16
  1343. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ecdh/ecdh.c +1 -1
  1344. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ecdsa/ecdsa.c +11 -5
  1345. data/third_party/boringssl-with-bazel/src/crypto/{hkdf → fipsmodule/hkdf}/hkdf.c +2 -2
  1346. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/cbc.c +2 -10
  1347. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/ctr.c +1 -4
  1348. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/gcm.c +115 -133
  1349. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/gcm_nohw.c +12 -14
  1350. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/internal.h +57 -47
  1351. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/ofb.c +1 -8
  1352. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/polyval.c +27 -28
  1353. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/fork_detect.c +40 -26
  1354. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/internal.h +21 -7
  1355. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/rand.c +38 -19
  1356. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/urandom.c +2 -41
  1357. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/internal.h +76 -16
  1358. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/padding.c +5 -288
  1359. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/rsa.c +143 -83
  1360. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/rsa_impl.c +126 -233
  1361. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/self_check/self_check.c +113 -24
  1362. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/service_indicator/service_indicator.c +4 -7
  1363. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/tls/internal.h +8 -0
  1364. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/tls/kdf.c +33 -0
  1365. data/third_party/boringssl-with-bazel/src/crypto/hpke/hpke.c +169 -6
  1366. data/third_party/boringssl-with-bazel/src/crypto/internal.h +216 -87
  1367. data/third_party/boringssl-with-bazel/src/crypto/kyber/internal.h +32 -2
  1368. data/third_party/boringssl-with-bazel/src/crypto/kyber/keccak.c +11 -12
  1369. data/third_party/boringssl-with-bazel/src/crypto/kyber/kyber.c +834 -0
  1370. data/third_party/boringssl-with-bazel/src/crypto/mem.c +7 -8
  1371. data/third_party/boringssl-with-bazel/src/crypto/obj/obj.c +25 -46
  1372. data/third_party/boringssl-with-bazel/src/crypto/obj/obj_dat.h +6 -13
  1373. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_lib.c +18 -14
  1374. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/internal.h +3 -3
  1375. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/p5_pbev2.c +3 -3
  1376. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/pkcs8.c +7 -7
  1377. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/pkcs8_x509.c +8 -5
  1378. data/third_party/boringssl-with-bazel/src/crypto/pool/internal.h +1 -0
  1379. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/deterministic.c +7 -6
  1380. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/forkunsafe.c +6 -12
  1381. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/getentropy.c +52 -0
  1382. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/{fuchsia.c → ios.c} +8 -8
  1383. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/trusty.c +38 -0
  1384. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/windows.c +41 -19
  1385. data/third_party/boringssl-with-bazel/src/crypto/{refcount_c11.c → refcount.c} +11 -17
  1386. data/third_party/boringssl-with-bazel/src/crypto/rsa_extra/internal.h +77 -0
  1387. data/third_party/boringssl-with-bazel/src/crypto/rsa_extra/rsa_crypt.c +568 -0
  1388. data/third_party/boringssl-with-bazel/src/crypto/stack/stack.c +152 -72
  1389. data/third_party/boringssl-with-bazel/src/crypto/thread_none.c +0 -8
  1390. data/third_party/boringssl-with-bazel/src/crypto/thread_pthread.c +6 -35
  1391. data/third_party/boringssl-with-bazel/src/crypto/thread_win.c +5 -26
  1392. data/third_party/boringssl-with-bazel/src/crypto/trust_token/internal.h +62 -0
  1393. data/third_party/boringssl-with-bazel/src/crypto/trust_token/pmbtoken.c +240 -72
  1394. data/third_party/boringssl-with-bazel/src/crypto/trust_token/trust_token.c +35 -0
  1395. data/third_party/boringssl-with-bazel/src/crypto/trust_token/voprf.c +588 -130
  1396. data/third_party/boringssl-with-bazel/src/crypto/x509/a_sign.c +27 -18
  1397. data/third_party/boringssl-with-bazel/src/crypto/x509/asn1_gen.c +1 -1
  1398. data/third_party/boringssl-with-bazel/src/crypto/x509/by_dir.c +10 -20
  1399. data/third_party/boringssl-with-bazel/src/crypto/x509/by_file.c +0 -3
  1400. data/third_party/boringssl-with-bazel/src/crypto/x509/internal.h +3 -2
  1401. data/third_party/boringssl-with-bazel/src/crypto/x509/name_print.c +17 -39
  1402. data/third_party/boringssl-with-bazel/src/crypto/x509/policy.c +18 -14
  1403. data/third_party/boringssl-with-bazel/src/crypto/x509/t_x509.c +39 -48
  1404. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_att.c +1 -141
  1405. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_d2.c +1 -3
  1406. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_lu.c +19 -25
  1407. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_req.c +72 -23
  1408. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_trs.c +8 -4
  1409. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_v3.c +8 -12
  1410. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_vfy.c +22 -24
  1411. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_vpm.c +1 -72
  1412. data/third_party/boringssl-with-bazel/src/crypto/x509/x509name.c +22 -29
  1413. data/third_party/boringssl-with-bazel/src/crypto/x509/x509spki.c +1 -1
  1414. data/third_party/boringssl-with-bazel/src/crypto/x509/x_crl.c +9 -7
  1415. data/third_party/boringssl-with-bazel/src/crypto/x509/x_name.c +1 -1
  1416. data/third_party/boringssl-with-bazel/src/crypto/x509/x_pubkey.c +7 -7
  1417. data/third_party/boringssl-with-bazel/src/crypto/x509/x_x509a.c +2 -2
  1418. data/third_party/boringssl-with-bazel/src/crypto/x509v3/internal.h +1 -1
  1419. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_alt.c +2 -3
  1420. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_conf.c +33 -46
  1421. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_cpols.c +1 -0
  1422. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_info.c +3 -5
  1423. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_lib.c +20 -52
  1424. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_prn.c +14 -26
  1425. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_purp.c +11 -9
  1426. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_skey.c +17 -10
  1427. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_utl.c +5 -3
  1428. data/third_party/boringssl-with-bazel/src/include/openssl/aead.h +5 -7
  1429. data/third_party/boringssl-with-bazel/src/include/openssl/arm_arch.h +4 -119
  1430. data/third_party/boringssl-with-bazel/src/include/openssl/asm_base.h +207 -0
  1431. data/third_party/boringssl-with-bazel/src/include/openssl/asn1.h +11 -4
  1432. data/third_party/boringssl-with-bazel/src/include/openssl/base.h +37 -112
  1433. data/third_party/boringssl-with-bazel/src/include/openssl/bio.h +19 -13
  1434. data/third_party/boringssl-with-bazel/src/include/openssl/blake2.h +1 -4
  1435. data/third_party/boringssl-with-bazel/src/include/openssl/bn.h +0 -2
  1436. data/third_party/boringssl-with-bazel/src/include/openssl/chacha.h +6 -0
  1437. data/third_party/boringssl-with-bazel/src/include/openssl/conf.h +5 -1
  1438. data/third_party/boringssl-with-bazel/src/include/openssl/dh.h +4 -1
  1439. data/third_party/boringssl-with-bazel/src/include/openssl/dsa.h +0 -21
  1440. data/third_party/boringssl-with-bazel/src/include/openssl/ec.h +28 -11
  1441. data/third_party/boringssl-with-bazel/src/include/openssl/ec_key.h +19 -6
  1442. data/third_party/boringssl-with-bazel/src/include/openssl/evp.h +14 -10
  1443. data/third_party/boringssl-with-bazel/src/include/openssl/hpke.h +34 -2
  1444. data/third_party/boringssl-with-bazel/src/include/openssl/kyber.h +128 -0
  1445. data/third_party/boringssl-with-bazel/src/include/openssl/nid.h +2 -11
  1446. data/third_party/boringssl-with-bazel/src/include/openssl/obj.h +8 -1
  1447. data/third_party/boringssl-with-bazel/src/include/openssl/pem.h +0 -3
  1448. data/third_party/boringssl-with-bazel/src/include/openssl/rand.h +13 -14
  1449. data/third_party/boringssl-with-bazel/src/include/openssl/rsa.h +91 -62
  1450. data/third_party/boringssl-with-bazel/src/include/openssl/span.h +26 -19
  1451. data/third_party/boringssl-with-bazel/src/include/openssl/ssl.h +275 -96
  1452. data/third_party/boringssl-with-bazel/src/include/openssl/stack.h +242 -223
  1453. data/third_party/boringssl-with-bazel/src/include/openssl/target.h +201 -0
  1454. data/third_party/boringssl-with-bazel/src/include/openssl/thread.h +1 -25
  1455. data/third_party/boringssl-with-bazel/src/include/openssl/tls1.h +4 -0
  1456. data/third_party/boringssl-with-bazel/src/include/openssl/trust_token.h +8 -0
  1457. data/third_party/boringssl-with-bazel/src/include/openssl/x509.h +760 -614
  1458. data/third_party/boringssl-with-bazel/src/include/openssl/x509v3.h +45 -12
  1459. data/third_party/boringssl-with-bazel/src/ssl/encrypted_client_hello.cc +11 -6
  1460. data/third_party/boringssl-with-bazel/src/ssl/extensions.cc +10 -68
  1461. data/third_party/boringssl-with-bazel/src/ssl/handoff.cc +20 -20
  1462. data/third_party/boringssl-with-bazel/src/ssl/handshake_client.cc +33 -18
  1463. data/third_party/boringssl-with-bazel/src/ssl/handshake_server.cc +1 -1
  1464. data/third_party/boringssl-with-bazel/src/ssl/internal.h +86 -46
  1465. data/third_party/boringssl-with-bazel/src/ssl/s3_both.cc +37 -18
  1466. data/third_party/boringssl-with-bazel/src/ssl/ssl_asn1.cc +8 -4
  1467. data/third_party/boringssl-with-bazel/src/ssl/ssl_cipher.cc +209 -209
  1468. data/third_party/boringssl-with-bazel/src/ssl/ssl_file.cc +6 -6
  1469. data/third_party/boringssl-with-bazel/src/ssl/ssl_key_share.cc +76 -118
  1470. data/third_party/boringssl-with-bazel/src/ssl/ssl_lib.cc +209 -33
  1471. data/third_party/boringssl-with-bazel/src/ssl/ssl_privkey.cc +17 -4
  1472. data/third_party/boringssl-with-bazel/src/ssl/ssl_session.cc +19 -21
  1473. data/third_party/boringssl-with-bazel/src/ssl/ssl_versions.cc +27 -19
  1474. data/third_party/boringssl-with-bazel/src/ssl/tls13_both.cc +2 -1
  1475. data/third_party/boringssl-with-bazel/src/ssl/tls13_client.cc +2 -3
  1476. data/third_party/boringssl-with-bazel/src/ssl/tls13_enc.cc +5 -21
  1477. data/third_party/boringssl-with-bazel/src/ssl/tls13_server.cc +5 -2
  1478. data/third_party/boringssl-with-bazel/src/third_party/fiat/curve25519_64_adx.h +691 -0
  1479. data/third_party/boringssl-with-bazel/src/third_party/fiat/curve25519_64_msvc.h +1281 -0
  1480. data/third_party/boringssl-with-bazel/src/third_party/fiat/p256_64_msvc.h +2002 -0
  1481. data/third_party/cares/cares/include/ares.h +23 -1
  1482. data/third_party/cares/cares/{src/lib → include}/ares_nameser.h +9 -7
  1483. data/third_party/cares/cares/include/ares_rules.h +2 -2
  1484. data/third_party/cares/cares/include/ares_version.h +3 -3
  1485. data/third_party/cares/cares/src/lib/ares__addrinfo2hostent.c +266 -0
  1486. data/third_party/cares/cares/src/lib/ares__addrinfo_localhost.c +240 -0
  1487. data/third_party/cares/cares/src/lib/ares__parse_into_addrinfo.c +49 -80
  1488. data/third_party/cares/cares/src/lib/ares__readaddrinfo.c +37 -43
  1489. data/third_party/cares/cares/src/lib/ares__sortaddrinfo.c +12 -4
  1490. data/third_party/cares/cares/src/lib/ares_data.c +16 -0
  1491. data/third_party/cares/cares/src/lib/ares_data.h +7 -0
  1492. data/third_party/cares/cares/src/lib/ares_destroy.c +8 -0
  1493. data/third_party/cares/cares/src/lib/ares_expand_name.c +17 -6
  1494. data/third_party/cares/cares/src/lib/ares_freeaddrinfo.c +1 -0
  1495. data/third_party/cares/cares/src/lib/ares_getaddrinfo.c +156 -78
  1496. data/third_party/cares/cares/src/lib/ares_gethostbyname.c +130 -326
  1497. data/third_party/cares/cares/src/lib/ares_init.c +97 -485
  1498. data/third_party/cares/cares/src/lib/ares_library_init.c +2 -89
  1499. data/third_party/cares/cares/src/lib/ares_parse_a_reply.c +23 -142
  1500. data/third_party/cares/cares/src/lib/ares_parse_aaaa_reply.c +22 -142
  1501. data/third_party/cares/cares/src/lib/ares_parse_uri_reply.c +184 -0
  1502. data/third_party/cares/cares/src/lib/ares_private.h +30 -16
  1503. data/third_party/cares/cares/src/lib/ares_process.c +55 -16
  1504. data/third_party/cares/cares/src/lib/ares_query.c +1 -35
  1505. data/third_party/cares/cares/src/lib/ares_rand.c +279 -0
  1506. data/third_party/cares/cares/src/lib/ares_send.c +5 -7
  1507. data/third_party/cares/cares/src/lib/ares_strdup.c +12 -19
  1508. data/third_party/cares/cares/src/lib/ares_strsplit.c +44 -128
  1509. data/third_party/cares/cares/src/lib/ares_strsplit.h +9 -10
  1510. data/third_party/cares/cares/src/lib/inet_net_pton.c +78 -116
  1511. data/third_party/cares/cares/src/tools/ares_getopt.h +53 -0
  1512. data/third_party/upb/upb/{table_internal.h → alloc.h} +6 -6
  1513. data/third_party/upb/upb/arena.h +4 -193
  1514. data/third_party/upb/upb/array.h +4 -51
  1515. data/third_party/upb/upb/base/descriptor_constants.h +104 -0
  1516. data/third_party/upb/upb/base/log2.h +57 -0
  1517. data/third_party/upb/upb/{status.c → base/status.c} +2 -7
  1518. data/third_party/upb/upb/base/status.h +66 -0
  1519. data/third_party/upb/upb/base/string_view.h +75 -0
  1520. data/third_party/upb/upb/{array.c → collections/array.c} +67 -36
  1521. data/third_party/upb/upb/collections/array.h +85 -0
  1522. data/third_party/upb/upb/collections/array_internal.h +135 -0
  1523. data/third_party/upb/upb/{map.c → collections/map.c} +53 -26
  1524. data/third_party/upb/upb/collections/map.h +135 -0
  1525. data/third_party/upb/upb/collections/map_gencode_util.h +78 -0
  1526. data/third_party/upb/upb/collections/map_internal.h +170 -0
  1527. data/third_party/upb/upb/collections/map_sorter.c +166 -0
  1528. data/third_party/upb/upb/collections/map_sorter_internal.h +109 -0
  1529. data/third_party/upb/upb/{message_value.h → collections/message_value.h} +12 -13
  1530. data/third_party/upb/upb/decode.h +3 -62
  1531. data/third_party/upb/upb/def.h +4 -384
  1532. data/third_party/upb/upb/def.hpp +3 -411
  1533. data/third_party/upb/upb/encode.h +3 -48
  1534. data/third_party/upb/upb/extension_registry.h +3 -52
  1535. data/third_party/upb/upb/{table.c → hash/common.c} +52 -110
  1536. data/third_party/upb/upb/hash/common.h +199 -0
  1537. data/third_party/upb/upb/hash/int_table.h +102 -0
  1538. data/third_party/upb/upb/hash/str_table.h +161 -0
  1539. data/third_party/upb/upb/{json_decode.c → json/decode.c} +63 -98
  1540. data/third_party/upb/upb/json/decode.h +52 -0
  1541. data/third_party/upb/upb/{json_encode.c → json/encode.c} +69 -45
  1542. data/third_party/upb/upb/json/encode.h +70 -0
  1543. data/third_party/upb/upb/json_decode.h +4 -15
  1544. data/third_party/upb/upb/json_encode.h +4 -33
  1545. data/third_party/upb/upb/lex/atoi.c +68 -0
  1546. data/third_party/upb/upb/lex/atoi.h +53 -0
  1547. data/third_party/upb/upb/{upb.c → lex/round_trip.c} +2 -11
  1548. data/third_party/upb/upb/{internal/upb.h → lex/round_trip.h} +17 -30
  1549. data/third_party/upb/upb/lex/strtod.c +97 -0
  1550. data/third_party/upb/upb/lex/strtod.h +46 -0
  1551. data/third_party/upb/upb/lex/unicode.c +57 -0
  1552. data/third_party/upb/upb/lex/unicode.h +77 -0
  1553. data/third_party/upb/upb/map.h +4 -85
  1554. data/third_party/upb/upb/mem/alloc.c +47 -0
  1555. data/third_party/upb/upb/mem/alloc.h +98 -0
  1556. data/third_party/upb/upb/mem/arena.c +367 -0
  1557. data/third_party/upb/upb/mem/arena.h +160 -0
  1558. data/third_party/upb/upb/mem/arena_internal.h +114 -0
  1559. data/third_party/upb/upb/message/accessors.c +68 -0
  1560. data/third_party/upb/upb/message/accessors.h +379 -0
  1561. data/third_party/upb/upb/message/accessors_internal.h +325 -0
  1562. data/third_party/upb/upb/message/extension_internal.h +83 -0
  1563. data/third_party/upb/upb/message/internal.h +135 -0
  1564. data/third_party/upb/upb/message/message.c +180 -0
  1565. data/third_party/upb/upb/message/message.h +69 -0
  1566. data/third_party/upb/upb/mini_table/common.c +128 -0
  1567. data/third_party/upb/upb/mini_table/common.h +170 -0
  1568. data/third_party/upb/upb/mini_table/common_internal.h +111 -0
  1569. data/third_party/upb/upb/{mini_table.c → mini_table/decode.c} +513 -533
  1570. data/third_party/upb/upb/mini_table/decode.h +179 -0
  1571. data/third_party/upb/upb/mini_table/encode.c +300 -0
  1572. data/third_party/upb/upb/mini_table/encode_internal.h +111 -0
  1573. data/third_party/upb/upb/{mini_table.hpp → mini_table/encode_internal.hpp} +32 -8
  1574. data/third_party/upb/upb/mini_table/enum_internal.h +88 -0
  1575. data/third_party/upb/upb/mini_table/extension_internal.h +47 -0
  1576. data/third_party/upb/upb/{extension_registry.c → mini_table/extension_registry.c} +27 -24
  1577. data/third_party/upb/upb/mini_table/extension_registry.h +104 -0
  1578. data/third_party/upb/upb/mini_table/field_internal.h +192 -0
  1579. data/third_party/upb/upb/mini_table/file_internal.h +47 -0
  1580. data/third_party/upb/upb/mini_table/message_internal.h +136 -0
  1581. data/third_party/upb/upb/mini_table/sub_internal.h +38 -0
  1582. data/third_party/upb/upb/mini_table/types.h +40 -0
  1583. data/third_party/upb/upb/msg.h +3 -38
  1584. data/third_party/upb/upb/port/atomic.h +101 -0
  1585. data/third_party/upb/upb/{port_def.inc → port/def.inc} +94 -27
  1586. data/third_party/upb/upb/{port_undef.inc → port/undef.inc} +13 -3
  1587. data/third_party/upb/upb/{internal → port}/vsnprintf_compat.h +5 -7
  1588. data/third_party/upb/upb/reflection/common.h +67 -0
  1589. data/third_party/upb/upb/reflection/def.h +42 -0
  1590. data/third_party/upb/upb/reflection/def.hpp +610 -0
  1591. data/third_party/upb/upb/reflection/def_builder.c +357 -0
  1592. data/third_party/upb/upb/reflection/def_builder_internal.h +157 -0
  1593. data/third_party/upb/upb/reflection/def_pool.c +462 -0
  1594. data/third_party/upb/upb/reflection/def_pool.h +108 -0
  1595. data/third_party/upb/upb/reflection/def_pool_internal.h +77 -0
  1596. data/third_party/upb/upb/reflection/def_type.c +50 -0
  1597. data/third_party/upb/upb/reflection/def_type.h +81 -0
  1598. data/third_party/upb/upb/reflection/desc_state.c +53 -0
  1599. data/third_party/upb/upb/reflection/desc_state_internal.h +64 -0
  1600. data/third_party/upb/upb/reflection/enum_def.c +310 -0
  1601. data/third_party/upb/upb/reflection/enum_def.h +80 -0
  1602. data/third_party/upb/upb/reflection/enum_def_internal.h +56 -0
  1603. data/third_party/upb/upb/reflection/enum_reserved_range.c +84 -0
  1604. data/third_party/upb/upb/reflection/enum_reserved_range.h +51 -0
  1605. data/third_party/upb/upb/reflection/enum_reserved_range_internal.h +55 -0
  1606. data/third_party/upb/upb/reflection/enum_value_def.c +144 -0
  1607. data/third_party/upb/upb/reflection/enum_value_def.h +57 -0
  1608. data/third_party/upb/upb/reflection/enum_value_def_internal.h +57 -0
  1609. data/third_party/upb/upb/reflection/extension_range.c +93 -0
  1610. data/third_party/upb/upb/reflection/extension_range.h +55 -0
  1611. data/third_party/upb/upb/reflection/extension_range_internal.h +54 -0
  1612. data/third_party/upb/upb/reflection/field_def.c +930 -0
  1613. data/third_party/upb/upb/reflection/field_def.h +91 -0
  1614. data/third_party/upb/upb/reflection/field_def_internal.h +76 -0
  1615. data/third_party/upb/upb/reflection/file_def.c +370 -0
  1616. data/third_party/upb/upb/reflection/file_def.h +77 -0
  1617. data/third_party/upb/upb/reflection/file_def_internal.h +57 -0
  1618. data/third_party/upb/upb/reflection/message.c +233 -0
  1619. data/third_party/upb/upb/reflection/message.h +102 -0
  1620. data/third_party/upb/upb/reflection/message.hpp +37 -0
  1621. data/third_party/upb/upb/reflection/message_def.c +718 -0
  1622. data/third_party/upb/upb/reflection/message_def.h +174 -0
  1623. data/third_party/upb/upb/reflection/message_def_internal.h +63 -0
  1624. data/third_party/upb/upb/reflection/message_reserved_range.c +81 -0
  1625. data/third_party/upb/upb/reflection/message_reserved_range.h +51 -0
  1626. data/third_party/upb/upb/reflection/message_reserved_range_internal.h +55 -0
  1627. data/third_party/upb/upb/reflection/method_def.c +124 -0
  1628. data/third_party/upb/upb/reflection/method_def.h +59 -0
  1629. data/third_party/upb/upb/reflection/method_def_internal.h +53 -0
  1630. data/third_party/upb/upb/reflection/oneof_def.c +226 -0
  1631. data/third_party/upb/upb/reflection/oneof_def.h +66 -0
  1632. data/third_party/upb/upb/reflection/oneof_def_internal.h +57 -0
  1633. data/third_party/upb/upb/reflection/service_def.c +128 -0
  1634. data/third_party/upb/upb/reflection/service_def.h +60 -0
  1635. data/third_party/upb/upb/reflection/service_def_internal.h +53 -0
  1636. data/third_party/upb/upb/reflection.h +4 -78
  1637. data/third_party/upb/upb/reflection.hpp +3 -7
  1638. data/third_party/upb/upb/status.h +4 -34
  1639. data/third_party/upb/upb/{collections.h → string_view.h} +7 -7
  1640. data/third_party/upb/upb/{text_encode.c → text/encode.c} +74 -70
  1641. data/third_party/upb/upb/text/encode.h +69 -0
  1642. data/third_party/upb/upb/text_encode.h +4 -32
  1643. data/third_party/upb/upb/upb.h +6 -151
  1644. data/third_party/upb/upb/upb.hpp +10 -18
  1645. data/third_party/upb/upb/wire/common.h +44 -0
  1646. data/third_party/upb/upb/wire/common_internal.h +50 -0
  1647. data/third_party/upb/upb/wire/decode.c +1343 -0
  1648. data/third_party/upb/upb/wire/decode.h +108 -0
  1649. data/third_party/upb/upb/{decode_fast.c → wire/decode_fast.c} +184 -225
  1650. data/third_party/upb/upb/{decode_fast.h → wire/decode_fast.h} +21 -7
  1651. data/third_party/upb/upb/{internal/decode.h → wire/decode_internal.h} +44 -92
  1652. data/third_party/upb/upb/{encode.c → wire/encode.c} +114 -95
  1653. data/third_party/upb/upb/wire/encode.h +92 -0
  1654. data/third_party/upb/upb/wire/eps_copy_input_stream.c +39 -0
  1655. data/third_party/upb/upb/wire/eps_copy_input_stream.h +425 -0
  1656. data/third_party/upb/upb/wire/reader.c +67 -0
  1657. data/third_party/upb/upb/wire/reader.h +227 -0
  1658. data/third_party/upb/upb/wire/swap_internal.h +63 -0
  1659. data/third_party/upb/upb/wire/types.h +41 -0
  1660. data/third_party/{upb/third_party/utf8_range → utf8_range}/range2-neon.c +1 -1
  1661. data/third_party/{upb/third_party/utf8_range → utf8_range}/utf8_range.h +12 -0
  1662. metadata +258 -82
  1663. data/src/core/ext/filters/client_channel/health/health_check_client.cc +0 -175
  1664. data/src/core/ext/filters/client_channel/health/health_check_client.h +0 -43
  1665. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_attributes.cc +0 -42
  1666. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_attributes.h +0 -64
  1667. data/src/core/ext/transport/chttp2/transport/context_list.cc +0 -71
  1668. data/src/core/ext/transport/chttp2/transport/context_list.h +0 -54
  1669. data/src/core/ext/transport/chttp2/transport/stream_map.cc +0 -177
  1670. data/src/core/ext/transport/chttp2/transport/stream_map.h +0 -68
  1671. data/src/core/lib/promise/detail/basic_join.h +0 -197
  1672. data/src/core/lib/promise/detail/switch.h +0 -1455
  1673. data/src/core/lib/promise/try_join.h +0 -82
  1674. data/third_party/abseil-cpp/absl/synchronization/internal/waiter.cc +0 -403
  1675. data/third_party/boringssl-with-bazel/src/crypto/refcount_lock.c +0 -52
  1676. data/third_party/cares/cares/src/lib/ares_library_init.h +0 -43
  1677. data/third_party/re2/util/benchmark.h +0 -156
  1678. data/third_party/re2/util/flags.h +0 -26
  1679. data/third_party/re2/util/malloc_counter.h +0 -19
  1680. data/third_party/re2/util/pcre.cc +0 -1025
  1681. data/third_party/re2/util/pcre.h +0 -681
  1682. data/third_party/re2/util/test.h +0 -50
  1683. data/third_party/upb/upb/arena.c +0 -277
  1684. data/third_party/upb/upb/decode.c +0 -1221
  1685. data/third_party/upb/upb/def.c +0 -3269
  1686. data/third_party/upb/upb/internal/table.h +0 -385
  1687. data/third_party/upb/upb/mini_table.h +0 -189
  1688. data/third_party/upb/upb/msg.c +0 -368
  1689. data/third_party/upb/upb/msg_internal.h +0 -837
  1690. data/third_party/upb/upb/reflection.c +0 -323
  1691. data/third_party/zlib/gzclose.c +0 -25
  1692. data/third_party/zlib/gzlib.c +0 -639
  1693. data/third_party/zlib/gzread.c +0 -650
  1694. data/third_party/zlib/gzwrite.c +0 -677
  1695. /data/third_party/{upb/third_party/utf8_range → utf8_range}/naive.c +0 -0
  1696. /data/third_party/{upb/third_party/utf8_range → utf8_range}/range2-sse.c +0 -0
@@ -62,6 +62,8 @@
62
62
  // pseudo-struct:
63
63
  //
64
64
  // struct BackingArray {
65
+ // // The number of elements we can insert before growing the capacity.
66
+ // size_t growth_left;
65
67
  // // Control bytes for the "real" slots.
66
68
  // ctrl_t ctrl[capacity];
67
69
  // // Always `ctrl_t::kSentinel`. This is used by iterators to find when to
@@ -115,7 +117,7 @@
115
117
  // starting with that index and extract potential candidates: occupied slots
116
118
  // with a control byte equal to `H2(hash(x))`. If we find an empty slot in the
117
119
  // group, we stop and return an error. Each candidate slot `y` is compared with
118
- // `x`; if `x == y`, we are done and return `&y`; otherwise we contine to the
120
+ // `x`; if `x == y`, we are done and return `&y`; otherwise we continue to the
119
121
  // next probe index. Tombstones effectively behave like full slots that never
120
122
  // match the value we're looking for.
121
123
  //
@@ -174,21 +176,23 @@
174
176
 
175
177
  #include <algorithm>
176
178
  #include <cmath>
179
+ #include <cstddef>
177
180
  #include <cstdint>
178
181
  #include <cstring>
179
182
  #include <iterator>
180
183
  #include <limits>
181
184
  #include <memory>
185
+ #include <string>
182
186
  #include <tuple>
183
187
  #include <type_traits>
184
188
  #include <utility>
185
189
 
186
190
  #include "absl/base/config.h"
187
191
  #include "absl/base/internal/endian.h"
188
- #include "absl/base/internal/prefetch.h"
189
192
  #include "absl/base/internal/raw_logging.h"
190
193
  #include "absl/base/optimization.h"
191
194
  #include "absl/base/port.h"
195
+ #include "absl/base/prefetch.h"
192
196
  #include "absl/container/internal/common.h"
193
197
  #include "absl/container/internal/compressed_tuple.h"
194
198
  #include "absl/container/internal/container_memory.h"
@@ -235,6 +239,14 @@ namespace container_internal {
235
239
  // We use uint8_t so we don't need to worry about padding.
236
240
  using GenerationType = uint8_t;
237
241
 
242
+ // A sentinel value for empty generations. Using 0 makes it easy to constexpr
243
+ // initialize an array of this value.
244
+ constexpr GenerationType SentinelEmptyGeneration() { return 0; }
245
+
246
+ constexpr GenerationType NextGeneration(GenerationType generation) {
247
+ return ++generation == SentinelEmptyGeneration() ? ++generation : generation;
248
+ }
249
+
238
250
  #ifdef ABSL_SWISSTABLE_ENABLE_GENERATIONS
239
251
  constexpr bool SwisstableGenerationsEnabled() { return true; }
240
252
  constexpr size_t NumGenerationBytes() { return sizeof(GenerationType); }
@@ -367,12 +379,12 @@ class NonIterableBitMask {
367
379
  return static_cast<uint32_t>((bit_width(mask_) - 1) >> Shift);
368
380
  }
369
381
 
370
- // Return the number of trailing zero *abstract* bits.
382
+ // Returns the number of trailing zero *abstract* bits.
371
383
  uint32_t TrailingZeros() const {
372
384
  return container_internal::TrailingZeros(mask_) >> Shift;
373
385
  }
374
386
 
375
- // Return the number of leading zero *abstract* bits.
387
+ // Returns the number of leading zero *abstract* bits.
376
388
  uint32_t LeadingZeros() const {
377
389
  constexpr int total_significant_bits = SignificantBits << Shift;
378
390
  constexpr int extra_bits = sizeof(T) * 8 - total_significant_bits;
@@ -475,19 +487,23 @@ static_assert(ctrl_t::kDeleted == static_cast<ctrl_t>(-2),
475
487
  "ctrl_t::kDeleted must be -2 to make the implementation of "
476
488
  "ConvertSpecialToEmptyAndFullToDeleted efficient");
477
489
 
478
- ABSL_DLL extern const ctrl_t kEmptyGroup[17];
490
+ // See definition comment for why this is size 32.
491
+ ABSL_DLL extern const ctrl_t kEmptyGroup[32];
479
492
 
480
493
  // Returns a pointer to a control byte group that can be used by empty tables.
481
494
  inline ctrl_t* EmptyGroup() {
482
495
  // Const must be cast away here; no uses of this function will actually write
483
496
  // to it, because it is only used for empty tables.
484
- return const_cast<ctrl_t*>(kEmptyGroup);
497
+ return const_cast<ctrl_t*>(kEmptyGroup + 16);
485
498
  }
486
499
 
487
- // Returns a pointer to the generation byte at the end of the empty group, if it
488
- // exists.
489
- inline GenerationType* EmptyGeneration() {
490
- return reinterpret_cast<GenerationType*>(EmptyGroup() + 16);
500
+ // Returns a pointer to a generation to use for an empty hashtable.
501
+ GenerationType* EmptyGeneration();
502
+
503
+ // Returns whether `generation` is a generation for an empty hashtable that
504
+ // could be returned by EmptyGeneration().
505
+ inline bool IsEmptyGeneration(const GenerationType* generation) {
506
+ return *generation == SentinelEmptyGeneration();
491
507
  }
492
508
 
493
509
  // Mixes a randomly generated per-process seed with `hash` and `ctrl` to
@@ -674,9 +690,10 @@ struct GroupAArch64Impl {
674
690
  void ConvertSpecialToEmptyAndFullToDeleted(ctrl_t* dst) const {
675
691
  uint64_t mask = vget_lane_u64(vreinterpret_u64_u8(ctrl), 0);
676
692
  constexpr uint64_t msbs = 0x8080808080808080ULL;
677
- constexpr uint64_t lsbs = 0x0101010101010101ULL;
678
- auto x = mask & msbs;
679
- auto res = (~x + (x >> 7)) & ~lsbs;
693
+ constexpr uint64_t slsbs = 0x0202020202020202ULL;
694
+ constexpr uint64_t midbs = 0x7e7e7e7e7e7e7e7eULL;
695
+ auto x = slsbs & (mask >> 6);
696
+ auto res = (x + midbs) | msbs;
680
697
  little_endian::Store64(dst, res);
681
698
  }
682
699
 
@@ -749,6 +766,15 @@ using Group = GroupAArch64Impl;
749
766
  using Group = GroupPortableImpl;
750
767
  #endif
751
768
 
769
+ // When there is an insertion with no reserved growth, we rehash with
770
+ // probability `min(1, RehashProbabilityConstant() / capacity())`. Using a
771
+ // constant divided by capacity ensures that inserting N elements is still O(N)
772
+ // in the average case. Using the constant 16 means that we expect to rehash ~8
773
+ // times more often than when generations are disabled. We are adding expected
774
+ // rehash_probability * #insertions/capacity_growth = 16/capacity * ((7/8 -
775
+ // 7/16) * capacity)/capacity_growth = ~7 extra rehashes per capacity growth.
776
+ inline size_t RehashProbabilityConstant() { return 16; }
777
+
752
778
  class CommonFieldsGenerationInfoEnabled {
753
779
  // A sentinel value for reserved_growth_ indicating that we just ran out of
754
780
  // reserved growth on the last insertion. When reserve is called and then
@@ -760,8 +786,11 @@ class CommonFieldsGenerationInfoEnabled {
760
786
  public:
761
787
  CommonFieldsGenerationInfoEnabled() = default;
762
788
  CommonFieldsGenerationInfoEnabled(CommonFieldsGenerationInfoEnabled&& that)
763
- : reserved_growth_(that.reserved_growth_), generation_(that.generation_) {
789
+ : reserved_growth_(that.reserved_growth_),
790
+ reservation_size_(that.reservation_size_),
791
+ generation_(that.generation_) {
764
792
  that.reserved_growth_ = 0;
793
+ that.reservation_size_ = 0;
765
794
  that.generation_ = EmptyGeneration();
766
795
  }
767
796
  CommonFieldsGenerationInfoEnabled& operator=(
@@ -769,19 +798,17 @@ class CommonFieldsGenerationInfoEnabled {
769
798
 
770
799
  // Whether we should rehash on insert in order to detect bugs of using invalid
771
800
  // references. We rehash on the first insertion after reserved_growth_ reaches
772
- // 0 after a call to reserve.
773
- // TODO(b/254649633): we could potentially do a rehash with low probability
801
+ // 0 after a call to reserve. We also do a rehash with low probability
774
802
  // whenever reserved_growth_ is zero.
775
- bool should_rehash_for_bug_detection_on_insert() const {
776
- return reserved_growth_ == kReservedGrowthJustRanOut;
777
- }
803
+ bool should_rehash_for_bug_detection_on_insert(const ctrl_t* ctrl,
804
+ size_t capacity) const;
778
805
  void maybe_increment_generation_on_insert() {
779
806
  if (reserved_growth_ == kReservedGrowthJustRanOut) reserved_growth_ = 0;
780
807
 
781
808
  if (reserved_growth_ > 0) {
782
809
  if (--reserved_growth_ == 0) reserved_growth_ = kReservedGrowthJustRanOut;
783
810
  } else {
784
- ++*generation_;
811
+ *generation_ = NextGeneration(*generation_);
785
812
  }
786
813
  }
787
814
  void reset_reserved_growth(size_t reservation, size_t size) {
@@ -789,6 +816,8 @@ class CommonFieldsGenerationInfoEnabled {
789
816
  }
790
817
  size_t reserved_growth() const { return reserved_growth_; }
791
818
  void set_reserved_growth(size_t r) { reserved_growth_ = r; }
819
+ size_t reservation_size() const { return reservation_size_; }
820
+ void set_reservation_size(size_t r) { reservation_size_ = r; }
792
821
  GenerationType generation() const { return *generation_; }
793
822
  void set_generation(GenerationType g) { *generation_ = g; }
794
823
  GenerationType* generation_ptr() const { return generation_; }
@@ -796,10 +825,14 @@ class CommonFieldsGenerationInfoEnabled {
796
825
 
797
826
  private:
798
827
  // The number of insertions remaining that are guaranteed to not rehash due to
799
- // a prior call to reserve. Note: we store reserved growth rather than
828
+ // a prior call to reserve. Note: we store reserved growth in addition to
800
829
  // reservation size because calls to erase() decrease size_ but don't decrease
801
830
  // reserved growth.
802
831
  size_t reserved_growth_ = 0;
832
+ // The maximum argument to reserve() since the container was cleared. We need
833
+ // to keep track of this, in addition to reserved growth, because we reset
834
+ // reserved growth to this when erase(begin(), end()) is called.
835
+ size_t reservation_size_ = 0;
803
836
  // Pointer to the generation counter, which is used to validate iterators and
804
837
  // is stored in the backing array between the control bytes and the slots.
805
838
  // Note that we can't store the generation inside the container itself and
@@ -820,11 +853,15 @@ class CommonFieldsGenerationInfoDisabled {
820
853
  CommonFieldsGenerationInfoDisabled& operator=(
821
854
  CommonFieldsGenerationInfoDisabled&&) = default;
822
855
 
823
- bool should_rehash_for_bug_detection_on_insert() const { return false; }
856
+ bool should_rehash_for_bug_detection_on_insert(const ctrl_t*, size_t) const {
857
+ return false;
858
+ }
824
859
  void maybe_increment_generation_on_insert() {}
825
860
  void reset_reserved_growth(size_t, size_t) {}
826
861
  size_t reserved_growth() const { return 0; }
827
862
  void set_reserved_growth(size_t) {}
863
+ size_t reservation_size() const { return 0; }
864
+ void set_reservation_size(size_t) {}
828
865
  GenerationType generation() const { return 0; }
829
866
  void set_generation(GenerationType) {}
830
867
  GenerationType* generation_ptr() const { return nullptr; }
@@ -867,6 +904,44 @@ using CommonFieldsGenerationInfo = CommonFieldsGenerationInfoDisabled;
867
904
  using HashSetIteratorGenerationInfo = HashSetIteratorGenerationInfoDisabled;
868
905
  #endif
869
906
 
907
+ // Returns whether `n` is a valid capacity (i.e., number of slots).
908
+ //
909
+ // A valid capacity is a non-zero integer `2^m - 1`.
910
+ inline bool IsValidCapacity(size_t n) { return ((n + 1) & n) == 0 && n > 0; }
911
+
912
+ // Computes the offset from the start of the backing allocation of the control
913
+ // bytes. growth_left is stored at the beginning of the backing array.
914
+ inline size_t ControlOffset() { return sizeof(size_t); }
915
+
916
+ // Returns the number of "cloned control bytes".
917
+ //
918
+ // This is the number of control bytes that are present both at the beginning
919
+ // of the control byte array and at the end, such that we can create a
920
+ // `Group::kWidth`-width probe window starting from any control byte.
921
+ constexpr size_t NumClonedBytes() { return Group::kWidth - 1; }
922
+
923
+ // Given the capacity of a table, computes the offset (from the start of the
924
+ // backing allocation) of the generation counter (if it exists).
925
+ inline size_t GenerationOffset(size_t capacity) {
926
+ assert(IsValidCapacity(capacity));
927
+ const size_t num_control_bytes = capacity + 1 + NumClonedBytes();
928
+ return ControlOffset() + num_control_bytes;
929
+ }
930
+
931
+ // Given the capacity of a table, computes the offset (from the start of the
932
+ // backing allocation) at which the slots begin.
933
+ inline size_t SlotOffset(size_t capacity, size_t slot_align) {
934
+ assert(IsValidCapacity(capacity));
935
+ return (GenerationOffset(capacity) + NumGenerationBytes() + slot_align - 1) &
936
+ (~slot_align + 1);
937
+ }
938
+
939
+ // Given the capacity of a table, computes the total size of the backing
940
+ // array.
941
+ inline size_t AllocSize(size_t capacity, size_t slot_size, size_t slot_align) {
942
+ return SlotOffset(capacity, slot_align) + capacity * slot_size;
943
+ }
944
+
870
945
  // CommonFields hold the fields in raw_hash_set that do not depend
871
946
  // on template parameters. This allows us to conveniently pass all
872
947
  // of this state to helper functions as a single argument.
@@ -884,72 +959,102 @@ class CommonFields : public CommonFieldsGenerationInfo {
884
959
  std::move(static_cast<CommonFieldsGenerationInfo&&>(that))),
885
960
  // Explicitly copying fields into "this" and then resetting "that"
886
961
  // fields generates less code then calling absl::exchange per field.
887
- control_(that.control_),
888
- slots_(that.slots_),
889
- size_(that.size_),
890
- capacity_(that.capacity_),
891
- compressed_tuple_(that.growth_left(), std::move(that.infoz())) {
892
- that.control_ = EmptyGroup();
893
- that.slots_ = nullptr;
894
- that.size_ = 0;
895
- that.capacity_ = 0;
896
- that.growth_left() = 0;
962
+ control_(that.control()),
963
+ slots_(that.slot_array()),
964
+ capacity_(that.capacity()),
965
+ compressed_tuple_(that.size(), std::move(that.infoz())) {
966
+ that.set_control(EmptyGroup());
967
+ that.set_slots(nullptr);
968
+ that.set_capacity(0);
969
+ that.set_size(0);
897
970
  }
898
971
  CommonFields& operator=(CommonFields&&) = default;
899
972
 
973
+ ctrl_t* control() const { return control_; }
974
+ void set_control(ctrl_t* c) { control_ = c; }
975
+ void* backing_array_start() const {
976
+ // growth_left is stored before control bytes.
977
+ assert(reinterpret_cast<uintptr_t>(control()) % alignof(size_t) == 0);
978
+ return control() - sizeof(size_t);
979
+ }
980
+
981
+ // Note: we can't use slots() because Qt defines "slots" as a macro.
982
+ void* slot_array() const { return slots_; }
983
+ void set_slots(void* s) { slots_ = s; }
984
+
985
+ // The number of filled slots.
986
+ size_t size() const { return compressed_tuple_.template get<0>(); }
987
+ void set_size(size_t s) { compressed_tuple_.template get<0>() = s; }
988
+
989
+ // The total number of available slots.
990
+ size_t capacity() const { return capacity_; }
991
+ void set_capacity(size_t c) {
992
+ assert(c == 0 || IsValidCapacity(c));
993
+ capacity_ = c;
994
+ }
995
+
900
996
  // The number of slots we can still fill without needing to rehash.
901
- size_t& growth_left() { return compressed_tuple_.template get<0>(); }
997
+ // This is stored in the heap allocation before the control bytes.
998
+ size_t growth_left() const {
999
+ return *reinterpret_cast<size_t*>(backing_array_start());
1000
+ }
1001
+ void set_growth_left(size_t gl) {
1002
+ *reinterpret_cast<size_t*>(backing_array_start()) = gl;
1003
+ }
902
1004
 
903
1005
  HashtablezInfoHandle& infoz() { return compressed_tuple_.template get<1>(); }
904
1006
  const HashtablezInfoHandle& infoz() const {
905
1007
  return compressed_tuple_.template get<1>();
906
1008
  }
907
1009
 
1010
+ bool should_rehash_for_bug_detection_on_insert() const {
1011
+ return CommonFieldsGenerationInfo::
1012
+ should_rehash_for_bug_detection_on_insert(control(), capacity());
1013
+ }
908
1014
  void reset_reserved_growth(size_t reservation) {
909
- CommonFieldsGenerationInfo::reset_reserved_growth(reservation, size_);
1015
+ CommonFieldsGenerationInfo::reset_reserved_growth(reservation, size());
1016
+ }
1017
+
1018
+ // The size of the backing array allocation.
1019
+ size_t alloc_size(size_t slot_size, size_t slot_align) const {
1020
+ return AllocSize(capacity(), slot_size, slot_align);
910
1021
  }
911
1022
 
1023
+ // Returns the number of control bytes set to kDeleted. For testing only.
1024
+ size_t TombstonesCount() const {
1025
+ return static_cast<size_t>(
1026
+ std::count(control(), control() + capacity(), ctrl_t::kDeleted));
1027
+ }
1028
+
1029
+ private:
912
1030
  // TODO(b/259599413): Investigate removing some of these fields:
913
1031
  // - control/slots can be derived from each other
914
- // - size can be moved into the slot array
1032
+ // - we can use 6 bits for capacity since it's always a power of two minus 1
915
1033
 
916
- // The control bytes (and, also, a pointer to the base of the backing array).
1034
+ // The control bytes (and, also, a pointer near to the base of the backing
1035
+ // array).
917
1036
  //
918
1037
  // This contains `capacity + 1 + NumClonedBytes()` entries, even
919
1038
  // when the table is empty (hence EmptyGroup).
1039
+ //
1040
+ // Note that growth_left is stored immediately before this pointer.
920
1041
  ctrl_t* control_ = EmptyGroup();
921
1042
 
922
1043
  // The beginning of the slots, located at `SlotOffset()` bytes after
923
1044
  // `control`. May be null for empty tables.
924
1045
  void* slots_ = nullptr;
925
1046
 
926
- // The number of filled slots.
927
- size_t size_ = 0;
928
-
929
- // The total number of available slots.
930
1047
  size_t capacity_ = 0;
931
1048
 
932
- // Bundle together growth_left and HashtablezInfoHandle to ensure EBO for
1049
+ // Bundle together size and HashtablezInfoHandle to ensure EBO for
933
1050
  // HashtablezInfoHandle when sampling is turned off.
934
1051
  absl::container_internal::CompressedTuple<size_t, HashtablezInfoHandle>
935
1052
  compressed_tuple_{0u, HashtablezInfoHandle{}};
936
1053
  };
937
1054
 
938
- // Returns he number of "cloned control bytes".
939
- //
940
- // This is the number of control bytes that are present both at the beginning
941
- // of the control byte array and at the end, such that we can create a
942
- // `Group::kWidth`-width probe window starting from any control byte.
943
- constexpr size_t NumClonedBytes() { return Group::kWidth - 1; }
944
-
945
1055
  template <class Policy, class Hash, class Eq, class Alloc>
946
1056
  class raw_hash_set;
947
1057
 
948
- // Returns whether `n` is a valid capacity (i.e., number of slots).
949
- //
950
- // A valid capacity is a non-zero integer `2^m - 1`.
951
- inline bool IsValidCapacity(size_t n) { return ((n + 1) & n) == 0 && n > 0; }
952
-
953
1058
  // Returns the next valid capacity after `n`.
954
1059
  inline size_t NextCapacity(size_t n) {
955
1060
  assert(IsValidCapacity(n) || n == 0);
@@ -1021,34 +1126,75 @@ size_t SelectBucketCountForIterRange(InputIter first, InputIter last,
1021
1126
  return 0;
1022
1127
  }
1023
1128
 
1024
- #define ABSL_INTERNAL_ASSERT_IS_FULL(ctrl, generation, generation_ptr, \
1025
- operation) \
1026
- do { \
1027
- ABSL_HARDENING_ASSERT( \
1028
- (ctrl != nullptr) && operation \
1029
- " called on invalid iterator. The iterator might be an end() " \
1030
- "iterator or may have been default constructed."); \
1031
- if (SwisstableGenerationsEnabled() && generation != *generation_ptr) \
1032
- ABSL_INTERNAL_LOG(FATAL, operation \
1033
- " called on invalidated iterator. The table could " \
1034
- "have rehashed since this iterator was initialized."); \
1035
- ABSL_HARDENING_ASSERT( \
1036
- (IsFull(*ctrl)) && operation \
1037
- " called on invalid iterator. The element might have been erased or " \
1038
- "the table might have rehashed."); \
1039
- } while (0)
1129
+ constexpr bool SwisstableDebugEnabled() {
1130
+ #if defined(ABSL_SWISSTABLE_ENABLE_GENERATIONS) || \
1131
+ ABSL_OPTION_HARDENED == 1 || !defined(NDEBUG)
1132
+ return true;
1133
+ #else
1134
+ return false;
1135
+ #endif
1136
+ }
1137
+
1138
+ inline void AssertIsFull(const ctrl_t* ctrl, GenerationType generation,
1139
+ const GenerationType* generation_ptr,
1140
+ const char* operation) {
1141
+ if (!SwisstableDebugEnabled()) return;
1142
+ if (ctrl == nullptr) {
1143
+ ABSL_INTERNAL_LOG(FATAL,
1144
+ std::string(operation) + " called on end() iterator.");
1145
+ }
1146
+ if (ctrl == EmptyGroup()) {
1147
+ ABSL_INTERNAL_LOG(FATAL, std::string(operation) +
1148
+ " called on default-constructed iterator.");
1149
+ }
1150
+ if (SwisstableGenerationsEnabled()) {
1151
+ if (generation != *generation_ptr) {
1152
+ ABSL_INTERNAL_LOG(FATAL,
1153
+ std::string(operation) +
1154
+ " called on invalid iterator. The table could have "
1155
+ "rehashed since this iterator was initialized.");
1156
+ }
1157
+ if (!IsFull(*ctrl)) {
1158
+ ABSL_INTERNAL_LOG(
1159
+ FATAL,
1160
+ std::string(operation) +
1161
+ " called on invalid iterator. The element was likely erased.");
1162
+ }
1163
+ } else {
1164
+ if (!IsFull(*ctrl)) {
1165
+ ABSL_INTERNAL_LOG(
1166
+ FATAL,
1167
+ std::string(operation) +
1168
+ " called on invalid iterator. The element might have been erased "
1169
+ "or the table might have rehashed. Consider running with "
1170
+ "--config=asan to diagnose rehashing issues.");
1171
+ }
1172
+ }
1173
+ }
1040
1174
 
1041
1175
  // Note that for comparisons, null/end iterators are valid.
1042
1176
  inline void AssertIsValidForComparison(const ctrl_t* ctrl,
1043
1177
  GenerationType generation,
1044
1178
  const GenerationType* generation_ptr) {
1045
- ABSL_HARDENING_ASSERT((ctrl == nullptr || IsFull(*ctrl)) &&
1046
- "Invalid iterator comparison. The element might have "
1047
- "been erased or the table might have rehashed.");
1048
- if (SwisstableGenerationsEnabled() && generation != *generation_ptr) {
1049
- ABSL_INTERNAL_LOG(FATAL,
1050
- "Invalid iterator comparison. The table could have "
1051
- "rehashed since this iterator was initialized.");
1179
+ if (!SwisstableDebugEnabled()) return;
1180
+ const bool ctrl_is_valid_for_comparison =
1181
+ ctrl == nullptr || ctrl == EmptyGroup() || IsFull(*ctrl);
1182
+ if (SwisstableGenerationsEnabled()) {
1183
+ if (generation != *generation_ptr) {
1184
+ ABSL_INTERNAL_LOG(FATAL,
1185
+ "Invalid iterator comparison. The table could have "
1186
+ "rehashed since this iterator was initialized.");
1187
+ }
1188
+ if (!ctrl_is_valid_for_comparison) {
1189
+ ABSL_INTERNAL_LOG(
1190
+ FATAL, "Invalid iterator comparison. The element was likely erased.");
1191
+ }
1192
+ } else {
1193
+ ABSL_HARDENING_ASSERT(
1194
+ ctrl_is_valid_for_comparison &&
1195
+ "Invalid iterator comparison. The element might have been erased or "
1196
+ "the table might have rehashed. Consider running with --config=asan to "
1197
+ "diagnose rehashing issues.");
1052
1198
  }
1053
1199
  }
1054
1200
 
@@ -1074,16 +1220,54 @@ inline bool AreItersFromSameContainer(const ctrl_t* ctrl_a,
1074
1220
  // Asserts that two iterators come from the same container.
1075
1221
  // Note: we take slots by reference so that it's not UB if they're uninitialized
1076
1222
  // as long as we don't read them (when ctrl is null).
1077
- // TODO(b/254649633): when generations are enabled, we can detect more cases of
1078
- // different containers by comparing the pointers to the generations - this
1079
- // can cover cases of end iterators that we would otherwise miss.
1080
1223
  inline void AssertSameContainer(const ctrl_t* ctrl_a, const ctrl_t* ctrl_b,
1081
1224
  const void* const& slot_a,
1082
- const void* const& slot_b) {
1083
- ABSL_HARDENING_ASSERT(
1084
- AreItersFromSameContainer(ctrl_a, ctrl_b, slot_a, slot_b) &&
1085
- "Invalid iterator comparison. The iterators may be from different "
1086
- "containers or the container might have rehashed.");
1225
+ const void* const& slot_b,
1226
+ const GenerationType* generation_ptr_a,
1227
+ const GenerationType* generation_ptr_b) {
1228
+ if (!SwisstableDebugEnabled()) return;
1229
+ const bool a_is_default = ctrl_a == EmptyGroup();
1230
+ const bool b_is_default = ctrl_b == EmptyGroup();
1231
+ if (a_is_default != b_is_default) {
1232
+ ABSL_INTERNAL_LOG(
1233
+ FATAL,
1234
+ "Invalid iterator comparison. Comparing default-constructed iterator "
1235
+ "with non-default-constructed iterator.");
1236
+ }
1237
+ if (a_is_default && b_is_default) return;
1238
+
1239
+ if (SwisstableGenerationsEnabled()) {
1240
+ if (generation_ptr_a == generation_ptr_b) return;
1241
+ const bool a_is_empty = IsEmptyGeneration(generation_ptr_a);
1242
+ const bool b_is_empty = IsEmptyGeneration(generation_ptr_b);
1243
+ if (a_is_empty != b_is_empty) {
1244
+ ABSL_INTERNAL_LOG(FATAL,
1245
+ "Invalid iterator comparison. Comparing iterator from "
1246
+ "a non-empty hashtable with an iterator from an empty "
1247
+ "hashtable.");
1248
+ }
1249
+ if (a_is_empty && b_is_empty) {
1250
+ ABSL_INTERNAL_LOG(FATAL,
1251
+ "Invalid iterator comparison. Comparing iterators from "
1252
+ "different empty hashtables.");
1253
+ }
1254
+ const bool a_is_end = ctrl_a == nullptr;
1255
+ const bool b_is_end = ctrl_b == nullptr;
1256
+ if (a_is_end || b_is_end) {
1257
+ ABSL_INTERNAL_LOG(FATAL,
1258
+ "Invalid iterator comparison. Comparing iterator with "
1259
+ "an end() iterator from a different hashtable.");
1260
+ }
1261
+ ABSL_INTERNAL_LOG(FATAL,
1262
+ "Invalid iterator comparison. Comparing non-end() "
1263
+ "iterators from different hashtables.");
1264
+ } else {
1265
+ ABSL_HARDENING_ASSERT(
1266
+ AreItersFromSameContainer(ctrl_a, ctrl_b, slot_a, slot_b) &&
1267
+ "Invalid iterator comparison. The iterators may be from different "
1268
+ "containers or the container might have rehashed. Consider running "
1269
+ "with --config=asan to diagnose rehashing issues.");
1270
+ }
1087
1271
  }
1088
1272
 
1089
1273
  struct FindInfo {
@@ -1106,11 +1290,13 @@ struct FindInfo {
1106
1290
  inline bool is_small(size_t capacity) { return capacity < Group::kWidth - 1; }
1107
1291
 
1108
1292
  // Begins a probing operation on `common.control`, using `hash`.
1109
- inline probe_seq<Group::kWidth> probe(const CommonFields& common, size_t hash) {
1110
- const ctrl_t* ctrl = common.control_;
1111
- const size_t capacity = common.capacity_;
1293
+ inline probe_seq<Group::kWidth> probe(const ctrl_t* ctrl, const size_t capacity,
1294
+ size_t hash) {
1112
1295
  return probe_seq<Group::kWidth>(H1(hash, ctrl), capacity);
1113
1296
  }
1297
+ inline probe_seq<Group::kWidth> probe(const CommonFields& common, size_t hash) {
1298
+ return probe(common.control(), common.capacity(), hash);
1299
+ }
1114
1300
 
1115
1301
  // Probes an array of control bits using a probe sequence derived from `hash`,
1116
1302
  // and returns the offset corresponding to the first deleted or empty slot.
@@ -1122,7 +1308,7 @@ inline probe_seq<Group::kWidth> probe(const CommonFields& common, size_t hash) {
1122
1308
  template <typename = void>
1123
1309
  inline FindInfo find_first_non_full(const CommonFields& common, size_t hash) {
1124
1310
  auto seq = probe(common, hash);
1125
- const ctrl_t* ctrl = common.control_;
1311
+ const ctrl_t* ctrl = common.control();
1126
1312
  while (true) {
1127
1313
  Group g{ctrl + seq.offset()};
1128
1314
  auto mask = g.MaskEmptyOrDeleted();
@@ -1132,14 +1318,14 @@ inline FindInfo find_first_non_full(const CommonFields& common, size_t hash) {
1132
1318
  // In debug build we will randomly insert in either the front or back of
1133
1319
  // the group.
1134
1320
  // TODO(kfm,sbenza): revisit after we do unconditional mixing
1135
- if (!is_small(common.capacity_) && ShouldInsertBackwards(hash, ctrl)) {
1321
+ if (!is_small(common.capacity()) && ShouldInsertBackwards(hash, ctrl)) {
1136
1322
  return {seq.offset(mask.HighestBitSet()), seq.index()};
1137
1323
  }
1138
1324
  #endif
1139
1325
  return {seq.offset(mask.LowestBitSet()), seq.index()};
1140
1326
  }
1141
1327
  seq.next();
1142
- assert(seq.index() <= common.capacity_ && "full table!");
1328
+ assert(seq.index() <= common.capacity() && "full table!");
1143
1329
  }
1144
1330
  }
1145
1331
 
@@ -1153,18 +1339,18 @@ extern template FindInfo find_first_non_full(const CommonFields&, size_t);
1153
1339
  FindInfo find_first_non_full_outofline(const CommonFields&, size_t);
1154
1340
 
1155
1341
  inline void ResetGrowthLeft(CommonFields& common) {
1156
- common.growth_left() = CapacityToGrowth(common.capacity_) - common.size_;
1342
+ common.set_growth_left(CapacityToGrowth(common.capacity()) - common.size());
1157
1343
  }
1158
1344
 
1159
1345
  // Sets `ctrl` to `{kEmpty, kSentinel, ..., kEmpty}`, marking the entire
1160
1346
  // array as marked as empty.
1161
1347
  inline void ResetCtrl(CommonFields& common, size_t slot_size) {
1162
- const size_t capacity = common.capacity_;
1163
- ctrl_t* ctrl = common.control_;
1348
+ const size_t capacity = common.capacity();
1349
+ ctrl_t* ctrl = common.control();
1164
1350
  std::memset(ctrl, static_cast<int8_t>(ctrl_t::kEmpty),
1165
1351
  capacity + 1 + NumClonedBytes());
1166
1352
  ctrl[capacity] = ctrl_t::kSentinel;
1167
- SanitizerPoisonMemoryRegion(common.slots_, slot_size * capacity);
1353
+ SanitizerPoisonMemoryRegion(common.slot_array(), slot_size * capacity);
1168
1354
  ResetGrowthLeft(common);
1169
1355
  }
1170
1356
 
@@ -1174,17 +1360,17 @@ inline void ResetCtrl(CommonFields& common, size_t slot_size) {
1174
1360
  // mirror the value to the cloned tail if necessary.
1175
1361
  inline void SetCtrl(const CommonFields& common, size_t i, ctrl_t h,
1176
1362
  size_t slot_size) {
1177
- const size_t capacity = common.capacity_;
1363
+ const size_t capacity = common.capacity();
1178
1364
  assert(i < capacity);
1179
1365
 
1180
- auto* slot_i = static_cast<const char*>(common.slots_) + i * slot_size;
1366
+ auto* slot_i = static_cast<const char*>(common.slot_array()) + i * slot_size;
1181
1367
  if (IsFull(h)) {
1182
1368
  SanitizerUnpoisonMemoryRegion(slot_i, slot_size);
1183
1369
  } else {
1184
1370
  SanitizerPoisonMemoryRegion(slot_i, slot_size);
1185
1371
  }
1186
1372
 
1187
- ctrl_t* ctrl = common.control_;
1373
+ ctrl_t* ctrl = common.control();
1188
1374
  ctrl[i] = h;
1189
1375
  ctrl[((i - NumClonedBytes()) & capacity) + (NumClonedBytes() & capacity)] = h;
1190
1376
  }
@@ -1195,56 +1381,41 @@ inline void SetCtrl(const CommonFields& common, size_t i, h2_t h,
1195
1381
  SetCtrl(common, i, static_cast<ctrl_t>(h), slot_size);
1196
1382
  }
1197
1383
 
1198
- // Given the capacity of a table, computes the offset (from the start of the
1199
- // backing allocation) of the generation counter (if it exists).
1200
- inline size_t GenerationOffset(size_t capacity) {
1201
- assert(IsValidCapacity(capacity));
1202
- const size_t num_control_bytes = capacity + 1 + NumClonedBytes();
1203
- return num_control_bytes;
1204
- }
1205
-
1206
- // Given the capacity of a table, computes the offset (from the start of the
1207
- // backing allocation) at which the slots begin.
1208
- inline size_t SlotOffset(size_t capacity, size_t slot_align) {
1209
- assert(IsValidCapacity(capacity));
1210
- const size_t num_control_bytes = capacity + 1 + NumClonedBytes();
1211
- return (num_control_bytes + NumGenerationBytes() + slot_align - 1) &
1212
- (~slot_align + 1);
1213
- }
1214
-
1215
- // Given the capacity of a table, computes the total size of the backing
1216
- // array.
1217
- inline size_t AllocSize(size_t capacity, size_t slot_size, size_t slot_align) {
1218
- return SlotOffset(capacity, slot_align) + capacity * slot_size;
1384
+ // growth_left (which is a size_t) is stored with the backing array.
1385
+ constexpr size_t BackingArrayAlignment(size_t align_of_slot) {
1386
+ return (std::max)(align_of_slot, alignof(size_t));
1219
1387
  }
1220
1388
 
1221
1389
  template <typename Alloc, size_t SizeOfSlot, size_t AlignOfSlot>
1222
1390
  ABSL_ATTRIBUTE_NOINLINE void InitializeSlots(CommonFields& c, Alloc alloc) {
1223
- assert(c.capacity_);
1391
+ assert(c.capacity());
1224
1392
  // Folks with custom allocators often make unwarranted assumptions about the
1225
1393
  // behavior of their classes vis-a-vis trivial destructability and what
1226
1394
  // calls they will or won't make. Avoid sampling for people with custom
1227
1395
  // allocators to get us out of this mess. This is not a hard guarantee but
1228
1396
  // a workaround while we plan the exact guarantee we want to provide.
1229
1397
  const size_t sample_size =
1230
- (std::is_same<Alloc, std::allocator<char>>::value && c.slots_ == nullptr)
1398
+ (std::is_same<Alloc, std::allocator<char>>::value &&
1399
+ c.slot_array() == nullptr)
1231
1400
  ? SizeOfSlot
1232
1401
  : 0;
1233
1402
 
1234
- const size_t cap = c.capacity_;
1403
+ const size_t cap = c.capacity();
1404
+ const size_t alloc_size = AllocSize(cap, SizeOfSlot, AlignOfSlot);
1405
+ // growth_left (which is a size_t) is stored with the backing array.
1235
1406
  char* mem = static_cast<char*>(
1236
- Allocate<AlignOfSlot>(&alloc, AllocSize(cap, SizeOfSlot, AlignOfSlot)));
1407
+ Allocate<BackingArrayAlignment(AlignOfSlot)>(&alloc, alloc_size));
1237
1408
  const GenerationType old_generation = c.generation();
1238
1409
  c.set_generation_ptr(
1239
1410
  reinterpret_cast<GenerationType*>(mem + GenerationOffset(cap)));
1240
- c.set_generation(old_generation + 1);
1241
- c.control_ = reinterpret_cast<ctrl_t*>(mem);
1242
- c.slots_ = mem + SlotOffset(cap, AlignOfSlot);
1411
+ c.set_generation(NextGeneration(old_generation));
1412
+ c.set_control(reinterpret_cast<ctrl_t*>(mem + ControlOffset()));
1413
+ c.set_slots(mem + SlotOffset(cap, AlignOfSlot));
1243
1414
  ResetCtrl(c, SizeOfSlot);
1244
1415
  if (sample_size) {
1245
1416
  c.infoz() = Sample(sample_size);
1246
1417
  }
1247
- c.infoz().RecordStorageChanged(c.size_, cap);
1418
+ c.infoz().RecordStorageChanged(c.size(), cap);
1248
1419
  }
1249
1420
 
1250
1421
  // PolicyFunctions bundles together some information for a particular
@@ -1254,15 +1425,14 @@ ABSL_ATTRIBUTE_NOINLINE void InitializeSlots(CommonFields& c, Alloc alloc) {
1254
1425
  struct PolicyFunctions {
1255
1426
  size_t slot_size;
1256
1427
 
1257
- // Return the hash of the pointed-to slot.
1428
+ // Returns the hash of the pointed-to slot.
1258
1429
  size_t (*hash_slot)(void* set, void* slot);
1259
1430
 
1260
1431
  // Transfer the contents of src_slot to dst_slot.
1261
1432
  void (*transfer)(void* set, void* dst_slot, void* src_slot);
1262
1433
 
1263
- // Deallocate the specified backing store which is sized for n slots.
1264
- void (*dealloc)(void* set, const PolicyFunctions& policy, ctrl_t* ctrl,
1265
- void* slot_array, size_t n);
1434
+ // Deallocate the backing store from common.
1435
+ void (*dealloc)(CommonFields& common, const PolicyFunctions& policy);
1266
1436
  };
1267
1437
 
1268
1438
  // ClearBackingArray clears the backing array, either modifying it in place,
@@ -1279,16 +1449,16 @@ void EraseMetaOnly(CommonFields& c, ctrl_t* it, size_t slot_size);
1279
1449
  // function body for raw_hash_set instantiations that have the
1280
1450
  // same slot alignment.
1281
1451
  template <size_t AlignOfSlot>
1282
- ABSL_ATTRIBUTE_NOINLINE void DeallocateStandard(void*,
1283
- const PolicyFunctions& policy,
1284
- ctrl_t* ctrl, void* slot_array,
1285
- size_t n) {
1452
+ ABSL_ATTRIBUTE_NOINLINE void DeallocateStandard(CommonFields& common,
1453
+ const PolicyFunctions& policy) {
1286
1454
  // Unpoison before returning the memory to the allocator.
1287
- SanitizerUnpoisonMemoryRegion(slot_array, policy.slot_size * n);
1455
+ SanitizerUnpoisonMemoryRegion(common.slot_array(),
1456
+ policy.slot_size * common.capacity());
1288
1457
 
1289
1458
  std::allocator<char> alloc;
1290
- Deallocate<AlignOfSlot>(&alloc, ctrl,
1291
- AllocSize(n, policy.slot_size, AlignOfSlot));
1459
+ Deallocate<BackingArrayAlignment(AlignOfSlot)>(
1460
+ &alloc, common.backing_array_start(),
1461
+ common.alloc_size(policy.slot_size, AlignOfSlot));
1292
1462
  }
1293
1463
 
1294
1464
  // For trivially relocatable types we use memcpy directly. This allows us to
@@ -1419,22 +1589,19 @@ class raw_hash_set {
1419
1589
 
1420
1590
  // PRECONDITION: not an end() iterator.
1421
1591
  reference operator*() const {
1422
- ABSL_INTERNAL_ASSERT_IS_FULL(ctrl_, generation(), generation_ptr(),
1423
- "operator*()");
1592
+ AssertIsFull(ctrl_, generation(), generation_ptr(), "operator*()");
1424
1593
  return PolicyTraits::element(slot_);
1425
1594
  }
1426
1595
 
1427
1596
  // PRECONDITION: not an end() iterator.
1428
1597
  pointer operator->() const {
1429
- ABSL_INTERNAL_ASSERT_IS_FULL(ctrl_, generation(), generation_ptr(),
1430
- "operator->");
1598
+ AssertIsFull(ctrl_, generation(), generation_ptr(), "operator->");
1431
1599
  return &operator*();
1432
1600
  }
1433
1601
 
1434
1602
  // PRECONDITION: not an end() iterator.
1435
1603
  iterator& operator++() {
1436
- ABSL_INTERNAL_ASSERT_IS_FULL(ctrl_, generation(), generation_ptr(),
1437
- "operator++");
1604
+ AssertIsFull(ctrl_, generation(), generation_ptr(), "operator++");
1438
1605
  ++ctrl_;
1439
1606
  ++slot_;
1440
1607
  skip_empty_or_deleted();
@@ -1448,9 +1615,10 @@ class raw_hash_set {
1448
1615
  }
1449
1616
 
1450
1617
  friend bool operator==(const iterator& a, const iterator& b) {
1451
- AssertSameContainer(a.ctrl_, b.ctrl_, a.slot_, b.slot_);
1452
1618
  AssertIsValidForComparison(a.ctrl_, a.generation(), a.generation_ptr());
1453
1619
  AssertIsValidForComparison(b.ctrl_, b.generation(), b.generation_ptr());
1620
+ AssertSameContainer(a.ctrl_, b.ctrl_, a.slot_, b.slot_,
1621
+ a.generation_ptr(), b.generation_ptr());
1454
1622
  return a.ctrl_ == b.ctrl_;
1455
1623
  }
1456
1624
  friend bool operator!=(const iterator& a, const iterator& b) {
@@ -1469,7 +1637,7 @@ class raw_hash_set {
1469
1637
  }
1470
1638
  // For end() iterators.
1471
1639
  explicit iterator(const GenerationType* generation_ptr)
1472
- : HashSetIteratorGenerationInfo(generation_ptr) {}
1640
+ : HashSetIteratorGenerationInfo(generation_ptr), ctrl_(nullptr) {}
1473
1641
 
1474
1642
  // Fixes up `ctrl_` to point to a full by advancing it and `slot_` until
1475
1643
  // they reach one.
@@ -1484,7 +1652,9 @@ class raw_hash_set {
1484
1652
  if (ABSL_PREDICT_FALSE(*ctrl_ == ctrl_t::kSentinel)) ctrl_ = nullptr;
1485
1653
  }
1486
1654
 
1487
- ctrl_t* ctrl_ = nullptr;
1655
+ // We use EmptyGroup() for default-constructed iterators so that they can
1656
+ // be distinguished from end iterators, which have nullptr ctrl_.
1657
+ ctrl_t* ctrl_ = EmptyGroup();
1488
1658
  // To avoid uninitialized member warnings, put slot_ in an anonymous union.
1489
1659
  // The member is not initialized on singleton and end iterators.
1490
1660
  union {
@@ -1537,9 +1707,9 @@ class raw_hash_set {
1537
1707
  // Note: can't use `= default` due to non-default noexcept (causes
1538
1708
  // problems for some compilers). NOLINTNEXTLINE
1539
1709
  raw_hash_set() noexcept(
1540
- std::is_nothrow_default_constructible<hasher>::value&&
1541
- std::is_nothrow_default_constructible<key_equal>::value&&
1542
- std::is_nothrow_default_constructible<allocator_type>::value) {}
1710
+ std::is_nothrow_default_constructible<hasher>::value &&
1711
+ std::is_nothrow_default_constructible<key_equal>::value &&
1712
+ std::is_nothrow_default_constructible<allocator_type>::value) {}
1543
1713
 
1544
1714
  ABSL_ATTRIBUTE_NOINLINE explicit raw_hash_set(
1545
1715
  size_t bucket_count, const hasher& hash = hasher(),
@@ -1547,7 +1717,7 @@ class raw_hash_set {
1547
1717
  const allocator_type& alloc = allocator_type())
1548
1718
  : settings_(CommonFields{}, hash, eq, alloc) {
1549
1719
  if (bucket_count) {
1550
- common().capacity_ = NormalizeCapacity(bucket_count);
1720
+ common().set_capacity(NormalizeCapacity(bucket_count));
1551
1721
  initialize_slots();
1552
1722
  }
1553
1723
  }
@@ -1649,7 +1819,9 @@ class raw_hash_set {
1649
1819
 
1650
1820
  raw_hash_set(const raw_hash_set& that, const allocator_type& a)
1651
1821
  : raw_hash_set(0, that.hash_ref(), that.eq_ref(), a) {
1652
- reserve(that.size());
1822
+ const size_t size = that.size();
1823
+ if (size == 0) return;
1824
+ reserve(size);
1653
1825
  // Because the table is guaranteed to be empty, we can do something faster
1654
1826
  // than a full `insert`.
1655
1827
  for (const auto& v : that) {
@@ -1660,14 +1832,14 @@ class raw_hash_set {
1660
1832
  common().maybe_increment_generation_on_insert();
1661
1833
  infoz().RecordInsert(hash, target.probe_length);
1662
1834
  }
1663
- common().size_ = that.size();
1664
- growth_left() -= that.size();
1835
+ common().set_size(size);
1836
+ set_growth_left(growth_left() - size);
1665
1837
  }
1666
1838
 
1667
1839
  ABSL_ATTRIBUTE_NOINLINE raw_hash_set(raw_hash_set&& that) noexcept(
1668
- std::is_nothrow_copy_constructible<hasher>::value&&
1669
- std::is_nothrow_copy_constructible<key_equal>::value&&
1670
- std::is_nothrow_copy_constructible<allocator_type>::value)
1840
+ std::is_nothrow_copy_constructible<hasher>::value &&
1841
+ std::is_nothrow_copy_constructible<key_equal>::value &&
1842
+ std::is_nothrow_copy_constructible<allocator_type>::value)
1671
1843
  : // Hash, equality and allocator are copied instead of moved because
1672
1844
  // `that` must be left valid. If Hash is std::function<Key>, moving it
1673
1845
  // would create a nullptr functor that cannot be called.
@@ -1696,9 +1868,9 @@ class raw_hash_set {
1696
1868
  }
1697
1869
 
1698
1870
  raw_hash_set& operator=(raw_hash_set&& that) noexcept(
1699
- absl::allocator_traits<allocator_type>::is_always_equal::value&&
1700
- std::is_nothrow_move_assignable<hasher>::value&&
1701
- std::is_nothrow_move_assignable<key_equal>::value) {
1871
+ absl::allocator_traits<allocator_type>::is_always_equal::value &&
1872
+ std::is_nothrow_move_assignable<hasher>::value &&
1873
+ std::is_nothrow_move_assignable<key_equal>::value) {
1702
1874
  // TODO(sbenza): We should only use the operations from the noexcept clause
1703
1875
  // to make sure we actually adhere to that contract.
1704
1876
  // NOLINTNEXTLINE: not returning *this for performance.
@@ -1714,30 +1886,36 @@ class raw_hash_set {
1714
1886
 
1715
1887
  // Unpoison before returning the memory to the allocator.
1716
1888
  SanitizerUnpoisonMemoryRegion(slot_array(), sizeof(slot_type) * cap);
1717
- Deallocate<alignof(slot_type)>(
1718
- &alloc_ref(), control(),
1889
+ Deallocate<BackingArrayAlignment(alignof(slot_type))>(
1890
+ &alloc_ref(), common().backing_array_start(),
1719
1891
  AllocSize(cap, sizeof(slot_type), alignof(slot_type)));
1720
1892
 
1721
1893
  infoz().Unregister();
1722
1894
  }
1723
1895
 
1724
- iterator begin() {
1896
+ iterator begin() ABSL_ATTRIBUTE_LIFETIME_BOUND {
1725
1897
  auto it = iterator_at(0);
1726
1898
  it.skip_empty_or_deleted();
1727
1899
  return it;
1728
1900
  }
1729
- iterator end() { return iterator(common().generation_ptr()); }
1901
+ iterator end() ABSL_ATTRIBUTE_LIFETIME_BOUND {
1902
+ return iterator(common().generation_ptr());
1903
+ }
1730
1904
 
1731
- const_iterator begin() const {
1905
+ const_iterator begin() const ABSL_ATTRIBUTE_LIFETIME_BOUND {
1732
1906
  return const_cast<raw_hash_set*>(this)->begin();
1733
1907
  }
1734
- const_iterator end() const { return iterator(common().generation_ptr()); }
1735
- const_iterator cbegin() const { return begin(); }
1736
- const_iterator cend() const { return end(); }
1908
+ const_iterator end() const ABSL_ATTRIBUTE_LIFETIME_BOUND {
1909
+ return iterator(common().generation_ptr());
1910
+ }
1911
+ const_iterator cbegin() const ABSL_ATTRIBUTE_LIFETIME_BOUND {
1912
+ return begin();
1913
+ }
1914
+ const_iterator cend() const ABSL_ATTRIBUTE_LIFETIME_BOUND { return end(); }
1737
1915
 
1738
1916
  bool empty() const { return !size(); }
1739
- size_t size() const { return common().size_; }
1740
- size_t capacity() const { return common().capacity_; }
1917
+ size_t size() const { return common().size(); }
1918
+ size_t capacity() const { return common().capacity(); }
1741
1919
  size_t max_size() const { return (std::numeric_limits<size_t>::max)(); }
1742
1920
 
1743
1921
  ABSL_ATTRIBUTE_REINITIALIZES void clear() {
@@ -1753,10 +1931,10 @@ class raw_hash_set {
1753
1931
  // Already guaranteed to be empty; so nothing to do.
1754
1932
  } else {
1755
1933
  destroy_slots();
1756
- ClearBackingArray(common(), GetPolicyFunctions(),
1757
- /*reuse=*/cap < 128);
1934
+ ClearBackingArray(common(), GetPolicyFunctions(), /*reuse=*/cap < 128);
1758
1935
  }
1759
1936
  common().set_reserved_growth(0);
1937
+ common().set_reservation_size(0);
1760
1938
  }
1761
1939
 
1762
1940
  inline void destroy_slots() {
@@ -1780,7 +1958,7 @@ class raw_hash_set {
1780
1958
  template <class T, RequiresInsertable<T> = 0, class T2 = T,
1781
1959
  typename std::enable_if<IsDecomposable<T2>::value, int>::type = 0,
1782
1960
  T* = nullptr>
1783
- std::pair<iterator, bool> insert(T&& value) {
1961
+ std::pair<iterator, bool> insert(T&& value) ABSL_ATTRIBUTE_LIFETIME_BOUND {
1784
1962
  return emplace(std::forward<T>(value));
1785
1963
  }
1786
1964
 
@@ -1795,13 +1973,11 @@ class raw_hash_set {
1795
1973
  // const char* p = "hello";
1796
1974
  // s.insert(p);
1797
1975
  //
1798
- // TODO(romanp): Once we stop supporting gcc 5.1 and below, replace
1799
- // RequiresInsertable<T> with RequiresInsertable<const T&>.
1800
- // We are hitting this bug: https://godbolt.org/g/1Vht4f.
1801
1976
  template <
1802
- class T, RequiresInsertable<T> = 0,
1977
+ class T, RequiresInsertable<const T&> = 0,
1803
1978
  typename std::enable_if<IsDecomposable<const T&>::value, int>::type = 0>
1804
- std::pair<iterator, bool> insert(const T& value) {
1979
+ std::pair<iterator, bool> insert(const T& value)
1980
+ ABSL_ATTRIBUTE_LIFETIME_BOUND {
1805
1981
  return emplace(value);
1806
1982
  }
1807
1983
 
@@ -1810,7 +1986,8 @@ class raw_hash_set {
1810
1986
  //
1811
1987
  // flat_hash_map<std::string, int> s;
1812
1988
  // s.insert({"abc", 42});
1813
- std::pair<iterator, bool> insert(init_type&& value) {
1989
+ std::pair<iterator, bool> insert(init_type&& value)
1990
+ ABSL_ATTRIBUTE_LIFETIME_BOUND {
1814
1991
  return emplace(std::move(value));
1815
1992
  }
1816
1993
 
@@ -1819,21 +1996,20 @@ class raw_hash_set {
1819
1996
  template <class T, RequiresInsertable<T> = 0, class T2 = T,
1820
1997
  typename std::enable_if<IsDecomposable<T2>::value, int>::type = 0,
1821
1998
  T* = nullptr>
1822
- iterator insert(const_iterator, T&& value) {
1999
+ iterator insert(const_iterator, T&& value) ABSL_ATTRIBUTE_LIFETIME_BOUND {
1823
2000
  return insert(std::forward<T>(value)).first;
1824
2001
  }
1825
2002
 
1826
- // TODO(romanp): Once we stop supporting gcc 5.1 and below, replace
1827
- // RequiresInsertable<T> with RequiresInsertable<const T&>.
1828
- // We are hitting this bug: https://godbolt.org/g/1Vht4f.
1829
2003
  template <
1830
- class T, RequiresInsertable<T> = 0,
2004
+ class T, RequiresInsertable<const T&> = 0,
1831
2005
  typename std::enable_if<IsDecomposable<const T&>::value, int>::type = 0>
1832
- iterator insert(const_iterator, const T& value) {
2006
+ iterator insert(const_iterator,
2007
+ const T& value) ABSL_ATTRIBUTE_LIFETIME_BOUND {
1833
2008
  return insert(value).first;
1834
2009
  }
1835
2010
 
1836
- iterator insert(const_iterator, init_type&& value) {
2011
+ iterator insert(const_iterator,
2012
+ init_type&& value) ABSL_ATTRIBUTE_LIFETIME_BOUND {
1837
2013
  return insert(std::move(value)).first;
1838
2014
  }
1839
2015
 
@@ -1851,7 +2027,7 @@ class raw_hash_set {
1851
2027
  insert(ilist.begin(), ilist.end());
1852
2028
  }
1853
2029
 
1854
- insert_return_type insert(node_type&& node) {
2030
+ insert_return_type insert(node_type&& node) ABSL_ATTRIBUTE_LIFETIME_BOUND {
1855
2031
  if (!node) return {end(), false, node_type()};
1856
2032
  const auto& elem = PolicyTraits::element(CommonAccess::GetSlot(node));
1857
2033
  auto res = PolicyTraits::apply(
@@ -1865,7 +2041,8 @@ class raw_hash_set {
1865
2041
  }
1866
2042
  }
1867
2043
 
1868
- iterator insert(const_iterator, node_type&& node) {
2044
+ iterator insert(const_iterator,
2045
+ node_type&& node) ABSL_ATTRIBUTE_LIFETIME_BOUND {
1869
2046
  auto res = insert(std::move(node));
1870
2047
  node = std::move(res.node);
1871
2048
  return res.position;
@@ -1882,7 +2059,8 @@ class raw_hash_set {
1882
2059
  // m.emplace("abc", "xyz");
1883
2060
  template <class... Args, typename std::enable_if<
1884
2061
  IsDecomposable<Args...>::value, int>::type = 0>
1885
- std::pair<iterator, bool> emplace(Args&&... args) {
2062
+ std::pair<iterator, bool> emplace(Args&&... args)
2063
+ ABSL_ATTRIBUTE_LIFETIME_BOUND {
1886
2064
  return PolicyTraits::apply(EmplaceDecomposable{*this},
1887
2065
  std::forward<Args>(args)...);
1888
2066
  }
@@ -1892,7 +2070,8 @@ class raw_hash_set {
1892
2070
  // destroys.
1893
2071
  template <class... Args, typename std::enable_if<
1894
2072
  !IsDecomposable<Args...>::value, int>::type = 0>
1895
- std::pair<iterator, bool> emplace(Args&&... args) {
2073
+ std::pair<iterator, bool> emplace(Args&&... args)
2074
+ ABSL_ATTRIBUTE_LIFETIME_BOUND {
1896
2075
  alignas(slot_type) unsigned char raw[sizeof(slot_type)];
1897
2076
  slot_type* slot = reinterpret_cast<slot_type*>(&raw);
1898
2077
 
@@ -1902,14 +2081,16 @@ class raw_hash_set {
1902
2081
  }
1903
2082
 
1904
2083
  template <class... Args>
1905
- iterator emplace_hint(const_iterator, Args&&... args) {
2084
+ iterator emplace_hint(const_iterator,
2085
+ Args&&... args) ABSL_ATTRIBUTE_LIFETIME_BOUND {
1906
2086
  return emplace(std::forward<Args>(args)...).first;
1907
2087
  }
1908
2088
 
1909
2089
  // Extension API: support for lazy emplace.
1910
2090
  //
1911
2091
  // Looks up key in the table. If found, returns the iterator to the element.
1912
- // Otherwise calls `f` with one argument of type `raw_hash_set::constructor`.
2092
+ // Otherwise calls `f` with one argument of type `raw_hash_set::constructor`,
2093
+ // and returns an iterator to the new element.
1913
2094
  //
1914
2095
  // `f` must abide by several restrictions:
1915
2096
  // - it MUST call `raw_hash_set::constructor` with arguments as if a
@@ -1952,7 +2133,8 @@ class raw_hash_set {
1952
2133
  };
1953
2134
 
1954
2135
  template <class K = key_type, class F>
1955
- iterator lazy_emplace(const key_arg<K>& key, F&& f) {
2136
+ iterator lazy_emplace(const key_arg<K>& key,
2137
+ F&& f) ABSL_ATTRIBUTE_LIFETIME_BOUND {
1956
2138
  auto res = find_or_prepare_insert(key);
1957
2139
  if (res.second) {
1958
2140
  slot_type* slot = slot_array() + res.first;
@@ -1997,13 +2179,25 @@ class raw_hash_set {
1997
2179
  // This overload is necessary because otherwise erase<K>(const K&) would be
1998
2180
  // a better match if non-const iterator is passed as an argument.
1999
2181
  void erase(iterator it) {
2000
- ABSL_INTERNAL_ASSERT_IS_FULL(it.ctrl_, it.generation(), it.generation_ptr(),
2001
- "erase()");
2182
+ AssertIsFull(it.ctrl_, it.generation(), it.generation_ptr(), "erase()");
2002
2183
  PolicyTraits::destroy(&alloc_ref(), it.slot_);
2003
2184
  erase_meta_only(it);
2004
2185
  }
2005
2186
 
2006
- iterator erase(const_iterator first, const_iterator last) {
2187
+ iterator erase(const_iterator first,
2188
+ const_iterator last) ABSL_ATTRIBUTE_LIFETIME_BOUND {
2189
+ // We check for empty first because ClearBackingArray requires that
2190
+ // capacity() > 0 as a precondition.
2191
+ if (empty()) return end();
2192
+ if (first == begin() && last == end()) {
2193
+ // TODO(ezb): we access control bytes in destroy_slots so it could make
2194
+ // sense to combine destroy_slots and ClearBackingArray to avoid cache
2195
+ // misses when the table is large. Note that we also do this in clear().
2196
+ destroy_slots();
2197
+ ClearBackingArray(common(), GetPolicyFunctions(), /*reuse=*/true);
2198
+ common().set_reserved_growth(common().reservation_size());
2199
+ return end();
2200
+ }
2007
2201
  while (first != last) {
2008
2202
  erase(first++);
2009
2203
  }
@@ -2032,9 +2226,8 @@ class raw_hash_set {
2032
2226
  }
2033
2227
 
2034
2228
  node_type extract(const_iterator position) {
2035
- ABSL_INTERNAL_ASSERT_IS_FULL(position.inner_.ctrl_,
2036
- position.inner_.generation(),
2037
- position.inner_.generation_ptr(), "extract()");
2229
+ AssertIsFull(position.inner_.ctrl_, position.inner_.generation(),
2230
+ position.inner_.generation_ptr(), "extract()");
2038
2231
  auto node =
2039
2232
  CommonAccess::Transfer<node_type>(alloc_ref(), position.inner_.slot_);
2040
2233
  erase_meta_only(position);
@@ -2064,8 +2257,7 @@ class raw_hash_set {
2064
2257
  void rehash(size_t n) {
2065
2258
  if (n == 0 && capacity() == 0) return;
2066
2259
  if (n == 0 && size() == 0) {
2067
- ClearBackingArray(common(), GetPolicyFunctions(),
2068
- /*reuse=*/false);
2260
+ ClearBackingArray(common(), GetPolicyFunctions(), /*reuse=*/false);
2069
2261
  return;
2070
2262
  }
2071
2263
 
@@ -2092,6 +2284,7 @@ class raw_hash_set {
2092
2284
  infoz().RecordReservation(n);
2093
2285
  }
2094
2286
  common().reset_reserved_growth(n);
2287
+ common().set_reservation_size(n);
2095
2288
  }
2096
2289
 
2097
2290
  // Extension API: support for heterogeneous keys.
@@ -2117,12 +2310,12 @@ class raw_hash_set {
2117
2310
  void prefetch(const key_arg<K>& key) const {
2118
2311
  (void)key;
2119
2312
  // Avoid probing if we won't be able to prefetch the addresses received.
2120
- #ifdef ABSL_INTERNAL_HAVE_PREFETCH
2313
+ #ifdef ABSL_HAVE_PREFETCH
2121
2314
  prefetch_heap_block();
2122
2315
  auto seq = probe(common(), hash_ref()(key));
2123
- base_internal::PrefetchT0(control() + seq.offset());
2124
- base_internal::PrefetchT0(slot_array() + seq.offset());
2125
- #endif // ABSL_INTERNAL_HAVE_PREFETCH
2316
+ PrefetchToLocalCache(control() + seq.offset());
2317
+ PrefetchToLocalCache(slot_array() + seq.offset());
2318
+ #endif // ABSL_HAVE_PREFETCH
2126
2319
  }
2127
2320
 
2128
2321
  // The API of find() has two extensions.
@@ -2133,7 +2326,8 @@ class raw_hash_set {
2133
2326
  // 2. The type of the key argument doesn't have to be key_type. This is so
2134
2327
  // called heterogeneous key support.
2135
2328
  template <class K = key_type>
2136
- iterator find(const key_arg<K>& key, size_t hash) {
2329
+ iterator find(const key_arg<K>& key,
2330
+ size_t hash) ABSL_ATTRIBUTE_LIFETIME_BOUND {
2137
2331
  auto seq = probe(common(), hash);
2138
2332
  slot_type* slot_ptr = slot_array();
2139
2333
  const ctrl_t* ctrl = control();
@@ -2151,17 +2345,19 @@ class raw_hash_set {
2151
2345
  }
2152
2346
  }
2153
2347
  template <class K = key_type>
2154
- iterator find(const key_arg<K>& key) {
2348
+ iterator find(const key_arg<K>& key) ABSL_ATTRIBUTE_LIFETIME_BOUND {
2155
2349
  prefetch_heap_block();
2156
2350
  return find(key, hash_ref()(key));
2157
2351
  }
2158
2352
 
2159
2353
  template <class K = key_type>
2160
- const_iterator find(const key_arg<K>& key, size_t hash) const {
2354
+ const_iterator find(const key_arg<K>& key,
2355
+ size_t hash) const ABSL_ATTRIBUTE_LIFETIME_BOUND {
2161
2356
  return const_cast<raw_hash_set*>(this)->find(key, hash);
2162
2357
  }
2163
2358
  template <class K = key_type>
2164
- const_iterator find(const key_arg<K>& key) const {
2359
+ const_iterator find(const key_arg<K>& key) const
2360
+ ABSL_ATTRIBUTE_LIFETIME_BOUND {
2165
2361
  prefetch_heap_block();
2166
2362
  return find(key, hash_ref()(key));
2167
2363
  }
@@ -2172,14 +2368,15 @@ class raw_hash_set {
2172
2368
  }
2173
2369
 
2174
2370
  template <class K = key_type>
2175
- std::pair<iterator, iterator> equal_range(const key_arg<K>& key) {
2371
+ std::pair<iterator, iterator> equal_range(const key_arg<K>& key)
2372
+ ABSL_ATTRIBUTE_LIFETIME_BOUND {
2176
2373
  auto it = find(key);
2177
2374
  if (it != end()) return {it, std::next(it)};
2178
2375
  return {it, it};
2179
2376
  }
2180
2377
  template <class K = key_type>
2181
2378
  std::pair<const_iterator, const_iterator> equal_range(
2182
- const key_arg<K>& key) const {
2379
+ const key_arg<K>& key) const ABSL_ATTRIBUTE_LIFETIME_BOUND {
2183
2380
  auto it = find(key);
2184
2381
  if (it != end()) return {it, std::next(it)};
2185
2382
  return {it, it};
@@ -2313,8 +2510,8 @@ class raw_hash_set {
2313
2510
  assert(IsValidCapacity(new_capacity));
2314
2511
  auto* old_ctrl = control();
2315
2512
  auto* old_slots = slot_array();
2316
- const size_t old_capacity = common().capacity_;
2317
- common().capacity_ = new_capacity;
2513
+ const size_t old_capacity = common().capacity();
2514
+ common().set_capacity(new_capacity);
2318
2515
  initialize_slots();
2319
2516
 
2320
2517
  auto* new_slots = slot_array();
@@ -2333,8 +2530,8 @@ class raw_hash_set {
2333
2530
  if (old_capacity) {
2334
2531
  SanitizerUnpoisonMemoryRegion(old_slots,
2335
2532
  sizeof(slot_type) * old_capacity);
2336
- Deallocate<alignof(slot_type)>(
2337
- &alloc_ref(), old_ctrl,
2533
+ Deallocate<BackingArrayAlignment(alignof(slot_type))>(
2534
+ &alloc_ref(), old_ctrl - ControlOffset(),
2338
2535
  AllocSize(old_capacity, sizeof(slot_type), alignof(slot_type)));
2339
2536
  }
2340
2537
  infoz().RecordRehash(total_probe_length);
@@ -2357,8 +2554,8 @@ class raw_hash_set {
2357
2554
  void rehash_and_grow_if_necessary() {
2358
2555
  const size_t cap = capacity();
2359
2556
  if (cap > Group::kWidth &&
2360
- // Do these calcuations in 64-bit to avoid overflow.
2361
- size() * uint64_t{32} <= cap* uint64_t{25}) {
2557
+ // Do these calculations in 64-bit to avoid overflow.
2558
+ size() * uint64_t{32} <= cap * uint64_t{25}) {
2362
2559
  // Squash DELETED without growing if there is enough capacity.
2363
2560
  //
2364
2561
  // Rehash in place if the current size is <= 25/32 of capacity.
@@ -2481,8 +2678,8 @@ class raw_hash_set {
2481
2678
  rehash_and_grow_if_necessary();
2482
2679
  target = find_first_non_full(common(), hash);
2483
2680
  }
2484
- ++common().size_;
2485
- growth_left() -= IsEmpty(control()[target.offset]);
2681
+ common().set_size(common().size() + 1);
2682
+ set_growth_left(growth_left() - IsEmpty(control()[target.offset]));
2486
2683
  SetCtrl(common(), target.offset, H2(hash), sizeof(slot_type));
2487
2684
  common().maybe_increment_generation_on_insert();
2488
2685
  infoz().RecordInsert(hash, target.probe_length);
@@ -2507,10 +2704,10 @@ class raw_hash_set {
2507
2704
  "constructed value does not match the lookup key");
2508
2705
  }
2509
2706
 
2510
- iterator iterator_at(size_t i) {
2707
+ iterator iterator_at(size_t i) ABSL_ATTRIBUTE_LIFETIME_BOUND {
2511
2708
  return {control() + i, slot_array() + i, common().generation_ptr()};
2512
2709
  }
2513
- const_iterator iterator_at(size_t i) const {
2710
+ const_iterator iterator_at(size_t i) const ABSL_ATTRIBUTE_LIFETIME_BOUND {
2514
2711
  return {control() + i, slot_array() + i, common().generation_ptr()};
2515
2712
  }
2516
2713
 
@@ -2527,19 +2724,24 @@ class raw_hash_set {
2527
2724
  // side-effect.
2528
2725
  //
2529
2726
  // See `CapacityToGrowth()`.
2530
- size_t& growth_left() { return common().growth_left(); }
2531
-
2532
- // Prefetch the heap-allocated memory region to resolve potential TLB misses.
2533
- // This is intended to overlap with execution of calculating the hash for a
2534
- // key.
2535
- void prefetch_heap_block() const { base_internal::PrefetchT2(control()); }
2727
+ size_t growth_left() const { return common().growth_left(); }
2728
+ void set_growth_left(size_t gl) { return common().set_growth_left(gl); }
2729
+
2730
+ // Prefetch the heap-allocated memory region to resolve potential TLB and
2731
+ // cache misses. This is intended to overlap with execution of calculating the
2732
+ // hash for a key.
2733
+ void prefetch_heap_block() const {
2734
+ #if ABSL_HAVE_BUILTIN(__builtin_prefetch) || defined(__GNUC__)
2735
+ __builtin_prefetch(control(), 0, 1);
2736
+ #endif
2737
+ }
2536
2738
 
2537
2739
  CommonFields& common() { return settings_.template get<0>(); }
2538
2740
  const CommonFields& common() const { return settings_.template get<0>(); }
2539
2741
 
2540
- ctrl_t* control() const { return common().control_; }
2742
+ ctrl_t* control() const { return common().control(); }
2541
2743
  slot_type* slot_array() const {
2542
- return static_cast<slot_type*>(common().slots_);
2744
+ return static_cast<slot_type*>(common().slot_array());
2543
2745
  }
2544
2746
  HashtablezInfoHandle& infoz() { return common().infoz(); }
2545
2747
 
@@ -2565,16 +2767,16 @@ class raw_hash_set {
2565
2767
  static_cast<slot_type*>(src));
2566
2768
  }
2567
2769
  // Note: dealloc_fn will only be used if we have a non-standard allocator.
2568
- static void dealloc_fn(void* set, const PolicyFunctions&, ctrl_t* ctrl,
2569
- void* slot_mem, size_t n) {
2570
- auto* h = static_cast<raw_hash_set*>(set);
2770
+ static void dealloc_fn(CommonFields& common, const PolicyFunctions&) {
2771
+ auto* set = reinterpret_cast<raw_hash_set*>(&common);
2571
2772
 
2572
2773
  // Unpoison before returning the memory to the allocator.
2573
- SanitizerUnpoisonMemoryRegion(slot_mem, sizeof(slot_type) * n);
2774
+ SanitizerUnpoisonMemoryRegion(common.slot_array(),
2775
+ sizeof(slot_type) * common.capacity());
2574
2776
 
2575
- Deallocate<alignof(slot_type)>(
2576
- &h->alloc_ref(), ctrl,
2577
- AllocSize(n, sizeof(slot_type), alignof(slot_type)));
2777
+ Deallocate<BackingArrayAlignment(alignof(slot_type))>(
2778
+ &set->alloc_ref(), common.backing_array_start(),
2779
+ common.alloc_size(sizeof(slot_type), alignof(slot_type)));
2578
2780
  }
2579
2781
 
2580
2782
  static const PolicyFunctions& GetPolicyFunctions() {
@@ -2680,6 +2882,5 @@ ABSL_NAMESPACE_END
2680
2882
  } // namespace absl
2681
2883
 
2682
2884
  #undef ABSL_SWISSTABLE_ENABLE_GENERATIONS
2683
- #undef ABSL_INTERNAL_ASSERT_IS_FULL
2684
2885
 
2685
2886
  #endif // ABSL_CONTAINER_INTERNAL_RAW_HASH_SET_H_