grpc 1.61.3 → 1.62.0.pre1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (723) hide show
  1. checksums.yaml +4 -4
  2. data/Makefile +218 -196
  3. data/include/grpc/event_engine/event_engine.h +5 -43
  4. data/include/grpc/event_engine/extensible.h +68 -0
  5. data/include/grpc/impl/slice_type.h +1 -1
  6. data/include/grpc/support/port_platform.h +12 -20
  7. data/src/core/{ext/filters/client_channel → client_channel}/backend_metric.cc +1 -1
  8. data/src/core/{ext/filters/client_channel → client_channel}/backend_metric.h +4 -4
  9. data/src/core/{ext/filters/client_channel → client_channel}/backup_poller.cc +1 -1
  10. data/src/core/{ext/filters/client_channel → client_channel}/backup_poller.h +3 -3
  11. data/src/core/{ext/filters/client_channel → client_channel}/channel_connectivity.cc +11 -11
  12. data/src/core/{ext/filters/client_channel → client_channel}/client_channel_channelz.cc +1 -1
  13. data/src/core/{ext/filters/client_channel → client_channel}/client_channel_channelz.h +3 -3
  14. data/src/core/{ext/filters/client_channel → client_channel}/client_channel_factory.cc +1 -1
  15. data/src/core/{ext/filters/client_channel → client_channel}/client_channel_factory.h +4 -4
  16. data/src/core/{ext/filters/client_channel/client_channel.cc → client_channel/client_channel_filter.cc} +247 -231
  17. data/src/core/{ext/filters/client_channel/client_channel.h → client_channel/client_channel_filter.h} +42 -42
  18. data/src/core/{ext/filters/client_channel → client_channel}/client_channel_internal.h +6 -6
  19. data/src/core/{ext/filters/client_channel → client_channel}/client_channel_plugin.cc +5 -5
  20. data/src/core/{ext/filters/client_channel → client_channel}/client_channel_service_config.cc +2 -2
  21. data/src/core/{ext/filters/client_channel → client_channel}/client_channel_service_config.h +5 -5
  22. data/src/core/{ext/filters/client_channel → client_channel}/config_selector.cc +1 -1
  23. data/src/core/{ext/filters/client_channel → client_channel}/config_selector.h +5 -5
  24. data/src/core/{ext/filters/client_channel → client_channel}/connector.h +3 -3
  25. data/src/core/{ext/filters/client_channel → client_channel}/dynamic_filters.cc +1 -1
  26. data/src/core/{ext/filters/client_channel → client_channel}/dynamic_filters.h +3 -3
  27. data/src/core/{ext/filters/client_channel → client_channel}/global_subchannel_pool.cc +2 -2
  28. data/src/core/{ext/filters/client_channel → client_channel}/global_subchannel_pool.h +4 -4
  29. data/src/core/{ext/filters/client_channel → client_channel}/http_proxy_mapper.cc +1 -1
  30. data/src/core/{ext/filters/client_channel → client_channel}/http_proxy_mapper.h +3 -3
  31. data/src/core/{ext/filters/client_channel → client_channel}/local_subchannel_pool.cc +2 -2
  32. data/src/core/{ext/filters/client_channel → client_channel}/local_subchannel_pool.h +4 -4
  33. data/src/core/{ext/filters/client_channel → client_channel}/retry_filter.cc +8 -8
  34. data/src/core/{ext/filters/client_channel → client_channel}/retry_filter.h +8 -8
  35. data/src/core/{ext/filters/client_channel → client_channel}/retry_filter_legacy_call_data.cc +12 -9
  36. data/src/core/{ext/filters/client_channel → client_channel}/retry_filter_legacy_call_data.h +11 -10
  37. data/src/core/{ext/filters/client_channel → client_channel}/retry_service_config.cc +1 -1
  38. data/src/core/{ext/filters/client_channel → client_channel}/retry_service_config.h +4 -4
  39. data/src/core/{ext/filters/client_channel → client_channel}/retry_throttle.cc +1 -1
  40. data/src/core/{ext/filters/client_channel → client_channel}/retry_throttle.h +3 -3
  41. data/src/core/{ext/filters/client_channel → client_channel}/service_config_channel_arg_filter.cc +4 -4
  42. data/src/core/{ext/filters/client_channel → client_channel}/subchannel.cc +2 -2
  43. data/src/core/{ext/filters/client_channel → client_channel}/subchannel.h +6 -6
  44. data/src/core/{ext/filters/client_channel → client_channel}/subchannel_interface_internal.h +5 -5
  45. data/src/core/{ext/filters/client_channel → client_channel}/subchannel_pool_interface.cc +1 -1
  46. data/src/core/{ext/filters/client_channel → client_channel}/subchannel_pool_interface.h +3 -3
  47. data/src/core/{ext/filters/client_channel → client_channel}/subchannel_stream_client.cc +1 -1
  48. data/src/core/{ext/filters/client_channel → client_channel}/subchannel_stream_client.h +4 -4
  49. data/src/core/ext/filters/backend_metrics/backend_metric_filter.cc +1 -1
  50. data/src/core/ext/filters/fault_injection/fault_injection_filter.cc +1 -1
  51. data/src/core/ext/filters/fault_injection/fault_injection_service_config_parser.h +1 -1
  52. data/src/core/ext/filters/http/message_compress/legacy_compression_filter.cc +2 -2
  53. data/src/core/ext/filters/http/server/http_server_filter.cc +1 -1
  54. data/src/core/ext/filters/message_size/message_size_filter.cc +3 -3
  55. data/src/core/ext/filters/message_size/message_size_filter.h +1 -1
  56. data/src/core/ext/filters/rbac/rbac_filter.cc +1 -1
  57. data/src/core/ext/filters/rbac/rbac_service_config_parser.h +1 -1
  58. data/src/core/ext/filters/server_config_selector/server_config_selector.h +2 -2
  59. data/src/core/ext/filters/server_config_selector/server_config_selector_filter.cc +2 -2
  60. data/src/core/ext/filters/stateful_session/stateful_session_filter.cc +2 -2
  61. data/src/core/ext/filters/stateful_session/stateful_session_filter.h +1 -1
  62. data/src/core/ext/filters/stateful_session/stateful_session_service_config_parser.h +1 -1
  63. data/src/core/ext/transport/chttp2/alpn/alpn.cc +4 -1
  64. data/src/core/ext/transport/chttp2/client/chttp2_connector.cc +5 -5
  65. data/src/core/ext/transport/chttp2/client/chttp2_connector.h +1 -1
  66. data/src/core/ext/transport/chttp2/transport/chttp2_transport.cc +1 -0
  67. data/src/core/ext/transport/chttp2/transport/hpack_encoder.h +5 -0
  68. data/src/core/ext/transport/chttp2/transport/hpack_parser.cc +27 -36
  69. data/src/core/ext/transport/chttp2/transport/hpack_parser.h +3 -3
  70. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.h +3 -1
  71. data/src/core/ext/transport/inproc/inproc_transport.cc +20 -13
  72. data/src/core/ext/transport/inproc/inproc_transport.h +8 -0
  73. data/src/core/ext/upb-gen/envoy/config/bootstrap/v3/bootstrap.upb.h +351 -164
  74. data/src/core/ext/upb-gen/envoy/config/bootstrap/v3/bootstrap.upb_minitable.c +89 -50
  75. data/src/core/ext/upb-gen/envoy/config/bootstrap/v3/bootstrap.upb_minitable.h +2 -0
  76. data/src/core/ext/upb-gen/envoy/config/cluster/v3/cluster.upb.h +47 -3
  77. data/src/core/ext/upb-gen/envoy/config/cluster/v3/cluster.upb_minitable.c +15 -7
  78. data/src/core/ext/upb-gen/envoy/config/cluster/v3/filter.upb.h +32 -3
  79. data/src/core/ext/upb-gen/envoy/config/cluster/v3/filter.upb_minitable.c +8 -5
  80. data/src/core/ext/upb-gen/envoy/config/cluster/v3/outlier_detection.upb.h +28 -0
  81. data/src/core/ext/upb-gen/envoy/config/cluster/v3/outlier_detection.upb_minitable.c +6 -4
  82. data/src/core/ext/upb-gen/envoy/config/common/matcher/v3/matcher.upb.h +0 -1
  83. data/src/core/ext/upb-gen/envoy/config/common/matcher/v3/matcher.upb_minitable.c +0 -1
  84. data/src/core/ext/upb-gen/envoy/config/core/v3/address.upb.h +29 -0
  85. data/src/core/ext/upb-gen/envoy/config/core/v3/address.upb_minitable.c +7 -4
  86. data/src/core/ext/upb-gen/envoy/config/core/v3/base.upb.h +17 -1
  87. data/src/core/ext/upb-gen/envoy/config/core/v3/base.upb_minitable.c +4 -3
  88. data/src/core/ext/upb-gen/envoy/config/core/v3/http_service.upb.h +166 -0
  89. data/src/core/ext/upb-gen/envoy/config/core/v3/http_service.upb_minitable.c +55 -0
  90. data/src/core/ext/upb-gen/envoy/config/core/v3/http_service.upb_minitable.h +30 -0
  91. data/src/core/ext/upb-gen/envoy/config/core/v3/protocol.upb.h +30 -0
  92. data/src/core/ext/upb-gen/envoy/config/core/v3/protocol.upb_minitable.c +7 -5
  93. data/src/core/ext/upb-gen/envoy/config/core/v3/substitution_format_string.upb.h +99 -19
  94. data/src/core/ext/upb-gen/envoy/config/core/v3/substitution_format_string.upb_minitable.c +29 -12
  95. data/src/core/ext/upb-gen/envoy/config/core/v3/substitution_format_string.upb_minitable.h +1 -0
  96. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/endpoint.upb.h +15 -0
  97. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/endpoint.upb_minitable.c +4 -3
  98. data/src/core/ext/upb-gen/envoy/config/route/v3/route.upb.h +31 -3
  99. data/src/core/ext/upb-gen/envoy/config/route/v3/route.upb_minitable.c +22 -4
  100. data/src/core/ext/upb-gen/envoy/config/route/v3/route_components.upb.h +91 -3
  101. data/src/core/ext/upb-gen/envoy/config/route/v3/route_components.upb_minitable.c +11 -8
  102. data/src/core/ext/upb-gen/envoy/config/tap/v3/common.upb.h +30 -0
  103. data/src/core/ext/upb-gen/envoy/config/tap/v3/common.upb_minitable.c +7 -4
  104. data/src/core/ext/upb-gen/envoy/config/trace/v3/dynamic_ot.upb.h +1 -0
  105. data/src/core/ext/upb-gen/envoy/config/trace/v3/dynamic_ot.upb_minitable.c +1 -0
  106. data/src/core/ext/upb-gen/envoy/config/trace/v3/opentelemetry.upb.h +125 -3
  107. data/src/core/ext/upb-gen/envoy/config/trace/v3/opentelemetry.upb_minitable.c +17 -4
  108. data/src/core/ext/upb-gen/envoy/data/accesslog/v3/accesslog.upb.h +19 -1
  109. data/src/core/ext/upb-gen/envoy/data/accesslog/v3/accesslog.upb_minitable.c +4 -3
  110. data/src/core/ext/upb-gen/envoy/extensions/filters/http/router/v3/router.upb.h +1 -0
  111. data/src/core/ext/upb-gen/envoy/extensions/filters/http/router/v3/router.upb_minitable.c +1 -0
  112. data/src/core/ext/upb-gen/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upb.h +15 -0
  113. data/src/core/ext/upb-gen/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upb_minitable.c +5 -2
  114. data/src/core/ext/upb-gen/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.h +42 -0
  115. data/src/core/ext/upb-gen/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb_minitable.c +11 -8
  116. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/common.upb.h +23 -8
  117. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/common.upb_minitable.c +9 -4
  118. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/tls.upb.h +58 -16
  119. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/tls.upb_minitable.c +14 -11
  120. data/src/core/ext/upb-gen/envoy/service/status/v3/csds.upb.h +15 -0
  121. data/src/core/ext/upb-gen/envoy/service/status/v3/csds.upb_minitable.c +7 -2
  122. data/src/core/ext/upb-gen/envoy/type/matcher/v3/value.upb.h +129 -0
  123. data/src/core/ext/upb-gen/envoy/type/matcher/v3/value.upb_minitable.c +27 -6
  124. data/src/core/ext/upb-gen/envoy/type/matcher/v3/value.upb_minitable.h +1 -0
  125. data/src/core/ext/upb-gen/xds/type/matcher/v3/cel.upb.h +15 -0
  126. data/src/core/ext/upb-gen/xds/type/matcher/v3/cel.upb_minitable.c +5 -2
  127. data/src/core/ext/upbdefs-gen/envoy/config/accesslog/v3/accesslog.upbdefs.c +60 -60
  128. data/src/core/ext/upbdefs-gen/envoy/config/bootstrap/v3/bootstrap.upbdefs.c +278 -256
  129. data/src/core/ext/upbdefs-gen/envoy/config/bootstrap/v3/bootstrap.upbdefs.h +10 -0
  130. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/cluster.upbdefs.c +483 -475
  131. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/filter.upbdefs.c +27 -20
  132. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/outlier_detection.upbdefs.c +17 -12
  133. data/src/core/ext/upbdefs-gen/envoy/config/common/matcher/v3/matcher.upbdefs.c +157 -161
  134. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/address.upbdefs.c +105 -97
  135. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/base.upbdefs.c +106 -102
  136. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/http_service.upbdefs.c +52 -0
  137. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/http_service.upbdefs.h +35 -0
  138. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/http_uri.upbdefs.c +14 -13
  139. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/protocol.upbdefs.c +228 -224
  140. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/substitution_format_string.upbdefs.c +32 -26
  141. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/substitution_format_string.upbdefs.h +5 -0
  142. data/src/core/ext/upbdefs-gen/envoy/config/endpoint/v3/endpoint.upbdefs.c +31 -28
  143. data/src/core/ext/upbdefs-gen/envoy/config/route/v3/route.upbdefs.c +22 -19
  144. data/src/core/ext/upbdefs-gen/envoy/config/route/v3/route_components.upbdefs.c +818 -813
  145. data/src/core/ext/upbdefs-gen/envoy/config/tap/v3/common.upbdefs.c +158 -151
  146. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/dynamic_ot.upbdefs.c +27 -23
  147. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/opencensus.upbdefs.c +59 -53
  148. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/opentelemetry.upbdefs.c +40 -18
  149. data/src/core/ext/upbdefs-gen/envoy/data/accesslog/v3/accesslog.upbdefs.c +106 -103
  150. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/router/v3/router.upbdefs.c +16 -12
  151. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upbdefs.c +22 -21
  152. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.c +265 -261
  153. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.c +127 -125
  154. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/tls.upbdefs.c +188 -182
  155. data/src/core/ext/upbdefs-gen/envoy/service/status/v3/csds.upbdefs.c +57 -56
  156. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/value.upbdefs.c +27 -20
  157. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/value.upbdefs.h +5 -0
  158. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/cel.upbdefs.c +10 -8
  159. data/src/core/ext/xds/xds_api.cc +63 -150
  160. data/src/core/ext/xds/xds_api.h +2 -7
  161. data/src/core/ext/xds/xds_bootstrap.h +3 -4
  162. data/src/core/ext/xds/xds_bootstrap_grpc.cc +4 -15
  163. data/src/core/ext/xds/xds_bootstrap_grpc.h +2 -1
  164. data/src/core/ext/xds/xds_client.cc +111 -59
  165. data/src/core/ext/xds/xds_client.h +20 -15
  166. data/src/core/ext/xds/xds_client_grpc.cc +53 -15
  167. data/src/core/ext/xds/xds_client_grpc.h +4 -1
  168. data/src/core/ext/xds/xds_client_stats.cc +11 -11
  169. data/src/core/ext/xds/xds_client_stats.h +8 -13
  170. data/src/core/ext/xds/xds_cluster.cc +1 -1
  171. data/src/core/ext/xds/xds_cluster.h +1 -1
  172. data/src/core/ext/xds/xds_endpoint.h +1 -1
  173. data/src/core/ext/xds/xds_health_status.h +1 -1
  174. data/src/core/ext/xds/xds_lb_policy_registry.cc +1 -1
  175. data/src/core/ext/xds/xds_route_config.cc +1 -1
  176. data/src/core/ext/xds/xds_server_config_fetcher.cc +2 -2
  177. data/src/core/ext/xds/xds_transport_grpc.cc +5 -5
  178. data/src/core/lib/channel/channel_args.h +15 -1
  179. data/src/core/lib/channel/connected_channel.cc +13 -12
  180. data/src/core/lib/channel/promise_based_filter.cc +4 -4
  181. data/src/core/lib/channel/promise_based_filter.h +1 -2
  182. data/src/core/lib/config/core_configuration.h +3 -3
  183. data/src/core/lib/event_engine/ares_resolver.cc +106 -59
  184. data/src/core/lib/event_engine/extensions/can_track_errors.h +40 -0
  185. data/src/core/lib/event_engine/extensions/supports_fd.h +160 -0
  186. data/src/core/lib/event_engine/forkable.cc +7 -5
  187. data/src/core/lib/event_engine/posix.h +11 -122
  188. data/src/core/lib/event_engine/posix_engine/native_posix_dns_resolver.h +1 -5
  189. data/src/core/lib/event_engine/posix_engine/posix_endpoint.cc +31 -7
  190. data/src/core/lib/event_engine/posix_engine/posix_endpoint.h +1 -0
  191. data/src/core/lib/event_engine/posix_engine/posix_engine.cc +3 -4
  192. data/src/core/lib/event_engine/posix_engine/posix_engine.h +2 -3
  193. data/src/core/lib/event_engine/posix_engine/posix_engine_listener.cc +14 -6
  194. data/src/core/lib/event_engine/posix_engine/posix_engine_listener_utils.cc +10 -0
  195. data/src/core/lib/event_engine/query_extensions.h +85 -0
  196. data/src/core/lib/event_engine/shim.cc +3 -17
  197. data/src/core/lib/event_engine/shim.h +0 -2
  198. data/src/core/lib/event_engine/thread_pool/thread_count.cc +28 -7
  199. data/src/core/lib/event_engine/thread_pool/thread_count.h +6 -1
  200. data/src/core/lib/event_engine/thread_pool/work_stealing_thread_pool.cc +109 -5
  201. data/src/core/lib/event_engine/thread_pool/work_stealing_thread_pool.h +9 -0
  202. data/src/core/lib/event_engine/utils.cc +2 -1
  203. data/src/core/lib/event_engine/windows/grpc_polled_fd_windows.cc +1 -0
  204. data/src/core/lib/experiments/config.cc +10 -2
  205. data/src/core/lib/experiments/config.h +6 -0
  206. data/src/core/lib/experiments/experiments.cc +57 -18
  207. data/src/core/lib/experiments/experiments.h +16 -8
  208. data/src/core/lib/gpr/posix/sync.cc +2 -2
  209. data/src/core/lib/gpr/posix/time.cc +0 -5
  210. data/src/core/lib/gpr/windows/sync.cc +2 -2
  211. data/src/core/lib/gprpp/debug_location.h +2 -0
  212. data/src/core/lib/gprpp/down_cast.h +49 -0
  213. data/src/core/lib/gprpp/linux/env.cc +1 -19
  214. data/src/core/lib/gprpp/load_file.cc +2 -1
  215. data/src/core/lib/gprpp/load_file.h +2 -1
  216. data/src/core/lib/gprpp/posix/thd.cc +27 -2
  217. data/src/core/lib/gprpp/thd.h +8 -0
  218. data/src/core/lib/gprpp/time.h +4 -3
  219. data/src/core/lib/gprpp/windows/thd.cc +10 -1
  220. data/src/core/lib/iomgr/combiner.cc +1 -1
  221. data/src/core/lib/iomgr/event_engine_shims/endpoint.cc +20 -14
  222. data/src/core/lib/iomgr/grpc_if_nametoindex_posix.cc +2 -2
  223. data/src/core/lib/iomgr/grpc_if_nametoindex_unsupported.cc +2 -2
  224. data/src/core/lib/iomgr/tcp_server_posix.cc +65 -50
  225. data/src/core/lib/iomgr/tcp_server_utils_posix_ifaddrs.cc +12 -0
  226. data/src/core/lib/json/json_writer.cc +1 -1
  227. data/src/core/lib/promise/activity.h +8 -2
  228. data/src/core/lib/promise/context.h +45 -7
  229. data/src/core/lib/promise/for_each.h +6 -9
  230. data/src/core/lib/promise/interceptor_list.h +13 -5
  231. data/src/core/lib/promise/latch.h +3 -3
  232. data/src/core/lib/promise/party.cc +12 -0
  233. data/src/core/lib/promise/party.h +37 -6
  234. data/src/core/lib/promise/pipe.h +2 -7
  235. data/src/core/lib/promise/sleep.cc +1 -1
  236. data/src/core/lib/promise/status_flag.h +32 -2
  237. data/src/core/lib/resource_quota/memory_quota.cc +4 -4
  238. data/src/core/lib/security/credentials/external/file_external_account_credentials.cc +5 -11
  239. data/src/core/lib/security/credentials/google_default/google_default_credentials.cc +11 -10
  240. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.cc +9 -7
  241. data/src/core/lib/security/credentials/plugin/plugin_credentials.h +1 -1
  242. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.cc +16 -24
  243. data/src/core/lib/security/credentials/xds/xds_credentials.cc +1 -1
  244. data/src/core/lib/security/security_connector/fake/fake_security_connector.cc +1 -1
  245. data/src/core/lib/security/security_connector/load_system_roots_supported.cc +3 -7
  246. data/src/core/lib/security/security_connector/local/local_security_connector.cc +1 -1
  247. data/src/core/lib/security/security_connector/ssl_utils.cc +26 -17
  248. data/src/core/lib/security/transport/legacy_server_auth_filter.cc +2 -2
  249. data/src/core/lib/security/transport/security_handshaker.cc +0 -8
  250. data/src/core/lib/security/transport/security_handshaker.h +0 -6
  251. data/src/core/lib/security/transport/server_auth_filter.cc +2 -2
  252. data/src/core/lib/slice/slice_buffer.h +3 -1
  253. data/src/core/lib/surface/call.cc +162 -76
  254. data/src/core/lib/surface/call_trace.cc +9 -9
  255. data/src/core/lib/surface/channel.cc +15 -24
  256. data/src/core/lib/surface/channel.h +4 -20
  257. data/src/core/lib/surface/channel_init.cc +81 -7
  258. data/src/core/lib/surface/channel_init.h +104 -6
  259. data/src/core/lib/surface/init.cc +1 -1
  260. data/src/core/lib/surface/server.cc +4 -7
  261. data/src/core/lib/surface/version.cc +2 -2
  262. data/src/core/lib/surface/wait_for_cq_end_op.cc +75 -0
  263. data/src/core/lib/surface/wait_for_cq_end_op.h +4 -26
  264. data/src/core/lib/transport/batch_builder.cc +2 -3
  265. data/src/core/lib/transport/batch_builder.h +1 -1
  266. data/src/core/lib/transport/call_factory.cc +41 -0
  267. data/src/core/lib/transport/call_factory.h +56 -0
  268. data/src/core/lib/transport/call_filters.cc +371 -0
  269. data/src/core/lib/transport/call_filters.h +1500 -0
  270. data/src/core/lib/transport/call_size_estimator.cc +41 -0
  271. data/src/core/lib/transport/call_size_estimator.h +52 -0
  272. data/src/core/lib/transport/call_spine.cc +107 -0
  273. data/src/core/lib/transport/call_spine.h +429 -0
  274. data/src/core/lib/transport/handshaker.cc +0 -8
  275. data/src/core/lib/transport/handshaker.h +0 -7
  276. data/src/core/lib/transport/message.cc +45 -0
  277. data/src/core/lib/transport/message.h +61 -0
  278. data/src/core/lib/transport/metadata.cc +37 -0
  279. data/src/core/lib/transport/metadata.h +78 -0
  280. data/src/core/lib/transport/metadata_batch.cc +4 -2
  281. data/src/core/lib/transport/metadata_batch.h +2 -2
  282. data/src/core/lib/transport/transport.cc +0 -105
  283. data/src/core/lib/transport/transport.h +3 -452
  284. data/src/core/{ext/filters/client_channel/lb_policy → load_balancing}/address_filtering.cc +1 -1
  285. data/src/core/{ext/filters/client_channel/lb_policy → load_balancing}/address_filtering.h +4 -4
  286. data/src/core/{ext/filters/client_channel/lb_policy → load_balancing}/backend_metric_data.h +3 -3
  287. data/src/core/{ext/filters/client_channel/lb_policy → load_balancing}/child_policy_handler.cc +4 -4
  288. data/src/core/{ext/filters/client_channel/lb_policy → load_balancing}/child_policy_handler.h +4 -4
  289. data/src/core/{lib/load_balancing → load_balancing}/delegating_helper.h +5 -5
  290. data/src/core/{ext/filters/client_channel/lb_policy → load_balancing}/endpoint_list.cc +6 -6
  291. data/src/core/{ext/filters/client_channel/lb_policy → load_balancing}/endpoint_list.h +6 -6
  292. data/src/core/{ext/filters/client_channel/lb_policy → load_balancing}/grpclb/client_load_reporting_filter.cc +2 -2
  293. data/src/core/{ext/filters/client_channel/lb_policy → load_balancing}/grpclb/client_load_reporting_filter.h +3 -3
  294. data/src/core/{ext/filters/client_channel/lb_policy → load_balancing}/grpclb/grpclb.cc +19 -19
  295. data/src/core/{ext/filters/client_channel/lb_policy → load_balancing}/grpclb/grpclb.h +3 -3
  296. data/src/core/{ext/filters/client_channel/lb_policy → load_balancing}/grpclb/grpclb_balancer_addresses.cc +1 -1
  297. data/src/core/{ext/filters/client_channel/lb_policy → load_balancing}/grpclb/grpclb_balancer_addresses.h +4 -4
  298. data/src/core/{ext/filters/client_channel/lb_policy → load_balancing}/grpclb/grpclb_client_stats.cc +1 -1
  299. data/src/core/{ext/filters/client_channel/lb_policy → load_balancing}/grpclb/grpclb_client_stats.h +3 -3
  300. data/src/core/{ext/filters/client_channel/lb_policy → load_balancing}/grpclb/load_balancer_api.cc +1 -1
  301. data/src/core/{ext/filters/client_channel/lb_policy → load_balancing}/grpclb/load_balancer_api.h +4 -4
  302. data/src/core/{ext/filters/client_channel/lb_policy → load_balancing}/health_check_client.cc +6 -6
  303. data/src/core/{ext/filters/client_channel/lb_policy → load_balancing}/health_check_client.h +4 -4
  304. data/src/core/{ext/filters/client_channel/lb_policy → load_balancing}/health_check_client_internal.h +7 -7
  305. data/src/core/{lib/load_balancing → load_balancing}/lb_policy.cc +1 -1
  306. data/src/core/{lib/load_balancing → load_balancing}/lb_policy.h +6 -6
  307. data/src/core/{lib/load_balancing → load_balancing}/lb_policy_factory.h +4 -4
  308. data/src/core/{lib/load_balancing → load_balancing}/lb_policy_registry.cc +2 -2
  309. data/src/core/{lib/load_balancing → load_balancing}/lb_policy_registry.h +5 -5
  310. data/src/core/{ext/filters/client_channel/lb_policy → load_balancing}/oob_backend_metric.cc +6 -6
  311. data/src/core/{ext/filters/client_channel/lb_policy → load_balancing}/oob_backend_metric.h +5 -5
  312. data/src/core/{ext/filters/client_channel/lb_policy → load_balancing}/oob_backend_metric_internal.h +8 -8
  313. data/src/core/{ext/filters/client_channel/lb_policy → load_balancing}/outlier_detection/outlier_detection.cc +10 -10
  314. data/src/core/{ext/filters/client_channel/lb_policy → load_balancing}/outlier_detection/outlier_detection.h +3 -3
  315. data/src/core/{ext/filters/client_channel/lb_policy → load_balancing}/pick_first/pick_first.cc +6 -6
  316. data/src/core/{ext/filters/client_channel/lb_policy → load_balancing}/pick_first/pick_first.h +4 -4
  317. data/src/core/{ext/filters/client_channel/lb_policy → load_balancing}/priority/priority.cc +8 -8
  318. data/src/core/{ext/filters/client_channel/lb_policy → load_balancing}/ring_hash/ring_hash.cc +8 -8
  319. data/src/core/{ext/filters/client_channel/lb_policy → load_balancing}/ring_hash/ring_hash.h +4 -4
  320. data/src/core/{ext/filters/client_channel/lb_policy → load_balancing}/rls/rls.cc +13 -13
  321. data/src/core/{ext/filters/client_channel/lb_policy → load_balancing}/round_robin/round_robin.cc +7 -7
  322. data/src/core/{lib/load_balancing → load_balancing}/subchannel_interface.h +3 -3
  323. data/src/core/{ext/filters/client_channel/lb_policy → load_balancing}/subchannel_list.h +8 -8
  324. data/src/core/{ext/filters/client_channel/lb_policy → load_balancing}/weighted_round_robin/static_stride_scheduler.cc +1 -1
  325. data/src/core/{ext/filters/client_channel/lb_policy → load_balancing}/weighted_round_robin/static_stride_scheduler.h +3 -3
  326. data/src/core/{ext/filters/client_channel/lb_policy → load_balancing}/weighted_round_robin/weighted_round_robin.cc +10 -10
  327. data/src/core/{ext/filters/client_channel/lb_policy → load_balancing}/weighted_target/weighted_target.cc +7 -7
  328. data/src/core/{ext/filters/client_channel/lb_policy → load_balancing}/xds/cds.cc +26 -23
  329. data/src/core/{ext/filters/client_channel/lb_policy → load_balancing}/xds/xds_channel_args.h +4 -4
  330. data/src/core/{ext/filters/client_channel/lb_policy → load_balancing}/xds/xds_cluster_impl.cc +11 -11
  331. data/src/core/{ext/filters/client_channel/lb_policy → load_balancing}/xds/xds_cluster_manager.cc +8 -8
  332. data/src/core/{ext/filters/client_channel/lb_policy → load_balancing}/xds/xds_override_host.cc +10 -10
  333. data/src/core/{ext/filters/client_channel/lb_policy → load_balancing}/xds/xds_override_host.h +4 -4
  334. data/src/core/{ext/filters/client_channel/lb_policy → load_balancing}/xds/xds_wrr_locality.cc +6 -6
  335. data/src/core/{ext/filters/client_channel/resolver → resolver}/binder/binder_resolver.cc +3 -3
  336. data/src/core/{ext/filters/client_channel/resolver → resolver}/dns/c_ares/dns_resolver_ares.cc +9 -9
  337. data/src/core/{ext/filters/client_channel/resolver → resolver}/dns/c_ares/dns_resolver_ares.h +3 -3
  338. data/src/core/{ext/filters/client_channel/resolver → resolver}/dns/c_ares/grpc_ares_ev_driver.h +4 -4
  339. data/src/core/{ext/filters/client_channel/resolver → resolver}/dns/c_ares/grpc_ares_ev_driver_posix.cc +2 -2
  340. data/src/core/{ext/filters/client_channel/resolver → resolver}/dns/c_ares/grpc_ares_ev_driver_windows.cc +2 -2
  341. data/src/core/{ext/filters/client_channel/resolver → resolver}/dns/c_ares/grpc_ares_wrapper.cc +2 -2
  342. data/src/core/{ext/filters/client_channel/resolver → resolver}/dns/c_ares/grpc_ares_wrapper.h +4 -4
  343. data/src/core/{ext/filters/client_channel/resolver → resolver}/dns/c_ares/grpc_ares_wrapper_posix.cc +1 -1
  344. data/src/core/{ext/filters/client_channel/resolver → resolver}/dns/c_ares/grpc_ares_wrapper_windows.cc +2 -2
  345. data/src/core/{ext/filters/client_channel/resolver → resolver}/dns/dns_resolver_plugin.cc +7 -5
  346. data/src/core/{ext/filters/client_channel/resolver → resolver}/dns/dns_resolver_plugin.h +3 -3
  347. data/src/core/{ext/filters/client_channel/resolver → resolver}/dns/event_engine/event_engine_client_channel_resolver.cc +9 -9
  348. data/src/core/{ext/filters/client_channel/resolver → resolver}/dns/event_engine/event_engine_client_channel_resolver.h +5 -5
  349. data/src/core/{ext/filters/client_channel/resolver → resolver}/dns/event_engine/service_config_helper.cc +1 -1
  350. data/src/core/{ext/filters/client_channel/resolver → resolver}/dns/event_engine/service_config_helper.h +3 -3
  351. data/src/core/{ext/filters/client_channel/resolver → resolver}/dns/native/dns_resolver.cc +4 -4
  352. data/src/core/{ext/filters/client_channel/resolver → resolver}/dns/native/dns_resolver.h +3 -3
  353. data/src/core/{lib/resolver → resolver}/endpoint_addresses.cc +1 -1
  354. data/src/core/{lib/resolver → resolver}/endpoint_addresses.h +3 -3
  355. data/src/core/{ext/filters/client_channel/resolver → resolver}/fake/fake_resolver.cc +2 -2
  356. data/src/core/{ext/filters/client_channel/resolver → resolver}/fake/fake_resolver.h +4 -4
  357. data/src/core/{ext/filters/client_channel/resolver → resolver}/google_c2p/google_c2p_resolver.cc +3 -3
  358. data/src/core/{ext/filters/client_channel/resolver → resolver}/polling_resolver.cc +3 -3
  359. data/src/core/{ext/filters/client_channel/resolver → resolver}/polling_resolver.h +5 -5
  360. data/src/core/{lib/resolver → resolver}/resolver.cc +1 -1
  361. data/src/core/{lib/resolver → resolver}/resolver.h +6 -6
  362. data/src/core/{lib/resolver → resolver}/resolver_factory.h +4 -4
  363. data/src/core/{lib/resolver → resolver}/resolver_registry.cc +1 -1
  364. data/src/core/{lib/resolver → resolver}/resolver_registry.h +5 -5
  365. data/src/core/{lib/resolver → resolver}/server_address.h +4 -4
  366. data/src/core/{ext/filters/client_channel/resolver → resolver}/sockaddr/sockaddr_resolver.cc +3 -3
  367. data/src/core/{ext/filters/client_channel/resolver → resolver}/xds/xds_dependency_manager.cc +4 -4
  368. data/src/core/{ext/filters/client_channel/resolver → resolver}/xds/xds_dependency_manager.h +4 -4
  369. data/src/core/{ext/filters/client_channel/resolver → resolver}/xds/xds_resolver.cc +11 -11
  370. data/src/core/{ext/filters/client_channel/resolver → resolver}/xds/xds_resolver_attributes.h +4 -4
  371. data/src/core/{ext/filters/client_channel/resolver → resolver}/xds/xds_resolver_trace.cc +1 -1
  372. data/src/core/{ext/filters/client_channel/resolver → resolver}/xds/xds_resolver_trace.h +3 -3
  373. data/src/core/{lib/service_config → service_config}/service_config.h +4 -4
  374. data/src/core/{lib/service_config → service_config}/service_config_call_data.h +5 -5
  375. data/src/core/{lib/service_config → service_config}/service_config_impl.cc +2 -2
  376. data/src/core/{lib/service_config → service_config}/service_config_impl.h +5 -5
  377. data/src/core/{lib/service_config → service_config}/service_config_parser.cc +1 -1
  378. data/src/core/{lib/service_config → service_config}/service_config_parser.h +3 -3
  379. data/src/core/tsi/fake_transport_security.cc +1 -1
  380. data/src/ruby/ext/grpc/extconf.rb +0 -1
  381. data/src/ruby/ext/grpc/rb_channel.c +11 -5
  382. data/src/ruby/ext/grpc/rb_event_thread.c +9 -3
  383. data/src/ruby/lib/grpc/version.rb +1 -1
  384. data/third_party/abseil-cpp/absl/algorithm/algorithm.h +8 -103
  385. data/third_party/abseil-cpp/absl/algorithm/container.h +57 -71
  386. data/third_party/abseil-cpp/absl/base/attributes.h +51 -12
  387. data/third_party/abseil-cpp/absl/base/call_once.h +15 -9
  388. data/third_party/abseil-cpp/absl/base/casts.h +1 -1
  389. data/third_party/abseil-cpp/absl/base/config.h +91 -24
  390. data/third_party/abseil-cpp/absl/base/internal/endian.h +13 -12
  391. data/third_party/abseil-cpp/absl/base/internal/identity.h +4 -2
  392. data/third_party/abseil-cpp/absl/base/internal/inline_variable.h +19 -18
  393. data/third_party/abseil-cpp/absl/base/internal/low_level_alloc.cc +1 -1
  394. data/third_party/abseil-cpp/absl/base/internal/nullability_impl.h +106 -0
  395. data/third_party/abseil-cpp/absl/base/internal/raw_logging.cc +9 -11
  396. data/third_party/abseil-cpp/absl/base/internal/raw_logging.h +2 -0
  397. data/third_party/abseil-cpp/absl/base/internal/spinlock.h +17 -4
  398. data/third_party/abseil-cpp/absl/base/internal/sysinfo.cc +20 -0
  399. data/third_party/abseil-cpp/absl/base/internal/thread_identity.cc +10 -4
  400. data/third_party/abseil-cpp/absl/base/internal/unaligned_access.h +13 -6
  401. data/third_party/abseil-cpp/absl/base/log_severity.cc +1 -0
  402. data/third_party/abseil-cpp/absl/base/log_severity.h +23 -10
  403. data/third_party/abseil-cpp/absl/base/no_destructor.h +217 -0
  404. data/third_party/abseil-cpp/absl/base/nullability.h +224 -0
  405. data/third_party/abseil-cpp/absl/base/optimization.h +1 -0
  406. data/third_party/abseil-cpp/absl/base/options.h +27 -1
  407. data/third_party/abseil-cpp/absl/base/prefetch.h +25 -14
  408. data/third_party/abseil-cpp/absl/base/thread_annotations.h +0 -2
  409. data/third_party/abseil-cpp/absl/container/flat_hash_map.h +3 -3
  410. data/third_party/abseil-cpp/absl/container/flat_hash_set.h +1 -1
  411. data/third_party/abseil-cpp/absl/container/internal/common_policy_traits.h +4 -2
  412. data/third_party/abseil-cpp/absl/container/internal/container_memory.h +13 -9
  413. data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler.h +2 -12
  414. data/third_party/abseil-cpp/absl/container/internal/inlined_vector.h +12 -1
  415. data/third_party/abseil-cpp/absl/container/internal/layout.h +6 -21
  416. data/third_party/abseil-cpp/absl/container/internal/raw_hash_map.h +11 -2
  417. data/third_party/abseil-cpp/absl/container/internal/raw_hash_set.cc +148 -31
  418. data/third_party/abseil-cpp/absl/container/internal/raw_hash_set.h +717 -278
  419. data/third_party/abseil-cpp/absl/crc/internal/cpu_detect.cc +26 -2
  420. data/third_party/abseil-cpp/absl/crc/internal/cpu_detect.h +6 -0
  421. data/third_party/abseil-cpp/absl/crc/internal/crc32_x86_arm_combined_simd.h +34 -5
  422. data/third_party/abseil-cpp/absl/crc/internal/crc_memcpy.h +6 -3
  423. data/third_party/abseil-cpp/absl/crc/internal/crc_memcpy_fallback.cc +4 -2
  424. data/third_party/abseil-cpp/absl/crc/internal/{crc_memcpy_x86_64.cc → crc_memcpy_x86_arm_combined.cc} +65 -47
  425. data/third_party/abseil-cpp/absl/crc/internal/crc_x86_arm_combined.cc +10 -2
  426. data/third_party/abseil-cpp/absl/debugging/internal/address_is_readable.cc +4 -2
  427. data/third_party/abseil-cpp/absl/debugging/internal/demangle.cc +24 -0
  428. data/third_party/abseil-cpp/absl/debugging/internal/demangle.h +35 -33
  429. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_aarch64-inl.inc +41 -17
  430. data/third_party/abseil-cpp/absl/debugging/symbolize_elf.inc +108 -44
  431. data/third_party/abseil-cpp/absl/flags/declare.h +0 -5
  432. data/third_party/abseil-cpp/absl/flags/flag.h +1 -10
  433. data/third_party/abseil-cpp/absl/flags/internal/flag.h +0 -5
  434. data/third_party/abseil-cpp/absl/flags/marshalling.cc +10 -1
  435. data/third_party/abseil-cpp/absl/flags/reflection.cc +2 -1
  436. data/third_party/abseil-cpp/absl/functional/function_ref.h +8 -0
  437. data/third_party/abseil-cpp/absl/functional/internal/any_invocable.h +2 -2
  438. data/third_party/abseil-cpp/absl/hash/internal/hash.h +49 -2
  439. data/third_party/abseil-cpp/absl/numeric/bits.h +37 -18
  440. data/third_party/abseil-cpp/absl/random/distributions.h +1 -1
  441. data/third_party/abseil-cpp/absl/status/internal/status_internal.cc +248 -0
  442. data/third_party/abseil-cpp/absl/status/internal/status_internal.h +55 -14
  443. data/third_party/abseil-cpp/absl/status/internal/statusor_internal.h +53 -2
  444. data/third_party/abseil-cpp/absl/status/status.cc +36 -238
  445. data/third_party/abseil-cpp/absl/status/status.h +95 -53
  446. data/third_party/abseil-cpp/absl/status/status_payload_printer.cc +1 -3
  447. data/third_party/abseil-cpp/absl/status/status_payload_printer.h +3 -2
  448. data/third_party/abseil-cpp/absl/status/statusor.cc +5 -2
  449. data/third_party/abseil-cpp/absl/status/statusor.h +43 -3
  450. data/third_party/abseil-cpp/absl/strings/ascii.cc +84 -12
  451. data/third_party/abseil-cpp/absl/strings/ascii.h +8 -6
  452. data/third_party/abseil-cpp/absl/strings/charconv.cc +19 -12
  453. data/third_party/abseil-cpp/absl/strings/charconv.h +6 -3
  454. data/third_party/abseil-cpp/absl/strings/charset.h +164 -0
  455. data/third_party/abseil-cpp/absl/strings/cord.cc +266 -69
  456. data/third_party/abseil-cpp/absl/strings/cord.h +138 -92
  457. data/third_party/abseil-cpp/absl/strings/cord_analysis.cc +19 -33
  458. data/third_party/abseil-cpp/absl/strings/cord_analysis.h +4 -3
  459. data/third_party/abseil-cpp/absl/strings/escaping.cc +5 -4
  460. data/third_party/abseil-cpp/absl/strings/has_absl_stringify.h +63 -0
  461. data/third_party/abseil-cpp/absl/strings/has_ostream_operator.h +42 -0
  462. data/third_party/abseil-cpp/absl/strings/internal/cord_internal.cc +0 -6
  463. data/third_party/abseil-cpp/absl/strings/internal/cord_internal.h +19 -45
  464. data/third_party/abseil-cpp/absl/strings/internal/cordz_info.cc +23 -28
  465. data/third_party/abseil-cpp/absl/strings/internal/has_absl_stringify.h +15 -26
  466. data/third_party/abseil-cpp/absl/strings/internal/memutil.cc +12 -4
  467. data/third_party/abseil-cpp/absl/strings/internal/str_format/arg.cc +145 -8
  468. data/third_party/abseil-cpp/absl/strings/internal/str_format/arg.h +72 -24
  469. data/third_party/abseil-cpp/absl/strings/internal/str_format/bind.cc +17 -1
  470. data/third_party/abseil-cpp/absl/strings/internal/str_format/bind.h +7 -4
  471. data/third_party/abseil-cpp/absl/strings/internal/str_format/constexpr_parser.h +8 -3
  472. data/third_party/abseil-cpp/absl/strings/internal/str_format/extension.h +10 -4
  473. data/third_party/abseil-cpp/absl/strings/internal/str_format/parser.h +5 -4
  474. data/third_party/abseil-cpp/absl/strings/match.cc +3 -0
  475. data/third_party/abseil-cpp/absl/strings/numbers.cc +396 -153
  476. data/third_party/abseil-cpp/absl/strings/numbers.h +193 -35
  477. data/third_party/abseil-cpp/absl/strings/str_cat.cc +151 -21
  478. data/third_party/abseil-cpp/absl/strings/str_cat.h +127 -25
  479. data/third_party/abseil-cpp/absl/strings/str_format.h +30 -20
  480. data/third_party/abseil-cpp/absl/strings/str_join.h +16 -16
  481. data/third_party/abseil-cpp/absl/strings/str_replace.cc +12 -3
  482. data/third_party/abseil-cpp/absl/strings/str_replace.h +8 -5
  483. data/third_party/abseil-cpp/absl/strings/str_split.cc +8 -6
  484. data/third_party/abseil-cpp/absl/strings/str_split.h +18 -0
  485. data/third_party/abseil-cpp/absl/strings/string_view.cc +26 -5
  486. data/third_party/abseil-cpp/absl/strings/string_view.h +91 -26
  487. data/third_party/abseil-cpp/absl/strings/strip.h +5 -2
  488. data/third_party/abseil-cpp/absl/strings/substitute.cc +12 -4
  489. data/third_party/abseil-cpp/absl/strings/substitute.h +103 -91
  490. data/third_party/abseil-cpp/absl/synchronization/internal/pthread_waiter.h +2 -2
  491. data/third_party/abseil-cpp/absl/synchronization/internal/waiter.h +2 -0
  492. data/third_party/abseil-cpp/absl/synchronization/internal/win32_waiter.h +4 -2
  493. data/third_party/abseil-cpp/absl/synchronization/mutex.cc +296 -332
  494. data/third_party/abseil-cpp/absl/synchronization/mutex.h +89 -34
  495. data/third_party/abseil-cpp/absl/time/civil_time.h +26 -0
  496. data/third_party/abseil-cpp/absl/time/clock.h +5 -1
  497. data/third_party/abseil-cpp/absl/time/duration.cc +3 -3
  498. data/third_party/abseil-cpp/absl/time/internal/cctz/include/cctz/civil_time_detail.h +2 -2
  499. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_format.cc +1 -1
  500. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_info.cc +9 -14
  501. data/third_party/abseil-cpp/absl/time/internal/cctz/src/tzfile.h +0 -8
  502. data/third_party/abseil-cpp/absl/types/bad_optional_access.cc +18 -0
  503. data/third_party/abseil-cpp/absl/types/bad_variant_access.cc +18 -0
  504. data/third_party/abseil-cpp/absl/types/internal/variant.h +3 -3
  505. data/third_party/abseil-cpp/absl/types/optional.h +3 -2
  506. data/third_party/abseil-cpp/absl/types/span.h +9 -4
  507. data/third_party/abseil-cpp/absl/utility/utility.h +11 -93
  508. data/third_party/boringssl-with-bazel/err_data.c +278 -276
  509. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_gentm.c +1 -1
  510. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_mbstr.c +9 -9
  511. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_strex.c +8 -21
  512. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_time.c +1 -1
  513. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_type.c +19 -1
  514. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_utctm.c +1 -1
  515. data/third_party/boringssl-with-bazel/src/crypto/asn1/asn1_lib.c +11 -3
  516. data/third_party/boringssl-with-bazel/src/crypto/asn1/internal.h +4 -1
  517. data/third_party/boringssl-with-bazel/src/crypto/asn1/posix_time.c +1 -1
  518. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_dec.c +3 -3
  519. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_enc.c +1 -6
  520. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_new.c +4 -13
  521. data/third_party/boringssl-with-bazel/src/crypto/base64/base64.c +1 -6
  522. data/third_party/boringssl-with-bazel/src/crypto/bio/bio.c +27 -4
  523. data/third_party/boringssl-with-bazel/src/crypto/bio/connect.c +1 -4
  524. data/third_party/boringssl-with-bazel/src/crypto/bio/pair.c +1 -4
  525. data/third_party/boringssl-with-bazel/src/crypto/bn_extra/convert.c +8 -0
  526. data/third_party/boringssl-with-bazel/src/crypto/buf/buf.c +1 -11
  527. data/third_party/boringssl-with-bazel/src/crypto/bytestring/ber.c +7 -8
  528. data/third_party/boringssl-with-bazel/src/crypto/bytestring/cbb.c +42 -12
  529. data/third_party/boringssl-with-bazel/src/crypto/bytestring/internal.h +0 -22
  530. data/third_party/boringssl-with-bazel/src/crypto/bytestring/unicode.c +9 -9
  531. data/third_party/boringssl-with-bazel/src/crypto/chacha/chacha.c +34 -1
  532. data/third_party/boringssl-with-bazel/src/crypto/chacha/internal.h +49 -3
  533. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_aesgcmsiv.c +30 -42
  534. data/third_party/boringssl-with-bazel/src/crypto/conf/conf.c +87 -96
  535. data/third_party/boringssl-with-bazel/src/crypto/conf/internal.h +5 -1
  536. data/third_party/boringssl-with-bazel/src/crypto/cpu_intel.c +4 -2
  537. data/third_party/boringssl-with-bazel/src/crypto/crypto.c +11 -0
  538. data/third_party/boringssl-with-bazel/src/crypto/curve25519/curve25519.c +4 -0
  539. data/third_party/boringssl-with-bazel/src/crypto/curve25519/spake25519.c +1 -2
  540. data/third_party/boringssl-with-bazel/src/crypto/des/des.c +105 -31
  541. data/third_party/boringssl-with-bazel/src/crypto/des/internal.h +10 -81
  542. data/third_party/boringssl-with-bazel/src/crypto/dsa/dsa.c +2 -15
  543. data/third_party/boringssl-with-bazel/src/crypto/engine/engine.c +1 -9
  544. data/third_party/boringssl-with-bazel/src/crypto/evp/evp.c +1 -5
  545. data/third_party/boringssl-with-bazel/src/crypto/evp/evp_ctx.c +2 -5
  546. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ec.c +1 -4
  547. data/third_party/boringssl-with-bazel/src/crypto/evp/p_hkdf.c +1 -2
  548. data/third_party/boringssl-with-bazel/src/crypto/evp/p_rsa.c +1 -3
  549. data/third_party/boringssl-with-bazel/src/crypto/evp/scrypt.c +2 -2
  550. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/add.c +2 -8
  551. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/bn.c +1 -1
  552. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/bytes.c +26 -17
  553. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/ctx.c +1 -1
  554. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/exponentiation.c +4 -2
  555. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/gcd.c +26 -5
  556. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/generic.c +10 -41
  557. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/internal.h +49 -2
  558. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/montgomery.c +26 -0
  559. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/montgomery_inv.c +27 -26
  560. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/mul.c +2 -6
  561. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/prime.c +1 -8
  562. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/random.c +8 -2
  563. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/cipher.c +11 -2
  564. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/e_aes.c +11 -24
  565. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/e_aesccm.c +43 -50
  566. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/dh/dh.c +2 -6
  567. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digest/digest.c +4 -0
  568. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/ec.c +1 -2
  569. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/ec_key.c +16 -9
  570. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p224-64.c +7 -6
  571. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/wnaf.c +2 -7
  572. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/fork_detect.c +51 -13
  573. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/fork_detect.h +17 -0
  574. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/rand.c +5 -2
  575. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/blinding.c +1 -2
  576. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/rsa.c +1 -3
  577. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/rsa_impl.c +6 -5
  578. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/self_check/fips.c +1 -2
  579. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/internal.h +153 -6
  580. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/sha1.c +87 -7
  581. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/sha256.c +39 -5
  582. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/sha512.c +32 -5
  583. data/third_party/boringssl-with-bazel/src/crypto/internal.h +254 -54
  584. data/third_party/boringssl-with-bazel/src/crypto/keccak/internal.h +70 -0
  585. data/third_party/boringssl-with-bazel/src/crypto/{kyber → keccak}/keccak.c +124 -49
  586. data/third_party/boringssl-with-bazel/src/crypto/kyber/internal.h +8 -39
  587. data/third_party/boringssl-with-bazel/src/crypto/kyber/kyber.c +39 -29
  588. data/third_party/boringssl-with-bazel/src/crypto/lhash/lhash.c +3 -6
  589. data/third_party/boringssl-with-bazel/src/crypto/mem.c +17 -33
  590. data/third_party/boringssl-with-bazel/src/crypto/obj/obj.c +36 -16
  591. data/third_party/boringssl-with-bazel/src/crypto/obj/obj_dat.h +0 -3
  592. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_info.c +31 -0
  593. data/third_party/boringssl-with-bazel/src/crypto/pkcs7/pkcs7_x509.c +2 -4
  594. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/pkcs8.c +3 -3
  595. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/pkcs8_x509.c +9 -13
  596. data/third_party/boringssl-with-bazel/src/crypto/pool/pool.c +3 -6
  597. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/forkunsafe.c +4 -0
  598. data/third_party/boringssl-with-bazel/src/crypto/rsa_extra/rsa_crypt.c +3 -1
  599. data/third_party/boringssl-with-bazel/src/crypto/spx/address.c +101 -0
  600. data/third_party/boringssl-with-bazel/src/crypto/spx/address.h +50 -0
  601. data/third_party/boringssl-with-bazel/src/crypto/spx/fors.c +133 -0
  602. data/third_party/boringssl-with-bazel/src/crypto/spx/fors.h +54 -0
  603. data/third_party/boringssl-with-bazel/src/crypto/spx/internal.h +79 -0
  604. data/third_party/boringssl-with-bazel/src/crypto/spx/merkle.c +150 -0
  605. data/third_party/boringssl-with-bazel/src/crypto/spx/merkle.h +61 -0
  606. data/third_party/boringssl-with-bazel/src/crypto/spx/params.h +71 -0
  607. data/third_party/boringssl-with-bazel/src/crypto/spx/spx.c +139 -0
  608. data/third_party/boringssl-with-bazel/src/crypto/spx/spx_util.c +53 -0
  609. data/third_party/boringssl-with-bazel/src/crypto/spx/spx_util.h +44 -0
  610. data/third_party/boringssl-with-bazel/src/crypto/spx/thash.c +136 -0
  611. data/third_party/boringssl-with-bazel/src/crypto/spx/thash.h +70 -0
  612. data/third_party/boringssl-with-bazel/src/crypto/spx/wots.c +135 -0
  613. data/third_party/boringssl-with-bazel/src/crypto/spx/wots.h +45 -0
  614. data/third_party/boringssl-with-bazel/src/crypto/stack/stack.c +4 -9
  615. data/third_party/boringssl-with-bazel/src/crypto/trust_token/pmbtoken.c +10 -22
  616. data/third_party/boringssl-with-bazel/src/crypto/trust_token/trust_token.c +3 -6
  617. data/third_party/boringssl-with-bazel/src/crypto/trust_token/voprf.c +12 -36
  618. data/third_party/boringssl-with-bazel/src/crypto/x509/algorithm.c +1 -2
  619. data/third_party/boringssl-with-bazel/src/crypto/x509/asn1_gen.c +0 -2
  620. data/third_party/boringssl-with-bazel/src/crypto/x509/by_dir.c +14 -9
  621. data/third_party/boringssl-with-bazel/src/crypto/x509/by_file.c +23 -33
  622. data/third_party/boringssl-with-bazel/src/crypto/x509/internal.h +225 -51
  623. data/third_party/boringssl-with-bazel/src/crypto/x509/policy.c +2 -6
  624. data/third_party/boringssl-with-bazel/src/crypto/x509/rsa_pss.c +6 -2
  625. data/third_party/boringssl-with-bazel/src/crypto/x509/t_crl.c +1 -1
  626. data/third_party/boringssl-with-bazel/src/crypto/x509/t_req.c +1 -4
  627. data/third_party/boringssl-with-bazel/src/crypto/x509/t_x509.c +1 -3
  628. data/third_party/boringssl-with-bazel/src/crypto/{x509v3 → x509}/v3_akey.c +1 -1
  629. data/third_party/boringssl-with-bazel/src/crypto/{x509v3 → x509}/v3_akeya.c +3 -1
  630. data/third_party/boringssl-with-bazel/src/crypto/{x509v3 → x509}/v3_alt.c +5 -6
  631. data/third_party/boringssl-with-bazel/src/crypto/{x509v3 → x509}/v3_bcons.c +1 -1
  632. data/third_party/boringssl-with-bazel/src/crypto/{x509v3 → x509}/v3_bitst.c +1 -1
  633. data/third_party/boringssl-with-bazel/src/crypto/{x509v3 → x509}/v3_conf.c +0 -2
  634. data/third_party/boringssl-with-bazel/src/crypto/{x509v3 → x509}/v3_cpols.c +1 -1
  635. data/third_party/boringssl-with-bazel/src/crypto/{x509v3 → x509}/v3_crld.c +1 -2
  636. data/third_party/boringssl-with-bazel/src/crypto/{x509v3 → x509}/v3_enum.c +1 -0
  637. data/third_party/boringssl-with-bazel/src/crypto/{x509v3 → x509}/v3_extku.c +1 -1
  638. data/third_party/boringssl-with-bazel/src/crypto/{x509v3 → x509}/v3_genn.c +12 -12
  639. data/third_party/boringssl-with-bazel/src/crypto/{x509v3 → x509}/v3_ia5.c +1 -1
  640. data/third_party/boringssl-with-bazel/src/crypto/{x509v3 → x509}/v3_info.c +4 -6
  641. data/third_party/boringssl-with-bazel/src/crypto/{x509v3 → x509}/v3_int.c +1 -1
  642. data/third_party/boringssl-with-bazel/src/crypto/{x509v3 → x509}/v3_lib.c +3 -2
  643. data/third_party/boringssl-with-bazel/src/crypto/{x509v3 → x509}/v3_ncons.c +2 -2
  644. data/third_party/boringssl-with-bazel/src/crypto/{x509v3 → x509}/v3_ocsp.c +1 -1
  645. data/third_party/boringssl-with-bazel/src/crypto/{x509v3 → x509}/v3_pcons.c +1 -1
  646. data/third_party/boringssl-with-bazel/src/crypto/{x509v3 → x509}/v3_pmaps.c +1 -1
  647. data/third_party/boringssl-with-bazel/src/crypto/{x509v3 → x509}/v3_prn.c +3 -4
  648. data/third_party/boringssl-with-bazel/src/crypto/{x509v3 → x509}/v3_purp.c +92 -335
  649. data/third_party/boringssl-with-bazel/src/crypto/{x509v3 → x509}/v3_skey.c +1 -2
  650. data/third_party/boringssl-with-bazel/src/crypto/{x509v3 → x509}/v3_utl.c +20 -18
  651. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_att.c +35 -32
  652. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_cmp.c +44 -59
  653. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_ext.c +0 -1
  654. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_lu.c +107 -255
  655. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_req.c +32 -20
  656. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_trs.c +25 -152
  657. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_v3.c +0 -1
  658. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_vfy.c +330 -944
  659. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_vpm.c +93 -215
  660. data/third_party/boringssl-with-bazel/src/crypto/x509/x509name.c +28 -6
  661. data/third_party/boringssl-with-bazel/src/crypto/x509/x509spki.c +1 -1
  662. data/third_party/boringssl-with-bazel/src/crypto/x509/x_crl.c +35 -129
  663. data/third_party/boringssl-with-bazel/src/crypto/x509/x_name.c +7 -8
  664. data/third_party/boringssl-with-bazel/src/crypto/x509/x_pubkey.c +46 -50
  665. data/third_party/boringssl-with-bazel/src/crypto/x509/x_spki.c +2 -0
  666. data/third_party/boringssl-with-bazel/src/crypto/x509/x_x509.c +1 -4
  667. data/third_party/boringssl-with-bazel/src/crypto/x509/x_x509a.c +6 -6
  668. data/third_party/boringssl-with-bazel/src/include/openssl/arm_arch.h +0 -21
  669. data/third_party/boringssl-with-bazel/src/include/openssl/asm_base.h +5 -6
  670. data/third_party/boringssl-with-bazel/src/include/openssl/base.h +3 -1
  671. data/third_party/boringssl-with-bazel/src/include/openssl/bio.h +24 -0
  672. data/third_party/boringssl-with-bazel/src/include/openssl/bn.h +14 -5
  673. data/third_party/boringssl-with-bazel/src/include/openssl/bytestring.h +22 -0
  674. data/third_party/boringssl-with-bazel/src/include/openssl/cipher.h +1 -0
  675. data/third_party/boringssl-with-bazel/src/include/openssl/conf.h +4 -1
  676. data/third_party/boringssl-with-bazel/src/include/openssl/curve25519.h +2 -2
  677. data/third_party/boringssl-with-bazel/src/include/openssl/des.h +0 -13
  678. data/third_party/boringssl-with-bazel/src/include/openssl/ec.h +33 -11
  679. data/third_party/boringssl-with-bazel/src/include/openssl/evp.h +1 -1
  680. data/third_party/boringssl-with-bazel/src/include/openssl/ex_data.h +5 -4
  681. data/third_party/boringssl-with-bazel/src/include/openssl/kyber.h +26 -18
  682. data/third_party/boringssl-with-bazel/src/include/openssl/mem.h +13 -6
  683. data/third_party/boringssl-with-bazel/src/include/openssl/obj.h +5 -1
  684. data/third_party/boringssl-with-bazel/src/include/openssl/opensslconf.h +1 -0
  685. data/third_party/boringssl-with-bazel/src/include/openssl/pem.h +19 -5
  686. data/third_party/boringssl-with-bazel/src/include/openssl/posix_time.h +45 -0
  687. data/third_party/boringssl-with-bazel/src/include/openssl/rand.h +5 -0
  688. data/third_party/boringssl-with-bazel/src/include/openssl/sha.h +20 -3
  689. data/third_party/boringssl-with-bazel/src/include/openssl/span.h +18 -20
  690. data/third_party/boringssl-with-bazel/src/include/openssl/ssl.h +76 -60
  691. data/third_party/boringssl-with-bazel/src/include/openssl/target.h +31 -6
  692. data/third_party/boringssl-with-bazel/src/include/openssl/time.h +3 -22
  693. data/third_party/boringssl-with-bazel/src/include/openssl/tls1.h +2 -1
  694. data/third_party/boringssl-with-bazel/src/include/openssl/x509.h +2806 -941
  695. data/third_party/boringssl-with-bazel/src/include/openssl/x509v3.h +38 -1025
  696. data/third_party/boringssl-with-bazel/src/include/openssl/x509v3_errors.h +124 -0
  697. data/third_party/boringssl-with-bazel/src/ssl/d1_both.cc +1 -2
  698. data/third_party/boringssl-with-bazel/src/ssl/extensions.cc +82 -9
  699. data/third_party/boringssl-with-bazel/src/ssl/handoff.cc +42 -4
  700. data/third_party/boringssl-with-bazel/src/ssl/internal.h +4 -0
  701. data/third_party/boringssl-with-bazel/src/ssl/ssl_key_share.cc +4 -5
  702. data/third_party/boringssl-with-bazel/src/ssl/ssl_lib.cc +9 -1
  703. data/third_party/boringssl-with-bazel/src/ssl/ssl_x509.cc +0 -1
  704. data/third_party/boringssl-with-bazel/src/ssl/tls13_client.cc +5 -1
  705. data/third_party/boringssl-with-bazel/src/ssl/tls13_server.cc +5 -1
  706. data/third_party/boringssl-with-bazel/src/third_party/fiat/curve25519_64_adx.h +4 -2
  707. data/third_party/boringssl-with-bazel/src/third_party/fiat/p256_64.h +21 -0
  708. data/third_party/cares/config_linux/ares_config.h +2 -38
  709. metadata +214 -179
  710. data/src/core/lib/iomgr/load_file.cc +0 -78
  711. data/src/core/lib/iomgr/load_file.h +0 -35
  712. data/third_party/abseil-cpp/absl/base/internal/prefetch.h +0 -137
  713. data/third_party/abseil-cpp/absl/base/internal/thread_annotations.h +0 -280
  714. data/third_party/abseil-cpp/absl/flags/flag.cc +0 -38
  715. data/third_party/abseil-cpp/absl/flags/internal/flag_msvc.inc +0 -116
  716. data/third_party/abseil-cpp/absl/strings/internal/char_map.h +0 -158
  717. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_ring.cc +0 -773
  718. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_ring.h +0 -607
  719. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_ring_reader.h +0 -118
  720. data/third_party/boringssl-with-bazel/src/crypto/x509/x_info.c +0 -100
  721. data/third_party/boringssl-with-bazel/src/crypto/x509/x_pkey.c +0 -111
  722. data/third_party/boringssl-with-bazel/src/crypto/x509v3/internal.h +0 -197
  723. /data/third_party/boringssl-with-bazel/src/crypto/{x509v3 → x509}/ext_dat.h +0 -0
@@ -4,6 +4,7 @@
4
4
  // Generate stack tracer for aarch64
5
5
 
6
6
  #if defined(__linux__)
7
+ #include <signal.h>
7
8
  #include <sys/mman.h>
8
9
  #include <ucontext.h>
9
10
  #include <unistd.h>
@@ -70,7 +71,7 @@ static const unsigned char* GetKernelRtSigreturnAddress() {
70
71
  // Compute the size of a stack frame in [low..high). We assume that
71
72
  // low < high. Return size of kUnknownFrameSize.
72
73
  template<typename T>
73
- static inline size_t ComputeStackFrameSize(const T* low,
74
+ static size_t ComputeStackFrameSize(const T* low,
74
75
  const T* high) {
75
76
  const char* low_char_ptr = reinterpret_cast<const char *>(low);
76
77
  const char* high_char_ptr = reinterpret_cast<const char *>(high);
@@ -78,6 +79,20 @@ static inline size_t ComputeStackFrameSize(const T* low,
78
79
  : kUnknownFrameSize;
79
80
  }
80
81
 
82
+ // Saves stack info that is expensive to calculate to avoid recalculating per frame.
83
+ struct StackInfo {
84
+ uintptr_t stack_low;
85
+ uintptr_t stack_high;
86
+ uintptr_t sig_stack_low;
87
+ uintptr_t sig_stack_high;
88
+ };
89
+
90
+ static bool InsideSignalStack(void** ptr, const StackInfo* stack_info) {
91
+ uintptr_t comparable_ptr = reinterpret_cast<uintptr_t>(ptr);
92
+ return (comparable_ptr >= stack_info->sig_stack_low &&
93
+ comparable_ptr < stack_info->sig_stack_high);
94
+ }
95
+
81
96
  // Given a pointer to a stack frame, locate and return the calling
82
97
  // stackframe, or return null if no stackframe can be found. Perform sanity
83
98
  // checks (the strictness of which is controlled by the boolean parameter
@@ -86,9 +101,8 @@ template<bool STRICT_UNWINDING, bool WITH_CONTEXT>
86
101
  ABSL_ATTRIBUTE_NO_SANITIZE_ADDRESS // May read random elements from stack.
87
102
  ABSL_ATTRIBUTE_NO_SANITIZE_MEMORY // May read random elements from stack.
88
103
  static void **NextStackFrame(void **old_frame_pointer, const void *uc,
89
- size_t stack_low, size_t stack_high) {
104
+ const StackInfo *stack_info) {
90
105
  void **new_frame_pointer = reinterpret_cast<void**>(*old_frame_pointer);
91
- bool check_frame_size = true;
92
106
 
93
107
  #if defined(__linux__)
94
108
  if (WITH_CONTEXT && uc != nullptr) {
@@ -114,10 +128,6 @@ static void **NextStackFrame(void **old_frame_pointer, const void *uc,
114
128
  if (!absl::debugging_internal::AddressIsReadable(
115
129
  new_frame_pointer))
116
130
  return nullptr;
117
-
118
- // Skip frame size check if we return from a signal. We may be using a
119
- // an alternate stack for signals.
120
- check_frame_size = false;
121
131
  }
122
132
  }
123
133
  #endif
@@ -126,9 +136,11 @@ static void **NextStackFrame(void **old_frame_pointer, const void *uc,
126
136
  if ((reinterpret_cast<uintptr_t>(new_frame_pointer) & 7) != 0)
127
137
  return nullptr;
128
138
 
129
- // Check frame size. In strict mode, we assume frames to be under
130
- // 100,000 bytes. In non-strict mode, we relax the limit to 1MB.
131
- if (check_frame_size) {
139
+ // Only check the size if both frames are in the same stack.
140
+ if (InsideSignalStack(new_frame_pointer, stack_info) ==
141
+ InsideSignalStack(old_frame_pointer, stack_info)) {
142
+ // Check frame size. In strict mode, we assume frames to be under
143
+ // 100,000 bytes. In non-strict mode, we relax the limit to 1MB.
132
144
  const size_t max_size = STRICT_UNWINDING ? 100000 : 1000000;
133
145
  const size_t frame_size =
134
146
  ComputeStackFrameSize(old_frame_pointer, new_frame_pointer);
@@ -136,15 +148,21 @@ static void **NextStackFrame(void **old_frame_pointer, const void *uc,
136
148
  return nullptr;
137
149
  // A very large frame may mean corrupt memory or an erroneous frame
138
150
  // pointer. But also maybe just a plain-old large frame. Assume that if the
139
- // frame is within the known stack, then it is valid.
151
+ // frame is within a known stack, then it is valid.
140
152
  if (frame_size > max_size) {
141
- if (stack_high < kUnknownStackEnd &&
153
+ size_t stack_low = stack_info->stack_low;
154
+ size_t stack_high = stack_info->stack_high;
155
+ if (InsideSignalStack(new_frame_pointer, stack_info)) {
156
+ stack_low = stack_info->sig_stack_low;
157
+ stack_high = stack_info->sig_stack_high;
158
+ }
159
+ if (stack_high < kUnknownStackEnd &&
142
160
  static_cast<size_t>(getpagesize()) < stack_low) {
143
161
  const uintptr_t new_fp_u =
144
162
  reinterpret_cast<uintptr_t>(new_frame_pointer);
145
163
  // Stack bounds are known.
146
164
  if (!(stack_low < new_fp_u && new_fp_u <= stack_high)) {
147
- // new_frame_pointer is not within the known stack.
165
+ // new_frame_pointer is not within a known stack.
148
166
  return nullptr;
149
167
  }
150
168
  } else {
@@ -158,6 +176,9 @@ static void **NextStackFrame(void **old_frame_pointer, const void *uc,
158
176
  }
159
177
 
160
178
  template <bool IS_STACK_FRAMES, bool IS_WITH_CONTEXT>
179
+ // We count on the bottom frame being this one. See the comment
180
+ // at prev_return_address
181
+ ABSL_ATTRIBUTE_NOINLINE
161
182
  ABSL_ATTRIBUTE_NO_SANITIZE_ADDRESS // May read random elements from stack.
162
183
  ABSL_ATTRIBUTE_NO_SANITIZE_MEMORY // May read random elements from stack.
163
184
  static int UnwindImpl(void** result, int* sizes, int max_depth, int skip_count,
@@ -171,8 +192,11 @@ static int UnwindImpl(void** result, int* sizes, int max_depth, int skip_count,
171
192
  int n = 0;
172
193
 
173
194
  // Assume that the first page is not stack.
174
- size_t stack_low = static_cast<size_t>(getpagesize());
175
- size_t stack_high = kUnknownStackEnd;
195
+ StackInfo stack_info;
196
+ stack_info.stack_low = static_cast<uintptr_t>(getpagesize());
197
+ stack_info.stack_high = kUnknownStackEnd;
198
+ stack_info.sig_stack_low = stack_info.stack_low;
199
+ stack_info.sig_stack_high = kUnknownStackEnd;
176
200
 
177
201
  // The frame pointer points to low address of a frame. The first 64-bit
178
202
  // word of a frame points to the next frame up the call chain, which normally
@@ -207,7 +231,7 @@ static int UnwindImpl(void** result, int* sizes, int max_depth, int skip_count,
207
231
  // that is as complete as possible (even if it contains a few bogus
208
232
  // entries in some rare cases).
209
233
  frame_pointer = NextStackFrame<!IS_STACK_FRAMES, IS_WITH_CONTEXT>(
210
- frame_pointer, ucp, stack_low, stack_high);
234
+ frame_pointer, ucp, &stack_info);
211
235
  }
212
236
 
213
237
  if (min_dropped_frames != nullptr) {
@@ -222,7 +246,7 @@ static int UnwindImpl(void** result, int* sizes, int max_depth, int skip_count,
222
246
  num_dropped_frames++;
223
247
  }
224
248
  frame_pointer = NextStackFrame<!IS_STACK_FRAMES, IS_WITH_CONTEXT>(
225
- frame_pointer, ucp, stack_low, stack_high);
249
+ frame_pointer, ucp, &stack_info);
226
250
  }
227
251
  *min_dropped_frames = num_dropped_frames;
228
252
  }
@@ -289,6 +289,30 @@ ObjFile *AddrMap::Add() {
289
289
  return new (&obj_[size_++]) ObjFile;
290
290
  }
291
291
 
292
+ class CachingFile {
293
+ public:
294
+ // Setup reader for fd that uses buf[0, buf_size-1] as a cache.
295
+ CachingFile(int fd, char *buf, size_t buf_size)
296
+ : fd_(fd),
297
+ cache_(buf),
298
+ cache_size_(buf_size),
299
+ cache_start_(0),
300
+ cache_limit_(0) {}
301
+
302
+ int fd() const { return fd_; }
303
+ ssize_t ReadFromOffset(void *buf, size_t count, off_t offset);
304
+ bool ReadFromOffsetExact(void *buf, size_t count, off_t offset);
305
+
306
+ private:
307
+ // Bytes [cache_start_, cache_limit_-1] from fd_ are stored in
308
+ // a prefix of cache_[0, cache_size_-1].
309
+ int fd_;
310
+ char *cache_;
311
+ size_t cache_size_;
312
+ off_t cache_start_;
313
+ off_t cache_limit_;
314
+ };
315
+
292
316
  // ---------------------------------------------------------------
293
317
 
294
318
  enum FindSymbolResult { SYMBOL_NOT_FOUND = 1, SYMBOL_TRUNCATED, SYMBOL_FOUND };
@@ -330,6 +354,7 @@ class Symbolizer {
330
354
  SYMBOL_BUF_SIZE = 3072,
331
355
  TMP_BUF_SIZE = 1024,
332
356
  SYMBOL_CACHE_LINES = 128,
357
+ FILE_CACHE_SIZE = 8192,
333
358
  };
334
359
 
335
360
  AddrMap addr_map_;
@@ -338,6 +363,7 @@ class Symbolizer {
338
363
  bool addr_map_read_;
339
364
 
340
365
  char symbol_buf_[SYMBOL_BUF_SIZE];
366
+ char file_cache_[FILE_CACHE_SIZE];
341
367
 
342
368
  // tmp_buf_ will be used to store arrays of ElfW(Shdr) and ElfW(Sym)
343
369
  // so we ensure that tmp_buf_ is properly aligned to store either.
@@ -436,34 +462,58 @@ static ssize_t ReadPersistent(int fd, void *buf, size_t count) {
436
462
  return static_cast<ssize_t>(num_bytes);
437
463
  }
438
464
 
439
- // Read up to "count" bytes from "offset" in the file pointed by file
440
- // descriptor "fd" into the buffer starting at "buf". On success,
441
- // return the number of bytes read. Otherwise, return -1.
442
- static ssize_t ReadFromOffset(const int fd, void *buf, const size_t count,
443
- const off_t offset) {
444
- off_t off = lseek(fd, offset, SEEK_SET);
445
- if (off == (off_t)-1) {
446
- ABSL_RAW_LOG(WARNING, "lseek(%d, %jd, SEEK_SET) failed: errno=%d", fd,
447
- static_cast<intmax_t>(offset), errno);
448
- return -1;
465
+ // Read up to "count" bytes from "offset" into the buffer starting at "buf",
466
+ // while handling short reads and EINTR. On success, return the number of bytes
467
+ // read. Otherwise, return -1.
468
+ ssize_t CachingFile::ReadFromOffset(void *buf, size_t count, off_t offset) {
469
+ char *dst = static_cast<char *>(buf);
470
+ size_t read = 0;
471
+ while (read < count) {
472
+ // Look in cache first.
473
+ if (offset >= cache_start_ && offset < cache_limit_) {
474
+ const char *hit_start = &cache_[offset - cache_start_];
475
+ const size_t n =
476
+ std::min(count - read, static_cast<size_t>(cache_limit_ - offset));
477
+ memcpy(dst, hit_start, n);
478
+ dst += n;
479
+ read += static_cast<size_t>(n);
480
+ offset += static_cast<off_t>(n);
481
+ continue;
482
+ }
483
+
484
+ cache_start_ = 0;
485
+ cache_limit_ = 0;
486
+ ssize_t n = pread(fd_, cache_, cache_size_, offset);
487
+ if (n < 0) {
488
+ if (errno == EINTR) {
489
+ continue;
490
+ }
491
+ ABSL_RAW_LOG(WARNING, "read failed: errno=%d", errno);
492
+ return -1;
493
+ }
494
+ if (n == 0) { // Reached EOF.
495
+ break;
496
+ }
497
+
498
+ cache_start_ = offset;
499
+ cache_limit_ = offset + static_cast<off_t>(n);
500
+ // Next iteration will copy from cache into dst.
449
501
  }
450
- return ReadPersistent(fd, buf, count);
502
+ return static_cast<ssize_t>(read);
451
503
  }
452
504
 
453
- // Try reading exactly "count" bytes from "offset" bytes in a file
454
- // pointed by "fd" into the buffer starting at "buf" while handling
455
- // short reads and EINTR. On success, return true. Otherwise, return
456
- // false.
457
- static bool ReadFromOffsetExact(const int fd, void *buf, const size_t count,
458
- const off_t offset) {
459
- ssize_t len = ReadFromOffset(fd, buf, count, offset);
505
+ // Try reading exactly "count" bytes from "offset" bytes into the buffer
506
+ // starting at "buf" while handling short reads and EINTR. On success, return
507
+ // true. Otherwise, return false.
508
+ bool CachingFile::ReadFromOffsetExact(void *buf, size_t count, off_t offset) {
509
+ ssize_t len = ReadFromOffset(buf, count, offset);
460
510
  return len >= 0 && static_cast<size_t>(len) == count;
461
511
  }
462
512
 
463
513
  // Returns elf_header.e_type if the file pointed by fd is an ELF binary.
464
- static int FileGetElfType(const int fd) {
514
+ static int FileGetElfType(CachingFile *file) {
465
515
  ElfW(Ehdr) elf_header;
466
- if (!ReadFromOffsetExact(fd, &elf_header, sizeof(elf_header), 0)) {
516
+ if (!file->ReadFromOffsetExact(&elf_header, sizeof(elf_header), 0)) {
467
517
  return -1;
468
518
  }
469
519
  if (memcmp(elf_header.e_ident, ELFMAG, SELFMAG) != 0) {
@@ -478,8 +528,8 @@ static int FileGetElfType(const int fd) {
478
528
  // To keep stack consumption low, we would like this function to not get
479
529
  // inlined.
480
530
  static ABSL_ATTRIBUTE_NOINLINE bool GetSectionHeaderByType(
481
- const int fd, ElfW(Half) sh_num, const off_t sh_offset, ElfW(Word) type,
482
- ElfW(Shdr) * out, char *tmp_buf, size_t tmp_buf_size) {
531
+ CachingFile *file, ElfW(Half) sh_num, const off_t sh_offset,
532
+ ElfW(Word) type, ElfW(Shdr) * out, char *tmp_buf, size_t tmp_buf_size) {
483
533
  ElfW(Shdr) *buf = reinterpret_cast<ElfW(Shdr) *>(tmp_buf);
484
534
  const size_t buf_entries = tmp_buf_size / sizeof(buf[0]);
485
535
  const size_t buf_bytes = buf_entries * sizeof(buf[0]);
@@ -490,7 +540,7 @@ static ABSL_ATTRIBUTE_NOINLINE bool GetSectionHeaderByType(
490
540
  const size_t num_bytes_to_read =
491
541
  (buf_bytes > num_bytes_left) ? num_bytes_left : buf_bytes;
492
542
  const off_t offset = sh_offset + static_cast<off_t>(i * sizeof(buf[0]));
493
- const ssize_t len = ReadFromOffset(fd, buf, num_bytes_to_read, offset);
543
+ const ssize_t len = file->ReadFromOffset(buf, num_bytes_to_read, offset);
494
544
  if (len < 0) {
495
545
  ABSL_RAW_LOG(
496
546
  WARNING,
@@ -524,11 +574,17 @@ static ABSL_ATTRIBUTE_NOINLINE bool GetSectionHeaderByType(
524
574
  // but there has (as yet) been no need for anything longer either.
525
575
  const int kMaxSectionNameLen = 64;
526
576
 
577
+ // Small cache to use for miscellaneous file reads.
578
+ const int kSmallFileCacheSize = 100;
579
+
527
580
  bool ForEachSection(int fd,
528
581
  const std::function<bool(absl::string_view name,
529
582
  const ElfW(Shdr) &)> &callback) {
583
+ char buf[kSmallFileCacheSize];
584
+ CachingFile file(fd, buf, sizeof(buf));
585
+
530
586
  ElfW(Ehdr) elf_header;
531
- if (!ReadFromOffsetExact(fd, &elf_header, sizeof(elf_header), 0)) {
587
+ if (!file.ReadFromOffsetExact(&elf_header, sizeof(elf_header), 0)) {
532
588
  return false;
533
589
  }
534
590
 
@@ -540,7 +596,7 @@ bool ForEachSection(int fd,
540
596
  ElfW(Shdr) shstrtab;
541
597
  off_t shstrtab_offset = static_cast<off_t>(elf_header.e_shoff) +
542
598
  elf_header.e_shentsize * elf_header.e_shstrndx;
543
- if (!ReadFromOffsetExact(fd, &shstrtab, sizeof(shstrtab), shstrtab_offset)) {
599
+ if (!file.ReadFromOffsetExact(&shstrtab, sizeof(shstrtab), shstrtab_offset)) {
544
600
  return false;
545
601
  }
546
602
 
@@ -548,13 +604,13 @@ bool ForEachSection(int fd,
548
604
  ElfW(Shdr) out;
549
605
  off_t section_header_offset =
550
606
  static_cast<off_t>(elf_header.e_shoff) + elf_header.e_shentsize * i;
551
- if (!ReadFromOffsetExact(fd, &out, sizeof(out), section_header_offset)) {
607
+ if (!file.ReadFromOffsetExact(&out, sizeof(out), section_header_offset)) {
552
608
  return false;
553
609
  }
554
610
  off_t name_offset = static_cast<off_t>(shstrtab.sh_offset) + out.sh_name;
555
611
  char header_name[kMaxSectionNameLen];
556
612
  ssize_t n_read =
557
- ReadFromOffset(fd, &header_name, kMaxSectionNameLen, name_offset);
613
+ file.ReadFromOffset(&header_name, kMaxSectionNameLen, name_offset);
558
614
  if (n_read < 0) {
559
615
  return false;
560
616
  } else if (n_read > kMaxSectionNameLen) {
@@ -584,8 +640,10 @@ bool GetSectionHeaderByName(int fd, const char *name, size_t name_len,
584
640
  return false;
585
641
  }
586
642
 
643
+ char buf[kSmallFileCacheSize];
644
+ CachingFile file(fd, buf, sizeof(buf));
587
645
  ElfW(Ehdr) elf_header;
588
- if (!ReadFromOffsetExact(fd, &elf_header, sizeof(elf_header), 0)) {
646
+ if (!file.ReadFromOffsetExact(&elf_header, sizeof(elf_header), 0)) {
589
647
  return false;
590
648
  }
591
649
 
@@ -597,18 +655,18 @@ bool GetSectionHeaderByName(int fd, const char *name, size_t name_len,
597
655
  ElfW(Shdr) shstrtab;
598
656
  off_t shstrtab_offset = static_cast<off_t>(elf_header.e_shoff) +
599
657
  elf_header.e_shentsize * elf_header.e_shstrndx;
600
- if (!ReadFromOffsetExact(fd, &shstrtab, sizeof(shstrtab), shstrtab_offset)) {
658
+ if (!file.ReadFromOffsetExact(&shstrtab, sizeof(shstrtab), shstrtab_offset)) {
601
659
  return false;
602
660
  }
603
661
 
604
662
  for (int i = 0; i < elf_header.e_shnum; ++i) {
605
663
  off_t section_header_offset =
606
664
  static_cast<off_t>(elf_header.e_shoff) + elf_header.e_shentsize * i;
607
- if (!ReadFromOffsetExact(fd, out, sizeof(*out), section_header_offset)) {
665
+ if (!file.ReadFromOffsetExact(out, sizeof(*out), section_header_offset)) {
608
666
  return false;
609
667
  }
610
668
  off_t name_offset = static_cast<off_t>(shstrtab.sh_offset) + out->sh_name;
611
- ssize_t n_read = ReadFromOffset(fd, &header_name, name_len, name_offset);
669
+ ssize_t n_read = file.ReadFromOffset(&header_name, name_len, name_offset);
612
670
  if (n_read < 0) {
613
671
  return false;
614
672
  } else if (static_cast<size_t>(n_read) != name_len) {
@@ -683,7 +741,7 @@ static const char *ComputeOffset(const char *base, ptrdiff_t offset) {
683
741
  // To keep stack consumption low, we would like this function to not get
684
742
  // inlined.
685
743
  static ABSL_ATTRIBUTE_NOINLINE FindSymbolResult FindSymbol(
686
- const void *const pc, const int fd, char *out, size_t out_size,
744
+ const void *const pc, CachingFile *file, char *out, size_t out_size,
687
745
  ptrdiff_t relocation, const ElfW(Shdr) * strtab, const ElfW(Shdr) * symtab,
688
746
  const ElfW(Shdr) * opd, char *tmp_buf, size_t tmp_buf_size) {
689
747
  if (symtab == nullptr) {
@@ -716,7 +774,7 @@ static ABSL_ATTRIBUTE_NOINLINE FindSymbolResult FindSymbol(
716
774
  const size_t entries_in_chunk =
717
775
  std::min(num_remaining_symbols, buf_entries);
718
776
  const size_t bytes_in_chunk = entries_in_chunk * sizeof(buf[0]);
719
- const ssize_t len = ReadFromOffset(fd, buf, bytes_in_chunk, offset);
777
+ const ssize_t len = file->ReadFromOffset(buf, bytes_in_chunk, offset);
720
778
  SAFE_ASSERT(len >= 0);
721
779
  SAFE_ASSERT(static_cast<size_t>(len) % sizeof(buf[0]) == 0);
722
780
  const size_t num_symbols_in_buf = static_cast<size_t>(len) / sizeof(buf[0]);
@@ -772,12 +830,12 @@ static ABSL_ATTRIBUTE_NOINLINE FindSymbolResult FindSymbol(
772
830
  if (found_match) {
773
831
  const off_t off =
774
832
  static_cast<off_t>(strtab->sh_offset) + best_match.st_name;
775
- const ssize_t n_read = ReadFromOffset(fd, out, out_size, off);
833
+ const ssize_t n_read = file->ReadFromOffset(out, out_size, off);
776
834
  if (n_read <= 0) {
777
835
  // This should never happen.
778
836
  ABSL_RAW_LOG(WARNING,
779
- "Unable to read from fd %d at offset %lld: n_read = %zd", fd,
780
- static_cast<long long>(off), n_read);
837
+ "Unable to read from fd %d at offset %lld: n_read = %zd",
838
+ file->fd(), static_cast<long long>(off), n_read);
781
839
  return SYMBOL_NOT_FOUND;
782
840
  }
783
841
  ABSL_RAW_CHECK(static_cast<size_t>(n_read) <= out_size,
@@ -827,22 +885,24 @@ FindSymbolResult Symbolizer::GetSymbolFromObjectFile(
827
885
  }
828
886
  }
829
887
 
888
+ CachingFile file(obj.fd, file_cache_, sizeof(file_cache_));
889
+
830
890
  // Consult a regular symbol table, then fall back to the dynamic symbol table.
831
891
  for (const auto symbol_table_type : {SHT_SYMTAB, SHT_DYNSYM}) {
832
- if (!GetSectionHeaderByType(obj.fd, obj.elf_header.e_shnum,
892
+ if (!GetSectionHeaderByType(&file, obj.elf_header.e_shnum,
833
893
  static_cast<off_t>(obj.elf_header.e_shoff),
834
894
  static_cast<ElfW(Word)>(symbol_table_type),
835
895
  &symtab, tmp_buf, tmp_buf_size)) {
836
896
  continue;
837
897
  }
838
- if (!ReadFromOffsetExact(
839
- obj.fd, &strtab, sizeof(strtab),
898
+ if (!file.ReadFromOffsetExact(
899
+ &strtab, sizeof(strtab),
840
900
  static_cast<off_t>(obj.elf_header.e_shoff +
841
901
  symtab.sh_link * sizeof(symtab)))) {
842
902
  continue;
843
903
  }
844
904
  const FindSymbolResult rc =
845
- FindSymbol(pc, obj.fd, out, out_size, relocation, &strtab, &symtab,
905
+ FindSymbol(pc, &file, out, out_size, relocation, &strtab, &symtab,
846
906
  opd_ptr, tmp_buf, tmp_buf_size);
847
907
  if (rc != SYMBOL_NOT_FOUND) {
848
908
  return rc;
@@ -1323,15 +1383,19 @@ static bool MaybeInitializeObjFile(ObjFile *obj) {
1323
1383
  ABSL_RAW_LOG(WARNING, "%s: open failed: errno=%d", obj->filename, errno);
1324
1384
  return false;
1325
1385
  }
1326
- obj->elf_type = FileGetElfType(obj->fd);
1386
+
1387
+ char buf[kSmallFileCacheSize];
1388
+ CachingFile file(obj->fd, buf, sizeof(buf));
1389
+
1390
+ obj->elf_type = FileGetElfType(&file);
1327
1391
  if (obj->elf_type < 0) {
1328
1392
  ABSL_RAW_LOG(WARNING, "%s: wrong elf type: %d", obj->filename,
1329
1393
  obj->elf_type);
1330
1394
  return false;
1331
1395
  }
1332
1396
 
1333
- if (!ReadFromOffsetExact(obj->fd, &obj->elf_header, sizeof(obj->elf_header),
1334
- 0)) {
1397
+ if (!file.ReadFromOffsetExact(&obj->elf_header, sizeof(obj->elf_header),
1398
+ 0)) {
1335
1399
  ABSL_RAW_LOG(WARNING, "%s: failed to read elf header", obj->filename);
1336
1400
  return false;
1337
1401
  }
@@ -1341,7 +1405,7 @@ static bool MaybeInitializeObjFile(ObjFile *obj) {
1341
1405
  size_t num_interesting_load_segments = 0;
1342
1406
  for (int j = 0; j < phnum; j++) {
1343
1407
  ElfW(Phdr) phdr;
1344
- if (!ReadFromOffsetExact(obj->fd, &phdr, sizeof(phdr), phoff)) {
1408
+ if (!file.ReadFromOffsetExact(&phdr, sizeof(phdr), phoff)) {
1345
1409
  ABSL_RAW_LOG(WARNING, "%s: failed to read program header %d",
1346
1410
  obj->filename, j);
1347
1411
  return false;
@@ -40,13 +40,8 @@ class Flag;
40
40
  // Flag
41
41
  //
42
42
  // Forward declaration of the `absl::Flag` type for use in defining the macro.
43
- #if defined(_MSC_VER) && !defined(__clang__)
44
- template <typename T>
45
- class Flag;
46
- #else
47
43
  template <typename T>
48
44
  using Flag = flags_internal::Flag<T>;
49
- #endif
50
45
 
51
46
  ABSL_NAMESPACE_END
52
47
  } // namespace absl
@@ -71,12 +71,9 @@ ABSL_NAMESPACE_BEGIN
71
71
  // For type support of Abseil Flags, see the marshalling.h header file, which
72
72
  // discusses supported standard types, optional flags, and additional Abseil
73
73
  // type support.
74
- #if !defined(_MSC_VER) || defined(__clang__)
74
+
75
75
  template <typename T>
76
76
  using Flag = flags_internal::Flag<T>;
77
- #else
78
- #include "absl/flags/internal/flag_msvc.inc"
79
- #endif
80
77
 
81
78
  // GetFlag()
82
79
  //
@@ -196,18 +193,12 @@ ABSL_NAMESPACE_END
196
193
  // -----------------------------------------------------------------------------
197
194
 
198
195
  // ABSL_FLAG_IMPL macro definition conditional on ABSL_FLAGS_STRIP_NAMES
199
- #if !defined(_MSC_VER) || defined(__clang__)
200
196
  #define ABSL_FLAG_IMPL_FLAG_PTR(flag) flag
201
197
  #define ABSL_FLAG_IMPL_HELP_ARG(name) \
202
198
  absl::flags_internal::HelpArg<AbslFlagHelpGenFor##name>( \
203
199
  FLAGS_help_storage_##name)
204
200
  #define ABSL_FLAG_IMPL_DEFAULT_ARG(Type, name) \
205
201
  absl::flags_internal::DefaultArg<Type, AbslFlagDefaultGenFor##name>(0)
206
- #else
207
- #define ABSL_FLAG_IMPL_FLAG_PTR(flag) flag.GetImpl()
208
- #define ABSL_FLAG_IMPL_HELP_ARG(name) &AbslFlagHelpGenFor##name::NonConst
209
- #define ABSL_FLAG_IMPL_DEFAULT_ARG(Type, name) &AbslFlagDefaultGenFor##name::Gen
210
- #endif
211
202
 
212
203
  #if ABSL_FLAGS_STRIP_NAMES
213
204
  #define ABSL_FLAG_IMPL_FLAGNAME(txt) ""
@@ -54,13 +54,8 @@ template <typename T>
54
54
  class Flag;
55
55
  } // namespace flags_internal
56
56
 
57
- #if defined(_MSC_VER) && !defined(__clang__)
58
- template <typename T>
59
- class Flag;
60
- #else
61
57
  template <typename T>
62
58
  using Flag = flags_internal::Flag<T>;
63
- #endif
64
59
 
65
60
  template <typename T>
66
61
  ABSL_MUST_USE_RESULT T GetFlag(const absl::Flag<T>& flag);
@@ -247,6 +247,14 @@ bool AbslParseFlag(absl::string_view text, absl::LogSeverity* dst,
247
247
  *err = "no value provided";
248
248
  return false;
249
249
  }
250
+ if (absl::EqualsIgnoreCase(text, "dfatal")) {
251
+ *dst = absl::kLogDebugFatal;
252
+ return true;
253
+ }
254
+ if (absl::EqualsIgnoreCase(text, "klogdebugfatal")) {
255
+ *dst = absl::kLogDebugFatal;
256
+ return true;
257
+ }
250
258
  if (text.front() == 'k' || text.front() == 'K') text.remove_prefix(1);
251
259
  if (absl::EqualsIgnoreCase(text, "info")) {
252
260
  *dst = absl::LogSeverity::kInfo;
@@ -269,7 +277,8 @@ bool AbslParseFlag(absl::string_view text, absl::LogSeverity* dst,
269
277
  *dst = static_cast<absl::LogSeverity>(numeric_value);
270
278
  return true;
271
279
  }
272
- *err = "only integers and absl::LogSeverity enumerators are accepted";
280
+ *err =
281
+ "only integers, absl::LogSeverity enumerators, and DFATAL are accepted";
273
282
  return false;
274
283
  }
275
284
 
@@ -21,6 +21,7 @@
21
21
  #include <string>
22
22
 
23
23
  #include "absl/base/config.h"
24
+ #include "absl/base/no_destructor.h"
24
25
  #include "absl/base/thread_annotations.h"
25
26
  #include "absl/container/flat_hash_map.h"
26
27
  #include "absl/flags/commandlineflag.h"
@@ -169,7 +170,7 @@ void FlagRegistry::RegisterFlag(CommandLineFlag& flag, const char* filename) {
169
170
  }
170
171
 
171
172
  FlagRegistry& FlagRegistry::GlobalRegistry() {
172
- static FlagRegistry* global_registry = new FlagRegistry;
173
+ static absl::NoDestructor<FlagRegistry> global_registry;
173
174
  return *global_registry;
174
175
  }
175
176
 
@@ -137,6 +137,14 @@ class FunctionRef<R(Args...)> {
137
137
  absl::functional_internal::Invoker<R, Args...> invoker_;
138
138
  };
139
139
 
140
+ // Allow const qualified function signatures. Since FunctionRef requires
141
+ // constness anyway we can just make this a no-op.
142
+ template <typename R, typename... Args>
143
+ class FunctionRef<R(Args...) const> : public FunctionRef<R(Args...)> {
144
+ public:
145
+ using FunctionRef<R(Args...)>::FunctionRef;
146
+ };
147
+
140
148
  ABSL_NAMESPACE_END
141
149
  } // namespace absl
142
150
 
@@ -215,8 +215,8 @@ T& ObjectInLocalStorage(TypeErasedState* const state) {
215
215
  // behavior, which works as intended on Abseil's officially supported
216
216
  // platforms as of Q2 2022.
217
217
  #if !defined(__clang__) && defined(__GNUC__)
218
- #pragma GCC diagnostic ignored "-Wstrict-aliasing"
219
218
  #pragma GCC diagnostic push
219
+ #pragma GCC diagnostic ignored "-Wstrict-aliasing"
220
220
  #endif
221
221
  return *reinterpret_cast<T*>(&state->storage);
222
222
  #if !defined(__clang__) && defined(__GNUC__)
@@ -526,10 +526,10 @@ class CoreImpl {
526
526
  // Since this is template-heavy code, we prefer to disable these warnings
527
527
  // locally instead of adding yet another overload of this function.
528
528
  #if !defined(__clang__) && defined(__GNUC__)
529
+ #pragma GCC diagnostic push
529
530
  #pragma GCC diagnostic ignored "-Wpragmas"
530
531
  #pragma GCC diagnostic ignored "-Waddress"
531
532
  #pragma GCC diagnostic ignored "-Wnonnull-compare"
532
- #pragma GCC diagnostic push
533
533
  #endif
534
534
  if (static_cast<RemoveCVRef<QualDecayedTRef>>(f) == nullptr) {
535
535
  #if !defined(__clang__) && defined(__GNUC__)