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.
- checksums.yaml +4 -4
- data/Makefile +105 -47
- data/include/grpc/compression.h +1 -1
- data/include/grpc/event_engine/event_engine.h +20 -11
- data/include/grpc/event_engine/slice_buffer.h +8 -2
- data/include/grpc/grpc.h +3 -3
- data/include/grpc/impl/codegen/compression_types.h +2 -1
- data/include/grpc/impl/codegen/connectivity_state.h +2 -1
- data/include/grpc/impl/codegen/gpr_types.h +2 -1
- data/include/grpc/impl/codegen/grpc_types.h +2 -1
- data/include/grpc/impl/codegen/port_platform.h +6 -3
- data/src/core/ext/filters/census/grpc_context.cc +3 -0
- data/src/core/ext/filters/channel_idle/channel_idle_filter.cc +17 -5
- data/src/core/ext/filters/channel_idle/channel_idle_filter.h +16 -0
- data/src/core/ext/filters/channel_idle/idle_filter_state.h +2 -0
- data/src/core/ext/filters/client_channel/backup_poller.cc +3 -1
- data/src/core/ext/filters/client_channel/channel_connectivity.cc +2 -2
- data/src/core/ext/filters/client_channel/client_channel.cc +51 -65
- data/src/core/ext/filters/client_channel/client_channel.h +19 -4
- data/src/core/ext/filters/client_channel/config_selector.h +1 -1
- data/src/core/ext/filters/client_channel/connector.h +1 -1
- data/src/core/ext/filters/client_channel/dynamic_filters.cc +6 -4
- data/src/core/ext/filters/client_channel/dynamic_filters.h +1 -1
- data/src/core/ext/filters/client_channel/lb_policy/address_filtering.cc +1 -1
- data/src/core/ext/filters/client_channel/lb_policy/grpclb/client_load_reporting_filter.cc +2 -2
- data/src/core/ext/filters/client_channel/lb_policy/grpclb/client_load_reporting_filter.h +1 -0
- data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb.cc +73 -43
- data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_balancer_addresses.cc +1 -1
- data/src/core/ext/filters/client_channel/lb_policy/oob_backend_metric.cc +0 -1
- data/src/core/ext/filters/client_channel/lb_policy/outlier_detection/outlier_detection.cc +33 -35
- data/src/core/ext/filters/client_channel/lb_policy/pick_first/pick_first.cc +106 -112
- data/src/core/ext/filters/client_channel/lb_policy/priority/priority.cc +91 -42
- data/src/core/ext/filters/client_channel/lb_policy/ring_hash/ring_hash.cc +177 -138
- data/src/core/ext/filters/client_channel/lb_policy/ring_hash/ring_hash.h +4 -1
- data/src/core/ext/filters/client_channel/lb_policy/rls/rls.cc +47 -44
- data/src/core/ext/filters/client_channel/lb_policy/round_robin/round_robin.cc +118 -103
- data/src/core/ext/filters/client_channel/lb_policy/subchannel_list.h +83 -78
- data/src/core/ext/filters/client_channel/lb_policy/weighted_target/weighted_target.cc +57 -67
- data/src/core/ext/filters/client_channel/lb_policy/xds/cds.cc +2 -2
- data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_impl.cc +5 -7
- data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_manager.cc +13 -17
- data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_resolver.cc +3 -3
- data/src/core/ext/filters/client_channel/lb_policy.h +0 -7
- data/src/core/ext/filters/client_channel/lb_policy_registry.cc +3 -5
- data/src/core/ext/filters/client_channel/proxy_mapper_registry.cc +0 -1
- data/src/core/ext/filters/client_channel/resolver/binder/binder_resolver.cc +3 -1
- data/src/core/ext/filters/client_channel/resolver/dns/c_ares/dns_resolver_ares.cc +6 -6
- data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver_windows.cc +5 -5
- data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.cc +10 -5
- data/src/core/ext/filters/client_channel/resolver/dns/native/dns_resolver.cc +12 -3
- data/src/core/ext/filters/client_channel/resolver/fake/fake_resolver.cc +5 -5
- data/src/core/ext/filters/client_channel/resolver/google_c2p/google_c2p_resolver.cc +3 -4
- data/src/core/ext/filters/client_channel/resolver/polling_resolver.cc +1 -1
- data/src/core/ext/filters/client_channel/resolver/sockaddr/sockaddr_resolver.cc +1 -0
- data/src/core/ext/filters/client_channel/resolver/xds/xds_resolver.cc +24 -15
- data/src/core/ext/filters/client_channel/resolver/xds/xds_resolver.h +3 -1
- data/src/core/ext/filters/client_channel/resolver_result_parsing.cc +7 -7
- data/src/core/ext/filters/client_channel/retry_filter.cc +35 -36
- data/src/core/ext/filters/client_channel/retry_filter.h +1 -0
- data/src/core/ext/filters/client_channel/retry_service_config.cc +4 -4
- data/src/core/ext/filters/client_channel/service_config_channel_arg_filter.cc +2 -1
- data/src/core/ext/filters/client_channel/subchannel.cc +53 -50
- data/src/core/ext/filters/client_channel/subchannel.h +6 -22
- data/src/core/ext/filters/client_channel/subchannel_interface.h +10 -18
- data/src/core/ext/filters/client_channel/subchannel_stream_client.cc +12 -97
- data/src/core/ext/filters/client_channel/subchannel_stream_client.h +5 -9
- data/src/core/ext/filters/deadline/deadline_filter.cc +12 -7
- data/src/core/ext/filters/deadline/deadline_filter.h +8 -1
- data/src/core/ext/filters/fault_injection/fault_injection_filter.cc +21 -2
- data/src/core/ext/filters/fault_injection/fault_injection_filter.h +8 -3
- data/src/core/ext/filters/fault_injection/service_config_parser.cc +7 -4
- data/src/core/ext/filters/fault_injection/service_config_parser.h +17 -3
- data/src/core/ext/filters/http/client/http_client_filter.cc +16 -5
- data/src/core/ext/filters/http/client/http_client_filter.h +8 -1
- data/src/core/ext/filters/http/client_authority_filter.cc +11 -10
- data/src/core/ext/filters/http/client_authority_filter.h +5 -2
- data/src/core/ext/filters/http/http_filters_plugin.cc +9 -1
- data/src/core/ext/filters/http/message_compress/message_compress_filter.cc +64 -187
- data/src/core/ext/filters/http/message_compress/message_compress_filter.h +1 -2
- data/src/core/ext/filters/http/message_compress/message_decompress_filter.cc +42 -106
- data/src/core/ext/filters/http/message_compress/message_decompress_filter.h +1 -0
- data/src/core/ext/filters/http/server/http_server_filter.cc +16 -9
- data/src/core/ext/filters/http/server/http_server_filter.h +6 -1
- data/src/core/ext/filters/message_size/message_size_filter.cc +25 -15
- data/src/core/ext/filters/message_size/message_size_filter.h +13 -0
- data/src/core/ext/filters/rbac/rbac_filter.cc +14 -3
- data/src/core/ext/filters/rbac/rbac_filter.h +8 -0
- data/src/core/ext/filters/rbac/rbac_service_config_parser.cc +13 -2
- data/src/core/ext/filters/rbac/rbac_service_config_parser.h +14 -2
- data/src/core/ext/filters/server_config_selector/server_config_selector.cc +1 -0
- data/src/core/ext/filters/server_config_selector/server_config_selector.h +9 -0
- data/src/core/ext/filters/server_config_selector/server_config_selector_filter.cc +22 -2
- data/src/core/ext/filters/server_config_selector/server_config_selector_filter.h +1 -0
- data/src/core/ext/transport/chttp2/client/chttp2_connector.cc +4 -4
- data/src/core/ext/transport/chttp2/server/chttp2_server.cc +15 -15
- data/src/core/ext/transport/chttp2/transport/chttp2_transport.cc +196 -476
- data/src/core/ext/transport/chttp2/transport/chttp2_transport.h +1 -1
- data/src/core/ext/transport/chttp2/transport/flow_control.cc +141 -261
- data/src/core/ext/transport/chttp2/transport/flow_control.h +176 -289
- data/src/core/ext/transport/chttp2/transport/frame_data.cc +57 -215
- data/src/core/ext/transport/chttp2/transport/frame_data.h +10 -36
- data/src/core/ext/transport/chttp2/transport/frame_settings.cc +0 -41
- data/src/core/ext/transport/chttp2/transport/frame_window_update.cc +7 -12
- data/src/core/ext/transport/chttp2/transport/hpack_parser.cc +7 -6
- data/src/core/ext/transport/chttp2/transport/hpack_parser_table.cc +0 -2
- data/src/core/ext/transport/chttp2/transport/internal.h +9 -111
- data/src/core/ext/transport/chttp2/transport/parsing.cc +51 -38
- data/src/core/ext/transport/chttp2/transport/stream_lists.cc +0 -4
- data/src/core/ext/transport/chttp2/transport/writing.cc +18 -21
- data/src/core/ext/transport/inproc/inproc_plugin.cc +0 -1
- data/src/core/ext/transport/inproc/inproc_transport.cc +85 -81
- data/src/core/ext/transport/inproc/inproc_transport.h +3 -1
- data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/ring_hash/v3/ring_hash.upb.c +52 -0
- data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/ring_hash/v3/ring_hash.upb.h +164 -0
- data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/wrr_locality/v3/wrr_locality.upb.c +46 -0
- data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/wrr_locality/v3/wrr_locality.upb.h +94 -0
- data/src/core/ext/xds/certificate_provider_factory.h +6 -1
- data/src/core/ext/xds/certificate_provider_registry.cc +8 -8
- data/src/core/ext/xds/certificate_provider_registry.h +3 -1
- data/src/core/ext/xds/certificate_provider_store.cc +2 -0
- data/src/core/ext/xds/certificate_provider_store.h +9 -0
- data/src/core/ext/xds/file_watcher_certificate_provider_factory.cc +9 -0
- data/src/core/ext/xds/file_watcher_certificate_provider_factory.h +8 -0
- data/src/core/ext/xds/upb_utils.h +1 -2
- data/src/core/ext/xds/xds_api.cc +16 -18
- data/src/core/ext/xds/xds_api.h +12 -5
- data/src/core/ext/xds/xds_bootstrap.cc +37 -24
- data/src/core/ext/xds/xds_bootstrap.h +9 -11
- data/src/core/ext/xds/xds_certificate_provider.cc +12 -3
- data/src/core/ext/xds/xds_certificate_provider.h +16 -1
- data/src/core/ext/xds/xds_channel_stack_modifier.cc +9 -0
- data/src/core/ext/xds/xds_channel_stack_modifier.h +5 -1
- data/src/core/ext/xds/xds_client.cc +71 -22
- data/src/core/ext/xds/xds_client.h +17 -3
- data/src/core/ext/xds/xds_client_stats.cc +3 -4
- data/src/core/ext/xds/xds_client_stats.h +4 -3
- data/src/core/ext/xds/xds_cluster.cc +21 -10
- data/src/core/ext/xds/xds_cluster.h +9 -1
- data/src/core/ext/xds/xds_cluster_specifier_plugin.cc +16 -7
- data/src/core/ext/xds/xds_cluster_specifier_plugin.h +1 -8
- data/src/core/ext/xds/xds_common_types.cc +36 -22
- data/src/core/ext/xds/xds_common_types.h +12 -4
- data/src/core/ext/xds/xds_endpoint.cc +25 -15
- data/src/core/ext/xds/xds_endpoint.h +13 -5
- data/src/core/ext/xds/xds_http_fault_filter.cc +7 -5
- data/src/core/ext/xds/xds_http_fault_filter.h +3 -1
- data/src/core/ext/xds/xds_http_filters.cc +7 -0
- data/src/core/ext/xds/xds_http_filters.h +3 -3
- data/src/core/ext/xds/xds_http_rbac_filter.cc +16 -0
- data/src/core/ext/xds/xds_http_rbac_filter.h +7 -0
- data/src/core/ext/xds/xds_lb_policy_registry.cc +291 -0
- data/src/core/ext/xds/xds_lb_policy_registry.h +72 -0
- data/src/core/ext/xds/xds_listener.cc +51 -33
- data/src/core/ext/xds/xds_listener.h +10 -1
- data/src/core/ext/xds/xds_resource_type.h +3 -3
- data/src/core/ext/xds/xds_resource_type_impl.h +7 -3
- data/src/core/ext/xds/xds_route_config.cc +56 -28
- data/src/core/ext/xds/xds_route_config.h +11 -2
- data/src/core/ext/xds/xds_routing.cc +16 -0
- data/src/core/ext/xds/xds_routing.h +7 -2
- data/src/core/ext/xds/xds_server_config_fetcher.cc +54 -6
- data/src/core/lib/address_utils/parse_address.cc +5 -8
- data/src/core/lib/address_utils/parse_address.h +3 -2
- data/src/core/lib/address_utils/sockaddr_utils.cc +8 -7
- data/src/core/lib/address_utils/sockaddr_utils.h +2 -0
- data/src/core/lib/avl/avl.h +3 -3
- data/src/core/lib/backoff/backoff.cc +1 -1
- data/src/core/lib/backoff/backoff.h +1 -1
- data/src/core/lib/channel/call_tracer.h +3 -3
- data/src/core/lib/channel/channel_args.h +1 -0
- data/src/core/lib/channel/channel_args_preconditioning.cc +1 -0
- data/src/core/lib/channel/channel_fwd.h +26 -0
- data/src/core/lib/channel/channel_stack.cc +4 -4
- data/src/core/lib/channel/channel_stack.h +1 -11
- data/src/core/lib/channel/channel_stack_builder.h +2 -5
- data/src/core/lib/channel/channel_stack_builder_impl.cc +1 -1
- data/src/core/lib/channel/channel_stack_builder_impl.h +1 -0
- data/src/core/lib/channel/channelz.cc +2 -1
- data/src/core/lib/channel/channelz.h +2 -3
- data/src/core/lib/channel/channelz_registry.cc +4 -5
- data/src/core/lib/channel/connected_channel.cc +1 -0
- data/src/core/lib/channel/connected_channel.h +1 -0
- data/src/core/lib/channel/promise_based_filter.cc +11 -5
- data/src/core/lib/channel/promise_based_filter.h +2 -0
- data/src/core/lib/compression/compression.cc +6 -1
- data/src/core/lib/compression/compression_internal.cc +3 -6
- data/src/core/lib/compression/compression_internal.h +3 -2
- data/src/core/lib/compression/message_compress.cc +3 -1
- data/src/core/lib/compression/message_compress.h +2 -3
- data/src/core/lib/debug/stats.cc +9 -9
- data/src/core/lib/debug/stats.h +2 -1
- data/src/core/lib/debug/stats_data.cc +2 -1
- data/src/core/lib/debug/stats_data.h +0 -4
- data/src/core/lib/debug/trace.h +13 -12
- data/src/core/lib/event_engine/default_event_engine_factory.cc +1 -1
- data/src/core/lib/event_engine/event_engine.cc +24 -19
- data/src/core/lib/event_engine/event_engine_factory.h +2 -2
- data/src/core/lib/event_engine/{iomgr_engine.cc → iomgr_engine/iomgr_engine.cc} +44 -91
- data/src/core/lib/event_engine/{iomgr_engine.h → iomgr_engine/iomgr_engine.h} +20 -16
- data/src/core/lib/event_engine/iomgr_engine/thread_pool.cc +123 -0
- data/src/core/lib/event_engine/iomgr_engine/thread_pool.h +70 -0
- data/src/core/lib/event_engine/iomgr_engine/time_averaged_stats.cc +62 -0
- data/src/core/lib/event_engine/iomgr_engine/time_averaged_stats.h +81 -0
- data/src/core/lib/event_engine/iomgr_engine/timer.cc +312 -0
- data/src/core/lib/event_engine/iomgr_engine/timer.h +193 -0
- data/src/core/lib/event_engine/iomgr_engine/timer_heap.cc +107 -0
- data/src/core/lib/event_engine/iomgr_engine/timer_heap.h +56 -0
- data/src/core/lib/event_engine/iomgr_engine/timer_manager.cc +254 -0
- data/src/core/lib/event_engine/iomgr_engine/timer_manager.h +111 -0
- data/src/core/lib/event_engine/promise.h +69 -0
- data/src/core/lib/gpr/time_posix.cc +6 -9
- data/src/core/lib/gpr/time_windows.cc +10 -7
- data/src/core/lib/gprpp/manual_constructor.h +0 -67
- data/src/core/lib/gprpp/status_helper.cc +44 -30
- data/src/core/lib/gprpp/time.cc +8 -0
- data/src/core/lib/gprpp/time.h +4 -0
- data/src/core/lib/http/format_request.cc +5 -4
- data/src/core/lib/http/format_request.h +1 -1
- data/src/core/lib/http/httpcli.cc +18 -12
- data/src/core/lib/http/httpcli.h +19 -3
- data/src/core/lib/http/httpcli_security_connector.cc +16 -4
- data/src/core/lib/http/httpcli_ssl_credentials.h +3 -1
- data/src/core/lib/http/parser.cc +6 -7
- data/src/core/lib/http/parser.h +3 -0
- data/src/core/lib/iomgr/call_combiner.cc +2 -2
- data/src/core/lib/iomgr/endpoint.h +1 -1
- data/src/core/lib/iomgr/endpoint_cfstream.cc +2 -2
- data/src/core/lib/iomgr/error.cc +11 -9
- data/src/core/lib/iomgr/error.h +9 -5
- data/src/core/lib/iomgr/ev_epoll1_linux.cc +57 -18
- data/src/core/lib/iomgr/ev_epoll1_linux.h +1 -1
- data/src/core/lib/iomgr/ev_poll_posix.cc +77 -52
- data/src/core/lib/iomgr/ev_poll_posix.h +2 -2
- data/src/core/lib/iomgr/ev_posix.cc +54 -92
- data/src/core/lib/iomgr/ev_posix.h +5 -3
- data/src/core/lib/iomgr/fork_posix.cc +1 -1
- data/src/core/lib/iomgr/iomgr.cc +7 -0
- data/src/core/lib/iomgr/iomgr_posix.cc +1 -0
- data/src/core/lib/iomgr/iomgr_posix_cfstream.cc +1 -0
- data/src/core/lib/iomgr/load_file.cc +1 -1
- data/src/core/lib/iomgr/resolve_address_posix.cc +1 -1
- data/src/core/lib/iomgr/resolve_address_windows.cc +1 -1
- data/src/core/lib/iomgr/tcp_client.cc +12 -7
- data/src/core/lib/iomgr/tcp_client.h +24 -13
- data/src/core/lib/iomgr/tcp_client_cfstream.cc +15 -9
- data/src/core/lib/iomgr/tcp_client_posix.cc +143 -25
- data/src/core/lib/iomgr/tcp_client_posix.h +1 -1
- data/src/core/lib/iomgr/tcp_client_windows.cc +14 -10
- data/src/core/lib/iomgr/tcp_posix.cc +91 -29
- data/src/core/lib/iomgr/tcp_server_posix.cc +7 -7
- data/src/core/lib/iomgr/tcp_server_utils_posix_common.cc +12 -12
- data/src/core/lib/iomgr/tcp_server_utils_posix_ifaddrs.cc +2 -2
- data/src/core/lib/iomgr/tcp_server_windows.cc +7 -7
- data/src/core/lib/iomgr/tcp_windows.cc +5 -5
- data/src/core/lib/iomgr/unix_sockets_posix.cc +2 -2
- data/src/core/lib/iomgr/wakeup_fd_pipe.cc +2 -2
- data/src/core/lib/iomgr/wakeup_fd_posix.cc +15 -12
- data/src/core/lib/iomgr/wakeup_fd_posix.h +0 -2
- data/src/core/lib/iomgr/work_serializer.h +2 -3
- data/src/core/lib/matchers/matchers.cc +6 -3
- data/src/core/lib/matchers/matchers.h +2 -0
- data/src/core/lib/promise/activity.cc +0 -1
- data/src/core/lib/promise/activity.h +7 -13
- data/src/core/lib/promise/loop.h +1 -0
- data/src/core/lib/promise/promise.h +1 -0
- data/src/core/lib/promise/sleep.cc +36 -31
- data/src/core/lib/promise/sleep.h +25 -25
- data/src/core/lib/resolver/resolver.cc +5 -0
- data/src/core/lib/resolver/resolver.h +3 -0
- data/src/core/lib/resolver/resolver_factory.h +5 -2
- data/src/core/lib/resolver/resolver_registry.cc +2 -9
- data/src/core/lib/resolver/resolver_registry.h +12 -1
- data/src/core/lib/resolver/server_address.cc +8 -0
- data/src/core/lib/resolver/server_address.h +9 -2
- data/src/core/lib/resource_quota/memory_quota.cc +18 -60
- data/src/core/lib/resource_quota/memory_quota.h +11 -25
- data/src/core/lib/security/authorization/authorization_policy_provider.h +7 -0
- data/src/core/lib/security/authorization/authorization_policy_provider_vtable.cc +4 -0
- data/src/core/lib/security/authorization/evaluate_args.cc +9 -3
- data/src/core/lib/security/authorization/evaluate_args.h +6 -3
- data/src/core/lib/security/authorization/grpc_authorization_engine.cc +6 -0
- data/src/core/lib/security/authorization/grpc_authorization_engine.h +7 -0
- data/src/core/lib/security/authorization/grpc_server_authz_filter.cc +12 -0
- data/src/core/lib/security/authorization/grpc_server_authz_filter.h +12 -1
- data/src/core/lib/security/authorization/matchers.cc +9 -1
- data/src/core/lib/security/authorization/matchers.h +7 -0
- data/src/core/lib/security/authorization/rbac_policy.cc +5 -0
- data/src/core/lib/security/authorization/rbac_policy.h +7 -0
- data/src/core/lib/security/context/security_context.cc +5 -2
- data/src/core/lib/security/context/security_context.h +14 -2
- data/src/core/lib/security/credentials/alts/alts_credentials.cc +4 -2
- data/src/core/lib/security/credentials/alts/alts_credentials.h +6 -1
- data/src/core/lib/security/credentials/alts/grpc_alts_credentials_client_options.cc +1 -3
- data/src/core/lib/security/credentials/alts/grpc_alts_credentials_server_options.cc +1 -4
- data/src/core/lib/security/credentials/call_creds_util.cc +8 -0
- data/src/core/lib/security/credentials/call_creds_util.h +1 -0
- data/src/core/lib/security/credentials/channel_creds_registry.h +6 -1
- data/src/core/lib/security/credentials/channel_creds_registry_init.cc +10 -0
- data/src/core/lib/security/credentials/composite/composite_credentials.cc +4 -4
- data/src/core/lib/security/credentials/composite/composite_credentials.h +16 -2
- data/src/core/lib/security/credentials/credentials.cc +4 -8
- data/src/core/lib/security/credentials/credentials.h +10 -8
- data/src/core/lib/security/credentials/external/aws_external_account_credentials.cc +28 -10
- data/src/core/lib/security/credentials/external/aws_external_account_credentials.h +10 -0
- data/src/core/lib/security/credentials/external/aws_request_signer.cc +9 -0
- data/src/core/lib/security/credentials/external/external_account_credentials.cc +24 -9
- data/src/core/lib/security/credentials/external/external_account_credentials.h +11 -0
- data/src/core/lib/security/credentials/external/file_external_account_credentials.cc +12 -4
- data/src/core/lib/security/credentials/external/file_external_account_credentials.h +6 -0
- data/src/core/lib/security/credentials/external/url_external_account_credentials.cc +20 -4
- data/src/core/lib/security/credentials/external/url_external_account_credentials.h +10 -0
- data/src/core/lib/security/credentials/fake/fake_credentials.cc +8 -6
- data/src/core/lib/security/credentials/fake/fake_credentials.h +13 -1
- data/src/core/lib/security/credentials/google_default/credentials_generic.cc +1 -0
- data/src/core/lib/security/credentials/google_default/google_default_credentials.cc +27 -10
- data/src/core/lib/security/credentials/google_default/google_default_credentials.h +10 -1
- data/src/core/lib/security/credentials/iam/iam_credentials.cc +9 -3
- data/src/core/lib/security/credentials/iam/iam_credentials.h +10 -0
- data/src/core/lib/security/credentials/insecure/insecure_credentials.cc +4 -0
- data/src/core/lib/security/credentials/insecure/insecure_credentials.h +5 -0
- data/src/core/lib/security/credentials/jwt/json_token.cc +5 -2
- data/src/core/lib/security/credentials/jwt/json_token.h +2 -2
- data/src/core/lib/security/credentials/jwt/jwt_credentials.cc +11 -5
- data/src/core/lib/security/credentials/jwt/jwt_credentials.h +14 -0
- data/src/core/lib/security/credentials/jwt/jwt_verifier.cc +28 -3
- data/src/core/lib/security/credentials/jwt/jwt_verifier.h +4 -2
- data/src/core/lib/security/credentials/local/local_credentials.cc +4 -3
- data/src/core/lib/security/credentials/local/local_credentials.h +7 -0
- data/src/core/lib/security/credentials/oauth2/oauth2_credentials.cc +26 -13
- data/src/core/lib/security/credentials/oauth2/oauth2_credentials.h +20 -0
- data/src/core/lib/security/credentials/plugin/plugin_credentials.cc +8 -7
- data/src/core/lib/security/credentials/plugin/plugin_credentials.h +24 -0
- data/src/core/lib/security/credentials/ssl/ssl_credentials.cc +5 -0
- data/src/core/lib/security/credentials/ssl/ssl_credentials.h +13 -0
- data/src/core/lib/security/credentials/tls/grpc_tls_certificate_distributor.cc +6 -6
- data/src/core/lib/security/credentials/tls/grpc_tls_certificate_distributor.h +9 -3
- data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.cc +29 -10
- data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.h +9 -4
- data/src/core/lib/security/credentials/tls/grpc_tls_certificate_verifier.cc +9 -2
- data/src/core/lib/security/credentials/tls/grpc_tls_certificate_verifier.h +6 -7
- data/src/core/lib/security/credentials/tls/grpc_tls_credentials_options.cc +4 -5
- data/src/core/lib/security/credentials/tls/tls_credentials.cc +7 -2
- data/src/core/lib/security/credentials/tls/tls_credentials.h +5 -1
- data/src/core/lib/security/credentials/tls/tls_utils.cc +2 -0
- data/src/core/lib/security/credentials/tls/tls_utils.h +1 -1
- data/src/core/lib/security/credentials/xds/xds_credentials.cc +8 -1
- data/src/core/lib/security/credentials/xds/xds_credentials.h +14 -0
- data/src/core/lib/security/security_connector/alts/alts_security_connector.cc +22 -2
- data/src/core/lib/security/security_connector/alts/alts_security_connector.h +6 -3
- data/src/core/lib/security/security_connector/fake/fake_security_connector.cc +17 -1
- data/src/core/lib/security/security_connector/fake/fake_security_connector.h +2 -2
- data/src/core/lib/security/security_connector/insecure/insecure_security_connector.cc +9 -0
- data/src/core/lib/security/security_connector/insecure/insecure_security_connector.h +17 -2
- data/src/core/lib/security/security_connector/load_system_roots_fallback.cc +5 -3
- data/src/core/lib/security/security_connector/{load_system_roots_linux.cc → load_system_roots_supported.cc} +27 -19
- data/src/core/lib/security/security_connector/{load_system_roots_linux.h → load_system_roots_supported.h} +5 -5
- data/src/core/lib/security/security_connector/local/local_security_connector.cc +22 -3
- data/src/core/lib/security/security_connector/local/local_security_connector.h +6 -2
- data/src/core/lib/security/security_connector/security_connector.cc +20 -18
- data/src/core/lib/security/security_connector/security_connector.h +18 -6
- data/src/core/lib/security/security_connector/ssl/ssl_security_connector.cc +18 -6
- data/src/core/lib/security/security_connector/ssl/ssl_security_connector.h +4 -2
- data/src/core/lib/security/security_connector/ssl_utils.cc +12 -2
- data/src/core/lib/security/security_connector/ssl_utils.h +10 -7
- data/src/core/lib/security/security_connector/ssl_utils_config.h +1 -1
- data/src/core/lib/security/security_connector/tls/tls_security_connector.cc +21 -13
- data/src/core/lib/security/security_connector/tls/tls_security_connector.h +23 -3
- data/src/core/lib/security/transport/auth_filters.h +7 -0
- data/src/core/lib/security/transport/client_auth_filter.cc +18 -9
- data/src/core/lib/security/transport/secure_endpoint.cc +63 -13
- data/src/core/lib/security/transport/secure_endpoint.h +4 -3
- data/src/core/lib/security/transport/security_handshaker.cc +44 -11
- data/src/core/lib/security/transport/security_handshaker.h +4 -0
- data/src/core/lib/security/transport/server_auth_filter.cc +26 -4
- data/src/core/lib/security/util/json_util.cc +3 -2
- data/src/core/lib/security/util/json_util.h +0 -2
- data/src/core/lib/service_config/service_config_call_data.h +2 -1
- data/src/core/lib/service_config/service_config_impl.cc +6 -6
- data/src/core/lib/service_config/service_config_impl.h +1 -3
- data/src/core/lib/service_config/service_config_parser.cc +2 -4
- data/src/core/lib/slice/slice_buffer.cc +30 -1
- data/src/core/lib/slice/slice_buffer.h +37 -6
- data/src/core/lib/slice/slice_string_helpers.cc +0 -20
- data/src/core/lib/slice/slice_string_helpers.h +0 -4
- data/src/core/lib/surface/call.cc +53 -115
- data/src/core/lib/surface/call.h +5 -1
- data/src/core/lib/surface/channel.h +2 -0
- data/src/core/lib/surface/channel_ping.cc +1 -1
- data/src/core/lib/surface/completion_queue.cc +15 -14
- data/src/core/lib/surface/completion_queue.h +2 -1
- data/src/core/lib/surface/init.cc +0 -1
- data/src/core/lib/surface/lame_client.cc +1 -1
- data/src/core/lib/surface/lame_client.h +1 -1
- data/src/core/lib/surface/server.cc +14 -8
- data/src/core/lib/surface/server.h +4 -1
- data/src/core/lib/surface/validate_metadata.cc +1 -1
- data/src/core/lib/surface/version.cc +2 -2
- data/src/core/lib/transport/error_utils.cc +13 -7
- data/src/core/lib/transport/handshaker.cc +3 -3
- data/src/core/lib/transport/http_connect_handshaker.cc +4 -4
- data/src/core/lib/transport/tcp_connect_handshaker.cc +2 -2
- data/src/core/lib/transport/transport.cc +0 -3
- data/src/core/lib/transport/transport.h +20 -14
- data/src/core/lib/transport/transport_fwd.h +20 -0
- data/src/core/lib/transport/transport_impl.h +1 -0
- data/src/core/lib/transport/transport_op_string.cc +9 -9
- data/src/core/tsi/alts/handshaker/alts_tsi_handshaker.cc +1 -1
- data/src/core/tsi/alts/zero_copy_frame_protector/alts_zero_copy_grpc_protector.cc +9 -1
- data/src/core/tsi/fake_transport_security.cc +13 -1
- data/src/core/tsi/fake_transport_security.h +6 -0
- data/src/core/tsi/ssl_transport_security.cc +1 -1
- data/src/core/tsi/transport_security_grpc.cc +3 -2
- data/src/core/tsi/transport_security_grpc.h +5 -2
- data/src/ruby/ext/grpc/ext-export-truffleruby.clang +2 -0
- data/src/ruby/ext/grpc/ext-export-truffleruby.gcc +7 -0
- data/src/ruby/ext/grpc/ext-export.clang +1 -0
- data/src/ruby/ext/grpc/ext-export.gcc +1 -0
- data/src/ruby/ext/grpc/extconf.rb +49 -18
- data/src/ruby/ext/grpc/rb_grpc_imports.generated.h +1 -1
- data/src/ruby/lib/grpc/errors.rb +1 -1
- data/src/ruby/lib/grpc/version.rb +1 -1
- data/src/ruby/spec/generic/client_stub_spec.rb +23 -23
- data/third_party/abseil-cpp/absl/algorithm/container.h +1 -1
- data/third_party/abseil-cpp/absl/base/attributes.h +49 -22
- data/third_party/abseil-cpp/absl/base/casts.h +61 -68
- data/third_party/abseil-cpp/absl/base/config.h +182 -41
- data/third_party/abseil-cpp/absl/base/internal/cycleclock.cc +12 -42
- data/third_party/abseil-cpp/absl/base/internal/cycleclock.h +67 -2
- data/third_party/abseil-cpp/absl/base/internal/direct_mmap.h +3 -3
- data/third_party/abseil-cpp/absl/base/internal/endian.h +17 -62
- data/third_party/abseil-cpp/absl/base/internal/fast_type_id.h +2 -0
- data/third_party/abseil-cpp/absl/base/internal/invoke.h +54 -0
- data/third_party/abseil-cpp/absl/base/internal/prefetch.h +138 -0
- data/third_party/abseil-cpp/absl/base/internal/raw_logging.cc +29 -22
- data/third_party/abseil-cpp/absl/base/internal/raw_logging.h +13 -12
- data/third_party/abseil-cpp/absl/base/internal/spinlock.cc +3 -0
- data/third_party/abseil-cpp/absl/base/internal/spinlock.h +8 -0
- data/third_party/abseil-cpp/absl/base/internal/spinlock_linux.inc +2 -5
- data/third_party/abseil-cpp/absl/base/internal/strerror.cc +88 -0
- data/third_party/abseil-cpp/absl/base/internal/strerror.h +39 -0
- data/third_party/abseil-cpp/absl/base/internal/sysinfo.cc +0 -1
- data/third_party/abseil-cpp/absl/base/internal/thread_identity.cc +2 -1
- data/third_party/abseil-cpp/absl/base/internal/unscaledcycleclock.cc +6 -7
- data/third_party/abseil-cpp/absl/base/internal/unscaledcycleclock.h +12 -3
- data/third_party/abseil-cpp/absl/base/log_severity.cc +28 -0
- data/third_party/abseil-cpp/absl/base/log_severity.h +51 -0
- data/third_party/abseil-cpp/absl/base/optimization.h +19 -11
- data/third_party/abseil-cpp/absl/base/options.h +1 -1
- data/third_party/abseil-cpp/absl/base/thread_annotations.h +2 -2
- data/third_party/abseil-cpp/absl/container/fixed_array.h +2 -0
- data/third_party/abseil-cpp/absl/container/flat_hash_map.h +11 -4
- data/third_party/abseil-cpp/absl/container/flat_hash_set.h +15 -9
- data/third_party/abseil-cpp/absl/container/inlined_vector.h +20 -9
- data/third_party/abseil-cpp/absl/container/internal/common.h +6 -5
- data/third_party/abseil-cpp/absl/container/internal/container_memory.h +10 -28
- data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler.cc +68 -20
- data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler.h +29 -11
- data/third_party/abseil-cpp/absl/container/internal/inlined_vector.h +59 -38
- data/third_party/abseil-cpp/absl/container/internal/raw_hash_set.cc +4 -0
- data/third_party/abseil-cpp/absl/container/internal/raw_hash_set.h +515 -184
- data/third_party/abseil-cpp/absl/debugging/internal/address_is_readable.cc +45 -88
- data/third_party/abseil-cpp/absl/debugging/internal/elf_mem_image.cc +4 -0
- data/third_party/abseil-cpp/absl/debugging/internal/elf_mem_image.h +3 -2
- data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_aarch64-inl.inc +8 -3
- data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_arm-inl.inc +8 -3
- data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_config.h +2 -1
- data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_powerpc-inl.inc +8 -3
- data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_riscv-inl.inc +20 -18
- data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_x86-inl.inc +8 -3
- data/third_party/abseil-cpp/absl/debugging/internal/vdso_support.cc +15 -2
- data/third_party/abseil-cpp/absl/debugging/symbolize.cc +6 -1
- data/third_party/abseil-cpp/absl/debugging/symbolize_elf.inc +46 -7
- data/third_party/abseil-cpp/absl/functional/bind_front.h +10 -1
- data/third_party/abseil-cpp/absl/functional/function_ref.h +2 -1
- data/third_party/abseil-cpp/absl/hash/hash.h +82 -8
- data/third_party/abseil-cpp/absl/hash/internal/hash.h +218 -23
- data/third_party/abseil-cpp/absl/numeric/bits.h +2 -1
- data/third_party/abseil-cpp/absl/numeric/int128.cc +4 -2
- data/third_party/abseil-cpp/absl/numeric/int128.h +2 -2
- data/third_party/abseil-cpp/absl/profiling/internal/sample_recorder.h +21 -6
- data/third_party/abseil-cpp/absl/random/bernoulli_distribution.h +4 -4
- data/third_party/abseil-cpp/absl/random/distributions.h +3 -3
- data/third_party/abseil-cpp/absl/random/internal/distribution_caller.h +3 -0
- data/third_party/abseil-cpp/absl/random/internal/fast_uniform_bits.h +2 -1
- data/third_party/abseil-cpp/absl/random/internal/generate_real.h +2 -2
- data/third_party/abseil-cpp/absl/random/internal/nonsecure_base.h +59 -48
- data/third_party/abseil-cpp/absl/random/internal/pcg_engine.h +1 -1
- data/third_party/abseil-cpp/absl/random/internal/randen.h +5 -11
- data/third_party/abseil-cpp/absl/random/internal/randen_detect.cc +6 -2
- data/third_party/abseil-cpp/absl/random/internal/randen_engine.h +48 -23
- data/third_party/abseil-cpp/absl/random/internal/salted_seed_seq.h +24 -26
- data/third_party/abseil-cpp/absl/random/internal/traits.h +53 -5
- data/third_party/abseil-cpp/absl/random/internal/uniform_helper.h +5 -5
- data/third_party/abseil-cpp/absl/random/internal/wide_multiply.h +33 -48
- data/third_party/abseil-cpp/absl/random/log_uniform_int_distribution.h +9 -10
- data/third_party/abseil-cpp/absl/random/poisson_distribution.h +7 -4
- data/third_party/abseil-cpp/absl/random/seed_sequences.h +1 -0
- data/third_party/abseil-cpp/absl/random/uniform_int_distribution.h +2 -2
- data/third_party/abseil-cpp/absl/random/uniform_real_distribution.h +1 -1
- data/third_party/abseil-cpp/absl/random/zipf_distribution.h +4 -3
- data/third_party/abseil-cpp/absl/status/internal/status_internal.h +17 -0
- data/third_party/abseil-cpp/absl/status/status.cc +174 -2
- data/third_party/abseil-cpp/absl/status/status.h +22 -12
- data/third_party/abseil-cpp/absl/status/statusor.h +9 -3
- data/third_party/abseil-cpp/absl/strings/ascii.h +4 -4
- data/third_party/abseil-cpp/absl/strings/cord.cc +194 -913
- data/third_party/abseil-cpp/absl/strings/cord.h +202 -81
- data/third_party/abseil-cpp/absl/strings/cord_analysis.cc +188 -0
- data/third_party/abseil-cpp/absl/strings/cord_analysis.h +44 -0
- data/third_party/abseil-cpp/absl/strings/cord_buffer.cc +30 -0
- data/third_party/abseil-cpp/absl/strings/cord_buffer.h +572 -0
- data/third_party/abseil-cpp/absl/strings/internal/cord_data_edge.h +63 -0
- data/third_party/abseil-cpp/absl/strings/internal/cord_internal.cc +20 -32
- data/third_party/abseil-cpp/absl/strings/internal/cord_internal.h +123 -88
- data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree.cc +149 -49
- data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree.h +44 -59
- data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree_navigator.cc +3 -1
- data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree_navigator.h +4 -2
- data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree_reader.cc +3 -2
- data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree_reader.h +5 -4
- data/third_party/abseil-cpp/absl/strings/internal/cord_rep_consume.cc +7 -74
- data/third_party/abseil-cpp/absl/strings/internal/cord_rep_crc.cc +54 -0
- data/third_party/abseil-cpp/absl/strings/internal/cord_rep_crc.h +102 -0
- data/third_party/abseil-cpp/absl/strings/internal/cord_rep_flat.h +58 -17
- data/third_party/abseil-cpp/absl/strings/internal/cord_rep_ring.cc +13 -11
- data/third_party/abseil-cpp/absl/strings/internal/cordz_info.cc +11 -38
- data/third_party/abseil-cpp/absl/strings/internal/cordz_statistics.h +1 -0
- data/third_party/abseil-cpp/absl/strings/internal/cordz_update_tracker.h +4 -2
- data/third_party/abseil-cpp/absl/strings/internal/escaping.cc +6 -5
- data/third_party/abseil-cpp/absl/strings/internal/ostringstream.cc +1 -1
- data/third_party/abseil-cpp/absl/strings/internal/str_format/arg.cc +1 -1
- data/third_party/abseil-cpp/absl/strings/internal/str_format/arg.h +1 -1
- data/third_party/abseil-cpp/absl/strings/internal/str_format/bind.h +38 -7
- data/third_party/abseil-cpp/absl/strings/internal/str_format/checker.h +7 -2
- data/third_party/abseil-cpp/absl/strings/internal/str_format/extension.cc +4 -5
- data/third_party/abseil-cpp/absl/strings/internal/str_format/extension.h +5 -2
- data/third_party/abseil-cpp/absl/strings/internal/str_format/output.h +2 -1
- data/third_party/abseil-cpp/absl/strings/internal/str_format/parser.h +4 -2
- data/third_party/abseil-cpp/absl/strings/internal/str_join_internal.h +9 -6
- data/third_party/abseil-cpp/absl/strings/internal/string_constant.h +10 -2
- data/third_party/abseil-cpp/absl/strings/internal/utf8.cc +9 -9
- data/third_party/abseil-cpp/absl/strings/numbers.cc +8 -8
- data/third_party/abseil-cpp/absl/strings/numbers.h +26 -23
- data/third_party/abseil-cpp/absl/strings/str_cat.h +20 -13
- data/third_party/abseil-cpp/absl/strings/str_join.h +9 -15
- data/third_party/abseil-cpp/absl/strings/str_split.h +1 -2
- data/third_party/abseil-cpp/absl/strings/string_view.cc +2 -13
- data/third_party/abseil-cpp/absl/strings/string_view.h +3 -2
- data/third_party/abseil-cpp/absl/strings/strip.h +8 -6
- data/third_party/abseil-cpp/absl/strings/substitute.h +10 -2
- data/third_party/abseil-cpp/absl/synchronization/internal/create_thread_identity.cc +9 -6
- data/third_party/abseil-cpp/absl/synchronization/internal/create_thread_identity.h +0 -4
- data/third_party/abseil-cpp/absl/synchronization/internal/per_thread_sem.cc +0 -4
- data/third_party/abseil-cpp/absl/synchronization/internal/per_thread_sem.h +1 -6
- data/third_party/abseil-cpp/absl/synchronization/internal/waiter.cc +0 -25
- data/third_party/abseil-cpp/absl/synchronization/internal/waiter.h +10 -4
- data/third_party/abseil-cpp/absl/synchronization/mutex.cc +75 -40
- data/third_party/abseil-cpp/absl/synchronization/mutex.h +17 -9
- data/third_party/abseil-cpp/absl/synchronization/notification.h +3 -2
- data/third_party/abseil-cpp/absl/time/duration.cc +5 -4
- data/third_party/abseil-cpp/absl/time/internal/cctz/include/cctz/civil_time_detail.h +11 -7
- data/third_party/abseil-cpp/absl/time/time.h +16 -12
- data/third_party/abseil-cpp/absl/types/internal/optional.h +8 -0
- data/third_party/abseil-cpp/absl/types/internal/variant.h +3 -3
- data/third_party/abseil-cpp/absl/types/optional.h +17 -14
- data/third_party/abseil-cpp/absl/types/span.h +2 -1
- metadata +39 -15
- data/src/core/lib/slice/slice_split.cc +0 -103
- data/src/core/lib/slice/slice_split.h +0 -36
- data/src/core/lib/transport/byte_stream.cc +0 -165
- data/src/core/lib/transport/byte_stream.h +0 -170
- data/third_party/abseil-cpp/absl/cleanup/cleanup.h +0 -140
- data/third_party/abseil-cpp/absl/cleanup/internal/cleanup.h +0 -100
- 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 */
|