grpc 0.12.0 → 0.13.0.pre1.1
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 +5707 -22222
- data/include/grpc/byte_buffer.h +2 -83
- data/include/grpc/census.h +191 -121
- data/include/grpc/compression.h +14 -38
- data/include/grpc/grpc.h +88 -434
- data/include/grpc/grpc_security.h +76 -46
- data/include/grpc/grpc_zookeeper.h +1 -1
- data/include/grpc/impl/codegen/alloc.h +74 -0
- data/include/grpc/impl/codegen/atm.h +92 -0
- data/include/grpc/impl/codegen/atm_gcc_atomic.h +72 -0
- data/include/grpc/impl/codegen/atm_gcc_sync.h +87 -0
- data/include/grpc/impl/codegen/atm_win32.h +125 -0
- data/include/grpc/impl/codegen/byte_buffer.h +121 -0
- data/include/grpc/impl/codegen/compression_types.h +73 -0
- data/include/grpc/impl/codegen/connectivity_state.h +59 -0
- data/include/grpc/impl/codegen/grpc_types.h +373 -0
- data/include/grpc/impl/codegen/log.h +110 -0
- data/include/grpc/impl/codegen/port_platform.h +362 -0
- data/include/grpc/impl/codegen/propagation_bits.h +67 -0
- data/include/grpc/impl/codegen/slice.h +182 -0
- data/include/grpc/impl/codegen/slice_buffer.h +105 -0
- data/include/grpc/impl/codegen/status.h +163 -0
- data/include/grpc/impl/codegen/sync.h +316 -0
- data/include/grpc/impl/codegen/sync_generic.h +55 -0
- data/{src/core/census/context.h → include/grpc/impl/codegen/sync_posix.h} +11 -11
- data/include/grpc/impl/codegen/sync_win32.h +49 -0
- data/include/grpc/impl/codegen/time.h +132 -0
- data/include/grpc/status.h +2 -126
- data/include/grpc/support/alloc.h +2 -35
- data/include/grpc/support/atm.h +2 -55
- data/include/grpc/support/atm_gcc_atomic.h +5 -38
- data/include/grpc/support/atm_gcc_sync.h +2 -50
- data/include/grpc/support/atm_win32.h +2 -88
- data/include/grpc/support/avl.h +7 -7
- data/include/grpc/support/cmdline.h +15 -13
- data/include/grpc/support/cpu.h +5 -3
- data/include/grpc/support/histogram.h +23 -20
- data/include/grpc/support/host_port.h +5 -3
- data/include/grpc/support/log.h +2 -71
- data/include/grpc/support/log_win32.h +2 -2
- data/include/grpc/support/port_platform.h +2 -319
- data/include/grpc/support/slice.h +2 -145
- data/include/grpc/support/slice_buffer.h +2 -65
- data/include/grpc/support/string_util.h +3 -3
- data/include/grpc/support/subprocess.h +8 -6
- data/include/grpc/support/sync.h +2 -278
- data/include/grpc/support/sync_generic.h +2 -18
- data/include/grpc/support/sync_posix.h +2 -10
- data/include/grpc/support/sync_win32.h +2 -12
- data/include/grpc/support/thd.h +11 -11
- data/include/grpc/support/time.h +2 -91
- data/include/grpc/support/tls.h +1 -1
- data/include/grpc/support/tls_gcc.h +1 -1
- data/include/grpc/support/tls_msvc.h +1 -1
- data/include/grpc/support/tls_pthread.h +2 -2
- data/src/boringssl/err_data.c +1252 -0
- data/src/core/census/context.c +492 -8
- data/src/core/census/grpc_filter.c +3 -3
- data/src/core/census/initialize.c +4 -7
- data/src/core/census/operation.c +2 -2
- data/src/core/census/placeholders.c +109 -0
- data/src/core/census/rpc_metric_id.h +6 -6
- data/src/core/census/tracing.c +1 -1
- data/src/core/channel/channel_args.c +4 -3
- data/src/core/channel/channel_stack.c +1 -1
- data/src/core/channel/client_channel.c +18 -14
- data/src/core/channel/client_uchannel.c +3 -3
- data/src/core/channel/compress_filter.c +8 -8
- data/src/core/channel/http_client_filter.c +2 -2
- data/src/core/channel/http_server_filter.c +9 -9
- data/src/core/channel/subchannel_call_holder.c +12 -10
- data/src/core/client_config/lb_policies/pick_first.c +49 -31
- data/src/core/client_config/lb_policies/round_robin.c +7 -7
- data/src/core/client_config/resolvers/dns_resolver.c +3 -3
- data/src/core/client_config/resolvers/sockaddr_resolver.c +5 -5
- data/src/core/client_config/subchannel.c +36 -25
- data/src/core/compression/algorithm.c +3 -3
- data/src/core/httpcli/format_request.c +1 -1
- data/src/core/httpcli/httpcli.c +5 -5
- data/src/core/httpcli/httpcli_security_connector.c +2 -3
- data/src/core/httpcli/parser.c +7 -7
- data/src/core/httpcli/parser.h +1 -1
- data/src/core/iomgr/closure.c +7 -7
- data/src/core/iomgr/closure.h +6 -5
- data/src/core/iomgr/exec_ctx.c +12 -8
- data/src/core/iomgr/exec_ctx.h +12 -5
- data/src/core/iomgr/executor.c +4 -4
- data/src/core/iomgr/executor.h +2 -2
- data/src/core/iomgr/fd_posix.c +28 -17
- data/src/core/iomgr/fd_posix.h +7 -4
- data/src/core/iomgr/iocp_windows.c +6 -8
- data/src/core/iomgr/pollset_multipoller_with_epoll.c +70 -5
- data/src/core/iomgr/pollset_multipoller_with_poll_posix.c +4 -2
- data/src/core/iomgr/pollset_posix.c +15 -15
- data/src/core/iomgr/pollset_posix.h +4 -2
- data/src/core/iomgr/pollset_windows.c +3 -12
- data/src/core/iomgr/resolve_address_posix.c +2 -2
- data/src/core/iomgr/resolve_address_windows.c +2 -2
- data/src/core/iomgr/sockaddr_utils.c +6 -6
- data/src/core/iomgr/sockaddr_win32.h +1 -6
- data/src/core/iomgr/tcp_client_posix.c +7 -7
- data/src/core/iomgr/tcp_client_windows.c +4 -4
- data/src/core/iomgr/tcp_posix.c +14 -8
- data/src/core/iomgr/tcp_posix.h +7 -1
- data/src/core/iomgr/tcp_server.h +40 -20
- data/src/core/iomgr/tcp_server_posix.c +106 -49
- data/src/core/iomgr/tcp_server_windows.c +98 -49
- data/src/core/iomgr/tcp_windows.c +11 -15
- data/src/core/iomgr/timer.c +8 -8
- data/src/core/iomgr/timer.h +1 -1
- data/src/core/iomgr/timer_heap.c +10 -10
- data/src/core/iomgr/timer_heap.h +2 -2
- data/src/core/iomgr/udp_server.c +2 -12
- data/src/core/iomgr/udp_server.h +1 -9
- data/src/core/iomgr/workqueue.h +2 -4
- data/src/core/iomgr/workqueue_posix.c +3 -3
- data/src/core/json/json_reader.c +11 -12
- data/src/core/json/json_reader.h +4 -4
- data/src/core/json/json_string.c +19 -19
- data/src/core/json/json_writer.c +7 -9
- data/src/core/profiling/basic_timers.c +1 -1
- data/src/core/security/base64.c +9 -9
- data/src/core/security/client_auth_filter.c +4 -4
- data/src/core/security/credentials.c +5 -5
- data/src/core/security/google_default_credentials.c +3 -3
- data/src/core/security/handshake.c +6 -5
- data/src/core/security/json_token.c +13 -7
- data/src/core/security/jwt_verifier.c +3 -2
- data/src/core/security/secure_endpoint.c +16 -16
- data/src/core/security/security_connector.c +47 -17
- data/src/core/security/security_connector.h +5 -5
- data/src/core/security/server_auth_filter.c +3 -3
- data/src/core/security/server_secure_chttp2.c +30 -31
- data/src/core/statistics/census_interface.h +2 -2
- data/src/core/statistics/census_rpc_stats.h +3 -3
- data/src/core/support/alloc.c +1 -1
- data/src/core/support/cpu_posix.c +2 -2
- data/src/core/support/env_linux.c +12 -2
- data/src/core/support/env_win32.c +15 -7
- data/src/core/support/histogram.c +5 -5
- data/src/core/support/log_posix.c +1 -1
- data/src/core/support/log_win32.c +4 -3
- data/src/core/support/murmur_hash.c +11 -11
- data/src/core/support/murmur_hash.h +1 -1
- data/src/core/support/slice.c +11 -11
- data/src/core/support/slice_buffer.c +6 -6
- data/src/core/support/stack_lockfree.c +20 -10
- data/src/core/support/string.c +15 -15
- data/src/core/support/string.h +5 -5
- data/src/core/support/string_win32.c +5 -5
- data/src/core/support/subprocess_windows.c +141 -0
- data/src/core/support/sync.c +4 -4
- data/src/core/support/sync_posix.c +2 -2
- data/src/core/support/sync_win32.c +10 -5
- data/src/core/support/time.c +29 -29
- data/src/core/support/time_posix.c +15 -6
- data/src/core/support/time_precise.c +2 -2
- data/src/core/support/time_win32.c +18 -9
- data/src/core/support/tls_pthread.c +1 -1
- data/src/core/support/wrap_memcpy.c +53 -0
- data/src/core/surface/alarm.c +83 -0
- data/src/core/surface/byte_buffer_reader.c +1 -1
- data/src/core/surface/call.c +78 -69
- data/src/core/surface/call.h +2 -2
- data/src/core/surface/call_test_only.h +2 -2
- data/src/core/surface/channel.c +9 -9
- data/src/core/surface/channel.h +1 -1
- data/src/core/surface/channel_connectivity.c +3 -3
- data/src/core/surface/channel_create.c +3 -3
- data/src/core/surface/channel_ping.c +2 -2
- data/src/core/surface/completion_queue.c +11 -12
- data/src/core/surface/completion_queue.h +1 -1
- data/src/core/surface/init.c +7 -5
- data/src/core/surface/lame_client.c +3 -3
- data/src/core/surface/secure_channel_create.c +3 -3
- data/src/core/surface/server.c +28 -28
- data/src/core/surface/server_chttp2.c +8 -8
- data/src/core/surface/server_create.c +1 -4
- data/src/core/surface/validate_metadata.c +3 -3
- data/src/core/surface/version.c +2 -2
- data/src/core/transport/byte_stream.c +8 -6
- data/src/core/transport/byte_stream.h +6 -5
- data/src/core/transport/chttp2/bin_encoder.c +29 -29
- data/src/core/transport/chttp2/frame_data.c +29 -26
- data/src/core/transport/chttp2/frame_data.h +6 -6
- data/src/core/transport/chttp2/frame_goaway.c +30 -30
- data/src/core/transport/chttp2/frame_goaway.h +6 -6
- data/src/core/transport/chttp2/frame_ping.c +6 -6
- data/src/core/transport/chttp2/frame_ping.h +5 -5
- data/src/core/transport/chttp2/frame_rst_stream.c +18 -19
- data/src/core/transport/chttp2/frame_rst_stream.h +4 -4
- data/src/core/transport/chttp2/frame_settings.c +30 -30
- data/src/core/transport/chttp2/frame_settings.h +13 -13
- data/src/core/transport/chttp2/frame_window_update.c +17 -18
- data/src/core/transport/chttp2/frame_window_update.h +5 -7
- data/src/core/transport/chttp2/hpack_encoder.c +69 -73
- data/src/core/transport/chttp2/hpack_encoder.h +16 -16
- data/src/core/transport/chttp2/hpack_parser.c +167 -167
- data/src/core/transport/chttp2/hpack_parser.h +16 -16
- data/src/core/transport/chttp2/hpack_table.c +13 -13
- data/src/core/transport/chttp2/hpack_table.h +11 -11
- data/src/core/transport/chttp2/internal.h +97 -86
- data/src/core/transport/chttp2/parsing.c +25 -25
- data/src/core/transport/chttp2/stream_lists.c +26 -3
- data/src/core/transport/chttp2/stream_map.c +13 -14
- data/src/core/transport/chttp2/stream_map.h +6 -7
- data/src/core/transport/chttp2/timeout_encoding.c +19 -16
- data/src/core/transport/chttp2/varint.c +8 -9
- data/src/core/transport/chttp2/varint.h +7 -8
- data/src/core/transport/chttp2/writing.c +26 -23
- data/src/core/transport/chttp2_transport.c +133 -92
- data/src/core/transport/connectivity_state.c +6 -6
- data/src/core/transport/metadata.c +18 -18
- data/src/core/transport/metadata.h +5 -5
- data/src/core/transport/static_metadata.c +15 -16
- data/src/core/transport/static_metadata.h +5 -5
- data/src/core/transport/transport.c +5 -5
- data/src/core/transport/transport.h +14 -1
- data/src/core/tsi/fake_transport_security.c +7 -7
- data/src/core/tsi/ssl_transport_security.c +6 -4
- data/src/core/tsi/ssl_types.h +55 -0
- data/src/ruby/ext/grpc/extconf.rb +51 -14
- data/src/ruby/ext/grpc/rb_byte_buffer.c +3 -1
- data/src/ruby/ext/grpc/rb_call.c +6 -3
- data/src/ruby/ext/grpc/rb_call_credentials.c +4 -0
- data/src/ruby/ext/grpc/rb_channel.c +4 -2
- data/src/ruby/ext/grpc/rb_channel_args.c +3 -1
- data/src/ruby/ext/grpc/rb_channel_credentials.c +3 -1
- data/src/ruby/ext/grpc/rb_completion_queue.c +3 -1
- data/src/ruby/ext/grpc/rb_event_thread.c +5 -0
- data/src/ruby/ext/grpc/rb_grpc.c +11 -3
- data/src/ruby/ext/grpc/rb_grpc_imports.generated.c +560 -0
- data/src/ruby/ext/grpc/rb_grpc_imports.generated.h +843 -0
- data/src/ruby/ext/grpc/rb_loader.c +72 -0
- data/src/ruby/ext/grpc/rb_loader.h +40 -0
- data/src/ruby/ext/grpc/rb_server.c +3 -1
- data/src/ruby/ext/grpc/rb_server_credentials.c +4 -2
- data/src/ruby/lib/grpc/generic/bidi_call.rb +1 -1
- data/src/ruby/lib/grpc/generic/rpc_desc.rb +1 -1
- data/src/ruby/lib/grpc/generic/rpc_server.rb +1 -1
- data/src/ruby/lib/grpc/grpc.rb +34 -0
- data/src/ruby/lib/grpc/version.rb +1 -1
- data/src/ruby/spec/pb/health/checker_spec.rb +1 -1
- data/third_party/boringssl/crypto/aes/aes.c +1142 -0
- data/third_party/boringssl/crypto/aes/internal.h +87 -0
- data/third_party/boringssl/crypto/aes/mode_wrappers.c +108 -0
- data/third_party/boringssl/crypto/asn1/a_bitstr.c +255 -0
- data/third_party/boringssl/crypto/asn1/a_bool.c +112 -0
- data/third_party/boringssl/crypto/asn1/a_bytes.c +317 -0
- data/third_party/boringssl/crypto/asn1/a_d2i_fp.c +286 -0
- data/third_party/boringssl/crypto/asn1/a_dup.c +103 -0
- data/third_party/boringssl/crypto/asn1/a_enum.c +183 -0
- data/third_party/boringssl/crypto/asn1/a_gentm.c +255 -0
- data/third_party/boringssl/crypto/asn1/a_i2d_fp.c +154 -0
- data/third_party/boringssl/crypto/asn1/a_int.c +456 -0
- data/third_party/boringssl/crypto/asn1/a_mbstr.c +390 -0
- data/third_party/boringssl/crypto/asn1/a_object.c +412 -0
- data/third_party/boringssl/crypto/asn1/a_octet.c +70 -0
- data/third_party/boringssl/crypto/asn1/a_print.c +119 -0
- data/third_party/boringssl/crypto/asn1/a_strnid.c +286 -0
- data/third_party/boringssl/crypto/asn1/a_time.c +221 -0
- data/third_party/boringssl/crypto/asn1/a_type.c +160 -0
- data/third_party/boringssl/crypto/asn1/a_utctm.c +342 -0
- data/third_party/boringssl/crypto/asn1/a_utf8.c +210 -0
- data/third_party/boringssl/crypto/asn1/asn1_lib.c +510 -0
- data/third_party/boringssl/crypto/asn1/asn1_locl.h +73 -0
- data/third_party/boringssl/crypto/asn1/asn1_par.c +444 -0
- data/third_party/boringssl/crypto/asn1/asn_pack.c +104 -0
- data/third_party/boringssl/crypto/asn1/bio_asn1.c +496 -0
- data/third_party/boringssl/crypto/asn1/bio_ndef.c +254 -0
- data/third_party/boringssl/crypto/asn1/f_enum.c +206 -0
- data/third_party/boringssl/crypto/asn1/f_int.c +210 -0
- data/third_party/boringssl/crypto/asn1/f_string.c +204 -0
- data/third_party/boringssl/crypto/asn1/t_bitst.c +102 -0
- data/third_party/boringssl/crypto/asn1/t_pkey.c +112 -0
- data/third_party/boringssl/crypto/asn1/tasn_dec.c +1342 -0
- data/third_party/boringssl/crypto/asn1/tasn_enc.c +695 -0
- data/third_party/boringssl/crypto/asn1/tasn_fre.c +264 -0
- data/third_party/boringssl/crypto/asn1/tasn_new.c +398 -0
- data/third_party/boringssl/crypto/asn1/tasn_prn.c +642 -0
- data/third_party/boringssl/crypto/asn1/tasn_typ.c +137 -0
- data/third_party/boringssl/crypto/asn1/tasn_utl.c +266 -0
- data/third_party/boringssl/crypto/asn1/x_bignum.c +143 -0
- data/third_party/boringssl/crypto/asn1/x_long.c +182 -0
- data/third_party/boringssl/crypto/base64/base64.c +478 -0
- data/third_party/boringssl/crypto/bio/bio.c +608 -0
- data/third_party/boringssl/crypto/bio/bio_mem.c +327 -0
- data/third_party/boringssl/crypto/bio/buffer.c +496 -0
- data/third_party/boringssl/crypto/bio/connect.c +544 -0
- data/third_party/boringssl/crypto/bio/fd.c +270 -0
- data/third_party/boringssl/crypto/bio/file.c +349 -0
- data/third_party/boringssl/crypto/bio/hexdump.c +192 -0
- data/third_party/boringssl/crypto/bio/internal.h +108 -0
- data/third_party/boringssl/crypto/bio/pair.c +803 -0
- data/third_party/boringssl/crypto/bio/printf.c +119 -0
- data/third_party/boringssl/crypto/bio/socket.c +195 -0
- data/third_party/boringssl/crypto/bio/socket_helper.c +113 -0
- data/third_party/boringssl/crypto/bn/add.c +377 -0
- data/third_party/boringssl/crypto/bn/asm/x86_64-gcc.c +599 -0
- data/third_party/boringssl/crypto/bn/bn.c +341 -0
- data/third_party/boringssl/crypto/bn/bn_asn1.c +93 -0
- data/third_party/boringssl/crypto/bn/cmp.c +200 -0
- data/third_party/boringssl/crypto/bn/convert.c +597 -0
- data/third_party/boringssl/crypto/bn/ctx.c +311 -0
- data/third_party/boringssl/crypto/bn/div.c +625 -0
- data/third_party/boringssl/crypto/bn/exponentiation.c +1544 -0
- data/third_party/boringssl/crypto/bn/gcd.c +711 -0
- data/third_party/boringssl/crypto/bn/generic.c +1019 -0
- data/third_party/boringssl/crypto/bn/internal.h +294 -0
- data/third_party/boringssl/crypto/bn/kronecker.c +175 -0
- data/third_party/boringssl/crypto/bn/montgomery.c +561 -0
- data/third_party/boringssl/crypto/bn/mul.c +888 -0
- data/third_party/boringssl/crypto/bn/prime.c +845 -0
- data/third_party/boringssl/crypto/bn/random.c +326 -0
- data/third_party/boringssl/crypto/bn/rsaz_exp.c +326 -0
- data/third_party/boringssl/crypto/bn/rsaz_exp.h +56 -0
- data/third_party/boringssl/crypto/bn/shift.c +299 -0
- data/third_party/boringssl/crypto/bn/sqrt.c +505 -0
- data/third_party/boringssl/crypto/buf/buf.c +235 -0
- data/third_party/boringssl/crypto/bytestring/ber.c +221 -0
- data/third_party/boringssl/crypto/bytestring/cbb.c +411 -0
- data/third_party/boringssl/crypto/bytestring/cbs.c +415 -0
- data/third_party/boringssl/crypto/bytestring/internal.h +46 -0
- data/third_party/boringssl/crypto/chacha/chacha_generic.c +140 -0
- data/third_party/boringssl/crypto/chacha/chacha_vec.c +323 -0
- data/third_party/boringssl/crypto/cipher/aead.c +167 -0
- data/third_party/boringssl/crypto/cipher/cipher.c +652 -0
- data/third_party/boringssl/crypto/cipher/derive_key.c +154 -0
- data/third_party/boringssl/crypto/cipher/e_aes.c +1767 -0
- data/third_party/boringssl/crypto/cipher/e_chacha20poly1305.c +311 -0
- data/third_party/boringssl/crypto/cipher/e_des.c +207 -0
- data/third_party/boringssl/crypto/cipher/e_null.c +85 -0
- data/third_party/boringssl/crypto/cipher/e_rc2.c +443 -0
- data/third_party/boringssl/crypto/cipher/e_rc4.c +87 -0
- data/third_party/boringssl/crypto/cipher/e_ssl3.c +463 -0
- data/third_party/boringssl/crypto/cipher/e_tls.c +673 -0
- data/third_party/boringssl/crypto/cipher/internal.h +164 -0
- data/third_party/boringssl/crypto/cipher/tls_cbc.c +495 -0
- data/third_party/boringssl/crypto/cmac/cmac.c +239 -0
- data/third_party/boringssl/crypto/conf/conf.c +778 -0
- data/third_party/boringssl/crypto/conf/conf_def.h +127 -0
- data/third_party/boringssl/crypto/conf/internal.h +31 -0
- data/third_party/boringssl/crypto/cpu-arm.c +199 -0
- data/third_party/boringssl/crypto/cpu-intel.c +261 -0
- data/third_party/boringssl/crypto/crypto.c +140 -0
- data/third_party/boringssl/crypto/curve25519/curve25519.c +4897 -0
- data/third_party/boringssl/crypto/des/des.c +771 -0
- data/third_party/boringssl/crypto/des/internal.h +212 -0
- data/third_party/boringssl/crypto/dh/check.c +180 -0
- data/third_party/boringssl/crypto/dh/dh.c +463 -0
- data/third_party/boringssl/crypto/dh/dh_asn1.c +84 -0
- data/third_party/boringssl/crypto/dh/internal.h +80 -0
- data/third_party/boringssl/crypto/dh/params.c +301 -0
- data/third_party/boringssl/crypto/digest/digest.c +248 -0
- data/third_party/boringssl/crypto/digest/digests.c +321 -0
- data/third_party/boringssl/crypto/digest/internal.h +112 -0
- data/third_party/boringssl/crypto/digest/md32_common.h +322 -0
- data/third_party/boringssl/crypto/directory.h +66 -0
- data/third_party/boringssl/crypto/directory_posix.c +108 -0
- data/third_party/boringssl/crypto/directory_win.c +144 -0
- data/third_party/boringssl/crypto/dsa/dsa.c +908 -0
- data/third_party/boringssl/crypto/dsa/dsa_asn1.c +150 -0
- data/third_party/boringssl/crypto/dsa/internal.h +78 -0
- data/third_party/boringssl/crypto/ec/ec.c +889 -0
- data/third_party/boringssl/crypto/ec/ec_asn1.c +586 -0
- data/third_party/boringssl/crypto/ec/ec_key.c +482 -0
- data/third_party/boringssl/crypto/ec/ec_montgomery.c +280 -0
- data/third_party/boringssl/crypto/ec/internal.h +318 -0
- data/third_party/boringssl/crypto/ec/oct.c +416 -0
- data/third_party/boringssl/crypto/ec/p224-64.c +1305 -0
- data/third_party/boringssl/crypto/ec/p256-64.c +1878 -0
- data/third_party/boringssl/crypto/ec/p256-x86_64-table.h +9548 -0
- data/third_party/boringssl/crypto/ec/p256-x86_64.c +596 -0
- data/third_party/boringssl/crypto/ec/simple.c +1313 -0
- data/third_party/boringssl/crypto/ec/util-64.c +183 -0
- data/third_party/boringssl/crypto/ec/wnaf.c +449 -0
- data/third_party/boringssl/crypto/ecdh/ecdh.c +153 -0
- data/third_party/boringssl/crypto/ecdsa/ecdsa.c +496 -0
- data/third_party/boringssl/crypto/ecdsa/ecdsa_asn1.c +240 -0
- data/third_party/boringssl/crypto/engine/engine.c +96 -0
- data/third_party/boringssl/crypto/err/err.c +756 -0
- data/third_party/boringssl/crypto/evp/algorithm.c +153 -0
- data/third_party/boringssl/crypto/evp/digestsign.c +159 -0
- data/third_party/boringssl/crypto/evp/evp.c +411 -0
- data/third_party/boringssl/crypto/evp/evp_asn1.c +179 -0
- data/third_party/boringssl/crypto/evp/evp_ctx.c +477 -0
- data/third_party/boringssl/crypto/evp/internal.h +278 -0
- data/third_party/boringssl/crypto/evp/p_dsa_asn1.c +588 -0
- data/third_party/boringssl/crypto/evp/p_ec.c +283 -0
- data/third_party/boringssl/crypto/evp/p_ec_asn1.c +562 -0
- data/third_party/boringssl/crypto/evp/p_rsa.c +596 -0
- data/third_party/boringssl/crypto/evp/p_rsa_asn1.c +737 -0
- data/third_party/boringssl/crypto/evp/pbkdf.c +151 -0
- data/third_party/boringssl/crypto/evp/sign.c +151 -0
- data/third_party/boringssl/crypto/ex_data.c +294 -0
- data/third_party/boringssl/crypto/hkdf/hkdf.c +89 -0
- data/third_party/boringssl/crypto/hmac/hmac.c +213 -0
- data/third_party/boringssl/crypto/internal.h +532 -0
- data/third_party/boringssl/crypto/lhash/lhash.c +346 -0
- data/third_party/boringssl/crypto/md4/md4.c +225 -0
- data/third_party/boringssl/crypto/md5/md5.c +275 -0
- data/third_party/boringssl/crypto/mem.c +200 -0
- data/third_party/boringssl/crypto/modes/cbc.c +216 -0
- data/third_party/boringssl/crypto/modes/cfb.c +231 -0
- data/third_party/boringssl/crypto/modes/ctr.c +226 -0
- data/third_party/boringssl/crypto/modes/gcm.c +1252 -0
- data/third_party/boringssl/crypto/modes/internal.h +370 -0
- data/third_party/boringssl/crypto/modes/ofb.c +108 -0
- data/third_party/boringssl/crypto/obj/obj.c +664 -0
- data/third_party/boringssl/crypto/obj/obj_dat.h +5257 -0
- data/third_party/boringssl/crypto/obj/obj_xref.c +124 -0
- data/third_party/boringssl/crypto/obj/obj_xref.h +96 -0
- data/third_party/boringssl/crypto/pem/pem_all.c +281 -0
- data/third_party/boringssl/crypto/pem/pem_info.c +404 -0
- data/third_party/boringssl/crypto/pem/pem_lib.c +835 -0
- data/third_party/boringssl/crypto/pem/pem_oth.c +89 -0
- data/third_party/boringssl/crypto/pem/pem_pk8.c +244 -0
- data/third_party/boringssl/crypto/pem/pem_pkey.c +312 -0
- data/third_party/boringssl/crypto/pem/pem_x509.c +65 -0
- data/third_party/boringssl/crypto/pem/pem_xaux.c +66 -0
- data/third_party/boringssl/crypto/pkcs8/internal.h +83 -0
- data/third_party/boringssl/crypto/pkcs8/p5_pbe.c +150 -0
- data/third_party/boringssl/crypto/pkcs8/p5_pbev2.c +440 -0
- data/third_party/boringssl/crypto/pkcs8/p8_pkey.c +85 -0
- data/third_party/boringssl/crypto/pkcs8/pkcs8.c +1217 -0
- data/third_party/boringssl/crypto/poly1305/poly1305.c +331 -0
- data/third_party/boringssl/crypto/poly1305/poly1305_arm.c +301 -0
- data/third_party/boringssl/crypto/poly1305/poly1305_vec.c +892 -0
- data/third_party/boringssl/crypto/rand/internal.h +32 -0
- data/third_party/boringssl/crypto/rand/rand.c +239 -0
- data/third_party/boringssl/crypto/rand/urandom.c +223 -0
- data/third_party/boringssl/crypto/rand/windows.c +56 -0
- data/third_party/boringssl/crypto/rc4/rc4.c +283 -0
- data/third_party/boringssl/crypto/refcount_c11.c +67 -0
- data/third_party/boringssl/crypto/refcount_lock.c +53 -0
- data/third_party/boringssl/crypto/rsa/blinding.c +462 -0
- data/third_party/boringssl/crypto/rsa/internal.h +164 -0
- data/third_party/boringssl/crypto/rsa/padding.c +711 -0
- data/third_party/boringssl/crypto/rsa/rsa.c +808 -0
- data/third_party/boringssl/crypto/rsa/rsa_asn1.c +473 -0
- data/third_party/boringssl/crypto/rsa/rsa_impl.c +1138 -0
- data/third_party/boringssl/crypto/sha/sha1.c +337 -0
- data/third_party/boringssl/crypto/sha/sha256.c +327 -0
- data/third_party/boringssl/crypto/sha/sha512.c +607 -0
- data/third_party/boringssl/crypto/stack/stack.c +386 -0
- data/third_party/boringssl/crypto/test/scoped_types.h +137 -0
- data/third_party/boringssl/crypto/test/test_util.h +35 -0
- data/third_party/boringssl/crypto/thread.c +101 -0
- data/third_party/boringssl/crypto/thread_none.c +55 -0
- data/third_party/boringssl/crypto/thread_pthread.c +167 -0
- data/third_party/boringssl/crypto/thread_win.c +282 -0
- data/third_party/boringssl/crypto/time_support.c +212 -0
- data/third_party/boringssl/crypto/x509/a_digest.c +97 -0
- data/third_party/boringssl/crypto/x509/a_sign.c +136 -0
- data/third_party/boringssl/crypto/x509/a_strex.c +564 -0
- data/third_party/boringssl/crypto/x509/a_verify.c +133 -0
- data/third_party/boringssl/crypto/x509/asn1_gen.c +873 -0
- data/third_party/boringssl/crypto/x509/by_dir.c +491 -0
- data/third_party/boringssl/crypto/x509/by_file.c +295 -0
- data/third_party/boringssl/crypto/x509/charmap.h +15 -0
- data/third_party/boringssl/crypto/x509/i2d_pr.c +84 -0
- data/third_party/boringssl/crypto/x509/pkcs7.c +353 -0
- data/third_party/boringssl/crypto/x509/t_crl.c +129 -0
- data/third_party/boringssl/crypto/x509/t_req.c +246 -0
- data/third_party/boringssl/crypto/x509/t_x509.c +500 -0
- data/third_party/boringssl/crypto/x509/t_x509a.c +109 -0
- data/third_party/boringssl/crypto/x509/vpm_int.h +70 -0
- data/third_party/boringssl/crypto/x509/x509.c +152 -0
- data/third_party/boringssl/crypto/x509/x509_att.c +353 -0
- data/third_party/boringssl/crypto/x509/x509_cmp.c +490 -0
- data/third_party/boringssl/crypto/x509/x509_d2.c +105 -0
- data/third_party/boringssl/crypto/x509/x509_def.c +88 -0
- data/third_party/boringssl/crypto/x509/x509_ext.c +206 -0
- data/third_party/boringssl/crypto/x509/x509_lu.c +738 -0
- data/third_party/boringssl/crypto/x509/x509_obj.c +191 -0
- data/third_party/boringssl/crypto/x509/x509_r2x.c +113 -0
- data/third_party/boringssl/crypto/x509/x509_req.c +315 -0
- data/third_party/boringssl/crypto/x509/x509_set.c +154 -0
- data/third_party/boringssl/crypto/x509/x509_trs.c +304 -0
- data/third_party/boringssl/crypto/x509/x509_txt.c +209 -0
- data/third_party/boringssl/crypto/x509/x509_v3.c +271 -0
- data/third_party/boringssl/crypto/x509/x509_vfy.c +2456 -0
- data/third_party/boringssl/crypto/x509/x509_vpm.c +672 -0
- data/third_party/boringssl/crypto/x509/x509cset.c +172 -0
- data/third_party/boringssl/crypto/x509/x509name.c +381 -0
- data/third_party/boringssl/crypto/x509/x509rset.c +80 -0
- data/third_party/boringssl/crypto/x509/x509spki.c +135 -0
- data/third_party/boringssl/crypto/x509/x509type.c +128 -0
- data/third_party/boringssl/crypto/x509/x_algor.c +154 -0
- data/third_party/boringssl/crypto/x509/x_all.c +547 -0
- data/third_party/boringssl/crypto/x509/x_attrib.c +117 -0
- data/third_party/boringssl/crypto/x509/x_crl.c +560 -0
- data/third_party/boringssl/crypto/x509/x_exten.c +75 -0
- data/third_party/boringssl/crypto/x509/x_info.c +95 -0
- data/third_party/boringssl/crypto/x509/x_name.c +538 -0
- data/third_party/boringssl/crypto/x509/x_pkey.c +100 -0
- data/third_party/boringssl/crypto/x509/x_pubkey.c +384 -0
- data/third_party/boringssl/crypto/x509/x_req.c +112 -0
- data/third_party/boringssl/crypto/x509/x_sig.c +69 -0
- data/third_party/boringssl/crypto/x509/x_spki.c +78 -0
- data/third_party/boringssl/crypto/x509/x_val.c +69 -0
- data/third_party/boringssl/crypto/x509/x_x509.c +227 -0
- data/third_party/boringssl/crypto/x509/x_x509a.c +197 -0
- data/third_party/boringssl/crypto/x509v3/ext_dat.h +129 -0
- data/third_party/boringssl/crypto/x509v3/pcy_cache.c +299 -0
- data/third_party/boringssl/crypto/x509v3/pcy_data.c +137 -0
- data/third_party/boringssl/crypto/x509v3/pcy_int.h +212 -0
- data/third_party/boringssl/crypto/x509v3/pcy_lib.c +165 -0
- data/third_party/boringssl/crypto/x509v3/pcy_map.c +133 -0
- data/third_party/boringssl/crypto/x509v3/pcy_node.c +197 -0
- data/third_party/boringssl/crypto/x509v3/pcy_tree.c +876 -0
- data/third_party/boringssl/crypto/x509v3/v3_akey.c +212 -0
- data/third_party/boringssl/crypto/x509v3/v3_akeya.c +71 -0
- data/third_party/boringssl/crypto/x509v3/v3_alt.c +622 -0
- data/third_party/boringssl/crypto/x509v3/v3_bcons.c +126 -0
- data/third_party/boringssl/crypto/x509v3/v3_bitst.c +141 -0
- data/third_party/boringssl/crypto/x509v3/v3_conf.c +459 -0
- data/third_party/boringssl/crypto/x509v3/v3_cpols.c +475 -0
- data/third_party/boringssl/crypto/x509v3/v3_crld.c +616 -0
- data/third_party/boringssl/crypto/x509v3/v3_enum.c +98 -0
- data/third_party/boringssl/crypto/x509v3/v3_extku.c +145 -0
- data/third_party/boringssl/crypto/x509v3/v3_genn.c +252 -0
- data/third_party/boringssl/crypto/x509v3/v3_ia5.c +117 -0
- data/third_party/boringssl/crypto/x509v3/v3_info.c +200 -0
- data/third_party/boringssl/crypto/x509v3/v3_int.c +87 -0
- data/third_party/boringssl/crypto/x509v3/v3_lib.c +335 -0
- data/third_party/boringssl/crypto/x509v3/v3_ncons.c +510 -0
- data/third_party/boringssl/crypto/x509v3/v3_pci.c +335 -0
- data/third_party/boringssl/crypto/x509v3/v3_pcia.c +56 -0
- data/third_party/boringssl/crypto/x509v3/v3_pcons.c +142 -0
- data/third_party/boringssl/crypto/x509v3/v3_pku.c +109 -0
- data/third_party/boringssl/crypto/x509v3/v3_pmaps.c +156 -0
- data/third_party/boringssl/crypto/x509v3/v3_prn.c +207 -0
- data/third_party/boringssl/crypto/x509v3/v3_purp.c +805 -0
- data/third_party/boringssl/crypto/x509v3/v3_skey.c +148 -0
- data/third_party/boringssl/crypto/x509v3/v3_sxnet.c +266 -0
- data/third_party/boringssl/crypto/x509v3/v3_utl.c +1322 -0
- data/third_party/boringssl/include/openssl/aead.h +346 -0
- data/third_party/boringssl/include/openssl/aes.h +158 -0
- data/third_party/boringssl/include/openssl/arm_arch.h +127 -0
- data/third_party/boringssl/include/openssl/asn1.h +1168 -0
- data/third_party/boringssl/include/openssl/asn1_mac.h +75 -0
- data/third_party/boringssl/include/openssl/asn1t.h +906 -0
- data/third_party/boringssl/include/openssl/base.h +261 -0
- data/third_party/boringssl/include/openssl/base64.h +184 -0
- data/third_party/boringssl/include/openssl/bio.h +902 -0
- data/third_party/boringssl/include/openssl/blowfish.h +93 -0
- data/third_party/boringssl/include/openssl/bn.h +885 -0
- data/third_party/boringssl/include/openssl/buf.h +118 -0
- data/third_party/boringssl/include/openssl/buffer.h +18 -0
- data/third_party/boringssl/include/openssl/bytestring.h +360 -0
- data/third_party/boringssl/include/openssl/cast.h +96 -0
- data/third_party/boringssl/include/openssl/chacha.h +37 -0
- data/third_party/boringssl/include/openssl/cipher.h +571 -0
- data/third_party/boringssl/include/openssl/cmac.h +76 -0
- data/third_party/boringssl/include/openssl/conf.h +145 -0
- data/third_party/boringssl/include/openssl/cpu.h +184 -0
- data/third_party/boringssl/include/openssl/crypto.h +68 -0
- data/third_party/boringssl/include/openssl/curve25519.h +88 -0
- data/third_party/boringssl/include/openssl/des.h +177 -0
- data/third_party/boringssl/include/openssl/dh.h +238 -0
- data/third_party/boringssl/include/openssl/digest.h +258 -0
- data/third_party/boringssl/include/openssl/dsa.h +343 -0
- data/third_party/boringssl/include/openssl/dtls1.h +16 -0
- data/third_party/boringssl/include/openssl/ec.h +355 -0
- data/third_party/boringssl/include/openssl/ec_key.h +280 -0
- data/third_party/boringssl/include/openssl/ecdh.h +102 -0
- data/third_party/boringssl/include/openssl/ecdsa.h +206 -0
- data/third_party/boringssl/include/openssl/engine.h +98 -0
- data/third_party/boringssl/include/openssl/err.h +487 -0
- data/third_party/boringssl/include/openssl/evp.h +750 -0
- data/third_party/boringssl/include/openssl/ex_data.h +213 -0
- data/third_party/boringssl/include/openssl/hkdf.h +44 -0
- data/third_party/boringssl/include/openssl/hmac.h +160 -0
- data/third_party/boringssl/include/openssl/lhash.h +192 -0
- data/third_party/boringssl/include/openssl/lhash_macros.h +132 -0
- data/third_party/boringssl/include/openssl/md4.h +102 -0
- data/third_party/boringssl/include/openssl/md5.h +107 -0
- data/third_party/boringssl/include/openssl/mem.h +140 -0
- data/third_party/boringssl/include/openssl/obj.h +198 -0
- data/third_party/boringssl/include/openssl/obj_mac.h +4140 -0
- data/third_party/boringssl/include/openssl/objects.h +18 -0
- data/third_party/boringssl/include/openssl/opensslfeatures.h +60 -0
- data/third_party/boringssl/include/openssl/opensslv.h +18 -0
- data/third_party/boringssl/include/openssl/ossl_typ.h +18 -0
- data/third_party/boringssl/include/openssl/pem.h +521 -0
- data/third_party/boringssl/include/openssl/pkcs12.h +18 -0
- data/third_party/boringssl/include/openssl/pkcs7.h +16 -0
- data/third_party/boringssl/include/openssl/pkcs8.h +220 -0
- data/third_party/boringssl/include/openssl/poly1305.h +51 -0
- data/third_party/boringssl/include/openssl/pqueue.h +146 -0
- data/third_party/boringssl/include/openssl/rand.h +113 -0
- data/third_party/boringssl/include/openssl/rc4.h +90 -0
- data/third_party/boringssl/include/openssl/rsa.h +637 -0
- data/third_party/boringssl/include/openssl/safestack.h +16 -0
- data/third_party/boringssl/include/openssl/sha.h +256 -0
- data/third_party/boringssl/include/openssl/srtp.h +18 -0
- data/third_party/boringssl/include/openssl/ssl.h +4466 -0
- data/third_party/boringssl/include/openssl/ssl3.h +441 -0
- data/third_party/boringssl/include/openssl/stack.h +298 -0
- data/third_party/boringssl/include/openssl/stack_macros.h +4190 -0
- data/third_party/boringssl/include/openssl/thread.h +173 -0
- data/third_party/boringssl/include/openssl/time_support.h +90 -0
- data/third_party/boringssl/include/openssl/tls1.h +653 -0
- data/third_party/boringssl/include/openssl/type_check.h +91 -0
- data/third_party/boringssl/include/openssl/x509.h +1258 -0
- data/third_party/boringssl/include/openssl/x509_vfy.h +611 -0
- data/third_party/boringssl/include/openssl/x509v3.h +798 -0
- data/third_party/boringssl/ssl/custom_extensions.c +257 -0
- data/third_party/boringssl/ssl/d1_both.c +880 -0
- data/third_party/boringssl/ssl/d1_clnt.c +566 -0
- data/third_party/boringssl/ssl/d1_lib.c +340 -0
- data/third_party/boringssl/ssl/d1_meth.c +130 -0
- data/third_party/boringssl/ssl/d1_pkt.c +578 -0
- data/third_party/boringssl/ssl/d1_srtp.c +234 -0
- data/third_party/boringssl/ssl/d1_srvr.c +485 -0
- data/third_party/boringssl/ssl/dtls_record.c +308 -0
- data/third_party/boringssl/ssl/internal.h +1276 -0
- data/third_party/boringssl/ssl/pqueue/pqueue.c +197 -0
- data/third_party/boringssl/ssl/s3_both.c +571 -0
- data/third_party/boringssl/ssl/s3_clnt.c +2241 -0
- data/third_party/boringssl/ssl/s3_enc.c +494 -0
- data/third_party/boringssl/ssl/s3_lib.c +587 -0
- data/third_party/boringssl/ssl/s3_meth.c +166 -0
- data/third_party/boringssl/ssl/s3_pkt.c +732 -0
- data/third_party/boringssl/ssl/s3_srvr.c +2536 -0
- data/third_party/boringssl/ssl/ssl_aead_ctx.c +300 -0
- data/third_party/boringssl/ssl/ssl_asn1.c +718 -0
- data/third_party/boringssl/ssl/ssl_buffer.c +319 -0
- data/third_party/boringssl/ssl/ssl_cert.c +539 -0
- data/third_party/boringssl/ssl/ssl_cipher.c +2003 -0
- data/third_party/boringssl/ssl/ssl_file.c +633 -0
- data/third_party/boringssl/ssl/ssl_lib.c +2653 -0
- data/third_party/boringssl/ssl/ssl_rsa.c +423 -0
- data/third_party/boringssl/ssl/ssl_session.c +764 -0
- data/third_party/boringssl/ssl/ssl_stat.c +591 -0
- data/third_party/boringssl/ssl/t1_enc.c +708 -0
- data/third_party/boringssl/ssl/t1_lib.c +2905 -0
- data/third_party/boringssl/ssl/test/async_bio.h +45 -0
- data/third_party/boringssl/ssl/test/packeted_bio.h +44 -0
- data/third_party/boringssl/ssl/test/scoped_types.h +28 -0
- data/third_party/boringssl/ssl/test/test_config.h +108 -0
- data/third_party/boringssl/ssl/tls_record.c +342 -0
- data/third_party/zlib/adler32.c +179 -0
- data/third_party/zlib/compress.c +80 -0
- data/third_party/zlib/crc32.c +425 -0
- data/third_party/zlib/crc32.h +441 -0
- data/third_party/zlib/deflate.c +1967 -0
- data/third_party/zlib/deflate.h +346 -0
- data/third_party/zlib/gzclose.c +25 -0
- data/third_party/zlib/gzguts.h +209 -0
- data/third_party/zlib/gzlib.c +634 -0
- data/third_party/zlib/gzread.c +594 -0
- data/third_party/zlib/gzwrite.c +577 -0
- data/third_party/zlib/infback.c +640 -0
- data/third_party/zlib/inffast.c +340 -0
- data/third_party/zlib/inffast.h +11 -0
- data/third_party/zlib/inffixed.h +94 -0
- data/third_party/zlib/inflate.c +1512 -0
- data/third_party/zlib/inflate.h +122 -0
- data/third_party/zlib/inftrees.c +306 -0
- data/third_party/zlib/inftrees.h +62 -0
- data/third_party/zlib/trees.c +1226 -0
- data/third_party/zlib/trees.h +128 -0
- data/third_party/zlib/uncompr.c +59 -0
- data/third_party/zlib/zconf.h +511 -0
- data/third_party/zlib/zlib.h +1768 -0
- data/third_party/zlib/zutil.c +324 -0
- data/third_party/zlib/zutil.h +253 -0
- metadata +492 -25
- data/Rakefile +0 -63
- data/src/ruby/lib/grpc/grpc.so +0 -0
@@ -0,0 +1,192 @@
|
|
1
|
+
/* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com)
|
2
|
+
* All rights reserved.
|
3
|
+
*
|
4
|
+
* This package is an SSL implementation written
|
5
|
+
* by Eric Young (eay@cryptsoft.com).
|
6
|
+
* The implementation was written so as to conform with Netscapes SSL.
|
7
|
+
*
|
8
|
+
* This library is free for commercial and non-commercial use as long as
|
9
|
+
* the following conditions are aheared to. The following conditions
|
10
|
+
* apply to all code found in this distribution, be it the RC4, RSA,
|
11
|
+
* lhash, DES, etc., code; not just the SSL code. The SSL documentation
|
12
|
+
* included with this distribution is covered by the same copyright terms
|
13
|
+
* except that the holder is Tim Hudson (tjh@cryptsoft.com).
|
14
|
+
*
|
15
|
+
* Copyright remains Eric Young's, and as such any Copyright notices in
|
16
|
+
* the code are not to be removed.
|
17
|
+
* If this package is used in a product, Eric Young should be given attribution
|
18
|
+
* as the author of the parts of the library used.
|
19
|
+
* This can be in the form of a textual message at program startup or
|
20
|
+
* in documentation (online or textual) provided with the package.
|
21
|
+
*
|
22
|
+
* Redistribution and use in source and binary forms, with or without
|
23
|
+
* modification, are permitted provided that the following conditions
|
24
|
+
* are met:
|
25
|
+
* 1. Redistributions of source code must retain the copyright
|
26
|
+
* notice, this list of conditions and the following disclaimer.
|
27
|
+
* 2. Redistributions in binary form must reproduce the above copyright
|
28
|
+
* notice, this list of conditions and the following disclaimer in the
|
29
|
+
* documentation and/or other materials provided with the distribution.
|
30
|
+
* 3. All advertising materials mentioning features or use of this software
|
31
|
+
* must display the following acknowledgement:
|
32
|
+
* "This product includes cryptographic software written by
|
33
|
+
* Eric Young (eay@cryptsoft.com)"
|
34
|
+
* The word 'cryptographic' can be left out if the rouines from the library
|
35
|
+
* being used are not cryptographic related :-).
|
36
|
+
* 4. If you include any Windows specific code (or a derivative thereof) from
|
37
|
+
* the apps directory (application code) you must include an acknowledgement:
|
38
|
+
* "This product includes software written by Tim Hudson (tjh@cryptsoft.com)"
|
39
|
+
*
|
40
|
+
* THIS SOFTWARE IS PROVIDED BY ERIC YOUNG ``AS IS'' AND
|
41
|
+
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
42
|
+
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
43
|
+
* ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
44
|
+
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
45
|
+
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
46
|
+
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
47
|
+
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
48
|
+
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
49
|
+
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
50
|
+
* SUCH DAMAGE.
|
51
|
+
*
|
52
|
+
* The licence and distribution terms for any publically available version or
|
53
|
+
* derivative of this code cannot be changed. i.e. this code cannot simply be
|
54
|
+
* copied and put under another distribution licence
|
55
|
+
* [including the GNU Public Licence.] */
|
56
|
+
|
57
|
+
#include <openssl/bio.h>
|
58
|
+
|
59
|
+
#include <limits.h>
|
60
|
+
#include <string.h>
|
61
|
+
|
62
|
+
|
63
|
+
/* hexdump_ctx contains the state of a hexdump. */
|
64
|
+
struct hexdump_ctx {
|
65
|
+
BIO *bio;
|
66
|
+
char right_chars[18]; /* the contents of the right-hand side, ASCII dump. */
|
67
|
+
unsigned used; /* number of bytes in the current line. */
|
68
|
+
size_t n; /* number of bytes total. */
|
69
|
+
unsigned indent;
|
70
|
+
};
|
71
|
+
|
72
|
+
static void hexbyte(char *out, uint8_t b) {
|
73
|
+
static const char hextable[] = "0123456789abcdef";
|
74
|
+
out[0] = hextable[b>>4];
|
75
|
+
out[1] = hextable[b&0x0f];
|
76
|
+
}
|
77
|
+
|
78
|
+
static char to_char(uint8_t b) {
|
79
|
+
if (b < 32 || b > 126) {
|
80
|
+
return '.';
|
81
|
+
}
|
82
|
+
return b;
|
83
|
+
}
|
84
|
+
|
85
|
+
/* hexdump_write adds |len| bytes of |data| to the current hex dump described by
|
86
|
+
* |ctx|. */
|
87
|
+
static int hexdump_write(struct hexdump_ctx *ctx, const uint8_t *data,
|
88
|
+
size_t len) {
|
89
|
+
size_t i;
|
90
|
+
char buf[10];
|
91
|
+
unsigned l;
|
92
|
+
|
93
|
+
/* Output lines look like:
|
94
|
+
* 00000010 2e 2f 30 31 32 33 34 35 36 37 38 ... 3c 3d // |./0123456789:;<=|
|
95
|
+
* ^ offset ^ extra space ^ ASCII of line
|
96
|
+
*/
|
97
|
+
|
98
|
+
for (i = 0; i < len; i++) {
|
99
|
+
if (ctx->used == 0) {
|
100
|
+
/* The beginning of a line. */
|
101
|
+
BIO_indent(ctx->bio, ctx->indent, UINT_MAX);
|
102
|
+
|
103
|
+
hexbyte(&buf[0], ctx->n >> 24);
|
104
|
+
hexbyte(&buf[2], ctx->n >> 16);
|
105
|
+
hexbyte(&buf[4], ctx->n >> 8);
|
106
|
+
hexbyte(&buf[6], ctx->n);
|
107
|
+
buf[8] = buf[9] = ' ';
|
108
|
+
if (BIO_write(ctx->bio, buf, 10) < 0) {
|
109
|
+
return 0;
|
110
|
+
}
|
111
|
+
}
|
112
|
+
|
113
|
+
hexbyte(buf, data[i]);
|
114
|
+
buf[2] = ' ';
|
115
|
+
l = 3;
|
116
|
+
if (ctx->used == 7) {
|
117
|
+
/* There's an additional space after the 8th byte. */
|
118
|
+
buf[3] = ' ';
|
119
|
+
l = 4;
|
120
|
+
} else if (ctx->used == 15) {
|
121
|
+
/* At the end of the line there's an extra space and the bar for the
|
122
|
+
* right column. */
|
123
|
+
buf[3] = ' ';
|
124
|
+
buf[4] = '|';
|
125
|
+
l = 5;
|
126
|
+
}
|
127
|
+
|
128
|
+
if (BIO_write(ctx->bio, buf, l) < 0) {
|
129
|
+
return 0;
|
130
|
+
}
|
131
|
+
ctx->right_chars[ctx->used] = to_char(data[i]);
|
132
|
+
ctx->used++;
|
133
|
+
ctx->n++;
|
134
|
+
if (ctx->used == 16) {
|
135
|
+
ctx->right_chars[16] = '|';
|
136
|
+
ctx->right_chars[17] = '\n';
|
137
|
+
if (BIO_write(ctx->bio, ctx->right_chars, sizeof(ctx->right_chars)) < 0) {
|
138
|
+
return 0;
|
139
|
+
}
|
140
|
+
ctx->used = 0;
|
141
|
+
}
|
142
|
+
}
|
143
|
+
|
144
|
+
return 1;
|
145
|
+
}
|
146
|
+
|
147
|
+
/* finish flushes any buffered data in |ctx|. */
|
148
|
+
static int finish(struct hexdump_ctx *ctx) {
|
149
|
+
/* See the comments in |hexdump| for the details of this format. */
|
150
|
+
const unsigned n_bytes = ctx->used;
|
151
|
+
unsigned l;
|
152
|
+
char buf[5];
|
153
|
+
|
154
|
+
if (n_bytes == 0) {
|
155
|
+
return 1;
|
156
|
+
}
|
157
|
+
|
158
|
+
memset(buf, ' ', 4);
|
159
|
+
buf[4] = '|';
|
160
|
+
|
161
|
+
for (; ctx->used < 16; ctx->used++) {
|
162
|
+
l = 3;
|
163
|
+
if (ctx->used == 7) {
|
164
|
+
l = 4;
|
165
|
+
} else if (ctx->used == 15) {
|
166
|
+
l = 5;
|
167
|
+
}
|
168
|
+
if (BIO_write(ctx->bio, buf, l) < 0) {
|
169
|
+
return 0;
|
170
|
+
}
|
171
|
+
}
|
172
|
+
|
173
|
+
ctx->right_chars[n_bytes] = '|';
|
174
|
+
ctx->right_chars[n_bytes + 1] = '\n';
|
175
|
+
if (BIO_write(ctx->bio, ctx->right_chars, n_bytes + 2) < 0) {
|
176
|
+
return 0;
|
177
|
+
}
|
178
|
+
return 1;
|
179
|
+
}
|
180
|
+
|
181
|
+
int BIO_hexdump(BIO *bio, const uint8_t *data, size_t len, unsigned indent) {
|
182
|
+
struct hexdump_ctx ctx;
|
183
|
+
memset(&ctx, 0, sizeof(ctx));
|
184
|
+
ctx.bio = bio;
|
185
|
+
ctx.indent = indent;
|
186
|
+
|
187
|
+
if (!hexdump_write(&ctx, data, len) || !finish(&ctx)) {
|
188
|
+
return 0;
|
189
|
+
}
|
190
|
+
|
191
|
+
return 1;
|
192
|
+
}
|
@@ -0,0 +1,108 @@
|
|
1
|
+
/* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com)
|
2
|
+
* All rights reserved.
|
3
|
+
*
|
4
|
+
* This package is an SSL implementation written
|
5
|
+
* by Eric Young (eay@cryptsoft.com).
|
6
|
+
* The implementation was written so as to conform with Netscapes SSL.
|
7
|
+
*
|
8
|
+
* This library is free for commercial and non-commercial use as long as
|
9
|
+
* the following conditions are aheared to. The following conditions
|
10
|
+
* apply to all code found in this distribution, be it the RC4, RSA,
|
11
|
+
* lhash, DES, etc., code; not just the SSL code. The SSL documentation
|
12
|
+
* included with this distribution is covered by the same copyright terms
|
13
|
+
* except that the holder is Tim Hudson (tjh@cryptsoft.com).
|
14
|
+
*
|
15
|
+
* Copyright remains Eric Young's, and as such any Copyright notices in
|
16
|
+
* the code are not to be removed.
|
17
|
+
* If this package is used in a product, Eric Young should be given attribution
|
18
|
+
* as the author of the parts of the library used.
|
19
|
+
* This can be in the form of a textual message at program startup or
|
20
|
+
* in documentation (online or textual) provided with the package.
|
21
|
+
*
|
22
|
+
* Redistribution and use in source and binary forms, with or without
|
23
|
+
* modification, are permitted provided that the following conditions
|
24
|
+
* are met:
|
25
|
+
* 1. Redistributions of source code must retain the copyright
|
26
|
+
* notice, this list of conditions and the following disclaimer.
|
27
|
+
* 2. Redistributions in binary form must reproduce the above copyright
|
28
|
+
* notice, this list of conditions and the following disclaimer in the
|
29
|
+
* documentation and/or other materials provided with the distribution.
|
30
|
+
* 3. All advertising materials mentioning features or use of this software
|
31
|
+
* must display the following acknowledgement:
|
32
|
+
* "This product includes cryptographic software written by
|
33
|
+
* Eric Young (eay@cryptsoft.com)"
|
34
|
+
* The word 'cryptographic' can be left out if the rouines from the library
|
35
|
+
* being used are not cryptographic related :-).
|
36
|
+
* 4. If you include any Windows specific code (or a derivative thereof) from
|
37
|
+
* the apps directory (application code) you must include an acknowledgement:
|
38
|
+
* "This product includes software written by Tim Hudson (tjh@cryptsoft.com)"
|
39
|
+
*
|
40
|
+
* THIS SOFTWARE IS PROVIDED BY ERIC YOUNG ``AS IS'' AND
|
41
|
+
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
42
|
+
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
43
|
+
* ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
44
|
+
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
45
|
+
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
46
|
+
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
47
|
+
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
48
|
+
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
49
|
+
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
50
|
+
* SUCH DAMAGE.
|
51
|
+
*
|
52
|
+
* The licence and distribution terms for any publically available version or
|
53
|
+
* derivative of this code cannot be changed. i.e. this code cannot simply be
|
54
|
+
* copied and put under another distribution licence
|
55
|
+
* [including the GNU Public Licence.] */
|
56
|
+
|
57
|
+
#ifndef OPENSSL_HEADER_BIO_INTERNAL_H
|
58
|
+
#define OPENSSL_HEADER_BIO_INTERNAL_H
|
59
|
+
|
60
|
+
#include <openssl/base.h>
|
61
|
+
|
62
|
+
#if !defined(OPENSSL_WINDOWS)
|
63
|
+
#if defined(OPENSSL_PNACL)
|
64
|
+
/* newlib uses u_short in socket.h without defining it. */
|
65
|
+
typedef unsigned short u_short;
|
66
|
+
#endif
|
67
|
+
#include <sys/types.h>
|
68
|
+
#include <sys/socket.h>
|
69
|
+
#else
|
70
|
+
typedef int socklen_t;
|
71
|
+
#endif
|
72
|
+
|
73
|
+
#if defined(__cplusplus)
|
74
|
+
extern "C" {
|
75
|
+
#endif
|
76
|
+
|
77
|
+
|
78
|
+
/* BIO_ip_and_port_to_socket_and_addr creates a socket and fills in |*out_addr|
|
79
|
+
* and |*out_addr_length| with the correct values for connecting to |hostname|
|
80
|
+
* on |port_str|. It returns one on success or zero on error. */
|
81
|
+
int bio_ip_and_port_to_socket_and_addr(int *out_sock,
|
82
|
+
struct sockaddr_storage *out_addr,
|
83
|
+
socklen_t *out_addr_length,
|
84
|
+
const char *hostname,
|
85
|
+
const char *port_str);
|
86
|
+
|
87
|
+
/* BIO_socket_nbio sets whether |sock| is non-blocking. It returns one on
|
88
|
+
* success and zero otherwise. */
|
89
|
+
int bio_socket_nbio(int sock, int on);
|
90
|
+
|
91
|
+
/* BIO_clear_socket_error clears the last system socket error.
|
92
|
+
*
|
93
|
+
* TODO(fork): remove all callers of this. */
|
94
|
+
void bio_clear_socket_error(void);
|
95
|
+
|
96
|
+
/* BIO_sock_error returns the last socket error on |sock|. */
|
97
|
+
int bio_sock_error(int sock);
|
98
|
+
|
99
|
+
/* BIO_fd_should_retry returns non-zero if |return_value| indicates an error
|
100
|
+
* and |errno| indicates that it's non-fatal. */
|
101
|
+
int bio_fd_should_retry(int return_value);
|
102
|
+
|
103
|
+
|
104
|
+
#if defined(__cplusplus)
|
105
|
+
} /* extern C */
|
106
|
+
#endif
|
107
|
+
|
108
|
+
#endif /* OPENSSL_HEADER_BIO_INTERNAL_H */
|
@@ -0,0 +1,803 @@
|
|
1
|
+
/* ====================================================================
|
2
|
+
* Copyright (c) 1998-2003 The OpenSSL Project. All rights reserved.
|
3
|
+
*
|
4
|
+
* Redistribution and use in source and binary forms, with or without
|
5
|
+
* modification, are permitted provided that the following conditions
|
6
|
+
* are met:
|
7
|
+
*
|
8
|
+
* 1. Redistributions of source code must retain the above copyright
|
9
|
+
* notice, this list of conditions and the following disclaimer.
|
10
|
+
*
|
11
|
+
* 2. Redistributions in binary form must reproduce the above copyright
|
12
|
+
* notice, this list of conditions and the following disclaimer in
|
13
|
+
* the documentation and/or other materials provided with the
|
14
|
+
* distribution.
|
15
|
+
*
|
16
|
+
* 3. All advertising materials mentioning features or use of this
|
17
|
+
* software must display the following acknowledgment:
|
18
|
+
* "This product includes software developed by the OpenSSL Project
|
19
|
+
* for use in the OpenSSL Toolkit. (http://www.openssl.org/)"
|
20
|
+
*
|
21
|
+
* 4. The names "OpenSSL Toolkit" and "OpenSSL Project" must not be used to
|
22
|
+
* endorse or promote products derived from this software without
|
23
|
+
* prior written permission. For written permission, please contact
|
24
|
+
* openssl-core@openssl.org.
|
25
|
+
*
|
26
|
+
* 5. Products derived from this software may not be called "OpenSSL"
|
27
|
+
* nor may "OpenSSL" appear in their names without prior written
|
28
|
+
* permission of the OpenSSL Project.
|
29
|
+
*
|
30
|
+
* 6. Redistributions of any form whatsoever must retain the following
|
31
|
+
* acknowledgment:
|
32
|
+
* "This product includes software developed by the OpenSSL Project
|
33
|
+
* for use in the OpenSSL Toolkit (http://www.openssl.org/)"
|
34
|
+
*
|
35
|
+
* THIS SOFTWARE IS PROVIDED BY THE OpenSSL PROJECT ``AS IS'' AND ANY
|
36
|
+
* EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
37
|
+
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
38
|
+
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE OpenSSL PROJECT OR
|
39
|
+
* ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
40
|
+
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
41
|
+
* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
42
|
+
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
43
|
+
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
|
44
|
+
* STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
45
|
+
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
|
46
|
+
* OF THE POSSIBILITY OF SUCH DAMAGE.
|
47
|
+
* ====================================================================
|
48
|
+
*
|
49
|
+
* This product includes cryptographic software written by Eric Young
|
50
|
+
* (eay@cryptsoft.com). This product includes software written by Tim
|
51
|
+
* Hudson (tjh@cryptsoft.com). */
|
52
|
+
|
53
|
+
#include <openssl/bio.h>
|
54
|
+
|
55
|
+
#include <assert.h>
|
56
|
+
#include <string.h>
|
57
|
+
|
58
|
+
#include <openssl/buf.h>
|
59
|
+
#include <openssl/err.h>
|
60
|
+
#include <openssl/mem.h>
|
61
|
+
|
62
|
+
|
63
|
+
struct bio_bio_st {
|
64
|
+
BIO *peer; /* NULL if buf == NULL.
|
65
|
+
* If peer != NULL, then peer->ptr is also a bio_bio_st,
|
66
|
+
* and its "peer" member points back to us.
|
67
|
+
* peer != NULL iff init != 0 in the BIO. */
|
68
|
+
|
69
|
+
/* This is for what we write (i.e. reading uses peer's struct): */
|
70
|
+
int closed; /* valid iff peer != NULL */
|
71
|
+
size_t len; /* valid iff buf != NULL; 0 if peer == NULL */
|
72
|
+
size_t offset; /* valid iff buf != NULL; 0 if len == 0 */
|
73
|
+
size_t size;
|
74
|
+
uint8_t *buf; /* "size" elements (if != NULL) */
|
75
|
+
char buf_externally_allocated; /* true iff buf was externally allocated. */
|
76
|
+
|
77
|
+
char zero_copy_read_lock; /* true iff a zero copy read operation
|
78
|
+
* is in progress. */
|
79
|
+
char zero_copy_write_lock; /* true iff a zero copy write operation
|
80
|
+
* is in progress. */
|
81
|
+
|
82
|
+
size_t request; /* valid iff peer != NULL; 0 if len != 0,
|
83
|
+
* otherwise set by peer to number of bytes
|
84
|
+
* it (unsuccessfully) tried to read,
|
85
|
+
* never more than buffer space (size-len) warrants. */
|
86
|
+
};
|
87
|
+
|
88
|
+
static int bio_new(BIO *bio) {
|
89
|
+
struct bio_bio_st *b;
|
90
|
+
|
91
|
+
b = OPENSSL_malloc(sizeof *b);
|
92
|
+
if (b == NULL) {
|
93
|
+
return 0;
|
94
|
+
}
|
95
|
+
memset(b, 0, sizeof(struct bio_bio_st));
|
96
|
+
|
97
|
+
b->size = 17 * 1024; /* enough for one TLS record (just a default) */
|
98
|
+
bio->ptr = b;
|
99
|
+
return 1;
|
100
|
+
}
|
101
|
+
|
102
|
+
static void bio_destroy_pair(BIO *bio) {
|
103
|
+
struct bio_bio_st *b = bio->ptr;
|
104
|
+
BIO *peer_bio;
|
105
|
+
struct bio_bio_st *peer_b;
|
106
|
+
|
107
|
+
if (b == NULL) {
|
108
|
+
return;
|
109
|
+
}
|
110
|
+
|
111
|
+
peer_bio = b->peer;
|
112
|
+
if (peer_bio == NULL) {
|
113
|
+
return;
|
114
|
+
}
|
115
|
+
|
116
|
+
peer_b = peer_bio->ptr;
|
117
|
+
|
118
|
+
assert(peer_b != NULL);
|
119
|
+
assert(peer_b->peer == bio);
|
120
|
+
|
121
|
+
peer_b->peer = NULL;
|
122
|
+
peer_bio->init = 0;
|
123
|
+
assert(peer_b->buf != NULL);
|
124
|
+
peer_b->len = 0;
|
125
|
+
peer_b->offset = 0;
|
126
|
+
|
127
|
+
b->peer = NULL;
|
128
|
+
bio->init = 0;
|
129
|
+
assert(b->buf != NULL);
|
130
|
+
b->len = 0;
|
131
|
+
b->offset = 0;
|
132
|
+
}
|
133
|
+
|
134
|
+
static int bio_free(BIO *bio) {
|
135
|
+
struct bio_bio_st *b;
|
136
|
+
|
137
|
+
if (bio == NULL) {
|
138
|
+
return 0;
|
139
|
+
}
|
140
|
+
b = bio->ptr;
|
141
|
+
|
142
|
+
assert(b != NULL);
|
143
|
+
|
144
|
+
if (b->peer) {
|
145
|
+
bio_destroy_pair(bio);
|
146
|
+
}
|
147
|
+
|
148
|
+
if (!b->buf_externally_allocated) {
|
149
|
+
OPENSSL_free(b->buf);
|
150
|
+
}
|
151
|
+
|
152
|
+
OPENSSL_free(b);
|
153
|
+
|
154
|
+
return 1;
|
155
|
+
}
|
156
|
+
|
157
|
+
static size_t bio_zero_copy_get_read_buf(struct bio_bio_st* peer_b,
|
158
|
+
uint8_t** out_read_buf,
|
159
|
+
size_t* out_buf_offset) {
|
160
|
+
size_t max_available;
|
161
|
+
if (peer_b->len > peer_b->size - peer_b->offset) {
|
162
|
+
/* Only the first half of the ring buffer can be read. */
|
163
|
+
max_available = peer_b->size - peer_b->offset;
|
164
|
+
} else {
|
165
|
+
max_available = peer_b->len;
|
166
|
+
}
|
167
|
+
|
168
|
+
*out_read_buf = peer_b->buf;
|
169
|
+
*out_buf_offset = peer_b->offset;
|
170
|
+
return max_available;
|
171
|
+
}
|
172
|
+
|
173
|
+
int BIO_zero_copy_get_read_buf(BIO* bio, uint8_t** out_read_buf,
|
174
|
+
size_t* out_buf_offset,
|
175
|
+
size_t* out_available_bytes) {
|
176
|
+
struct bio_bio_st* b;
|
177
|
+
struct bio_bio_st* peer_b;
|
178
|
+
size_t max_available;
|
179
|
+
*out_available_bytes = 0;
|
180
|
+
|
181
|
+
BIO_clear_retry_flags(bio);
|
182
|
+
|
183
|
+
if (!bio->init) {
|
184
|
+
OPENSSL_PUT_ERROR(BIO, BIO_R_UNINITIALIZED);
|
185
|
+
return 0;
|
186
|
+
}
|
187
|
+
|
188
|
+
b = bio->ptr;
|
189
|
+
|
190
|
+
if (!b || !b->peer) {
|
191
|
+
OPENSSL_PUT_ERROR(BIO, BIO_R_UNSUPPORTED_METHOD);
|
192
|
+
return 0;
|
193
|
+
}
|
194
|
+
|
195
|
+
peer_b = b->peer->ptr;
|
196
|
+
if (!peer_b || !peer_b->peer || peer_b->peer->ptr != b) {
|
197
|
+
OPENSSL_PUT_ERROR(BIO, BIO_R_UNSUPPORTED_METHOD);
|
198
|
+
return 0;
|
199
|
+
}
|
200
|
+
|
201
|
+
if (peer_b->zero_copy_read_lock) {
|
202
|
+
OPENSSL_PUT_ERROR(BIO, BIO_R_INVALID_ARGUMENT);
|
203
|
+
return 0;
|
204
|
+
}
|
205
|
+
|
206
|
+
peer_b->request = 0; /* Is not used by zero-copy API. */
|
207
|
+
|
208
|
+
max_available =
|
209
|
+
bio_zero_copy_get_read_buf(peer_b, out_read_buf, out_buf_offset);
|
210
|
+
|
211
|
+
assert(peer_b->buf != NULL);
|
212
|
+
if (max_available > 0) {
|
213
|
+
peer_b->zero_copy_read_lock = 1;
|
214
|
+
}
|
215
|
+
|
216
|
+
*out_available_bytes = max_available;
|
217
|
+
return 1;
|
218
|
+
}
|
219
|
+
|
220
|
+
int BIO_zero_copy_get_read_buf_done(BIO* bio, size_t bytes_read) {
|
221
|
+
struct bio_bio_st* b;
|
222
|
+
struct bio_bio_st* peer_b;
|
223
|
+
size_t max_available;
|
224
|
+
size_t dummy_read_offset;
|
225
|
+
uint8_t* dummy_read_buf;
|
226
|
+
|
227
|
+
assert(BIO_get_retry_flags(bio) == 0);
|
228
|
+
|
229
|
+
if (!bio->init) {
|
230
|
+
OPENSSL_PUT_ERROR(BIO, BIO_R_UNINITIALIZED);
|
231
|
+
return 0;
|
232
|
+
}
|
233
|
+
|
234
|
+
b = bio->ptr;
|
235
|
+
|
236
|
+
if (!b || !b->peer) {
|
237
|
+
OPENSSL_PUT_ERROR(BIO, BIO_R_UNSUPPORTED_METHOD);
|
238
|
+
return 0;
|
239
|
+
}
|
240
|
+
|
241
|
+
peer_b = b->peer->ptr;
|
242
|
+
if (!peer_b || !peer_b->peer || peer_b->peer->ptr != b) {
|
243
|
+
OPENSSL_PUT_ERROR(BIO, BIO_R_UNSUPPORTED_METHOD);
|
244
|
+
return 0;
|
245
|
+
}
|
246
|
+
|
247
|
+
if (!peer_b->zero_copy_read_lock) {
|
248
|
+
OPENSSL_PUT_ERROR(BIO, BIO_R_INVALID_ARGUMENT);
|
249
|
+
return 0;
|
250
|
+
}
|
251
|
+
|
252
|
+
max_available =
|
253
|
+
bio_zero_copy_get_read_buf(peer_b, &dummy_read_buf, &dummy_read_offset);
|
254
|
+
if (bytes_read > max_available) {
|
255
|
+
OPENSSL_PUT_ERROR(BIO, BIO_R_INVALID_ARGUMENT);
|
256
|
+
return 0;
|
257
|
+
}
|
258
|
+
|
259
|
+
assert(peer_b->len >= bytes_read);
|
260
|
+
peer_b->len -= bytes_read;
|
261
|
+
assert(peer_b->offset + bytes_read <= peer_b->size);
|
262
|
+
|
263
|
+
/* Move read offset. If zero_copy_write_lock == 1 we must advance the
|
264
|
+
* offset even if buffer becomes empty, to make sure
|
265
|
+
* write_offset = (offset + len) mod size does not change. */
|
266
|
+
if (peer_b->offset + bytes_read == peer_b->size ||
|
267
|
+
(!peer_b->zero_copy_write_lock && peer_b->len == 0)) {
|
268
|
+
peer_b->offset = 0;
|
269
|
+
} else {
|
270
|
+
peer_b->offset += bytes_read;
|
271
|
+
}
|
272
|
+
|
273
|
+
bio->num_read += bytes_read;
|
274
|
+
peer_b->zero_copy_read_lock = 0;
|
275
|
+
return 1;
|
276
|
+
}
|
277
|
+
|
278
|
+
static size_t bio_zero_copy_get_write_buf(struct bio_bio_st* b,
|
279
|
+
uint8_t** out_write_buf,
|
280
|
+
size_t* out_buf_offset) {
|
281
|
+
size_t write_offset;
|
282
|
+
size_t max_available;
|
283
|
+
|
284
|
+
assert(b->len <= b->size);
|
285
|
+
|
286
|
+
write_offset = b->offset + b->len;
|
287
|
+
|
288
|
+
if (write_offset >= b->size) {
|
289
|
+
/* Only the first half of the ring buffer can be written to. */
|
290
|
+
write_offset -= b->size;
|
291
|
+
/* write up to the start of the ring buffer. */
|
292
|
+
max_available = b->offset - write_offset;
|
293
|
+
} else {
|
294
|
+
/* write up to the end the buffer. */
|
295
|
+
max_available = b->size - write_offset;
|
296
|
+
}
|
297
|
+
|
298
|
+
*out_write_buf = b->buf;
|
299
|
+
*out_buf_offset = write_offset;
|
300
|
+
return max_available;
|
301
|
+
}
|
302
|
+
|
303
|
+
int BIO_zero_copy_get_write_buf(BIO* bio, uint8_t** out_write_buf,
|
304
|
+
size_t* out_buf_offset,
|
305
|
+
size_t* out_available_bytes) {
|
306
|
+
struct bio_bio_st* b;
|
307
|
+
struct bio_bio_st* peer_b;
|
308
|
+
size_t max_available;
|
309
|
+
|
310
|
+
*out_available_bytes = 0;
|
311
|
+
BIO_clear_retry_flags(bio);
|
312
|
+
|
313
|
+
if (!bio->init) {
|
314
|
+
OPENSSL_PUT_ERROR(BIO, BIO_R_UNINITIALIZED);
|
315
|
+
return 0;
|
316
|
+
}
|
317
|
+
|
318
|
+
b = bio->ptr;
|
319
|
+
|
320
|
+
if (!b || !b->buf || !b->peer) {
|
321
|
+
OPENSSL_PUT_ERROR(BIO, BIO_R_UNSUPPORTED_METHOD);
|
322
|
+
return 0;
|
323
|
+
}
|
324
|
+
peer_b = b->peer->ptr;
|
325
|
+
if (!peer_b || !peer_b->peer || peer_b->peer->ptr != b) {
|
326
|
+
OPENSSL_PUT_ERROR(BIO, BIO_R_UNSUPPORTED_METHOD);
|
327
|
+
return 0;
|
328
|
+
}
|
329
|
+
|
330
|
+
assert(b->buf != NULL);
|
331
|
+
|
332
|
+
if (b->zero_copy_write_lock) {
|
333
|
+
OPENSSL_PUT_ERROR(BIO, BIO_R_INVALID_ARGUMENT);
|
334
|
+
return 0;
|
335
|
+
}
|
336
|
+
|
337
|
+
b->request = 0;
|
338
|
+
if (b->closed) {
|
339
|
+
/* Bio is already closed. */
|
340
|
+
OPENSSL_PUT_ERROR(BIO, BIO_R_BROKEN_PIPE);
|
341
|
+
return 0;
|
342
|
+
}
|
343
|
+
|
344
|
+
max_available = bio_zero_copy_get_write_buf(b, out_write_buf, out_buf_offset);
|
345
|
+
|
346
|
+
if (max_available > 0) {
|
347
|
+
b->zero_copy_write_lock = 1;
|
348
|
+
}
|
349
|
+
|
350
|
+
*out_available_bytes = max_available;
|
351
|
+
return 1;
|
352
|
+
}
|
353
|
+
|
354
|
+
int BIO_zero_copy_get_write_buf_done(BIO* bio, size_t bytes_written) {
|
355
|
+
struct bio_bio_st* b;
|
356
|
+
struct bio_bio_st* peer_b;
|
357
|
+
|
358
|
+
size_t rest;
|
359
|
+
size_t dummy_write_offset;
|
360
|
+
uint8_t* dummy_write_buf;
|
361
|
+
|
362
|
+
if (!bio->init) {
|
363
|
+
OPENSSL_PUT_ERROR(BIO, BIO_R_UNINITIALIZED);
|
364
|
+
return 0;
|
365
|
+
}
|
366
|
+
|
367
|
+
b = bio->ptr;
|
368
|
+
|
369
|
+
if (!b || !b->buf || !b->peer) {
|
370
|
+
OPENSSL_PUT_ERROR(BIO, BIO_R_UNSUPPORTED_METHOD);
|
371
|
+
return 0;
|
372
|
+
}
|
373
|
+
peer_b = b->peer->ptr;
|
374
|
+
if (!peer_b || !peer_b->peer || peer_b->peer->ptr != b) {
|
375
|
+
OPENSSL_PUT_ERROR(BIO, BIO_R_UNSUPPORTED_METHOD);
|
376
|
+
return 0;
|
377
|
+
}
|
378
|
+
|
379
|
+
b->request = 0;
|
380
|
+
if (b->closed) {
|
381
|
+
/* BIO is already closed. */
|
382
|
+
OPENSSL_PUT_ERROR(BIO, BIO_R_BROKEN_PIPE);
|
383
|
+
return 0;
|
384
|
+
}
|
385
|
+
|
386
|
+
if (!b->zero_copy_write_lock) {
|
387
|
+
OPENSSL_PUT_ERROR(BIO, BIO_R_INVALID_ARGUMENT);
|
388
|
+
return 0;
|
389
|
+
}
|
390
|
+
|
391
|
+
rest = bio_zero_copy_get_write_buf(b, &dummy_write_buf, &dummy_write_offset);
|
392
|
+
|
393
|
+
if (bytes_written > rest) {
|
394
|
+
OPENSSL_PUT_ERROR(BIO, BIO_R_INVALID_ARGUMENT);
|
395
|
+
return 0;
|
396
|
+
}
|
397
|
+
|
398
|
+
bio->num_write += bytes_written;
|
399
|
+
/* Move write offset. */
|
400
|
+
b->len += bytes_written;
|
401
|
+
b->zero_copy_write_lock = 0;
|
402
|
+
return 1;
|
403
|
+
}
|
404
|
+
|
405
|
+
static int bio_read(BIO *bio, char *buf, int size_) {
|
406
|
+
size_t size = size_;
|
407
|
+
size_t rest;
|
408
|
+
struct bio_bio_st *b, *peer_b;
|
409
|
+
|
410
|
+
BIO_clear_retry_flags(bio);
|
411
|
+
|
412
|
+
if (!bio->init) {
|
413
|
+
return 0;
|
414
|
+
}
|
415
|
+
|
416
|
+
b = bio->ptr;
|
417
|
+
assert(b != NULL);
|
418
|
+
assert(b->peer != NULL);
|
419
|
+
peer_b = b->peer->ptr;
|
420
|
+
assert(peer_b != NULL);
|
421
|
+
assert(peer_b->buf != NULL);
|
422
|
+
|
423
|
+
peer_b->request = 0; /* will be set in "retry_read" situation */
|
424
|
+
|
425
|
+
if (buf == NULL || size == 0 || peer_b->zero_copy_read_lock) {
|
426
|
+
return 0;
|
427
|
+
}
|
428
|
+
|
429
|
+
if (peer_b->len == 0) {
|
430
|
+
if (peer_b->closed) {
|
431
|
+
return 0; /* writer has closed, and no data is left */
|
432
|
+
} else {
|
433
|
+
BIO_set_retry_read(bio); /* buffer is empty */
|
434
|
+
if (size <= peer_b->size) {
|
435
|
+
peer_b->request = size;
|
436
|
+
} else {
|
437
|
+
/* don't ask for more than the peer can
|
438
|
+
* deliver in one write */
|
439
|
+
peer_b->request = peer_b->size;
|
440
|
+
}
|
441
|
+
return -1;
|
442
|
+
}
|
443
|
+
}
|
444
|
+
|
445
|
+
/* we can read */
|
446
|
+
if (peer_b->len < size) {
|
447
|
+
size = peer_b->len;
|
448
|
+
}
|
449
|
+
|
450
|
+
/* now read "size" bytes */
|
451
|
+
rest = size;
|
452
|
+
|
453
|
+
assert(rest > 0);
|
454
|
+
/* one or two iterations */
|
455
|
+
do {
|
456
|
+
size_t chunk;
|
457
|
+
|
458
|
+
assert(rest <= peer_b->len);
|
459
|
+
if (peer_b->offset + rest <= peer_b->size) {
|
460
|
+
chunk = rest;
|
461
|
+
} else {
|
462
|
+
/* wrap around ring buffer */
|
463
|
+
chunk = peer_b->size - peer_b->offset;
|
464
|
+
}
|
465
|
+
assert(peer_b->offset + chunk <= peer_b->size);
|
466
|
+
|
467
|
+
memcpy(buf, peer_b->buf + peer_b->offset, chunk);
|
468
|
+
|
469
|
+
peer_b->len -= chunk;
|
470
|
+
/* If zero_copy_write_lock == 1 we must advance the offset even if buffer
|
471
|
+
* becomes empty, to make sure write_offset = (offset + len) % size
|
472
|
+
* does not change. */
|
473
|
+
if (peer_b->len || peer_b->zero_copy_write_lock) {
|
474
|
+
peer_b->offset += chunk;
|
475
|
+
assert(peer_b->offset <= peer_b->size);
|
476
|
+
if (peer_b->offset == peer_b->size) {
|
477
|
+
peer_b->offset = 0;
|
478
|
+
}
|
479
|
+
buf += chunk;
|
480
|
+
} else {
|
481
|
+
/* buffer now empty, no need to advance "buf" */
|
482
|
+
assert(chunk == rest);
|
483
|
+
peer_b->offset = 0;
|
484
|
+
}
|
485
|
+
rest -= chunk;
|
486
|
+
} while (rest);
|
487
|
+
|
488
|
+
return size;
|
489
|
+
}
|
490
|
+
|
491
|
+
static int bio_write(BIO *bio, const char *buf, int num_) {
|
492
|
+
size_t num = num_;
|
493
|
+
size_t rest;
|
494
|
+
struct bio_bio_st *b;
|
495
|
+
|
496
|
+
BIO_clear_retry_flags(bio);
|
497
|
+
|
498
|
+
if (!bio->init || buf == NULL || num == 0) {
|
499
|
+
return 0;
|
500
|
+
}
|
501
|
+
|
502
|
+
b = bio->ptr;
|
503
|
+
assert(b != NULL);
|
504
|
+
assert(b->peer != NULL);
|
505
|
+
assert(b->buf != NULL);
|
506
|
+
|
507
|
+
if (b->zero_copy_write_lock) {
|
508
|
+
return 0;
|
509
|
+
}
|
510
|
+
|
511
|
+
b->request = 0;
|
512
|
+
if (b->closed) {
|
513
|
+
/* we already closed */
|
514
|
+
OPENSSL_PUT_ERROR(BIO, BIO_R_BROKEN_PIPE);
|
515
|
+
return -1;
|
516
|
+
}
|
517
|
+
|
518
|
+
assert(b->len <= b->size);
|
519
|
+
|
520
|
+
if (b->len == b->size) {
|
521
|
+
BIO_set_retry_write(bio); /* buffer is full */
|
522
|
+
return -1;
|
523
|
+
}
|
524
|
+
|
525
|
+
/* we can write */
|
526
|
+
if (num > b->size - b->len) {
|
527
|
+
num = b->size - b->len;
|
528
|
+
}
|
529
|
+
|
530
|
+
/* now write "num" bytes */
|
531
|
+
rest = num;
|
532
|
+
|
533
|
+
assert(rest > 0);
|
534
|
+
/* one or two iterations */
|
535
|
+
do {
|
536
|
+
size_t write_offset;
|
537
|
+
size_t chunk;
|
538
|
+
|
539
|
+
assert(b->len + rest <= b->size);
|
540
|
+
|
541
|
+
write_offset = b->offset + b->len;
|
542
|
+
if (write_offset >= b->size) {
|
543
|
+
write_offset -= b->size;
|
544
|
+
}
|
545
|
+
/* b->buf[write_offset] is the first byte we can write to. */
|
546
|
+
|
547
|
+
if (write_offset + rest <= b->size) {
|
548
|
+
chunk = rest;
|
549
|
+
} else {
|
550
|
+
/* wrap around ring buffer */
|
551
|
+
chunk = b->size - write_offset;
|
552
|
+
}
|
553
|
+
|
554
|
+
memcpy(b->buf + write_offset, buf, chunk);
|
555
|
+
|
556
|
+
b->len += chunk;
|
557
|
+
|
558
|
+
assert(b->len <= b->size);
|
559
|
+
|
560
|
+
rest -= chunk;
|
561
|
+
buf += chunk;
|
562
|
+
} while (rest);
|
563
|
+
|
564
|
+
return num;
|
565
|
+
}
|
566
|
+
|
567
|
+
static int bio_make_pair(BIO* bio1, BIO* bio2,
|
568
|
+
size_t writebuf1_len, uint8_t* ext_writebuf1,
|
569
|
+
size_t writebuf2_len, uint8_t* ext_writebuf2) {
|
570
|
+
struct bio_bio_st *b1, *b2;
|
571
|
+
|
572
|
+
assert(bio1 != NULL);
|
573
|
+
assert(bio2 != NULL);
|
574
|
+
|
575
|
+
b1 = bio1->ptr;
|
576
|
+
b2 = bio2->ptr;
|
577
|
+
|
578
|
+
if (b1->peer != NULL || b2->peer != NULL) {
|
579
|
+
OPENSSL_PUT_ERROR(BIO, BIO_R_IN_USE);
|
580
|
+
return 0;
|
581
|
+
}
|
582
|
+
|
583
|
+
assert(b1->buf_externally_allocated == 0);
|
584
|
+
assert(b2->buf_externally_allocated == 0);
|
585
|
+
|
586
|
+
if (b1->buf == NULL) {
|
587
|
+
if (writebuf1_len) {
|
588
|
+
b1->size = writebuf1_len;
|
589
|
+
}
|
590
|
+
if (!ext_writebuf1) {
|
591
|
+
b1->buf_externally_allocated = 0;
|
592
|
+
b1->buf = OPENSSL_malloc(b1->size);
|
593
|
+
if (b1->buf == NULL) {
|
594
|
+
OPENSSL_PUT_ERROR(BIO, ERR_R_MALLOC_FAILURE);
|
595
|
+
return 0;
|
596
|
+
}
|
597
|
+
} else {
|
598
|
+
b1->buf = ext_writebuf1;
|
599
|
+
b1->buf_externally_allocated = 1;
|
600
|
+
}
|
601
|
+
b1->len = 0;
|
602
|
+
b1->offset = 0;
|
603
|
+
}
|
604
|
+
|
605
|
+
if (b2->buf == NULL) {
|
606
|
+
if (writebuf2_len) {
|
607
|
+
b2->size = writebuf2_len;
|
608
|
+
}
|
609
|
+
if (!ext_writebuf2) {
|
610
|
+
b2->buf_externally_allocated = 0;
|
611
|
+
b2->buf = OPENSSL_malloc(b2->size);
|
612
|
+
if (b2->buf == NULL) {
|
613
|
+
OPENSSL_PUT_ERROR(BIO, ERR_R_MALLOC_FAILURE);
|
614
|
+
return 0;
|
615
|
+
}
|
616
|
+
} else {
|
617
|
+
b2->buf = ext_writebuf2;
|
618
|
+
b2->buf_externally_allocated = 1;
|
619
|
+
}
|
620
|
+
b2->len = 0;
|
621
|
+
b2->offset = 0;
|
622
|
+
}
|
623
|
+
|
624
|
+
b1->peer = bio2;
|
625
|
+
b1->closed = 0;
|
626
|
+
b1->request = 0;
|
627
|
+
b1->zero_copy_read_lock = 0;
|
628
|
+
b1->zero_copy_write_lock = 0;
|
629
|
+
b2->peer = bio1;
|
630
|
+
b2->closed = 0;
|
631
|
+
b2->request = 0;
|
632
|
+
b2->zero_copy_read_lock = 0;
|
633
|
+
b2->zero_copy_write_lock = 0;
|
634
|
+
|
635
|
+
bio1->init = 1;
|
636
|
+
bio2->init = 1;
|
637
|
+
|
638
|
+
return 1;
|
639
|
+
}
|
640
|
+
|
641
|
+
static long bio_ctrl(BIO *bio, int cmd, long num, void *ptr) {
|
642
|
+
long ret;
|
643
|
+
struct bio_bio_st *b = bio->ptr;
|
644
|
+
|
645
|
+
assert(b != NULL);
|
646
|
+
|
647
|
+
switch (cmd) {
|
648
|
+
/* specific CTRL codes */
|
649
|
+
|
650
|
+
case BIO_C_GET_WRITE_BUF_SIZE:
|
651
|
+
ret = (long)b->size;
|
652
|
+
break;
|
653
|
+
|
654
|
+
case BIO_C_GET_WRITE_GUARANTEE:
|
655
|
+
/* How many bytes can the caller feed to the next write
|
656
|
+
* without having to keep any? */
|
657
|
+
if (b->peer == NULL || b->closed) {
|
658
|
+
ret = 0;
|
659
|
+
} else {
|
660
|
+
ret = (long)b->size - b->len;
|
661
|
+
}
|
662
|
+
break;
|
663
|
+
|
664
|
+
case BIO_C_GET_READ_REQUEST:
|
665
|
+
/* If the peer unsuccessfully tried to read, how many bytes
|
666
|
+
* were requested? (As with BIO_CTRL_PENDING, that number
|
667
|
+
* can usually be treated as boolean.) */
|
668
|
+
ret = (long)b->request;
|
669
|
+
break;
|
670
|
+
|
671
|
+
case BIO_C_RESET_READ_REQUEST:
|
672
|
+
/* Reset request. (Can be useful after read attempts
|
673
|
+
* at the other side that are meant to be non-blocking,
|
674
|
+
* e.g. when probing SSL_read to see if any data is
|
675
|
+
* available.) */
|
676
|
+
b->request = 0;
|
677
|
+
ret = 1;
|
678
|
+
break;
|
679
|
+
|
680
|
+
case BIO_C_SHUTDOWN_WR:
|
681
|
+
/* similar to shutdown(..., SHUT_WR) */
|
682
|
+
b->closed = 1;
|
683
|
+
ret = 1;
|
684
|
+
break;
|
685
|
+
|
686
|
+
/* standard CTRL codes follow */
|
687
|
+
|
688
|
+
case BIO_CTRL_GET_CLOSE:
|
689
|
+
ret = bio->shutdown;
|
690
|
+
break;
|
691
|
+
|
692
|
+
case BIO_CTRL_SET_CLOSE:
|
693
|
+
bio->shutdown = (int)num;
|
694
|
+
ret = 1;
|
695
|
+
break;
|
696
|
+
|
697
|
+
case BIO_CTRL_PENDING:
|
698
|
+
if (b->peer != NULL) {
|
699
|
+
struct bio_bio_st *peer_b = b->peer->ptr;
|
700
|
+
ret = (long)peer_b->len;
|
701
|
+
} else {
|
702
|
+
ret = 0;
|
703
|
+
}
|
704
|
+
break;
|
705
|
+
|
706
|
+
case BIO_CTRL_WPENDING:
|
707
|
+
ret = 0;
|
708
|
+
if (b->buf != NULL) {
|
709
|
+
ret = (long)b->len;
|
710
|
+
}
|
711
|
+
break;
|
712
|
+
|
713
|
+
case BIO_CTRL_FLUSH:
|
714
|
+
ret = 1;
|
715
|
+
break;
|
716
|
+
|
717
|
+
case BIO_CTRL_EOF: {
|
718
|
+
BIO *other_bio = ptr;
|
719
|
+
|
720
|
+
if (other_bio) {
|
721
|
+
struct bio_bio_st *other_b = other_bio->ptr;
|
722
|
+
assert(other_b != NULL);
|
723
|
+
ret = other_b->len == 0 && other_b->closed;
|
724
|
+
} else {
|
725
|
+
ret = 1;
|
726
|
+
}
|
727
|
+
} break;
|
728
|
+
|
729
|
+
default:
|
730
|
+
ret = 0;
|
731
|
+
}
|
732
|
+
return ret;
|
733
|
+
}
|
734
|
+
|
735
|
+
static int bio_puts(BIO *bio, const char *str) {
|
736
|
+
return bio_write(bio, str, strlen(str));
|
737
|
+
}
|
738
|
+
|
739
|
+
static const BIO_METHOD methods_biop = {
|
740
|
+
BIO_TYPE_BIO, "BIO pair", bio_write, bio_read,
|
741
|
+
bio_puts, NULL /* no bio_gets */, bio_ctrl, bio_new,
|
742
|
+
bio_free, NULL /* no bio_callback_ctrl */
|
743
|
+
};
|
744
|
+
|
745
|
+
const BIO_METHOD *bio_s_bio(void) { return &methods_biop; }
|
746
|
+
|
747
|
+
int BIO_new_bio_pair(BIO** bio1_p, size_t writebuf1,
|
748
|
+
BIO** bio2_p, size_t writebuf2) {
|
749
|
+
return BIO_new_bio_pair_external_buf(bio1_p, writebuf1, NULL, bio2_p,
|
750
|
+
writebuf2, NULL);
|
751
|
+
}
|
752
|
+
|
753
|
+
int BIO_new_bio_pair_external_buf(BIO** bio1_p, size_t writebuf1_len,
|
754
|
+
uint8_t* ext_writebuf1,
|
755
|
+
BIO** bio2_p, size_t writebuf2_len,
|
756
|
+
uint8_t* ext_writebuf2) {
|
757
|
+
BIO *bio1 = NULL, *bio2 = NULL;
|
758
|
+
int ret = 0;
|
759
|
+
|
760
|
+
/* External buffers must have sizes greater than 0. */
|
761
|
+
if ((ext_writebuf1 && !writebuf1_len) || (ext_writebuf2 && !writebuf2_len)) {
|
762
|
+
goto err;
|
763
|
+
}
|
764
|
+
|
765
|
+
bio1 = BIO_new(bio_s_bio());
|
766
|
+
if (bio1 == NULL) {
|
767
|
+
goto err;
|
768
|
+
}
|
769
|
+
bio2 = BIO_new(bio_s_bio());
|
770
|
+
if (bio2 == NULL) {
|
771
|
+
goto err;
|
772
|
+
}
|
773
|
+
|
774
|
+
if (!bio_make_pair(bio1, bio2, writebuf1_len, ext_writebuf1, writebuf2_len,
|
775
|
+
ext_writebuf2)) {
|
776
|
+
goto err;
|
777
|
+
}
|
778
|
+
ret = 1;
|
779
|
+
|
780
|
+
err:
|
781
|
+
if (ret == 0) {
|
782
|
+
BIO_free(bio1);
|
783
|
+
bio1 = NULL;
|
784
|
+
BIO_free(bio2);
|
785
|
+
bio2 = NULL;
|
786
|
+
}
|
787
|
+
|
788
|
+
*bio1_p = bio1;
|
789
|
+
*bio2_p = bio2;
|
790
|
+
return ret;
|
791
|
+
}
|
792
|
+
|
793
|
+
size_t BIO_ctrl_get_read_request(BIO *bio) {
|
794
|
+
return BIO_ctrl(bio, BIO_C_GET_READ_REQUEST, 0, NULL);
|
795
|
+
}
|
796
|
+
|
797
|
+
size_t BIO_ctrl_get_write_guarantee(BIO *bio) {
|
798
|
+
return BIO_ctrl(bio, BIO_C_GET_WRITE_GUARANTEE, 0, NULL);
|
799
|
+
}
|
800
|
+
|
801
|
+
int BIO_shutdown_wr(BIO *bio) {
|
802
|
+
return BIO_ctrl(bio, BIO_C_SHUTDOWN_WR, 0, NULL);
|
803
|
+
}
|