grpc 1.47.0 → 1.48.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 (574) hide show
  1. checksums.yaml +4 -4
  2. data/Makefile +105 -47
  3. data/include/grpc/compression.h +1 -1
  4. data/include/grpc/event_engine/event_engine.h +20 -11
  5. data/include/grpc/event_engine/slice_buffer.h +8 -2
  6. data/include/grpc/grpc.h +3 -3
  7. data/include/grpc/impl/codegen/compression_types.h +2 -1
  8. data/include/grpc/impl/codegen/connectivity_state.h +2 -1
  9. data/include/grpc/impl/codegen/gpr_types.h +2 -1
  10. data/include/grpc/impl/codegen/grpc_types.h +2 -1
  11. data/include/grpc/impl/codegen/port_platform.h +6 -3
  12. data/src/core/ext/filters/census/grpc_context.cc +3 -0
  13. data/src/core/ext/filters/channel_idle/channel_idle_filter.cc +17 -5
  14. data/src/core/ext/filters/channel_idle/channel_idle_filter.h +16 -0
  15. data/src/core/ext/filters/channel_idle/idle_filter_state.h +2 -0
  16. data/src/core/ext/filters/client_channel/backup_poller.cc +3 -1
  17. data/src/core/ext/filters/client_channel/channel_connectivity.cc +2 -2
  18. data/src/core/ext/filters/client_channel/client_channel.cc +51 -65
  19. data/src/core/ext/filters/client_channel/client_channel.h +19 -4
  20. data/src/core/ext/filters/client_channel/config_selector.h +1 -1
  21. data/src/core/ext/filters/client_channel/connector.h +1 -1
  22. data/src/core/ext/filters/client_channel/dynamic_filters.cc +6 -4
  23. data/src/core/ext/filters/client_channel/dynamic_filters.h +1 -1
  24. data/src/core/ext/filters/client_channel/lb_policy/address_filtering.cc +1 -1
  25. data/src/core/ext/filters/client_channel/lb_policy/grpclb/client_load_reporting_filter.cc +2 -2
  26. data/src/core/ext/filters/client_channel/lb_policy/grpclb/client_load_reporting_filter.h +1 -0
  27. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb.cc +73 -43
  28. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_balancer_addresses.cc +1 -1
  29. data/src/core/ext/filters/client_channel/lb_policy/oob_backend_metric.cc +0 -1
  30. data/src/core/ext/filters/client_channel/lb_policy/outlier_detection/outlier_detection.cc +33 -35
  31. data/src/core/ext/filters/client_channel/lb_policy/pick_first/pick_first.cc +106 -112
  32. data/src/core/ext/filters/client_channel/lb_policy/priority/priority.cc +91 -42
  33. data/src/core/ext/filters/client_channel/lb_policy/ring_hash/ring_hash.cc +177 -138
  34. data/src/core/ext/filters/client_channel/lb_policy/ring_hash/ring_hash.h +4 -1
  35. data/src/core/ext/filters/client_channel/lb_policy/rls/rls.cc +47 -44
  36. data/src/core/ext/filters/client_channel/lb_policy/round_robin/round_robin.cc +118 -103
  37. data/src/core/ext/filters/client_channel/lb_policy/subchannel_list.h +83 -78
  38. data/src/core/ext/filters/client_channel/lb_policy/weighted_target/weighted_target.cc +57 -67
  39. data/src/core/ext/filters/client_channel/lb_policy/xds/cds.cc +2 -2
  40. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_impl.cc +5 -7
  41. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_manager.cc +13 -17
  42. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_resolver.cc +3 -3
  43. data/src/core/ext/filters/client_channel/lb_policy.h +0 -7
  44. data/src/core/ext/filters/client_channel/lb_policy_registry.cc +3 -5
  45. data/src/core/ext/filters/client_channel/proxy_mapper_registry.cc +0 -1
  46. data/src/core/ext/filters/client_channel/resolver/binder/binder_resolver.cc +3 -1
  47. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/dns_resolver_ares.cc +6 -6
  48. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver_windows.cc +5 -5
  49. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.cc +10 -5
  50. data/src/core/ext/filters/client_channel/resolver/dns/native/dns_resolver.cc +12 -3
  51. data/src/core/ext/filters/client_channel/resolver/fake/fake_resolver.cc +5 -5
  52. data/src/core/ext/filters/client_channel/resolver/google_c2p/google_c2p_resolver.cc +3 -4
  53. data/src/core/ext/filters/client_channel/resolver/polling_resolver.cc +1 -1
  54. data/src/core/ext/filters/client_channel/resolver/sockaddr/sockaddr_resolver.cc +1 -0
  55. data/src/core/ext/filters/client_channel/resolver/xds/xds_resolver.cc +24 -15
  56. data/src/core/ext/filters/client_channel/resolver/xds/xds_resolver.h +3 -1
  57. data/src/core/ext/filters/client_channel/resolver_result_parsing.cc +7 -7
  58. data/src/core/ext/filters/client_channel/retry_filter.cc +35 -36
  59. data/src/core/ext/filters/client_channel/retry_filter.h +1 -0
  60. data/src/core/ext/filters/client_channel/retry_service_config.cc +4 -4
  61. data/src/core/ext/filters/client_channel/service_config_channel_arg_filter.cc +2 -1
  62. data/src/core/ext/filters/client_channel/subchannel.cc +53 -50
  63. data/src/core/ext/filters/client_channel/subchannel.h +6 -22
  64. data/src/core/ext/filters/client_channel/subchannel_interface.h +10 -18
  65. data/src/core/ext/filters/client_channel/subchannel_stream_client.cc +12 -97
  66. data/src/core/ext/filters/client_channel/subchannel_stream_client.h +5 -9
  67. data/src/core/ext/filters/deadline/deadline_filter.cc +12 -7
  68. data/src/core/ext/filters/deadline/deadline_filter.h +8 -1
  69. data/src/core/ext/filters/fault_injection/fault_injection_filter.cc +21 -2
  70. data/src/core/ext/filters/fault_injection/fault_injection_filter.h +8 -3
  71. data/src/core/ext/filters/fault_injection/service_config_parser.cc +7 -4
  72. data/src/core/ext/filters/fault_injection/service_config_parser.h +17 -3
  73. data/src/core/ext/filters/http/client/http_client_filter.cc +16 -5
  74. data/src/core/ext/filters/http/client/http_client_filter.h +8 -1
  75. data/src/core/ext/filters/http/client_authority_filter.cc +11 -10
  76. data/src/core/ext/filters/http/client_authority_filter.h +5 -2
  77. data/src/core/ext/filters/http/http_filters_plugin.cc +9 -1
  78. data/src/core/ext/filters/http/message_compress/message_compress_filter.cc +64 -187
  79. data/src/core/ext/filters/http/message_compress/message_compress_filter.h +1 -2
  80. data/src/core/ext/filters/http/message_compress/message_decompress_filter.cc +42 -106
  81. data/src/core/ext/filters/http/message_compress/message_decompress_filter.h +1 -0
  82. data/src/core/ext/filters/http/server/http_server_filter.cc +16 -9
  83. data/src/core/ext/filters/http/server/http_server_filter.h +6 -1
  84. data/src/core/ext/filters/message_size/message_size_filter.cc +25 -15
  85. data/src/core/ext/filters/message_size/message_size_filter.h +13 -0
  86. data/src/core/ext/filters/rbac/rbac_filter.cc +14 -3
  87. data/src/core/ext/filters/rbac/rbac_filter.h +8 -0
  88. data/src/core/ext/filters/rbac/rbac_service_config_parser.cc +13 -2
  89. data/src/core/ext/filters/rbac/rbac_service_config_parser.h +14 -2
  90. data/src/core/ext/filters/server_config_selector/server_config_selector.cc +1 -0
  91. data/src/core/ext/filters/server_config_selector/server_config_selector.h +9 -0
  92. data/src/core/ext/filters/server_config_selector/server_config_selector_filter.cc +22 -2
  93. data/src/core/ext/filters/server_config_selector/server_config_selector_filter.h +1 -0
  94. data/src/core/ext/transport/chttp2/client/chttp2_connector.cc +4 -4
  95. data/src/core/ext/transport/chttp2/server/chttp2_server.cc +15 -15
  96. data/src/core/ext/transport/chttp2/transport/chttp2_transport.cc +196 -476
  97. data/src/core/ext/transport/chttp2/transport/chttp2_transport.h +1 -1
  98. data/src/core/ext/transport/chttp2/transport/flow_control.cc +141 -261
  99. data/src/core/ext/transport/chttp2/transport/flow_control.h +176 -289
  100. data/src/core/ext/transport/chttp2/transport/frame_data.cc +57 -215
  101. data/src/core/ext/transport/chttp2/transport/frame_data.h +10 -36
  102. data/src/core/ext/transport/chttp2/transport/frame_settings.cc +0 -41
  103. data/src/core/ext/transport/chttp2/transport/frame_window_update.cc +7 -12
  104. data/src/core/ext/transport/chttp2/transport/hpack_parser.cc +7 -6
  105. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.cc +0 -2
  106. data/src/core/ext/transport/chttp2/transport/internal.h +9 -111
  107. data/src/core/ext/transport/chttp2/transport/parsing.cc +51 -38
  108. data/src/core/ext/transport/chttp2/transport/stream_lists.cc +0 -4
  109. data/src/core/ext/transport/chttp2/transport/writing.cc +18 -21
  110. data/src/core/ext/transport/inproc/inproc_plugin.cc +0 -1
  111. data/src/core/ext/transport/inproc/inproc_transport.cc +85 -81
  112. data/src/core/ext/transport/inproc/inproc_transport.h +3 -1
  113. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/ring_hash/v3/ring_hash.upb.c +52 -0
  114. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/ring_hash/v3/ring_hash.upb.h +164 -0
  115. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/wrr_locality/v3/wrr_locality.upb.c +46 -0
  116. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/wrr_locality/v3/wrr_locality.upb.h +94 -0
  117. data/src/core/ext/xds/certificate_provider_factory.h +6 -1
  118. data/src/core/ext/xds/certificate_provider_registry.cc +8 -8
  119. data/src/core/ext/xds/certificate_provider_registry.h +3 -1
  120. data/src/core/ext/xds/certificate_provider_store.cc +2 -0
  121. data/src/core/ext/xds/certificate_provider_store.h +9 -0
  122. data/src/core/ext/xds/file_watcher_certificate_provider_factory.cc +9 -0
  123. data/src/core/ext/xds/file_watcher_certificate_provider_factory.h +8 -0
  124. data/src/core/ext/xds/upb_utils.h +1 -2
  125. data/src/core/ext/xds/xds_api.cc +16 -18
  126. data/src/core/ext/xds/xds_api.h +12 -5
  127. data/src/core/ext/xds/xds_bootstrap.cc +37 -24
  128. data/src/core/ext/xds/xds_bootstrap.h +9 -11
  129. data/src/core/ext/xds/xds_certificate_provider.cc +12 -3
  130. data/src/core/ext/xds/xds_certificate_provider.h +16 -1
  131. data/src/core/ext/xds/xds_channel_stack_modifier.cc +9 -0
  132. data/src/core/ext/xds/xds_channel_stack_modifier.h +5 -1
  133. data/src/core/ext/xds/xds_client.cc +71 -22
  134. data/src/core/ext/xds/xds_client.h +17 -3
  135. data/src/core/ext/xds/xds_client_stats.cc +3 -4
  136. data/src/core/ext/xds/xds_client_stats.h +4 -3
  137. data/src/core/ext/xds/xds_cluster.cc +21 -10
  138. data/src/core/ext/xds/xds_cluster.h +9 -1
  139. data/src/core/ext/xds/xds_cluster_specifier_plugin.cc +16 -7
  140. data/src/core/ext/xds/xds_cluster_specifier_plugin.h +1 -8
  141. data/src/core/ext/xds/xds_common_types.cc +36 -22
  142. data/src/core/ext/xds/xds_common_types.h +12 -4
  143. data/src/core/ext/xds/xds_endpoint.cc +25 -15
  144. data/src/core/ext/xds/xds_endpoint.h +13 -5
  145. data/src/core/ext/xds/xds_http_fault_filter.cc +7 -5
  146. data/src/core/ext/xds/xds_http_fault_filter.h +3 -1
  147. data/src/core/ext/xds/xds_http_filters.cc +7 -0
  148. data/src/core/ext/xds/xds_http_filters.h +3 -3
  149. data/src/core/ext/xds/xds_http_rbac_filter.cc +16 -0
  150. data/src/core/ext/xds/xds_http_rbac_filter.h +7 -0
  151. data/src/core/ext/xds/xds_lb_policy_registry.cc +291 -0
  152. data/src/core/ext/xds/xds_lb_policy_registry.h +72 -0
  153. data/src/core/ext/xds/xds_listener.cc +51 -33
  154. data/src/core/ext/xds/xds_listener.h +10 -1
  155. data/src/core/ext/xds/xds_resource_type.h +3 -3
  156. data/src/core/ext/xds/xds_resource_type_impl.h +7 -3
  157. data/src/core/ext/xds/xds_route_config.cc +56 -28
  158. data/src/core/ext/xds/xds_route_config.h +11 -2
  159. data/src/core/ext/xds/xds_routing.cc +16 -0
  160. data/src/core/ext/xds/xds_routing.h +7 -2
  161. data/src/core/ext/xds/xds_server_config_fetcher.cc +54 -6
  162. data/src/core/lib/address_utils/parse_address.cc +5 -8
  163. data/src/core/lib/address_utils/parse_address.h +3 -2
  164. data/src/core/lib/address_utils/sockaddr_utils.cc +8 -7
  165. data/src/core/lib/address_utils/sockaddr_utils.h +2 -0
  166. data/src/core/lib/avl/avl.h +3 -3
  167. data/src/core/lib/backoff/backoff.cc +1 -1
  168. data/src/core/lib/backoff/backoff.h +1 -1
  169. data/src/core/lib/channel/call_tracer.h +3 -3
  170. data/src/core/lib/channel/channel_args.h +1 -0
  171. data/src/core/lib/channel/channel_args_preconditioning.cc +1 -0
  172. data/src/core/lib/channel/channel_fwd.h +26 -0
  173. data/src/core/lib/channel/channel_stack.cc +4 -4
  174. data/src/core/lib/channel/channel_stack.h +1 -11
  175. data/src/core/lib/channel/channel_stack_builder.h +2 -5
  176. data/src/core/lib/channel/channel_stack_builder_impl.cc +1 -1
  177. data/src/core/lib/channel/channel_stack_builder_impl.h +1 -0
  178. data/src/core/lib/channel/channelz.cc +2 -1
  179. data/src/core/lib/channel/channelz.h +2 -3
  180. data/src/core/lib/channel/channelz_registry.cc +4 -5
  181. data/src/core/lib/channel/connected_channel.cc +1 -0
  182. data/src/core/lib/channel/connected_channel.h +1 -0
  183. data/src/core/lib/channel/promise_based_filter.cc +11 -5
  184. data/src/core/lib/channel/promise_based_filter.h +2 -0
  185. data/src/core/lib/compression/compression.cc +6 -1
  186. data/src/core/lib/compression/compression_internal.cc +3 -6
  187. data/src/core/lib/compression/compression_internal.h +3 -2
  188. data/src/core/lib/compression/message_compress.cc +3 -1
  189. data/src/core/lib/compression/message_compress.h +2 -3
  190. data/src/core/lib/debug/stats.cc +9 -9
  191. data/src/core/lib/debug/stats.h +2 -1
  192. data/src/core/lib/debug/stats_data.cc +2 -1
  193. data/src/core/lib/debug/stats_data.h +0 -4
  194. data/src/core/lib/debug/trace.h +13 -12
  195. data/src/core/lib/event_engine/default_event_engine_factory.cc +1 -1
  196. data/src/core/lib/event_engine/event_engine.cc +24 -19
  197. data/src/core/lib/event_engine/event_engine_factory.h +2 -2
  198. data/src/core/lib/event_engine/{iomgr_engine.cc → iomgr_engine/iomgr_engine.cc} +44 -91
  199. data/src/core/lib/event_engine/{iomgr_engine.h → iomgr_engine/iomgr_engine.h} +20 -16
  200. data/src/core/lib/event_engine/iomgr_engine/thread_pool.cc +123 -0
  201. data/src/core/lib/event_engine/iomgr_engine/thread_pool.h +70 -0
  202. data/src/core/lib/event_engine/iomgr_engine/time_averaged_stats.cc +62 -0
  203. data/src/core/lib/event_engine/iomgr_engine/time_averaged_stats.h +81 -0
  204. data/src/core/lib/event_engine/iomgr_engine/timer.cc +312 -0
  205. data/src/core/lib/event_engine/iomgr_engine/timer.h +193 -0
  206. data/src/core/lib/event_engine/iomgr_engine/timer_heap.cc +107 -0
  207. data/src/core/lib/event_engine/iomgr_engine/timer_heap.h +56 -0
  208. data/src/core/lib/event_engine/iomgr_engine/timer_manager.cc +254 -0
  209. data/src/core/lib/event_engine/iomgr_engine/timer_manager.h +111 -0
  210. data/src/core/lib/event_engine/promise.h +69 -0
  211. data/src/core/lib/gpr/time_posix.cc +6 -9
  212. data/src/core/lib/gpr/time_windows.cc +10 -7
  213. data/src/core/lib/gprpp/manual_constructor.h +0 -67
  214. data/src/core/lib/gprpp/status_helper.cc +44 -30
  215. data/src/core/lib/gprpp/time.cc +8 -0
  216. data/src/core/lib/gprpp/time.h +4 -0
  217. data/src/core/lib/http/format_request.cc +5 -4
  218. data/src/core/lib/http/format_request.h +1 -1
  219. data/src/core/lib/http/httpcli.cc +18 -12
  220. data/src/core/lib/http/httpcli.h +19 -3
  221. data/src/core/lib/http/httpcli_security_connector.cc +16 -4
  222. data/src/core/lib/http/httpcli_ssl_credentials.h +3 -1
  223. data/src/core/lib/http/parser.cc +6 -7
  224. data/src/core/lib/http/parser.h +3 -0
  225. data/src/core/lib/iomgr/call_combiner.cc +2 -2
  226. data/src/core/lib/iomgr/endpoint.h +1 -1
  227. data/src/core/lib/iomgr/endpoint_cfstream.cc +2 -2
  228. data/src/core/lib/iomgr/error.cc +11 -9
  229. data/src/core/lib/iomgr/error.h +9 -5
  230. data/src/core/lib/iomgr/ev_epoll1_linux.cc +57 -18
  231. data/src/core/lib/iomgr/ev_epoll1_linux.h +1 -1
  232. data/src/core/lib/iomgr/ev_poll_posix.cc +77 -52
  233. data/src/core/lib/iomgr/ev_poll_posix.h +2 -2
  234. data/src/core/lib/iomgr/ev_posix.cc +54 -92
  235. data/src/core/lib/iomgr/ev_posix.h +5 -3
  236. data/src/core/lib/iomgr/fork_posix.cc +1 -1
  237. data/src/core/lib/iomgr/iomgr.cc +7 -0
  238. data/src/core/lib/iomgr/iomgr_posix.cc +1 -0
  239. data/src/core/lib/iomgr/iomgr_posix_cfstream.cc +1 -0
  240. data/src/core/lib/iomgr/load_file.cc +1 -1
  241. data/src/core/lib/iomgr/resolve_address_posix.cc +1 -1
  242. data/src/core/lib/iomgr/resolve_address_windows.cc +1 -1
  243. data/src/core/lib/iomgr/tcp_client.cc +12 -7
  244. data/src/core/lib/iomgr/tcp_client.h +24 -13
  245. data/src/core/lib/iomgr/tcp_client_cfstream.cc +15 -9
  246. data/src/core/lib/iomgr/tcp_client_posix.cc +143 -25
  247. data/src/core/lib/iomgr/tcp_client_posix.h +1 -1
  248. data/src/core/lib/iomgr/tcp_client_windows.cc +14 -10
  249. data/src/core/lib/iomgr/tcp_posix.cc +91 -29
  250. data/src/core/lib/iomgr/tcp_server_posix.cc +7 -7
  251. data/src/core/lib/iomgr/tcp_server_utils_posix_common.cc +12 -12
  252. data/src/core/lib/iomgr/tcp_server_utils_posix_ifaddrs.cc +2 -2
  253. data/src/core/lib/iomgr/tcp_server_windows.cc +7 -7
  254. data/src/core/lib/iomgr/tcp_windows.cc +5 -5
  255. data/src/core/lib/iomgr/unix_sockets_posix.cc +2 -2
  256. data/src/core/lib/iomgr/wakeup_fd_pipe.cc +2 -2
  257. data/src/core/lib/iomgr/wakeup_fd_posix.cc +15 -12
  258. data/src/core/lib/iomgr/wakeup_fd_posix.h +0 -2
  259. data/src/core/lib/iomgr/work_serializer.h +2 -3
  260. data/src/core/lib/matchers/matchers.cc +6 -3
  261. data/src/core/lib/matchers/matchers.h +2 -0
  262. data/src/core/lib/promise/activity.cc +0 -1
  263. data/src/core/lib/promise/activity.h +7 -13
  264. data/src/core/lib/promise/loop.h +1 -0
  265. data/src/core/lib/promise/promise.h +1 -0
  266. data/src/core/lib/promise/sleep.cc +36 -31
  267. data/src/core/lib/promise/sleep.h +25 -25
  268. data/src/core/lib/resolver/resolver.cc +5 -0
  269. data/src/core/lib/resolver/resolver.h +3 -0
  270. data/src/core/lib/resolver/resolver_factory.h +5 -2
  271. data/src/core/lib/resolver/resolver_registry.cc +2 -9
  272. data/src/core/lib/resolver/resolver_registry.h +12 -1
  273. data/src/core/lib/resolver/server_address.cc +8 -0
  274. data/src/core/lib/resolver/server_address.h +9 -2
  275. data/src/core/lib/resource_quota/memory_quota.cc +18 -60
  276. data/src/core/lib/resource_quota/memory_quota.h +11 -25
  277. data/src/core/lib/security/authorization/authorization_policy_provider.h +7 -0
  278. data/src/core/lib/security/authorization/authorization_policy_provider_vtable.cc +4 -0
  279. data/src/core/lib/security/authorization/evaluate_args.cc +9 -3
  280. data/src/core/lib/security/authorization/evaluate_args.h +6 -3
  281. data/src/core/lib/security/authorization/grpc_authorization_engine.cc +6 -0
  282. data/src/core/lib/security/authorization/grpc_authorization_engine.h +7 -0
  283. data/src/core/lib/security/authorization/grpc_server_authz_filter.cc +12 -0
  284. data/src/core/lib/security/authorization/grpc_server_authz_filter.h +12 -1
  285. data/src/core/lib/security/authorization/matchers.cc +9 -1
  286. data/src/core/lib/security/authorization/matchers.h +7 -0
  287. data/src/core/lib/security/authorization/rbac_policy.cc +5 -0
  288. data/src/core/lib/security/authorization/rbac_policy.h +7 -0
  289. data/src/core/lib/security/context/security_context.cc +5 -2
  290. data/src/core/lib/security/context/security_context.h +14 -2
  291. data/src/core/lib/security/credentials/alts/alts_credentials.cc +4 -2
  292. data/src/core/lib/security/credentials/alts/alts_credentials.h +6 -1
  293. data/src/core/lib/security/credentials/alts/grpc_alts_credentials_client_options.cc +1 -3
  294. data/src/core/lib/security/credentials/alts/grpc_alts_credentials_server_options.cc +1 -4
  295. data/src/core/lib/security/credentials/call_creds_util.cc +8 -0
  296. data/src/core/lib/security/credentials/call_creds_util.h +1 -0
  297. data/src/core/lib/security/credentials/channel_creds_registry.h +6 -1
  298. data/src/core/lib/security/credentials/channel_creds_registry_init.cc +10 -0
  299. data/src/core/lib/security/credentials/composite/composite_credentials.cc +4 -4
  300. data/src/core/lib/security/credentials/composite/composite_credentials.h +16 -2
  301. data/src/core/lib/security/credentials/credentials.cc +4 -8
  302. data/src/core/lib/security/credentials/credentials.h +10 -8
  303. data/src/core/lib/security/credentials/external/aws_external_account_credentials.cc +28 -10
  304. data/src/core/lib/security/credentials/external/aws_external_account_credentials.h +10 -0
  305. data/src/core/lib/security/credentials/external/aws_request_signer.cc +9 -0
  306. data/src/core/lib/security/credentials/external/external_account_credentials.cc +24 -9
  307. data/src/core/lib/security/credentials/external/external_account_credentials.h +11 -0
  308. data/src/core/lib/security/credentials/external/file_external_account_credentials.cc +12 -4
  309. data/src/core/lib/security/credentials/external/file_external_account_credentials.h +6 -0
  310. data/src/core/lib/security/credentials/external/url_external_account_credentials.cc +20 -4
  311. data/src/core/lib/security/credentials/external/url_external_account_credentials.h +10 -0
  312. data/src/core/lib/security/credentials/fake/fake_credentials.cc +8 -6
  313. data/src/core/lib/security/credentials/fake/fake_credentials.h +13 -1
  314. data/src/core/lib/security/credentials/google_default/credentials_generic.cc +1 -0
  315. data/src/core/lib/security/credentials/google_default/google_default_credentials.cc +27 -10
  316. data/src/core/lib/security/credentials/google_default/google_default_credentials.h +10 -1
  317. data/src/core/lib/security/credentials/iam/iam_credentials.cc +9 -3
  318. data/src/core/lib/security/credentials/iam/iam_credentials.h +10 -0
  319. data/src/core/lib/security/credentials/insecure/insecure_credentials.cc +4 -0
  320. data/src/core/lib/security/credentials/insecure/insecure_credentials.h +5 -0
  321. data/src/core/lib/security/credentials/jwt/json_token.cc +5 -2
  322. data/src/core/lib/security/credentials/jwt/json_token.h +2 -2
  323. data/src/core/lib/security/credentials/jwt/jwt_credentials.cc +11 -5
  324. data/src/core/lib/security/credentials/jwt/jwt_credentials.h +14 -0
  325. data/src/core/lib/security/credentials/jwt/jwt_verifier.cc +28 -3
  326. data/src/core/lib/security/credentials/jwt/jwt_verifier.h +4 -2
  327. data/src/core/lib/security/credentials/local/local_credentials.cc +4 -3
  328. data/src/core/lib/security/credentials/local/local_credentials.h +7 -0
  329. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.cc +26 -13
  330. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.h +20 -0
  331. data/src/core/lib/security/credentials/plugin/plugin_credentials.cc +8 -7
  332. data/src/core/lib/security/credentials/plugin/plugin_credentials.h +24 -0
  333. data/src/core/lib/security/credentials/ssl/ssl_credentials.cc +5 -0
  334. data/src/core/lib/security/credentials/ssl/ssl_credentials.h +13 -0
  335. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_distributor.cc +6 -6
  336. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_distributor.h +9 -3
  337. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.cc +29 -10
  338. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.h +9 -4
  339. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_verifier.cc +9 -2
  340. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_verifier.h +6 -7
  341. data/src/core/lib/security/credentials/tls/grpc_tls_credentials_options.cc +4 -5
  342. data/src/core/lib/security/credentials/tls/tls_credentials.cc +7 -2
  343. data/src/core/lib/security/credentials/tls/tls_credentials.h +5 -1
  344. data/src/core/lib/security/credentials/tls/tls_utils.cc +2 -0
  345. data/src/core/lib/security/credentials/tls/tls_utils.h +1 -1
  346. data/src/core/lib/security/credentials/xds/xds_credentials.cc +8 -1
  347. data/src/core/lib/security/credentials/xds/xds_credentials.h +14 -0
  348. data/src/core/lib/security/security_connector/alts/alts_security_connector.cc +22 -2
  349. data/src/core/lib/security/security_connector/alts/alts_security_connector.h +6 -3
  350. data/src/core/lib/security/security_connector/fake/fake_security_connector.cc +17 -1
  351. data/src/core/lib/security/security_connector/fake/fake_security_connector.h +2 -2
  352. data/src/core/lib/security/security_connector/insecure/insecure_security_connector.cc +9 -0
  353. data/src/core/lib/security/security_connector/insecure/insecure_security_connector.h +17 -2
  354. data/src/core/lib/security/security_connector/load_system_roots_fallback.cc +5 -3
  355. data/src/core/lib/security/security_connector/{load_system_roots_linux.cc → load_system_roots_supported.cc} +27 -19
  356. data/src/core/lib/security/security_connector/{load_system_roots_linux.h → load_system_roots_supported.h} +5 -5
  357. data/src/core/lib/security/security_connector/local/local_security_connector.cc +22 -3
  358. data/src/core/lib/security/security_connector/local/local_security_connector.h +6 -2
  359. data/src/core/lib/security/security_connector/security_connector.cc +20 -18
  360. data/src/core/lib/security/security_connector/security_connector.h +18 -6
  361. data/src/core/lib/security/security_connector/ssl/ssl_security_connector.cc +18 -6
  362. data/src/core/lib/security/security_connector/ssl/ssl_security_connector.h +4 -2
  363. data/src/core/lib/security/security_connector/ssl_utils.cc +12 -2
  364. data/src/core/lib/security/security_connector/ssl_utils.h +10 -7
  365. data/src/core/lib/security/security_connector/ssl_utils_config.h +1 -1
  366. data/src/core/lib/security/security_connector/tls/tls_security_connector.cc +21 -13
  367. data/src/core/lib/security/security_connector/tls/tls_security_connector.h +23 -3
  368. data/src/core/lib/security/transport/auth_filters.h +7 -0
  369. data/src/core/lib/security/transport/client_auth_filter.cc +18 -9
  370. data/src/core/lib/security/transport/secure_endpoint.cc +63 -13
  371. data/src/core/lib/security/transport/secure_endpoint.h +4 -3
  372. data/src/core/lib/security/transport/security_handshaker.cc +44 -11
  373. data/src/core/lib/security/transport/security_handshaker.h +4 -0
  374. data/src/core/lib/security/transport/server_auth_filter.cc +26 -4
  375. data/src/core/lib/security/util/json_util.cc +3 -2
  376. data/src/core/lib/security/util/json_util.h +0 -2
  377. data/src/core/lib/service_config/service_config_call_data.h +2 -1
  378. data/src/core/lib/service_config/service_config_impl.cc +6 -6
  379. data/src/core/lib/service_config/service_config_impl.h +1 -3
  380. data/src/core/lib/service_config/service_config_parser.cc +2 -4
  381. data/src/core/lib/slice/slice_buffer.cc +30 -1
  382. data/src/core/lib/slice/slice_buffer.h +37 -6
  383. data/src/core/lib/slice/slice_string_helpers.cc +0 -20
  384. data/src/core/lib/slice/slice_string_helpers.h +0 -4
  385. data/src/core/lib/surface/call.cc +53 -115
  386. data/src/core/lib/surface/call.h +5 -1
  387. data/src/core/lib/surface/channel.h +2 -0
  388. data/src/core/lib/surface/channel_ping.cc +1 -1
  389. data/src/core/lib/surface/completion_queue.cc +15 -14
  390. data/src/core/lib/surface/completion_queue.h +2 -1
  391. data/src/core/lib/surface/init.cc +0 -1
  392. data/src/core/lib/surface/lame_client.cc +1 -1
  393. data/src/core/lib/surface/lame_client.h +1 -1
  394. data/src/core/lib/surface/server.cc +14 -8
  395. data/src/core/lib/surface/server.h +4 -1
  396. data/src/core/lib/surface/validate_metadata.cc +1 -1
  397. data/src/core/lib/surface/version.cc +2 -2
  398. data/src/core/lib/transport/error_utils.cc +13 -7
  399. data/src/core/lib/transport/handshaker.cc +3 -3
  400. data/src/core/lib/transport/http_connect_handshaker.cc +4 -4
  401. data/src/core/lib/transport/tcp_connect_handshaker.cc +2 -2
  402. data/src/core/lib/transport/transport.cc +0 -3
  403. data/src/core/lib/transport/transport.h +20 -14
  404. data/src/core/lib/transport/transport_fwd.h +20 -0
  405. data/src/core/lib/transport/transport_impl.h +1 -0
  406. data/src/core/lib/transport/transport_op_string.cc +9 -9
  407. data/src/core/tsi/alts/handshaker/alts_tsi_handshaker.cc +1 -1
  408. data/src/core/tsi/alts/zero_copy_frame_protector/alts_zero_copy_grpc_protector.cc +9 -1
  409. data/src/core/tsi/fake_transport_security.cc +13 -1
  410. data/src/core/tsi/fake_transport_security.h +6 -0
  411. data/src/core/tsi/ssl_transport_security.cc +1 -1
  412. data/src/core/tsi/transport_security_grpc.cc +3 -2
  413. data/src/core/tsi/transport_security_grpc.h +5 -2
  414. data/src/ruby/ext/grpc/ext-export-truffleruby.clang +2 -0
  415. data/src/ruby/ext/grpc/ext-export-truffleruby.gcc +7 -0
  416. data/src/ruby/ext/grpc/ext-export.clang +1 -0
  417. data/src/ruby/ext/grpc/ext-export.gcc +1 -0
  418. data/src/ruby/ext/grpc/extconf.rb +49 -18
  419. data/src/ruby/ext/grpc/rb_grpc_imports.generated.h +1 -1
  420. data/src/ruby/lib/grpc/errors.rb +1 -1
  421. data/src/ruby/lib/grpc/version.rb +1 -1
  422. data/src/ruby/spec/generic/client_stub_spec.rb +23 -23
  423. data/third_party/abseil-cpp/absl/algorithm/container.h +1 -1
  424. data/third_party/abseil-cpp/absl/base/attributes.h +49 -22
  425. data/third_party/abseil-cpp/absl/base/casts.h +61 -68
  426. data/third_party/abseil-cpp/absl/base/config.h +182 -41
  427. data/third_party/abseil-cpp/absl/base/internal/cycleclock.cc +12 -42
  428. data/third_party/abseil-cpp/absl/base/internal/cycleclock.h +67 -2
  429. data/third_party/abseil-cpp/absl/base/internal/direct_mmap.h +3 -3
  430. data/third_party/abseil-cpp/absl/base/internal/endian.h +17 -62
  431. data/third_party/abseil-cpp/absl/base/internal/fast_type_id.h +2 -0
  432. data/third_party/abseil-cpp/absl/base/internal/invoke.h +54 -0
  433. data/third_party/abseil-cpp/absl/base/internal/prefetch.h +138 -0
  434. data/third_party/abseil-cpp/absl/base/internal/raw_logging.cc +29 -22
  435. data/third_party/abseil-cpp/absl/base/internal/raw_logging.h +13 -12
  436. data/third_party/abseil-cpp/absl/base/internal/spinlock.cc +3 -0
  437. data/third_party/abseil-cpp/absl/base/internal/spinlock.h +8 -0
  438. data/third_party/abseil-cpp/absl/base/internal/spinlock_linux.inc +2 -5
  439. data/third_party/abseil-cpp/absl/base/internal/strerror.cc +88 -0
  440. data/third_party/abseil-cpp/absl/base/internal/strerror.h +39 -0
  441. data/third_party/abseil-cpp/absl/base/internal/sysinfo.cc +0 -1
  442. data/third_party/abseil-cpp/absl/base/internal/thread_identity.cc +2 -1
  443. data/third_party/abseil-cpp/absl/base/internal/unscaledcycleclock.cc +6 -7
  444. data/third_party/abseil-cpp/absl/base/internal/unscaledcycleclock.h +12 -3
  445. data/third_party/abseil-cpp/absl/base/log_severity.cc +28 -0
  446. data/third_party/abseil-cpp/absl/base/log_severity.h +51 -0
  447. data/third_party/abseil-cpp/absl/base/optimization.h +19 -11
  448. data/third_party/abseil-cpp/absl/base/options.h +1 -1
  449. data/third_party/abseil-cpp/absl/base/thread_annotations.h +2 -2
  450. data/third_party/abseil-cpp/absl/container/fixed_array.h +2 -0
  451. data/third_party/abseil-cpp/absl/container/flat_hash_map.h +11 -4
  452. data/third_party/abseil-cpp/absl/container/flat_hash_set.h +15 -9
  453. data/third_party/abseil-cpp/absl/container/inlined_vector.h +20 -9
  454. data/third_party/abseil-cpp/absl/container/internal/common.h +6 -5
  455. data/third_party/abseil-cpp/absl/container/internal/container_memory.h +10 -28
  456. data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler.cc +68 -20
  457. data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler.h +29 -11
  458. data/third_party/abseil-cpp/absl/container/internal/inlined_vector.h +59 -38
  459. data/third_party/abseil-cpp/absl/container/internal/raw_hash_set.cc +4 -0
  460. data/third_party/abseil-cpp/absl/container/internal/raw_hash_set.h +515 -184
  461. data/third_party/abseil-cpp/absl/debugging/internal/address_is_readable.cc +45 -88
  462. data/third_party/abseil-cpp/absl/debugging/internal/elf_mem_image.cc +4 -0
  463. data/third_party/abseil-cpp/absl/debugging/internal/elf_mem_image.h +3 -2
  464. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_aarch64-inl.inc +8 -3
  465. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_arm-inl.inc +8 -3
  466. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_config.h +2 -1
  467. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_powerpc-inl.inc +8 -3
  468. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_riscv-inl.inc +20 -18
  469. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_x86-inl.inc +8 -3
  470. data/third_party/abseil-cpp/absl/debugging/internal/vdso_support.cc +15 -2
  471. data/third_party/abseil-cpp/absl/debugging/symbolize.cc +6 -1
  472. data/third_party/abseil-cpp/absl/debugging/symbolize_elf.inc +46 -7
  473. data/third_party/abseil-cpp/absl/functional/bind_front.h +10 -1
  474. data/third_party/abseil-cpp/absl/functional/function_ref.h +2 -1
  475. data/third_party/abseil-cpp/absl/hash/hash.h +82 -8
  476. data/third_party/abseil-cpp/absl/hash/internal/hash.h +218 -23
  477. data/third_party/abseil-cpp/absl/numeric/bits.h +2 -1
  478. data/third_party/abseil-cpp/absl/numeric/int128.cc +4 -2
  479. data/third_party/abseil-cpp/absl/numeric/int128.h +2 -2
  480. data/third_party/abseil-cpp/absl/profiling/internal/sample_recorder.h +21 -6
  481. data/third_party/abseil-cpp/absl/random/bernoulli_distribution.h +4 -4
  482. data/third_party/abseil-cpp/absl/random/distributions.h +3 -3
  483. data/third_party/abseil-cpp/absl/random/internal/distribution_caller.h +3 -0
  484. data/third_party/abseil-cpp/absl/random/internal/fast_uniform_bits.h +2 -1
  485. data/third_party/abseil-cpp/absl/random/internal/generate_real.h +2 -2
  486. data/third_party/abseil-cpp/absl/random/internal/nonsecure_base.h +59 -48
  487. data/third_party/abseil-cpp/absl/random/internal/pcg_engine.h +1 -1
  488. data/third_party/abseil-cpp/absl/random/internal/randen.h +5 -11
  489. data/third_party/abseil-cpp/absl/random/internal/randen_detect.cc +6 -2
  490. data/third_party/abseil-cpp/absl/random/internal/randen_engine.h +48 -23
  491. data/third_party/abseil-cpp/absl/random/internal/salted_seed_seq.h +24 -26
  492. data/third_party/abseil-cpp/absl/random/internal/traits.h +53 -5
  493. data/third_party/abseil-cpp/absl/random/internal/uniform_helper.h +5 -5
  494. data/third_party/abseil-cpp/absl/random/internal/wide_multiply.h +33 -48
  495. data/third_party/abseil-cpp/absl/random/log_uniform_int_distribution.h +9 -10
  496. data/third_party/abseil-cpp/absl/random/poisson_distribution.h +7 -4
  497. data/third_party/abseil-cpp/absl/random/seed_sequences.h +1 -0
  498. data/third_party/abseil-cpp/absl/random/uniform_int_distribution.h +2 -2
  499. data/third_party/abseil-cpp/absl/random/uniform_real_distribution.h +1 -1
  500. data/third_party/abseil-cpp/absl/random/zipf_distribution.h +4 -3
  501. data/third_party/abseil-cpp/absl/status/internal/status_internal.h +17 -0
  502. data/third_party/abseil-cpp/absl/status/status.cc +174 -2
  503. data/third_party/abseil-cpp/absl/status/status.h +22 -12
  504. data/third_party/abseil-cpp/absl/status/statusor.h +9 -3
  505. data/third_party/abseil-cpp/absl/strings/ascii.h +4 -4
  506. data/third_party/abseil-cpp/absl/strings/cord.cc +194 -913
  507. data/third_party/abseil-cpp/absl/strings/cord.h +202 -81
  508. data/third_party/abseil-cpp/absl/strings/cord_analysis.cc +188 -0
  509. data/third_party/abseil-cpp/absl/strings/cord_analysis.h +44 -0
  510. data/third_party/abseil-cpp/absl/strings/cord_buffer.cc +30 -0
  511. data/third_party/abseil-cpp/absl/strings/cord_buffer.h +572 -0
  512. data/third_party/abseil-cpp/absl/strings/internal/cord_data_edge.h +63 -0
  513. data/third_party/abseil-cpp/absl/strings/internal/cord_internal.cc +20 -32
  514. data/third_party/abseil-cpp/absl/strings/internal/cord_internal.h +123 -88
  515. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree.cc +149 -49
  516. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree.h +44 -59
  517. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree_navigator.cc +3 -1
  518. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree_navigator.h +4 -2
  519. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree_reader.cc +3 -2
  520. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree_reader.h +5 -4
  521. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_consume.cc +7 -74
  522. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_crc.cc +54 -0
  523. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_crc.h +102 -0
  524. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_flat.h +58 -17
  525. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_ring.cc +13 -11
  526. data/third_party/abseil-cpp/absl/strings/internal/cordz_info.cc +11 -38
  527. data/third_party/abseil-cpp/absl/strings/internal/cordz_statistics.h +1 -0
  528. data/third_party/abseil-cpp/absl/strings/internal/cordz_update_tracker.h +4 -2
  529. data/third_party/abseil-cpp/absl/strings/internal/escaping.cc +6 -5
  530. data/third_party/abseil-cpp/absl/strings/internal/ostringstream.cc +1 -1
  531. data/third_party/abseil-cpp/absl/strings/internal/str_format/arg.cc +1 -1
  532. data/third_party/abseil-cpp/absl/strings/internal/str_format/arg.h +1 -1
  533. data/third_party/abseil-cpp/absl/strings/internal/str_format/bind.h +38 -7
  534. data/third_party/abseil-cpp/absl/strings/internal/str_format/checker.h +7 -2
  535. data/third_party/abseil-cpp/absl/strings/internal/str_format/extension.cc +4 -5
  536. data/third_party/abseil-cpp/absl/strings/internal/str_format/extension.h +5 -2
  537. data/third_party/abseil-cpp/absl/strings/internal/str_format/output.h +2 -1
  538. data/third_party/abseil-cpp/absl/strings/internal/str_format/parser.h +4 -2
  539. data/third_party/abseil-cpp/absl/strings/internal/str_join_internal.h +9 -6
  540. data/third_party/abseil-cpp/absl/strings/internal/string_constant.h +10 -2
  541. data/third_party/abseil-cpp/absl/strings/internal/utf8.cc +9 -9
  542. data/third_party/abseil-cpp/absl/strings/numbers.cc +8 -8
  543. data/third_party/abseil-cpp/absl/strings/numbers.h +26 -23
  544. data/third_party/abseil-cpp/absl/strings/str_cat.h +20 -13
  545. data/third_party/abseil-cpp/absl/strings/str_join.h +9 -15
  546. data/third_party/abseil-cpp/absl/strings/str_split.h +1 -2
  547. data/third_party/abseil-cpp/absl/strings/string_view.cc +2 -13
  548. data/third_party/abseil-cpp/absl/strings/string_view.h +3 -2
  549. data/third_party/abseil-cpp/absl/strings/strip.h +8 -6
  550. data/third_party/abseil-cpp/absl/strings/substitute.h +10 -2
  551. data/third_party/abseil-cpp/absl/synchronization/internal/create_thread_identity.cc +9 -6
  552. data/third_party/abseil-cpp/absl/synchronization/internal/create_thread_identity.h +0 -4
  553. data/third_party/abseil-cpp/absl/synchronization/internal/per_thread_sem.cc +0 -4
  554. data/third_party/abseil-cpp/absl/synchronization/internal/per_thread_sem.h +1 -6
  555. data/third_party/abseil-cpp/absl/synchronization/internal/waiter.cc +0 -25
  556. data/third_party/abseil-cpp/absl/synchronization/internal/waiter.h +10 -4
  557. data/third_party/abseil-cpp/absl/synchronization/mutex.cc +75 -40
  558. data/third_party/abseil-cpp/absl/synchronization/mutex.h +17 -9
  559. data/third_party/abseil-cpp/absl/synchronization/notification.h +3 -2
  560. data/third_party/abseil-cpp/absl/time/duration.cc +5 -4
  561. data/third_party/abseil-cpp/absl/time/internal/cctz/include/cctz/civil_time_detail.h +11 -7
  562. data/third_party/abseil-cpp/absl/time/time.h +16 -12
  563. data/third_party/abseil-cpp/absl/types/internal/optional.h +8 -0
  564. data/third_party/abseil-cpp/absl/types/internal/variant.h +3 -3
  565. data/third_party/abseil-cpp/absl/types/optional.h +17 -14
  566. data/third_party/abseil-cpp/absl/types/span.h +2 -1
  567. metadata +39 -15
  568. data/src/core/lib/slice/slice_split.cc +0 -103
  569. data/src/core/lib/slice/slice_split.h +0 -36
  570. data/src/core/lib/transport/byte_stream.cc +0 -165
  571. data/src/core/lib/transport/byte_stream.h +0 -170
  572. data/third_party/abseil-cpp/absl/cleanup/cleanup.h +0 -140
  573. data/third_party/abseil-cpp/absl/cleanup/internal/cleanup.h +0 -100
  574. data/third_party/abseil-cpp/absl/container/internal/have_sse.h +0 -50
@@ -0,0 +1,312 @@
1
+ /*
2
+ *
3
+ * Copyright 2015 gRPC authors.
4
+ *
5
+ * Licensed under the Apache License, Version 2.0 (the "License");
6
+ * you may not use this file except in compliance with the License.
7
+ * You may obtain a copy of the License at
8
+ *
9
+ * http://www.apache.org/licenses/LICENSE-2.0
10
+ *
11
+ * Unless required by applicable law or agreed to in writing, software
12
+ * distributed under the License is distributed on an "AS IS" BASIS,
13
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
+ * See the License for the specific language governing permissions and
15
+ * limitations under the License.
16
+ *
17
+ */
18
+
19
+ #include <grpc/support/port_platform.h>
20
+
21
+ #include "src/core/lib/event_engine/iomgr_engine/timer.h"
22
+
23
+ #include <algorithm>
24
+ #include <atomic>
25
+ #include <limits>
26
+ #include <type_traits>
27
+ #include <utility>
28
+
29
+ #include <grpc/support/cpu.h>
30
+
31
+ #include "src/core/lib/event_engine/iomgr_engine/timer_heap.h"
32
+ #include "src/core/lib/gpr/useful.h"
33
+ #include "src/core/lib/gprpp/time.h"
34
+
35
+ namespace grpc_event_engine {
36
+ namespace iomgr_engine {
37
+
38
+ static const size_t kInvalidHeapIndex = std::numeric_limits<size_t>::max();
39
+ static const double kAddDeadlineScale = 0.33;
40
+ static const double kMinQueueWindowDuration = 0.01;
41
+ static const double kMaxQueueWindowDuration = 1.0;
42
+
43
+ grpc_core::Timestamp TimerList::Shard::ComputeMinDeadline() {
44
+ return heap.is_empty()
45
+ ? queue_deadline_cap + grpc_core::Duration::Epsilon()
46
+ : grpc_core::Timestamp::FromMillisecondsAfterProcessEpoch(
47
+ heap.Top()->deadline);
48
+ }
49
+
50
+ TimerList::Shard::Shard() : stats(1.0 / kAddDeadlineScale, 0.1, 0.5) {}
51
+
52
+ TimerList::TimerList(TimerListHost* host)
53
+ : host_(host),
54
+ num_shards_(grpc_core::Clamp(2 * gpr_cpu_num_cores(), 1u, 32u)),
55
+ min_timer_(host_->Now().milliseconds_after_process_epoch()),
56
+ shards_(new Shard[num_shards_]),
57
+ shard_queue_(new Shard*[num_shards_]) {
58
+ for (size_t i = 0; i < num_shards_; i++) {
59
+ Shard& shard = shards_[i];
60
+ shard.queue_deadline_cap =
61
+ grpc_core::Timestamp::FromMillisecondsAfterProcessEpoch(
62
+ min_timer_.load(std::memory_order_relaxed));
63
+ shard.shard_queue_index = i;
64
+ shard.list.next = shard.list.prev = &shard.list;
65
+ shard.min_deadline = shard.ComputeMinDeadline();
66
+ shard_queue_[i] = &shard;
67
+ }
68
+ }
69
+
70
+ namespace {
71
+ /* returns true if the first element in the list */
72
+ void ListJoin(Timer* head, Timer* timer) {
73
+ timer->next = head;
74
+ timer->prev = head->prev;
75
+ timer->next->prev = timer->prev->next = timer;
76
+ }
77
+
78
+ void ListRemove(Timer* timer) {
79
+ timer->next->prev = timer->prev;
80
+ timer->prev->next = timer->next;
81
+ }
82
+ } // namespace
83
+
84
+ void TimerList::SwapAdjacentShardsInQueue(uint32_t first_shard_queue_index) {
85
+ Shard* temp;
86
+ temp = shard_queue_[first_shard_queue_index];
87
+ shard_queue_[first_shard_queue_index] =
88
+ shard_queue_[first_shard_queue_index + 1];
89
+ shard_queue_[first_shard_queue_index + 1] = temp;
90
+ shard_queue_[first_shard_queue_index]->shard_queue_index =
91
+ first_shard_queue_index;
92
+ shard_queue_[first_shard_queue_index + 1]->shard_queue_index =
93
+ first_shard_queue_index + 1;
94
+ }
95
+
96
+ void TimerList::NoteDeadlineChange(Shard* shard) {
97
+ while (shard->shard_queue_index > 0 &&
98
+ shard->min_deadline <
99
+ shard_queue_[shard->shard_queue_index - 1]->min_deadline) {
100
+ SwapAdjacentShardsInQueue(shard->shard_queue_index - 1);
101
+ }
102
+ while (shard->shard_queue_index < num_shards_ - 1 &&
103
+ shard->min_deadline >
104
+ shard_queue_[shard->shard_queue_index + 1]->min_deadline) {
105
+ SwapAdjacentShardsInQueue(shard->shard_queue_index);
106
+ }
107
+ }
108
+
109
+ void TimerList::TimerInit(Timer* timer, grpc_core::Timestamp deadline,
110
+ experimental::EventEngine::Closure* closure) {
111
+ bool is_first_timer = false;
112
+ Shard* shard = &shards_[grpc_core::HashPointer(timer, num_shards_)];
113
+ timer->closure = closure;
114
+ timer->deadline = deadline.milliseconds_after_process_epoch();
115
+
116
+ #ifndef NDEBUG
117
+ timer->hash_table_next = nullptr;
118
+ #endif
119
+
120
+ {
121
+ grpc_core::MutexLock lock(&shard->mu);
122
+ timer->pending = true;
123
+ grpc_core::Timestamp now = host_->Now();
124
+ if (deadline <= now) {
125
+ deadline = now;
126
+ }
127
+
128
+ shard->stats.AddSample((deadline - now).millis() / 1000.0);
129
+
130
+ if (deadline < shard->queue_deadline_cap) {
131
+ is_first_timer = shard->heap.Add(timer);
132
+ } else {
133
+ timer->heap_index = kInvalidHeapIndex;
134
+ ListJoin(&shard->list, timer);
135
+ }
136
+ }
137
+
138
+ /* Deadline may have decreased, we need to adjust the main queue. Note
139
+ that there is a potential racy unlocked region here. There could be a
140
+ reordering of multiple TimerInit calls, at this point, but the < test
141
+ below should ensure that we err on the side of caution. There could
142
+ also be a race with TimerCheck, which might beat us to the lock. In
143
+ that case, it is possible that the timer that we added will have already
144
+ run by the time we hold the lock, but that too is a safe error.
145
+ Finally, it's possible that the TimerCheck that intervened failed to
146
+ trigger the new timer because the min_deadline hadn't yet been reduced.
147
+ In that case, the timer will simply have to wait for the next
148
+ TimerCheck. */
149
+ if (is_first_timer) {
150
+ grpc_core::MutexLock lock(&mu_);
151
+ if (deadline < shard->min_deadline) {
152
+ grpc_core::Timestamp old_min_deadline = shard_queue_[0]->min_deadline;
153
+ shard->min_deadline = deadline;
154
+ NoteDeadlineChange(shard);
155
+ if (shard->shard_queue_index == 0 && deadline < old_min_deadline) {
156
+ min_timer_.store(deadline.milliseconds_after_process_epoch(),
157
+ std::memory_order_relaxed);
158
+ host_->Kick();
159
+ }
160
+ }
161
+ }
162
+ }
163
+
164
+ bool TimerList::TimerCancel(Timer* timer) {
165
+ Shard* shard = &shards_[grpc_core::HashPointer(timer, num_shards_)];
166
+ grpc_core::MutexLock lock(&shard->mu);
167
+
168
+ if (timer->pending) {
169
+ timer->pending = false;
170
+ if (timer->heap_index == kInvalidHeapIndex) {
171
+ ListRemove(timer);
172
+ } else {
173
+ shard->heap.Remove(timer);
174
+ }
175
+ return true;
176
+ }
177
+
178
+ return false;
179
+ }
180
+
181
+ /* Rebalances the timer shard by computing a new 'queue_deadline_cap' and moving
182
+ all relevant timers in shard->list (i.e timers with deadlines earlier than
183
+ 'queue_deadline_cap') into into shard->heap.
184
+ Returns 'true' if shard->heap has at least ONE element */
185
+ bool TimerList::Shard::RefillHeap(grpc_core::Timestamp now) {
186
+ /* Compute the new queue window width and bound by the limits: */
187
+ double computed_deadline_delta = stats.UpdateAverage() * kAddDeadlineScale;
188
+ double deadline_delta =
189
+ grpc_core::Clamp(computed_deadline_delta, kMinQueueWindowDuration,
190
+ kMaxQueueWindowDuration);
191
+ Timer *timer, *next;
192
+
193
+ /* Compute the new cap and put all timers under it into the queue: */
194
+ queue_deadline_cap = std::max(now, queue_deadline_cap) +
195
+ grpc_core::Duration::FromSecondsAsDouble(deadline_delta);
196
+
197
+ for (timer = list.next; timer != &list; timer = next) {
198
+ next = timer->next;
199
+ auto timer_deadline =
200
+ grpc_core::Timestamp::FromMillisecondsAfterProcessEpoch(
201
+ timer->deadline);
202
+
203
+ if (timer_deadline < queue_deadline_cap) {
204
+ ListRemove(timer);
205
+ heap.Add(timer);
206
+ }
207
+ }
208
+ return !heap.is_empty();
209
+ }
210
+
211
+ /* This pops the next non-cancelled timer with deadline <= now from the
212
+ queue, or returns NULL if there isn't one. */
213
+ Timer* TimerList::Shard::PopOne(grpc_core::Timestamp now) {
214
+ Timer* timer;
215
+ for (;;) {
216
+ if (heap.is_empty()) {
217
+ if (now < queue_deadline_cap) return nullptr;
218
+ if (!RefillHeap(now)) return nullptr;
219
+ }
220
+ timer = heap.Top();
221
+ auto timer_deadline =
222
+ grpc_core::Timestamp::FromMillisecondsAfterProcessEpoch(
223
+ timer->deadline);
224
+ if (timer_deadline > now) return nullptr;
225
+ timer->pending = false;
226
+ heap.Pop();
227
+ return timer;
228
+ }
229
+ }
230
+
231
+ void TimerList::Shard::PopTimers(
232
+ grpc_core::Timestamp now, grpc_core::Timestamp* new_min_deadline,
233
+ std::vector<experimental::EventEngine::Closure*>* out) {
234
+ grpc_core::MutexLock lock(&mu);
235
+ while (Timer* timer = PopOne(now)) {
236
+ out->push_back(timer->closure);
237
+ }
238
+ *new_min_deadline = ComputeMinDeadline();
239
+ }
240
+
241
+ std::vector<experimental::EventEngine::Closure*> TimerList::FindExpiredTimers(
242
+ grpc_core::Timestamp now, grpc_core::Timestamp* next) {
243
+ grpc_core::Timestamp min_timer =
244
+ grpc_core::Timestamp::FromMillisecondsAfterProcessEpoch(
245
+ min_timer_.load(std::memory_order_relaxed));
246
+
247
+ std::vector<experimental::EventEngine::Closure*> done;
248
+ if (now < min_timer) {
249
+ if (next != nullptr) *next = std::min(*next, min_timer);
250
+ return done;
251
+ }
252
+
253
+ grpc_core::MutexLock lock(&mu_);
254
+
255
+ while (shard_queue_[0]->min_deadline < now ||
256
+ (now != grpc_core::Timestamp::InfFuture() &&
257
+ shard_queue_[0]->min_deadline == now)) {
258
+ grpc_core::Timestamp new_min_deadline;
259
+
260
+ /* For efficiency, we pop as many available timers as we can from the
261
+ shard. This may violate perfect timer deadline ordering, but that
262
+ shouldn't be a big deal because we don't make ordering guarantees. */
263
+ shard_queue_[0]->PopTimers(now, &new_min_deadline, &done);
264
+
265
+ /* An TimerInit() on the shard could intervene here, adding a new
266
+ timer that is earlier than new_min_deadline. However,
267
+ TimerInit() will block on the mutex before it can call
268
+ set_min_deadline, so this one will complete first and then the Addtimer
269
+ will reduce the min_deadline (perhaps unnecessarily). */
270
+ shard_queue_[0]->min_deadline = new_min_deadline;
271
+ NoteDeadlineChange(shard_queue_[0]);
272
+ }
273
+
274
+ if (next) {
275
+ *next = std::min(*next, shard_queue_[0]->min_deadline);
276
+ }
277
+
278
+ min_timer_.store(
279
+ shard_queue_[0]->min_deadline.milliseconds_after_process_epoch(),
280
+ std::memory_order_relaxed);
281
+
282
+ return done;
283
+ }
284
+
285
+ absl::optional<std::vector<experimental::EventEngine::Closure*>>
286
+ TimerList::TimerCheck(grpc_core::Timestamp* next) {
287
+ // prelude
288
+ grpc_core::Timestamp now = host_->Now();
289
+
290
+ /* fetch from a thread-local first: this avoids contention on a globally
291
+ mutable cacheline in the common case */
292
+ grpc_core::Timestamp min_timer =
293
+ grpc_core::Timestamp::FromMillisecondsAfterProcessEpoch(
294
+ min_timer_.load(std::memory_order_relaxed));
295
+
296
+ if (now < min_timer) {
297
+ if (next != nullptr) {
298
+ *next = std::min(*next, min_timer);
299
+ }
300
+ return std::vector<experimental::EventEngine::Closure*>();
301
+ }
302
+
303
+ if (!checker_mu_.TryLock()) return absl::nullopt;
304
+ std::vector<experimental::EventEngine::Closure*> run =
305
+ FindExpiredTimers(now, next);
306
+ checker_mu_.Unlock();
307
+
308
+ return std::move(run);
309
+ }
310
+
311
+ } // namespace iomgr_engine
312
+ } // namespace grpc_event_engine
@@ -0,0 +1,193 @@
1
+ /*
2
+ *
3
+ * Copyright 2015 gRPC authors.
4
+ *
5
+ * Licensed under the Apache License, Version 2.0 (the "License");
6
+ * you may not use this file except in compliance with the License.
7
+ * You may obtain a copy of the License at
8
+ *
9
+ * http://www.apache.org/licenses/LICENSE-2.0
10
+ *
11
+ * Unless required by applicable law or agreed to in writing, software
12
+ * distributed under the License is distributed on an "AS IS" BASIS,
13
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
+ * See the License for the specific language governing permissions and
15
+ * limitations under the License.
16
+ *
17
+ */
18
+
19
+ #ifndef GRPC_CORE_LIB_EVENT_ENGINE_IOMGR_ENGINE_TIMER_H
20
+ #define GRPC_CORE_LIB_EVENT_ENGINE_IOMGR_ENGINE_TIMER_H
21
+
22
+ #include <grpc/support/port_platform.h>
23
+
24
+ #include <stddef.h>
25
+
26
+ #include <atomic>
27
+ #include <cstdint>
28
+ #include <memory>
29
+ #include <vector>
30
+
31
+ #include "absl/base/thread_annotations.h"
32
+ #include "absl/types/optional.h"
33
+
34
+ #include <grpc/event_engine/event_engine.h>
35
+
36
+ #include "src/core/lib/event_engine/iomgr_engine/time_averaged_stats.h"
37
+ #include "src/core/lib/event_engine/iomgr_engine/timer_heap.h"
38
+ #include "src/core/lib/gprpp/sync.h"
39
+ #include "src/core/lib/gprpp/time.h"
40
+
41
+ namespace grpc_event_engine {
42
+ namespace iomgr_engine {
43
+
44
+ struct Timer {
45
+ int64_t deadline;
46
+ // kInvalidHeapIndex if not in heap.
47
+ size_t heap_index;
48
+ bool pending;
49
+ struct Timer* next;
50
+ struct Timer* prev;
51
+ experimental::EventEngine::Closure* closure;
52
+ #ifndef NDEBUG
53
+ struct Timer* hash_table_next;
54
+ #endif
55
+
56
+ grpc_event_engine::experimental::EventEngine::TaskHandle task_handle;
57
+ };
58
+
59
+ // Dependency injection: allow tests and/or TimerManager to inject
60
+ // their own implementations of Now, Kick.
61
+ class TimerListHost {
62
+ public:
63
+ // Return the current timestamp.
64
+ // Abstracted so that tests can be run deterministically.
65
+ virtual grpc_core::Timestamp Now() = 0;
66
+ // Wake up a thread to check for timers.
67
+ virtual void Kick() = 0;
68
+
69
+ protected:
70
+ ~TimerListHost() = default;
71
+ };
72
+
73
+ class TimerList {
74
+ public:
75
+ explicit TimerList(TimerListHost* host);
76
+
77
+ TimerList(const TimerList&) = delete;
78
+ TimerList& operator=(const TimerList&) = delete;
79
+
80
+ /* Initialize *timer. When expired or canceled, closure will be called with
81
+ error set to indicate if it expired (GRPC_ERROR_NONE) or was canceled
82
+ (GRPC_ERROR_CANCELLED). *closure is guaranteed to be called exactly once, and
83
+ application code should check the error to determine how it was invoked. The
84
+ application callback is also responsible for maintaining information about
85
+ when to free up any user-level state. Behavior is undefined for a deadline of
86
+ grpc_core::Timestamp::InfFuture(). */
87
+ void TimerInit(Timer* timer, grpc_core::Timestamp deadline,
88
+ experimental::EventEngine::Closure* closure);
89
+
90
+ /* Note that there is no timer destroy function. This is because the
91
+ timer is a one-time occurrence with a guarantee that the callback will
92
+ be called exactly once, either at expiration or cancellation. Thus, all
93
+ the internal timer event management state is destroyed just before
94
+ that callback is invoked. If the user has additional state associated with
95
+ the timer, the user is responsible for determining when it is safe to
96
+ destroy that state. */
97
+
98
+ /* Cancel an *timer.
99
+ There are three cases:
100
+ 1. We normally cancel the timer
101
+ 2. The timer has already run
102
+ 3. We can't cancel the timer because it is "in flight".
103
+
104
+ In all of these cases, the cancellation is still considered successful.
105
+ They are essentially distinguished in that the timer_cb will be run
106
+ exactly once from either the cancellation (with error GRPC_ERROR_CANCELLED)
107
+ or from the activation (with error GRPC_ERROR_NONE).
108
+
109
+ Note carefully that the callback function MAY occur in the same callstack
110
+ as grpc_timer_cancel. It's expected that most timers will be cancelled
111
+ (their primary use is to implement deadlines), and so this code is
112
+ optimized such that cancellation costs as little as possible. Making
113
+ callbacks run inline matches this aim.
114
+
115
+ Requires: cancel() must happen after init() on a given timer */
116
+ bool TimerCancel(Timer* timer) GRPC_MUST_USE_RESULT;
117
+
118
+ /* iomgr internal api for dealing with timers */
119
+
120
+ /* Check for timers to be run, and return them.
121
+ Return nullopt if timers could not be checked due to contention with
122
+ another thread checking.
123
+ Return a vector of closures that *must* be run otherwise.
124
+ If next is non-null, TRY to update *next with the next running timer
125
+ IF that timer occurs before *next current value.
126
+ *next is never guaranteed to be updated on any given execution; however,
127
+ with high probability at least one thread in the system will see an update
128
+ at any time slice. */
129
+ absl::optional<std::vector<experimental::EventEngine::Closure*>> TimerCheck(
130
+ grpc_core::Timestamp* next);
131
+
132
+ private:
133
+ /* A "timer shard". Contains a 'heap' and a 'list' of timers. All timers with
134
+ * deadlines earlier than 'queue_deadline_cap' are maintained in the heap and
135
+ * others are maintained in the list (unordered). This helps to keep the
136
+ * number of elements in the heap low.
137
+ *
138
+ * The 'queue_deadline_cap' gets recomputed periodically based on the timer
139
+ * stats maintained in 'stats' and the relevant timers are then moved from the
140
+ * 'list' to 'heap'.
141
+ */
142
+ struct Shard {
143
+ Shard();
144
+
145
+ grpc_core::Timestamp ComputeMinDeadline() ABSL_EXCLUSIVE_LOCKS_REQUIRED(mu);
146
+ bool RefillHeap(grpc_core::Timestamp now) ABSL_EXCLUSIVE_LOCKS_REQUIRED(mu);
147
+ Timer* PopOne(grpc_core::Timestamp now) ABSL_EXCLUSIVE_LOCKS_REQUIRED(mu);
148
+ void PopTimers(grpc_core::Timestamp now,
149
+ grpc_core::Timestamp* new_min_deadline,
150
+ std::vector<experimental::EventEngine::Closure*>* out)
151
+ ABSL_LOCKS_EXCLUDED(mu);
152
+
153
+ grpc_core::Mutex mu;
154
+ TimeAveragedStats stats ABSL_GUARDED_BY(mu);
155
+ /* All and only timers with deadlines < this will be in the heap. */
156
+ grpc_core::Timestamp queue_deadline_cap ABSL_GUARDED_BY(mu);
157
+ /* The deadline of the next timer due in this shard. */
158
+ grpc_core::Timestamp min_deadline ABSL_GUARDED_BY(&TimerList::mu_);
159
+ /* Index of this timer_shard in the g_shard_queue. */
160
+ uint32_t shard_queue_index ABSL_GUARDED_BY(&TimerList::mu_);
161
+ /* This holds all timers with deadlines < queue_deadline_cap. Timers in this
162
+ list have the top bit of their deadline set to 0. */
163
+ TimerHeap heap ABSL_GUARDED_BY(mu);
164
+ /* This holds timers whose deadline is >= queue_deadline_cap. */
165
+ Timer list ABSL_GUARDED_BY(mu);
166
+ };
167
+
168
+ void SwapAdjacentShardsInQueue(uint32_t first_shard_queue_index)
169
+ ABSL_EXCLUSIVE_LOCKS_REQUIRED(mu_);
170
+ void NoteDeadlineChange(Shard* shard) ABSL_EXCLUSIVE_LOCKS_REQUIRED(mu_);
171
+ std::vector<experimental::EventEngine::Closure*> FindExpiredTimers(
172
+ grpc_core::Timestamp now, grpc_core::Timestamp* next);
173
+
174
+ TimerListHost* const host_;
175
+ const size_t num_shards_;
176
+ grpc_core::Mutex mu_;
177
+ /* The deadline of the next timer due across all timer shards */
178
+ std::atomic<uint64_t> min_timer_;
179
+ /* Allow only one FindExpiredTimers at once (used as a TryLock, protects no
180
+ * fields but ensures limits on concurrency) */
181
+ grpc_core::Mutex checker_mu_;
182
+ /* Array of timer shards. Whenever a timer (Timer *) is added, its address
183
+ * is hashed to select the timer shard to add the timer to */
184
+ const std::unique_ptr<Shard[]> shards_;
185
+ /* Maintains a sorted list of timer shards (sorted by their min_deadline, i.e
186
+ * the deadline of the next timer in each shard). */
187
+ const std::unique_ptr<Shard*[]> shard_queue_ ABSL_GUARDED_BY(mu_);
188
+ };
189
+
190
+ } // namespace iomgr_engine
191
+ } // namespace grpc_event_engine
192
+
193
+ #endif /* GRPC_CORE_LIB_EVENT_ENGINE_IOMGR_ENGINE_TIMER_H */
@@ -0,0 +1,107 @@
1
+ /*
2
+ *
3
+ * Copyright 2015 gRPC authors.
4
+ *
5
+ * Licensed under the Apache License, Version 2.0 (the "License");
6
+ * you may not use this file except in compliance with the License.
7
+ * You may obtain a copy of the License at
8
+ *
9
+ * http://www.apache.org/licenses/LICENSE-2.0
10
+ *
11
+ * Unless required by applicable law or agreed to in writing, software
12
+ * distributed under the License is distributed on an "AS IS" BASIS,
13
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
+ * See the License for the specific language governing permissions and
15
+ * limitations under the License.
16
+ *
17
+ */
18
+
19
+ #include <grpc/support/port_platform.h>
20
+
21
+ #include "src/core/lib/event_engine/iomgr_engine/timer_heap.h"
22
+
23
+ #include <stdint.h>
24
+
25
+ #include <algorithm>
26
+
27
+ #include "src/core/lib/event_engine/iomgr_engine/timer.h"
28
+
29
+ namespace grpc_event_engine {
30
+ namespace iomgr_engine {
31
+
32
+ /* Adjusts a heap so as to move a hole at position i closer to the root,
33
+ until a suitable position is found for element t. Then, copies t into that
34
+ position. This functor is called each time immediately after modifying a
35
+ value in the underlying container, with the offset of the modified element as
36
+ its argument. */
37
+ void TimerHeap::AdjustUpwards(size_t i, Timer* t) {
38
+ while (i > 0) {
39
+ size_t parent = (i - 1) / 2;
40
+ if (timers_[parent]->deadline <= t->deadline) break;
41
+ timers_[i] = timers_[parent];
42
+ timers_[i]->heap_index = i;
43
+ i = parent;
44
+ }
45
+ timers_[i] = t;
46
+ t->heap_index = i;
47
+ }
48
+
49
+ /* Adjusts a heap so as to move a hole at position i farther away from the root,
50
+ until a suitable position is found for element t. Then, copies t into that
51
+ position. */
52
+ void TimerHeap::AdjustDownwards(size_t i, Timer* t) {
53
+ for (;;) {
54
+ size_t left_child = 1 + 2 * i;
55
+ if (left_child >= timers_.size()) break;
56
+ size_t right_child = left_child + 1;
57
+ size_t next_i =
58
+ right_child < timers_.size() &&
59
+ timers_[left_child]->deadline > timers_[right_child]->deadline
60
+ ? right_child
61
+ : left_child;
62
+ if (t->deadline <= timers_[next_i]->deadline) break;
63
+ timers_[i] = timers_[next_i];
64
+ timers_[i]->heap_index = i;
65
+ i = next_i;
66
+ }
67
+ timers_[i] = t;
68
+ t->heap_index = i;
69
+ }
70
+
71
+ void TimerHeap::NoteChangedPriority(Timer* timer) {
72
+ uint32_t i = timer->heap_index;
73
+ uint32_t parent = static_cast<uint32_t>((static_cast<int>(i) - 1) / 2);
74
+ if (timers_[parent]->deadline > timer->deadline) {
75
+ AdjustUpwards(i, timer);
76
+ } else {
77
+ AdjustDownwards(i, timer);
78
+ }
79
+ }
80
+
81
+ bool TimerHeap::Add(Timer* timer) {
82
+ timer->heap_index = timers_.size();
83
+ timers_.push_back(timer);
84
+ AdjustUpwards(timer->heap_index, timer);
85
+ return timer->heap_index == 0;
86
+ }
87
+
88
+ void TimerHeap::Remove(Timer* timer) {
89
+ uint32_t i = timer->heap_index;
90
+ if (i == timers_.size() - 1) {
91
+ timers_.pop_back();
92
+ return;
93
+ }
94
+ timers_[i] = timers_[timers_.size() - 1];
95
+ timers_[i]->heap_index = i;
96
+ timers_.pop_back();
97
+ NoteChangedPriority(timers_[i]);
98
+ }
99
+
100
+ bool TimerHeap::is_empty() { return timers_.empty(); }
101
+
102
+ Timer* TimerHeap::Top() { return timers_[0]; }
103
+
104
+ void TimerHeap::Pop() { Remove(Top()); }
105
+
106
+ } // namespace iomgr_engine
107
+ } // namespace grpc_event_engine
@@ -0,0 +1,56 @@
1
+ /*
2
+ *
3
+ * Copyright 2015 gRPC authors.
4
+ *
5
+ * Licensed under the Apache License, Version 2.0 (the "License");
6
+ * you may not use this file except in compliance with the License.
7
+ * You may obtain a copy of the License at
8
+ *
9
+ * http://www.apache.org/licenses/LICENSE-2.0
10
+ *
11
+ * Unless required by applicable law or agreed to in writing, software
12
+ * distributed under the License is distributed on an "AS IS" BASIS,
13
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
+ * See the License for the specific language governing permissions and
15
+ * limitations under the License.
16
+ *
17
+ */
18
+
19
+ #ifndef GRPC_CORE_LIB_EVENT_ENGINE_IOMGR_ENGINE_TIMER_HEAP_H
20
+ #define GRPC_CORE_LIB_EVENT_ENGINE_IOMGR_ENGINE_TIMER_HEAP_H
21
+
22
+ #include <grpc/support/port_platform.h>
23
+
24
+ #include <cstddef>
25
+ #include <vector>
26
+
27
+ namespace grpc_event_engine {
28
+ namespace iomgr_engine {
29
+
30
+ struct Timer;
31
+
32
+ class TimerHeap {
33
+ public:
34
+ /* return true if the new timer is the first timer in the heap */
35
+ bool Add(Timer* timer);
36
+
37
+ void Remove(Timer* timer);
38
+ Timer* Top();
39
+ void Pop();
40
+
41
+ bool is_empty();
42
+
43
+ const std::vector<Timer*>& TestOnlyGetTimers() const { return timers_; }
44
+
45
+ private:
46
+ void AdjustUpwards(size_t i, Timer* t);
47
+ void AdjustDownwards(size_t i, Timer* t);
48
+ void NoteChangedPriority(Timer* timer);
49
+
50
+ std::vector<Timer*> timers_;
51
+ };
52
+
53
+ } // namespace iomgr_engine
54
+ } // namespace grpc_event_engine
55
+
56
+ #endif /* GRPC_CORE_LIB_EVENT_ENGINE_IOMGR_ENGINE_TIMER_HEAP_H */