grpc 1.56.2 → 1.57.0.pre1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/Makefile +29 -22
- data/include/grpc/event_engine/event_engine.h +22 -32
- data/include/grpc/impl/grpc_types.h +3 -0
- data/include/grpc/support/port_platform.h +29 -23
- data/src/core/ext/filters/client_channel/client_channel.cc +44 -8
- data/src/core/ext/filters/client_channel/dynamic_filters.h +3 -3
- data/src/core/ext/filters/client_channel/http_proxy.cc +5 -0
- data/src/core/ext/filters/client_channel/lb_policy/address_filtering.cc +21 -52
- data/src/core/ext/filters/client_channel/lb_policy/address_filtering.h +19 -7
- data/src/core/ext/filters/client_channel/lb_policy/child_policy_handler.cc +25 -35
- data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb.cc +78 -132
- data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_balancer_addresses.cc +2 -1
- data/src/core/ext/filters/client_channel/lb_policy/grpclb/load_balancer_api.cc +4 -3
- data/src/core/ext/filters/client_channel/lb_policy/grpclb/load_balancer_api.h +3 -1
- data/src/core/ext/filters/client_channel/lb_policy/health_check_client.cc +38 -15
- data/src/core/ext/filters/client_channel/lb_policy/health_check_client.h +3 -5
- data/src/core/ext/filters/client_channel/lb_policy/health_check_client_internal.h +22 -6
- data/src/core/ext/filters/client_channel/lb_policy/oob_backend_metric_internal.h +2 -0
- data/src/core/ext/filters/client_channel/lb_policy/outlier_detection/outlier_detection.cc +97 -71
- data/src/core/ext/filters/client_channel/lb_policy/outlier_detection/outlier_detection.h +2 -16
- data/src/core/ext/filters/client_channel/lb_policy/pick_first/pick_first.cc +56 -11
- data/src/core/ext/filters/client_channel/lb_policy/pick_first/pick_first.h +25 -0
- data/src/core/ext/filters/client_channel/lb_policy/priority/priority.cc +6 -32
- data/src/core/ext/filters/client_channel/lb_policy/ring_hash/ring_hash.cc +4 -6
- data/src/core/ext/filters/client_channel/lb_policy/rls/rls.cc +20 -79
- data/src/core/ext/filters/client_channel/lb_policy/round_robin/round_robin.cc +1 -1
- data/src/core/ext/filters/client_channel/lb_policy/subchannel_list.h +31 -19
- data/src/core/ext/filters/client_channel/lb_policy/weighted_round_robin/weighted_round_robin.cc +1 -1
- data/src/core/ext/filters/client_channel/lb_policy/weighted_target/weighted_target.cc +7 -41
- data/src/core/ext/filters/client_channel/lb_policy/xds/cds.cc +3 -67
- data/src/core/ext/filters/client_channel/lb_policy/xds/xds_channel_args.h +8 -0
- data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_impl.cc +31 -74
- data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_manager.cc +7 -51
- data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_resolver.cc +16 -87
- data/src/core/ext/filters/client_channel/lb_policy/xds/xds_override_host.cc +16 -50
- data/src/core/ext/filters/client_channel/lb_policy/xds/xds_wrr_locality.cc +12 -74
- data/src/core/ext/filters/client_channel/resolver/dns/c_ares/dns_resolver_ares.cc +1 -4
- data/src/core/ext/filters/client_channel/resolver/dns/event_engine/event_engine_client_channel_resolver.cc +69 -59
- data/src/core/ext/filters/client_channel/resolver/polling_resolver.cc +7 -2
- data/src/core/ext/filters/client_channel/resolver/polling_resolver.h +1 -0
- data/src/core/ext/filters/client_channel/resolver/sockaddr/sockaddr_resolver.cc +25 -13
- data/src/core/ext/filters/client_channel/resolver/xds/xds_resolver.cc +366 -311
- data/src/core/ext/filters/client_channel/resolver/xds/xds_resolver.h +17 -1
- data/src/core/ext/filters/client_channel/retry_filter.cc +39 -2498
- data/src/core/ext/filters/client_channel/retry_filter.h +91 -1
- data/src/core/ext/filters/client_channel/retry_filter_legacy_call_data.cc +2052 -0
- data/src/core/ext/filters/client_channel/retry_filter_legacy_call_data.h +442 -0
- data/src/core/ext/filters/client_channel/service_config_channel_arg_filter.cc +38 -58
- data/src/core/ext/filters/client_channel/subchannel.h +3 -3
- data/src/core/ext/filters/client_channel/subchannel_interface_internal.h +3 -0
- data/src/core/ext/filters/rbac/rbac_filter.cc +40 -111
- data/src/core/ext/filters/rbac/rbac_filter.h +12 -30
- data/src/core/ext/filters/stateful_session/stateful_session_filter.cc +162 -86
- data/src/core/ext/filters/stateful_session/stateful_session_filter.h +0 -6
- data/src/core/ext/transport/chttp2/server/chttp2_server.cc +7 -4
- data/src/core/ext/transport/chttp2/transport/chttp2_transport.cc +131 -186
- data/src/core/ext/transport/chttp2/transport/decode_huff.cc +6569 -174
- data/src/core/ext/transport/chttp2/transport/decode_huff.h +2278 -441
- data/src/core/ext/transport/chttp2/transport/frame_ping.cc +2 -3
- data/src/core/ext/transport/chttp2/transport/hpack_parse_result.h +4 -3
- data/src/core/ext/transport/chttp2/transport/hpack_parser.cc +9 -8
- data/src/core/ext/transport/chttp2/transport/hpack_parser_table.cc +4 -4
- data/src/core/ext/transport/chttp2/transport/hpack_parser_table.h +3 -2
- data/src/core/ext/transport/chttp2/transport/internal.h +8 -4
- data/src/core/ext/transport/chttp2/transport/parsing.cc +15 -3
- data/src/core/ext/transport/chttp2/transport/writing.cc +2 -3
- data/src/core/ext/upb-generated/envoy/config/accesslog/v3/accesslog.upb.c +27 -6
- data/src/core/ext/upb-generated/envoy/config/accesslog/v3/accesslog.upb.h +143 -0
- data/src/core/ext/upb-generated/envoy/config/core/v3/config_source.upb.c +2 -9
- data/src/core/ext/upb-generated/envoy/config/core/v3/config_source.upb.h +0 -39
- data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_service.upb.c +13 -8
- data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_service.upb.h +35 -6
- data/src/core/ext/upb-generated/envoy/config/core/v3/health_check.upb.c +17 -13
- data/src/core/ext/upb-generated/envoy/config/core/v3/health_check.upb.h +85 -20
- data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.c +26 -7
- data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.h +45 -3
- data/src/core/ext/upb-generated/envoy/config/metrics/v3/metrics_service.upb.c +4 -3
- data/src/core/ext/upb-generated/envoy/config/metrics/v3/metrics_service.upb.h +21 -0
- data/src/core/ext/upb-generated/envoy/config/overload/v3/overload.upb.c +30 -6
- data/src/core/ext/upb-generated/envoy/config/overload/v3/overload.upb.h +180 -0
- data/src/core/ext/upb-generated/envoy/data/accesslog/v3/accesslog.upb.c +558 -0
- data/src/core/ext/upb-generated/envoy/data/accesslog/v3/accesslog.upb.h +2710 -0
- data/src/core/ext/upb-generated/envoy/extensions/filters/http/fault/v3/fault.upb.c +30 -11
- data/src/core/ext/upb-generated/envoy/extensions/filters/http/fault/v3/fault.upb.h +53 -24
- data/src/core/ext/upb-generated/envoy/extensions/filters/http/router/v3/router.upb.c +30 -5
- data/src/core/ext/upb-generated/envoy/extensions/filters/http/router/v3/router.upb.h +110 -0
- data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.c +41 -15
- data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.h +150 -27
- data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/client_side_weighted_round_robin/v3/client_side_weighted_round_robin.upb.c +1 -0
- data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/pick_first/v3/pick_first.upb.c +47 -0
- data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/pick_first/v3/pick_first.upb.h +93 -0
- data/src/core/ext/upbdefs-generated/envoy/config/accesslog/v3/accesslog.upbdefs.c +88 -76
- data/src/core/ext/upbdefs-generated/envoy/config/accesslog/v3/accesslog.upbdefs.h +5 -0
- data/src/core/ext/upbdefs-generated/envoy/config/core/v3/config_source.upbdefs.c +11 -12
- data/src/core/ext/upbdefs-generated/envoy/config/core/v3/config_source.upbdefs.h +0 -5
- data/src/core/ext/upbdefs-generated/envoy/config/core/v3/grpc_service.upbdefs.c +162 -160
- data/src/core/ext/upbdefs-generated/envoy/config/core/v3/health_check.upbdefs.c +129 -118
- data/src/core/ext/upbdefs-generated/envoy/config/core/v3/protocol.upbdefs.c +141 -135
- data/src/core/ext/upbdefs-generated/envoy/config/metrics/v3/metrics_service.upbdefs.c +19 -12
- data/src/core/ext/upbdefs-generated/envoy/config/overload/v3/overload.upbdefs.c +38 -30
- data/src/core/ext/upbdefs-generated/envoy/config/overload/v3/overload.upbdefs.h +5 -0
- data/src/core/ext/upbdefs-generated/envoy/data/accesslog/v3/accesslog.upbdefs.c +402 -0
- data/src/core/ext/upbdefs-generated/envoy/data/accesslog/v3/accesslog.upbdefs.h +111 -0
- data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/fault/v3/fault.upbdefs.c +80 -74
- data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/router/v3/router.upbdefs.c +63 -47
- data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/router/v3/router.upbdefs.h +5 -0
- data/src/core/ext/upbdefs-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.c +315 -293
- data/src/core/ext/upbdefs-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.h +5 -0
- data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/regex.upbdefs.c +29 -29
- data/src/core/ext/xds/xds_bootstrap_grpc.cc +33 -30
- data/src/core/ext/xds/xds_bootstrap_grpc.h +5 -13
- data/src/core/ext/xds/xds_client_grpc.cc +11 -6
- data/src/core/ext/xds/xds_client_grpc.h +16 -2
- data/src/core/ext/xds/xds_client_stats.h +10 -0
- data/src/core/ext/xds/xds_cluster.cc +26 -16
- data/src/core/ext/xds/xds_endpoint.cc +4 -7
- data/src/core/ext/xds/xds_health_status.cc +0 -17
- data/src/core/ext/xds/xds_health_status.h +5 -25
- data/src/core/ext/xds/xds_lb_policy_registry.cc +39 -0
- data/src/core/ext/xds/xds_route_config.cc +4 -0
- data/src/core/ext/xds/xds_transport_grpc.cc +1 -3
- data/src/core/lib/address_utils/parse_address.cc +63 -1
- data/src/core/lib/address_utils/parse_address.h +8 -0
- data/src/core/lib/address_utils/sockaddr_utils.cc +46 -1
- data/src/core/lib/address_utils/sockaddr_utils.h +2 -2
- data/src/core/lib/channel/channel_args.cc +21 -10
- data/src/core/lib/channel/channel_args.h +3 -0
- data/src/core/lib/channel/connected_channel.cc +4 -1
- data/src/core/lib/channel/promise_based_filter.h +1 -0
- data/src/core/lib/debug/trace.cc +1 -4
- data/src/core/lib/event_engine/cf_engine/cf_engine.cc +2 -1
- data/src/core/lib/event_engine/cf_engine/cf_engine.h +1 -1
- data/src/core/lib/event_engine/event_engine.cc +0 -12
- data/src/core/lib/event_engine/forkable.cc +47 -42
- data/src/core/lib/event_engine/handle_containers.h +0 -4
- data/src/core/lib/event_engine/posix_engine/ev_epoll1_linux.cc +4 -6
- data/src/core/lib/event_engine/posix_engine/ev_poll_posix.cc +4 -6
- data/src/core/lib/event_engine/posix_engine/posix_endpoint.cc +25 -11
- data/src/core/lib/event_engine/posix_engine/posix_endpoint.h +3 -1
- data/src/core/lib/event_engine/posix_engine/posix_engine.cc +2 -1
- data/src/core/lib/event_engine/posix_engine/posix_engine.h +8 -12
- data/src/core/lib/event_engine/posix_engine/posix_engine_listener.cc +37 -27
- data/src/core/lib/event_engine/posix_engine/posix_engine_listener.h +2 -0
- data/src/core/lib/event_engine/posix_engine/posix_engine_listener_utils.cc +4 -2
- data/src/core/lib/event_engine/posix_engine/tcp_socket_utils.cc +42 -2
- data/src/core/lib/event_engine/posix_engine/tcp_socket_utils.h +6 -0
- data/src/core/lib/event_engine/posix_engine/timer.h +10 -37
- data/src/core/lib/event_engine/tcp_socket_utils.cc +67 -7
- data/src/core/lib/event_engine/tcp_socket_utils.h +3 -0
- data/src/core/lib/event_engine/thread_pool/work_stealing_thread_pool.cc +90 -37
- data/src/core/lib/event_engine/thread_pool/work_stealing_thread_pool.h +32 -12
- data/src/core/lib/event_engine/thready_event_engine/thready_event_engine.cc +12 -21
- data/src/core/lib/event_engine/thready_event_engine/thready_event_engine.h +8 -12
- data/src/core/lib/event_engine/windows/windows_endpoint.cc +55 -54
- data/src/core/lib/event_engine/windows/windows_endpoint.h +15 -12
- data/src/core/lib/event_engine/windows/windows_engine.cc +2 -1
- data/src/core/lib/event_engine/windows/windows_engine.h +8 -12
- data/src/core/lib/experiments/config.cc +60 -22
- data/src/core/lib/experiments/config.h +20 -8
- data/src/core/lib/experiments/experiments.cc +278 -0
- data/src/core/lib/experiments/experiments.h +59 -1
- data/src/core/lib/gprpp/dual_ref_counted.h +9 -9
- data/src/core/lib/gprpp/fork.cc +8 -9
- data/src/core/lib/gprpp/fork.h +6 -5
- data/src/core/lib/gprpp/if_list.h +4530 -0
- data/src/core/lib/gprpp/orphanable.h +3 -3
- data/src/core/lib/gprpp/ref_counted.h +6 -6
- data/src/core/lib/gprpp/sorted_pack.h +3 -12
- data/src/core/lib/gprpp/status_helper.h +16 -15
- data/src/core/lib/gprpp/time.h +12 -0
- data/src/core/lib/gprpp/type_list.h +32 -0
- data/src/core/lib/http/httpcli.h +6 -9
- data/src/core/lib/iomgr/error.cc +32 -2
- data/src/core/lib/iomgr/error.h +9 -10
- data/src/core/lib/iomgr/ev_epoll1_linux.cc +5 -7
- data/src/core/lib/iomgr/ev_poll_posix.cc +6 -5
- data/src/core/lib/iomgr/exec_ctx.h +11 -0
- data/src/core/lib/iomgr/pollset.h +4 -5
- data/src/core/lib/iomgr/port.h +10 -0
- data/src/core/lib/iomgr/resolve_address.cc +13 -1
- data/src/core/lib/iomgr/resolve_address.h +17 -3
- data/src/core/lib/iomgr/sockaddr_posix.h +7 -0
- data/src/core/lib/iomgr/socket_utils_common_posix.cc +29 -0
- data/src/core/lib/iomgr/socket_utils_posix.cc +2 -0
- data/src/core/lib/iomgr/socket_utils_posix.h +6 -0
- data/src/core/lib/iomgr/tcp_client_posix.cc +4 -1
- data/src/core/lib/iomgr/tcp_posix.cc +21 -4
- data/src/core/lib/iomgr/tcp_server_posix.cc +3 -2
- data/src/core/lib/iomgr/tcp_server_utils_posix_common.cc +5 -2
- data/src/core/lib/iomgr/tcp_windows.cc +1 -3
- data/src/core/lib/iomgr/vsock.cc +59 -0
- data/src/core/lib/iomgr/vsock.h +38 -0
- data/src/core/lib/iomgr/wakeup_fd_posix.h +3 -6
- data/src/core/lib/load_balancing/delegating_helper.h +115 -0
- data/src/core/lib/load_balancing/lb_policy.h +20 -0
- data/src/core/lib/load_balancing/subchannel_interface.h +6 -0
- data/src/core/lib/promise/party.h +1 -1
- data/src/core/lib/resolver/resolver_factory.h +3 -2
- data/src/core/lib/resolver/server_address.cc +9 -94
- data/src/core/lib/resolver/server_address.h +10 -64
- data/src/core/lib/resource_quota/memory_quota.h +1 -1
- data/src/core/lib/security/credentials/channel_creds_registry.h +51 -27
- data/src/core/lib/security/credentials/channel_creds_registry_init.cc +169 -9
- data/src/core/lib/security/credentials/composite/composite_credentials.cc +1 -1
- data/src/core/lib/security/credentials/composite/composite_credentials.h +3 -1
- data/src/core/lib/security/credentials/external/external_account_credentials.cc +40 -1
- data/src/core/lib/security/credentials/external/external_account_credentials.h +6 -0
- data/src/core/lib/security/credentials/fake/fake_credentials.cc +30 -38
- data/src/core/lib/security/credentials/fake/fake_credentials.h +28 -0
- data/src/core/lib/security/credentials/tls/tls_credentials.cc +1 -1
- data/src/core/lib/security/credentials/tls/tls_credentials.h +3 -1
- data/src/core/lib/service_config/service_config_call_data.h +5 -0
- data/src/core/lib/slice/slice.h +16 -0
- data/src/core/lib/surface/call.cc +31 -29
- data/src/core/lib/surface/server.h +2 -2
- data/src/core/lib/surface/version.cc +2 -2
- data/src/core/lib/transport/metadata_batch.cc +7 -7
- data/src/core/lib/transport/metadata_batch.h +86 -48
- data/src/core/lib/transport/parsed_metadata.h +34 -20
- data/src/core/lib/transport/simple_slice_based_metadata.h +9 -2
- data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_record_protocol_common.cc +4 -6
- data/src/core/tsi/alts/zero_copy_frame_protector/alts_zero_copy_grpc_protector.cc +1 -2
- data/src/core/tsi/ssl_transport_security.cc +28 -7
- data/src/ruby/bin/math_pb.rb +24 -18
- data/src/ruby/ext/grpc/extconf.rb +19 -18
- data/src/ruby/ext/grpc/rb_call.c +62 -39
- data/src/ruby/ext/grpc/rb_call_credentials.c +0 -1
- data/src/ruby/ext/grpc/rb_channel.c +126 -49
- data/src/ruby/ext/grpc/rb_channel.h +1 -0
- data/src/ruby/ext/grpc/rb_channel_args.c +16 -2
- data/src/ruby/ext/grpc/rb_channel_args.h +4 -0
- data/src/ruby/ext/grpc/rb_channel_credentials.c +0 -1
- data/src/ruby/ext/grpc/rb_compression_options.c +0 -1
- data/src/ruby/ext/grpc/rb_event_thread.c +22 -6
- data/src/ruby/ext/grpc/rb_event_thread.h +1 -0
- data/src/ruby/ext/grpc/rb_grpc.c +192 -30
- data/src/ruby/ext/grpc/rb_grpc.h +8 -2
- data/src/ruby/ext/grpc/rb_server.c +62 -45
- data/src/ruby/ext/grpc/rb_server_credentials.c +0 -1
- data/src/ruby/ext/grpc/rb_xds_channel_credentials.c +0 -1
- data/src/ruby/ext/grpc/rb_xds_server_credentials.c +0 -1
- data/src/ruby/lib/grpc/generic/bidi_call.rb +2 -0
- data/src/ruby/lib/grpc/version.rb +1 -1
- data/src/ruby/pb/grpc/health/v1/health_pb.rb +24 -13
- data/src/ruby/pb/src/proto/grpc/testing/empty_pb.rb +24 -3
- data/src/ruby/pb/src/proto/grpc/testing/messages_pb.rb +25 -111
- data/src/ruby/pb/src/proto/grpc/testing/test_pb.rb +25 -2
- data/third_party/boringssl-with-bazel/err_data.c +552 -552
- data/third_party/boringssl-with-bazel/src/crypto/asn1/a_strnid.c +5 -5
- data/third_party/boringssl-with-bazel/src/crypto/asn1/a_time.c +34 -1
- data/third_party/boringssl-with-bazel/src/crypto/asn1/a_utctm.c +4 -1
- data/third_party/boringssl-with-bazel/src/crypto/bio/bio.c +3 -3
- data/third_party/boringssl-with-bazel/src/crypto/bio/bio_mem.c +7 -8
- data/third_party/boringssl-with-bazel/src/crypto/bio/connect.c +2 -2
- data/third_party/boringssl-with-bazel/src/crypto/bio/fd.c +2 -2
- data/third_party/boringssl-with-bazel/src/crypto/bio/file.c +8 -8
- data/third_party/boringssl-with-bazel/src/crypto/bio/socket.c +2 -2
- data/third_party/boringssl-with-bazel/src/crypto/bio/socket_helper.c +2 -2
- data/third_party/boringssl-with-bazel/src/crypto/chacha/chacha.c +19 -1
- data/third_party/boringssl-with-bazel/src/crypto/chacha/internal.h +8 -1
- data/third_party/boringssl-with-bazel/src/crypto/conf/conf.c +28 -185
- data/third_party/boringssl-with-bazel/src/crypto/conf/conf_def.h +3 -7
- data/third_party/boringssl-with-bazel/src/crypto/conf/internal.h +8 -0
- data/third_party/boringssl-with-bazel/src/crypto/cpu_aarch64_apple.c +3 -0
- data/third_party/boringssl-with-bazel/src/crypto/curve25519/curve25519.c +49 -46
- data/third_party/boringssl-with-bazel/src/crypto/curve25519/curve25519_64_adx.c +18 -0
- data/third_party/boringssl-with-bazel/src/crypto/curve25519/curve25519_tables.h +2809 -7417
- data/third_party/boringssl-with-bazel/src/crypto/curve25519/internal.h +27 -5
- data/third_party/boringssl-with-bazel/src/crypto/dsa/internal.h +20 -0
- data/third_party/boringssl-with-bazel/src/crypto/ec_extra/ec_asn1.c +110 -72
- data/third_party/boringssl-with-bazel/src/crypto/ec_extra/ec_derive.c +4 -3
- data/third_party/boringssl-with-bazel/src/crypto/ec_extra/hash_to_curve.c +15 -14
- data/third_party/boringssl-with-bazel/src/crypto/err/err.c +13 -10
- data/third_party/boringssl-with-bazel/src/crypto/evp/evp.c +35 -12
- data/third_party/boringssl-with-bazel/src/crypto/evp/p_ec.c +2 -4
- data/third_party/boringssl-with-bazel/src/crypto/evp/p_ec_asn1.c +3 -7
- data/third_party/boringssl-with-bazel/src/crypto/evp/pbkdf.c +3 -3
- data/third_party/boringssl-with-bazel/src/crypto/evp/print.c +7 -6
- data/third_party/boringssl-with-bazel/src/crypto/ex_data.c +34 -72
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bcm.c +1 -1
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/div.c +12 -5
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/gcd.c +5 -6
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/internal.h +12 -6
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/montgomery.c +17 -18
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/montgomery_inv.c +51 -15
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/rsaz_exp.c +7 -7
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/delocate.h +5 -6
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/dh/internal.h +2 -0
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/builtin_curves.h +277 -0
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/ec.c +180 -404
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/ec_key.c +3 -3
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/ec_montgomery.c +24 -57
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/felem.c +17 -13
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/internal.h +33 -71
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/oct.c +18 -17
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p224-64.c +5 -7
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p256-nistz.c +15 -18
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p256.c +9 -11
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/scalar.c +24 -24
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/simple.c +11 -27
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/simple_mul.c +8 -8
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/wnaf.c +4 -4
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ecdsa/ecdsa.c +9 -3
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/hkdf/hkdf.c +1 -1
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/fork_detect.c +40 -26
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/internal.h +21 -7
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/rand.c +38 -19
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/urandom.c +2 -29
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/internal.h +55 -0
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/rsa_impl.c +33 -52
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/self_check/self_check.c +3 -8
- data/third_party/boringssl-with-bazel/src/crypto/internal.h +198 -79
- data/third_party/boringssl-with-bazel/src/crypto/kyber/kyber.c +5 -4
- data/third_party/boringssl-with-bazel/src/crypto/mem.c +7 -8
- data/third_party/boringssl-with-bazel/src/crypto/obj/obj.c +19 -23
- data/third_party/boringssl-with-bazel/src/crypto/pkcs8/internal.h +3 -3
- data/third_party/boringssl-with-bazel/src/crypto/pkcs8/p5_pbev2.c +3 -3
- data/third_party/boringssl-with-bazel/src/crypto/pkcs8/pkcs8.c +7 -7
- data/third_party/boringssl-with-bazel/src/crypto/pkcs8/pkcs8_x509.c +8 -5
- data/third_party/boringssl-with-bazel/src/crypto/pool/internal.h +1 -0
- data/third_party/boringssl-with-bazel/src/crypto/rand_extra/deterministic.c +7 -6
- data/third_party/boringssl-with-bazel/src/crypto/rand_extra/forkunsafe.c +6 -12
- data/third_party/boringssl-with-bazel/src/crypto/rand_extra/getentropy.c +48 -0
- data/third_party/boringssl-with-bazel/src/crypto/rand_extra/{fuchsia.c → ios.c} +8 -8
- data/third_party/boringssl-with-bazel/src/crypto/{refcount_no_threads.c → rand_extra/trusty.c} +15 -19
- data/third_party/boringssl-with-bazel/src/crypto/rand_extra/windows.c +41 -19
- data/third_party/boringssl-with-bazel/src/crypto/{refcount_c11.c → refcount.c} +11 -17
- data/third_party/boringssl-with-bazel/src/crypto/stack/stack.c +147 -72
- data/third_party/boringssl-with-bazel/src/crypto/thread_none.c +0 -8
- data/third_party/boringssl-with-bazel/src/crypto/thread_pthread.c +6 -35
- data/third_party/boringssl-with-bazel/src/crypto/thread_win.c +5 -26
- data/third_party/boringssl-with-bazel/src/crypto/trust_token/pmbtoken.c +14 -18
- data/third_party/boringssl-with-bazel/src/crypto/trust_token/voprf.c +54 -143
- data/third_party/boringssl-with-bazel/src/crypto/x509/by_dir.c +7 -13
- data/third_party/boringssl-with-bazel/src/crypto/x509/internal.h +1 -1
- data/third_party/boringssl-with-bazel/src/crypto/x509/x509_att.c +1 -1
- data/third_party/boringssl-with-bazel/src/crypto/x509/x509_lu.c +2 -4
- data/third_party/boringssl-with-bazel/src/crypto/x509/x509_req.c +2 -2
- data/third_party/boringssl-with-bazel/src/crypto/x509/x509_trs.c +1 -1
- data/third_party/boringssl-with-bazel/src/crypto/x509/x509_v3.c +8 -12
- data/third_party/boringssl-with-bazel/src/crypto/x509/x509_vfy.c +19 -20
- data/third_party/boringssl-with-bazel/src/crypto/x509/x509name.c +11 -15
- data/third_party/boringssl-with-bazel/src/crypto/x509/x_crl.c +5 -5
- data/third_party/boringssl-with-bazel/src/crypto/x509/x_name.c +1 -1
- data/third_party/boringssl-with-bazel/src/crypto/x509/x_pubkey.c +7 -7
- data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_lib.c +2 -3
- data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_purp.c +4 -6
- data/third_party/boringssl-with-bazel/src/include/openssl/arm_arch.h +4 -119
- data/third_party/boringssl-with-bazel/src/include/openssl/asm_base.h +207 -0
- data/third_party/boringssl-with-bazel/src/include/openssl/asn1.h +5 -0
- data/third_party/boringssl-with-bazel/src/include/openssl/base.h +2 -116
- data/third_party/boringssl-with-bazel/src/include/openssl/bn.h +0 -2
- data/third_party/boringssl-with-bazel/src/include/openssl/chacha.h +6 -0
- data/third_party/boringssl-with-bazel/src/include/openssl/conf.h +5 -1
- data/third_party/boringssl-with-bazel/src/include/openssl/dsa.h +0 -21
- data/third_party/boringssl-with-bazel/src/include/openssl/ec.h +21 -2
- data/third_party/boringssl-with-bazel/src/include/openssl/ec_key.h +19 -6
- data/third_party/boringssl-with-bazel/src/include/openssl/evp.h +11 -7
- data/third_party/boringssl-with-bazel/src/include/openssl/rand.h +13 -14
- data/third_party/boringssl-with-bazel/src/include/openssl/rsa.h +0 -61
- data/third_party/boringssl-with-bazel/src/include/openssl/ssl.h +127 -81
- data/third_party/boringssl-with-bazel/src/include/openssl/stack.h +224 -209
- data/third_party/boringssl-with-bazel/src/include/openssl/target.h +154 -0
- data/third_party/boringssl-with-bazel/src/include/openssl/thread.h +1 -29
- data/third_party/boringssl-with-bazel/src/include/openssl/x509.h +4 -4
- data/third_party/boringssl-with-bazel/src/include/openssl/x509v3.h +3 -2
- data/third_party/boringssl-with-bazel/src/ssl/extensions.cc +9 -65
- data/third_party/boringssl-with-bazel/src/ssl/handoff.cc +20 -20
- data/third_party/boringssl-with-bazel/src/ssl/handshake_server.cc +1 -1
- data/third_party/boringssl-with-bazel/src/ssl/internal.h +4 -11
- data/third_party/boringssl-with-bazel/src/ssl/ssl_cipher.cc +24 -18
- data/third_party/boringssl-with-bazel/src/ssl/ssl_key_share.cc +37 -30
- data/third_party/boringssl-with-bazel/src/ssl/ssl_lib.cc +125 -26
- data/third_party/boringssl-with-bazel/src/ssl/tls13_client.cc +2 -3
- data/third_party/boringssl-with-bazel/src/third_party/fiat/curve25519_64_adx.h +691 -0
- data/third_party/upb/upb/collections/map.c +3 -3
- metadata +27 -12
- data/src/core/ext/filters/client_channel/lb_policy/xds/xds_attributes.cc +0 -42
- data/src/core/ext/filters/client_channel/lb_policy/xds/xds_attributes.h +0 -64
- data/src/core/ext/transport/chttp2/transport/stream_map.cc +0 -177
- data/src/core/ext/transport/chttp2/transport/stream_map.h +0 -68
- data/third_party/boringssl-with-bazel/src/crypto/refcount_win.c +0 -89
@@ -57,22 +57,38 @@
|
|
57
57
|
#include <openssl/stack.h>
|
58
58
|
|
59
59
|
#include <assert.h>
|
60
|
+
#include <limits.h>
|
60
61
|
|
62
|
+
#include <openssl/err.h>
|
61
63
|
#include <openssl/mem.h>
|
62
64
|
|
63
65
|
#include "../internal.h"
|
64
66
|
|
65
67
|
|
68
|
+
struct stack_st {
|
69
|
+
// num contains the number of valid pointers in |data|.
|
70
|
+
size_t num;
|
71
|
+
void **data;
|
72
|
+
// sorted is non-zero if the values pointed to by |data| are in ascending
|
73
|
+
// order, based on |comp|.
|
74
|
+
int sorted;
|
75
|
+
// num_alloc contains the number of pointers allocated in the buffer pointed
|
76
|
+
// to by |data|, which may be larger than |num|.
|
77
|
+
size_t num_alloc;
|
78
|
+
// comp is an optional comparison function.
|
79
|
+
OPENSSL_sk_cmp_func comp;
|
80
|
+
};
|
81
|
+
|
66
82
|
// kMinSize is the number of pointers that will be initially allocated in a new
|
67
83
|
// stack.
|
68
84
|
static const size_t kMinSize = 4;
|
69
85
|
|
70
|
-
|
71
|
-
|
86
|
+
OPENSSL_STACK *OPENSSL_sk_new(OPENSSL_sk_cmp_func comp) {
|
87
|
+
OPENSSL_STACK *ret = OPENSSL_malloc(sizeof(OPENSSL_STACK));
|
72
88
|
if (ret == NULL) {
|
73
89
|
return NULL;
|
74
90
|
}
|
75
|
-
OPENSSL_memset(ret, 0, sizeof(
|
91
|
+
OPENSSL_memset(ret, 0, sizeof(OPENSSL_STACK));
|
76
92
|
|
77
93
|
ret->data = OPENSSL_malloc(sizeof(void *) * kMinSize);
|
78
94
|
if (ret->data == NULL) {
|
@@ -91,16 +107,16 @@ err:
|
|
91
107
|
return NULL;
|
92
108
|
}
|
93
109
|
|
94
|
-
|
110
|
+
OPENSSL_STACK *OPENSSL_sk_new_null(void) { return OPENSSL_sk_new(NULL); }
|
95
111
|
|
96
|
-
size_t
|
112
|
+
size_t OPENSSL_sk_num(const OPENSSL_STACK *sk) {
|
97
113
|
if (sk == NULL) {
|
98
114
|
return 0;
|
99
115
|
}
|
100
116
|
return sk->num;
|
101
117
|
}
|
102
118
|
|
103
|
-
void
|
119
|
+
void OPENSSL_sk_zero(OPENSSL_STACK *sk) {
|
104
120
|
if (sk == NULL || sk->num == 0) {
|
105
121
|
return;
|
106
122
|
}
|
@@ -109,21 +125,21 @@ void sk_zero(_STACK *sk) {
|
|
109
125
|
sk->sorted = 0;
|
110
126
|
}
|
111
127
|
|
112
|
-
void *
|
128
|
+
void *OPENSSL_sk_value(const OPENSSL_STACK *sk, size_t i) {
|
113
129
|
if (!sk || i >= sk->num) {
|
114
130
|
return NULL;
|
115
131
|
}
|
116
132
|
return sk->data[i];
|
117
133
|
}
|
118
134
|
|
119
|
-
void *
|
135
|
+
void *OPENSSL_sk_set(OPENSSL_STACK *sk, size_t i, void *value) {
|
120
136
|
if (!sk || i >= sk->num) {
|
121
137
|
return NULL;
|
122
138
|
}
|
123
139
|
return sk->data[i] = value;
|
124
140
|
}
|
125
141
|
|
126
|
-
void
|
142
|
+
void OPENSSL_sk_free(OPENSSL_STACK *sk) {
|
127
143
|
if (sk == NULL) {
|
128
144
|
return;
|
129
145
|
}
|
@@ -131,8 +147,9 @@ void sk_free(_STACK *sk) {
|
|
131
147
|
OPENSSL_free(sk);
|
132
148
|
}
|
133
149
|
|
134
|
-
void
|
135
|
-
|
150
|
+
void OPENSSL_sk_pop_free_ex(OPENSSL_STACK *sk,
|
151
|
+
OPENSSL_sk_call_free_func call_free_func,
|
152
|
+
OPENSSL_sk_free_func free_func) {
|
136
153
|
if (sk == NULL) {
|
137
154
|
return;
|
138
155
|
}
|
@@ -142,7 +159,7 @@ void sk_pop_free_ex(_STACK *sk, OPENSSL_sk_call_free_func call_free_func,
|
|
142
159
|
call_free_func(free_func, sk->data[i]);
|
143
160
|
}
|
144
161
|
}
|
145
|
-
|
162
|
+
OPENSSL_sk_free(sk);
|
146
163
|
}
|
147
164
|
|
148
165
|
// Historically, |sk_pop_free| called the function as |OPENSSL_sk_free_func|
|
@@ -152,15 +169,20 @@ static void call_free_func_legacy(OPENSSL_sk_free_func func, void *ptr) {
|
|
152
169
|
func(ptr);
|
153
170
|
}
|
154
171
|
|
155
|
-
void sk_pop_free(
|
156
|
-
|
172
|
+
void sk_pop_free(OPENSSL_STACK *sk, OPENSSL_sk_free_func free_func) {
|
173
|
+
OPENSSL_sk_pop_free_ex(sk, call_free_func_legacy, free_func);
|
157
174
|
}
|
158
175
|
|
159
|
-
size_t
|
176
|
+
size_t OPENSSL_sk_insert(OPENSSL_STACK *sk, void *p, size_t where) {
|
160
177
|
if (sk == NULL) {
|
161
178
|
return 0;
|
162
179
|
}
|
163
180
|
|
181
|
+
if (sk->num >= INT_MAX) {
|
182
|
+
OPENSSL_PUT_ERROR(CRYPTO, ERR_R_OVERFLOW);
|
183
|
+
return 0;
|
184
|
+
}
|
185
|
+
|
164
186
|
if (sk->num_alloc <= sk->num + 1) {
|
165
187
|
// Attempt to double the size of the array.
|
166
188
|
size_t new_alloc = sk->num_alloc << 1;
|
@@ -201,7 +223,7 @@ size_t sk_insert(_STACK *sk, void *p, size_t where) {
|
|
201
223
|
return sk->num;
|
202
224
|
}
|
203
225
|
|
204
|
-
void *
|
226
|
+
void *OPENSSL_sk_delete(OPENSSL_STACK *sk, size_t where) {
|
205
227
|
void *ret;
|
206
228
|
|
207
229
|
if (!sk || where >= sk->num) {
|
@@ -219,22 +241,23 @@ void *sk_delete(_STACK *sk, size_t where) {
|
|
219
241
|
return ret;
|
220
242
|
}
|
221
243
|
|
222
|
-
void *
|
244
|
+
void *OPENSSL_sk_delete_ptr(OPENSSL_STACK *sk, const void *p) {
|
223
245
|
if (sk == NULL) {
|
224
246
|
return NULL;
|
225
247
|
}
|
226
248
|
|
227
249
|
for (size_t i = 0; i < sk->num; i++) {
|
228
250
|
if (sk->data[i] == p) {
|
229
|
-
return
|
251
|
+
return OPENSSL_sk_delete(sk, i);
|
230
252
|
}
|
231
253
|
}
|
232
254
|
|
233
255
|
return NULL;
|
234
256
|
}
|
235
257
|
|
236
|
-
void
|
237
|
-
|
258
|
+
void OPENSSL_sk_delete_if(OPENSSL_STACK *sk,
|
259
|
+
OPENSSL_sk_call_delete_if_func call_func,
|
260
|
+
OPENSSL_sk_delete_if_func func, void *data) {
|
238
261
|
if (sk == NULL) {
|
239
262
|
return;
|
240
263
|
}
|
@@ -249,8 +272,8 @@ void sk_delete_if(_STACK *sk, OPENSSL_sk_call_delete_if_func call_func,
|
|
249
272
|
sk->num = new_num;
|
250
273
|
}
|
251
274
|
|
252
|
-
int
|
253
|
-
|
275
|
+
int OPENSSL_sk_find(const OPENSSL_STACK *sk, size_t *out_index, const void *p,
|
276
|
+
OPENSSL_sk_call_cmp_func call_cmp_func) {
|
254
277
|
if (sk == NULL) {
|
255
278
|
return 0;
|
256
279
|
}
|
@@ -272,10 +295,9 @@ int sk_find(const _STACK *sk, size_t *out_index, const void *p,
|
|
272
295
|
return 0;
|
273
296
|
}
|
274
297
|
|
275
|
-
if (!
|
298
|
+
if (!OPENSSL_sk_is_sorted(sk)) {
|
276
299
|
for (size_t i = 0; i < sk->num; i++) {
|
277
|
-
|
278
|
-
if (call_cmp_func(sk->comp, &p, &elem) == 0) {
|
300
|
+
if (call_cmp_func(sk->comp, p, sk->data[i]) == 0) {
|
279
301
|
if (out_index) {
|
280
302
|
*out_index = i;
|
281
303
|
}
|
@@ -294,8 +316,7 @@ int sk_find(const _STACK *sk, size_t *out_index, const void *p,
|
|
294
316
|
// Bias |mid| towards |lo|. See the |r == 0| case below.
|
295
317
|
size_t mid = lo + (hi - lo - 1) / 2;
|
296
318
|
assert(lo <= mid && mid < hi);
|
297
|
-
|
298
|
-
int r = call_cmp_func(sk->comp, &p, &elem);
|
319
|
+
int r = call_cmp_func(sk->comp, p, sk->data[mid]);
|
299
320
|
if (r > 0) {
|
300
321
|
lo = mid + 1; // |mid| is too low.
|
301
322
|
} else if (r < 0) {
|
@@ -320,38 +341,40 @@ int sk_find(const _STACK *sk, size_t *out_index, const void *p,
|
|
320
341
|
return 0; // Not found.
|
321
342
|
}
|
322
343
|
|
323
|
-
void *
|
344
|
+
void *OPENSSL_sk_shift(OPENSSL_STACK *sk) {
|
324
345
|
if (sk == NULL) {
|
325
346
|
return NULL;
|
326
347
|
}
|
327
348
|
if (sk->num == 0) {
|
328
349
|
return NULL;
|
329
350
|
}
|
330
|
-
return
|
351
|
+
return OPENSSL_sk_delete(sk, 0);
|
331
352
|
}
|
332
353
|
|
333
|
-
size_t
|
354
|
+
size_t OPENSSL_sk_push(OPENSSL_STACK *sk, void *p) {
|
355
|
+
return OPENSSL_sk_insert(sk, p, sk->num);
|
356
|
+
}
|
334
357
|
|
335
|
-
void *
|
358
|
+
void *OPENSSL_sk_pop(OPENSSL_STACK *sk) {
|
336
359
|
if (sk == NULL) {
|
337
360
|
return NULL;
|
338
361
|
}
|
339
362
|
if (sk->num == 0) {
|
340
363
|
return NULL;
|
341
364
|
}
|
342
|
-
return
|
365
|
+
return OPENSSL_sk_delete(sk, sk->num - 1);
|
343
366
|
}
|
344
367
|
|
345
|
-
|
368
|
+
OPENSSL_STACK *OPENSSL_sk_dup(const OPENSSL_STACK *sk) {
|
346
369
|
if (sk == NULL) {
|
347
370
|
return NULL;
|
348
371
|
}
|
349
372
|
|
350
|
-
|
373
|
+
OPENSSL_STACK *ret = OPENSSL_malloc(sizeof(OPENSSL_STACK));
|
351
374
|
if (ret == NULL) {
|
352
375
|
return NULL;
|
353
376
|
}
|
354
|
-
OPENSSL_memset(ret, 0, sizeof(
|
377
|
+
OPENSSL_memset(ret, 0, sizeof(OPENSSL_STACK));
|
355
378
|
|
356
379
|
ret->data = OPENSSL_malloc(sizeof(void *) * sk->num_alloc);
|
357
380
|
if (ret->data == NULL) {
|
@@ -366,52 +389,88 @@ _STACK *sk_dup(const _STACK *sk) {
|
|
366
389
|
return ret;
|
367
390
|
|
368
391
|
err:
|
369
|
-
|
392
|
+
OPENSSL_sk_free(ret);
|
370
393
|
return NULL;
|
371
394
|
}
|
372
395
|
|
373
|
-
|
374
|
-
|
375
|
-
|
376
|
-
|
377
|
-
|
396
|
+
static size_t parent_idx(size_t idx) {
|
397
|
+
assert(idx > 0);
|
398
|
+
return (idx - 1) / 2;
|
399
|
+
}
|
400
|
+
|
401
|
+
static size_t left_idx(size_t idx) {
|
402
|
+
// The largest possible index is |PTRDIFF_MAX|, not |SIZE_MAX|. If
|
403
|
+
// |ptrdiff_t|, a signed type, is the same size as |size_t|, this cannot
|
404
|
+
// overflow.
|
405
|
+
assert(idx <= PTRDIFF_MAX);
|
406
|
+
static_assert(PTRDIFF_MAX <= (SIZE_MAX - 1) / 2, "2 * idx + 1 may oveflow");
|
407
|
+
return 2 * idx + 1;
|
408
|
+
}
|
409
|
+
|
410
|
+
// down_heap fixes the subtree rooted at |i|. |i|'s children must each satisfy
|
411
|
+
// the heap property. Only the first |num| elements of |sk| are considered.
|
412
|
+
static void down_heap(OPENSSL_STACK *sk, OPENSSL_sk_call_cmp_func call_cmp_func,
|
413
|
+
size_t i, size_t num) {
|
414
|
+
assert(i < num && num <= sk->num);
|
415
|
+
for (;;) {
|
416
|
+
size_t left = left_idx(i);
|
417
|
+
if (left >= num) {
|
418
|
+
break; // No left child.
|
419
|
+
}
|
420
|
+
|
421
|
+
// Swap |i| with the largest of its children.
|
422
|
+
size_t next = i;
|
423
|
+
if (call_cmp_func(sk->comp, sk->data[next], sk->data[left]) < 0) {
|
424
|
+
next = left;
|
425
|
+
}
|
426
|
+
size_t right = left + 1; // Cannot overflow because |left < num|.
|
427
|
+
if (right < num &&
|
428
|
+
call_cmp_func(sk->comp, sk->data[next], sk->data[right]) < 0) {
|
429
|
+
next = right;
|
430
|
+
}
|
378
431
|
|
379
|
-
|
380
|
-
|
381
|
-
|
432
|
+
if (i == next) {
|
433
|
+
break; // |i| is already larger than its children.
|
434
|
+
}
|
435
|
+
|
436
|
+
void *tmp = sk->data[i];
|
437
|
+
sk->data[i] = sk->data[next];
|
438
|
+
sk->data[next] = tmp;
|
439
|
+
i = next;
|
440
|
+
}
|
382
441
|
}
|
383
|
-
#endif
|
384
442
|
|
385
|
-
void
|
443
|
+
void OPENSSL_sk_sort(OPENSSL_STACK *sk,
|
444
|
+
OPENSSL_sk_call_cmp_func call_cmp_func) {
|
386
445
|
if (sk == NULL || sk->comp == NULL || sk->sorted) {
|
387
446
|
return;
|
388
447
|
}
|
389
448
|
|
390
449
|
if (sk->num >= 2) {
|
391
|
-
|
392
|
-
//
|
393
|
-
//
|
394
|
-
|
395
|
-
qsort_s(sk->data, sk->num, sizeof(void *), sort_compare, &ctx);
|
396
|
-
#else
|
397
|
-
// sk->comp is a function that takes pointers to pointers to elements, but
|
398
|
-
// qsort take a comparison function that just takes pointers to elements.
|
399
|
-
// However, since we're passing an array of pointers to qsort, we can just
|
400
|
-
// cast the comparison function and everything works.
|
401
|
-
//
|
402
|
-
// TODO(davidben): This is undefined behavior, but the call is in libc so,
|
403
|
-
// e.g., CFI does not notice. |qsort| is missing a void* parameter in its
|
404
|
-
// callback, while no one defines |qsort_r| or |qsort_s| consistently. See
|
450
|
+
// |qsort| lacks a context parameter in the comparison function for us to
|
451
|
+
// pass in |call_cmp_func| and |sk->comp|. While we could cast |sk->comp| to
|
452
|
+
// the expected type, it is undefined behavior in C can trip sanitizers.
|
453
|
+
// |qsort_r| and |qsort_s| avoid this, but using them is impractical. See
|
405
454
|
// https://stackoverflow.com/a/39561369
|
406
|
-
|
407
|
-
|
408
|
-
|
409
|
-
|
455
|
+
//
|
456
|
+
// Use our own heap sort instead. This is not performance-sensitive, so we
|
457
|
+
// optimize for simplicity and size. First, build a max-heap in place.
|
458
|
+
for (size_t i = parent_idx(sk->num - 1); i < sk->num; i--) {
|
459
|
+
down_heap(sk, call_cmp_func, i, sk->num);
|
460
|
+
}
|
461
|
+
|
462
|
+
// Iteratively remove the maximum element to populate the result in reverse.
|
463
|
+
for (size_t i = sk->num - 1; i > 0; i--) {
|
464
|
+
void *tmp = sk->data[0];
|
465
|
+
sk->data[0] = sk->data[i];
|
466
|
+
sk->data[i] = tmp;
|
467
|
+
down_heap(sk, call_cmp_func, 0, i);
|
468
|
+
}
|
410
469
|
}
|
411
470
|
sk->sorted = 1;
|
412
471
|
}
|
413
472
|
|
414
|
-
int
|
473
|
+
int OPENSSL_sk_is_sorted(const OPENSSL_STACK *sk) {
|
415
474
|
if (!sk) {
|
416
475
|
return 1;
|
417
476
|
}
|
@@ -419,7 +478,8 @@ int sk_is_sorted(const _STACK *sk) {
|
|
419
478
|
return sk->sorted || (sk->comp != NULL && sk->num < 2);
|
420
479
|
}
|
421
480
|
|
422
|
-
OPENSSL_sk_cmp_func
|
481
|
+
OPENSSL_sk_cmp_func OPENSSL_sk_set_cmp_func(OPENSSL_STACK *sk,
|
482
|
+
OPENSSL_sk_cmp_func comp) {
|
423
483
|
OPENSSL_sk_cmp_func old = sk->comp;
|
424
484
|
|
425
485
|
if (sk->comp != comp) {
|
@@ -430,11 +490,12 @@ OPENSSL_sk_cmp_func sk_set_cmp_func(_STACK *sk, OPENSSL_sk_cmp_func comp) {
|
|
430
490
|
return old;
|
431
491
|
}
|
432
492
|
|
433
|
-
|
434
|
-
|
435
|
-
|
436
|
-
|
437
|
-
|
493
|
+
OPENSSL_STACK *OPENSSL_sk_deep_copy(const OPENSSL_STACK *sk,
|
494
|
+
OPENSSL_sk_call_copy_func call_copy_func,
|
495
|
+
OPENSSL_sk_copy_func copy_func,
|
496
|
+
OPENSSL_sk_call_free_func call_free_func,
|
497
|
+
OPENSSL_sk_free_func free_func) {
|
498
|
+
OPENSSL_STACK *ret = OPENSSL_sk_dup(sk);
|
438
499
|
if (ret == NULL) {
|
439
500
|
return NULL;
|
440
501
|
}
|
@@ -450,10 +511,24 @@ _STACK *sk_deep_copy(const _STACK *sk, OPENSSL_sk_call_copy_func call_copy_func,
|
|
450
511
|
call_free_func(free_func, ret->data[j]);
|
451
512
|
}
|
452
513
|
}
|
453
|
-
|
514
|
+
OPENSSL_sk_free(ret);
|
454
515
|
return NULL;
|
455
516
|
}
|
456
517
|
}
|
457
518
|
|
458
519
|
return ret;
|
459
520
|
}
|
521
|
+
|
522
|
+
OPENSSL_STACK *sk_new_null(void) { return OPENSSL_sk_new_null(); }
|
523
|
+
|
524
|
+
size_t sk_num(const OPENSSL_STACK *sk) { return OPENSSL_sk_num(sk); }
|
525
|
+
|
526
|
+
void *sk_value(const OPENSSL_STACK *sk, size_t i) {
|
527
|
+
return OPENSSL_sk_value(sk, i);
|
528
|
+
}
|
529
|
+
|
530
|
+
void sk_free(OPENSSL_STACK *sk) { OPENSSL_sk_free(sk); }
|
531
|
+
|
532
|
+
size_t sk_push(OPENSSL_STACK *sk, void *p) { return OPENSSL_sk_push(sk, p); }
|
533
|
+
|
534
|
+
void *sk_pop(OPENSSL_STACK *sk) { return OPENSSL_sk_pop(sk); }
|
@@ -28,14 +28,6 @@ void CRYPTO_MUTEX_unlock_write(CRYPTO_MUTEX *lock) {}
|
|
28
28
|
|
29
29
|
void CRYPTO_MUTEX_cleanup(CRYPTO_MUTEX *lock) {}
|
30
30
|
|
31
|
-
void CRYPTO_STATIC_MUTEX_lock_read(struct CRYPTO_STATIC_MUTEX *lock) {}
|
32
|
-
|
33
|
-
void CRYPTO_STATIC_MUTEX_lock_write(struct CRYPTO_STATIC_MUTEX *lock) {}
|
34
|
-
|
35
|
-
void CRYPTO_STATIC_MUTEX_unlock_read(struct CRYPTO_STATIC_MUTEX *lock) {}
|
36
|
-
|
37
|
-
void CRYPTO_STATIC_MUTEX_unlock_write(struct CRYPTO_STATIC_MUTEX *lock) {}
|
38
|
-
|
39
31
|
void CRYPTO_once(CRYPTO_once_t *once, void (*init)(void)) {
|
40
32
|
if (*once) {
|
41
33
|
return;
|
@@ -23,67 +23,38 @@
|
|
23
23
|
#include <stdlib.h>
|
24
24
|
#include <string.h>
|
25
25
|
|
26
|
-
static_assert(sizeof(CRYPTO_MUTEX) >= sizeof(pthread_rwlock_t),
|
27
|
-
"CRYPTO_MUTEX is too small");
|
28
|
-
static_assert(alignof(CRYPTO_MUTEX) >= alignof(pthread_rwlock_t),
|
29
|
-
"CRYPTO_MUTEX has insufficient alignment");
|
30
|
-
|
31
26
|
void CRYPTO_MUTEX_init(CRYPTO_MUTEX *lock) {
|
32
|
-
if (pthread_rwlock_init(
|
27
|
+
if (pthread_rwlock_init(lock, NULL) != 0) {
|
33
28
|
abort();
|
34
29
|
}
|
35
30
|
}
|
36
31
|
|
37
32
|
void CRYPTO_MUTEX_lock_read(CRYPTO_MUTEX *lock) {
|
38
|
-
if (pthread_rwlock_rdlock(
|
33
|
+
if (pthread_rwlock_rdlock(lock) != 0) {
|
39
34
|
abort();
|
40
35
|
}
|
41
36
|
}
|
42
37
|
|
43
38
|
void CRYPTO_MUTEX_lock_write(CRYPTO_MUTEX *lock) {
|
44
|
-
if (pthread_rwlock_wrlock(
|
39
|
+
if (pthread_rwlock_wrlock(lock) != 0) {
|
45
40
|
abort();
|
46
41
|
}
|
47
42
|
}
|
48
43
|
|
49
44
|
void CRYPTO_MUTEX_unlock_read(CRYPTO_MUTEX *lock) {
|
50
|
-
if (pthread_rwlock_unlock(
|
45
|
+
if (pthread_rwlock_unlock(lock) != 0) {
|
51
46
|
abort();
|
52
47
|
}
|
53
48
|
}
|
54
49
|
|
55
50
|
void CRYPTO_MUTEX_unlock_write(CRYPTO_MUTEX *lock) {
|
56
|
-
if (pthread_rwlock_unlock(
|
51
|
+
if (pthread_rwlock_unlock(lock) != 0) {
|
57
52
|
abort();
|
58
53
|
}
|
59
54
|
}
|
60
55
|
|
61
56
|
void CRYPTO_MUTEX_cleanup(CRYPTO_MUTEX *lock) {
|
62
|
-
pthread_rwlock_destroy(
|
63
|
-
}
|
64
|
-
|
65
|
-
void CRYPTO_STATIC_MUTEX_lock_read(struct CRYPTO_STATIC_MUTEX *lock) {
|
66
|
-
if (pthread_rwlock_rdlock(&lock->lock) != 0) {
|
67
|
-
abort();
|
68
|
-
}
|
69
|
-
}
|
70
|
-
|
71
|
-
void CRYPTO_STATIC_MUTEX_lock_write(struct CRYPTO_STATIC_MUTEX *lock) {
|
72
|
-
if (pthread_rwlock_wrlock(&lock->lock) != 0) {
|
73
|
-
abort();
|
74
|
-
}
|
75
|
-
}
|
76
|
-
|
77
|
-
void CRYPTO_STATIC_MUTEX_unlock_read(struct CRYPTO_STATIC_MUTEX *lock) {
|
78
|
-
if (pthread_rwlock_unlock(&lock->lock) != 0) {
|
79
|
-
abort();
|
80
|
-
}
|
81
|
-
}
|
82
|
-
|
83
|
-
void CRYPTO_STATIC_MUTEX_unlock_write(struct CRYPTO_STATIC_MUTEX *lock) {
|
84
|
-
if (pthread_rwlock_unlock(&lock->lock) != 0) {
|
85
|
-
abort();
|
86
|
-
}
|
57
|
+
pthread_rwlock_destroy(lock);
|
87
58
|
}
|
88
59
|
|
89
60
|
void CRYPTO_once(CRYPTO_once_t *once, void (*init)(void)) {
|
@@ -26,11 +26,6 @@ OPENSSL_MSVC_PRAGMA(warning(pop))
|
|
26
26
|
#include <stdlib.h>
|
27
27
|
#include <string.h>
|
28
28
|
|
29
|
-
static_assert(sizeof(CRYPTO_MUTEX) >= sizeof(SRWLOCK),
|
30
|
-
"CRYPTO_MUTEX is too small");
|
31
|
-
static_assert(alignof(CRYPTO_MUTEX) >= alignof(SRWLOCK),
|
32
|
-
"CRYPTO_MUTEX has insufficient alignment");
|
33
|
-
|
34
29
|
static BOOL CALLBACK call_once_init(INIT_ONCE *once, void *arg, void **out) {
|
35
30
|
void (**init)(void) = (void (**)(void))arg;
|
36
31
|
(**init)();
|
@@ -44,45 +39,29 @@ void CRYPTO_once(CRYPTO_once_t *once, void (*init)(void)) {
|
|
44
39
|
}
|
45
40
|
|
46
41
|
void CRYPTO_MUTEX_init(CRYPTO_MUTEX *lock) {
|
47
|
-
InitializeSRWLock(
|
42
|
+
InitializeSRWLock(lock);
|
48
43
|
}
|
49
44
|
|
50
45
|
void CRYPTO_MUTEX_lock_read(CRYPTO_MUTEX *lock) {
|
51
|
-
AcquireSRWLockShared(
|
46
|
+
AcquireSRWLockShared(lock);
|
52
47
|
}
|
53
48
|
|
54
49
|
void CRYPTO_MUTEX_lock_write(CRYPTO_MUTEX *lock) {
|
55
|
-
AcquireSRWLockExclusive(
|
50
|
+
AcquireSRWLockExclusive(lock);
|
56
51
|
}
|
57
52
|
|
58
53
|
void CRYPTO_MUTEX_unlock_read(CRYPTO_MUTEX *lock) {
|
59
|
-
ReleaseSRWLockShared(
|
54
|
+
ReleaseSRWLockShared(lock);
|
60
55
|
}
|
61
56
|
|
62
57
|
void CRYPTO_MUTEX_unlock_write(CRYPTO_MUTEX *lock) {
|
63
|
-
ReleaseSRWLockExclusive(
|
58
|
+
ReleaseSRWLockExclusive(lock);
|
64
59
|
}
|
65
60
|
|
66
61
|
void CRYPTO_MUTEX_cleanup(CRYPTO_MUTEX *lock) {
|
67
62
|
// SRWLOCKs require no cleanup.
|
68
63
|
}
|
69
64
|
|
70
|
-
void CRYPTO_STATIC_MUTEX_lock_read(struct CRYPTO_STATIC_MUTEX *lock) {
|
71
|
-
AcquireSRWLockShared(&lock->lock);
|
72
|
-
}
|
73
|
-
|
74
|
-
void CRYPTO_STATIC_MUTEX_lock_write(struct CRYPTO_STATIC_MUTEX *lock) {
|
75
|
-
AcquireSRWLockExclusive(&lock->lock);
|
76
|
-
}
|
77
|
-
|
78
|
-
void CRYPTO_STATIC_MUTEX_unlock_read(struct CRYPTO_STATIC_MUTEX *lock) {
|
79
|
-
ReleaseSRWLockShared(&lock->lock);
|
80
|
-
}
|
81
|
-
|
82
|
-
void CRYPTO_STATIC_MUTEX_unlock_write(struct CRYPTO_STATIC_MUTEX *lock) {
|
83
|
-
ReleaseSRWLockExclusive(&lock->lock);
|
84
|
-
}
|
85
|
-
|
86
65
|
static SRWLOCK g_destructors_lock = SRWLOCK_INIT;
|
87
66
|
static thread_local_destructor_t g_destructors[NUM_OPENSSL_THREAD_LOCALS];
|
88
67
|
|