grpc 1.24.0 → 1.25.0
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 +306 -243
- data/etc/roots.pem +0 -100
- data/include/grpc/grpc_security.h +44 -18
- data/include/grpc/impl/codegen/grpc_types.h +15 -0
- data/include/grpc/impl/codegen/port_platform.h +27 -11
- data/include/grpc/impl/codegen/sync_generic.h +1 -1
- data/src/boringssl/err_data.c +695 -650
- data/src/core/ext/filters/client_channel/client_channel.cc +257 -179
- data/src/core/ext/filters/client_channel/client_channel.h +24 -0
- data/src/core/ext/filters/client_channel/client_channel_channelz.cc +2 -3
- data/src/core/ext/filters/client_channel/client_channel_factory.h +1 -5
- data/src/core/ext/filters/client_channel/health/health_check_client.cc +18 -45
- data/src/core/ext/filters/client_channel/health/health_check_client.h +5 -13
- data/src/core/ext/filters/client_channel/http_connect_handshaker.cc +1 -1
- data/src/core/ext/filters/client_channel/lb_policy.cc +2 -3
- data/src/core/ext/filters/client_channel/lb_policy.h +65 -55
- data/src/core/ext/filters/client_channel/lb_policy/grpclb/client_load_reporting_filter.cc +14 -14
- data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb.cc +113 -36
- data/src/core/ext/filters/client_channel/lb_policy/pick_first/pick_first.cc +14 -19
- data/src/core/ext/filters/client_channel/lb_policy/round_robin/round_robin.cc +36 -13
- data/src/core/ext/filters/client_channel/lb_policy/subchannel_list.h +3 -10
- data/src/core/ext/filters/client_channel/lb_policy/xds/xds.cc +814 -1589
- data/src/core/ext/filters/client_channel/lb_policy/xds/xds.h +2 -5
- data/src/core/ext/filters/client_channel/lb_policy_factory.h +3 -6
- data/src/core/ext/filters/client_channel/resolver.cc +1 -2
- data/src/core/ext/filters/client_channel/resolver.h +8 -16
- data/src/core/ext/filters/client_channel/resolver/dns/c_ares/dns_resolver_ares.cc +25 -8
- data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver.cc +46 -12
- data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver.h +10 -17
- data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver_libuv.cc +7 -8
- data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver_posix.cc +4 -4
- data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver_windows.cc +111 -44
- data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.cc +22 -14
- data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.h +1 -1
- data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper_fallback.cc +2 -2
- data/src/core/ext/filters/client_channel/resolver/dns/native/dns_resolver.cc +29 -10
- data/src/core/ext/filters/client_channel/resolver/fake/fake_resolver.cc +27 -36
- data/src/core/ext/filters/client_channel/resolver/sockaddr/sockaddr_resolver.cc +7 -10
- data/src/core/ext/filters/client_channel/resolver/xds/xds_resolver.cc +60 -16
- data/src/core/ext/filters/client_channel/resolver_factory.h +4 -8
- data/src/core/ext/filters/client_channel/resolver_registry.cc +1 -1
- data/src/core/ext/filters/client_channel/resolver_registry.h +1 -1
- data/src/core/ext/filters/client_channel/resolver_result_parsing.cc +7 -10
- data/src/core/ext/filters/client_channel/resolving_lb_policy.cc +7 -8
- data/src/core/ext/filters/client_channel/resolving_lb_policy.h +1 -1
- data/src/core/ext/filters/client_channel/retry_throttle.cc +5 -5
- data/src/core/ext/filters/client_channel/retry_throttle.h +1 -4
- data/src/core/ext/filters/client_channel/service_config.h +8 -8
- data/src/core/ext/filters/client_channel/subchannel.cc +53 -86
- data/src/core/ext/filters/client_channel/subchannel.h +7 -9
- data/src/core/ext/filters/client_channel/subchannel_interface.h +9 -13
- data/src/core/ext/filters/client_channel/subchannel_pool_interface.h +3 -6
- data/src/core/ext/filters/client_channel/{lb_policy/xds/xds_load_balancer_api.cc → xds/xds_api.cc} +169 -52
- data/src/core/ext/filters/client_channel/xds/xds_api.h +171 -0
- data/src/core/ext/filters/client_channel/xds/xds_bootstrap.cc +450 -0
- data/src/core/ext/filters/client_channel/xds/xds_bootstrap.h +99 -0
- data/src/core/ext/filters/client_channel/{lb_policy/xds → xds}/xds_channel.h +8 -6
- data/src/core/ext/filters/client_channel/xds/xds_channel_args.h +26 -0
- data/src/core/ext/filters/client_channel/{lb_policy/xds → xds}/xds_channel_secure.cc +28 -11
- data/src/core/ext/filters/client_channel/xds/xds_client.cc +1413 -0
- data/src/core/ext/filters/client_channel/xds/xds_client.h +221 -0
- data/src/core/ext/filters/client_channel/{lb_policy/xds → xds}/xds_client_stats.cc +1 -5
- data/src/core/ext/filters/client_channel/{lb_policy/xds → xds}/xds_client_stats.h +3 -4
- data/src/core/ext/filters/deadline/deadline_filter.cc +20 -20
- data/src/core/ext/filters/http/client/http_client_filter.cc +15 -15
- data/src/core/ext/filters/http/client_authority_filter.cc +14 -14
- data/src/core/ext/filters/http/message_compress/message_compress_filter.cc +12 -12
- data/src/core/ext/filters/max_age/max_age_filter.cc +59 -50
- data/src/core/ext/filters/message_size/message_size_filter.cc +18 -18
- data/src/core/ext/filters/workarounds/workaround_cronet_compression_filter.cc +15 -14
- data/src/core/ext/transport/chttp2/transport/chttp2_transport.cc +233 -175
- data/src/core/ext/transport/chttp2/transport/flow_control.h +21 -24
- data/src/core/ext/transport/chttp2/transport/hpack_encoder.cc +253 -163
- data/src/core/ext/transport/chttp2/transport/hpack_encoder.h +24 -12
- data/src/core/ext/transport/chttp2/transport/hpack_parser.cc +2 -3
- data/src/core/ext/transport/chttp2/transport/internal.h +13 -15
- data/src/core/ext/transport/chttp2/transport/writing.cc +3 -0
- data/src/core/ext/transport/inproc/inproc_transport.cc +20 -13
- data/src/core/lib/channel/channel_args.cc +16 -0
- data/src/core/lib/channel/channel_args.h +22 -0
- data/src/core/lib/channel/channelz.cc +5 -6
- data/src/core/lib/channel/channelz.h +1 -1
- data/src/core/lib/channel/connected_channel.cc +20 -20
- data/src/core/lib/channel/handshaker.h +3 -4
- data/src/core/lib/channel/handshaker_factory.h +1 -3
- data/src/core/lib/debug/trace.h +3 -2
- data/src/core/lib/gprpp/arena.cc +3 -3
- data/src/core/lib/gprpp/arena.h +2 -3
- data/src/core/lib/gprpp/inlined_vector.h +9 -0
- data/src/core/lib/gprpp/map.h +3 -501
- data/src/core/lib/gprpp/memory.h +45 -41
- data/src/core/lib/gprpp/mpscq.cc +108 -0
- data/src/core/lib/gprpp/mpscq.h +98 -0
- data/src/core/lib/gprpp/orphanable.h +6 -11
- data/src/core/lib/gprpp/ref_counted.h +25 -19
- data/src/core/lib/gprpp/set.h +33 -0
- data/src/core/lib/gprpp/thd.h +2 -4
- data/src/core/lib/http/httpcli.cc +1 -1
- data/src/core/lib/http/httpcli_security_connector.cc +15 -11
- data/src/core/lib/http/parser.cc +1 -1
- data/src/core/lib/iomgr/buffer_list.cc +4 -5
- data/src/core/lib/iomgr/buffer_list.h +5 -6
- data/src/core/lib/iomgr/call_combiner.cc +4 -5
- data/src/core/lib/iomgr/call_combiner.h +2 -2
- data/src/core/lib/iomgr/cfstream_handle.h +3 -5
- data/src/core/lib/iomgr/closure.h +8 -3
- data/src/core/lib/iomgr/combiner.cc +45 -82
- data/src/core/lib/iomgr/combiner.h +32 -8
- data/src/core/lib/iomgr/endpoint_cfstream.cc +5 -3
- data/src/core/lib/iomgr/ev_epoll1_linux.cc +19 -15
- data/src/core/lib/iomgr/ev_poll_posix.cc +3 -1
- data/src/core/lib/iomgr/exec_ctx.h +4 -3
- data/src/core/lib/iomgr/executor.cc +4 -2
- data/src/core/lib/iomgr/executor.h +3 -0
- data/src/core/lib/iomgr/executor/mpmcqueue.h +3 -6
- data/src/core/lib/iomgr/executor/threadpool.cc +1 -2
- data/src/core/lib/iomgr/executor/threadpool.h +7 -11
- data/src/core/lib/iomgr/resource_quota.cc +55 -51
- data/src/core/lib/iomgr/resource_quota.h +13 -9
- data/src/core/lib/iomgr/socket_utils_common_posix.cc +13 -0
- data/src/core/lib/iomgr/socket_utils_posix.h +4 -0
- data/src/core/lib/iomgr/tcp_client_posix.cc +4 -11
- data/src/core/lib/iomgr/tcp_custom.cc +9 -7
- data/src/core/lib/iomgr/tcp_posix.cc +20 -16
- data/src/core/lib/iomgr/tcp_server.h +1 -4
- data/src/core/lib/iomgr/tcp_server_custom.cc +5 -5
- data/src/core/lib/iomgr/tcp_server_posix.cc +1 -1
- data/src/core/lib/iomgr/tcp_server_utils_posix_common.cc +2 -11
- data/src/core/lib/iomgr/timer_custom.cc +2 -2
- data/src/core/lib/iomgr/udp_server.cc +3 -2
- data/src/core/lib/iomgr/udp_server.h +6 -12
- data/src/core/lib/json/json.h +1 -1
- data/src/core/lib/json/json_string.cc +2 -2
- data/src/core/lib/profiling/basic_timers.cc +2 -2
- data/src/core/lib/security/credentials/alts/alts_credentials.cc +2 -2
- data/src/core/lib/security/credentials/alts/grpc_alts_credentials_server_options.cc +1 -1
- data/src/core/lib/security/credentials/credentials.h +4 -20
- data/src/core/lib/security/credentials/fake/fake_credentials.cc +4 -4
- data/src/core/lib/security/credentials/oauth2/oauth2_credentials.h +1 -3
- data/src/core/lib/security/credentials/tls/grpc_tls_credentials_options.h +64 -0
- data/src/core/lib/security/security_connector/alts/alts_security_connector.cc +4 -4
- data/src/core/lib/security/security_connector/fake/fake_security_connector.cc +9 -7
- data/src/core/lib/security/security_connector/load_system_roots_linux.cc +2 -0
- data/src/core/lib/security/security_connector/local/local_security_connector.cc +4 -4
- data/src/core/lib/security/security_connector/security_connector.cc +1 -0
- data/src/core/lib/security/security_connector/security_connector.h +19 -17
- data/src/core/lib/security/security_connector/ssl/ssl_security_connector.cc +8 -5
- data/src/core/lib/security/security_connector/ssl_utils.cc +2 -2
- data/src/core/lib/security/security_connector/ssl_utils.h +1 -1
- data/src/core/lib/security/security_connector/tls/spiffe_security_connector.cc +14 -6
- data/src/core/lib/security/security_connector/tls/spiffe_security_connector.h +4 -2
- data/src/core/lib/security/transport/client_auth_filter.cc +17 -17
- data/src/core/lib/security/transport/security_handshaker.cc +29 -13
- data/src/core/lib/security/transport/security_handshaker.h +4 -2
- data/src/core/lib/security/transport/server_auth_filter.cc +14 -14
- data/src/core/lib/slice/slice.cc +2 -10
- data/src/core/lib/slice/slice_hash_table.h +4 -6
- data/src/core/lib/slice/slice_intern.cc +42 -39
- data/src/core/lib/slice/slice_internal.h +3 -3
- data/src/core/lib/slice/slice_utils.h +21 -4
- data/src/core/lib/slice/slice_weak_hash_table.h +4 -6
- data/src/core/lib/surface/call.cc +3 -3
- data/src/core/lib/surface/channel.cc +7 -0
- data/src/core/lib/surface/completion_queue.cc +12 -11
- data/src/core/lib/surface/completion_queue.h +4 -2
- data/src/core/lib/surface/init.cc +1 -0
- data/src/core/lib/surface/lame_client.cc +33 -18
- data/src/core/lib/surface/server.cc +77 -76
- data/src/core/lib/surface/version.cc +1 -1
- data/src/core/lib/transport/byte_stream.h +3 -7
- data/src/core/lib/transport/connectivity_state.cc +112 -98
- data/src/core/lib/transport/connectivity_state.h +100 -50
- data/src/core/lib/transport/static_metadata.cc +276 -288
- data/src/core/lib/transport/static_metadata.h +73 -76
- data/src/core/lib/transport/status_conversion.cc +1 -1
- data/src/core/lib/transport/status_metadata.cc +1 -1
- data/src/core/lib/transport/transport.cc +2 -2
- data/src/core/lib/transport/transport.h +12 -4
- data/src/core/lib/transport/transport_op_string.cc +14 -11
- data/src/core/tsi/alts/frame_protector/alts_unseal_privacy_integrity_crypter.cc +1 -1
- data/src/core/tsi/alts/handshaker/alts_shared_resource.cc +1 -1
- data/src/core/tsi/alts/handshaker/alts_tsi_handshaker.cc +5 -5
- data/src/core/tsi/alts/zero_copy_frame_protector/alts_zero_copy_grpc_protector.cc +12 -2
- data/src/core/tsi/fake_transport_security.cc +7 -5
- data/src/core/tsi/grpc_shadow_boringssl.h +2918 -2627
- data/src/core/tsi/local_transport_security.cc +8 -6
- data/src/core/tsi/ssl/session_cache/ssl_session.h +1 -3
- data/src/core/tsi/ssl/session_cache/ssl_session_boringssl.cc +1 -2
- data/src/core/tsi/ssl/session_cache/ssl_session_cache.cc +7 -5
- data/src/core/tsi/ssl/session_cache/ssl_session_cache.h +4 -6
- data/src/core/tsi/ssl/session_cache/ssl_session_openssl.cc +1 -2
- data/src/core/tsi/ssl_transport_security.cc +12 -12
- data/src/core/tsi/ssl_transport_security.h +2 -2
- data/src/core/tsi/transport_security_grpc.cc +7 -0
- data/src/core/tsi/transport_security_grpc.h +6 -0
- data/src/ruby/ext/grpc/extconf.rb +1 -0
- data/src/ruby/ext/grpc/rb_call.c +1 -1
- data/src/ruby/ext/grpc/rb_channel.c +1 -1
- data/src/ruby/lib/grpc/generic/bidi_call.rb +1 -1
- data/src/ruby/lib/grpc/generic/rpc_server.rb +1 -1
- data/src/ruby/lib/grpc/version.rb +1 -1
- data/src/ruby/spec/google_rpc_status_utils_spec.rb +2 -2
- data/third_party/boringssl/crypto/asn1/a_bool.c +18 -5
- data/third_party/boringssl/crypto/asn1/a_d2i_fp.c +17 -221
- data/third_party/boringssl/crypto/asn1/a_dup.c +0 -24
- data/third_party/boringssl/crypto/asn1/a_enum.c +2 -2
- data/third_party/boringssl/crypto/asn1/a_i2d_fp.c +10 -72
- data/third_party/boringssl/crypto/asn1/a_int.c +12 -71
- data/third_party/boringssl/crypto/asn1/a_mbstr.c +110 -216
- data/third_party/boringssl/crypto/asn1/a_object.c +16 -5
- data/third_party/boringssl/crypto/asn1/a_strnid.c +1 -0
- data/third_party/boringssl/crypto/asn1/asn1_lib.c +5 -1
- data/third_party/boringssl/crypto/asn1/tasn_enc.c +3 -1
- data/third_party/boringssl/crypto/base64/base64.c +2 -2
- data/third_party/boringssl/crypto/bio/bio.c +73 -9
- data/third_party/boringssl/crypto/bio/connect.c +4 -0
- data/third_party/boringssl/crypto/bio/fd.c +4 -0
- data/third_party/boringssl/crypto/bio/file.c +5 -2
- data/third_party/boringssl/crypto/bio/socket.c +4 -0
- data/third_party/boringssl/crypto/bio/socket_helper.c +4 -0
- data/third_party/boringssl/crypto/bn_extra/convert.c +11 -7
- data/third_party/boringssl/crypto/bytestring/ber.c +8 -4
- data/third_party/boringssl/crypto/bytestring/cbb.c +19 -7
- data/third_party/boringssl/crypto/bytestring/cbs.c +28 -15
- data/third_party/boringssl/crypto/bytestring/internal.h +28 -7
- data/third_party/boringssl/crypto/bytestring/unicode.c +155 -0
- data/third_party/boringssl/crypto/chacha/chacha.c +36 -19
- data/third_party/boringssl/crypto/chacha/internal.h +45 -0
- data/third_party/boringssl/crypto/cipher_extra/cipher_extra.c +29 -0
- data/third_party/boringssl/crypto/cipher_extra/e_aesccm.c +269 -25
- data/third_party/boringssl/crypto/cipher_extra/e_aesctrhmac.c +16 -14
- data/third_party/boringssl/crypto/cipher_extra/e_aesgcmsiv.c +54 -38
- data/third_party/boringssl/crypto/cipher_extra/e_chacha20poly1305.c +133 -41
- data/third_party/boringssl/crypto/cipher_extra/e_tls.c +23 -15
- data/third_party/boringssl/crypto/cipher_extra/tls_cbc.c +24 -15
- data/third_party/boringssl/crypto/cmac/cmac.c +62 -25
- data/third_party/boringssl/crypto/conf/conf.c +7 -0
- data/third_party/boringssl/crypto/cpu-arm-linux.c +4 -148
- data/third_party/boringssl/crypto/cpu-arm-linux.h +201 -0
- data/third_party/boringssl/crypto/cpu-intel.c +45 -51
- data/third_party/boringssl/crypto/crypto.c +39 -22
- data/third_party/boringssl/crypto/curve25519/spake25519.c +1 -1
- data/third_party/boringssl/crypto/dsa/dsa.c +77 -53
- data/third_party/boringssl/crypto/ec_extra/ec_asn1.c +20 -8
- data/third_party/boringssl/crypto/ec_extra/ec_derive.c +96 -0
- data/third_party/boringssl/crypto/{ecdh/ecdh.c → ecdh_extra/ecdh_extra.c} +20 -58
- data/third_party/boringssl/crypto/ecdsa_extra/ecdsa_asn1.c +1 -9
- data/third_party/boringssl/crypto/engine/engine.c +2 -1
- data/third_party/boringssl/crypto/err/err.c +2 -0
- data/third_party/boringssl/crypto/err/internal.h +2 -2
- data/third_party/boringssl/crypto/evp/evp.c +89 -8
- data/third_party/boringssl/crypto/evp/evp_asn1.c +56 -5
- data/third_party/boringssl/crypto/evp/evp_ctx.c +52 -14
- data/third_party/boringssl/crypto/evp/internal.h +18 -1
- data/third_party/boringssl/crypto/evp/p_dsa_asn1.c +5 -0
- data/third_party/boringssl/crypto/evp/p_ec.c +51 -3
- data/third_party/boringssl/crypto/evp/p_ec_asn1.c +6 -7
- data/third_party/boringssl/crypto/evp/p_ed25519.c +36 -3
- data/third_party/boringssl/crypto/evp/p_ed25519_asn1.c +76 -45
- data/third_party/boringssl/crypto/evp/p_rsa.c +3 -1
- data/third_party/boringssl/crypto/evp/p_rsa_asn1.c +5 -0
- data/third_party/boringssl/crypto/evp/p_x25519.c +110 -0
- data/third_party/boringssl/crypto/evp/p_x25519_asn1.c +249 -0
- data/third_party/boringssl/crypto/evp/scrypt.c +6 -2
- data/third_party/boringssl/crypto/fipsmodule/aes/aes.c +34 -274
- data/third_party/boringssl/crypto/fipsmodule/aes/internal.h +161 -21
- data/third_party/boringssl/crypto/fipsmodule/aes/key_wrap.c +111 -13
- data/third_party/boringssl/crypto/fipsmodule/aes/mode_wrappers.c +17 -21
- data/third_party/boringssl/crypto/fipsmodule/bcm.c +119 -7
- data/third_party/boringssl/crypto/fipsmodule/bn/bn.c +19 -2
- data/third_party/boringssl/crypto/fipsmodule/bn/cmp.c +2 -2
- data/third_party/boringssl/crypto/fipsmodule/bn/ctx.c +93 -160
- data/third_party/boringssl/crypto/fipsmodule/bn/div.c +48 -57
- data/third_party/boringssl/crypto/fipsmodule/bn/div_extra.c +87 -0
- data/third_party/boringssl/crypto/fipsmodule/bn/exponentiation.c +143 -211
- data/third_party/boringssl/crypto/fipsmodule/bn/gcd.c +0 -305
- data/third_party/boringssl/crypto/fipsmodule/bn/gcd_extra.c +325 -0
- data/third_party/boringssl/crypto/fipsmodule/bn/internal.h +168 -50
- data/third_party/boringssl/crypto/fipsmodule/bn/montgomery.c +68 -92
- data/third_party/boringssl/crypto/fipsmodule/bn/montgomery_inv.c +7 -6
- data/third_party/boringssl/crypto/fipsmodule/bn/mul.c +11 -14
- data/third_party/boringssl/crypto/fipsmodule/bn/prime.c +358 -443
- data/third_party/boringssl/crypto/fipsmodule/bn/random.c +25 -35
- data/third_party/boringssl/crypto/fipsmodule/bn/rsaz_exp.c +20 -25
- data/third_party/boringssl/crypto/fipsmodule/bn/rsaz_exp.h +76 -5
- data/third_party/boringssl/crypto/fipsmodule/bn/shift.c +14 -14
- data/third_party/boringssl/crypto/fipsmodule/cipher/cipher.c +7 -2
- data/third_party/boringssl/crypto/fipsmodule/cipher/e_aes.c +383 -516
- data/third_party/boringssl/crypto/fipsmodule/cipher/e_des.c +4 -0
- data/third_party/boringssl/crypto/fipsmodule/cipher/internal.h +3 -4
- data/third_party/boringssl/crypto/fipsmodule/delocate.h +3 -2
- data/third_party/boringssl/crypto/fipsmodule/digest/digest.c +32 -17
- data/third_party/boringssl/crypto/fipsmodule/digest/md32_common.h +3 -3
- data/third_party/boringssl/crypto/fipsmodule/ec/ec.c +228 -122
- data/third_party/boringssl/crypto/fipsmodule/ec/ec_key.c +34 -8
- data/third_party/boringssl/crypto/fipsmodule/ec/ec_montgomery.c +311 -98
- data/third_party/boringssl/crypto/fipsmodule/ec/felem.c +82 -0
- data/third_party/boringssl/crypto/fipsmodule/ec/internal.h +263 -97
- data/third_party/boringssl/crypto/fipsmodule/ec/oct.c +22 -59
- data/third_party/boringssl/crypto/fipsmodule/ec/p224-64.c +317 -234
- data/third_party/boringssl/crypto/fipsmodule/ec/p256-x86_64-table.h +9473 -9475
- data/third_party/boringssl/crypto/fipsmodule/ec/p256-x86_64.c +313 -109
- data/third_party/boringssl/crypto/fipsmodule/ec/p256-x86_64.h +36 -0
- data/third_party/boringssl/crypto/fipsmodule/ec/scalar.c +96 -0
- data/third_party/boringssl/crypto/fipsmodule/ec/simple.c +126 -792
- data/third_party/boringssl/crypto/fipsmodule/ec/simple_mul.c +84 -0
- data/third_party/boringssl/crypto/fipsmodule/ec/util.c +163 -12
- data/third_party/boringssl/crypto/fipsmodule/ec/wnaf.c +84 -211
- data/third_party/boringssl/crypto/fipsmodule/ecdh/ecdh.c +122 -0
- data/third_party/boringssl/crypto/fipsmodule/ecdsa/ecdsa.c +60 -205
- data/third_party/boringssl/crypto/fipsmodule/fips_shared_support.c +32 -0
- data/third_party/boringssl/crypto/fipsmodule/is_fips.c +2 -0
- data/third_party/boringssl/crypto/fipsmodule/md4/md4.c +3 -1
- data/third_party/boringssl/crypto/fipsmodule/md5/internal.h +37 -0
- data/third_party/boringssl/crypto/fipsmodule/md5/md5.c +11 -8
- data/third_party/boringssl/crypto/fipsmodule/modes/cbc.c +35 -79
- data/third_party/boringssl/crypto/fipsmodule/modes/cfb.c +7 -39
- data/third_party/boringssl/crypto/fipsmodule/modes/ctr.c +7 -27
- data/third_party/boringssl/crypto/fipsmodule/modes/gcm.c +123 -309
- data/third_party/boringssl/crypto/fipsmodule/modes/internal.h +189 -126
- data/third_party/boringssl/crypto/fipsmodule/modes/ofb.c +3 -2
- data/third_party/boringssl/crypto/fipsmodule/rand/ctrdrbg.c +2 -2
- data/third_party/boringssl/crypto/fipsmodule/rand/internal.h +35 -0
- data/third_party/boringssl/crypto/fipsmodule/rand/rand.c +24 -19
- data/third_party/boringssl/crypto/fipsmodule/rand/urandom.c +256 -77
- data/third_party/boringssl/crypto/fipsmodule/rsa/padding.c +10 -7
- data/third_party/boringssl/crypto/fipsmodule/rsa/rsa.c +5 -1
- data/third_party/boringssl/crypto/fipsmodule/rsa/rsa_impl.c +131 -14
- data/third_party/boringssl/crypto/fipsmodule/self_check/self_check.c +83 -10
- data/third_party/boringssl/crypto/fipsmodule/sha/internal.h +53 -0
- data/third_party/boringssl/crypto/fipsmodule/sha/sha1.c +9 -13
- data/third_party/boringssl/crypto/fipsmodule/sha/sha256.c +18 -12
- data/third_party/boringssl/crypto/fipsmodule/sha/sha512.c +95 -168
- data/third_party/boringssl/crypto/hrss/hrss.c +2201 -0
- data/third_party/boringssl/crypto/hrss/internal.h +62 -0
- data/third_party/boringssl/crypto/internal.h +95 -20
- data/third_party/boringssl/crypto/lhash/lhash.c +45 -33
- data/third_party/boringssl/crypto/mem.c +39 -2
- data/third_party/boringssl/crypto/obj/obj.c +4 -4
- data/third_party/boringssl/crypto/obj/obj_dat.h +6181 -875
- data/third_party/boringssl/crypto/pem/pem_all.c +2 -3
- data/third_party/boringssl/crypto/pem/pem_info.c +144 -162
- data/third_party/boringssl/crypto/pem/pem_lib.c +53 -52
- data/third_party/boringssl/crypto/pem/pem_pkey.c +13 -21
- data/third_party/boringssl/crypto/pkcs7/pkcs7.c +15 -22
- data/third_party/boringssl/crypto/pkcs7/pkcs7_x509.c +168 -16
- data/third_party/boringssl/crypto/pkcs8/internal.h +11 -0
- data/third_party/boringssl/crypto/pkcs8/p5_pbev2.c +24 -15
- data/third_party/boringssl/crypto/pkcs8/pkcs8.c +42 -25
- data/third_party/boringssl/crypto/pkcs8/pkcs8_x509.c +559 -43
- data/third_party/boringssl/crypto/pool/internal.h +1 -1
- data/third_party/boringssl/crypto/pool/pool.c +21 -0
- data/third_party/boringssl/crypto/rand_extra/deterministic.c +8 -0
- data/third_party/boringssl/crypto/rand_extra/fuchsia.c +1 -14
- data/third_party/boringssl/crypto/refcount_lock.c +2 -2
- data/third_party/boringssl/crypto/rsa_extra/rsa_print.c +22 -0
- data/third_party/boringssl/crypto/siphash/siphash.c +80 -0
- data/third_party/boringssl/crypto/stack/stack.c +83 -32
- data/third_party/boringssl/crypto/thread_none.c +2 -2
- data/third_party/boringssl/crypto/thread_pthread.c +2 -2
- data/third_party/boringssl/crypto/thread_win.c +38 -19
- data/third_party/boringssl/crypto/x509/a_strex.c +22 -2
- data/third_party/boringssl/crypto/x509/asn1_gen.c +2 -1
- data/third_party/boringssl/crypto/x509/by_dir.c +7 -0
- data/third_party/boringssl/crypto/x509/by_file.c +12 -10
- data/third_party/boringssl/crypto/x509/t_crl.c +5 -8
- data/third_party/boringssl/crypto/x509/t_req.c +1 -3
- data/third_party/boringssl/crypto/x509/t_x509.c +5 -8
- data/third_party/boringssl/crypto/x509/x509_cmp.c +1 -1
- data/third_party/boringssl/crypto/x509/x509_def.c +1 -1
- data/third_party/boringssl/crypto/x509/x509_lu.c +114 -5
- data/third_party/boringssl/crypto/x509/x509_req.c +20 -0
- data/third_party/boringssl/crypto/x509/x509_set.c +5 -0
- data/third_party/boringssl/crypto/x509/x509_trs.c +1 -0
- data/third_party/boringssl/crypto/x509/x509_txt.c +4 -5
- data/third_party/boringssl/crypto/x509/x509_vfy.c +145 -138
- data/third_party/boringssl/crypto/x509/x509_vpm.c +2 -0
- data/third_party/boringssl/crypto/x509/x509cset.c +40 -0
- data/third_party/boringssl/crypto/x509/x509name.c +2 -3
- data/third_party/boringssl/crypto/x509/x_all.c +109 -210
- data/third_party/boringssl/crypto/x509/x_x509.c +6 -0
- data/third_party/boringssl/crypto/x509v3/ext_dat.h +1 -3
- data/third_party/boringssl/crypto/x509v3/internal.h +56 -0
- data/third_party/boringssl/crypto/x509v3/pcy_cache.c +2 -0
- data/third_party/boringssl/crypto/x509v3/pcy_node.c +1 -0
- data/third_party/boringssl/crypto/x509v3/pcy_tree.c +4 -2
- data/third_party/boringssl/crypto/x509v3/v3_akey.c +5 -2
- data/third_party/boringssl/crypto/x509v3/v3_alt.c +19 -13
- data/third_party/boringssl/crypto/x509v3/v3_conf.c +2 -1
- data/third_party/boringssl/crypto/x509v3/v3_cpols.c +3 -2
- data/third_party/boringssl/crypto/x509v3/v3_genn.c +1 -6
- data/third_party/boringssl/crypto/x509v3/v3_lib.c +1 -0
- data/third_party/boringssl/crypto/x509v3/v3_ocsp.c +68 -0
- data/third_party/boringssl/crypto/x509v3/v3_pci.c +2 -1
- data/third_party/boringssl/crypto/x509v3/v3_purp.c +47 -69
- data/third_party/boringssl/crypto/x509v3/v3_skey.c +5 -2
- data/third_party/boringssl/crypto/x509v3/v3_utl.c +69 -25
- data/third_party/boringssl/include/openssl/aead.h +45 -19
- data/third_party/boringssl/include/openssl/aes.h +32 -7
- data/third_party/boringssl/include/openssl/asn1.h +7 -77
- data/third_party/boringssl/include/openssl/base.h +120 -6
- data/third_party/boringssl/include/openssl/base64.h +4 -1
- data/third_party/boringssl/include/openssl/bio.h +112 -81
- data/third_party/boringssl/include/openssl/blowfish.h +3 -3
- data/third_party/boringssl/include/openssl/bn.h +55 -29
- data/third_party/boringssl/include/openssl/buf.h +2 -2
- data/third_party/boringssl/include/openssl/bytestring.h +54 -32
- data/third_party/boringssl/include/openssl/cast.h +2 -2
- data/third_party/boringssl/include/openssl/cipher.h +46 -16
- data/third_party/boringssl/include/openssl/cmac.h +6 -2
- data/third_party/boringssl/include/openssl/conf.h +3 -6
- data/third_party/boringssl/include/openssl/cpu.h +25 -9
- data/third_party/boringssl/include/openssl/crypto.h +32 -10
- data/third_party/boringssl/include/openssl/curve25519.h +4 -4
- data/third_party/boringssl/include/openssl/dh.h +3 -2
- data/third_party/boringssl/include/openssl/digest.h +21 -7
- data/third_party/boringssl/include/openssl/dsa.h +8 -2
- data/third_party/boringssl/include/openssl/e_os2.h +18 -0
- data/third_party/boringssl/include/openssl/ec.h +25 -21
- data/third_party/boringssl/include/openssl/ec_key.h +36 -8
- data/third_party/boringssl/include/openssl/ecdh.h +17 -0
- data/third_party/boringssl/include/openssl/ecdsa.h +3 -3
- data/third_party/boringssl/include/openssl/engine.h +4 -4
- data/third_party/boringssl/include/openssl/err.h +3 -0
- data/third_party/boringssl/include/openssl/evp.h +199 -42
- data/third_party/boringssl/include/openssl/hmac.h +4 -4
- data/third_party/boringssl/include/openssl/hrss.h +100 -0
- data/third_party/boringssl/include/openssl/lhash.h +131 -23
- data/third_party/boringssl/include/openssl/md4.h +6 -4
- data/third_party/boringssl/include/openssl/md5.h +6 -4
- data/third_party/boringssl/include/openssl/mem.h +6 -2
- data/third_party/boringssl/include/openssl/nid.h +3 -0
- data/third_party/boringssl/include/openssl/obj.h +3 -0
- data/third_party/boringssl/include/openssl/pem.h +102 -64
- data/third_party/boringssl/include/openssl/pkcs7.h +136 -3
- data/third_party/boringssl/include/openssl/pkcs8.h +42 -3
- data/third_party/boringssl/include/openssl/pool.h +13 -2
- data/third_party/boringssl/include/openssl/ripemd.h +5 -4
- data/third_party/boringssl/include/openssl/rsa.h +46 -15
- data/third_party/boringssl/include/openssl/sha.h +40 -28
- data/third_party/boringssl/include/openssl/siphash.h +37 -0
- data/third_party/boringssl/include/openssl/span.h +17 -9
- data/third_party/boringssl/include/openssl/ssl.h +766 -393
- data/third_party/boringssl/include/openssl/ssl3.h +4 -3
- data/third_party/boringssl/include/openssl/stack.h +134 -77
- data/third_party/boringssl/include/openssl/thread.h +1 -1
- data/third_party/boringssl/include/openssl/tls1.h +25 -9
- data/third_party/boringssl/include/openssl/type_check.h +14 -15
- data/third_party/boringssl/include/openssl/x509.h +28 -3
- data/third_party/boringssl/include/openssl/x509_vfy.h +98 -32
- data/third_party/boringssl/include/openssl/x509v3.h +17 -13
- data/third_party/boringssl/ssl/d1_both.cc +9 -18
- data/third_party/boringssl/ssl/d1_lib.cc +4 -3
- data/third_party/boringssl/ssl/d1_pkt.cc +4 -4
- data/third_party/boringssl/ssl/d1_srtp.cc +15 -15
- data/third_party/boringssl/ssl/dtls_method.cc +0 -1
- data/third_party/boringssl/ssl/dtls_record.cc +28 -28
- data/third_party/boringssl/ssl/handoff.cc +295 -91
- data/third_party/boringssl/ssl/handshake.cc +133 -72
- data/third_party/boringssl/ssl/handshake_client.cc +218 -189
- data/third_party/boringssl/ssl/handshake_server.cc +399 -272
- data/third_party/boringssl/ssl/internal.h +1413 -928
- data/third_party/boringssl/ssl/s3_both.cc +175 -36
- data/third_party/boringssl/ssl/s3_lib.cc +9 -13
- data/third_party/boringssl/ssl/s3_pkt.cc +63 -29
- data/third_party/boringssl/ssl/ssl_aead_ctx.cc +55 -35
- data/third_party/boringssl/ssl/ssl_asn1.cc +57 -73
- data/third_party/boringssl/ssl/ssl_buffer.cc +13 -12
- data/third_party/boringssl/ssl/ssl_cert.cc +313 -210
- data/third_party/boringssl/ssl/ssl_cipher.cc +159 -221
- data/third_party/boringssl/ssl/ssl_file.cc +2 -0
- data/third_party/boringssl/ssl/ssl_key_share.cc +164 -19
- data/third_party/boringssl/ssl/ssl_lib.cc +847 -555
- data/third_party/boringssl/ssl/ssl_privkey.cc +441 -111
- data/third_party/boringssl/ssl/ssl_session.cc +230 -178
- data/third_party/boringssl/ssl/ssl_transcript.cc +21 -142
- data/third_party/boringssl/ssl/ssl_versions.cc +88 -93
- data/third_party/boringssl/ssl/ssl_x509.cc +279 -218
- data/third_party/boringssl/ssl/t1_enc.cc +5 -96
- data/third_party/boringssl/ssl/t1_lib.cc +931 -678
- data/third_party/boringssl/ssl/tls13_both.cc +251 -121
- data/third_party/boringssl/ssl/tls13_client.cc +129 -73
- data/third_party/boringssl/ssl/tls13_enc.cc +350 -282
- data/third_party/boringssl/ssl/tls13_server.cc +259 -192
- data/third_party/boringssl/ssl/tls_method.cc +26 -21
- data/third_party/boringssl/ssl/tls_record.cc +42 -47
- data/third_party/boringssl/third_party/fiat/curve25519.c +261 -1324
- data/third_party/boringssl/third_party/fiat/curve25519_32.h +911 -0
- data/third_party/boringssl/third_party/fiat/curve25519_64.h +559 -0
- data/third_party/boringssl/third_party/fiat/p256.c +238 -999
- data/third_party/boringssl/third_party/fiat/p256_32.h +3226 -0
- data/third_party/boringssl/third_party/fiat/p256_64.h +1217 -0
- data/third_party/upb/upb/port_def.inc +1 -1
- data/third_party/upb/upb/table.c +2 -1
- metadata +72 -44
- data/src/core/ext/filters/client_channel/lb_policy/xds/xds_load_balancer_api.h +0 -127
- data/src/core/lib/gpr/mpscq.cc +0 -117
- data/src/core/lib/gpr/mpscq.h +0 -88
- data/src/core/lib/gprpp/abstract.h +0 -47
- data/src/core/lib/gprpp/pair.h +0 -38
- data/third_party/boringssl/crypto/cipher_extra/e_ssl3.c +0 -460
- data/third_party/boringssl/crypto/fipsmodule/modes/ccm.c +0 -256
- data/third_party/boringssl/include/openssl/lhash_macros.h +0 -174
- data/third_party/boringssl/ssl/custom_extensions.cc +0 -265
@@ -68,7 +68,7 @@
|
|
68
68
|
|
69
69
|
int i2d_ASN1_OBJECT(ASN1_OBJECT *a, unsigned char **pp)
|
70
70
|
{
|
71
|
-
unsigned char *p;
|
71
|
+
unsigned char *p, *allocated = NULL;
|
72
72
|
int objsize;
|
73
73
|
|
74
74
|
if ((a == NULL) || (a->data == NULL))
|
@@ -78,13 +78,24 @@ int i2d_ASN1_OBJECT(ASN1_OBJECT *a, unsigned char **pp)
|
|
78
78
|
if (pp == NULL || objsize == -1)
|
79
79
|
return objsize;
|
80
80
|
|
81
|
-
|
81
|
+
if (*pp == NULL) {
|
82
|
+
if ((p = allocated = OPENSSL_malloc(objsize)) == NULL) {
|
83
|
+
OPENSSL_PUT_ERROR(ASN1, ERR_R_MALLOC_FAILURE);
|
84
|
+
return 0;
|
85
|
+
}
|
86
|
+
} else {
|
87
|
+
p = *pp;
|
88
|
+
}
|
89
|
+
|
82
90
|
ASN1_put_object(&p, 0, a->length, V_ASN1_OBJECT, V_ASN1_UNIVERSAL);
|
83
91
|
OPENSSL_memcpy(p, a->data, a->length);
|
84
|
-
p += a->length;
|
85
92
|
|
86
|
-
|
87
|
-
|
93
|
+
/*
|
94
|
+
* If a new buffer was allocated, just return it back.
|
95
|
+
* If not, return the incremented buffer pointer.
|
96
|
+
*/
|
97
|
+
*pp = allocated != NULL ? allocated : p + a->length;
|
98
|
+
return objsize;
|
88
99
|
}
|
89
100
|
|
90
101
|
int i2t_ASN1_OBJECT(char *buf, int buf_len, ASN1_OBJECT *a)
|
@@ -205,7 +205,11 @@ static int asn1_get_length(const unsigned char **pp, int *inf, long *rl,
|
|
205
205
|
} else
|
206
206
|
ret = i;
|
207
207
|
}
|
208
|
-
|
208
|
+
/*
|
209
|
+
* Bound the length to comfortably fit in an int. Lengths in this module
|
210
|
+
* often switch between int and long without overflow checks.
|
211
|
+
*/
|
212
|
+
if (ret > INT_MAX / 2)
|
209
213
|
return 0;
|
210
214
|
*pp = p;
|
211
215
|
*rl = (long)ret;
|
@@ -192,7 +192,7 @@ int ASN1_item_ex_i2d(ASN1_VALUE **pval, unsigned char **out,
|
|
192
192
|
/* Use indefinite length constructed if requested */
|
193
193
|
if (aclass & ASN1_TFLG_NDEF)
|
194
194
|
ndef = 2;
|
195
|
-
|
195
|
+
OPENSSL_FALLTHROUGH;
|
196
196
|
|
197
197
|
case ASN1_ITYPE_SEQUENCE:
|
198
198
|
i = asn1_enc_restore(&seqcontlen, out, pval, it);
|
@@ -583,6 +583,8 @@ int asn1_ex_i2c(ASN1_VALUE **pval, unsigned char *cout, int *putype,
|
|
583
583
|
otmp = (ASN1_OBJECT *)*pval;
|
584
584
|
cont = otmp->data;
|
585
585
|
len = otmp->length;
|
586
|
+
if (cont == NULL || len == 0)
|
587
|
+
return -1;
|
586
588
|
break;
|
587
589
|
|
588
590
|
case V_ASN1_NULL:
|
@@ -98,8 +98,8 @@ static uint8_t conv_bin2ascii(uint8_t a) {
|
|
98
98
|
return ret;
|
99
99
|
}
|
100
100
|
|
101
|
-
|
102
|
-
|
101
|
+
OPENSSL_STATIC_ASSERT(sizeof(((EVP_ENCODE_CTX *)(NULL))->data) % 3 == 0,
|
102
|
+
"data length must be a multiple of base64 chunk size");
|
103
103
|
|
104
104
|
int EVP_EncodedLength(size_t *out_len, size_t len) {
|
105
105
|
if (len + 2 < len) {
|
@@ -61,6 +61,7 @@
|
|
61
61
|
#include <limits.h>
|
62
62
|
#include <string.h>
|
63
63
|
|
64
|
+
#include <openssl/asn1.h>
|
64
65
|
#include <openssl/err.h>
|
65
66
|
#include <openssl/mem.h>
|
66
67
|
#include <openssl/thread.h>
|
@@ -177,6 +178,19 @@ int BIO_write(BIO *bio, const void *in, int inl) {
|
|
177
178
|
return ret;
|
178
179
|
}
|
179
180
|
|
181
|
+
int BIO_write_all(BIO *bio, const void *data, size_t len) {
|
182
|
+
const uint8_t *data_u8 = data;
|
183
|
+
while (len > 0) {
|
184
|
+
int ret = BIO_write(bio, data_u8, len > INT_MAX ? INT_MAX : (int)len);
|
185
|
+
if (ret <= 0) {
|
186
|
+
return 0;
|
187
|
+
}
|
188
|
+
data_u8 += ret;
|
189
|
+
len -= ret;
|
190
|
+
}
|
191
|
+
return 1;
|
192
|
+
}
|
193
|
+
|
180
194
|
int BIO_puts(BIO *bio, const char *in) {
|
181
195
|
return BIO_write(bio, in, strlen(in));
|
182
196
|
}
|
@@ -468,11 +482,52 @@ static int bio_read_all(BIO *bio, uint8_t **out, size_t *out_len,
|
|
468
482
|
}
|
469
483
|
}
|
470
484
|
|
485
|
+
// bio_read_full reads |len| bytes |bio| and writes them into |out|. It
|
486
|
+
// tolerates partial reads from |bio| and returns one on success or zero if a
|
487
|
+
// read fails before |len| bytes are read. On failure, it additionally sets
|
488
|
+
// |*out_eof_on_first_read| to whether the error was due to |bio| returning zero
|
489
|
+
// on the first read. |out_eof_on_first_read| may be NULL to discard the value.
|
490
|
+
static int bio_read_full(BIO *bio, uint8_t *out, int *out_eof_on_first_read,
|
491
|
+
size_t len) {
|
492
|
+
int first_read = 1;
|
493
|
+
while (len > 0) {
|
494
|
+
int todo = len <= INT_MAX ? (int)len : INT_MAX;
|
495
|
+
int ret = BIO_read(bio, out, todo);
|
496
|
+
if (ret <= 0) {
|
497
|
+
if (out_eof_on_first_read != NULL) {
|
498
|
+
*out_eof_on_first_read = first_read && ret == 0;
|
499
|
+
}
|
500
|
+
return 0;
|
501
|
+
}
|
502
|
+
out += ret;
|
503
|
+
len -= (size_t)ret;
|
504
|
+
first_read = 0;
|
505
|
+
}
|
506
|
+
|
507
|
+
return 1;
|
508
|
+
}
|
509
|
+
|
510
|
+
// For compatibility with existing |d2i_*_bio| callers, |BIO_read_asn1| uses
|
511
|
+
// |ERR_LIB_ASN1| errors.
|
512
|
+
OPENSSL_DECLARE_ERROR_REASON(ASN1, ASN1_R_DECODE_ERROR)
|
513
|
+
OPENSSL_DECLARE_ERROR_REASON(ASN1, ASN1_R_HEADER_TOO_LONG)
|
514
|
+
OPENSSL_DECLARE_ERROR_REASON(ASN1, ASN1_R_NOT_ENOUGH_DATA)
|
515
|
+
OPENSSL_DECLARE_ERROR_REASON(ASN1, ASN1_R_TOO_LONG)
|
516
|
+
|
471
517
|
int BIO_read_asn1(BIO *bio, uint8_t **out, size_t *out_len, size_t max_len) {
|
472
518
|
uint8_t header[6];
|
473
519
|
|
474
520
|
static const size_t kInitialHeaderLen = 2;
|
475
|
-
|
521
|
+
int eof_on_first_read;
|
522
|
+
if (!bio_read_full(bio, header, &eof_on_first_read, kInitialHeaderLen)) {
|
523
|
+
if (eof_on_first_read) {
|
524
|
+
// Historically, OpenSSL returned |ASN1_R_HEADER_TOO_LONG| when
|
525
|
+
// |d2i_*_bio| could not read anything. CPython conditions on this to
|
526
|
+
// determine if |bio| was empty.
|
527
|
+
OPENSSL_PUT_ERROR(ASN1, ASN1_R_HEADER_TOO_LONG);
|
528
|
+
} else {
|
529
|
+
OPENSSL_PUT_ERROR(ASN1, ASN1_R_NOT_ENOUGH_DATA);
|
530
|
+
}
|
476
531
|
return 0;
|
477
532
|
}
|
478
533
|
|
@@ -481,6 +536,7 @@ int BIO_read_asn1(BIO *bio, uint8_t **out, size_t *out_len, size_t max_len) {
|
|
481
536
|
|
482
537
|
if ((tag & 0x1f) == 0x1f) {
|
483
538
|
// Long form tags are not supported.
|
539
|
+
OPENSSL_PUT_ERROR(ASN1, ASN1_R_DECODE_ERROR);
|
484
540
|
return 0;
|
485
541
|
}
|
486
542
|
|
@@ -494,34 +550,40 @@ int BIO_read_asn1(BIO *bio, uint8_t **out, size_t *out_len, size_t max_len) {
|
|
494
550
|
|
495
551
|
if ((tag & 0x20 /* constructed */) != 0 && num_bytes == 0) {
|
496
552
|
// indefinite length.
|
497
|
-
|
498
|
-
|
553
|
+
if (!bio_read_all(bio, out, out_len, header, kInitialHeaderLen,
|
554
|
+
max_len)) {
|
555
|
+
OPENSSL_PUT_ERROR(ASN1, ASN1_R_NOT_ENOUGH_DATA);
|
556
|
+
return 0;
|
557
|
+
}
|
558
|
+
return 1;
|
499
559
|
}
|
500
560
|
|
501
561
|
if (num_bytes == 0 || num_bytes > 4) {
|
562
|
+
OPENSSL_PUT_ERROR(ASN1, ASN1_R_DECODE_ERROR);
|
502
563
|
return 0;
|
503
564
|
}
|
504
565
|
|
505
|
-
if (
|
506
|
-
|
566
|
+
if (!bio_read_full(bio, header + kInitialHeaderLen, NULL, num_bytes)) {
|
567
|
+
OPENSSL_PUT_ERROR(ASN1, ASN1_R_NOT_ENOUGH_DATA);
|
507
568
|
return 0;
|
508
569
|
}
|
509
570
|
header_len = kInitialHeaderLen + num_bytes;
|
510
571
|
|
511
572
|
uint32_t len32 = 0;
|
512
|
-
unsigned i;
|
513
|
-
for (i = 0; i < num_bytes; i++) {
|
573
|
+
for (unsigned i = 0; i < num_bytes; i++) {
|
514
574
|
len32 <<= 8;
|
515
575
|
len32 |= header[kInitialHeaderLen + i];
|
516
576
|
}
|
517
577
|
|
518
578
|
if (len32 < 128) {
|
519
579
|
// Length should have used short-form encoding.
|
580
|
+
OPENSSL_PUT_ERROR(ASN1, ASN1_R_DECODE_ERROR);
|
520
581
|
return 0;
|
521
582
|
}
|
522
583
|
|
523
584
|
if ((len32 >> ((num_bytes-1)*8)) == 0) {
|
524
585
|
// Length should have been at least one byte shorter.
|
586
|
+
OPENSSL_PUT_ERROR(ASN1, ASN1_R_DECODE_ERROR);
|
525
587
|
return 0;
|
526
588
|
}
|
527
589
|
|
@@ -531,6 +593,7 @@ int BIO_read_asn1(BIO *bio, uint8_t **out, size_t *out_len, size_t max_len) {
|
|
531
593
|
if (len + header_len < len ||
|
532
594
|
len + header_len > max_len ||
|
533
595
|
len > INT_MAX) {
|
596
|
+
OPENSSL_PUT_ERROR(ASN1, ASN1_R_TOO_LONG);
|
534
597
|
return 0;
|
535
598
|
}
|
536
599
|
len += header_len;
|
@@ -538,11 +601,12 @@ int BIO_read_asn1(BIO *bio, uint8_t **out, size_t *out_len, size_t max_len) {
|
|
538
601
|
|
539
602
|
*out = OPENSSL_malloc(len);
|
540
603
|
if (*out == NULL) {
|
604
|
+
OPENSSL_PUT_ERROR(ASN1, ERR_R_MALLOC_FAILURE);
|
541
605
|
return 0;
|
542
606
|
}
|
543
607
|
OPENSSL_memcpy(*out, header, header_len);
|
544
|
-
if (
|
545
|
-
|
608
|
+
if (!bio_read_full(bio, (*out) + header_len, NULL, len - header_len)) {
|
609
|
+
OPENSSL_PUT_ERROR(ASN1, ASN1_R_NOT_ENOUGH_DATA);
|
546
610
|
OPENSSL_free(*out);
|
547
611
|
return 0;
|
548
612
|
}
|
@@ -56,6 +56,8 @@
|
|
56
56
|
|
57
57
|
#include <openssl/bio.h>
|
58
58
|
|
59
|
+
#if !defined(OPENSSL_TRUSTY)
|
60
|
+
|
59
61
|
#include <assert.h>
|
60
62
|
#include <errno.h>
|
61
63
|
#include <string.h>
|
@@ -540,3 +542,5 @@ int BIO_set_nbio(BIO *bio, int on) {
|
|
540
542
|
int BIO_do_connect(BIO *bio) {
|
541
543
|
return BIO_ctrl(bio, BIO_C_DO_STATE_MACHINE, 0, NULL);
|
542
544
|
}
|
545
|
+
|
546
|
+
#endif // OPENSSL_TRUSTY
|
@@ -56,6 +56,8 @@
|
|
56
56
|
|
57
57
|
#include <openssl/bio.h>
|
58
58
|
|
59
|
+
#if !defined(OPENSSL_TRUSTY)
|
60
|
+
|
59
61
|
#include <errno.h>
|
60
62
|
#include <string.h>
|
61
63
|
|
@@ -274,3 +276,5 @@ int BIO_set_fd(BIO *bio, int fd, int close_flag) {
|
|
274
276
|
int BIO_get_fd(BIO *bio, int *out_fd) {
|
275
277
|
return BIO_ctrl(bio, BIO_C_GET_FD, 0, (char *) out_fd);
|
276
278
|
}
|
279
|
+
|
280
|
+
#endif // OPENSSL_TRUSTY
|
@@ -73,6 +73,8 @@
|
|
73
73
|
|
74
74
|
#include <openssl/bio.h>
|
75
75
|
|
76
|
+
#if !defined(OPENSSL_TRUSTY)
|
77
|
+
|
76
78
|
#include <errno.h>
|
77
79
|
#include <stdio.h>
|
78
80
|
#include <string.h>
|
@@ -105,13 +107,12 @@ BIO *BIO_new_file(const char *filename, const char *mode) {
|
|
105
107
|
return NULL;
|
106
108
|
}
|
107
109
|
|
108
|
-
ret =
|
110
|
+
ret = BIO_new_fp(file, BIO_CLOSE);
|
109
111
|
if (ret == NULL) {
|
110
112
|
fclose(file);
|
111
113
|
return NULL;
|
112
114
|
}
|
113
115
|
|
114
|
-
BIO_set_fp(ret, file, BIO_CLOSE);
|
115
116
|
return ret;
|
116
117
|
}
|
117
118
|
|
@@ -313,3 +314,5 @@ int BIO_rw_filename(BIO *bio, const char *filename) {
|
|
313
314
|
return BIO_ctrl(bio, BIO_C_SET_FILENAME,
|
314
315
|
BIO_CLOSE | BIO_FP_READ | BIO_FP_WRITE, (char *)filename);
|
315
316
|
}
|
317
|
+
|
318
|
+
#endif // OPENSSL_TRUSTY
|
@@ -57,6 +57,8 @@
|
|
57
57
|
|
58
58
|
#include <openssl/bio.h>
|
59
59
|
|
60
|
+
#if !defined(OPENSSL_TRUSTY)
|
61
|
+
|
60
62
|
#include <fcntl.h>
|
61
63
|
#include <string.h>
|
62
64
|
|
@@ -200,3 +202,5 @@ BIO *BIO_new_socket(int fd, int close_flag) {
|
|
200
202
|
BIO_set_fd(ret, fd, close_flag);
|
201
203
|
return ret;
|
202
204
|
}
|
205
|
+
|
206
|
+
#endif // OPENSSL_TRUSTY
|
@@ -18,6 +18,8 @@
|
|
18
18
|
#include <openssl/bio.h>
|
19
19
|
#include <openssl/err.h>
|
20
20
|
|
21
|
+
#if !defined(OPENSSL_TRUSTY)
|
22
|
+
|
21
23
|
#include <fcntl.h>
|
22
24
|
#include <string.h>
|
23
25
|
#include <sys/types.h>
|
@@ -112,3 +114,5 @@ int bio_sock_error(int sock) {
|
|
112
114
|
}
|
113
115
|
return error;
|
114
116
|
}
|
117
|
+
|
118
|
+
#endif // OPENSSL_TRUSTY
|
@@ -367,17 +367,13 @@ end:
|
|
367
367
|
}
|
368
368
|
|
369
369
|
int BN_print_fp(FILE *fp, const BIGNUM *a) {
|
370
|
-
BIO *b;
|
371
|
-
int ret;
|
372
|
-
|
373
|
-
b = BIO_new(BIO_s_file());
|
370
|
+
BIO *b = BIO_new_fp(fp, BIO_NOCLOSE);
|
374
371
|
if (b == NULL) {
|
375
372
|
return 0;
|
376
373
|
}
|
377
|
-
BIO_set_fp(b, fp, BIO_NOCLOSE);
|
378
|
-
ret = BN_print(b, a);
|
379
|
-
BIO_free(b);
|
380
374
|
|
375
|
+
int ret = BN_print(b, a);
|
376
|
+
BIO_free(b);
|
381
377
|
return ret;
|
382
378
|
}
|
383
379
|
|
@@ -464,3 +460,11 @@ BIGNUM *BN_mpi2bn(const uint8_t *in, size_t len, BIGNUM *out) {
|
|
464
460
|
}
|
465
461
|
return out;
|
466
462
|
}
|
463
|
+
|
464
|
+
int BN_bn2binpad(const BIGNUM *in, uint8_t *out, int len) {
|
465
|
+
if (len < 0 ||
|
466
|
+
!BN_bn2bin_padded(out, (size_t)len, in)) {
|
467
|
+
return -1;
|
468
|
+
}
|
469
|
+
return len;
|
470
|
+
}
|
@@ -189,7 +189,7 @@ static int cbs_convert_ber(CBS *in, CBB *out, unsigned string_tag,
|
|
189
189
|
return looking_for_eoc == 0;
|
190
190
|
}
|
191
191
|
|
192
|
-
int CBS_asn1_ber_to_der(CBS *in,
|
192
|
+
int CBS_asn1_ber_to_der(CBS *in, CBS *out, uint8_t **out_storage) {
|
193
193
|
CBB cbb;
|
194
194
|
|
195
195
|
// First, do a quick walk to find any indefinite-length elements. Most of the
|
@@ -200,18 +200,22 @@ int CBS_asn1_ber_to_der(CBS *in, uint8_t **out, size_t *out_len) {
|
|
200
200
|
}
|
201
201
|
|
202
202
|
if (!conversion_needed) {
|
203
|
-
|
204
|
-
|
203
|
+
if (!CBS_get_any_asn1_element(in, out, NULL, NULL)) {
|
204
|
+
return 0;
|
205
|
+
}
|
206
|
+
*out_storage = NULL;
|
205
207
|
return 1;
|
206
208
|
}
|
207
209
|
|
210
|
+
size_t len;
|
208
211
|
if (!CBB_init(&cbb, CBS_len(in)) ||
|
209
212
|
!cbs_convert_ber(in, &cbb, 0, 0, 0) ||
|
210
|
-
!CBB_finish(&cbb,
|
213
|
+
!CBB_finish(&cbb, out_storage, &len)) {
|
211
214
|
CBB_cleanup(&cbb);
|
212
215
|
return 0;
|
213
216
|
}
|
214
217
|
|
218
|
+
CBS_init(out, *out_storage, len);
|
215
219
|
return 1;
|
216
220
|
}
|
217
221
|
|
@@ -44,7 +44,7 @@ static int cbb_init(CBB *cbb, uint8_t *buf, size_t cap) {
|
|
44
44
|
base->error = 0;
|
45
45
|
|
46
46
|
cbb->base = base;
|
47
|
-
cbb->
|
47
|
+
cbb->is_child = 0;
|
48
48
|
return 1;
|
49
49
|
}
|
50
50
|
|
@@ -76,11 +76,14 @@ int CBB_init_fixed(CBB *cbb, uint8_t *buf, size_t len) {
|
|
76
76
|
}
|
77
77
|
|
78
78
|
void CBB_cleanup(CBB *cbb) {
|
79
|
-
|
80
|
-
|
81
|
-
|
82
|
-
|
79
|
+
// Child |CBB|s are non-owning. They are implicitly discarded and should not
|
80
|
+
// be used with |CBB_cleanup| or |ScopedCBB|.
|
81
|
+
assert(!cbb->is_child);
|
82
|
+
if (cbb->is_child) {
|
83
|
+
return;
|
84
|
+
}
|
83
85
|
|
86
|
+
if (cbb->base) {
|
84
87
|
if (cbb->base->can_resize) {
|
85
88
|
OPENSSL_free(cbb->base->buf);
|
86
89
|
}
|
@@ -144,7 +147,7 @@ static int cbb_buffer_add(struct cbb_buffer_st *base, uint8_t **out,
|
|
144
147
|
return 1;
|
145
148
|
}
|
146
149
|
|
147
|
-
static int cbb_buffer_add_u(struct cbb_buffer_st *base,
|
150
|
+
static int cbb_buffer_add_u(struct cbb_buffer_st *base, uint64_t v,
|
148
151
|
size_t len_len) {
|
149
152
|
if (len_len == 0) {
|
150
153
|
return 1;
|
@@ -169,7 +172,7 @@ static int cbb_buffer_add_u(struct cbb_buffer_st *base, uint32_t v,
|
|
169
172
|
}
|
170
173
|
|
171
174
|
int CBB_finish(CBB *cbb, uint8_t **out_data, size_t *out_len) {
|
172
|
-
if (
|
175
|
+
if (cbb->is_child) {
|
173
176
|
return 0;
|
174
177
|
}
|
175
178
|
|
@@ -310,6 +313,7 @@ static int cbb_add_length_prefixed(CBB *cbb, CBB *out_contents,
|
|
310
313
|
OPENSSL_memset(prefix_bytes, 0, len_len);
|
311
314
|
OPENSSL_memset(out_contents, 0, sizeof(CBB));
|
312
315
|
out_contents->base = cbb->base;
|
316
|
+
out_contents->is_child = 1;
|
313
317
|
cbb->child = out_contents;
|
314
318
|
cbb->child->offset = offset;
|
315
319
|
cbb->child->pending_len_len = len_len;
|
@@ -381,6 +385,7 @@ int CBB_add_asn1(CBB *cbb, CBB *out_contents, unsigned tag) {
|
|
381
385
|
|
382
386
|
OPENSSL_memset(out_contents, 0, sizeof(CBB));
|
383
387
|
out_contents->base = cbb->base;
|
388
|
+
out_contents->is_child = 1;
|
384
389
|
cbb->child = out_contents;
|
385
390
|
cbb->child->offset = offset;
|
386
391
|
cbb->child->pending_len_len = 1;
|
@@ -459,6 +464,13 @@ int CBB_add_u32(CBB *cbb, uint32_t value) {
|
|
459
464
|
return cbb_buffer_add_u(cbb->base, value, 4);
|
460
465
|
}
|
461
466
|
|
467
|
+
int CBB_add_u64(CBB *cbb, uint64_t value) {
|
468
|
+
if (!CBB_flush(cbb)) {
|
469
|
+
return 0;
|
470
|
+
}
|
471
|
+
return cbb_buffer_add_u(cbb->base, value, 8);
|
472
|
+
}
|
473
|
+
|
462
474
|
void CBB_discard_child(CBB *cbb) {
|
463
475
|
if (cbb->child == NULL) {
|
464
476
|
return;
|