grpc 1.31.1 → 1.32.0.pre1

Sign up to get free protection for your applications and to get access to all the features.

Potentially problematic release.


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

Files changed (431) hide show
  1. checksums.yaml +4 -4
  2. data/Makefile +595 -15723
  3. data/include/grpc/grpc_security.h +31 -14
  4. data/include/grpc/impl/codegen/README.md +22 -0
  5. data/include/grpc/impl/codegen/port_platform.h +6 -1
  6. data/src/core/ext/filters/client_channel/backup_poller.cc +3 -2
  7. data/src/core/ext/filters/client_channel/client_channel.cc +64 -20
  8. data/src/core/ext/filters/client_channel/client_channel.h +1 -1
  9. data/src/core/ext/filters/client_channel/client_channel_channelz.h +0 -3
  10. data/src/core/ext/filters/client_channel/health/health_check_client.cc +6 -1
  11. data/src/core/ext/filters/client_channel/http_connect_handshaker.cc +2 -3
  12. data/src/core/ext/filters/client_channel/lb_policy.h +2 -0
  13. data/src/core/ext/filters/client_channel/lb_policy/child_policy_handler.cc +6 -4
  14. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb.cc +20 -13
  15. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_balancer_addresses.cc +0 -13
  16. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_balancer_addresses.h +0 -3
  17. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_channel_secure.cc +1 -37
  18. data/src/core/ext/filters/client_channel/lb_policy/pick_first/pick_first.cc +19 -13
  19. data/src/core/ext/filters/client_channel/lb_policy/priority/priority.cc +29 -10
  20. data/src/core/ext/filters/client_channel/lb_policy/round_robin/round_robin.cc +5 -4
  21. data/src/core/ext/filters/client_channel/lb_policy/weighted_target/weighted_target.cc +20 -9
  22. data/src/core/ext/filters/client_channel/lb_policy/xds/cds.cc +18 -12
  23. data/src/core/ext/filters/client_channel/lb_policy/xds/eds.cc +22 -14
  24. data/src/core/ext/filters/client_channel/lb_policy/xds/lrs.cc +18 -9
  25. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_routing.cc +54 -56
  26. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.cc +3 -3
  27. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper_libuv.cc +1 -1
  28. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper_windows.cc +1 -1
  29. data/src/core/ext/filters/client_channel/resolver/fake/fake_resolver.cc +1 -1
  30. data/src/core/ext/filters/client_channel/resolver/sockaddr/sockaddr_resolver.cc +1 -1
  31. data/src/core/ext/filters/client_channel/resolver/xds/xds_resolver.cc +363 -14
  32. data/src/core/ext/filters/client_channel/resolver_result_parsing.h +0 -1
  33. data/src/core/ext/filters/client_channel/resolving_lb_policy.cc +5 -4
  34. data/src/core/ext/filters/client_channel/server_address.cc +40 -7
  35. data/src/core/ext/filters/client_channel/server_address.h +42 -4
  36. data/src/core/ext/filters/client_channel/subchannel.cc +64 -23
  37. data/src/core/ext/filters/client_channel/subchannel.h +16 -4
  38. data/src/core/ext/filters/max_age/max_age_filter.cc +2 -1
  39. data/src/core/ext/transport/chttp2/client/chttp2_connector.cc +87 -31
  40. data/src/core/ext/transport/chttp2/client/chttp2_connector.h +18 -1
  41. data/src/core/ext/transport/chttp2/client/secure/secure_channel_create.cc +10 -35
  42. data/src/core/ext/transport/chttp2/server/chttp2_server.cc +19 -25
  43. data/src/core/ext/transport/chttp2/server/chttp2_server.h +2 -1
  44. data/src/core/ext/transport/chttp2/server/insecure/server_chttp2.cc +2 -2
  45. data/src/core/ext/transport/chttp2/server/insecure/server_chttp2_posix.cc +6 -6
  46. data/src/core/ext/transport/chttp2/server/secure/server_secure_chttp2.cc +3 -2
  47. data/src/core/ext/transport/chttp2/transport/chttp2_transport.cc +239 -277
  48. data/src/core/ext/transport/chttp2/transport/flow_control.cc +1 -1
  49. data/src/core/ext/transport/chttp2/transport/frame_settings.cc +2 -2
  50. data/src/core/ext/transport/chttp2/transport/internal.h +5 -1
  51. data/src/core/ext/transport/chttp2/transport/parsing.cc +1 -28
  52. data/src/core/ext/transport/chttp2/transport/writing.cc +6 -5
  53. data/src/core/ext/transport/inproc/inproc_transport.cc +12 -12
  54. data/src/core/ext/upb-generated/envoy/config/accesslog/v3/accesslog.upb.c +224 -0
  55. data/src/core/ext/upb-generated/envoy/config/accesslog/v3/accesslog.upb.h +700 -0
  56. data/src/core/ext/upb-generated/envoy/config/cluster/v3/circuit_breaker.upb.c +74 -0
  57. data/src/core/ext/upb-generated/envoy/config/cluster/v3/circuit_breaker.upb.h +226 -0
  58. data/src/core/ext/upb-generated/envoy/config/cluster/v3/cluster.upb.c +380 -0
  59. data/src/core/ext/upb-generated/envoy/config/cluster/v3/cluster.upb.h +1378 -0
  60. data/src/core/ext/upb-generated/envoy/{api/v2/cluster → config/cluster/v3}/filter.upb.c +8 -8
  61. data/src/core/ext/upb-generated/envoy/config/cluster/v3/filter.upb.h +69 -0
  62. data/src/core/ext/upb-generated/envoy/{api/v2/cluster → config/cluster/v3}/outlier_detection.upb.c +8 -8
  63. data/src/core/ext/upb-generated/envoy/config/cluster/v3/outlier_detection.upb.h +323 -0
  64. data/src/core/ext/upb-generated/envoy/config/core/v3/address.upb.c +112 -0
  65. data/src/core/ext/upb-generated/envoy/config/core/v3/address.upb.h +334 -0
  66. data/src/core/ext/upb-generated/envoy/{api/v2/core → config/core/v3}/backoff.upb.c +8 -8
  67. data/src/core/ext/upb-generated/envoy/config/core/v3/backoff.upb.h +79 -0
  68. data/src/core/ext/upb-generated/envoy/config/core/v3/base.upb.c +309 -0
  69. data/src/core/ext/upb-generated/envoy/config/core/v3/base.upb.h +869 -0
  70. data/src/core/ext/upb-generated/envoy/config/core/v3/config_source.upb.c +96 -0
  71. data/src/core/ext/upb-generated/envoy/config/core/v3/config_source.upb.h +328 -0
  72. data/src/core/ext/upb-generated/envoy/config/core/v3/event_service_config.upb.c +34 -0
  73. data/src/core/ext/upb-generated/envoy/config/core/v3/event_service_config.upb.h +71 -0
  74. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_service.upb.c +195 -0
  75. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_service.upb.h +634 -0
  76. data/src/core/ext/upb-generated/envoy/config/core/v3/health_check.upb.c +170 -0
  77. data/src/core/ext/upb-generated/envoy/config/core/v3/health_check.upb.h +684 -0
  78. data/src/core/ext/upb-generated/envoy/{api/v2/core → config/core/v3}/http_uri.upb.c +8 -8
  79. data/src/core/ext/upb-generated/envoy/config/core/v3/http_uri.upb.h +80 -0
  80. data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.c +152 -0
  81. data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.h +536 -0
  82. data/src/core/ext/upb-generated/envoy/config/core/v3/proxy_protocol.upb.c +28 -0
  83. data/src/core/ext/upb-generated/envoy/config/core/v3/proxy_protocol.upb.h +58 -0
  84. data/src/core/ext/upb-generated/envoy/{api/v2/core → config/core/v3}/socket_option.upb.c +6 -6
  85. data/src/core/ext/upb-generated/envoy/config/core/v3/socket_option.upb.h +88 -0
  86. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint.upb.c +91 -0
  87. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint.upb.h +220 -0
  88. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint_components.upb.c +91 -0
  89. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint_components.upb.h +273 -0
  90. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/load_report.upb.c +112 -0
  91. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/load_report.upb.h +332 -0
  92. data/src/core/ext/upb-generated/envoy/config/listener/{v2 → v3}/api_listener.upb.c +8 -8
  93. data/src/core/ext/upb-generated/envoy/config/listener/v3/api_listener.upb.h +65 -0
  94. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener.upb.c +108 -0
  95. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener.upb.h +401 -0
  96. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener_components.upb.c +138 -0
  97. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener_components.upb.h +490 -0
  98. data/src/core/ext/upb-generated/envoy/config/listener/v3/udp_listener_config.upb.c +41 -0
  99. data/src/core/ext/upb-generated/envoy/config/listener/v3/udp_listener_config.upb.h +94 -0
  100. data/src/core/ext/upb-generated/envoy/config/rbac/v3/rbac.upb.c +174 -0
  101. data/src/core/ext/upb-generated/envoy/config/rbac/v3/rbac.upb.h +599 -0
  102. data/src/core/ext/upb-generated/envoy/config/route/v3/route.upb.c +63 -0
  103. data/src/core/ext/upb-generated/envoy/config/route/v3/route.upb.h +204 -0
  104. data/src/core/ext/upb-generated/envoy/config/route/v3/route_components.upb.c +773 -0
  105. data/src/core/ext/upb-generated/envoy/config/route/v3/route_components.upb.h +2855 -0
  106. data/src/core/ext/upb-generated/envoy/config/route/v3/scoped_route.upb.c +59 -0
  107. data/src/core/ext/upb-generated/envoy/config/route/v3/scoped_route.upb.h +135 -0
  108. data/src/core/ext/upb-generated/envoy/config/trace/v3/http_tracer.upb.c +50 -0
  109. data/src/core/ext/upb-generated/envoy/config/trace/v3/http_tracer.upb.h +108 -0
  110. data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.c +312 -0
  111. data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.h +1125 -0
  112. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/cert.upb.c +20 -0
  113. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/cert.upb.h +34 -0
  114. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/common.upb.c +111 -0
  115. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/common.upb.h +401 -0
  116. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/secret.upb.c +72 -0
  117. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/secret.upb.h +198 -0
  118. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls.upb.c +105 -0
  119. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls.upb.h +388 -0
  120. data/src/core/ext/upb-generated/envoy/{api/v2 → service/cluster/v3}/cds.upb.c +5 -6
  121. data/src/core/ext/upb-generated/envoy/service/cluster/v3/cds.upb.h +49 -0
  122. data/src/core/ext/upb-generated/envoy/service/discovery/{v2 → v3}/ads.upb.c +5 -4
  123. data/src/core/ext/upb-generated/envoy/service/discovery/v3/ads.upb.h +49 -0
  124. data/src/core/ext/upb-generated/envoy/service/discovery/v3/discovery.upb.c +129 -0
  125. data/src/core/ext/upb-generated/envoy/service/discovery/v3/discovery.upb.h +386 -0
  126. data/src/core/ext/upb-generated/envoy/{api/v2 → service/endpoint/v3}/eds.upb.c +5 -6
  127. data/src/core/ext/upb-generated/envoy/service/endpoint/v3/eds.upb.h +49 -0
  128. data/src/core/ext/upb-generated/envoy/{api/v2 → service/listener/v3}/lds.upb.c +5 -6
  129. data/src/core/ext/upb-generated/envoy/service/listener/v3/lds.upb.h +49 -0
  130. data/src/core/ext/upb-generated/envoy/service/load_stats/v3/lrs.upb.c +55 -0
  131. data/src/core/ext/upb-generated/envoy/service/load_stats/v3/lrs.upb.h +136 -0
  132. data/src/core/ext/upb-generated/envoy/{api/v2 → service/route/v3}/rds.upb.c +5 -6
  133. data/src/core/ext/upb-generated/envoy/service/route/v3/rds.upb.h +49 -0
  134. data/src/core/ext/upb-generated/envoy/{api/v2 → service/route/v3}/srds.upb.c +5 -6
  135. data/src/core/ext/upb-generated/envoy/service/route/v3/srds.upb.h +49 -0
  136. data/src/core/ext/upb-generated/envoy/type/matcher/v3/metadata.upb.c +47 -0
  137. data/src/core/ext/upb-generated/envoy/type/matcher/v3/metadata.upb.h +114 -0
  138. data/src/core/ext/upb-generated/envoy/type/matcher/v3/number.upb.c +35 -0
  139. data/src/core/ext/upb-generated/envoy/type/matcher/v3/number.upb.h +77 -0
  140. data/src/core/ext/upb-generated/envoy/type/matcher/v3/path.upb.c +34 -0
  141. data/src/core/ext/upb-generated/envoy/type/matcher/v3/path.upb.h +71 -0
  142. data/src/core/ext/upb-generated/envoy/type/matcher/v3/regex.upb.c +64 -0
  143. data/src/core/ext/upb-generated/envoy/type/matcher/v3/regex.upb.h +145 -0
  144. data/src/core/ext/upb-generated/envoy/type/matcher/v3/string.upb.c +53 -0
  145. data/src/core/ext/upb-generated/envoy/type/matcher/v3/string.upb.h +127 -0
  146. data/src/core/ext/upb-generated/envoy/type/matcher/v3/value.upb.c +63 -0
  147. data/src/core/ext/upb-generated/envoy/type/matcher/v3/value.upb.h +188 -0
  148. data/src/core/ext/upb-generated/envoy/type/metadata/v3/metadata.upb.c +88 -0
  149. data/src/core/ext/upb-generated/envoy/type/metadata/v3/metadata.upb.h +258 -0
  150. data/src/core/ext/upb-generated/envoy/type/tracing/v3/custom_tag.upb.c +90 -0
  151. data/src/core/ext/upb-generated/envoy/type/tracing/v3/custom_tag.upb.h +250 -0
  152. data/src/core/ext/upb-generated/envoy/type/{http.upb.c → v3/http.upb.c} +2 -2
  153. data/src/core/ext/upb-generated/envoy/type/{http.upb.h → v3/http.upb.h} +8 -8
  154. data/src/core/ext/upb-generated/envoy/type/{percent.upb.c → v3/percent.upb.c} +9 -8
  155. data/src/core/ext/upb-generated/envoy/type/v3/percent.upb.h +86 -0
  156. data/src/core/ext/upb-generated/envoy/type/{range.upb.c → v3/range.upb.c} +12 -11
  157. data/src/core/ext/upb-generated/envoy/type/v3/range.upb.h +111 -0
  158. data/src/core/ext/upb-generated/envoy/type/{semantic_version.upb.c → v3/semantic_version.upb.c} +6 -5
  159. data/src/core/ext/upb-generated/envoy/type/v3/semantic_version.upb.h +61 -0
  160. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/syntax.upb.c +234 -0
  161. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/syntax.upb.h +759 -0
  162. data/src/core/ext/upb-generated/google/protobuf/descriptor.upb.c +36 -36
  163. data/src/core/ext/upb-generated/google/protobuf/struct.upb.h +1 -1
  164. data/src/core/ext/upb-generated/udpa/annotations/versioning.upb.c +27 -0
  165. data/src/core/ext/upb-generated/udpa/annotations/versioning.upb.h +53 -0
  166. data/src/core/ext/upb-generated/validate/validate.upb.c +11 -11
  167. data/src/core/ext/upb-generated/validate/validate.upb.h +1 -1
  168. data/src/core/ext/{filters/client_channel/xds → xds}/xds_api.cc +1045 -767
  169. data/src/core/ext/{filters/client_channel/xds → xds}/xds_api.h +114 -99
  170. data/src/core/ext/{filters/client_channel/xds → xds}/xds_bootstrap.cc +44 -2
  171. data/src/core/ext/{filters/client_channel/xds → xds}/xds_bootstrap.h +8 -3
  172. data/src/core/ext/{filters/client_channel/xds → xds}/xds_channel.h +4 -4
  173. data/src/core/ext/{filters/client_channel/xds → xds}/xds_channel_args.h +3 -3
  174. data/src/core/ext/{filters/client_channel/xds → xds}/xds_channel_secure.cc +2 -5
  175. data/src/core/ext/{filters/client_channel/xds → xds}/xds_client.cc +85 -417
  176. data/src/core/ext/{filters/client_channel/xds → xds}/xds_client.h +12 -45
  177. data/src/core/ext/{filters/client_channel/xds → xds}/xds_client_stats.cc +2 -2
  178. data/src/core/ext/{filters/client_channel/xds → xds}/xds_client_stats.h +3 -3
  179. data/src/core/lib/channel/channelz.cc +14 -15
  180. data/src/core/lib/channel/channelz.h +1 -1
  181. data/src/core/lib/channel/channelz_registry.cc +3 -1
  182. data/src/core/lib/gpr/sync_posix.cc +2 -8
  183. data/src/core/lib/iomgr/endpoint.cc +5 -1
  184. data/src/core/lib/iomgr/endpoint.h +7 -3
  185. data/src/core/lib/iomgr/endpoint_cfstream.cc +32 -11
  186. data/src/core/lib/iomgr/ev_posix.cc +0 -2
  187. data/src/core/lib/iomgr/iomgr.cc +0 -10
  188. data/src/core/lib/iomgr/iomgr.h +0 -10
  189. data/src/core/{ext/filters/client_channel → lib/iomgr}/parse_address.cc +1 -1
  190. data/src/core/{ext/filters/client_channel → lib/iomgr}/parse_address.h +3 -3
  191. data/src/core/lib/iomgr/sockaddr_utils.cc +2 -1
  192. data/src/core/lib/iomgr/sockaddr_utils.h +2 -1
  193. data/src/core/lib/iomgr/tcp_custom.cc +32 -16
  194. data/src/core/lib/iomgr/tcp_posix.cc +31 -13
  195. data/src/core/lib/iomgr/tcp_windows.cc +26 -10
  196. data/src/core/lib/security/authorization/authorization_engine.cc +177 -0
  197. data/src/core/lib/security/authorization/authorization_engine.h +84 -0
  198. data/src/core/lib/security/authorization/evaluate_args.cc +153 -0
  199. data/src/core/lib/security/authorization/evaluate_args.h +59 -0
  200. data/src/core/lib/security/authorization/mock_cel/activation.h +57 -0
  201. data/src/core/lib/security/authorization/mock_cel/cel_expr_builder_factory.h +42 -0
  202. data/src/core/lib/security/authorization/mock_cel/cel_expression.h +68 -0
  203. data/src/core/lib/security/authorization/mock_cel/cel_value.h +93 -0
  204. data/src/core/lib/security/authorization/mock_cel/evaluator_core.h +67 -0
  205. data/src/core/lib/security/authorization/mock_cel/flat_expr_builder.h +56 -0
  206. data/src/core/lib/security/authorization/mock_cel/statusor.h +50 -0
  207. data/src/core/lib/security/credentials/google_default/google_default_credentials.cc +56 -38
  208. data/src/core/lib/security/security_connector/fake/fake_security_connector.cc +1 -2
  209. data/src/core/lib/security/transport/secure_endpoint.cc +7 -1
  210. data/src/core/lib/surface/call.cc +12 -12
  211. data/src/core/lib/surface/call.h +2 -1
  212. data/src/core/lib/surface/channel.cc +28 -20
  213. data/src/core/lib/surface/channel.h +12 -2
  214. data/src/core/lib/surface/completion_queue.cc +10 -272
  215. data/src/core/lib/surface/completion_queue.h +0 -8
  216. data/src/core/lib/surface/init.cc +1 -3
  217. data/src/core/lib/surface/server.cc +1066 -1244
  218. data/src/core/lib/surface/server.h +363 -87
  219. data/src/core/lib/surface/version.cc +2 -2
  220. data/src/core/lib/transport/authority_override.cc +38 -0
  221. data/src/core/lib/transport/authority_override.h +32 -0
  222. data/src/core/lib/transport/connectivity_state.cc +18 -13
  223. data/src/core/lib/transport/connectivity_state.h +18 -6
  224. data/src/core/lib/transport/error_utils.cc +13 -0
  225. data/src/core/lib/transport/error_utils.h +6 -0
  226. data/src/core/lib/transport/static_metadata.cc +295 -276
  227. data/src/core/lib/transport/static_metadata.h +80 -73
  228. data/src/core/lib/transport/transport.h +7 -0
  229. data/src/core/lib/uri/uri_parser.cc +23 -21
  230. data/src/core/lib/uri/uri_parser.h +3 -1
  231. data/src/core/tsi/alts/handshaker/alts_tsi_handshaker.cc +22 -0
  232. data/src/core/tsi/ssl_transport_security.cc +3 -9
  233. data/src/ruby/ext/grpc/rb_channel_credentials.c +9 -0
  234. data/src/ruby/ext/grpc/rb_grpc_imports.generated.c +2 -2
  235. data/src/ruby/ext/grpc/rb_grpc_imports.generated.h +4 -4
  236. data/src/ruby/lib/grpc/version.rb +1 -1
  237. data/src/ruby/spec/channel_credentials_spec.rb +10 -0
  238. data/src/ruby/spec/generic/active_call_spec.rb +19 -8
  239. data/third_party/abseil-cpp/absl/algorithm/container.h +1727 -0
  240. data/third_party/abseil-cpp/absl/base/internal/direct_mmap.h +161 -0
  241. data/third_party/abseil-cpp/absl/base/internal/exponential_biased.cc +93 -0
  242. data/third_party/abseil-cpp/absl/base/internal/exponential_biased.h +130 -0
  243. data/third_party/abseil-cpp/absl/base/internal/low_level_alloc.cc +620 -0
  244. data/third_party/abseil-cpp/absl/base/internal/low_level_alloc.h +126 -0
  245. data/third_party/abseil-cpp/absl/container/fixed_array.h +515 -0
  246. data/third_party/abseil-cpp/absl/container/flat_hash_set.h +503 -0
  247. data/third_party/abseil-cpp/absl/container/internal/common.h +202 -0
  248. data/third_party/abseil-cpp/absl/container/internal/container_memory.h +440 -0
  249. data/third_party/abseil-cpp/absl/container/internal/hash_function_defaults.h +146 -0
  250. data/third_party/abseil-cpp/absl/container/internal/hash_policy_traits.h +191 -0
  251. data/third_party/abseil-cpp/absl/container/internal/hashtable_debug_hooks.h +85 -0
  252. data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler.cc +269 -0
  253. data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler.h +297 -0
  254. data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler_force_weak_definition.cc +30 -0
  255. data/third_party/abseil-cpp/absl/container/internal/have_sse.h +49 -0
  256. data/third_party/abseil-cpp/absl/container/internal/layout.h +741 -0
  257. data/third_party/abseil-cpp/absl/container/internal/raw_hash_set.cc +48 -0
  258. data/third_party/abseil-cpp/absl/container/internal/raw_hash_set.h +1882 -0
  259. data/third_party/abseil-cpp/absl/debugging/internal/address_is_readable.cc +138 -0
  260. data/third_party/abseil-cpp/absl/debugging/internal/address_is_readable.h +32 -0
  261. data/third_party/abseil-cpp/absl/debugging/internal/demangle.cc +1895 -0
  262. data/third_party/abseil-cpp/absl/debugging/internal/demangle.h +71 -0
  263. data/third_party/abseil-cpp/absl/debugging/internal/elf_mem_image.cc +382 -0
  264. data/third_party/abseil-cpp/absl/debugging/internal/elf_mem_image.h +134 -0
  265. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_aarch64-inl.inc +192 -0
  266. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_arm-inl.inc +125 -0
  267. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_config.h +70 -0
  268. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_generic-inl.inc +99 -0
  269. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_powerpc-inl.inc +248 -0
  270. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_unimplemented-inl.inc +24 -0
  271. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_win32-inl.inc +85 -0
  272. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_x86-inl.inc +346 -0
  273. data/third_party/abseil-cpp/absl/debugging/internal/symbolize.h +128 -0
  274. data/third_party/abseil-cpp/absl/debugging/internal/vdso_support.cc +194 -0
  275. data/third_party/abseil-cpp/absl/debugging/internal/vdso_support.h +158 -0
  276. data/third_party/abseil-cpp/absl/debugging/stacktrace.cc +140 -0
  277. data/third_party/abseil-cpp/absl/debugging/stacktrace.h +231 -0
  278. data/third_party/abseil-cpp/absl/debugging/symbolize.cc +25 -0
  279. data/third_party/abseil-cpp/absl/debugging/symbolize.h +99 -0
  280. data/third_party/abseil-cpp/absl/debugging/symbolize_elf.inc +1480 -0
  281. data/third_party/abseil-cpp/absl/debugging/symbolize_unimplemented.inc +40 -0
  282. data/third_party/abseil-cpp/absl/debugging/symbolize_win32.inc +81 -0
  283. data/third_party/abseil-cpp/absl/functional/function_ref.h +139 -0
  284. data/third_party/abseil-cpp/absl/functional/internal/function_ref.h +106 -0
  285. data/third_party/abseil-cpp/absl/hash/hash.h +324 -0
  286. data/third_party/abseil-cpp/absl/hash/internal/city.cc +346 -0
  287. data/third_party/abseil-cpp/absl/hash/internal/city.h +96 -0
  288. data/third_party/abseil-cpp/absl/hash/internal/hash.cc +55 -0
  289. data/third_party/abseil-cpp/absl/hash/internal/hash.h +988 -0
  290. data/third_party/abseil-cpp/absl/status/status.cc +447 -0
  291. data/third_party/abseil-cpp/absl/status/status.h +428 -0
  292. data/third_party/abseil-cpp/absl/status/status_payload_printer.cc +43 -0
  293. data/third_party/abseil-cpp/absl/status/status_payload_printer.h +51 -0
  294. data/third_party/abseil-cpp/absl/strings/cord.cc +2019 -0
  295. data/third_party/abseil-cpp/absl/strings/cord.h +1121 -0
  296. data/third_party/abseil-cpp/absl/strings/internal/cord_internal.h +151 -0
  297. data/third_party/abseil-cpp/absl/synchronization/barrier.cc +52 -0
  298. data/third_party/abseil-cpp/absl/synchronization/barrier.h +79 -0
  299. data/third_party/abseil-cpp/absl/synchronization/blocking_counter.cc +57 -0
  300. data/third_party/abseil-cpp/absl/synchronization/blocking_counter.h +99 -0
  301. data/third_party/abseil-cpp/absl/synchronization/internal/create_thread_identity.cc +140 -0
  302. data/third_party/abseil-cpp/absl/synchronization/internal/create_thread_identity.h +60 -0
  303. data/third_party/abseil-cpp/absl/synchronization/internal/graphcycles.cc +697 -0
  304. data/third_party/abseil-cpp/absl/synchronization/internal/graphcycles.h +141 -0
  305. data/third_party/abseil-cpp/absl/synchronization/internal/kernel_timeout.h +155 -0
  306. data/third_party/abseil-cpp/absl/synchronization/internal/mutex_nonprod.inc +261 -0
  307. data/third_party/abseil-cpp/absl/synchronization/internal/per_thread_sem.cc +106 -0
  308. data/third_party/abseil-cpp/absl/synchronization/internal/per_thread_sem.h +115 -0
  309. data/third_party/abseil-cpp/absl/synchronization/internal/waiter.cc +484 -0
  310. data/third_party/abseil-cpp/absl/synchronization/internal/waiter.h +159 -0
  311. data/third_party/abseil-cpp/absl/synchronization/mutex.cc +2728 -0
  312. data/third_party/abseil-cpp/absl/synchronization/mutex.h +1056 -0
  313. data/third_party/abseil-cpp/absl/synchronization/notification.cc +78 -0
  314. data/third_party/abseil-cpp/absl/synchronization/notification.h +123 -0
  315. data/third_party/abseil-cpp/absl/types/bad_variant_access.cc +64 -0
  316. data/third_party/abseil-cpp/absl/types/bad_variant_access.h +82 -0
  317. data/third_party/abseil-cpp/absl/types/internal/variant.h +1646 -0
  318. data/third_party/abseil-cpp/absl/types/variant.h +861 -0
  319. data/third_party/boringssl-with-bazel/err_data.c +263 -257
  320. data/third_party/boringssl-with-bazel/src/crypto/evp/evp_asn1.c +16 -0
  321. data/third_party/boringssl-with-bazel/src/crypto/hpke/hpke.c +456 -0
  322. data/third_party/boringssl-with-bazel/src/crypto/hpke/internal.h +192 -0
  323. data/third_party/boringssl-with-bazel/src/crypto/x509/x_sig.c +20 -0
  324. data/third_party/boringssl-with-bazel/src/include/openssl/arm_arch.h +52 -0
  325. data/third_party/boringssl-with-bazel/src/include/openssl/base.h +1 -1
  326. data/third_party/boringssl-with-bazel/src/include/openssl/ssl.h +39 -7
  327. data/third_party/boringssl-with-bazel/src/include/openssl/tls1.h +2 -3
  328. data/third_party/boringssl-with-bazel/src/include/openssl/x509.h +11 -0
  329. data/third_party/boringssl-with-bazel/src/ssl/internal.h +4 -0
  330. data/third_party/boringssl-with-bazel/src/ssl/ssl_cert.cc +3 -6
  331. data/third_party/boringssl-with-bazel/src/ssl/ssl_lib.cc +10 -0
  332. data/third_party/boringssl-with-bazel/src/ssl/t1_lib.cc +34 -9
  333. data/third_party/boringssl-with-bazel/src/ssl/tls13_server.cc +5 -0
  334. data/third_party/boringssl-with-bazel/src/ssl/tls_record.cc +5 -3
  335. data/third_party/upb/upb/decode.c +64 -15
  336. data/third_party/upb/upb/encode.c +2 -2
  337. data/third_party/upb/upb/msg.h +2 -2
  338. data/third_party/upb/upb/port_def.inc +1 -1
  339. data/third_party/upb/upb/table.c +0 -11
  340. data/third_party/upb/upb/table.int.h +0 -9
  341. data/third_party/upb/upb/upb.c +16 -14
  342. data/third_party/upb/upb/upb.h +26 -0
  343. data/third_party/upb/upb/upb.hpp +2 -0
  344. metadata +257 -155
  345. data/src/core/ext/upb-generated/envoy/api/v2/auth/cert.upb.c +0 -21
  346. data/src/core/ext/upb-generated/envoy/api/v2/auth/cert.upb.h +0 -34
  347. data/src/core/ext/upb-generated/envoy/api/v2/auth/common.upb.c +0 -114
  348. data/src/core/ext/upb-generated/envoy/api/v2/auth/common.upb.h +0 -429
  349. data/src/core/ext/upb-generated/envoy/api/v2/auth/secret.upb.c +0 -72
  350. data/src/core/ext/upb-generated/envoy/api/v2/auth/secret.upb.h +0 -198
  351. data/src/core/ext/upb-generated/envoy/api/v2/auth/tls.upb.c +0 -105
  352. data/src/core/ext/upb-generated/envoy/api/v2/auth/tls.upb.h +0 -388
  353. data/src/core/ext/upb-generated/envoy/api/v2/cds.upb.h +0 -52
  354. data/src/core/ext/upb-generated/envoy/api/v2/cluster.upb.c +0 -403
  355. data/src/core/ext/upb-generated/envoy/api/v2/cluster.upb.h +0 -1453
  356. data/src/core/ext/upb-generated/envoy/api/v2/cluster/circuit_breaker.upb.c +0 -74
  357. data/src/core/ext/upb-generated/envoy/api/v2/cluster/circuit_breaker.upb.h +0 -226
  358. data/src/core/ext/upb-generated/envoy/api/v2/cluster/filter.upb.h +0 -69
  359. data/src/core/ext/upb-generated/envoy/api/v2/cluster/outlier_detection.upb.h +0 -323
  360. data/src/core/ext/upb-generated/envoy/api/v2/core/address.upb.c +0 -112
  361. data/src/core/ext/upb-generated/envoy/api/v2/core/address.upb.h +0 -334
  362. data/src/core/ext/upb-generated/envoy/api/v2/core/backoff.upb.h +0 -79
  363. data/src/core/ext/upb-generated/envoy/api/v2/core/base.upb.c +0 -313
  364. data/src/core/ext/upb-generated/envoy/api/v2/core/base.upb.h +0 -891
  365. data/src/core/ext/upb-generated/envoy/api/v2/core/config_source.upb.c +0 -96
  366. data/src/core/ext/upb-generated/envoy/api/v2/core/config_source.upb.h +0 -328
  367. data/src/core/ext/upb-generated/envoy/api/v2/core/event_service_config.upb.c +0 -34
  368. data/src/core/ext/upb-generated/envoy/api/v2/core/event_service_config.upb.h +0 -71
  369. data/src/core/ext/upb-generated/envoy/api/v2/core/grpc_service.upb.c +0 -197
  370. data/src/core/ext/upb-generated/envoy/api/v2/core/grpc_service.upb.h +0 -649
  371. data/src/core/ext/upb-generated/envoy/api/v2/core/health_check.upb.c +0 -172
  372. data/src/core/ext/upb-generated/envoy/api/v2/core/health_check.upb.h +0 -693
  373. data/src/core/ext/upb-generated/envoy/api/v2/core/http_uri.upb.h +0 -80
  374. data/src/core/ext/upb-generated/envoy/api/v2/core/protocol.upb.c +0 -152
  375. data/src/core/ext/upb-generated/envoy/api/v2/core/protocol.upb.h +0 -536
  376. data/src/core/ext/upb-generated/envoy/api/v2/core/socket_option.upb.h +0 -88
  377. data/src/core/ext/upb-generated/envoy/api/v2/discovery.upb.c +0 -129
  378. data/src/core/ext/upb-generated/envoy/api/v2/discovery.upb.h +0 -386
  379. data/src/core/ext/upb-generated/envoy/api/v2/eds.upb.h +0 -52
  380. data/src/core/ext/upb-generated/envoy/api/v2/endpoint.upb.c +0 -92
  381. data/src/core/ext/upb-generated/envoy/api/v2/endpoint.upb.h +0 -224
  382. data/src/core/ext/upb-generated/envoy/api/v2/endpoint/endpoint.upb.c +0 -18
  383. data/src/core/ext/upb-generated/envoy/api/v2/endpoint/endpoint.upb.h +0 -32
  384. data/src/core/ext/upb-generated/envoy/api/v2/endpoint/endpoint_components.upb.c +0 -91
  385. data/src/core/ext/upb-generated/envoy/api/v2/endpoint/endpoint_components.upb.h +0 -273
  386. data/src/core/ext/upb-generated/envoy/api/v2/endpoint/load_report.upb.c +0 -112
  387. data/src/core/ext/upb-generated/envoy/api/v2/endpoint/load_report.upb.h +0 -332
  388. data/src/core/ext/upb-generated/envoy/api/v2/lds.upb.h +0 -52
  389. data/src/core/ext/upb-generated/envoy/api/v2/listener.upb.c +0 -109
  390. data/src/core/ext/upb-generated/envoy/api/v2/listener.upb.h +0 -415
  391. data/src/core/ext/upb-generated/envoy/api/v2/listener/listener.upb.c +0 -18
  392. data/src/core/ext/upb-generated/envoy/api/v2/listener/listener.upb.h +0 -32
  393. data/src/core/ext/upb-generated/envoy/api/v2/listener/listener_components.upb.c +0 -145
  394. data/src/core/ext/upb-generated/envoy/api/v2/listener/listener_components.upb.h +0 -538
  395. data/src/core/ext/upb-generated/envoy/api/v2/listener/udp_listener_config.upb.c +0 -43
  396. data/src/core/ext/upb-generated/envoy/api/v2/listener/udp_listener_config.upb.h +0 -111
  397. data/src/core/ext/upb-generated/envoy/api/v2/rds.upb.h +0 -52
  398. data/src/core/ext/upb-generated/envoy/api/v2/route.upb.c +0 -63
  399. data/src/core/ext/upb-generated/envoy/api/v2/route.upb.h +0 -204
  400. data/src/core/ext/upb-generated/envoy/api/v2/route/route.upb.c +0 -18
  401. data/src/core/ext/upb-generated/envoy/api/v2/route/route.upb.h +0 -32
  402. data/src/core/ext/upb-generated/envoy/api/v2/route/route_components.upb.c +0 -815
  403. data/src/core/ext/upb-generated/envoy/api/v2/route/route_components.upb.h +0 -2984
  404. data/src/core/ext/upb-generated/envoy/api/v2/scoped_route.upb.c +0 -59
  405. data/src/core/ext/upb-generated/envoy/api/v2/scoped_route.upb.h +0 -135
  406. data/src/core/ext/upb-generated/envoy/api/v2/srds.upb.h +0 -52
  407. data/src/core/ext/upb-generated/envoy/config/filter/accesslog/v2/accesslog.upb.c +0 -228
  408. data/src/core/ext/upb-generated/envoy/config/filter/accesslog/v2/accesslog.upb.h +0 -732
  409. data/src/core/ext/upb-generated/envoy/config/filter/network/http_connection_manager/v2/http_connection_manager.upb.c +0 -316
  410. data/src/core/ext/upb-generated/envoy/config/filter/network/http_connection_manager/v2/http_connection_manager.upb.h +0 -1167
  411. data/src/core/ext/upb-generated/envoy/config/listener/v2/api_listener.upb.h +0 -65
  412. data/src/core/ext/upb-generated/envoy/config/trace/v2/http_tracer.upb.c +0 -51
  413. data/src/core/ext/upb-generated/envoy/config/trace/v2/http_tracer.upb.h +0 -125
  414. data/src/core/ext/upb-generated/envoy/service/discovery/v2/ads.upb.h +0 -49
  415. data/src/core/ext/upb-generated/envoy/service/load_stats/v2/lrs.upb.c +0 -54
  416. data/src/core/ext/upb-generated/envoy/service/load_stats/v2/lrs.upb.h +0 -136
  417. data/src/core/ext/upb-generated/envoy/type/matcher/regex.upb.c +0 -63
  418. data/src/core/ext/upb-generated/envoy/type/matcher/regex.upb.h +0 -145
  419. data/src/core/ext/upb-generated/envoy/type/matcher/string.upb.c +0 -53
  420. data/src/core/ext/upb-generated/envoy/type/matcher/string.upb.h +0 -133
  421. data/src/core/ext/upb-generated/envoy/type/metadata/v2/metadata.upb.c +0 -88
  422. data/src/core/ext/upb-generated/envoy/type/metadata/v2/metadata.upb.h +0 -258
  423. data/src/core/ext/upb-generated/envoy/type/percent.upb.h +0 -86
  424. data/src/core/ext/upb-generated/envoy/type/range.upb.h +0 -111
  425. data/src/core/ext/upb-generated/envoy/type/semantic_version.upb.h +0 -61
  426. data/src/core/ext/upb-generated/envoy/type/tracing/v2/custom_tag.upb.c +0 -89
  427. data/src/core/ext/upb-generated/envoy/type/tracing/v2/custom_tag.upb.h +0 -250
  428. data/src/core/lib/security/transport/target_authority_table.cc +0 -75
  429. data/src/core/lib/security/transport/target_authority_table.h +0 -40
  430. data/src/core/lib/slice/slice_hash_table.h +0 -199
  431. data/src/core/lib/slice/slice_weak_hash_table.h +0 -102
@@ -0,0 +1,106 @@
1
+ // Copyright 2017 The Abseil Authors.
2
+ //
3
+ // Licensed under the Apache License, Version 2.0 (the "License");
4
+ // you may not use this file except in compliance with the License.
5
+ // You may obtain a copy of the License at
6
+ //
7
+ // https://www.apache.org/licenses/LICENSE-2.0
8
+ //
9
+ // Unless required by applicable law or agreed to in writing, software
10
+ // distributed under the License is distributed on an "AS IS" BASIS,
11
+ // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
+ // See the License for the specific language governing permissions and
13
+ // limitations under the License.
14
+
15
+ // This file is a no-op if the required LowLevelAlloc support is missing.
16
+ #include "absl/base/internal/low_level_alloc.h"
17
+ #ifndef ABSL_LOW_LEVEL_ALLOC_MISSING
18
+
19
+ #include "absl/synchronization/internal/per_thread_sem.h"
20
+
21
+ #include <atomic>
22
+
23
+ #include "absl/base/attributes.h"
24
+ #include "absl/base/internal/thread_identity.h"
25
+ #include "absl/synchronization/internal/waiter.h"
26
+
27
+ namespace absl {
28
+ ABSL_NAMESPACE_BEGIN
29
+ namespace synchronization_internal {
30
+
31
+ void PerThreadSem::SetThreadBlockedCounter(std::atomic<int> *counter) {
32
+ base_internal::ThreadIdentity *identity;
33
+ identity = GetOrCreateCurrentThreadIdentity();
34
+ identity->blocked_count_ptr = counter;
35
+ }
36
+
37
+ std::atomic<int> *PerThreadSem::GetThreadBlockedCounter() {
38
+ base_internal::ThreadIdentity *identity;
39
+ identity = GetOrCreateCurrentThreadIdentity();
40
+ return identity->blocked_count_ptr;
41
+ }
42
+
43
+ void PerThreadSem::Init(base_internal::ThreadIdentity *identity) {
44
+ new (Waiter::GetWaiter(identity)) Waiter();
45
+ identity->ticker.store(0, std::memory_order_relaxed);
46
+ identity->wait_start.store(0, std::memory_order_relaxed);
47
+ identity->is_idle.store(false, std::memory_order_relaxed);
48
+ }
49
+
50
+ void PerThreadSem::Destroy(base_internal::ThreadIdentity *identity) {
51
+ Waiter::GetWaiter(identity)->~Waiter();
52
+ }
53
+
54
+ void PerThreadSem::Tick(base_internal::ThreadIdentity *identity) {
55
+ const int ticker =
56
+ identity->ticker.fetch_add(1, std::memory_order_relaxed) + 1;
57
+ const int wait_start = identity->wait_start.load(std::memory_order_relaxed);
58
+ const bool is_idle = identity->is_idle.load(std::memory_order_relaxed);
59
+ if (wait_start && (ticker - wait_start > Waiter::kIdlePeriods) && !is_idle) {
60
+ // Wakeup the waiting thread since it is time for it to become idle.
61
+ Waiter::GetWaiter(identity)->Poke();
62
+ }
63
+ }
64
+
65
+ } // namespace synchronization_internal
66
+ ABSL_NAMESPACE_END
67
+ } // namespace absl
68
+
69
+ extern "C" {
70
+
71
+ ABSL_ATTRIBUTE_WEAK void AbslInternalPerThreadSemPost(
72
+ absl::base_internal::ThreadIdentity *identity) {
73
+ absl::synchronization_internal::Waiter::GetWaiter(identity)->Post();
74
+ }
75
+
76
+ ABSL_ATTRIBUTE_WEAK bool AbslInternalPerThreadSemWait(
77
+ absl::synchronization_internal::KernelTimeout t) {
78
+ bool timeout = false;
79
+ absl::base_internal::ThreadIdentity *identity;
80
+ identity = absl::synchronization_internal::GetOrCreateCurrentThreadIdentity();
81
+
82
+ // Ensure wait_start != 0.
83
+ int ticker = identity->ticker.load(std::memory_order_relaxed);
84
+ identity->wait_start.store(ticker ? ticker : 1, std::memory_order_relaxed);
85
+ identity->is_idle.store(false, std::memory_order_relaxed);
86
+
87
+ if (identity->blocked_count_ptr != nullptr) {
88
+ // Increment count of threads blocked in a given thread pool.
89
+ identity->blocked_count_ptr->fetch_add(1, std::memory_order_relaxed);
90
+ }
91
+
92
+ timeout =
93
+ !absl::synchronization_internal::Waiter::GetWaiter(identity)->Wait(t);
94
+
95
+ if (identity->blocked_count_ptr != nullptr) {
96
+ identity->blocked_count_ptr->fetch_sub(1, std::memory_order_relaxed);
97
+ }
98
+
99
+ identity->is_idle.store(false, std::memory_order_relaxed);
100
+ identity->wait_start.store(0, std::memory_order_relaxed);
101
+ return !timeout;
102
+ }
103
+
104
+ } // extern "C"
105
+
106
+ #endif // ABSL_LOW_LEVEL_ALLOC_MISSING
@@ -0,0 +1,115 @@
1
+ // Copyright 2017 The Abseil Authors.
2
+ //
3
+ // Licensed under the Apache License, Version 2.0 (the "License");
4
+ // you may not use this file except in compliance with the License.
5
+ // You may obtain a copy of the License at
6
+ //
7
+ // https://www.apache.org/licenses/LICENSE-2.0
8
+ //
9
+ // Unless required by applicable law or agreed to in writing, software
10
+ // distributed under the License is distributed on an "AS IS" BASIS,
11
+ // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
+ // See the License for the specific language governing permissions and
13
+ // limitations under the License.
14
+ //
15
+
16
+ // PerThreadSem is a low-level synchronization primitive controlling the
17
+ // runnability of a single thread, used internally by Mutex and CondVar.
18
+ //
19
+ // This is NOT a general-purpose synchronization mechanism, and should not be
20
+ // used directly by applications. Applications should use Mutex and CondVar.
21
+ //
22
+ // The semantics of PerThreadSem are the same as that of a counting semaphore.
23
+ // Each thread maintains an abstract "count" value associated with its identity.
24
+
25
+ #ifndef ABSL_SYNCHRONIZATION_INTERNAL_PER_THREAD_SEM_H_
26
+ #define ABSL_SYNCHRONIZATION_INTERNAL_PER_THREAD_SEM_H_
27
+
28
+ #include <atomic>
29
+
30
+ #include "absl/base/internal/thread_identity.h"
31
+ #include "absl/synchronization/internal/create_thread_identity.h"
32
+ #include "absl/synchronization/internal/kernel_timeout.h"
33
+
34
+ namespace absl {
35
+ ABSL_NAMESPACE_BEGIN
36
+
37
+ class Mutex;
38
+
39
+ namespace synchronization_internal {
40
+
41
+ class PerThreadSem {
42
+ public:
43
+ PerThreadSem() = delete;
44
+ PerThreadSem(const PerThreadSem&) = delete;
45
+ PerThreadSem& operator=(const PerThreadSem&) = delete;
46
+
47
+ // Routine invoked periodically (once a second) by a background thread.
48
+ // Has no effect on user-visible state.
49
+ static void Tick(base_internal::ThreadIdentity* identity);
50
+
51
+ // ---------------------------------------------------------------------------
52
+ // Routines used by autosizing threadpools to detect when threads are
53
+ // blocked. Each thread has a counter pointer, initially zero. If non-zero,
54
+ // the implementation atomically increments the counter when it blocks on a
55
+ // semaphore, a decrements it again when it wakes. This allows a threadpool
56
+ // to keep track of how many of its threads are blocked.
57
+ // SetThreadBlockedCounter() should be used only by threadpool
58
+ // implementations. GetThreadBlockedCounter() should be used by modules that
59
+ // block threads; if the pointer returned is non-zero, the location should be
60
+ // incremented before the thread blocks, and decremented after it wakes.
61
+ static void SetThreadBlockedCounter(std::atomic<int> *counter);
62
+ static std::atomic<int> *GetThreadBlockedCounter();
63
+
64
+ private:
65
+ // Create the PerThreadSem associated with "identity". Initializes count=0.
66
+ // REQUIRES: May only be called by ThreadIdentity.
67
+ static void Init(base_internal::ThreadIdentity* identity);
68
+
69
+ // Destroy the PerThreadSem associated with "identity".
70
+ // REQUIRES: May only be called by ThreadIdentity.
71
+ static void Destroy(base_internal::ThreadIdentity* identity);
72
+
73
+ // Increments "identity"'s count.
74
+ static inline void Post(base_internal::ThreadIdentity* identity);
75
+
76
+ // Waits until either our count > 0 or t has expired.
77
+ // If count > 0, decrements count and returns true. Otherwise returns false.
78
+ // !t.has_timeout() => Wait(t) will return true.
79
+ static inline bool Wait(KernelTimeout t);
80
+
81
+ // White-listed callers.
82
+ friend class PerThreadSemTest;
83
+ friend class absl::Mutex;
84
+ friend absl::base_internal::ThreadIdentity* CreateThreadIdentity();
85
+ friend void ReclaimThreadIdentity(void* v);
86
+ };
87
+
88
+ } // namespace synchronization_internal
89
+ ABSL_NAMESPACE_END
90
+ } // namespace absl
91
+
92
+ // In some build configurations we pass --detect-odr-violations to the
93
+ // gold linker. This causes it to flag weak symbol overrides as ODR
94
+ // violations. Because ODR only applies to C++ and not C,
95
+ // --detect-odr-violations ignores symbols not mangled with C++ names.
96
+ // By changing our extension points to be extern "C", we dodge this
97
+ // check.
98
+ extern "C" {
99
+ void AbslInternalPerThreadSemPost(
100
+ absl::base_internal::ThreadIdentity* identity);
101
+ bool AbslInternalPerThreadSemWait(
102
+ absl::synchronization_internal::KernelTimeout t);
103
+ } // extern "C"
104
+
105
+ void absl::synchronization_internal::PerThreadSem::Post(
106
+ absl::base_internal::ThreadIdentity* identity) {
107
+ AbslInternalPerThreadSemPost(identity);
108
+ }
109
+
110
+ bool absl::synchronization_internal::PerThreadSem::Wait(
111
+ absl::synchronization_internal::KernelTimeout t) {
112
+ return AbslInternalPerThreadSemWait(t);
113
+ }
114
+
115
+ #endif // ABSL_SYNCHRONIZATION_INTERNAL_PER_THREAD_SEM_H_
@@ -0,0 +1,484 @@
1
+ // Copyright 2017 The Abseil Authors.
2
+ //
3
+ // Licensed under the Apache License, Version 2.0 (the "License");
4
+ // you may not use this file except in compliance with the License.
5
+ // You may obtain a copy of the License at
6
+ //
7
+ // https://www.apache.org/licenses/LICENSE-2.0
8
+ //
9
+ // Unless required by applicable law or agreed to in writing, software
10
+ // distributed under the License is distributed on an "AS IS" BASIS,
11
+ // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
+ // See the License for the specific language governing permissions and
13
+ // limitations under the License.
14
+
15
+ #include "absl/synchronization/internal/waiter.h"
16
+
17
+ #include "absl/base/config.h"
18
+
19
+ #ifdef _WIN32
20
+ #include <windows.h>
21
+ #else
22
+ #include <pthread.h>
23
+ #include <sys/time.h>
24
+ #include <unistd.h>
25
+ #endif
26
+
27
+ #ifdef __linux__
28
+ #include <linux/futex.h>
29
+ #include <sys/syscall.h>
30
+ #endif
31
+
32
+ #ifdef ABSL_HAVE_SEMAPHORE_H
33
+ #include <semaphore.h>
34
+ #endif
35
+
36
+ #include <errno.h>
37
+ #include <stdio.h>
38
+ #include <time.h>
39
+
40
+ #include <atomic>
41
+ #include <cassert>
42
+ #include <cstdint>
43
+ #include <new>
44
+ #include <type_traits>
45
+
46
+ #include "absl/base/internal/raw_logging.h"
47
+ #include "absl/base/internal/thread_identity.h"
48
+ #include "absl/base/optimization.h"
49
+ #include "absl/synchronization/internal/kernel_timeout.h"
50
+
51
+ namespace absl {
52
+ ABSL_NAMESPACE_BEGIN
53
+ namespace synchronization_internal {
54
+
55
+ static void MaybeBecomeIdle() {
56
+ base_internal::ThreadIdentity *identity =
57
+ base_internal::CurrentThreadIdentityIfPresent();
58
+ assert(identity != nullptr);
59
+ const bool is_idle = identity->is_idle.load(std::memory_order_relaxed);
60
+ const int ticker = identity->ticker.load(std::memory_order_relaxed);
61
+ const int wait_start = identity->wait_start.load(std::memory_order_relaxed);
62
+ if (!is_idle && ticker - wait_start > Waiter::kIdlePeriods) {
63
+ identity->is_idle.store(true, std::memory_order_relaxed);
64
+ }
65
+ }
66
+
67
+ #if ABSL_WAITER_MODE == ABSL_WAITER_MODE_FUTEX
68
+
69
+ // Some Android headers are missing these definitions even though they
70
+ // support these futex operations.
71
+ #ifdef __BIONIC__
72
+ #ifndef SYS_futex
73
+ #define SYS_futex __NR_futex
74
+ #endif
75
+ #ifndef FUTEX_WAIT_BITSET
76
+ #define FUTEX_WAIT_BITSET 9
77
+ #endif
78
+ #ifndef FUTEX_PRIVATE_FLAG
79
+ #define FUTEX_PRIVATE_FLAG 128
80
+ #endif
81
+ #ifndef FUTEX_CLOCK_REALTIME
82
+ #define FUTEX_CLOCK_REALTIME 256
83
+ #endif
84
+ #ifndef FUTEX_BITSET_MATCH_ANY
85
+ #define FUTEX_BITSET_MATCH_ANY 0xFFFFFFFF
86
+ #endif
87
+ #endif
88
+
89
+ class Futex {
90
+ public:
91
+ static int WaitUntil(std::atomic<int32_t> *v, int32_t val,
92
+ KernelTimeout t) {
93
+ int err = 0;
94
+ if (t.has_timeout()) {
95
+ // https://locklessinc.com/articles/futex_cheat_sheet/
96
+ // Unlike FUTEX_WAIT, FUTEX_WAIT_BITSET uses absolute time.
97
+ struct timespec abs_timeout = t.MakeAbsTimespec();
98
+ // Atomically check that the futex value is still 0, and if it
99
+ // is, sleep until abs_timeout or until woken by FUTEX_WAKE.
100
+ err = syscall(
101
+ SYS_futex, reinterpret_cast<int32_t *>(v),
102
+ FUTEX_WAIT_BITSET | FUTEX_PRIVATE_FLAG | FUTEX_CLOCK_REALTIME, val,
103
+ &abs_timeout, nullptr, FUTEX_BITSET_MATCH_ANY);
104
+ } else {
105
+ // Atomically check that the futex value is still 0, and if it
106
+ // is, sleep until woken by FUTEX_WAKE.
107
+ err = syscall(SYS_futex, reinterpret_cast<int32_t *>(v),
108
+ FUTEX_WAIT | FUTEX_PRIVATE_FLAG, val, nullptr);
109
+ }
110
+ if (err != 0) {
111
+ err = -errno;
112
+ }
113
+ return err;
114
+ }
115
+
116
+ static int Wake(std::atomic<int32_t> *v, int32_t count) {
117
+ int err = syscall(SYS_futex, reinterpret_cast<int32_t *>(v),
118
+ FUTEX_WAKE | FUTEX_PRIVATE_FLAG, count);
119
+ if (ABSL_PREDICT_FALSE(err < 0)) {
120
+ err = -errno;
121
+ }
122
+ return err;
123
+ }
124
+ };
125
+
126
+ Waiter::Waiter() {
127
+ futex_.store(0, std::memory_order_relaxed);
128
+ }
129
+
130
+ Waiter::~Waiter() = default;
131
+
132
+ bool Waiter::Wait(KernelTimeout t) {
133
+ // Loop until we can atomically decrement futex from a positive
134
+ // value, waiting on a futex while we believe it is zero.
135
+ // Note that, since the thread ticker is just reset, we don't need to check
136
+ // whether the thread is idle on the very first pass of the loop.
137
+ bool first_pass = true;
138
+ while (true) {
139
+ int32_t x = futex_.load(std::memory_order_relaxed);
140
+ while (x != 0) {
141
+ if (!futex_.compare_exchange_weak(x, x - 1,
142
+ std::memory_order_acquire,
143
+ std::memory_order_relaxed)) {
144
+ continue; // Raced with someone, retry.
145
+ }
146
+ return true; // Consumed a wakeup, we are done.
147
+ }
148
+
149
+
150
+ if (!first_pass) MaybeBecomeIdle();
151
+ const int err = Futex::WaitUntil(&futex_, 0, t);
152
+ if (err != 0) {
153
+ if (err == -EINTR || err == -EWOULDBLOCK) {
154
+ // Do nothing, the loop will retry.
155
+ } else if (err == -ETIMEDOUT) {
156
+ return false;
157
+ } else {
158
+ ABSL_RAW_LOG(FATAL, "Futex operation failed with error %d\n", err);
159
+ }
160
+ }
161
+ first_pass = false;
162
+ }
163
+ }
164
+
165
+ void Waiter::Post() {
166
+ if (futex_.fetch_add(1, std::memory_order_release) == 0) {
167
+ // We incremented from 0, need to wake a potential waiter.
168
+ Poke();
169
+ }
170
+ }
171
+
172
+ void Waiter::Poke() {
173
+ // Wake one thread waiting on the futex.
174
+ const int err = Futex::Wake(&futex_, 1);
175
+ if (ABSL_PREDICT_FALSE(err < 0)) {
176
+ ABSL_RAW_LOG(FATAL, "Futex operation failed with error %d\n", err);
177
+ }
178
+ }
179
+
180
+ #elif ABSL_WAITER_MODE == ABSL_WAITER_MODE_CONDVAR
181
+
182
+ class PthreadMutexHolder {
183
+ public:
184
+ explicit PthreadMutexHolder(pthread_mutex_t *mu) : mu_(mu) {
185
+ const int err = pthread_mutex_lock(mu_);
186
+ if (err != 0) {
187
+ ABSL_RAW_LOG(FATAL, "pthread_mutex_lock failed: %d", err);
188
+ }
189
+ }
190
+
191
+ PthreadMutexHolder(const PthreadMutexHolder &rhs) = delete;
192
+ PthreadMutexHolder &operator=(const PthreadMutexHolder &rhs) = delete;
193
+
194
+ ~PthreadMutexHolder() {
195
+ const int err = pthread_mutex_unlock(mu_);
196
+ if (err != 0) {
197
+ ABSL_RAW_LOG(FATAL, "pthread_mutex_unlock failed: %d", err);
198
+ }
199
+ }
200
+
201
+ private:
202
+ pthread_mutex_t *mu_;
203
+ };
204
+
205
+ Waiter::Waiter() {
206
+ const int err = pthread_mutex_init(&mu_, 0);
207
+ if (err != 0) {
208
+ ABSL_RAW_LOG(FATAL, "pthread_mutex_init failed: %d", err);
209
+ }
210
+
211
+ const int err2 = pthread_cond_init(&cv_, 0);
212
+ if (err2 != 0) {
213
+ ABSL_RAW_LOG(FATAL, "pthread_cond_init failed: %d", err2);
214
+ }
215
+
216
+ waiter_count_ = 0;
217
+ wakeup_count_ = 0;
218
+ }
219
+
220
+ Waiter::~Waiter() {
221
+ const int err = pthread_mutex_destroy(&mu_);
222
+ if (err != 0) {
223
+ ABSL_RAW_LOG(FATAL, "pthread_mutex_destroy failed: %d", err);
224
+ }
225
+
226
+ const int err2 = pthread_cond_destroy(&cv_);
227
+ if (err2 != 0) {
228
+ ABSL_RAW_LOG(FATAL, "pthread_cond_destroy failed: %d", err2);
229
+ }
230
+ }
231
+
232
+ bool Waiter::Wait(KernelTimeout t) {
233
+ struct timespec abs_timeout;
234
+ if (t.has_timeout()) {
235
+ abs_timeout = t.MakeAbsTimespec();
236
+ }
237
+
238
+ PthreadMutexHolder h(&mu_);
239
+ ++waiter_count_;
240
+ // Loop until we find a wakeup to consume or timeout.
241
+ // Note that, since the thread ticker is just reset, we don't need to check
242
+ // whether the thread is idle on the very first pass of the loop.
243
+ bool first_pass = true;
244
+ while (wakeup_count_ == 0) {
245
+ if (!first_pass) MaybeBecomeIdle();
246
+ // No wakeups available, time to wait.
247
+ if (!t.has_timeout()) {
248
+ const int err = pthread_cond_wait(&cv_, &mu_);
249
+ if (err != 0) {
250
+ ABSL_RAW_LOG(FATAL, "pthread_cond_wait failed: %d", err);
251
+ }
252
+ } else {
253
+ const int err = pthread_cond_timedwait(&cv_, &mu_, &abs_timeout);
254
+ if (err == ETIMEDOUT) {
255
+ --waiter_count_;
256
+ return false;
257
+ }
258
+ if (err != 0) {
259
+ ABSL_RAW_LOG(FATAL, "pthread_cond_timedwait failed: %d", err);
260
+ }
261
+ }
262
+ first_pass = false;
263
+ }
264
+ // Consume a wakeup and we're done.
265
+ --wakeup_count_;
266
+ --waiter_count_;
267
+ return true;
268
+ }
269
+
270
+ void Waiter::Post() {
271
+ PthreadMutexHolder h(&mu_);
272
+ ++wakeup_count_;
273
+ InternalCondVarPoke();
274
+ }
275
+
276
+ void Waiter::Poke() {
277
+ PthreadMutexHolder h(&mu_);
278
+ InternalCondVarPoke();
279
+ }
280
+
281
+ void Waiter::InternalCondVarPoke() {
282
+ if (waiter_count_ != 0) {
283
+ const int err = pthread_cond_signal(&cv_);
284
+ if (ABSL_PREDICT_FALSE(err != 0)) {
285
+ ABSL_RAW_LOG(FATAL, "pthread_cond_signal failed: %d", err);
286
+ }
287
+ }
288
+ }
289
+
290
+ #elif ABSL_WAITER_MODE == ABSL_WAITER_MODE_SEM
291
+
292
+ Waiter::Waiter() {
293
+ if (sem_init(&sem_, 0, 0) != 0) {
294
+ ABSL_RAW_LOG(FATAL, "sem_init failed with errno %d\n", errno);
295
+ }
296
+ wakeups_.store(0, std::memory_order_relaxed);
297
+ }
298
+
299
+ Waiter::~Waiter() {
300
+ if (sem_destroy(&sem_) != 0) {
301
+ ABSL_RAW_LOG(FATAL, "sem_destroy failed with errno %d\n", errno);
302
+ }
303
+ }
304
+
305
+ bool Waiter::Wait(KernelTimeout t) {
306
+ struct timespec abs_timeout;
307
+ if (t.has_timeout()) {
308
+ abs_timeout = t.MakeAbsTimespec();
309
+ }
310
+
311
+ // Loop until we timeout or consume a wakeup.
312
+ // Note that, since the thread ticker is just reset, we don't need to check
313
+ // whether the thread is idle on the very first pass of the loop.
314
+ bool first_pass = true;
315
+ while (true) {
316
+ int x = wakeups_.load(std::memory_order_relaxed);
317
+ while (x != 0) {
318
+ if (!wakeups_.compare_exchange_weak(x, x - 1,
319
+ std::memory_order_acquire,
320
+ std::memory_order_relaxed)) {
321
+ continue; // Raced with someone, retry.
322
+ }
323
+ // Successfully consumed a wakeup, we're done.
324
+ return true;
325
+ }
326
+
327
+ if (!first_pass) MaybeBecomeIdle();
328
+ // Nothing to consume, wait (looping on EINTR).
329
+ while (true) {
330
+ if (!t.has_timeout()) {
331
+ if (sem_wait(&sem_) == 0) break;
332
+ if (errno == EINTR) continue;
333
+ ABSL_RAW_LOG(FATAL, "sem_wait failed: %d", errno);
334
+ } else {
335
+ if (sem_timedwait(&sem_, &abs_timeout) == 0) break;
336
+ if (errno == EINTR) continue;
337
+ if (errno == ETIMEDOUT) return false;
338
+ ABSL_RAW_LOG(FATAL, "sem_timedwait failed: %d", errno);
339
+ }
340
+ }
341
+ first_pass = false;
342
+ }
343
+ }
344
+
345
+ void Waiter::Post() {
346
+ // Post a wakeup.
347
+ if (wakeups_.fetch_add(1, std::memory_order_release) == 0) {
348
+ // We incremented from 0, need to wake a potential waiter.
349
+ Poke();
350
+ }
351
+ }
352
+
353
+ void Waiter::Poke() {
354
+ if (sem_post(&sem_) != 0) { // Wake any semaphore waiter.
355
+ ABSL_RAW_LOG(FATAL, "sem_post failed with errno %d\n", errno);
356
+ }
357
+ }
358
+
359
+ #elif ABSL_WAITER_MODE == ABSL_WAITER_MODE_WIN32
360
+
361
+ class Waiter::WinHelper {
362
+ public:
363
+ static SRWLOCK *GetLock(Waiter *w) {
364
+ return reinterpret_cast<SRWLOCK *>(&w->mu_storage_);
365
+ }
366
+
367
+ static CONDITION_VARIABLE *GetCond(Waiter *w) {
368
+ return reinterpret_cast<CONDITION_VARIABLE *>(&w->cv_storage_);
369
+ }
370
+
371
+ static_assert(sizeof(SRWLOCK) == sizeof(void *),
372
+ "`mu_storage_` does not have the same size as SRWLOCK");
373
+ static_assert(alignof(SRWLOCK) == alignof(void *),
374
+ "`mu_storage_` does not have the same alignment as SRWLOCK");
375
+
376
+ static_assert(sizeof(CONDITION_VARIABLE) == sizeof(void *),
377
+ "`ABSL_CONDITION_VARIABLE_STORAGE` does not have the same size "
378
+ "as `CONDITION_VARIABLE`");
379
+ static_assert(
380
+ alignof(CONDITION_VARIABLE) == alignof(void *),
381
+ "`cv_storage_` does not have the same alignment as `CONDITION_VARIABLE`");
382
+
383
+ // The SRWLOCK and CONDITION_VARIABLE types must be trivially constructible
384
+ // and destructible because we never call their constructors or destructors.
385
+ static_assert(std::is_trivially_constructible<SRWLOCK>::value,
386
+ "The `SRWLOCK` type must be trivially constructible");
387
+ static_assert(
388
+ std::is_trivially_constructible<CONDITION_VARIABLE>::value,
389
+ "The `CONDITION_VARIABLE` type must be trivially constructible");
390
+ static_assert(std::is_trivially_destructible<SRWLOCK>::value,
391
+ "The `SRWLOCK` type must be trivially destructible");
392
+ static_assert(std::is_trivially_destructible<CONDITION_VARIABLE>::value,
393
+ "The `CONDITION_VARIABLE` type must be trivially destructible");
394
+ };
395
+
396
+ class LockHolder {
397
+ public:
398
+ explicit LockHolder(SRWLOCK* mu) : mu_(mu) {
399
+ AcquireSRWLockExclusive(mu_);
400
+ }
401
+
402
+ LockHolder(const LockHolder&) = delete;
403
+ LockHolder& operator=(const LockHolder&) = delete;
404
+
405
+ ~LockHolder() {
406
+ ReleaseSRWLockExclusive(mu_);
407
+ }
408
+
409
+ private:
410
+ SRWLOCK* mu_;
411
+ };
412
+
413
+ Waiter::Waiter() {
414
+ auto *mu = ::new (static_cast<void *>(&mu_storage_)) SRWLOCK;
415
+ auto *cv = ::new (static_cast<void *>(&cv_storage_)) CONDITION_VARIABLE;
416
+ InitializeSRWLock(mu);
417
+ InitializeConditionVariable(cv);
418
+ waiter_count_ = 0;
419
+ wakeup_count_ = 0;
420
+ }
421
+
422
+ // SRW locks and condition variables do not need to be explicitly destroyed.
423
+ // https://docs.microsoft.com/en-us/windows/win32/api/synchapi/nf-synchapi-initializesrwlock
424
+ // https://stackoverflow.com/questions/28975958/why-does-windows-have-no-deleteconditionvariable-function-to-go-together-with
425
+ Waiter::~Waiter() = default;
426
+
427
+ bool Waiter::Wait(KernelTimeout t) {
428
+ SRWLOCK *mu = WinHelper::GetLock(this);
429
+ CONDITION_VARIABLE *cv = WinHelper::GetCond(this);
430
+
431
+ LockHolder h(mu);
432
+ ++waiter_count_;
433
+
434
+ // Loop until we find a wakeup to consume or timeout.
435
+ // Note that, since the thread ticker is just reset, we don't need to check
436
+ // whether the thread is idle on the very first pass of the loop.
437
+ bool first_pass = true;
438
+ while (wakeup_count_ == 0) {
439
+ if (!first_pass) MaybeBecomeIdle();
440
+ // No wakeups available, time to wait.
441
+ if (!SleepConditionVariableSRW(cv, mu, t.InMillisecondsFromNow(), 0)) {
442
+ // GetLastError() returns a Win32 DWORD, but we assign to
443
+ // unsigned long to simplify the ABSL_RAW_LOG case below. The uniform
444
+ // initialization guarantees this is not a narrowing conversion.
445
+ const unsigned long err{GetLastError()}; // NOLINT(runtime/int)
446
+ if (err == ERROR_TIMEOUT) {
447
+ --waiter_count_;
448
+ return false;
449
+ } else {
450
+ ABSL_RAW_LOG(FATAL, "SleepConditionVariableSRW failed: %lu", err);
451
+ }
452
+ }
453
+ first_pass = false;
454
+ }
455
+ // Consume a wakeup and we're done.
456
+ --wakeup_count_;
457
+ --waiter_count_;
458
+ return true;
459
+ }
460
+
461
+ void Waiter::Post() {
462
+ LockHolder h(WinHelper::GetLock(this));
463
+ ++wakeup_count_;
464
+ InternalCondVarPoke();
465
+ }
466
+
467
+ void Waiter::Poke() {
468
+ LockHolder h(WinHelper::GetLock(this));
469
+ InternalCondVarPoke();
470
+ }
471
+
472
+ void Waiter::InternalCondVarPoke() {
473
+ if (waiter_count_ != 0) {
474
+ WakeConditionVariable(WinHelper::GetCond(this));
475
+ }
476
+ }
477
+
478
+ #else
479
+ #error Unknown ABSL_WAITER_MODE
480
+ #endif
481
+
482
+ } // namespace synchronization_internal
483
+ ABSL_NAMESPACE_END
484
+ } // namespace absl