grpc 1.31.1 → 1.35.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 (1104) hide show
  1. checksums.yaml +4 -4
  2. data/Makefile +719 -17819
  3. data/etc/roots.pem +257 -573
  4. data/include/grpc/compression.h +1 -1
  5. data/include/grpc/grpc.h +15 -7
  6. data/include/grpc/grpc_security.h +254 -186
  7. data/include/grpc/impl/codegen/README.md +22 -0
  8. data/include/grpc/impl/codegen/atm_windows.h +4 -0
  9. data/include/grpc/impl/codegen/byte_buffer.h +1 -1
  10. data/include/grpc/impl/codegen/grpc_types.h +10 -8
  11. data/include/grpc/impl/codegen/log.h +0 -2
  12. data/include/grpc/impl/codegen/port_platform.h +28 -56
  13. data/include/grpc/impl/codegen/sync_windows.h +4 -0
  14. data/include/grpc/slice_buffer.h +3 -3
  15. data/include/grpc/support/sync.h +3 -3
  16. data/include/grpc/support/time.h +7 -7
  17. data/src/core/ext/filters/client_channel/backend_metric.cc +2 -4
  18. data/src/core/ext/filters/client_channel/backup_poller.cc +3 -2
  19. data/src/core/ext/filters/client_channel/client_channel.cc +2831 -1540
  20. data/src/core/ext/filters/client_channel/client_channel.h +1 -5
  21. data/src/core/ext/filters/client_channel/client_channel_channelz.h +0 -3
  22. data/src/core/ext/filters/client_channel/client_channel_plugin.cc +1 -1
  23. data/src/core/ext/filters/client_channel/config_selector.cc +0 -4
  24. data/src/core/ext/filters/client_channel/config_selector.h +40 -8
  25. data/src/core/ext/filters/client_channel/dynamic_filters.cc +186 -0
  26. data/src/core/ext/filters/client_channel/dynamic_filters.h +99 -0
  27. data/src/core/ext/filters/client_channel/health/health_check_client.cc +16 -8
  28. data/src/core/ext/filters/client_channel/health/health_check_client.h +4 -4
  29. data/src/core/ext/filters/client_channel/http_connect_handshaker.cc +7 -9
  30. data/src/core/ext/filters/client_channel/http_proxy.cc +21 -20
  31. data/src/core/ext/filters/client_channel/lb_policy.cc +6 -2
  32. data/src/core/ext/filters/client_channel/lb_policy.h +8 -7
  33. data/src/core/ext/filters/client_channel/lb_policy/address_filtering.cc +48 -35
  34. data/src/core/ext/filters/client_channel/lb_policy/address_filtering.h +7 -5
  35. data/src/core/ext/filters/client_channel/lb_policy/child_policy_handler.cc +10 -7
  36. data/src/core/ext/filters/client_channel/lb_policy/child_policy_handler.h +1 -1
  37. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb.cc +210 -192
  38. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_balancer_addresses.cc +0 -13
  39. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_balancer_addresses.h +0 -3
  40. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_channel_secure.cc +1 -37
  41. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_client_stats.cc +3 -1
  42. data/src/core/ext/filters/client_channel/lb_policy/grpclb/load_balancer_api.cc +3 -3
  43. data/src/core/ext/filters/client_channel/lb_policy/grpclb/load_balancer_api.h +1 -1
  44. data/src/core/ext/filters/client_channel/lb_policy/pick_first/pick_first.cc +23 -17
  45. data/src/core/ext/filters/client_channel/lb_policy/priority/priority.cc +79 -30
  46. data/src/core/ext/filters/client_channel/lb_policy/round_robin/round_robin.cc +10 -9
  47. data/src/core/ext/filters/client_channel/lb_policy/subchannel_list.h +14 -34
  48. data/src/core/ext/filters/client_channel/lb_policy/weighted_target/weighted_target.cc +26 -15
  49. data/src/core/ext/filters/client_channel/lb_policy/xds/cds.cc +350 -130
  50. data/src/core/ext/filters/client_channel/lb_policy/xds/xds.h +52 -24
  51. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_channel_args.h +24 -0
  52. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_impl.cc +812 -0
  53. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_manager.cc +722 -0
  54. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_resolver.cc +1262 -0
  55. data/src/core/ext/filters/client_channel/lb_policy_registry.cc +8 -1
  56. data/src/core/ext/filters/client_channel/resolver.cc +3 -1
  57. data/src/core/ext/filters/client_channel/resolver.h +4 -1
  58. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/dns_resolver_ares.cc +9 -16
  59. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver.h +1 -32
  60. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver_posix.cc +3 -3
  61. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.cc +457 -19
  62. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.h +5 -0
  63. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper_libuv.cc +1 -1
  64. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper_windows.cc +1 -1
  65. data/src/core/ext/filters/client_channel/resolver/dns/native/dns_resolver.cc +7 -10
  66. data/src/core/ext/filters/client_channel/resolver/fake/fake_resolver.cc +4 -4
  67. data/src/core/ext/filters/client_channel/resolver/fake/fake_resolver.h +1 -1
  68. data/src/core/ext/filters/client_channel/resolver/sockaddr/sockaddr_resolver.cc +35 -28
  69. data/src/core/ext/filters/client_channel/resolver/xds/xds_resolver.cc +664 -63
  70. data/src/core/ext/filters/client_channel/resolver/xds/xds_resolver.h +28 -0
  71. data/src/core/ext/filters/client_channel/resolver_factory.h +6 -6
  72. data/src/core/ext/filters/client_channel/resolver_registry.cc +40 -39
  73. data/src/core/ext/filters/client_channel/resolver_registry.h +2 -2
  74. data/src/core/ext/filters/client_channel/resolver_result_parsing.cc +29 -74
  75. data/src/core/ext/filters/client_channel/resolver_result_parsing.h +12 -11
  76. data/src/core/ext/filters/client_channel/retry_throttle.cc +5 -3
  77. data/src/core/ext/filters/client_channel/retry_throttle.h +4 -2
  78. data/src/core/ext/filters/client_channel/server_address.cc +120 -7
  79. data/src/core/ext/filters/client_channel/server_address.h +44 -21
  80. data/src/core/ext/filters/client_channel/service_config.cc +18 -13
  81. data/src/core/ext/filters/client_channel/service_config.h +8 -5
  82. data/src/core/ext/filters/client_channel/service_config_call_data.h +19 -1
  83. data/src/core/ext/filters/client_channel/service_config_channel_arg_filter.cc +2 -2
  84. data/src/core/ext/filters/client_channel/service_config_parser.cc +8 -6
  85. data/src/core/ext/filters/client_channel/service_config_parser.h +8 -5
  86. data/src/core/ext/filters/client_channel/subchannel.cc +115 -87
  87. data/src/core/ext/filters/client_channel/subchannel.h +30 -24
  88. data/src/core/ext/filters/client_channel/subchannel_interface.h +41 -5
  89. data/src/core/ext/filters/client_channel/subchannel_pool_interface.h +6 -2
  90. data/src/core/ext/filters/deadline/deadline_filter.cc +87 -79
  91. data/src/core/ext/filters/deadline/deadline_filter.h +7 -11
  92. data/src/core/ext/filters/http/client/http_client_filter.cc +1 -1
  93. data/src/core/ext/filters/http/client_authority_filter.cc +6 -6
  94. data/src/core/ext/filters/http/http_filters_plugin.cc +6 -3
  95. data/src/core/ext/filters/http/server/http_server_filter.cc +3 -3
  96. data/src/core/ext/filters/max_age/max_age_filter.cc +3 -2
  97. data/src/core/ext/filters/message_size/message_size_filter.cc +3 -2
  98. data/src/core/ext/filters/message_size/message_size_filter.h +2 -1
  99. data/src/core/ext/filters/workarounds/workaround_utils.cc +1 -1
  100. data/src/core/ext/transport/chttp2/client/authority.cc +3 -3
  101. data/src/core/ext/transport/chttp2/client/chttp2_connector.cc +87 -31
  102. data/src/core/ext/transport/chttp2/client/chttp2_connector.h +19 -2
  103. data/src/core/ext/transport/chttp2/client/insecure/channel_create.cc +20 -8
  104. data/src/core/ext/transport/chttp2/client/insecure/channel_create_posix.cc +21 -10
  105. data/src/core/ext/transport/chttp2/client/secure/secure_channel_create.cc +34 -47
  106. data/src/core/ext/transport/chttp2/server/chttp2_server.cc +200 -100
  107. data/src/core/ext/transport/chttp2/server/chttp2_server.h +2 -1
  108. data/src/core/ext/transport/chttp2/server/insecure/server_chttp2.cc +2 -2
  109. data/src/core/ext/transport/chttp2/server/insecure/server_chttp2_posix.cc +16 -9
  110. data/src/core/ext/transport/chttp2/server/secure/server_secure_chttp2.cc +3 -2
  111. data/src/core/ext/transport/chttp2/transport/bin_decoder.cc +7 -7
  112. data/src/core/ext/transport/chttp2/transport/chttp2_transport.cc +267 -319
  113. data/src/core/ext/transport/chttp2/transport/flow_control.cc +11 -3
  114. data/src/core/ext/transport/chttp2/transport/flow_control.h +13 -3
  115. data/src/core/ext/transport/chttp2/transport/frame_goaway.cc +2 -1
  116. data/src/core/ext/transport/chttp2/transport/frame_settings.cc +2 -2
  117. data/src/core/ext/transport/chttp2/transport/frame_settings.h +2 -1
  118. data/src/core/ext/transport/chttp2/transport/frame_window_update.cc +6 -6
  119. data/src/core/ext/transport/chttp2/transport/hpack_parser.cc +12 -8
  120. data/src/core/ext/transport/chttp2/transport/internal.h +10 -2
  121. data/src/core/ext/transport/chttp2/transport/parsing.cc +19 -31
  122. data/src/core/ext/transport/chttp2/transport/writing.cc +8 -8
  123. data/src/core/ext/transport/inproc/inproc_transport.cc +52 -18
  124. data/src/core/ext/upb-generated/envoy/annotations/deprecation.upb.h +1 -0
  125. data/src/core/ext/upb-generated/envoy/annotations/resource.upb.c +1 -1
  126. data/src/core/ext/upb-generated/envoy/annotations/resource.upb.h +7 -0
  127. data/src/core/ext/upb-generated/envoy/config/accesslog/v3/accesslog.upb.c +244 -0
  128. data/src/core/ext/upb-generated/envoy/config/accesslog/v3/accesslog.upb.h +865 -0
  129. data/src/core/ext/upb-generated/envoy/config/cluster/v3/circuit_breaker.upb.c +74 -0
  130. data/src/core/ext/upb-generated/envoy/config/cluster/v3/circuit_breaker.upb.h +253 -0
  131. data/src/core/ext/upb-generated/envoy/config/cluster/v3/cluster.upb.c +458 -0
  132. data/src/core/ext/upb-generated/envoy/config/cluster/v3/cluster.upb.h +1818 -0
  133. data/src/core/ext/upb-generated/envoy/config/cluster/v3/filter.upb.c +35 -0
  134. data/src/core/ext/upb-generated/envoy/config/cluster/v3/filter.upb.h +77 -0
  135. data/src/core/ext/upb-generated/envoy/config/cluster/v3/outlier_detection.upb.c +55 -0
  136. data/src/core/ext/upb-generated/envoy/config/cluster/v3/outlier_detection.upb.h +349 -0
  137. data/src/core/ext/upb-generated/envoy/config/core/v3/address.upb.c +124 -0
  138. data/src/core/ext/upb-generated/envoy/config/core/v3/address.upb.h +428 -0
  139. data/src/core/ext/upb-generated/envoy/config/core/v3/backoff.upb.c +35 -0
  140. data/src/core/ext/upb-generated/envoy/config/core/v3/backoff.upb.h +88 -0
  141. data/src/core/ext/upb-generated/envoy/config/core/v3/base.upb.c +310 -0
  142. data/src/core/ext/upb-generated/envoy/config/core/v3/base.upb.h +991 -0
  143. data/src/core/ext/upb-generated/envoy/config/core/v3/config_source.upb.c +103 -0
  144. data/src/core/ext/upb-generated/envoy/config/core/v3/config_source.upb.h +388 -0
  145. data/src/core/ext/upb-generated/envoy/config/core/v3/event_service_config.upb.c +34 -0
  146. data/src/core/ext/upb-generated/envoy/config/core/v3/event_service_config.upb.h +78 -0
  147. data/src/core/ext/upb-generated/envoy/config/core/v3/extension.upb.c +53 -0
  148. data/src/core/ext/upb-generated/envoy/config/core/v3/extension.upb.h +149 -0
  149. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_service.upb.c +241 -0
  150. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_service.upb.h +839 -0
  151. data/src/core/ext/upb-generated/envoy/config/core/v3/health_check.upb.c +170 -0
  152. data/src/core/ext/upb-generated/envoy/config/core/v3/health_check.upb.h +752 -0
  153. data/src/core/ext/upb-generated/envoy/config/core/v3/http_uri.upb.c +36 -0
  154. data/src/core/ext/upb-generated/envoy/config/core/v3/http_uri.upb.h +88 -0
  155. data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.c +176 -0
  156. data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.h +730 -0
  157. data/src/core/ext/upb-generated/envoy/config/core/v3/proxy_protocol.upb.c +28 -0
  158. data/src/core/ext/upb-generated/envoy/config/core/v3/proxy_protocol.upb.h +65 -0
  159. data/src/core/ext/upb-generated/envoy/{api/v2/core → config/core/v3}/socket_option.upb.c +8 -8
  160. data/src/core/ext/upb-generated/envoy/config/core/v3/socket_option.upb.h +95 -0
  161. data/src/core/ext/upb-generated/envoy/config/core/v3/substitution_format_string.upb.c +36 -0
  162. data/src/core/ext/upb-generated/envoy/config/core/v3/substitution_format_string.upb.h +92 -0
  163. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint.upb.c +91 -0
  164. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint.upb.h +243 -0
  165. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint_components.upb.c +91 -0
  166. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint_components.upb.h +305 -0
  167. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/load_report.upb.c +112 -0
  168. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/load_report.upb.h +367 -0
  169. data/src/core/ext/upb-generated/envoy/config/listener/v3/api_listener.upb.c +33 -0
  170. data/src/core/ext/upb-generated/envoy/config/listener/v3/api_listener.upb.h +73 -0
  171. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener.upb.c +128 -0
  172. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener.upb.h +512 -0
  173. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener_components.upb.c +155 -0
  174. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener_components.upb.h +591 -0
  175. data/src/core/ext/upb-generated/envoy/config/listener/v3/udp_listener_config.upb.c +41 -0
  176. data/src/core/ext/upb-generated/envoy/config/listener/v3/udp_listener_config.upb.h +107 -0
  177. data/src/core/ext/upb-generated/envoy/config/rbac/v3/rbac.upb.c +178 -0
  178. data/src/core/ext/upb-generated/envoy/config/rbac/v3/rbac.upb.h +662 -0
  179. data/src/core/ext/upb-generated/envoy/config/route/v3/route.upb.c +63 -0
  180. data/src/core/ext/upb-generated/envoy/config/route/v3/route.upb.h +220 -0
  181. data/src/core/ext/upb-generated/envoy/config/route/v3/route_components.upb.c +900 -0
  182. data/src/core/ext/upb-generated/envoy/config/route/v3/route_components.upb.h +3640 -0
  183. data/src/core/ext/upb-generated/envoy/config/route/v3/scoped_route.upb.c +60 -0
  184. data/src/core/ext/upb-generated/envoy/config/route/v3/scoped_route.upb.h +159 -0
  185. data/src/core/ext/upb-generated/envoy/config/trace/v3/http_tracer.upb.c +50 -0
  186. data/src/core/ext/upb-generated/envoy/config/trace/v3/http_tracer.upb.h +122 -0
  187. data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.c +364 -0
  188. data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.h +1475 -0
  189. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/cert.upb.c +20 -0
  190. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/cert.upb.h +35 -0
  191. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/common.upb.c +110 -0
  192. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/common.upb.h +426 -0
  193. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/secret.upb.c +76 -0
  194. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/secret.upb.h +236 -0
  195. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls.upb.c +147 -0
  196. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls.upb.h +621 -0
  197. data/src/core/ext/upb-generated/envoy/{api/v2 → service/cluster/v3}/cds.upb.c +6 -7
  198. data/src/core/ext/upb-generated/envoy/service/cluster/v3/cds.upb.h +56 -0
  199. data/src/core/ext/upb-generated/envoy/service/discovery/{v2 → v3}/ads.upb.c +6 -5
  200. data/src/core/ext/upb-generated/envoy/service/discovery/v3/ads.upb.h +56 -0
  201. data/src/core/ext/upb-generated/envoy/service/discovery/v3/discovery.upb.c +139 -0
  202. data/src/core/ext/upb-generated/envoy/service/discovery/v3/discovery.upb.h +487 -0
  203. data/src/core/ext/upb-generated/envoy/{api/v2 → service/endpoint/v3}/eds.upb.c +6 -7
  204. data/src/core/ext/upb-generated/envoy/service/endpoint/v3/eds.upb.h +56 -0
  205. data/src/core/ext/upb-generated/envoy/{api/v2 → service/listener/v3}/lds.upb.c +6 -7
  206. data/src/core/ext/upb-generated/envoy/service/listener/v3/lds.upb.h +56 -0
  207. data/src/core/ext/upb-generated/envoy/service/load_stats/v3/lrs.upb.c +55 -0
  208. data/src/core/ext/upb-generated/envoy/service/load_stats/v3/lrs.upb.h +151 -0
  209. data/src/core/ext/upb-generated/envoy/{api/v2 → service/route/v3}/rds.upb.c +6 -7
  210. data/src/core/ext/upb-generated/envoy/service/route/v3/rds.upb.h +56 -0
  211. data/src/core/ext/upb-generated/envoy/{api/v2 → service/route/v3}/srds.upb.c +6 -7
  212. data/src/core/ext/upb-generated/envoy/service/route/v3/srds.upb.h +56 -0
  213. data/src/core/ext/upb-generated/envoy/type/matcher/v3/metadata.upb.c +47 -0
  214. data/src/core/ext/upb-generated/envoy/type/matcher/v3/metadata.upb.h +128 -0
  215. data/src/core/ext/upb-generated/envoy/type/matcher/v3/number.upb.c +35 -0
  216. data/src/core/ext/upb-generated/envoy/type/matcher/v3/number.upb.h +84 -0
  217. data/src/core/ext/upb-generated/envoy/type/matcher/v3/path.upb.c +34 -0
  218. data/src/core/ext/upb-generated/envoy/type/matcher/v3/path.upb.h +78 -0
  219. data/src/core/ext/upb-generated/envoy/type/matcher/v3/regex.upb.c +64 -0
  220. data/src/core/ext/upb-generated/envoy/type/matcher/v3/regex.upb.h +166 -0
  221. data/src/core/ext/upb-generated/envoy/type/matcher/v3/string.upb.c +54 -0
  222. data/src/core/ext/upb-generated/envoy/type/matcher/v3/string.upb.h +146 -0
  223. data/src/core/ext/upb-generated/envoy/type/matcher/v3/value.upb.c +63 -0
  224. data/src/core/ext/upb-generated/envoy/type/matcher/v3/value.upb.h +207 -0
  225. data/src/core/ext/upb-generated/envoy/type/metadata/v3/metadata.upb.c +88 -0
  226. data/src/core/ext/upb-generated/envoy/type/metadata/v3/metadata.upb.h +301 -0
  227. data/src/core/ext/upb-generated/envoy/type/tracing/v3/custom_tag.upb.c +90 -0
  228. data/src/core/ext/upb-generated/envoy/type/tracing/v3/custom_tag.upb.h +283 -0
  229. data/src/core/ext/upb-generated/envoy/type/{http.upb.c → v3/http.upb.c} +2 -2
  230. data/src/core/ext/upb-generated/envoy/type/{http.upb.h → v3/http.upb.h} +9 -8
  231. data/src/core/ext/upb-generated/envoy/type/v3/percent.upb.c +40 -0
  232. data/src/core/ext/upb-generated/envoy/type/v3/percent.upb.h +99 -0
  233. data/src/core/ext/upb-generated/envoy/type/v3/range.upb.c +51 -0
  234. data/src/core/ext/upb-generated/envoy/type/v3/range.upb.h +130 -0
  235. data/src/core/ext/upb-generated/envoy/type/{semantic_version.upb.c → v3/semantic_version.upb.c} +7 -6
  236. data/src/core/ext/upb-generated/envoy/type/v3/semantic_version.upb.h +68 -0
  237. data/src/core/ext/upb-generated/google/api/annotations.upb.h +1 -0
  238. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/checked.upb.c +242 -0
  239. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/checked.upb.h +830 -0
  240. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/syntax.upb.c +234 -0
  241. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/syntax.upb.h +842 -0
  242. data/src/core/ext/upb-generated/google/api/http.upb.c +3 -3
  243. data/src/core/ext/upb-generated/google/api/http.upb.h +25 -6
  244. data/src/core/ext/upb-generated/google/protobuf/any.upb.c +1 -1
  245. data/src/core/ext/upb-generated/google/protobuf/any.upb.h +7 -0
  246. data/src/core/ext/upb-generated/google/protobuf/descriptor.upb.c +103 -103
  247. data/src/core/ext/upb-generated/google/protobuf/descriptor.upb.h +455 -292
  248. data/src/core/ext/upb-generated/google/protobuf/duration.upb.c +1 -1
  249. data/src/core/ext/upb-generated/google/protobuf/duration.upb.h +7 -0
  250. data/src/core/ext/upb-generated/google/protobuf/empty.upb.c +1 -1
  251. data/src/core/ext/upb-generated/google/protobuf/empty.upb.h +7 -0
  252. data/src/core/ext/upb-generated/google/protobuf/struct.upb.c +4 -4
  253. data/src/core/ext/upb-generated/google/protobuf/struct.upb.h +23 -4
  254. data/src/core/ext/upb-generated/google/protobuf/timestamp.upb.c +1 -1
  255. data/src/core/ext/upb-generated/google/protobuf/timestamp.upb.h +7 -0
  256. data/src/core/ext/upb-generated/google/protobuf/wrappers.upb.c +9 -9
  257. data/src/core/ext/upb-generated/google/protobuf/wrappers.upb.h +55 -0
  258. data/src/core/ext/upb-generated/google/rpc/status.upb.c +1 -1
  259. data/src/core/ext/upb-generated/google/rpc/status.upb.h +10 -3
  260. data/src/core/ext/upb-generated/src/proto/grpc/gcp/altscontext.upb.c +4 -4
  261. data/src/core/ext/upb-generated/src/proto/grpc/gcp/altscontext.upb.h +11 -3
  262. data/src/core/ext/upb-generated/src/proto/grpc/gcp/handshaker.upb.c +41 -41
  263. data/src/core/ext/upb-generated/src/proto/grpc/gcp/handshaker.upb.h +149 -76
  264. data/src/core/ext/upb-generated/src/proto/grpc/gcp/transport_security_common.upb.c +5 -5
  265. data/src/core/ext/upb-generated/src/proto/grpc/gcp/transport_security_common.upb.h +21 -6
  266. data/src/core/ext/upb-generated/src/proto/grpc/health/v1/health.upb.c +2 -2
  267. data/src/core/ext/upb-generated/src/proto/grpc/health/v1/health.upb.h +13 -0
  268. data/src/core/ext/upb-generated/src/proto/grpc/lb/v1/load_balancer.upb.c +17 -17
  269. data/src/core/ext/upb-generated/src/proto/grpc/lb/v1/load_balancer.upb.h +82 -25
  270. data/src/core/ext/upb-generated/udpa/annotations/migrate.upb.c +3 -3
  271. data/src/core/ext/upb-generated/udpa/annotations/migrate.upb.h +19 -0
  272. data/src/core/ext/upb-generated/udpa/annotations/security.upb.c +31 -0
  273. data/src/core/ext/upb-generated/udpa/annotations/security.upb.h +64 -0
  274. data/src/core/ext/upb-generated/udpa/annotations/sensitive.upb.h +1 -0
  275. data/src/core/ext/upb-generated/udpa/annotations/status.upb.c +2 -2
  276. data/src/core/ext/upb-generated/udpa/annotations/status.upb.h +9 -2
  277. data/src/core/ext/upb-generated/udpa/annotations/versioning.upb.c +27 -0
  278. data/src/core/ext/upb-generated/udpa/annotations/versioning.upb.h +60 -0
  279. data/src/core/ext/upb-generated/udpa/core/v1/authority.upb.c +28 -0
  280. data/src/core/ext/upb-generated/udpa/core/v1/authority.upb.h +60 -0
  281. data/src/core/ext/upb-generated/udpa/core/v1/collection_entry.upb.c +52 -0
  282. data/src/core/ext/upb-generated/udpa/core/v1/collection_entry.upb.h +143 -0
  283. data/src/core/ext/upb-generated/udpa/core/v1/context_params.upb.c +42 -0
  284. data/src/core/ext/upb-generated/udpa/core/v1/context_params.upb.h +84 -0
  285. data/src/core/ext/upb-generated/udpa/core/v1/resource.upb.c +36 -0
  286. data/src/core/ext/upb-generated/udpa/core/v1/resource.upb.h +94 -0
  287. data/src/core/ext/upb-generated/udpa/core/v1/resource_locator.upb.c +54 -0
  288. data/src/core/ext/upb-generated/udpa/core/v1/resource_locator.upb.h +173 -0
  289. data/src/core/ext/upb-generated/udpa/core/v1/resource_name.upb.c +36 -0
  290. data/src/core/ext/upb-generated/udpa/core/v1/resource_name.upb.h +92 -0
  291. data/src/core/ext/upb-generated/udpa/data/orca/v1/orca_load_report.upb.c +3 -3
  292. data/src/core/ext/upb-generated/udpa/data/orca/v1/orca_load_report.upb.h +7 -0
  293. data/src/core/ext/upb-generated/validate/validate.upb.c +68 -68
  294. data/src/core/ext/upb-generated/validate/validate.upb.h +296 -157
  295. data/src/core/ext/upbdefs-generated/envoy/annotations/deprecation.upbdefs.c +38 -0
  296. data/src/core/ext/upbdefs-generated/envoy/annotations/deprecation.upbdefs.h +30 -0
  297. data/src/core/ext/upbdefs-generated/envoy/annotations/resource.upbdefs.c +41 -0
  298. data/src/core/ext/upbdefs-generated/envoy/annotations/resource.upbdefs.h +35 -0
  299. data/src/core/ext/upbdefs-generated/envoy/config/accesslog/v3/accesslog.upbdefs.c +254 -0
  300. data/src/core/ext/upbdefs-generated/envoy/config/accesslog/v3/accesslog.upbdefs.h +105 -0
  301. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/circuit_breaker.upbdefs.c +100 -0
  302. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/circuit_breaker.upbdefs.h +45 -0
  303. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/cluster.upbdefs.c +558 -0
  304. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/cluster.upbdefs.h +145 -0
  305. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/filter.upbdefs.c +53 -0
  306. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/filter.upbdefs.h +35 -0
  307. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/outlier_detection.upbdefs.c +133 -0
  308. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/outlier_detection.upbdefs.h +35 -0
  309. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/address.upbdefs.c +127 -0
  310. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/address.upbdefs.h +65 -0
  311. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/backoff.upbdefs.c +56 -0
  312. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/backoff.upbdefs.h +35 -0
  313. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/base.upbdefs.c +266 -0
  314. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/base.upbdefs.h +125 -0
  315. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/config_source.upbdefs.c +143 -0
  316. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/config_source.upbdefs.h +55 -0
  317. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/event_service_config.upbdefs.c +56 -0
  318. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/event_service_config.upbdefs.h +35 -0
  319. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/extension.upbdefs.c +66 -0
  320. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/extension.upbdefs.h +40 -0
  321. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/grpc_service.upbdefs.c +263 -0
  322. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/grpc_service.upbdefs.h +100 -0
  323. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/health_check.upbdefs.c +233 -0
  324. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/health_check.upbdefs.h +70 -0
  325. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/http_uri.upbdefs.c +56 -0
  326. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/http_uri.upbdefs.h +35 -0
  327. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/protocol.upbdefs.c +228 -0
  328. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/protocol.upbdefs.h +80 -0
  329. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/proxy_protocol.upbdefs.c +46 -0
  330. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/proxy_protocol.upbdefs.h +35 -0
  331. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/socket_option.upbdefs.c +59 -0
  332. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/socket_option.upbdefs.h +35 -0
  333. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/substitution_format_string.upbdefs.c +55 -0
  334. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/substitution_format_string.upbdefs.h +35 -0
  335. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint.upbdefs.c +110 -0
  336. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint.upbdefs.h +50 -0
  337. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint_components.upbdefs.c +113 -0
  338. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint_components.upbdefs.h +50 -0
  339. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/load_report.upbdefs.c +146 -0
  340. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/load_report.upbdefs.h +55 -0
  341. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/api_listener.upbdefs.c +50 -0
  342. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/api_listener.upbdefs.h +35 -0
  343. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener.upbdefs.c +190 -0
  344. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener.upbdefs.h +55 -0
  345. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener_components.upbdefs.c +185 -0
  346. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener_components.upbdefs.h +65 -0
  347. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/udp_listener_config.upbdefs.c +62 -0
  348. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/udp_listener_config.upbdefs.h +40 -0
  349. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route.upbdefs.c +97 -0
  350. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route.upbdefs.h +40 -0
  351. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route_components.upbdefs.c +915 -0
  352. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route_components.upbdefs.h +280 -0
  353. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/scoped_route.upbdefs.c +71 -0
  354. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/scoped_route.upbdefs.h +45 -0
  355. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/http_tracer.upbdefs.c +64 -0
  356. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/http_tracer.upbdefs.h +40 -0
  357. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.c +511 -0
  358. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.h +115 -0
  359. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/cert.upbdefs.c +48 -0
  360. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/cert.upbdefs.h +30 -0
  361. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.c +166 -0
  362. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.h +55 -0
  363. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/secret.upbdefs.c +105 -0
  364. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/secret.upbdefs.h +45 -0
  365. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls.upbdefs.c +249 -0
  366. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls.upbdefs.h +60 -0
  367. data/src/core/ext/upbdefs-generated/envoy/service/cluster/v3/cds.upbdefs.c +72 -0
  368. data/src/core/ext/upbdefs-generated/envoy/service/cluster/v3/cds.upbdefs.h +35 -0
  369. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/ads.upbdefs.c +60 -0
  370. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/ads.upbdefs.h +35 -0
  371. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/discovery.upbdefs.c +152 -0
  372. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/discovery.upbdefs.h +60 -0
  373. data/src/core/ext/upbdefs-generated/envoy/service/endpoint/v3/eds.upbdefs.c +83 -0
  374. data/src/core/ext/upbdefs-generated/envoy/service/endpoint/v3/eds.upbdefs.h +35 -0
  375. data/src/core/ext/upbdefs-generated/envoy/service/listener/v3/lds.upbdefs.c +82 -0
  376. data/src/core/ext/upbdefs-generated/envoy/service/listener/v3/lds.upbdefs.h +35 -0
  377. data/src/core/ext/upbdefs-generated/envoy/service/load_stats/v3/lrs.upbdefs.c +83 -0
  378. data/src/core/ext/upbdefs-generated/envoy/service/load_stats/v3/lrs.upbdefs.h +40 -0
  379. data/src/core/ext/upbdefs-generated/envoy/service/route/v3/rds.upbdefs.c +86 -0
  380. data/src/core/ext/upbdefs-generated/envoy/service/route/v3/rds.upbdefs.h +35 -0
  381. data/src/core/ext/upbdefs-generated/envoy/service/route/v3/srds.upbdefs.c +74 -0
  382. data/src/core/ext/upbdefs-generated/envoy/service/route/v3/srds.upbdefs.h +35 -0
  383. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/metadata.upbdefs.c +64 -0
  384. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/metadata.upbdefs.h +40 -0
  385. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/number.upbdefs.c +54 -0
  386. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/number.upbdefs.h +35 -0
  387. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/path.upbdefs.c +53 -0
  388. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/path.upbdefs.h +35 -0
  389. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/regex.upbdefs.c +73 -0
  390. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/regex.upbdefs.h +45 -0
  391. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/string.upbdefs.c +72 -0
  392. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/string.upbdefs.h +40 -0
  393. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/value.upbdefs.c +81 -0
  394. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/value.upbdefs.h +45 -0
  395. data/src/core/ext/upbdefs-generated/envoy/type/metadata/v3/metadata.upbdefs.c +92 -0
  396. data/src/core/ext/upbdefs-generated/envoy/type/metadata/v3/metadata.upbdefs.h +65 -0
  397. data/src/core/ext/upbdefs-generated/envoy/type/tracing/v3/custom_tag.upbdefs.c +95 -0
  398. data/src/core/ext/upbdefs-generated/envoy/type/tracing/v3/custom_tag.upbdefs.h +55 -0
  399. data/src/core/ext/upbdefs-generated/envoy/type/v3/http.upbdefs.c +34 -0
  400. data/src/core/ext/{upb-generated/gogoproto/gogo.upb.h → upbdefs-generated/envoy/type/v3/http.upbdefs.h} +10 -9
  401. data/src/core/ext/upbdefs-generated/envoy/type/v3/percent.upbdefs.c +59 -0
  402. data/src/core/ext/upbdefs-generated/envoy/type/v3/percent.upbdefs.h +40 -0
  403. data/src/core/ext/upbdefs-generated/envoy/type/v3/range.upbdefs.c +54 -0
  404. data/src/core/ext/upbdefs-generated/envoy/type/v3/range.upbdefs.h +45 -0
  405. data/src/core/ext/upbdefs-generated/envoy/type/v3/semantic_version.upbdefs.c +47 -0
  406. data/src/core/ext/upbdefs-generated/envoy/type/v3/semantic_version.upbdefs.h +35 -0
  407. data/src/core/ext/upbdefs-generated/google/api/annotations.upbdefs.c +40 -0
  408. data/src/core/ext/upbdefs-generated/google/api/annotations.upbdefs.h +30 -0
  409. data/src/core/ext/upbdefs-generated/google/api/http.upbdefs.c +61 -0
  410. data/src/core/ext/upbdefs-generated/google/api/http.upbdefs.h +45 -0
  411. data/src/core/ext/upbdefs-generated/google/protobuf/any.upbdefs.c +38 -0
  412. data/src/core/ext/upbdefs-generated/google/protobuf/any.upbdefs.h +35 -0
  413. data/src/core/ext/upbdefs-generated/google/protobuf/descriptor.upbdefs.c +386 -0
  414. data/src/core/ext/upbdefs-generated/google/protobuf/descriptor.upbdefs.h +165 -0
  415. data/src/core/ext/upbdefs-generated/google/protobuf/duration.upbdefs.c +39 -0
  416. data/src/core/ext/upbdefs-generated/google/protobuf/duration.upbdefs.h +35 -0
  417. data/src/core/ext/upbdefs-generated/google/protobuf/empty.upbdefs.c +37 -0
  418. data/src/core/ext/upbdefs-generated/google/protobuf/empty.upbdefs.h +35 -0
  419. data/src/core/ext/upbdefs-generated/google/protobuf/struct.upbdefs.c +65 -0
  420. data/src/core/ext/upbdefs-generated/google/protobuf/struct.upbdefs.h +50 -0
  421. data/src/core/ext/upbdefs-generated/google/protobuf/timestamp.upbdefs.c +39 -0
  422. data/src/core/ext/upbdefs-generated/google/protobuf/timestamp.upbdefs.h +35 -0
  423. data/src/core/ext/upbdefs-generated/google/protobuf/wrappers.upbdefs.c +66 -0
  424. data/src/core/ext/upbdefs-generated/google/protobuf/wrappers.upbdefs.h +75 -0
  425. data/src/core/ext/upbdefs-generated/google/rpc/status.upbdefs.c +42 -0
  426. data/src/core/ext/upbdefs-generated/google/rpc/status.upbdefs.h +35 -0
  427. data/src/core/ext/upbdefs-generated/udpa/annotations/migrate.upbdefs.c +70 -0
  428. data/src/core/ext/upbdefs-generated/udpa/annotations/migrate.upbdefs.h +45 -0
  429. data/src/core/ext/upbdefs-generated/udpa/annotations/security.upbdefs.c +56 -0
  430. data/src/core/ext/upbdefs-generated/udpa/annotations/security.upbdefs.h +35 -0
  431. data/src/core/ext/upbdefs-generated/udpa/annotations/sensitive.upbdefs.c +33 -0
  432. data/src/core/ext/upbdefs-generated/udpa/annotations/sensitive.upbdefs.h +30 -0
  433. data/src/core/ext/upbdefs-generated/udpa/annotations/status.upbdefs.c +49 -0
  434. data/src/core/ext/upbdefs-generated/udpa/annotations/status.upbdefs.h +35 -0
  435. data/src/core/ext/upbdefs-generated/udpa/annotations/versioning.upbdefs.c +43 -0
  436. data/src/core/ext/upbdefs-generated/udpa/annotations/versioning.upbdefs.h +35 -0
  437. data/src/core/ext/upbdefs-generated/udpa/core/v1/authority.upbdefs.c +42 -0
  438. data/src/core/ext/upbdefs-generated/udpa/core/v1/authority.upbdefs.h +35 -0
  439. data/src/core/ext/upbdefs-generated/udpa/core/v1/collection_entry.upbdefs.c +62 -0
  440. data/src/core/ext/upbdefs-generated/udpa/core/v1/collection_entry.upbdefs.h +40 -0
  441. data/src/core/ext/upbdefs-generated/udpa/core/v1/context_params.upbdefs.c +45 -0
  442. data/src/core/ext/upbdefs-generated/udpa/core/v1/context_params.upbdefs.h +40 -0
  443. data/src/core/ext/upbdefs-generated/udpa/core/v1/resource.upbdefs.c +49 -0
  444. data/src/core/ext/upbdefs-generated/udpa/core/v1/resource.upbdefs.h +35 -0
  445. data/src/core/ext/upbdefs-generated/udpa/core/v1/resource_locator.upbdefs.c +68 -0
  446. data/src/core/ext/upbdefs-generated/udpa/core/v1/resource_locator.upbdefs.h +40 -0
  447. data/src/core/ext/upbdefs-generated/udpa/core/v1/resource_name.upbdefs.c +51 -0
  448. data/src/core/ext/upbdefs-generated/udpa/core/v1/resource_name.upbdefs.h +35 -0
  449. data/src/core/ext/upbdefs-generated/validate/validate.upbdefs.c +307 -0
  450. data/src/core/ext/upbdefs-generated/validate/validate.upbdefs.h +145 -0
  451. data/src/core/ext/xds/certificate_provider_factory.h +61 -0
  452. data/src/core/ext/xds/certificate_provider_registry.cc +103 -0
  453. data/src/core/ext/xds/certificate_provider_registry.h +57 -0
  454. data/src/core/ext/xds/certificate_provider_store.cc +87 -0
  455. data/src/core/ext/xds/certificate_provider_store.h +112 -0
  456. data/src/core/ext/xds/file_watcher_certificate_provider_factory.cc +144 -0
  457. data/src/core/ext/xds/file_watcher_certificate_provider_factory.h +69 -0
  458. data/src/core/ext/xds/xds_api.cc +2308 -0
  459. data/src/core/ext/xds/xds_api.h +469 -0
  460. data/src/core/ext/{filters/client_channel/xds → xds}/xds_bootstrap.cc +208 -19
  461. data/src/core/ext/{filters/client_channel/xds → xds}/xds_bootstrap.h +31 -11
  462. data/src/core/ext/xds/xds_certificate_provider.cc +299 -0
  463. data/src/core/ext/xds/xds_certificate_provider.h +112 -0
  464. data/src/core/ext/{filters/client_channel/xds → xds}/xds_channel_args.h +9 -6
  465. data/src/core/ext/{filters/client_channel/xds → xds}/xds_client.cc +656 -865
  466. data/src/core/ext/{filters/client_channel/xds → xds}/xds_client.h +126 -99
  467. data/src/core/ext/{filters/client_channel/xds → xds}/xds_client_stats.cc +61 -18
  468. data/src/core/ext/{filters/client_channel/xds → xds}/xds_client_stats.h +38 -10
  469. data/src/core/ext/xds/xds_server_config_fetcher.cc +131 -0
  470. data/src/core/lib/channel/channel_args.cc +9 -8
  471. data/src/core/lib/channel/channel_args.h +0 -1
  472. data/src/core/lib/channel/channel_trace.cc +4 -2
  473. data/src/core/lib/channel/channel_trace.h +1 -1
  474. data/src/core/lib/channel/channelz.cc +37 -74
  475. data/src/core/lib/channel/channelz.h +14 -23
  476. data/src/core/lib/channel/channelz_registry.cc +15 -12
  477. data/src/core/lib/channel/channelz_registry.h +3 -1
  478. data/src/core/lib/channel/handshaker.cc +2 -2
  479. data/src/core/lib/channel/handshaker.h +2 -2
  480. data/src/core/lib/compression/compression.cc +8 -4
  481. data/src/core/lib/compression/compression_args.cc +3 -2
  482. data/src/core/lib/compression/compression_internal.cc +10 -5
  483. data/src/core/lib/compression/compression_internal.h +2 -1
  484. data/src/core/lib/compression/stream_compression_identity.cc +1 -3
  485. data/src/core/lib/debug/stats.h +2 -2
  486. data/src/core/lib/debug/stats_data.cc +1 -0
  487. data/src/core/lib/debug/stats_data.h +13 -13
  488. data/src/core/lib/gpr/alloc.cc +3 -2
  489. data/src/core/lib/gpr/cpu_iphone.cc +10 -2
  490. data/src/core/lib/gpr/log.cc +53 -16
  491. data/src/core/lib/gpr/log_linux.cc +19 -3
  492. data/src/core/lib/gpr/log_posix.cc +15 -1
  493. data/src/core/lib/gpr/log_windows.cc +18 -4
  494. data/src/core/lib/gpr/murmur_hash.cc +1 -1
  495. data/src/core/lib/gpr/spinlock.h +10 -2
  496. data/src/core/lib/gpr/string.cc +23 -22
  497. data/src/core/lib/gpr/string.h +5 -6
  498. data/src/core/lib/gpr/sync.cc +4 -4
  499. data/src/core/lib/gpr/sync_posix.cc +2 -8
  500. data/src/core/lib/gpr/time.cc +12 -12
  501. data/src/core/lib/gpr/time_precise.cc +5 -2
  502. data/src/core/lib/gpr/time_precise.h +6 -2
  503. data/src/core/lib/gpr/tls.h +4 -0
  504. data/src/core/lib/gpr/tls_msvc.h +2 -0
  505. data/src/core/lib/gpr/tls_stdcpp.h +48 -0
  506. data/src/core/lib/gpr/useful.h +5 -4
  507. data/src/core/lib/gprpp/arena.h +3 -2
  508. data/src/core/lib/gprpp/dual_ref_counted.h +331 -0
  509. data/src/core/lib/gprpp/examine_stack.cc +43 -0
  510. data/src/core/lib/gprpp/examine_stack.h +46 -0
  511. data/src/core/lib/gprpp/fork.cc +2 -2
  512. data/src/core/lib/gprpp/manual_constructor.h +1 -1
  513. data/src/core/lib/gprpp/orphanable.h +4 -8
  514. data/src/core/lib/gprpp/ref_counted.h +91 -68
  515. data/src/core/lib/gprpp/ref_counted_ptr.h +166 -7
  516. data/src/core/lib/gprpp/stat.h +38 -0
  517. data/src/core/lib/gprpp/stat_posix.cc +49 -0
  518. data/src/core/lib/gprpp/stat_windows.cc +48 -0
  519. data/src/core/lib/gprpp/thd.h +2 -2
  520. data/src/core/lib/gprpp/thd_posix.cc +42 -37
  521. data/src/core/lib/gprpp/thd_windows.cc +3 -1
  522. data/src/core/lib/http/httpcli.cc +1 -1
  523. data/src/core/lib/http/httpcli.h +2 -3
  524. data/src/core/lib/http/httpcli_security_connector.cc +1 -1
  525. data/src/core/lib/http/parser.cc +47 -27
  526. data/src/core/lib/iomgr/call_combiner.cc +8 -5
  527. data/src/core/lib/iomgr/combiner.cc +2 -1
  528. data/src/core/lib/iomgr/endpoint.cc +5 -1
  529. data/src/core/lib/iomgr/endpoint.h +8 -4
  530. data/src/core/lib/iomgr/endpoint_cfstream.cc +36 -11
  531. data/src/core/lib/iomgr/error.cc +17 -12
  532. data/src/core/lib/iomgr/error_internal.h +1 -1
  533. data/src/core/lib/iomgr/ev_epoll1_linux.cc +20 -13
  534. data/src/core/lib/iomgr/ev_epollex_linux.cc +25 -17
  535. data/src/core/lib/iomgr/ev_poll_posix.cc +9 -7
  536. data/src/core/lib/iomgr/ev_posix.cc +0 -2
  537. data/src/core/lib/iomgr/exec_ctx.cc +1 -1
  538. data/src/core/lib/iomgr/exec_ctx.h +16 -12
  539. data/src/core/lib/iomgr/executor.cc +2 -1
  540. data/src/core/lib/iomgr/executor.h +1 -1
  541. data/src/core/lib/iomgr/executor/mpmcqueue.h +5 -5
  542. data/src/core/lib/iomgr/executor/threadpool.h +4 -4
  543. data/src/core/lib/iomgr/iomgr.cc +1 -11
  544. data/src/core/lib/iomgr/iomgr.h +0 -10
  545. data/src/core/lib/iomgr/load_file.h +1 -1
  546. data/src/core/lib/iomgr/lockfree_event.cc +19 -14
  547. data/src/core/lib/iomgr/lockfree_event.h +2 -2
  548. data/src/core/{ext/filters/client_channel → lib/iomgr}/parse_address.cc +128 -44
  549. data/src/core/lib/iomgr/parse_address.h +77 -0
  550. data/src/core/lib/iomgr/poller/eventmanager_libuv.cc +2 -1
  551. data/src/core/lib/iomgr/poller/eventmanager_libuv.h +1 -1
  552. data/src/core/lib/iomgr/pollset_set_custom.cc +1 -1
  553. data/src/core/lib/iomgr/python_util.h +4 -4
  554. data/src/core/lib/iomgr/resolve_address.cc +4 -4
  555. data/src/core/lib/iomgr/resolve_address_posix.cc +1 -5
  556. data/src/core/lib/iomgr/resource_quota.cc +4 -4
  557. data/src/core/lib/iomgr/sockaddr_utils.cc +12 -11
  558. data/src/core/lib/iomgr/sockaddr_utils.h +3 -2
  559. data/src/core/lib/iomgr/socket_factory_posix.cc +3 -2
  560. data/src/core/lib/iomgr/socket_mutator.cc +3 -2
  561. data/src/core/lib/iomgr/tcp_client.cc +3 -3
  562. data/src/core/lib/iomgr/tcp_client_custom.cc +7 -6
  563. data/src/core/lib/iomgr/tcp_custom.cc +53 -32
  564. data/src/core/lib/iomgr/tcp_posix.cc +43 -21
  565. data/src/core/lib/iomgr/tcp_server_custom.cc +28 -22
  566. data/src/core/lib/iomgr/tcp_windows.cc +26 -10
  567. data/src/core/lib/iomgr/timer_custom.cc +5 -5
  568. data/src/core/lib/iomgr/timer_generic.cc +3 -3
  569. data/src/core/lib/iomgr/timer_manager.cc +2 -2
  570. data/src/core/lib/iomgr/udp_server.cc +1 -2
  571. data/src/core/lib/iomgr/udp_server.h +1 -2
  572. data/src/core/lib/iomgr/unix_sockets_posix.cc +32 -21
  573. data/src/core/lib/iomgr/unix_sockets_posix.h +5 -0
  574. data/src/core/lib/iomgr/unix_sockets_posix_noop.cc +7 -0
  575. data/src/core/lib/iomgr/wakeup_fd_pipe.cc +2 -2
  576. data/src/core/lib/json/json.h +12 -2
  577. data/src/core/lib/json/json_reader.cc +8 -4
  578. data/src/core/lib/json/json_util.cc +58 -0
  579. data/src/core/lib/json/json_util.h +204 -0
  580. data/src/core/lib/json/json_writer.cc +2 -1
  581. data/src/core/lib/security/authorization/authorization_engine.cc +177 -0
  582. data/src/core/lib/security/authorization/authorization_engine.h +84 -0
  583. data/src/core/lib/security/authorization/evaluate_args.cc +148 -0
  584. data/src/core/lib/security/authorization/evaluate_args.h +59 -0
  585. data/src/core/lib/security/authorization/mock_cel/activation.h +57 -0
  586. data/src/core/lib/security/authorization/mock_cel/cel_expr_builder_factory.h +44 -0
  587. data/src/core/lib/security/authorization/mock_cel/cel_expression.h +69 -0
  588. data/src/core/lib/security/authorization/mock_cel/cel_value.h +97 -0
  589. data/src/core/lib/security/authorization/mock_cel/evaluator_core.h +67 -0
  590. data/src/core/lib/security/authorization/mock_cel/flat_expr_builder.h +57 -0
  591. data/src/core/lib/security/context/security_context.cc +4 -3
  592. data/src/core/lib/security/context/security_context.h +3 -1
  593. data/src/core/lib/security/credentials/alts/check_gcp_environment.cc +1 -1
  594. data/src/core/lib/security/credentials/credentials.cc +7 -7
  595. data/src/core/lib/security/credentials/credentials.h +3 -3
  596. data/src/core/lib/security/credentials/external/aws_external_account_credentials.cc +413 -0
  597. data/src/core/lib/security/credentials/external/aws_external_account_credentials.h +80 -0
  598. data/src/core/lib/security/credentials/external/aws_request_signer.cc +213 -0
  599. data/src/core/lib/security/credentials/external/aws_request_signer.h +72 -0
  600. data/src/core/lib/security/credentials/external/external_account_credentials.cc +497 -0
  601. data/src/core/lib/security/credentials/external/external_account_credentials.h +120 -0
  602. data/src/core/lib/security/credentials/external/file_external_account_credentials.cc +135 -0
  603. data/src/core/lib/security/credentials/external/file_external_account_credentials.h +48 -0
  604. data/src/core/lib/security/credentials/external/url_external_account_credentials.cc +213 -0
  605. data/src/core/lib/security/credentials/external/url_external_account_credentials.h +58 -0
  606. data/src/core/lib/security/credentials/fake/fake_credentials.cc +2 -1
  607. data/src/core/lib/security/credentials/google_default/google_default_credentials.cc +74 -50
  608. data/src/core/lib/security/credentials/insecure/insecure_credentials.cc +64 -0
  609. data/src/core/lib/security/credentials/jwt/json_token.cc +6 -3
  610. data/src/core/lib/security/credentials/jwt/jwt_credentials.h +4 -3
  611. data/src/core/lib/security/credentials/jwt/jwt_verifier.cc +8 -4
  612. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.cc +39 -46
  613. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.h +5 -4
  614. data/src/core/lib/security/credentials/plugin/plugin_credentials.cc +1 -1
  615. data/src/core/lib/security/credentials/ssl/ssl_credentials.cc +5 -5
  616. data/src/core/lib/security/credentials/ssl/ssl_credentials.h +1 -1
  617. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_distributor.cc +346 -0
  618. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_distributor.h +213 -0
  619. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.cc +399 -0
  620. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.h +138 -0
  621. data/src/core/lib/security/credentials/tls/grpc_tls_credentials_options.cc +78 -150
  622. data/src/core/lib/security/credentials/tls/grpc_tls_credentials_options.h +57 -187
  623. data/src/core/lib/security/credentials/tls/tls_credentials.cc +16 -12
  624. data/src/core/lib/security/credentials/tls/tls_credentials.h +2 -2
  625. data/src/core/lib/security/credentials/tls/tls_utils.cc +91 -0
  626. data/src/core/lib/security/credentials/tls/tls_utils.h +38 -0
  627. data/src/core/lib/security/credentials/xds/xds_credentials.cc +175 -0
  628. data/src/core/lib/security/credentials/xds/xds_credentials.h +69 -0
  629. data/src/core/lib/security/security_connector/alts/alts_security_connector.cc +1 -1
  630. data/src/core/lib/security/security_connector/fake/fake_security_connector.cc +10 -15
  631. data/src/core/lib/security/security_connector/insecure/insecure_security_connector.cc +121 -0
  632. data/src/core/lib/security/security_connector/insecure/insecure_security_connector.h +87 -0
  633. data/src/core/lib/security/security_connector/load_system_roots.h +4 -0
  634. data/src/core/lib/security/security_connector/load_system_roots_linux.h +2 -0
  635. data/src/core/lib/security/security_connector/local/local_security_connector.cc +3 -3
  636. data/src/core/lib/security/security_connector/security_connector.cc +4 -3
  637. data/src/core/lib/security/security_connector/security_connector.h +4 -2
  638. data/src/core/lib/security/security_connector/ssl/ssl_security_connector.cc +4 -4
  639. data/src/core/lib/security/security_connector/ssl_utils.cc +2 -2
  640. data/src/core/lib/security/security_connector/ssl_utils.h +19 -19
  641. data/src/core/lib/security/security_connector/tls/tls_security_connector.cc +342 -279
  642. data/src/core/lib/security/security_connector/tls/tls_security_connector.h +105 -61
  643. data/src/core/lib/security/transport/secure_endpoint.cc +9 -3
  644. data/src/core/lib/security/transport/security_handshaker.cc +3 -3
  645. data/src/core/lib/security/transport/server_auth_filter.cc +2 -1
  646. data/src/core/lib/security/util/json_util.h +1 -0
  647. data/src/core/lib/slice/slice.cc +7 -4
  648. data/src/core/lib/slice/slice_buffer.cc +2 -1
  649. data/src/core/lib/slice/slice_intern.cc +6 -7
  650. data/src/core/lib/slice/slice_internal.h +2 -2
  651. data/src/core/lib/surface/call.cc +53 -44
  652. data/src/core/lib/surface/call.h +2 -1
  653. data/src/core/lib/surface/call_details.cc +8 -8
  654. data/src/core/lib/surface/channel.cc +53 -61
  655. data/src/core/lib/surface/channel.h +21 -5
  656. data/src/core/lib/surface/channel_init.cc +1 -1
  657. data/src/core/lib/surface/completion_queue.cc +38 -294
  658. data/src/core/lib/surface/completion_queue.h +16 -24
  659. data/src/core/lib/surface/init.cc +32 -16
  660. data/src/core/lib/surface/lame_client.cc +20 -46
  661. data/src/core/lib/surface/lame_client.h +4 -0
  662. data/src/core/lib/surface/server.cc +1107 -1239
  663. data/src/core/lib/surface/server.h +394 -86
  664. data/src/core/lib/surface/validate_metadata.h +3 -0
  665. data/src/core/lib/surface/version.cc +2 -2
  666. data/src/core/lib/transport/authority_override.cc +40 -0
  667. data/src/core/lib/transport/authority_override.h +37 -0
  668. data/src/core/lib/transport/bdp_estimator.cc +1 -1
  669. data/src/core/lib/transport/bdp_estimator.h +2 -1
  670. data/src/core/lib/transport/byte_stream.h +3 -3
  671. data/src/core/lib/transport/connectivity_state.cc +18 -13
  672. data/src/core/lib/transport/connectivity_state.h +26 -12
  673. data/src/core/lib/transport/error_utils.cc +13 -0
  674. data/src/core/lib/transport/error_utils.h +7 -1
  675. data/src/core/lib/transport/metadata.cc +11 -1
  676. data/src/core/lib/transport/metadata.h +2 -2
  677. data/src/core/lib/transport/metadata_batch.h +4 -4
  678. data/src/core/lib/transport/static_metadata.cc +296 -277
  679. data/src/core/lib/transport/static_metadata.h +80 -73
  680. data/src/core/lib/transport/status_metadata.cc +4 -3
  681. data/src/core/lib/transport/timeout_encoding.cc +4 -4
  682. data/src/core/lib/transport/transport.cc +5 -3
  683. data/src/core/lib/transport/transport.h +15 -8
  684. data/src/core/lib/uri/uri_parser.cc +131 -247
  685. data/src/core/lib/uri/uri_parser.h +58 -20
  686. data/src/core/plugin_registry/grpc_plugin_registry.cc +41 -20
  687. data/src/core/tsi/alts/crypt/gsec.cc +5 -4
  688. data/src/core/tsi/alts/frame_protector/frame_handler.cc +8 -6
  689. data/src/core/tsi/alts/handshaker/alts_handshaker_client.cc +1 -1
  690. data/src/core/tsi/alts/handshaker/alts_tsi_handshaker.cc +49 -26
  691. data/src/core/tsi/alts/zero_copy_frame_protector/alts_iovec_record_protocol.cc +8 -6
  692. data/src/core/tsi/alts/zero_copy_frame_protector/alts_zero_copy_grpc_protector.cc +4 -4
  693. data/src/core/tsi/fake_transport_security.cc +6 -3
  694. data/src/core/tsi/local_transport_security.cc +5 -1
  695. data/src/core/tsi/local_transport_security.h +6 -7
  696. data/src/core/tsi/ssl/session_cache/ssl_session.h +3 -0
  697. data/src/core/tsi/ssl/session_cache/ssl_session_boringssl.cc +1 -1
  698. data/src/core/tsi/ssl/session_cache/ssl_session_cache.h +4 -1
  699. data/src/core/tsi/ssl_transport_security.cc +81 -67
  700. data/src/core/tsi/ssl_transport_security.h +9 -6
  701. data/src/core/tsi/transport_security.cc +10 -8
  702. data/src/core/tsi/transport_security_interface.h +1 -1
  703. data/src/ruby/ext/grpc/extconf.rb +1 -1
  704. data/src/ruby/ext/grpc/rb_channel_credentials.c +9 -0
  705. data/src/ruby/ext/grpc/rb_event_thread.c +2 -0
  706. data/src/ruby/ext/grpc/rb_grpc_imports.generated.c +38 -18
  707. data/src/ruby/ext/grpc/rb_grpc_imports.generated.h +74 -44
  708. data/src/ruby/lib/grpc/version.rb +1 -1
  709. data/src/ruby/pb/src/proto/grpc/testing/messages_pb.rb +28 -0
  710. data/src/ruby/pb/src/proto/grpc/testing/test_services_pb.rb +18 -0
  711. data/src/ruby/spec/channel_credentials_spec.rb +10 -0
  712. data/src/ruby/spec/generic/active_call_spec.rb +19 -8
  713. data/src/ruby/spec/pb/codegen/package_option_spec.rb +2 -6
  714. data/third_party/abseil-cpp/absl/algorithm/container.h +1764 -0
  715. data/third_party/abseil-cpp/absl/base/attributes.h +99 -38
  716. data/third_party/abseil-cpp/absl/base/call_once.h +1 -1
  717. data/third_party/abseil-cpp/absl/base/casts.h +9 -6
  718. data/third_party/abseil-cpp/absl/base/config.h +60 -17
  719. data/third_party/abseil-cpp/absl/base/dynamic_annotations.h +428 -335
  720. data/third_party/abseil-cpp/absl/base/internal/bits.h +17 -16
  721. data/third_party/abseil-cpp/absl/base/internal/direct_mmap.h +166 -0
  722. data/third_party/abseil-cpp/absl/base/internal/dynamic_annotations.h +398 -0
  723. data/third_party/abseil-cpp/absl/base/internal/exponential_biased.cc +93 -0
  724. data/third_party/abseil-cpp/absl/base/internal/exponential_biased.h +130 -0
  725. data/third_party/abseil-cpp/absl/base/internal/invoke.h +4 -4
  726. data/third_party/abseil-cpp/absl/base/internal/low_level_alloc.cc +620 -0
  727. data/third_party/abseil-cpp/absl/base/internal/low_level_alloc.h +126 -0
  728. data/third_party/abseil-cpp/absl/base/internal/low_level_scheduling.h +29 -1
  729. data/third_party/abseil-cpp/absl/base/internal/raw_logging.cc +2 -2
  730. data/third_party/abseil-cpp/absl/base/internal/raw_logging.h +7 -5
  731. data/third_party/abseil-cpp/absl/base/internal/spinlock.cc +25 -38
  732. data/third_party/abseil-cpp/absl/base/internal/spinlock.h +19 -25
  733. data/third_party/abseil-cpp/absl/base/internal/spinlock_linux.inc +8 -0
  734. data/third_party/abseil-cpp/absl/base/internal/sysinfo.cc +28 -5
  735. data/third_party/abseil-cpp/absl/base/internal/sysinfo.h +8 -0
  736. data/third_party/abseil-cpp/absl/base/internal/tsan_mutex_interface.h +3 -1
  737. data/third_party/abseil-cpp/absl/base/internal/unaligned_access.h +2 -2
  738. data/third_party/abseil-cpp/absl/base/internal/unscaledcycleclock.h +3 -3
  739. data/third_party/abseil-cpp/absl/base/macros.h +36 -109
  740. data/third_party/abseil-cpp/absl/base/optimization.h +61 -1
  741. data/third_party/abseil-cpp/absl/base/options.h +31 -4
  742. data/third_party/abseil-cpp/absl/base/policy_checks.h +1 -1
  743. data/third_party/abseil-cpp/absl/base/thread_annotations.h +94 -39
  744. data/third_party/abseil-cpp/absl/container/fixed_array.h +532 -0
  745. data/third_party/abseil-cpp/absl/container/flat_hash_map.h +606 -0
  746. data/third_party/abseil-cpp/absl/container/flat_hash_set.h +504 -0
  747. data/third_party/abseil-cpp/absl/container/inlined_vector.h +33 -36
  748. data/third_party/abseil-cpp/absl/container/internal/common.h +206 -0
  749. data/third_party/abseil-cpp/absl/container/internal/compressed_tuple.h +33 -8
  750. data/third_party/abseil-cpp/absl/container/internal/container_memory.h +460 -0
  751. data/third_party/abseil-cpp/absl/container/internal/hash_function_defaults.h +161 -0
  752. data/third_party/abseil-cpp/absl/container/internal/hash_policy_traits.h +208 -0
  753. data/third_party/abseil-cpp/absl/container/internal/hashtable_debug_hooks.h +85 -0
  754. data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler.cc +270 -0
  755. data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler.h +321 -0
  756. data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler_force_weak_definition.cc +30 -0
  757. data/third_party/abseil-cpp/absl/container/internal/have_sse.h +50 -0
  758. data/third_party/abseil-cpp/absl/container/internal/layout.h +743 -0
  759. data/third_party/abseil-cpp/absl/container/internal/raw_hash_map.h +197 -0
  760. data/third_party/abseil-cpp/absl/container/internal/raw_hash_set.cc +48 -0
  761. data/third_party/abseil-cpp/absl/container/internal/raw_hash_set.h +1903 -0
  762. data/third_party/abseil-cpp/absl/debugging/internal/address_is_readable.cc +139 -0
  763. data/third_party/abseil-cpp/absl/debugging/internal/address_is_readable.h +32 -0
  764. data/third_party/abseil-cpp/absl/debugging/internal/demangle.cc +1945 -0
  765. data/third_party/abseil-cpp/absl/debugging/internal/demangle.h +71 -0
  766. data/third_party/abseil-cpp/absl/debugging/internal/elf_mem_image.cc +382 -0
  767. data/third_party/abseil-cpp/absl/debugging/internal/elf_mem_image.h +134 -0
  768. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_aarch64-inl.inc +196 -0
  769. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_arm-inl.inc +134 -0
  770. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_config.h +89 -0
  771. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_generic-inl.inc +108 -0
  772. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_powerpc-inl.inc +248 -0
  773. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_unimplemented-inl.inc +24 -0
  774. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_win32-inl.inc +93 -0
  775. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_x86-inl.inc +346 -0
  776. data/third_party/abseil-cpp/absl/debugging/internal/symbolize.h +149 -0
  777. data/third_party/abseil-cpp/absl/debugging/internal/vdso_support.cc +173 -0
  778. data/third_party/abseil-cpp/absl/debugging/internal/vdso_support.h +158 -0
  779. data/third_party/abseil-cpp/absl/debugging/stacktrace.cc +140 -0
  780. data/third_party/abseil-cpp/absl/debugging/stacktrace.h +231 -0
  781. data/third_party/abseil-cpp/absl/debugging/symbolize.cc +36 -0
  782. data/third_party/abseil-cpp/absl/debugging/symbolize.h +99 -0
  783. data/third_party/abseil-cpp/absl/debugging/symbolize_darwin.inc +101 -0
  784. data/third_party/abseil-cpp/absl/debugging/symbolize_elf.inc +1560 -0
  785. data/third_party/abseil-cpp/absl/debugging/symbolize_unimplemented.inc +40 -0
  786. data/third_party/abseil-cpp/absl/debugging/symbolize_win32.inc +81 -0
  787. data/third_party/abseil-cpp/absl/functional/bind_front.h +184 -0
  788. data/third_party/abseil-cpp/absl/functional/function_ref.h +139 -0
  789. data/third_party/abseil-cpp/absl/functional/internal/front_binder.h +95 -0
  790. data/third_party/abseil-cpp/absl/functional/internal/function_ref.h +106 -0
  791. data/third_party/abseil-cpp/absl/hash/hash.h +325 -0
  792. data/third_party/abseil-cpp/absl/hash/internal/city.cc +346 -0
  793. data/third_party/abseil-cpp/absl/hash/internal/city.h +96 -0
  794. data/third_party/abseil-cpp/absl/hash/internal/hash.cc +55 -0
  795. data/third_party/abseil-cpp/absl/hash/internal/hash.h +996 -0
  796. data/third_party/abseil-cpp/absl/memory/memory.h +4 -0
  797. data/third_party/abseil-cpp/absl/meta/type_traits.h +2 -8
  798. data/third_party/abseil-cpp/absl/numeric/int128.cc +13 -27
  799. data/third_party/abseil-cpp/absl/numeric/int128.h +16 -15
  800. data/third_party/abseil-cpp/absl/status/internal/status_internal.h +51 -0
  801. data/third_party/abseil-cpp/absl/status/internal/statusor_internal.h +399 -0
  802. data/third_party/abseil-cpp/absl/status/status.cc +445 -0
  803. data/third_party/abseil-cpp/absl/status/status.h +817 -0
  804. data/third_party/abseil-cpp/absl/status/status_payload_printer.cc +38 -0
  805. data/third_party/abseil-cpp/absl/status/status_payload_printer.h +51 -0
  806. data/third_party/abseil-cpp/absl/status/statusor.cc +71 -0
  807. data/third_party/abseil-cpp/absl/status/statusor.h +760 -0
  808. data/third_party/abseil-cpp/absl/strings/charconv.cc +2 -2
  809. data/third_party/abseil-cpp/absl/strings/cord.cc +1998 -0
  810. data/third_party/abseil-cpp/absl/strings/cord.h +1276 -0
  811. data/third_party/abseil-cpp/absl/strings/escaping.cc +9 -9
  812. data/third_party/abseil-cpp/absl/strings/internal/char_map.h +1 -1
  813. data/third_party/abseil-cpp/absl/strings/internal/charconv_bigint.cc +1 -1
  814. data/third_party/abseil-cpp/absl/strings/internal/charconv_bigint.h +2 -2
  815. data/third_party/abseil-cpp/absl/strings/internal/charconv_parse.cc +2 -2
  816. data/third_party/abseil-cpp/absl/strings/internal/cord_internal.h +173 -0
  817. data/third_party/abseil-cpp/absl/strings/internal/str_format/arg.cc +222 -136
  818. data/third_party/abseil-cpp/absl/strings/internal/str_format/arg.h +136 -64
  819. data/third_party/abseil-cpp/absl/strings/internal/str_format/bind.cc +1 -1
  820. data/third_party/abseil-cpp/absl/strings/internal/str_format/bind.h +14 -21
  821. data/third_party/abseil-cpp/absl/strings/internal/str_format/checker.h +7 -14
  822. data/third_party/abseil-cpp/absl/strings/internal/str_format/extension.cc +31 -7
  823. data/third_party/abseil-cpp/absl/strings/internal/str_format/extension.h +147 -135
  824. data/third_party/abseil-cpp/absl/strings/internal/str_format/float_conversion.cc +999 -87
  825. data/third_party/abseil-cpp/absl/strings/internal/str_format/float_conversion.h +3 -3
  826. data/third_party/abseil-cpp/absl/strings/internal/str_format/output.h +4 -12
  827. data/third_party/abseil-cpp/absl/strings/internal/str_format/parser.cc +8 -6
  828. data/third_party/abseil-cpp/absl/strings/internal/str_format/parser.h +13 -11
  829. data/third_party/abseil-cpp/absl/strings/internal/str_split_internal.h +2 -2
  830. data/third_party/abseil-cpp/absl/strings/str_cat.cc +4 -4
  831. data/third_party/abseil-cpp/absl/strings/str_cat.h +1 -1
  832. data/third_party/abseil-cpp/absl/strings/str_format.h +289 -13
  833. data/third_party/abseil-cpp/absl/strings/str_split.cc +2 -2
  834. data/third_party/abseil-cpp/absl/strings/str_split.h +1 -0
  835. data/third_party/abseil-cpp/absl/strings/string_view.h +26 -19
  836. data/third_party/abseil-cpp/absl/strings/substitute.cc +5 -5
  837. data/third_party/abseil-cpp/absl/strings/substitute.h +32 -29
  838. data/third_party/abseil-cpp/absl/synchronization/barrier.cc +52 -0
  839. data/third_party/abseil-cpp/absl/synchronization/barrier.h +79 -0
  840. data/third_party/abseil-cpp/absl/synchronization/blocking_counter.cc +57 -0
  841. data/third_party/abseil-cpp/absl/synchronization/blocking_counter.h +99 -0
  842. data/third_party/abseil-cpp/absl/synchronization/internal/create_thread_identity.cc +140 -0
  843. data/third_party/abseil-cpp/absl/synchronization/internal/create_thread_identity.h +60 -0
  844. data/third_party/abseil-cpp/absl/synchronization/internal/graphcycles.cc +697 -0
  845. data/third_party/abseil-cpp/absl/synchronization/internal/graphcycles.h +141 -0
  846. data/third_party/abseil-cpp/absl/synchronization/internal/kernel_timeout.h +155 -0
  847. data/third_party/abseil-cpp/absl/synchronization/internal/mutex_nonprod.inc +249 -0
  848. data/third_party/abseil-cpp/absl/synchronization/internal/per_thread_sem.cc +106 -0
  849. data/third_party/abseil-cpp/absl/synchronization/internal/per_thread_sem.h +115 -0
  850. data/third_party/abseil-cpp/absl/synchronization/internal/waiter.cc +492 -0
  851. data/third_party/abseil-cpp/absl/synchronization/internal/waiter.h +159 -0
  852. data/third_party/abseil-cpp/absl/synchronization/mutex.cc +2739 -0
  853. data/third_party/abseil-cpp/absl/synchronization/mutex.h +1065 -0
  854. data/third_party/abseil-cpp/absl/synchronization/notification.cc +78 -0
  855. data/third_party/abseil-cpp/absl/synchronization/notification.h +123 -0
  856. data/third_party/abseil-cpp/absl/time/civil_time.cc +9 -9
  857. data/third_party/abseil-cpp/absl/time/clock.cc +3 -3
  858. data/third_party/abseil-cpp/absl/time/duration.cc +90 -59
  859. data/third_party/abseil-cpp/absl/time/format.cc +43 -36
  860. data/third_party/abseil-cpp/absl/time/internal/cctz/include/cctz/civil_time_detail.h +26 -16
  861. data/third_party/abseil-cpp/absl/time/internal/cctz/include/cctz/time_zone.h +4 -2
  862. data/third_party/abseil-cpp/absl/time/internal/cctz/include/cctz/zone_info_source.h +1 -1
  863. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_format.cc +136 -29
  864. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_impl.cc +13 -21
  865. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_impl.h +1 -1
  866. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_info.cc +136 -129
  867. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_info.h +4 -5
  868. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_libc.cc +8 -7
  869. data/third_party/abseil-cpp/absl/time/internal/cctz/src/tzfile.h +6 -6
  870. data/third_party/abseil-cpp/absl/time/internal/cctz/src/zone_info_source.cc +2 -1
  871. data/third_party/abseil-cpp/absl/time/time.h +15 -16
  872. data/third_party/abseil-cpp/absl/types/bad_variant_access.cc +64 -0
  873. data/third_party/abseil-cpp/absl/types/bad_variant_access.h +82 -0
  874. data/third_party/abseil-cpp/absl/types/internal/variant.h +1646 -0
  875. data/third_party/abseil-cpp/absl/types/optional.h +9 -9
  876. data/third_party/abseil-cpp/absl/types/span.h +49 -36
  877. data/third_party/abseil-cpp/absl/types/variant.h +861 -0
  878. data/third_party/abseil-cpp/absl/utility/utility.h +2 -2
  879. data/third_party/address_sorting/include/address_sorting/address_sorting.h +2 -0
  880. data/third_party/boringssl-with-bazel/err_data.c +479 -467
  881. data/third_party/boringssl-with-bazel/src/crypto/asn1/asn1_lib.c +0 -6
  882. data/third_party/boringssl-with-bazel/src/crypto/bio/bio.c +2 -0
  883. data/third_party/boringssl-with-bazel/src/crypto/dsa/dsa.c +9 -43
  884. data/third_party/boringssl-with-bazel/src/crypto/dsa/dsa_asn1.c +55 -4
  885. data/third_party/boringssl-with-bazel/src/crypto/dsa/internal.h +34 -0
  886. data/third_party/boringssl-with-bazel/src/crypto/evp/evp.c +4 -0
  887. data/third_party/boringssl-with-bazel/src/crypto/evp/evp_asn1.c +16 -0
  888. data/third_party/boringssl-with-bazel/src/crypto/evp/p_dsa_asn1.c +6 -2
  889. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/e_aes.c +173 -35
  890. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digest/digest.c +2 -0
  891. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/internal.h +4 -0
  892. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/rsa.c +30 -10
  893. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/rsa_impl.c +56 -22
  894. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/self_check/self_check.c +8 -2
  895. data/third_party/boringssl-with-bazel/src/crypto/hpke/hpke.c +543 -0
  896. data/third_party/boringssl-with-bazel/src/crypto/hpke/internal.h +237 -0
  897. data/third_party/boringssl-with-bazel/src/crypto/trust_token/internal.h +118 -49
  898. data/third_party/boringssl-with-bazel/src/crypto/trust_token/pmbtoken.c +267 -95
  899. data/third_party/boringssl-with-bazel/src/crypto/trust_token/trust_token.c +210 -34
  900. data/third_party/boringssl-with-bazel/src/crypto/trust_token/voprf.c +766 -0
  901. data/third_party/boringssl-with-bazel/src/crypto/x509/a_strex.c +3 -3
  902. data/third_party/boringssl-with-bazel/src/crypto/x509/algorithm.c +6 -4
  903. data/third_party/boringssl-with-bazel/src/crypto/x509/t_crl.c +3 -3
  904. data/third_party/boringssl-with-bazel/src/crypto/x509/t_x509.c +1 -1
  905. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_cmp.c +7 -2
  906. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_ext.c +21 -18
  907. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_obj.c +1 -1
  908. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_set.c +24 -3
  909. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_trs.c +3 -3
  910. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_txt.c +67 -67
  911. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_v3.c +3 -3
  912. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_vfy.c +29 -35
  913. data/third_party/boringssl-with-bazel/src/crypto/x509/x509cset.c +13 -2
  914. data/third_party/boringssl-with-bazel/src/crypto/x509/x509name.c +9 -8
  915. data/third_party/boringssl-with-bazel/src/crypto/x509/x_all.c +10 -10
  916. data/third_party/boringssl-with-bazel/src/crypto/x509/x_crl.c +2 -2
  917. data/third_party/boringssl-with-bazel/src/crypto/x509/x_name.c +28 -40
  918. data/third_party/boringssl-with-bazel/src/crypto/x509/x_sig.c +20 -0
  919. data/third_party/boringssl-with-bazel/src/crypto/x509/x_x509.c +3 -1
  920. data/third_party/boringssl-with-bazel/src/crypto/x509v3/ext_dat.h +1 -4
  921. data/third_party/boringssl-with-bazel/src/crypto/x509v3/pcy_data.c +5 -3
  922. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_alt.c +14 -14
  923. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_conf.c +7 -3
  924. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_genn.c +2 -2
  925. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_info.c +1 -1
  926. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_prn.c +1 -1
  927. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_purp.c +55 -8
  928. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_skey.c +1 -1
  929. data/third_party/boringssl-with-bazel/src/include/openssl/aead.h +24 -0
  930. data/third_party/boringssl-with-bazel/src/include/openssl/arm_arch.h +54 -0
  931. data/third_party/boringssl-with-bazel/src/include/openssl/asn1.h +0 -1
  932. data/third_party/boringssl-with-bazel/src/include/openssl/base.h +6 -3
  933. data/third_party/boringssl-with-bazel/src/include/openssl/bio.h +4 -0
  934. data/third_party/boringssl-with-bazel/src/include/openssl/cipher.h +6 -0
  935. data/third_party/boringssl-with-bazel/src/include/openssl/crypto.h +1 -1
  936. data/third_party/boringssl-with-bazel/src/include/openssl/des.h +6 -0
  937. data/third_party/boringssl-with-bazel/src/include/openssl/dh.h +12 -0
  938. data/third_party/boringssl-with-bazel/src/include/openssl/digest.h +9 -0
  939. data/third_party/boringssl-with-bazel/src/include/openssl/evp.h +4 -1
  940. data/third_party/boringssl-with-bazel/src/include/openssl/opensslconf.h +3 -0
  941. data/third_party/boringssl-with-bazel/src/include/openssl/pem.h +202 -134
  942. data/third_party/boringssl-with-bazel/src/include/openssl/ssl.h +103 -10
  943. data/third_party/boringssl-with-bazel/src/include/openssl/tls1.h +5 -2
  944. data/third_party/boringssl-with-bazel/src/include/openssl/trust_token.h +42 -14
  945. data/third_party/boringssl-with-bazel/src/include/openssl/x509.h +199 -78
  946. data/third_party/boringssl-with-bazel/src/include/openssl/x509v3.h +482 -432
  947. data/third_party/boringssl-with-bazel/src/ssl/bio_ssl.cc +18 -5
  948. data/third_party/boringssl-with-bazel/src/ssl/handoff.cc +35 -0
  949. data/third_party/boringssl-with-bazel/src/ssl/handshake.cc +18 -18
  950. data/third_party/boringssl-with-bazel/src/ssl/handshake_client.cc +2 -3
  951. data/third_party/boringssl-with-bazel/src/ssl/handshake_server.cc +1 -1
  952. data/third_party/boringssl-with-bazel/src/ssl/internal.h +49 -10
  953. data/third_party/boringssl-with-bazel/src/ssl/ssl_asn1.cc +42 -1
  954. data/third_party/boringssl-with-bazel/src/ssl/ssl_cert.cc +3 -6
  955. data/third_party/boringssl-with-bazel/src/ssl/ssl_cipher.cc +8 -9
  956. data/third_party/boringssl-with-bazel/src/ssl/ssl_lib.cc +77 -0
  957. data/third_party/boringssl-with-bazel/src/ssl/ssl_session.cc +11 -14
  958. data/third_party/boringssl-with-bazel/src/ssl/t1_lib.cc +250 -20
  959. data/third_party/boringssl-with-bazel/src/ssl/tls13_both.cc +1 -2
  960. data/third_party/boringssl-with-bazel/src/ssl/tls13_client.cc +57 -19
  961. data/third_party/boringssl-with-bazel/src/ssl/tls13_server.cc +140 -41
  962. data/third_party/boringssl-with-bazel/src/ssl/tls_record.cc +5 -3
  963. data/third_party/upb/third_party/wyhash/wyhash.h +145 -0
  964. data/third_party/upb/upb/decode.c +275 -145
  965. data/third_party/upb/upb/decode.h +20 -1
  966. data/third_party/upb/upb/decode.int.h +163 -0
  967. data/third_party/upb/upb/decode_fast.c +1040 -0
  968. data/third_party/upb/upb/decode_fast.h +126 -0
  969. data/third_party/upb/upb/def.c +2178 -0
  970. data/third_party/upb/upb/def.h +315 -0
  971. data/third_party/upb/upb/def.hpp +439 -0
  972. data/third_party/upb/upb/encode.c +229 -171
  973. data/third_party/upb/upb/encode.h +27 -2
  974. data/third_party/upb/upb/json_decode.c +1443 -0
  975. data/third_party/upb/upb/json_decode.h +23 -0
  976. data/third_party/upb/upb/json_encode.c +713 -0
  977. data/third_party/upb/upb/json_encode.h +36 -0
  978. data/third_party/upb/upb/msg.c +167 -88
  979. data/third_party/upb/upb/msg.h +175 -35
  980. data/third_party/upb/upb/port_def.inc +75 -62
  981. data/third_party/upb/upb/port_undef.inc +3 -7
  982. data/third_party/upb/upb/reflection.c +408 -0
  983. data/third_party/upb/upb/reflection.h +168 -0
  984. data/third_party/upb/upb/table.c +34 -208
  985. data/third_party/upb/upb/table.int.h +14 -14
  986. data/third_party/upb/upb/text_encode.c +421 -0
  987. data/third_party/upb/upb/text_encode.h +38 -0
  988. data/third_party/upb/upb/upb.c +33 -54
  989. data/third_party/upb/upb/upb.h +56 -1
  990. data/third_party/upb/upb/upb.hpp +6 -4
  991. data/third_party/upb/upb/upb.int.h +29 -0
  992. metadata +508 -172
  993. data/src/core/ext/filters/client_channel/lb_policy/xds/eds.cc +0 -938
  994. data/src/core/ext/filters/client_channel/lb_policy/xds/lrs.cc +0 -528
  995. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_routing.cc +0 -1143
  996. data/src/core/ext/filters/client_channel/parse_address.h +0 -53
  997. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver.cc +0 -485
  998. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper_fallback.cc +0 -68
  999. data/src/core/ext/filters/client_channel/resolving_lb_policy.cc +0 -353
  1000. data/src/core/ext/filters/client_channel/resolving_lb_policy.h +0 -142
  1001. data/src/core/ext/filters/client_channel/xds/xds_api.cc +0 -2110
  1002. data/src/core/ext/filters/client_channel/xds/xds_api.h +0 -345
  1003. data/src/core/ext/filters/client_channel/xds/xds_channel.h +0 -46
  1004. data/src/core/ext/filters/client_channel/xds/xds_channel_secure.cc +0 -106
  1005. data/src/core/ext/upb-generated/envoy/api/v2/auth/cert.upb.c +0 -21
  1006. data/src/core/ext/upb-generated/envoy/api/v2/auth/cert.upb.h +0 -34
  1007. data/src/core/ext/upb-generated/envoy/api/v2/auth/common.upb.c +0 -114
  1008. data/src/core/ext/upb-generated/envoy/api/v2/auth/common.upb.h +0 -429
  1009. data/src/core/ext/upb-generated/envoy/api/v2/auth/secret.upb.c +0 -72
  1010. data/src/core/ext/upb-generated/envoy/api/v2/auth/secret.upb.h +0 -198
  1011. data/src/core/ext/upb-generated/envoy/api/v2/auth/tls.upb.c +0 -105
  1012. data/src/core/ext/upb-generated/envoy/api/v2/auth/tls.upb.h +0 -388
  1013. data/src/core/ext/upb-generated/envoy/api/v2/cds.upb.h +0 -52
  1014. data/src/core/ext/upb-generated/envoy/api/v2/cluster.upb.c +0 -403
  1015. data/src/core/ext/upb-generated/envoy/api/v2/cluster.upb.h +0 -1453
  1016. data/src/core/ext/upb-generated/envoy/api/v2/cluster/circuit_breaker.upb.c +0 -74
  1017. data/src/core/ext/upb-generated/envoy/api/v2/cluster/circuit_breaker.upb.h +0 -226
  1018. data/src/core/ext/upb-generated/envoy/api/v2/cluster/filter.upb.c +0 -35
  1019. data/src/core/ext/upb-generated/envoy/api/v2/cluster/filter.upb.h +0 -69
  1020. data/src/core/ext/upb-generated/envoy/api/v2/cluster/outlier_detection.upb.c +0 -55
  1021. data/src/core/ext/upb-generated/envoy/api/v2/cluster/outlier_detection.upb.h +0 -323
  1022. data/src/core/ext/upb-generated/envoy/api/v2/core/address.upb.c +0 -112
  1023. data/src/core/ext/upb-generated/envoy/api/v2/core/address.upb.h +0 -334
  1024. data/src/core/ext/upb-generated/envoy/api/v2/core/backoff.upb.c +0 -35
  1025. data/src/core/ext/upb-generated/envoy/api/v2/core/backoff.upb.h +0 -79
  1026. data/src/core/ext/upb-generated/envoy/api/v2/core/base.upb.c +0 -313
  1027. data/src/core/ext/upb-generated/envoy/api/v2/core/base.upb.h +0 -891
  1028. data/src/core/ext/upb-generated/envoy/api/v2/core/config_source.upb.c +0 -96
  1029. data/src/core/ext/upb-generated/envoy/api/v2/core/config_source.upb.h +0 -328
  1030. data/src/core/ext/upb-generated/envoy/api/v2/core/event_service_config.upb.c +0 -34
  1031. data/src/core/ext/upb-generated/envoy/api/v2/core/event_service_config.upb.h +0 -71
  1032. data/src/core/ext/upb-generated/envoy/api/v2/core/grpc_service.upb.c +0 -197
  1033. data/src/core/ext/upb-generated/envoy/api/v2/core/grpc_service.upb.h +0 -649
  1034. data/src/core/ext/upb-generated/envoy/api/v2/core/health_check.upb.c +0 -172
  1035. data/src/core/ext/upb-generated/envoy/api/v2/core/health_check.upb.h +0 -693
  1036. data/src/core/ext/upb-generated/envoy/api/v2/core/http_uri.upb.c +0 -36
  1037. data/src/core/ext/upb-generated/envoy/api/v2/core/http_uri.upb.h +0 -80
  1038. data/src/core/ext/upb-generated/envoy/api/v2/core/protocol.upb.c +0 -152
  1039. data/src/core/ext/upb-generated/envoy/api/v2/core/protocol.upb.h +0 -536
  1040. data/src/core/ext/upb-generated/envoy/api/v2/core/socket_option.upb.h +0 -88
  1041. data/src/core/ext/upb-generated/envoy/api/v2/discovery.upb.c +0 -129
  1042. data/src/core/ext/upb-generated/envoy/api/v2/discovery.upb.h +0 -386
  1043. data/src/core/ext/upb-generated/envoy/api/v2/eds.upb.h +0 -52
  1044. data/src/core/ext/upb-generated/envoy/api/v2/endpoint.upb.c +0 -92
  1045. data/src/core/ext/upb-generated/envoy/api/v2/endpoint.upb.h +0 -224
  1046. data/src/core/ext/upb-generated/envoy/api/v2/endpoint/endpoint.upb.c +0 -18
  1047. data/src/core/ext/upb-generated/envoy/api/v2/endpoint/endpoint.upb.h +0 -32
  1048. data/src/core/ext/upb-generated/envoy/api/v2/endpoint/endpoint_components.upb.c +0 -91
  1049. data/src/core/ext/upb-generated/envoy/api/v2/endpoint/endpoint_components.upb.h +0 -273
  1050. data/src/core/ext/upb-generated/envoy/api/v2/endpoint/load_report.upb.c +0 -112
  1051. data/src/core/ext/upb-generated/envoy/api/v2/endpoint/load_report.upb.h +0 -332
  1052. data/src/core/ext/upb-generated/envoy/api/v2/lds.upb.h +0 -52
  1053. data/src/core/ext/upb-generated/envoy/api/v2/listener.upb.c +0 -109
  1054. data/src/core/ext/upb-generated/envoy/api/v2/listener.upb.h +0 -415
  1055. data/src/core/ext/upb-generated/envoy/api/v2/listener/listener.upb.c +0 -18
  1056. data/src/core/ext/upb-generated/envoy/api/v2/listener/listener.upb.h +0 -32
  1057. data/src/core/ext/upb-generated/envoy/api/v2/listener/listener_components.upb.c +0 -145
  1058. data/src/core/ext/upb-generated/envoy/api/v2/listener/listener_components.upb.h +0 -538
  1059. data/src/core/ext/upb-generated/envoy/api/v2/listener/udp_listener_config.upb.c +0 -43
  1060. data/src/core/ext/upb-generated/envoy/api/v2/listener/udp_listener_config.upb.h +0 -111
  1061. data/src/core/ext/upb-generated/envoy/api/v2/rds.upb.h +0 -52
  1062. data/src/core/ext/upb-generated/envoy/api/v2/route.upb.c +0 -63
  1063. data/src/core/ext/upb-generated/envoy/api/v2/route.upb.h +0 -204
  1064. data/src/core/ext/upb-generated/envoy/api/v2/route/route.upb.c +0 -18
  1065. data/src/core/ext/upb-generated/envoy/api/v2/route/route.upb.h +0 -32
  1066. data/src/core/ext/upb-generated/envoy/api/v2/route/route_components.upb.c +0 -815
  1067. data/src/core/ext/upb-generated/envoy/api/v2/route/route_components.upb.h +0 -2984
  1068. data/src/core/ext/upb-generated/envoy/api/v2/scoped_route.upb.c +0 -59
  1069. data/src/core/ext/upb-generated/envoy/api/v2/scoped_route.upb.h +0 -135
  1070. data/src/core/ext/upb-generated/envoy/api/v2/srds.upb.h +0 -52
  1071. data/src/core/ext/upb-generated/envoy/config/filter/accesslog/v2/accesslog.upb.c +0 -228
  1072. data/src/core/ext/upb-generated/envoy/config/filter/accesslog/v2/accesslog.upb.h +0 -732
  1073. data/src/core/ext/upb-generated/envoy/config/filter/network/http_connection_manager/v2/http_connection_manager.upb.c +0 -316
  1074. data/src/core/ext/upb-generated/envoy/config/filter/network/http_connection_manager/v2/http_connection_manager.upb.h +0 -1167
  1075. data/src/core/ext/upb-generated/envoy/config/listener/v2/api_listener.upb.c +0 -33
  1076. data/src/core/ext/upb-generated/envoy/config/listener/v2/api_listener.upb.h +0 -65
  1077. data/src/core/ext/upb-generated/envoy/config/trace/v2/http_tracer.upb.c +0 -51
  1078. data/src/core/ext/upb-generated/envoy/config/trace/v2/http_tracer.upb.h +0 -125
  1079. data/src/core/ext/upb-generated/envoy/service/discovery/v2/ads.upb.h +0 -49
  1080. data/src/core/ext/upb-generated/envoy/service/load_stats/v2/lrs.upb.c +0 -54
  1081. data/src/core/ext/upb-generated/envoy/service/load_stats/v2/lrs.upb.h +0 -136
  1082. data/src/core/ext/upb-generated/envoy/type/matcher/regex.upb.c +0 -63
  1083. data/src/core/ext/upb-generated/envoy/type/matcher/regex.upb.h +0 -145
  1084. data/src/core/ext/upb-generated/envoy/type/matcher/string.upb.c +0 -53
  1085. data/src/core/ext/upb-generated/envoy/type/matcher/string.upb.h +0 -133
  1086. data/src/core/ext/upb-generated/envoy/type/metadata/v2/metadata.upb.c +0 -88
  1087. data/src/core/ext/upb-generated/envoy/type/metadata/v2/metadata.upb.h +0 -258
  1088. data/src/core/ext/upb-generated/envoy/type/percent.upb.c +0 -39
  1089. data/src/core/ext/upb-generated/envoy/type/percent.upb.h +0 -86
  1090. data/src/core/ext/upb-generated/envoy/type/range.upb.c +0 -50
  1091. data/src/core/ext/upb-generated/envoy/type/range.upb.h +0 -111
  1092. data/src/core/ext/upb-generated/envoy/type/semantic_version.upb.h +0 -61
  1093. data/src/core/ext/upb-generated/envoy/type/tracing/v2/custom_tag.upb.c +0 -89
  1094. data/src/core/ext/upb-generated/envoy/type/tracing/v2/custom_tag.upb.h +0 -250
  1095. data/src/core/ext/upb-generated/gogoproto/gogo.upb.c +0 -17
  1096. data/src/core/lib/gprpp/map.h +0 -53
  1097. data/src/core/lib/security/transport/target_authority_table.cc +0 -75
  1098. data/src/core/lib/security/transport/target_authority_table.h +0 -40
  1099. data/src/core/lib/slice/slice_hash_table.h +0 -199
  1100. data/src/core/lib/slice/slice_weak_hash_table.h +0 -102
  1101. data/third_party/abseil-cpp/absl/base/dynamic_annotations.cc +0 -129
  1102. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_pku.c +0 -110
  1103. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_sxnet.c +0 -274
  1104. data/third_party/upb/upb/port.c +0 -26
@@ -32,34 +32,12 @@
32
32
  // of them are not supported in older version of Clang. Thus, we check
33
33
  // `__has_attribute()` first. If the check fails, we check if we are on GCC and
34
34
  // assume the attribute exists on GCC (which is verified on GCC 4.7).
35
- //
36
- // -----------------------------------------------------------------------------
37
- // Sanitizer Attributes
38
- // -----------------------------------------------------------------------------
39
- //
40
- // Sanitizer-related attributes are not "defined" in this file (and indeed
41
- // are not defined as such in any file). To utilize the following
42
- // sanitizer-related attributes within your builds, define the following macros
43
- // within your build using a `-D` flag, along with the given value for
44
- // `-fsanitize`:
45
- //
46
- // * `ADDRESS_SANITIZER` + `-fsanitize=address` (Clang, GCC 4.8)
47
- // * `MEMORY_SANITIZER` + `-fsanitize=memory` (Clang-only)
48
- // * `THREAD_SANITIZER + `-fsanitize=thread` (Clang, GCC 4.8+)
49
- // * `UNDEFINED_BEHAVIOR_SANITIZER` + `-fsanitize=undefined` (Clang, GCC 4.9+)
50
- // * `CONTROL_FLOW_INTEGRITY` + -fsanitize=cfi (Clang-only)
51
- //
52
- // Example:
53
- //
54
- // // Enable branches in the Abseil code that are tagged for ASan:
55
- // $ bazel build --copt=-DADDRESS_SANITIZER --copt=-fsanitize=address
56
- // --linkopt=-fsanitize=address *target*
57
- //
58
- // Since these macro names are only supported by GCC and Clang, we only check
59
- // for `__GNUC__` (GCC or Clang) and the above macros.
35
+
60
36
  #ifndef ABSL_BASE_ATTRIBUTES_H_
61
37
  #define ABSL_BASE_ATTRIBUTES_H_
62
38
 
39
+ #include "absl/base/config.h"
40
+
63
41
  // ABSL_HAVE_ATTRIBUTE
64
42
  //
65
43
  // A function-like feature checking macro that is a wrapper around
@@ -234,7 +212,7 @@
234
212
  // out of bounds or does other scary things with memory.
235
213
  // NOTE: GCC supports AddressSanitizer(asan) since 4.8.
236
214
  // https://gcc.gnu.org/gcc-4.8/changes.html
237
- #if defined(__GNUC__)
215
+ #if ABSL_HAVE_ATTRIBUTE(no_sanitize_address)
238
216
  #define ABSL_ATTRIBUTE_NO_SANITIZE_ADDRESS __attribute__((no_sanitize_address))
239
217
  #else
240
218
  #define ABSL_ATTRIBUTE_NO_SANITIZE_ADDRESS
@@ -242,13 +220,13 @@
242
220
 
243
221
  // ABSL_ATTRIBUTE_NO_SANITIZE_MEMORY
244
222
  //
245
- // Tells the MemorySanitizer to relax the handling of a given function. All
246
- // "Use of uninitialized value" warnings from such functions will be suppressed,
247
- // and all values loaded from memory will be considered fully initialized.
248
- // This attribute is similar to the ADDRESS_SANITIZER attribute above, but deals
249
- // with initialized-ness rather than addressability issues.
223
+ // Tells the MemorySanitizer to relax the handling of a given function. All "Use
224
+ // of uninitialized value" warnings from such functions will be suppressed, and
225
+ // all values loaded from memory will be considered fully initialized. This
226
+ // attribute is similar to the ABSL_ATTRIBUTE_NO_SANITIZE_ADDRESS attribute
227
+ // above, but deals with initialized-ness rather than addressability issues.
250
228
  // NOTE: MemorySanitizer(msan) is supported by Clang but not GCC.
251
- #if defined(__clang__)
229
+ #if ABSL_HAVE_ATTRIBUTE(no_sanitize_memory)
252
230
  #define ABSL_ATTRIBUTE_NO_SANITIZE_MEMORY __attribute__((no_sanitize_memory))
253
231
  #else
254
232
  #define ABSL_ATTRIBUTE_NO_SANITIZE_MEMORY
@@ -259,7 +237,7 @@
259
237
  // Tells the ThreadSanitizer to not instrument a given function.
260
238
  // NOTE: GCC supports ThreadSanitizer(tsan) since 4.8.
261
239
  // https://gcc.gnu.org/gcc-4.8/changes.html
262
- #if defined(__GNUC__)
240
+ #if ABSL_HAVE_ATTRIBUTE(no_sanitize_thread)
263
241
  #define ABSL_ATTRIBUTE_NO_SANITIZE_THREAD __attribute__((no_sanitize_thread))
264
242
  #else
265
243
  #define ABSL_ATTRIBUTE_NO_SANITIZE_THREAD
@@ -271,8 +249,10 @@
271
249
  // where certain behavior (eg. division by zero) is being used intentionally.
272
250
  // NOTE: GCC supports UndefinedBehaviorSanitizer(ubsan) since 4.9.
273
251
  // https://gcc.gnu.org/gcc-4.9/changes.html
274
- #if defined(__GNUC__) && \
275
- (defined(UNDEFINED_BEHAVIOR_SANITIZER) || defined(ADDRESS_SANITIZER))
252
+ #if ABSL_HAVE_ATTRIBUTE(no_sanitize_undefined)
253
+ #define ABSL_ATTRIBUTE_NO_SANITIZE_UNDEFINED \
254
+ __attribute__((no_sanitize_undefined))
255
+ #elif ABSL_HAVE_ATTRIBUTE(no_sanitize)
276
256
  #define ABSL_ATTRIBUTE_NO_SANITIZE_UNDEFINED \
277
257
  __attribute__((no_sanitize("undefined")))
278
258
  #else
@@ -283,7 +263,7 @@
283
263
  //
284
264
  // Tells the ControlFlowIntegrity sanitizer to not instrument a given function.
285
265
  // See https://clang.llvm.org/docs/ControlFlowIntegrity.html for details.
286
- #if defined(__GNUC__) && defined(CONTROL_FLOW_INTEGRITY)
266
+ #if ABSL_HAVE_ATTRIBUTE(no_sanitize)
287
267
  #define ABSL_ATTRIBUTE_NO_SANITIZE_CFI __attribute__((no_sanitize("cfi")))
288
268
  #else
289
269
  #define ABSL_ATTRIBUTE_NO_SANITIZE_CFI
@@ -293,7 +273,7 @@
293
273
  //
294
274
  // Tells the SafeStack to not instrument a given function.
295
275
  // See https://clang.llvm.org/docs/SafeStack.html for details.
296
- #if defined(__GNUC__) && defined(SAFESTACK_SANITIZER)
276
+ #if ABSL_HAVE_ATTRIBUTE(no_sanitize)
297
277
  #define ABSL_ATTRIBUTE_NO_SANITIZE_SAFESTACK \
298
278
  __attribute__((no_sanitize("safe-stack")))
299
279
  #else
@@ -507,8 +487,10 @@
507
487
  // packages/targets, as this may lead to conflicting definitions of functions at
508
488
  // link-time.
509
489
  //
490
+ // XRay isn't currently supported on Android:
491
+ // https://github.com/android/ndk/issues/368
510
492
  #if ABSL_HAVE_CPP_ATTRIBUTE(clang::xray_always_instrument) && \
511
- !defined(ABSL_NO_XRAY_ATTRIBUTES)
493
+ !defined(ABSL_NO_XRAY_ATTRIBUTES) && !defined(__ANDROID__)
512
494
  #define ABSL_XRAY_ALWAYS_INSTRUMENT [[clang::xray_always_instrument]]
513
495
  #define ABSL_XRAY_NEVER_INSTRUMENT [[clang::xray_never_instrument]]
514
496
  #if ABSL_HAVE_CPP_ATTRIBUTE(clang::xray_log_args)
@@ -592,6 +574,85 @@
592
574
  #define ABSL_ATTRIBUTE_FUNC_ALIGN(bytes)
593
575
  #endif
594
576
 
577
+ // ABSL_FALLTHROUGH_INTENDED
578
+ //
579
+ // Annotates implicit fall-through between switch labels, allowing a case to
580
+ // indicate intentional fallthrough and turn off warnings about any lack of a
581
+ // `break` statement. The ABSL_FALLTHROUGH_INTENDED macro should be followed by
582
+ // a semicolon and can be used in most places where `break` can, provided that
583
+ // no statements exist between it and the next switch label.
584
+ //
585
+ // Example:
586
+ //
587
+ // switch (x) {
588
+ // case 40:
589
+ // case 41:
590
+ // if (truth_is_out_there) {
591
+ // ++x;
592
+ // ABSL_FALLTHROUGH_INTENDED; // Use instead of/along with annotations
593
+ // // in comments
594
+ // } else {
595
+ // return x;
596
+ // }
597
+ // case 42:
598
+ // ...
599
+ //
600
+ // Notes: when compiled with clang in C++11 mode, the ABSL_FALLTHROUGH_INTENDED
601
+ // macro is expanded to the [[clang::fallthrough]] attribute, which is analysed
602
+ // when performing switch labels fall-through diagnostic
603
+ // (`-Wimplicit-fallthrough`). See clang documentation on language extensions
604
+ // for details:
605
+ // https://clang.llvm.org/docs/AttributeReference.html#fallthrough-clang-fallthrough
606
+ //
607
+ // When used with unsupported compilers, the ABSL_FALLTHROUGH_INTENDED macro
608
+ // has no effect on diagnostics. In any case this macro has no effect on runtime
609
+ // behavior and performance of code.
610
+ #ifdef ABSL_FALLTHROUGH_INTENDED
611
+ #error "ABSL_FALLTHROUGH_INTENDED should not be defined."
612
+ #endif
613
+
614
+ // TODO(zhangxy): Use c++17 standard [[fallthrough]] macro, when supported.
615
+ #if defined(__clang__) && defined(__has_warning)
616
+ #if __has_feature(cxx_attributes) && __has_warning("-Wimplicit-fallthrough")
617
+ #define ABSL_FALLTHROUGH_INTENDED [[clang::fallthrough]]
618
+ #endif
619
+ #elif defined(__GNUC__) && __GNUC__ >= 7
620
+ #define ABSL_FALLTHROUGH_INTENDED [[gnu::fallthrough]]
621
+ #endif
622
+
623
+ #ifndef ABSL_FALLTHROUGH_INTENDED
624
+ #define ABSL_FALLTHROUGH_INTENDED \
625
+ do { \
626
+ } while (0)
627
+ #endif
628
+
629
+ // ABSL_DEPRECATED()
630
+ //
631
+ // Marks a deprecated class, struct, enum, function, method and variable
632
+ // declarations. The macro argument is used as a custom diagnostic message (e.g.
633
+ // suggestion of a better alternative).
634
+ //
635
+ // Examples:
636
+ //
637
+ // class ABSL_DEPRECATED("Use Bar instead") Foo {...};
638
+ //
639
+ // ABSL_DEPRECATED("Use Baz() instead") void Bar() {...}
640
+ //
641
+ // template <typename T>
642
+ // ABSL_DEPRECATED("Use DoThat() instead")
643
+ // void DoThis();
644
+ //
645
+ // Every usage of a deprecated entity will trigger a warning when compiled with
646
+ // clang's `-Wdeprecated-declarations` option. This option is turned off by
647
+ // default, but the warnings will be reported by clang-tidy.
648
+ #if defined(__clang__) && __cplusplus >= 201103L
649
+ #define ABSL_DEPRECATED(message) __attribute__((deprecated(message)))
650
+ #endif
651
+
652
+ #ifndef ABSL_DEPRECATED
653
+ #define ABSL_DEPRECATED(message)
654
+ #endif
655
+
595
656
  // ABSL_CONST_INIT
596
657
  //
597
658
  // A variable declaration annotated with the `ABSL_CONST_INIT` attribute will
@@ -175,7 +175,7 @@ void CallOnceImpl(std::atomic<uint32_t>* control,
175
175
  std::memory_order_relaxed) ||
176
176
  base_internal::SpinLockWait(control, ABSL_ARRAYSIZE(trans), trans,
177
177
  scheduling_mode) == kOnceInit) {
178
- base_internal::Invoke(std::forward<Callable>(fn),
178
+ base_internal::invoke(std::forward<Callable>(fn),
179
179
  std::forward<Args>(args)...);
180
180
  // The call to SpinLockWake below is an optimization, because the waiter
181
181
  // in SpinLockWait is waiting with a short timeout. The atomic load/store
@@ -159,16 +159,19 @@ inline Dest bit_cast(const Source& source) {
159
159
  return dest;
160
160
  }
161
161
 
162
- // NOTE: This overload is only picked if the requirements of bit_cast are not
163
- // met. It is therefore UB, but is provided temporarily as previous versions of
164
- // this function template were unchecked. Do not use this in new code.
162
+ // NOTE: This overload is only picked if the requirements of bit_cast are
163
+ // not met. It is therefore UB, but is provided temporarily as previous
164
+ // versions of this function template were unchecked. Do not use this in
165
+ // new code.
165
166
  template <
166
167
  typename Dest, typename Source,
167
168
  typename std::enable_if<
168
- !internal_casts::is_bitcastable<Dest, Source>::value, int>::type = 0>
169
+ !internal_casts::is_bitcastable<Dest, Source>::value,
170
+ int>::type = 0>
169
171
  ABSL_DEPRECATED(
170
- "absl::bit_cast type requirements were violated. Update the types being "
171
- "used such that they are the same size and are both TriviallyCopyable.")
172
+ "absl::bit_cast type requirements were violated. Update the types "
173
+ "being used such that they are the same size and are both "
174
+ "TriviallyCopyable.")
172
175
  inline Dest bit_cast(const Source& source) {
173
176
  static_assert(sizeof(Dest) == sizeof(Source),
174
177
  "Source and destination types should have equal sizes.");
@@ -154,6 +154,12 @@ static_assert(ABSL_INTERNAL_INLINE_NAMESPACE_STR[0] != 'h' ||
154
154
  #define ABSL_INTERNAL_HAS_KEYWORD(x) 0
155
155
  #endif
156
156
 
157
+ #ifdef __has_feature
158
+ #define ABSL_HAVE_FEATURE(f) __has_feature(f)
159
+ #else
160
+ #define ABSL_HAVE_FEATURE(f) 0
161
+ #endif
162
+
157
163
  // ABSL_HAVE_TLS is defined to 1 when __thread should be supported.
158
164
  // We assume __thread is supported on Linux when compiled with Clang or compiled
159
165
  // against libstdc++ with _GLIBCXX_HAVE_TLS defined.
@@ -226,11 +232,9 @@ static_assert(ABSL_INTERNAL_INLINE_NAMESPACE_STR[0] != 'h' ||
226
232
  // * Xcode 9.3 started disallowing `thread_local` for 32-bit iOS simulator
227
233
  // targeting iOS 9.x.
228
234
  // * Xcode 10 moves the deployment target check for iOS < 9.0 to link time
229
- // making __has_feature unreliable there.
235
+ // making ABSL_HAVE_FEATURE unreliable there.
230
236
  //
231
- // Otherwise, `__has_feature` is only supported by Clang so it has be inside
232
- // `defined(__APPLE__)` check.
233
- #if __has_feature(cxx_thread_local) && \
237
+ #if ABSL_HAVE_FEATURE(cxx_thread_local) && \
234
238
  !(TARGET_OS_IPHONE && __IPHONE_OS_VERSION_MIN_REQUIRED < __IPHONE_9_0)
235
239
  #define ABSL_HAVE_THREAD_LOCAL 1
236
240
  #endif
@@ -262,13 +266,6 @@ static_assert(ABSL_INTERNAL_INLINE_NAMESPACE_STR[0] != 'h' ||
262
266
  #endif
263
267
  #endif // defined(__ANDROID__) && defined(__clang__)
264
268
 
265
- // Emscripten doesn't yet support `thread_local` or `__thread`.
266
- // https://github.com/emscripten-core/emscripten/issues/3502
267
- #if defined(__EMSCRIPTEN__)
268
- #undef ABSL_HAVE_TLS
269
- #undef ABSL_HAVE_THREAD_LOCAL
270
- #endif // defined(__EMSCRIPTEN__)
271
-
272
269
  // ABSL_HAVE_INTRINSIC_INT128
273
270
  //
274
271
  // Checks whether the __int128 compiler extension for a 128-bit integral type is
@@ -319,15 +316,15 @@ static_assert(ABSL_INTERNAL_INLINE_NAMESPACE_STR[0] != 'h' ||
319
316
 
320
317
  #if __clang_major__ > 3 || (__clang_major__ == 3 && __clang_minor__ >= 6)
321
318
  // Clang >= 3.6
322
- #if __has_feature(cxx_exceptions)
319
+ #if ABSL_HAVE_FEATURE(cxx_exceptions)
323
320
  #define ABSL_HAVE_EXCEPTIONS 1
324
- #endif // __has_feature(cxx_exceptions)
321
+ #endif // ABSL_HAVE_FEATURE(cxx_exceptions)
325
322
  #else
326
323
  // Clang < 3.6
327
324
  // http://releases.llvm.org/3.6.0/tools/clang/docs/ReleaseNotes.html#the-exceptions-macro
328
- #if defined(__EXCEPTIONS) && __has_feature(cxx_exceptions)
325
+ #if defined(__EXCEPTIONS) && ABSL_HAVE_FEATURE(cxx_exceptions)
329
326
  #define ABSL_HAVE_EXCEPTIONS 1
330
- #endif // defined(__EXCEPTIONS) && __has_feature(cxx_exceptions)
327
+ #endif // defined(__EXCEPTIONS) && ABSL_HAVE_FEATURE(cxx_exceptions)
331
328
  #endif // __clang_major__ > 3 || (__clang_major__ == 3 && __clang_minor__ >= 6)
332
329
 
333
330
  // Handle remaining special cases and default to exceptions being supported.
@@ -477,9 +474,9 @@ static_assert(ABSL_INTERNAL_INLINE_NAMESPACE_STR[0] != 'h' ||
477
474
  (defined(__ENVIRONMENT_IPHONE_OS_VERSION_MIN_REQUIRED__) && \
478
475
  __ENVIRONMENT_IPHONE_OS_VERSION_MIN_REQUIRED__ < 120000) || \
479
476
  (defined(__ENVIRONMENT_WATCH_OS_VERSION_MIN_REQUIRED__) && \
480
- __ENVIRONMENT_WATCH_OS_VERSION_MIN_REQUIRED__ < 120000) || \
477
+ __ENVIRONMENT_WATCH_OS_VERSION_MIN_REQUIRED__ < 50000) || \
481
478
  (defined(__ENVIRONMENT_TV_OS_VERSION_MIN_REQUIRED__) && \
482
- __ENVIRONMENT_TV_OS_VERSION_MIN_REQUIRED__ < 50000))
479
+ __ENVIRONMENT_TV_OS_VERSION_MIN_REQUIRED__ < 120000))
483
480
  #define ABSL_INTERNAL_APPLE_CXX17_TYPES_UNAVAILABLE 1
484
481
  #else
485
482
  #define ABSL_INTERNAL_APPLE_CXX17_TYPES_UNAVAILABLE 0
@@ -668,4 +665,50 @@ static_assert(ABSL_INTERNAL_INLINE_NAMESPACE_STR[0] != 'h' ||
668
665
  #define ABSL_DLL
669
666
  #endif // defined(_MSC_VER)
670
667
 
668
+ // ABSL_HAVE_MEMORY_SANITIZER
669
+ //
670
+ // MemorySanitizer (MSan) is a detector of uninitialized reads. It consists of
671
+ // a compiler instrumentation module and a run-time library.
672
+ #ifdef ABSL_HAVE_MEMORY_SANITIZER
673
+ #error "ABSL_HAVE_MEMORY_SANITIZER cannot be directly set."
674
+ #elif defined(MEMORY_SANITIZER)
675
+ // The MEMORY_SANITIZER macro is deprecated but we will continue to honor it
676
+ // for now.
677
+ #define ABSL_HAVE_MEMORY_SANITIZER 1
678
+ #elif defined(__SANITIZE_MEMORY__)
679
+ #define ABSL_HAVE_MEMORY_SANITIZER 1
680
+ #elif !defined(__native_client__) && ABSL_HAVE_FEATURE(memory_sanitizer)
681
+ #define ABSL_HAVE_MEMORY_SANITIZER 1
682
+ #endif
683
+
684
+ // ABSL_HAVE_THREAD_SANITIZER
685
+ //
686
+ // ThreadSanitizer (TSan) is a fast data race detector.
687
+ #ifdef ABSL_HAVE_THREAD_SANITIZER
688
+ #error "ABSL_HAVE_THREAD_SANITIZER cannot be directly set."
689
+ #elif defined(THREAD_SANITIZER)
690
+ // The THREAD_SANITIZER macro is deprecated but we will continue to honor it
691
+ // for now.
692
+ #define ABSL_HAVE_THREAD_SANITIZER 1
693
+ #elif defined(__SANITIZE_THREAD__)
694
+ #define ABSL_HAVE_THREAD_SANITIZER 1
695
+ #elif ABSL_HAVE_FEATURE(thread_sanitizer)
696
+ #define ABSL_HAVE_THREAD_SANITIZER 1
697
+ #endif
698
+
699
+ // ABSL_HAVE_ADDRESS_SANITIZER
700
+ //
701
+ // AddressSanitizer (ASan) is a fast memory error detector.
702
+ #ifdef ABSL_HAVE_ADDRESS_SANITIZER
703
+ #error "ABSL_HAVE_ADDRESS_SANITIZER cannot be directly set."
704
+ #elif defined(ADDRESS_SANITIZER)
705
+ // The ADDRESS_SANITIZER macro is deprecated but we will continue to honor it
706
+ // for now.
707
+ #define ABSL_HAVE_ADDRESS_SANITIZER 1
708
+ #elif defined(__SANITIZE_ADDRESS__)
709
+ #define ABSL_HAVE_ADDRESS_SANITIZER 1
710
+ #elif ABSL_HAVE_FEATURE(address_sanitizer)
711
+ #define ABSL_HAVE_ADDRESS_SANITIZER 1
712
+ #endif
713
+
671
714
  #endif // ABSL_BASE_CONFIG_H_
@@ -1,389 +1,482 @@
1
- /*
2
- * Copyright 2017 The Abseil Authors.
3
- *
4
- * Licensed under the Apache License, Version 2.0 (the "License");
5
- * you may not use this file except in compliance with the License.
6
- * You may obtain a copy of the License at
7
- *
8
- * https://www.apache.org/licenses/LICENSE-2.0
9
- *
10
- * Unless required by applicable law or agreed to in writing, software
11
- * distributed under the License is distributed on an "AS IS" BASIS,
12
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
- * See the License for the specific language governing permissions and
14
- * limitations under the License.
15
- */
16
- /* This file defines dynamic annotations for use with dynamic analysis
17
- tool such as valgrind, PIN, etc.
18
-
19
- Dynamic annotation is a source code annotation that affects
20
- the generated code (that is, the annotation is not a comment).
21
- Each such annotation is attached to a particular
22
- instruction and/or to a particular object (address) in the program.
23
-
24
- The annotations that should be used by users are macros in all upper-case
25
- (e.g., ANNOTATE_THREAD_NAME).
26
-
27
- Actual implementation of these macros may differ depending on the
28
- dynamic analysis tool being used.
29
-
30
- This file supports the following configurations:
31
- - Dynamic Annotations enabled (with static thread-safety warnings disabled).
32
- In this case, macros expand to functions implemented by Thread Sanitizer,
33
- when building with TSan. When not provided an external implementation,
34
- dynamic_annotations.cc provides no-op implementations.
35
-
36
- - Static Clang thread-safety warnings enabled.
37
- When building with a Clang compiler that supports thread-safety warnings,
38
- a subset of annotations can be statically-checked at compile-time. We
39
- expand these macros to static-inline functions that can be analyzed for
40
- thread-safety, but afterwards elided when building the final binary.
41
-
42
- - All annotations are disabled.
43
- If neither Dynamic Annotations nor Clang thread-safety warnings are
44
- enabled, then all annotation-macros expand to empty. */
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 defines dynamic annotations for use with dynamic analysis tool
16
+ // such as valgrind, PIN, etc.
17
+ //
18
+ // Dynamic annotation is a source code annotation that affects the generated
19
+ // code (that is, the annotation is not a comment). Each such annotation is
20
+ // attached to a particular instruction and/or to a particular object (address)
21
+ // in the program.
22
+ //
23
+ // The annotations that should be used by users are macros in all upper-case
24
+ // (e.g., ABSL_ANNOTATE_THREAD_NAME).
25
+ //
26
+ // Actual implementation of these macros may differ depending on the dynamic
27
+ // analysis tool being used.
28
+ //
29
+ // This file supports the following configurations:
30
+ // - Dynamic Annotations enabled (with static thread-safety warnings disabled).
31
+ // In this case, macros expand to functions implemented by Thread Sanitizer,
32
+ // when building with TSan. When not provided an external implementation,
33
+ // dynamic_annotations.cc provides no-op implementations.
34
+ //
35
+ // - Static Clang thread-safety warnings enabled.
36
+ // When building with a Clang compiler that supports thread-safety warnings,
37
+ // a subset of annotations can be statically-checked at compile-time. We
38
+ // expand these macros to static-inline functions that can be analyzed for
39
+ // thread-safety, but afterwards elided when building the final binary.
40
+ //
41
+ // - All annotations are disabled.
42
+ // If neither Dynamic Annotations nor Clang thread-safety warnings are
43
+ // enabled, then all annotation-macros expand to empty.
45
44
 
46
45
  #ifndef ABSL_BASE_DYNAMIC_ANNOTATIONS_H_
47
46
  #define ABSL_BASE_DYNAMIC_ANNOTATIONS_H_
48
47
 
49
- #ifndef DYNAMIC_ANNOTATIONS_ENABLED
50
- # define DYNAMIC_ANNOTATIONS_ENABLED 0
51
- #endif
48
+ #include <stddef.h>
52
49
 
53
- #if DYNAMIC_ANNOTATIONS_ENABLED != 0
54
-
55
- /* -------------------------------------------------------------
56
- Annotations that suppress errors. It is usually better to express the
57
- program's synchronization using the other annotations, but these can
58
- be used when all else fails. */
59
-
60
- /* Report that we may have a benign race at "pointer", with size
61
- "sizeof(*(pointer))". "pointer" must be a non-void* pointer. Insert at the
62
- point where "pointer" has been allocated, preferably close to the point
63
- where the race happens. See also ANNOTATE_BENIGN_RACE_STATIC. */
64
- #define ANNOTATE_BENIGN_RACE(pointer, description) \
65
- AnnotateBenignRaceSized(__FILE__, __LINE__, pointer, \
66
- sizeof(*(pointer)), description)
67
-
68
- /* Same as ANNOTATE_BENIGN_RACE(address, description), but applies to
69
- the memory range [address, address+size). */
70
- #define ANNOTATE_BENIGN_RACE_SIZED(address, size, description) \
71
- AnnotateBenignRaceSized(__FILE__, __LINE__, address, size, description)
72
-
73
- /* Enable (enable!=0) or disable (enable==0) race detection for all threads.
74
- This annotation could be useful if you want to skip expensive race analysis
75
- during some period of program execution, e.g. during initialization. */
76
- #define ANNOTATE_ENABLE_RACE_DETECTION(enable) \
77
- AnnotateEnableRaceDetection(__FILE__, __LINE__, enable)
78
-
79
- /* -------------------------------------------------------------
80
- Annotations useful for debugging. */
81
-
82
- /* Report the current thread name to a race detector. */
83
- #define ANNOTATE_THREAD_NAME(name) \
84
- AnnotateThreadName(__FILE__, __LINE__, name)
85
-
86
- /* -------------------------------------------------------------
87
- Annotations useful when implementing locks. They are not
88
- normally needed by modules that merely use locks.
89
- The "lock" argument is a pointer to the lock object. */
90
-
91
- /* Report that a lock has been created at address "lock". */
92
- #define ANNOTATE_RWLOCK_CREATE(lock) \
93
- AnnotateRWLockCreate(__FILE__, __LINE__, lock)
94
-
95
- /* Report that a linker initialized lock has been created at address "lock".
96
- */
97
- #ifdef THREAD_SANITIZER
98
- #define ANNOTATE_RWLOCK_CREATE_STATIC(lock) \
99
- AnnotateRWLockCreateStatic(__FILE__, __LINE__, lock)
100
- #else
101
- #define ANNOTATE_RWLOCK_CREATE_STATIC(lock) ANNOTATE_RWLOCK_CREATE(lock)
50
+ #include "absl/base/attributes.h"
51
+ #include "absl/base/config.h"
52
+ #ifdef __cplusplus
53
+ #include "absl/base/macros.h"
102
54
  #endif
103
55
 
104
- /* Report that the lock at address "lock" is about to be destroyed. */
105
- #define ANNOTATE_RWLOCK_DESTROY(lock) \
106
- AnnotateRWLockDestroy(__FILE__, __LINE__, lock)
56
+ // TODO(rogeeff): Remove after the backward compatibility period.
57
+ #include "absl/base/internal/dynamic_annotations.h" // IWYU pragma: export
107
58
 
108
- /* Report that the lock at address "lock" has been acquired.
109
- is_w=1 for writer lock, is_w=0 for reader lock. */
110
- #define ANNOTATE_RWLOCK_ACQUIRED(lock, is_w) \
111
- AnnotateRWLockAcquired(__FILE__, __LINE__, lock, is_w)
59
+ // -------------------------------------------------------------------------
60
+ // Decide which features are enabled.
112
61
 
113
- /* Report that the lock at address "lock" is about to be released. */
114
- #define ANNOTATE_RWLOCK_RELEASED(lock, is_w) \
115
- AnnotateRWLockReleased(__FILE__, __LINE__, lock, is_w)
62
+ #ifdef ABSL_HAVE_THREAD_SANITIZER
116
63
 
117
- #else /* DYNAMIC_ANNOTATIONS_ENABLED == 0 */
64
+ #define ABSL_INTERNAL_RACE_ANNOTATIONS_ENABLED 1
65
+ #define ABSL_INTERNAL_READS_ANNOTATIONS_ENABLED 1
66
+ #define ABSL_INTERNAL_WRITES_ANNOTATIONS_ENABLED 1
67
+ #define ABSL_INTERNAL_ANNOTALYSIS_ENABLED 0
68
+ #define ABSL_INTERNAL_READS_WRITES_ANNOTATIONS_ENABLED 1
118
69
 
119
- #define ANNOTATE_RWLOCK_CREATE(lock) /* empty */
120
- #define ANNOTATE_RWLOCK_CREATE_STATIC(lock) /* empty */
121
- #define ANNOTATE_RWLOCK_DESTROY(lock) /* empty */
122
- #define ANNOTATE_RWLOCK_ACQUIRED(lock, is_w) /* empty */
123
- #define ANNOTATE_RWLOCK_RELEASED(lock, is_w) /* empty */
124
- #define ANNOTATE_BENIGN_RACE(address, description) /* empty */
125
- #define ANNOTATE_BENIGN_RACE_SIZED(address, size, description) /* empty */
126
- #define ANNOTATE_THREAD_NAME(name) /* empty */
127
- #define ANNOTATE_ENABLE_RACE_DETECTION(enable) /* empty */
70
+ #else
128
71
 
129
- #endif /* DYNAMIC_ANNOTATIONS_ENABLED */
72
+ #define ABSL_INTERNAL_RACE_ANNOTATIONS_ENABLED 0
73
+ #define ABSL_INTERNAL_READS_ANNOTATIONS_ENABLED 0
74
+ #define ABSL_INTERNAL_WRITES_ANNOTATIONS_ENABLED 0
130
75
 
131
- /* These annotations are also made available to LLVM's Memory Sanitizer */
132
- #if DYNAMIC_ANNOTATIONS_ENABLED == 1 || defined(MEMORY_SANITIZER)
133
- #define ANNOTATE_MEMORY_IS_INITIALIZED(address, size) \
134
- AnnotateMemoryIsInitialized(__FILE__, __LINE__, address, size)
76
+ // Clang provides limited support for static thread-safety analysis through a
77
+ // feature called Annotalysis. We configure macro-definitions according to
78
+ // whether Annotalysis support is available. When running in opt-mode, GCC
79
+ // will issue a warning, if these attributes are compiled. Only include them
80
+ // when compiling using Clang.
135
81
 
136
- #define ANNOTATE_MEMORY_IS_UNINITIALIZED(address, size) \
137
- AnnotateMemoryIsUninitialized(__FILE__, __LINE__, address, size)
82
+ #if defined(__clang__)
83
+ #define ABSL_INTERNAL_ANNOTALYSIS_ENABLED 1
84
+ #if !defined(SWIG)
85
+ #define ABSL_INTERNAL_IGNORE_READS_ATTRIBUTE_ENABLED 1
86
+ #endif
138
87
  #else
139
- #define ANNOTATE_MEMORY_IS_INITIALIZED(address, size) /* empty */
140
- #define ANNOTATE_MEMORY_IS_UNINITIALIZED(address, size) /* empty */
141
- #endif /* DYNAMIC_ANNOTATIONS_ENABLED || MEMORY_SANITIZER */
142
-
143
- /* TODO(delesley) -- Replace __CLANG_SUPPORT_DYN_ANNOTATION__ with the
144
- appropriate feature ID. */
145
- #if defined(__clang__) && (!defined(SWIG)) \
146
- && defined(__CLANG_SUPPORT_DYN_ANNOTATION__)
147
-
148
- #if DYNAMIC_ANNOTATIONS_ENABLED == 0
149
- #define ANNOTALYSIS_ENABLED
150
- #endif
151
-
152
- /* When running in opt-mode, GCC will issue a warning, if these attributes are
153
- compiled. Only include them when compiling using Clang. */
154
- #define ATTRIBUTE_IGNORE_READS_BEGIN \
155
- __attribute((exclusive_lock_function("*")))
156
- #define ATTRIBUTE_IGNORE_READS_END \
157
- __attribute((unlock_function("*")))
88
+ #define ABSL_INTERNAL_ANNOTALYSIS_ENABLED 0
89
+ #endif
90
+
91
+ // Read/write annotations are enabled in Annotalysis mode; disabled otherwise.
92
+ #define ABSL_INTERNAL_READS_WRITES_ANNOTATIONS_ENABLED \
93
+ ABSL_INTERNAL_ANNOTALYSIS_ENABLED
94
+
95
+ #endif // ABSL_HAVE_THREAD_SANITIZER
96
+
97
+ #ifdef __cplusplus
98
+ #define ABSL_INTERNAL_BEGIN_EXTERN_C extern "C" {
99
+ #define ABSL_INTERNAL_END_EXTERN_C } // extern "C"
100
+ #define ABSL_INTERNAL_GLOBAL_SCOPED(F) ::F
101
+ #define ABSL_INTERNAL_STATIC_INLINE inline
158
102
  #else
159
- #define ATTRIBUTE_IGNORE_READS_BEGIN /* empty */
160
- #define ATTRIBUTE_IGNORE_READS_END /* empty */
161
- #endif /* defined(__clang__) && ... */
103
+ #define ABSL_INTERNAL_BEGIN_EXTERN_C // empty
104
+ #define ABSL_INTERNAL_END_EXTERN_C // empty
105
+ #define ABSL_INTERNAL_GLOBAL_SCOPED(F) F
106
+ #define ABSL_INTERNAL_STATIC_INLINE static inline
107
+ #endif
162
108
 
163
- #if (DYNAMIC_ANNOTATIONS_ENABLED != 0) || defined(ANNOTALYSIS_ENABLED)
164
- #define ANNOTATIONS_ENABLED
109
+ // -------------------------------------------------------------------------
110
+ // Define race annotations.
111
+
112
+ #if ABSL_INTERNAL_RACE_ANNOTATIONS_ENABLED == 1
113
+
114
+ // -------------------------------------------------------------
115
+ // Annotations that suppress errors. It is usually better to express the
116
+ // program's synchronization using the other annotations, but these can be used
117
+ // when all else fails.
118
+
119
+ // Report that we may have a benign race at `pointer`, with size
120
+ // "sizeof(*(pointer))". `pointer` must be a non-void* pointer. Insert at the
121
+ // point where `pointer` has been allocated, preferably close to the point
122
+ // where the race happens. See also ABSL_ANNOTATE_BENIGN_RACE_STATIC.
123
+ #define ABSL_ANNOTATE_BENIGN_RACE(pointer, description) \
124
+ ABSL_INTERNAL_GLOBAL_SCOPED(AnnotateBenignRaceSized) \
125
+ (__FILE__, __LINE__, pointer, sizeof(*(pointer)), description)
126
+
127
+ // Same as ABSL_ANNOTATE_BENIGN_RACE(`address`, `description`), but applies to
128
+ // the memory range [`address`, `address`+`size`).
129
+ #define ABSL_ANNOTATE_BENIGN_RACE_SIZED(address, size, description) \
130
+ ABSL_INTERNAL_GLOBAL_SCOPED(AnnotateBenignRaceSized) \
131
+ (__FILE__, __LINE__, address, size, description)
132
+
133
+ // Enable (`enable`!=0) or disable (`enable`==0) race detection for all threads.
134
+ // This annotation could be useful if you want to skip expensive race analysis
135
+ // during some period of program execution, e.g. during initialization.
136
+ #define ABSL_ANNOTATE_ENABLE_RACE_DETECTION(enable) \
137
+ ABSL_INTERNAL_GLOBAL_SCOPED(AnnotateEnableRaceDetection) \
138
+ (__FILE__, __LINE__, enable)
139
+
140
+ // -------------------------------------------------------------
141
+ // Annotations useful for debugging.
142
+
143
+ // Report the current thread `name` to a race detector.
144
+ #define ABSL_ANNOTATE_THREAD_NAME(name) \
145
+ ABSL_INTERNAL_GLOBAL_SCOPED(AnnotateThreadName)(__FILE__, __LINE__, name)
146
+
147
+ // -------------------------------------------------------------
148
+ // Annotations useful when implementing locks. They are not normally needed by
149
+ // modules that merely use locks. The `lock` argument is a pointer to the lock
150
+ // object.
151
+
152
+ // Report that a lock has been created at address `lock`.
153
+ #define ABSL_ANNOTATE_RWLOCK_CREATE(lock) \
154
+ ABSL_INTERNAL_GLOBAL_SCOPED(AnnotateRWLockCreate)(__FILE__, __LINE__, lock)
155
+
156
+ // Report that a linker initialized lock has been created at address `lock`.
157
+ #ifdef ABSL_HAVE_THREAD_SANITIZER
158
+ #define ABSL_ANNOTATE_RWLOCK_CREATE_STATIC(lock) \
159
+ ABSL_INTERNAL_GLOBAL_SCOPED(AnnotateRWLockCreateStatic) \
160
+ (__FILE__, __LINE__, lock)
161
+ #else
162
+ #define ABSL_ANNOTATE_RWLOCK_CREATE_STATIC(lock) \
163
+ ABSL_ANNOTATE_RWLOCK_CREATE(lock)
165
164
  #endif
166
165
 
167
- #if (DYNAMIC_ANNOTATIONS_ENABLED != 0)
166
+ // Report that the lock at address `lock` is about to be destroyed.
167
+ #define ABSL_ANNOTATE_RWLOCK_DESTROY(lock) \
168
+ ABSL_INTERNAL_GLOBAL_SCOPED(AnnotateRWLockDestroy)(__FILE__, __LINE__, lock)
169
+
170
+ // Report that the lock at address `lock` has been acquired.
171
+ // `is_w`=1 for writer lock, `is_w`=0 for reader lock.
172
+ #define ABSL_ANNOTATE_RWLOCK_ACQUIRED(lock, is_w) \
173
+ ABSL_INTERNAL_GLOBAL_SCOPED(AnnotateRWLockAcquired) \
174
+ (__FILE__, __LINE__, lock, is_w)
175
+
176
+ // Report that the lock at address `lock` is about to be released.
177
+ // `is_w`=1 for writer lock, `is_w`=0 for reader lock.
178
+ #define ABSL_ANNOTATE_RWLOCK_RELEASED(lock, is_w) \
179
+ ABSL_INTERNAL_GLOBAL_SCOPED(AnnotateRWLockReleased) \
180
+ (__FILE__, __LINE__, lock, is_w)
181
+
182
+ // Apply ABSL_ANNOTATE_BENIGN_RACE_SIZED to a static variable `static_var`.
183
+ #define ABSL_ANNOTATE_BENIGN_RACE_STATIC(static_var, description) \
184
+ namespace { \
185
+ class static_var##_annotator { \
186
+ public: \
187
+ static_var##_annotator() { \
188
+ ABSL_ANNOTATE_BENIGN_RACE_SIZED(&static_var, sizeof(static_var), \
189
+ #static_var ": " description); \
190
+ } \
191
+ }; \
192
+ static static_var##_annotator the##static_var##_annotator; \
193
+ } // namespace
194
+
195
+ // Function prototypes of annotations provided by the compiler-based sanitizer
196
+ // implementation.
197
+ ABSL_INTERNAL_BEGIN_EXTERN_C
198
+ void AnnotateRWLockCreate(const char* file, int line,
199
+ const volatile void* lock);
200
+ void AnnotateRWLockCreateStatic(const char* file, int line,
201
+ const volatile void* lock);
202
+ void AnnotateRWLockDestroy(const char* file, int line,
203
+ const volatile void* lock);
204
+ void AnnotateRWLockAcquired(const char* file, int line,
205
+ const volatile void* lock, long is_w); // NOLINT
206
+ void AnnotateRWLockReleased(const char* file, int line,
207
+ const volatile void* lock, long is_w); // NOLINT
208
+ void AnnotateBenignRace(const char* file, int line,
209
+ const volatile void* address, const char* description);
210
+ void AnnotateBenignRaceSized(const char* file, int line,
211
+ const volatile void* address, size_t size,
212
+ const char* description);
213
+ void AnnotateThreadName(const char* file, int line, const char* name);
214
+ void AnnotateEnableRaceDetection(const char* file, int line, int enable);
215
+ ABSL_INTERNAL_END_EXTERN_C
216
+
217
+ #else // ABSL_INTERNAL_RACE_ANNOTATIONS_ENABLED == 0
218
+
219
+ #define ABSL_ANNOTATE_RWLOCK_CREATE(lock) // empty
220
+ #define ABSL_ANNOTATE_RWLOCK_CREATE_STATIC(lock) // empty
221
+ #define ABSL_ANNOTATE_RWLOCK_DESTROY(lock) // empty
222
+ #define ABSL_ANNOTATE_RWLOCK_ACQUIRED(lock, is_w) // empty
223
+ #define ABSL_ANNOTATE_RWLOCK_RELEASED(lock, is_w) // empty
224
+ #define ABSL_ANNOTATE_BENIGN_RACE(address, description) // empty
225
+ #define ABSL_ANNOTATE_BENIGN_RACE_SIZED(address, size, description) // empty
226
+ #define ABSL_ANNOTATE_THREAD_NAME(name) // empty
227
+ #define ABSL_ANNOTATE_ENABLE_RACE_DETECTION(enable) // empty
228
+ #define ABSL_ANNOTATE_BENIGN_RACE_STATIC(static_var, description) // empty
229
+
230
+ #endif // ABSL_INTERNAL_RACE_ANNOTATIONS_ENABLED
231
+
232
+ // -------------------------------------------------------------------------
233
+ // Define memory annotations.
234
+
235
+ #ifdef ABSL_HAVE_MEMORY_SANITIZER
236
+
237
+ #include <sanitizer/msan_interface.h>
238
+
239
+ #define ABSL_ANNOTATE_MEMORY_IS_INITIALIZED(address, size) \
240
+ __msan_unpoison(address, size)
241
+
242
+ #define ABSL_ANNOTATE_MEMORY_IS_UNINITIALIZED(address, size) \
243
+ __msan_allocated_memory(address, size)
244
+
245
+ #else // !defined(ABSL_HAVE_MEMORY_SANITIZER)
246
+
247
+ // TODO(rogeeff): remove this branch
248
+ #ifdef ABSL_HAVE_THREAD_SANITIZER
249
+ #define ABSL_ANNOTATE_MEMORY_IS_INITIALIZED(address, size) \
250
+ do { \
251
+ (void)(address); \
252
+ (void)(size); \
253
+ } while (0)
254
+ #define ABSL_ANNOTATE_MEMORY_IS_UNINITIALIZED(address, size) \
255
+ do { \
256
+ (void)(address); \
257
+ (void)(size); \
258
+ } while (0)
259
+ #else
168
260
 
169
- /* Request the analysis tool to ignore all reads in the current thread
170
- until ANNOTATE_IGNORE_READS_END is called.
171
- Useful to ignore intentional racey reads, while still checking
172
- other reads and all writes.
173
- See also ANNOTATE_UNPROTECTED_READ. */
174
- #define ANNOTATE_IGNORE_READS_BEGIN() \
175
- AnnotateIgnoreReadsBegin(__FILE__, __LINE__)
261
+ #define ABSL_ANNOTATE_MEMORY_IS_INITIALIZED(address, size) // empty
262
+ #define ABSL_ANNOTATE_MEMORY_IS_UNINITIALIZED(address, size) // empty
176
263
 
177
- /* Stop ignoring reads. */
178
- #define ANNOTATE_IGNORE_READS_END() \
179
- AnnotateIgnoreReadsEnd(__FILE__, __LINE__)
264
+ #endif
265
+
266
+ #endif // ABSL_HAVE_MEMORY_SANITIZER
267
+
268
+ // -------------------------------------------------------------------------
269
+ // Define IGNORE_READS_BEGIN/_END attributes.
270
+
271
+ #if defined(ABSL_INTERNAL_IGNORE_READS_ATTRIBUTE_ENABLED)
272
+
273
+ #define ABSL_INTERNAL_IGNORE_READS_BEGIN_ATTRIBUTE \
274
+ __attribute((exclusive_lock_function("*")))
275
+ #define ABSL_INTERNAL_IGNORE_READS_END_ATTRIBUTE \
276
+ __attribute((unlock_function("*")))
277
+
278
+ #else // !defined(ABSL_INTERNAL_IGNORE_READS_ATTRIBUTE_ENABLED)
279
+
280
+ #define ABSL_INTERNAL_IGNORE_READS_BEGIN_ATTRIBUTE // empty
281
+ #define ABSL_INTERNAL_IGNORE_READS_END_ATTRIBUTE // empty
180
282
 
181
- /* Similar to ANNOTATE_IGNORE_READS_BEGIN, but ignore writes instead. */
182
- #define ANNOTATE_IGNORE_WRITES_BEGIN() \
183
- AnnotateIgnoreWritesBegin(__FILE__, __LINE__)
283
+ #endif // defined(ABSL_INTERNAL_IGNORE_READS_ATTRIBUTE_ENABLED)
184
284
 
185
- /* Stop ignoring writes. */
186
- #define ANNOTATE_IGNORE_WRITES_END() \
187
- AnnotateIgnoreWritesEnd(__FILE__, __LINE__)
285
+ // -------------------------------------------------------------------------
286
+ // Define IGNORE_READS_BEGIN/_END annotations.
188
287
 
189
- /* Clang provides limited support for static thread-safety analysis
190
- through a feature called Annotalysis. We configure macro-definitions
191
- according to whether Annotalysis support is available. */
192
- #elif defined(ANNOTALYSIS_ENABLED)
288
+ #if ABSL_INTERNAL_READS_ANNOTATIONS_ENABLED == 1
193
289
 
194
- #define ANNOTATE_IGNORE_READS_BEGIN() \
195
- StaticAnnotateIgnoreReadsBegin(__FILE__, __LINE__)
290
+ // Request the analysis tool to ignore all reads in the current thread until
291
+ // ABSL_ANNOTATE_IGNORE_READS_END is called. Useful to ignore intentional racey
292
+ // reads, while still checking other reads and all writes.
293
+ // See also ABSL_ANNOTATE_UNPROTECTED_READ.
294
+ #define ABSL_ANNOTATE_IGNORE_READS_BEGIN() \
295
+ ABSL_INTERNAL_GLOBAL_SCOPED(AnnotateIgnoreReadsBegin)(__FILE__, __LINE__)
196
296
 
197
- #define ANNOTATE_IGNORE_READS_END() \
198
- StaticAnnotateIgnoreReadsEnd(__FILE__, __LINE__)
297
+ // Stop ignoring reads.
298
+ #define ABSL_ANNOTATE_IGNORE_READS_END() \
299
+ ABSL_INTERNAL_GLOBAL_SCOPED(AnnotateIgnoreReadsEnd)(__FILE__, __LINE__)
199
300
 
200
- #define ANNOTATE_IGNORE_WRITES_BEGIN() \
201
- StaticAnnotateIgnoreWritesBegin(__FILE__, __LINE__)
301
+ // Function prototypes of annotations provided by the compiler-based sanitizer
302
+ // implementation.
303
+ ABSL_INTERNAL_BEGIN_EXTERN_C
304
+ void AnnotateIgnoreReadsBegin(const char* file, int line)
305
+ ABSL_INTERNAL_IGNORE_READS_BEGIN_ATTRIBUTE;
306
+ void AnnotateIgnoreReadsEnd(const char* file,
307
+ int line) ABSL_INTERNAL_IGNORE_READS_END_ATTRIBUTE;
308
+ ABSL_INTERNAL_END_EXTERN_C
202
309
 
203
- #define ANNOTATE_IGNORE_WRITES_END() \
204
- StaticAnnotateIgnoreWritesEnd(__FILE__, __LINE__)
310
+ #elif defined(ABSL_INTERNAL_ANNOTALYSIS_ENABLED)
311
+
312
+ // When Annotalysis is enabled without Dynamic Annotations, the use of
313
+ // static-inline functions allows the annotations to be read at compile-time,
314
+ // while still letting the compiler elide the functions from the final build.
315
+ //
316
+ // TODO(delesley) -- The exclusive lock here ignores writes as well, but
317
+ // allows IGNORE_READS_AND_WRITES to work properly.
318
+
319
+ #define ABSL_ANNOTATE_IGNORE_READS_BEGIN() \
320
+ ABSL_INTERNAL_GLOBAL_SCOPED(AbslInternalAnnotateIgnoreReadsBegin)()
321
+
322
+ #define ABSL_ANNOTATE_IGNORE_READS_END() \
323
+ ABSL_INTERNAL_GLOBAL_SCOPED(AbslInternalAnnotateIgnoreReadsEnd)()
324
+
325
+ ABSL_INTERNAL_STATIC_INLINE void AbslInternalAnnotateIgnoreReadsBegin()
326
+ ABSL_INTERNAL_IGNORE_READS_BEGIN_ATTRIBUTE {}
327
+
328
+ ABSL_INTERNAL_STATIC_INLINE void AbslInternalAnnotateIgnoreReadsEnd()
329
+ ABSL_INTERNAL_IGNORE_READS_END_ATTRIBUTE {}
205
330
 
206
331
  #else
207
- #define ANNOTATE_IGNORE_READS_BEGIN() /* empty */
208
- #define ANNOTATE_IGNORE_READS_END() /* empty */
209
- #define ANNOTATE_IGNORE_WRITES_BEGIN() /* empty */
210
- #define ANNOTATE_IGNORE_WRITES_END() /* empty */
332
+
333
+ #define ABSL_ANNOTATE_IGNORE_READS_BEGIN() // empty
334
+ #define ABSL_ANNOTATE_IGNORE_READS_END() // empty
335
+
211
336
  #endif
212
337
 
213
- /* Implement the ANNOTATE_IGNORE_READS_AND_WRITES_* annotations using the more
214
- primitive annotations defined above. */
215
- #if defined(ANNOTATIONS_ENABLED)
338
+ // -------------------------------------------------------------------------
339
+ // Define IGNORE_WRITES_BEGIN/_END annotations.
340
+
341
+ #if ABSL_INTERNAL_WRITES_ANNOTATIONS_ENABLED == 1
216
342
 
217
- /* Start ignoring all memory accesses (both reads and writes). */
218
- #define ANNOTATE_IGNORE_READS_AND_WRITES_BEGIN() \
219
- do { \
220
- ANNOTATE_IGNORE_READS_BEGIN(); \
221
- ANNOTATE_IGNORE_WRITES_BEGIN(); \
222
- }while (0)
343
+ // Similar to ABSL_ANNOTATE_IGNORE_READS_BEGIN, but ignore writes instead.
344
+ #define ABSL_ANNOTATE_IGNORE_WRITES_BEGIN() \
345
+ ABSL_INTERNAL_GLOBAL_SCOPED(AnnotateIgnoreWritesBegin)(__FILE__, __LINE__)
223
346
 
224
- /* Stop ignoring both reads and writes. */
225
- #define ANNOTATE_IGNORE_READS_AND_WRITES_END() \
226
- do { \
227
- ANNOTATE_IGNORE_WRITES_END(); \
228
- ANNOTATE_IGNORE_READS_END(); \
229
- }while (0)
347
+ // Stop ignoring writes.
348
+ #define ABSL_ANNOTATE_IGNORE_WRITES_END() \
349
+ ABSL_INTERNAL_GLOBAL_SCOPED(AnnotateIgnoreWritesEnd)(__FILE__, __LINE__)
350
+
351
+ // Function prototypes of annotations provided by the compiler-based sanitizer
352
+ // implementation.
353
+ ABSL_INTERNAL_BEGIN_EXTERN_C
354
+ void AnnotateIgnoreWritesBegin(const char* file, int line);
355
+ void AnnotateIgnoreWritesEnd(const char* file, int line);
356
+ ABSL_INTERNAL_END_EXTERN_C
230
357
 
231
358
  #else
232
- #define ANNOTATE_IGNORE_READS_AND_WRITES_BEGIN() /* empty */
233
- #define ANNOTATE_IGNORE_READS_AND_WRITES_END() /* empty */
234
- #endif
235
359
 
236
- /* Use the macros above rather than using these functions directly. */
237
- #include <stddef.h>
238
- #ifdef __cplusplus
239
- extern "C" {
240
- #endif
241
- void AnnotateRWLockCreate(const char *file, int line,
242
- const volatile void *lock);
243
- void AnnotateRWLockCreateStatic(const char *file, int line,
244
- const volatile void *lock);
245
- void AnnotateRWLockDestroy(const char *file, int line,
246
- const volatile void *lock);
247
- void AnnotateRWLockAcquired(const char *file, int line,
248
- const volatile void *lock, long is_w); /* NOLINT */
249
- void AnnotateRWLockReleased(const char *file, int line,
250
- const volatile void *lock, long is_w); /* NOLINT */
251
- void AnnotateBenignRace(const char *file, int line,
252
- const volatile void *address,
253
- const char *description);
254
- void AnnotateBenignRaceSized(const char *file, int line,
255
- const volatile void *address,
256
- size_t size,
257
- const char *description);
258
- void AnnotateThreadName(const char *file, int line,
259
- const char *name);
260
- void AnnotateEnableRaceDetection(const char *file, int line, int enable);
261
- void AnnotateMemoryIsInitialized(const char *file, int line,
262
- const volatile void *mem, size_t size);
263
- void AnnotateMemoryIsUninitialized(const char *file, int line,
264
- const volatile void *mem, size_t size);
265
-
266
- /* Annotations expand to these functions, when Dynamic Annotations are enabled.
267
- These functions are either implemented as no-op calls, if no Sanitizer is
268
- attached, or provided with externally-linked implementations by a library
269
- like ThreadSanitizer. */
270
- void AnnotateIgnoreReadsBegin(const char *file, int line)
271
- ATTRIBUTE_IGNORE_READS_BEGIN;
272
- void AnnotateIgnoreReadsEnd(const char *file, int line)
273
- ATTRIBUTE_IGNORE_READS_END;
274
- void AnnotateIgnoreWritesBegin(const char *file, int line);
275
- void AnnotateIgnoreWritesEnd(const char *file, int line);
276
-
277
- #if defined(ANNOTALYSIS_ENABLED)
278
- /* When Annotalysis is enabled without Dynamic Annotations, the use of
279
- static-inline functions allows the annotations to be read at compile-time,
280
- while still letting the compiler elide the functions from the final build.
281
-
282
- TODO(delesley) -- The exclusive lock here ignores writes as well, but
283
- allows IGNORE_READS_AND_WRITES to work properly. */
284
- #pragma GCC diagnostic push
285
- #pragma GCC diagnostic ignored "-Wunused-function"
286
- static inline void StaticAnnotateIgnoreReadsBegin(const char *file, int line)
287
- ATTRIBUTE_IGNORE_READS_BEGIN { (void)file; (void)line; }
288
- static inline void StaticAnnotateIgnoreReadsEnd(const char *file, int line)
289
- ATTRIBUTE_IGNORE_READS_END { (void)file; (void)line; }
290
- static inline void StaticAnnotateIgnoreWritesBegin(
291
- const char *file, int line) { (void)file; (void)line; }
292
- static inline void StaticAnnotateIgnoreWritesEnd(
293
- const char *file, int line) { (void)file; (void)line; }
294
- #pragma GCC diagnostic pop
360
+ #define ABSL_ANNOTATE_IGNORE_WRITES_BEGIN() // empty
361
+ #define ABSL_ANNOTATE_IGNORE_WRITES_END() // empty
362
+
295
363
  #endif
296
364
 
297
- /* Return non-zero value if running under valgrind.
298
-
299
- If "valgrind.h" is included into dynamic_annotations.cc,
300
- the regular valgrind mechanism will be used.
301
- See http://valgrind.org/docs/manual/manual-core-adv.html about
302
- RUNNING_ON_VALGRIND and other valgrind "client requests".
303
- The file "valgrind.h" may be obtained by doing
304
- svn co svn://svn.valgrind.org/valgrind/trunk/include
305
-
306
- If for some reason you can't use "valgrind.h" or want to fake valgrind,
307
- there are two ways to make this function return non-zero:
308
- - Use environment variable: export RUNNING_ON_VALGRIND=1
309
- - Make your tool intercept the function RunningOnValgrind() and
310
- change its return value.
311
- */
312
- int RunningOnValgrind(void);
313
-
314
- /* ValgrindSlowdown returns:
315
- * 1.0, if (RunningOnValgrind() == 0)
316
- * 50.0, if (RunningOnValgrind() != 0 && getenv("VALGRIND_SLOWDOWN") == NULL)
317
- * atof(getenv("VALGRIND_SLOWDOWN")) otherwise
318
- This function can be used to scale timeout values:
319
- EXAMPLE:
320
- for (;;) {
321
- DoExpensiveBackgroundTask();
322
- SleepForSeconds(5 * ValgrindSlowdown());
323
- }
324
- */
325
- double ValgrindSlowdown(void);
365
+ // -------------------------------------------------------------------------
366
+ // Define the ABSL_ANNOTATE_IGNORE_READS_AND_WRITES_* annotations using the more
367
+ // primitive annotations defined above.
368
+ //
369
+ // Instead of doing
370
+ // ABSL_ANNOTATE_IGNORE_READS_BEGIN();
371
+ // ... = x;
372
+ // ABSL_ANNOTATE_IGNORE_READS_END();
373
+ // one can use
374
+ // ... = ABSL_ANNOTATE_UNPROTECTED_READ(x);
375
+
376
+ #if defined(ABSL_INTERNAL_READS_WRITES_ANNOTATIONS_ENABLED)
377
+
378
+ // Start ignoring all memory accesses (both reads and writes).
379
+ #define ABSL_ANNOTATE_IGNORE_READS_AND_WRITES_BEGIN() \
380
+ do { \
381
+ ABSL_ANNOTATE_IGNORE_READS_BEGIN(); \
382
+ ABSL_ANNOTATE_IGNORE_WRITES_BEGIN(); \
383
+ } while (0)
384
+
385
+ // Stop ignoring both reads and writes.
386
+ #define ABSL_ANNOTATE_IGNORE_READS_AND_WRITES_END() \
387
+ do { \
388
+ ABSL_ANNOTATE_IGNORE_WRITES_END(); \
389
+ ABSL_ANNOTATE_IGNORE_READS_END(); \
390
+ } while (0)
326
391
 
327
392
  #ifdef __cplusplus
328
- }
329
- #endif
393
+ // ABSL_ANNOTATE_UNPROTECTED_READ is the preferred way to annotate racey reads.
394
+ #define ABSL_ANNOTATE_UNPROTECTED_READ(x) \
395
+ absl::base_internal::AnnotateUnprotectedRead(x)
330
396
 
331
- /* ANNOTATE_UNPROTECTED_READ is the preferred way to annotate racey reads.
397
+ namespace absl {
398
+ ABSL_NAMESPACE_BEGIN
399
+ namespace base_internal {
332
400
 
333
- Instead of doing
334
- ANNOTATE_IGNORE_READS_BEGIN();
335
- ... = x;
336
- ANNOTATE_IGNORE_READS_END();
337
- one can use
338
- ... = ANNOTATE_UNPROTECTED_READ(x); */
339
- #if defined(__cplusplus) && defined(ANNOTATIONS_ENABLED)
340
401
  template <typename T>
341
- inline T ANNOTATE_UNPROTECTED_READ(const volatile T &x) { /* NOLINT */
342
- ANNOTATE_IGNORE_READS_BEGIN();
402
+ inline T AnnotateUnprotectedRead(const volatile T& x) { // NOLINT
403
+ ABSL_ANNOTATE_IGNORE_READS_BEGIN();
343
404
  T res = x;
344
- ANNOTATE_IGNORE_READS_END();
405
+ ABSL_ANNOTATE_IGNORE_READS_END();
345
406
  return res;
346
- }
407
+ }
408
+
409
+ } // namespace base_internal
410
+ ABSL_NAMESPACE_END
411
+ } // namespace absl
412
+ #endif
413
+
347
414
  #else
348
- #define ANNOTATE_UNPROTECTED_READ(x) (x)
415
+
416
+ #define ABSL_ANNOTATE_IGNORE_READS_AND_WRITES_BEGIN() // empty
417
+ #define ABSL_ANNOTATE_IGNORE_READS_AND_WRITES_END() // empty
418
+ #define ABSL_ANNOTATE_UNPROTECTED_READ(x) (x)
419
+
420
+ #endif
421
+
422
+ #ifdef __cplusplus
423
+ #ifdef ABSL_HAVE_THREAD_SANITIZER
424
+ ABSL_INTERNAL_BEGIN_EXTERN_C
425
+ int RunningOnValgrind();
426
+ double ValgrindSlowdown();
427
+ ABSL_INTERNAL_END_EXTERN_C
428
+ #else
429
+ namespace absl {
430
+ ABSL_NAMESPACE_BEGIN
431
+ namespace base_internal {
432
+ ABSL_DEPRECATED(
433
+ "Don't use this interface. It is misleading and is being deleted.")
434
+ ABSL_ATTRIBUTE_ALWAYS_INLINE inline int RunningOnValgrind() { return 0; }
435
+ ABSL_DEPRECATED(
436
+ "Don't use this interface. It is misleading and is being deleted.")
437
+ ABSL_ATTRIBUTE_ALWAYS_INLINE inline double ValgrindSlowdown() { return 1.0; }
438
+ } // namespace base_internal
439
+ ABSL_NAMESPACE_END
440
+ } // namespace absl
441
+
442
+ using absl::base_internal::RunningOnValgrind;
443
+ using absl::base_internal::ValgrindSlowdown;
444
+ #endif
349
445
  #endif
350
446
 
351
- #if DYNAMIC_ANNOTATIONS_ENABLED != 0 && defined(__cplusplus)
352
- /* Apply ANNOTATE_BENIGN_RACE_SIZED to a static variable. */
353
- #define ANNOTATE_BENIGN_RACE_STATIC(static_var, description) \
354
- namespace { \
355
- class static_var ## _annotator { \
356
- public: \
357
- static_var ## _annotator() { \
358
- ANNOTATE_BENIGN_RACE_SIZED(&static_var, \
359
- sizeof(static_var), \
360
- # static_var ": " description); \
361
- } \
362
- }; \
363
- static static_var ## _annotator the ## static_var ## _annotator;\
364
- } // namespace
365
- #else /* DYNAMIC_ANNOTATIONS_ENABLED == 0 */
366
- #define ANNOTATE_BENIGN_RACE_STATIC(static_var, description) /* empty */
367
- #endif /* DYNAMIC_ANNOTATIONS_ENABLED */
368
-
369
- #ifdef ADDRESS_SANITIZER
370
- /* Describe the current state of a contiguous container such as e.g.
371
- * std::vector or std::string. For more details see
372
- * sanitizer/common_interface_defs.h, which is provided by the compiler. */
447
+ // -------------------------------------------------------------------------
448
+ // Address sanitizer annotations
449
+
450
+ #ifdef ABSL_HAVE_ADDRESS_SANITIZER
451
+ // Describe the current state of a contiguous container such as e.g.
452
+ // std::vector or std::string. For more details see
453
+ // sanitizer/common_interface_defs.h, which is provided by the compiler.
373
454
  #include <sanitizer/common_interface_defs.h>
374
- #define ANNOTATE_CONTIGUOUS_CONTAINER(beg, end, old_mid, new_mid) \
455
+
456
+ #define ABSL_ANNOTATE_CONTIGUOUS_CONTAINER(beg, end, old_mid, new_mid) \
375
457
  __sanitizer_annotate_contiguous_container(beg, end, old_mid, new_mid)
376
- #define ADDRESS_SANITIZER_REDZONE(name) \
377
- struct { char x[8] __attribute__ ((aligned (8))); } name
458
+ #define ABSL_ADDRESS_SANITIZER_REDZONE(name) \
459
+ struct { \
460
+ char x[8] __attribute__((aligned(8))); \
461
+ } name
462
+
378
463
  #else
379
- #define ANNOTATE_CONTIGUOUS_CONTAINER(beg, end, old_mid, new_mid)
380
- #define ADDRESS_SANITIZER_REDZONE(name) static_assert(true, "")
381
- #endif // ADDRESS_SANITIZER
382
464
 
383
- /* Undefine the macros intended only in this file. */
384
- #undef ANNOTALYSIS_ENABLED
385
- #undef ANNOTATIONS_ENABLED
386
- #undef ATTRIBUTE_IGNORE_READS_BEGIN
387
- #undef ATTRIBUTE_IGNORE_READS_END
465
+ #define ABSL_ANNOTATE_CONTIGUOUS_CONTAINER(beg, end, old_mid, new_mid) // empty
466
+ #define ABSL_ADDRESS_SANITIZER_REDZONE(name) static_assert(true, "")
467
+
468
+ #endif // ABSL_HAVE_ADDRESS_SANITIZER
469
+
470
+ // -------------------------------------------------------------------------
471
+ // Undefine the macros intended only for this file.
472
+
473
+ #undef ABSL_INTERNAL_RACE_ANNOTATIONS_ENABLED
474
+ #undef ABSL_INTERNAL_READS_ANNOTATIONS_ENABLED
475
+ #undef ABSL_INTERNAL_WRITES_ANNOTATIONS_ENABLED
476
+ #undef ABSL_INTERNAL_ANNOTALYSIS_ENABLED
477
+ #undef ABSL_INTERNAL_READS_WRITES_ANNOTATIONS_ENABLED
478
+ #undef ABSL_INTERNAL_BEGIN_EXTERN_C
479
+ #undef ABSL_INTERNAL_END_EXTERN_C
480
+ #undef ABSL_INTERNAL_STATIC_INLINE
388
481
 
389
- #endif /* ABSL_BASE_DYNAMIC_ANNOTATIONS_H_ */
482
+ #endif // ABSL_BASE_DYNAMIC_ANNOTATIONS_H_