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.

Files changed (673) hide show
  1. checksums.yaml +4 -4
  2. data/Makefile +5707 -22222
  3. data/include/grpc/byte_buffer.h +2 -83
  4. data/include/grpc/census.h +191 -121
  5. data/include/grpc/compression.h +14 -38
  6. data/include/grpc/grpc.h +88 -434
  7. data/include/grpc/grpc_security.h +76 -46
  8. data/include/grpc/grpc_zookeeper.h +1 -1
  9. data/include/grpc/impl/codegen/alloc.h +74 -0
  10. data/include/grpc/impl/codegen/atm.h +92 -0
  11. data/include/grpc/impl/codegen/atm_gcc_atomic.h +72 -0
  12. data/include/grpc/impl/codegen/atm_gcc_sync.h +87 -0
  13. data/include/grpc/impl/codegen/atm_win32.h +125 -0
  14. data/include/grpc/impl/codegen/byte_buffer.h +121 -0
  15. data/include/grpc/impl/codegen/compression_types.h +73 -0
  16. data/include/grpc/impl/codegen/connectivity_state.h +59 -0
  17. data/include/grpc/impl/codegen/grpc_types.h +373 -0
  18. data/include/grpc/impl/codegen/log.h +110 -0
  19. data/include/grpc/impl/codegen/port_platform.h +362 -0
  20. data/include/grpc/impl/codegen/propagation_bits.h +67 -0
  21. data/include/grpc/impl/codegen/slice.h +182 -0
  22. data/include/grpc/impl/codegen/slice_buffer.h +105 -0
  23. data/include/grpc/impl/codegen/status.h +163 -0
  24. data/include/grpc/impl/codegen/sync.h +316 -0
  25. data/include/grpc/impl/codegen/sync_generic.h +55 -0
  26. data/{src/core/census/context.h → include/grpc/impl/codegen/sync_posix.h} +11 -11
  27. data/include/grpc/impl/codegen/sync_win32.h +49 -0
  28. data/include/grpc/impl/codegen/time.h +132 -0
  29. data/include/grpc/status.h +2 -126
  30. data/include/grpc/support/alloc.h +2 -35
  31. data/include/grpc/support/atm.h +2 -55
  32. data/include/grpc/support/atm_gcc_atomic.h +5 -38
  33. data/include/grpc/support/atm_gcc_sync.h +2 -50
  34. data/include/grpc/support/atm_win32.h +2 -88
  35. data/include/grpc/support/avl.h +7 -7
  36. data/include/grpc/support/cmdline.h +15 -13
  37. data/include/grpc/support/cpu.h +5 -3
  38. data/include/grpc/support/histogram.h +23 -20
  39. data/include/grpc/support/host_port.h +5 -3
  40. data/include/grpc/support/log.h +2 -71
  41. data/include/grpc/support/log_win32.h +2 -2
  42. data/include/grpc/support/port_platform.h +2 -319
  43. data/include/grpc/support/slice.h +2 -145
  44. data/include/grpc/support/slice_buffer.h +2 -65
  45. data/include/grpc/support/string_util.h +3 -3
  46. data/include/grpc/support/subprocess.h +8 -6
  47. data/include/grpc/support/sync.h +2 -278
  48. data/include/grpc/support/sync_generic.h +2 -18
  49. data/include/grpc/support/sync_posix.h +2 -10
  50. data/include/grpc/support/sync_win32.h +2 -12
  51. data/include/grpc/support/thd.h +11 -11
  52. data/include/grpc/support/time.h +2 -91
  53. data/include/grpc/support/tls.h +1 -1
  54. data/include/grpc/support/tls_gcc.h +1 -1
  55. data/include/grpc/support/tls_msvc.h +1 -1
  56. data/include/grpc/support/tls_pthread.h +2 -2
  57. data/src/boringssl/err_data.c +1252 -0
  58. data/src/core/census/context.c +492 -8
  59. data/src/core/census/grpc_filter.c +3 -3
  60. data/src/core/census/initialize.c +4 -7
  61. data/src/core/census/operation.c +2 -2
  62. data/src/core/census/placeholders.c +109 -0
  63. data/src/core/census/rpc_metric_id.h +6 -6
  64. data/src/core/census/tracing.c +1 -1
  65. data/src/core/channel/channel_args.c +4 -3
  66. data/src/core/channel/channel_stack.c +1 -1
  67. data/src/core/channel/client_channel.c +18 -14
  68. data/src/core/channel/client_uchannel.c +3 -3
  69. data/src/core/channel/compress_filter.c +8 -8
  70. data/src/core/channel/http_client_filter.c +2 -2
  71. data/src/core/channel/http_server_filter.c +9 -9
  72. data/src/core/channel/subchannel_call_holder.c +12 -10
  73. data/src/core/client_config/lb_policies/pick_first.c +49 -31
  74. data/src/core/client_config/lb_policies/round_robin.c +7 -7
  75. data/src/core/client_config/resolvers/dns_resolver.c +3 -3
  76. data/src/core/client_config/resolvers/sockaddr_resolver.c +5 -5
  77. data/src/core/client_config/subchannel.c +36 -25
  78. data/src/core/compression/algorithm.c +3 -3
  79. data/src/core/httpcli/format_request.c +1 -1
  80. data/src/core/httpcli/httpcli.c +5 -5
  81. data/src/core/httpcli/httpcli_security_connector.c +2 -3
  82. data/src/core/httpcli/parser.c +7 -7
  83. data/src/core/httpcli/parser.h +1 -1
  84. data/src/core/iomgr/closure.c +7 -7
  85. data/src/core/iomgr/closure.h +6 -5
  86. data/src/core/iomgr/exec_ctx.c +12 -8
  87. data/src/core/iomgr/exec_ctx.h +12 -5
  88. data/src/core/iomgr/executor.c +4 -4
  89. data/src/core/iomgr/executor.h +2 -2
  90. data/src/core/iomgr/fd_posix.c +28 -17
  91. data/src/core/iomgr/fd_posix.h +7 -4
  92. data/src/core/iomgr/iocp_windows.c +6 -8
  93. data/src/core/iomgr/pollset_multipoller_with_epoll.c +70 -5
  94. data/src/core/iomgr/pollset_multipoller_with_poll_posix.c +4 -2
  95. data/src/core/iomgr/pollset_posix.c +15 -15
  96. data/src/core/iomgr/pollset_posix.h +4 -2
  97. data/src/core/iomgr/pollset_windows.c +3 -12
  98. data/src/core/iomgr/resolve_address_posix.c +2 -2
  99. data/src/core/iomgr/resolve_address_windows.c +2 -2
  100. data/src/core/iomgr/sockaddr_utils.c +6 -6
  101. data/src/core/iomgr/sockaddr_win32.h +1 -6
  102. data/src/core/iomgr/tcp_client_posix.c +7 -7
  103. data/src/core/iomgr/tcp_client_windows.c +4 -4
  104. data/src/core/iomgr/tcp_posix.c +14 -8
  105. data/src/core/iomgr/tcp_posix.h +7 -1
  106. data/src/core/iomgr/tcp_server.h +40 -20
  107. data/src/core/iomgr/tcp_server_posix.c +106 -49
  108. data/src/core/iomgr/tcp_server_windows.c +98 -49
  109. data/src/core/iomgr/tcp_windows.c +11 -15
  110. data/src/core/iomgr/timer.c +8 -8
  111. data/src/core/iomgr/timer.h +1 -1
  112. data/src/core/iomgr/timer_heap.c +10 -10
  113. data/src/core/iomgr/timer_heap.h +2 -2
  114. data/src/core/iomgr/udp_server.c +2 -12
  115. data/src/core/iomgr/udp_server.h +1 -9
  116. data/src/core/iomgr/workqueue.h +2 -4
  117. data/src/core/iomgr/workqueue_posix.c +3 -3
  118. data/src/core/json/json_reader.c +11 -12
  119. data/src/core/json/json_reader.h +4 -4
  120. data/src/core/json/json_string.c +19 -19
  121. data/src/core/json/json_writer.c +7 -9
  122. data/src/core/profiling/basic_timers.c +1 -1
  123. data/src/core/security/base64.c +9 -9
  124. data/src/core/security/client_auth_filter.c +4 -4
  125. data/src/core/security/credentials.c +5 -5
  126. data/src/core/security/google_default_credentials.c +3 -3
  127. data/src/core/security/handshake.c +6 -5
  128. data/src/core/security/json_token.c +13 -7
  129. data/src/core/security/jwt_verifier.c +3 -2
  130. data/src/core/security/secure_endpoint.c +16 -16
  131. data/src/core/security/security_connector.c +47 -17
  132. data/src/core/security/security_connector.h +5 -5
  133. data/src/core/security/server_auth_filter.c +3 -3
  134. data/src/core/security/server_secure_chttp2.c +30 -31
  135. data/src/core/statistics/census_interface.h +2 -2
  136. data/src/core/statistics/census_rpc_stats.h +3 -3
  137. data/src/core/support/alloc.c +1 -1
  138. data/src/core/support/cpu_posix.c +2 -2
  139. data/src/core/support/env_linux.c +12 -2
  140. data/src/core/support/env_win32.c +15 -7
  141. data/src/core/support/histogram.c +5 -5
  142. data/src/core/support/log_posix.c +1 -1
  143. data/src/core/support/log_win32.c +4 -3
  144. data/src/core/support/murmur_hash.c +11 -11
  145. data/src/core/support/murmur_hash.h +1 -1
  146. data/src/core/support/slice.c +11 -11
  147. data/src/core/support/slice_buffer.c +6 -6
  148. data/src/core/support/stack_lockfree.c +20 -10
  149. data/src/core/support/string.c +15 -15
  150. data/src/core/support/string.h +5 -5
  151. data/src/core/support/string_win32.c +5 -5
  152. data/src/core/support/subprocess_windows.c +141 -0
  153. data/src/core/support/sync.c +4 -4
  154. data/src/core/support/sync_posix.c +2 -2
  155. data/src/core/support/sync_win32.c +10 -5
  156. data/src/core/support/time.c +29 -29
  157. data/src/core/support/time_posix.c +15 -6
  158. data/src/core/support/time_precise.c +2 -2
  159. data/src/core/support/time_win32.c +18 -9
  160. data/src/core/support/tls_pthread.c +1 -1
  161. data/src/core/support/wrap_memcpy.c +53 -0
  162. data/src/core/surface/alarm.c +83 -0
  163. data/src/core/surface/byte_buffer_reader.c +1 -1
  164. data/src/core/surface/call.c +78 -69
  165. data/src/core/surface/call.h +2 -2
  166. data/src/core/surface/call_test_only.h +2 -2
  167. data/src/core/surface/channel.c +9 -9
  168. data/src/core/surface/channel.h +1 -1
  169. data/src/core/surface/channel_connectivity.c +3 -3
  170. data/src/core/surface/channel_create.c +3 -3
  171. data/src/core/surface/channel_ping.c +2 -2
  172. data/src/core/surface/completion_queue.c +11 -12
  173. data/src/core/surface/completion_queue.h +1 -1
  174. data/src/core/surface/init.c +7 -5
  175. data/src/core/surface/lame_client.c +3 -3
  176. data/src/core/surface/secure_channel_create.c +3 -3
  177. data/src/core/surface/server.c +28 -28
  178. data/src/core/surface/server_chttp2.c +8 -8
  179. data/src/core/surface/server_create.c +1 -4
  180. data/src/core/surface/validate_metadata.c +3 -3
  181. data/src/core/surface/version.c +2 -2
  182. data/src/core/transport/byte_stream.c +8 -6
  183. data/src/core/transport/byte_stream.h +6 -5
  184. data/src/core/transport/chttp2/bin_encoder.c +29 -29
  185. data/src/core/transport/chttp2/frame_data.c +29 -26
  186. data/src/core/transport/chttp2/frame_data.h +6 -6
  187. data/src/core/transport/chttp2/frame_goaway.c +30 -30
  188. data/src/core/transport/chttp2/frame_goaway.h +6 -6
  189. data/src/core/transport/chttp2/frame_ping.c +6 -6
  190. data/src/core/transport/chttp2/frame_ping.h +5 -5
  191. data/src/core/transport/chttp2/frame_rst_stream.c +18 -19
  192. data/src/core/transport/chttp2/frame_rst_stream.h +4 -4
  193. data/src/core/transport/chttp2/frame_settings.c +30 -30
  194. data/src/core/transport/chttp2/frame_settings.h +13 -13
  195. data/src/core/transport/chttp2/frame_window_update.c +17 -18
  196. data/src/core/transport/chttp2/frame_window_update.h +5 -7
  197. data/src/core/transport/chttp2/hpack_encoder.c +69 -73
  198. data/src/core/transport/chttp2/hpack_encoder.h +16 -16
  199. data/src/core/transport/chttp2/hpack_parser.c +167 -167
  200. data/src/core/transport/chttp2/hpack_parser.h +16 -16
  201. data/src/core/transport/chttp2/hpack_table.c +13 -13
  202. data/src/core/transport/chttp2/hpack_table.h +11 -11
  203. data/src/core/transport/chttp2/internal.h +97 -86
  204. data/src/core/transport/chttp2/parsing.c +25 -25
  205. data/src/core/transport/chttp2/stream_lists.c +26 -3
  206. data/src/core/transport/chttp2/stream_map.c +13 -14
  207. data/src/core/transport/chttp2/stream_map.h +6 -7
  208. data/src/core/transport/chttp2/timeout_encoding.c +19 -16
  209. data/src/core/transport/chttp2/varint.c +8 -9
  210. data/src/core/transport/chttp2/varint.h +7 -8
  211. data/src/core/transport/chttp2/writing.c +26 -23
  212. data/src/core/transport/chttp2_transport.c +133 -92
  213. data/src/core/transport/connectivity_state.c +6 -6
  214. data/src/core/transport/metadata.c +18 -18
  215. data/src/core/transport/metadata.h +5 -5
  216. data/src/core/transport/static_metadata.c +15 -16
  217. data/src/core/transport/static_metadata.h +5 -5
  218. data/src/core/transport/transport.c +5 -5
  219. data/src/core/transport/transport.h +14 -1
  220. data/src/core/tsi/fake_transport_security.c +7 -7
  221. data/src/core/tsi/ssl_transport_security.c +6 -4
  222. data/src/core/tsi/ssl_types.h +55 -0
  223. data/src/ruby/ext/grpc/extconf.rb +51 -14
  224. data/src/ruby/ext/grpc/rb_byte_buffer.c +3 -1
  225. data/src/ruby/ext/grpc/rb_call.c +6 -3
  226. data/src/ruby/ext/grpc/rb_call_credentials.c +4 -0
  227. data/src/ruby/ext/grpc/rb_channel.c +4 -2
  228. data/src/ruby/ext/grpc/rb_channel_args.c +3 -1
  229. data/src/ruby/ext/grpc/rb_channel_credentials.c +3 -1
  230. data/src/ruby/ext/grpc/rb_completion_queue.c +3 -1
  231. data/src/ruby/ext/grpc/rb_event_thread.c +5 -0
  232. data/src/ruby/ext/grpc/rb_grpc.c +11 -3
  233. data/src/ruby/ext/grpc/rb_grpc_imports.generated.c +560 -0
  234. data/src/ruby/ext/grpc/rb_grpc_imports.generated.h +843 -0
  235. data/src/ruby/ext/grpc/rb_loader.c +72 -0
  236. data/src/ruby/ext/grpc/rb_loader.h +40 -0
  237. data/src/ruby/ext/grpc/rb_server.c +3 -1
  238. data/src/ruby/ext/grpc/rb_server_credentials.c +4 -2
  239. data/src/ruby/lib/grpc/generic/bidi_call.rb +1 -1
  240. data/src/ruby/lib/grpc/generic/rpc_desc.rb +1 -1
  241. data/src/ruby/lib/grpc/generic/rpc_server.rb +1 -1
  242. data/src/ruby/lib/grpc/grpc.rb +34 -0
  243. data/src/ruby/lib/grpc/version.rb +1 -1
  244. data/src/ruby/spec/pb/health/checker_spec.rb +1 -1
  245. data/third_party/boringssl/crypto/aes/aes.c +1142 -0
  246. data/third_party/boringssl/crypto/aes/internal.h +87 -0
  247. data/third_party/boringssl/crypto/aes/mode_wrappers.c +108 -0
  248. data/third_party/boringssl/crypto/asn1/a_bitstr.c +255 -0
  249. data/third_party/boringssl/crypto/asn1/a_bool.c +112 -0
  250. data/third_party/boringssl/crypto/asn1/a_bytes.c +317 -0
  251. data/third_party/boringssl/crypto/asn1/a_d2i_fp.c +286 -0
  252. data/third_party/boringssl/crypto/asn1/a_dup.c +103 -0
  253. data/third_party/boringssl/crypto/asn1/a_enum.c +183 -0
  254. data/third_party/boringssl/crypto/asn1/a_gentm.c +255 -0
  255. data/third_party/boringssl/crypto/asn1/a_i2d_fp.c +154 -0
  256. data/third_party/boringssl/crypto/asn1/a_int.c +456 -0
  257. data/third_party/boringssl/crypto/asn1/a_mbstr.c +390 -0
  258. data/third_party/boringssl/crypto/asn1/a_object.c +412 -0
  259. data/third_party/boringssl/crypto/asn1/a_octet.c +70 -0
  260. data/third_party/boringssl/crypto/asn1/a_print.c +119 -0
  261. data/third_party/boringssl/crypto/asn1/a_strnid.c +286 -0
  262. data/third_party/boringssl/crypto/asn1/a_time.c +221 -0
  263. data/third_party/boringssl/crypto/asn1/a_type.c +160 -0
  264. data/third_party/boringssl/crypto/asn1/a_utctm.c +342 -0
  265. data/third_party/boringssl/crypto/asn1/a_utf8.c +210 -0
  266. data/third_party/boringssl/crypto/asn1/asn1_lib.c +510 -0
  267. data/third_party/boringssl/crypto/asn1/asn1_locl.h +73 -0
  268. data/third_party/boringssl/crypto/asn1/asn1_par.c +444 -0
  269. data/third_party/boringssl/crypto/asn1/asn_pack.c +104 -0
  270. data/third_party/boringssl/crypto/asn1/bio_asn1.c +496 -0
  271. data/third_party/boringssl/crypto/asn1/bio_ndef.c +254 -0
  272. data/third_party/boringssl/crypto/asn1/f_enum.c +206 -0
  273. data/third_party/boringssl/crypto/asn1/f_int.c +210 -0
  274. data/third_party/boringssl/crypto/asn1/f_string.c +204 -0
  275. data/third_party/boringssl/crypto/asn1/t_bitst.c +102 -0
  276. data/third_party/boringssl/crypto/asn1/t_pkey.c +112 -0
  277. data/third_party/boringssl/crypto/asn1/tasn_dec.c +1342 -0
  278. data/third_party/boringssl/crypto/asn1/tasn_enc.c +695 -0
  279. data/third_party/boringssl/crypto/asn1/tasn_fre.c +264 -0
  280. data/third_party/boringssl/crypto/asn1/tasn_new.c +398 -0
  281. data/third_party/boringssl/crypto/asn1/tasn_prn.c +642 -0
  282. data/third_party/boringssl/crypto/asn1/tasn_typ.c +137 -0
  283. data/third_party/boringssl/crypto/asn1/tasn_utl.c +266 -0
  284. data/third_party/boringssl/crypto/asn1/x_bignum.c +143 -0
  285. data/third_party/boringssl/crypto/asn1/x_long.c +182 -0
  286. data/third_party/boringssl/crypto/base64/base64.c +478 -0
  287. data/third_party/boringssl/crypto/bio/bio.c +608 -0
  288. data/third_party/boringssl/crypto/bio/bio_mem.c +327 -0
  289. data/third_party/boringssl/crypto/bio/buffer.c +496 -0
  290. data/third_party/boringssl/crypto/bio/connect.c +544 -0
  291. data/third_party/boringssl/crypto/bio/fd.c +270 -0
  292. data/third_party/boringssl/crypto/bio/file.c +349 -0
  293. data/third_party/boringssl/crypto/bio/hexdump.c +192 -0
  294. data/third_party/boringssl/crypto/bio/internal.h +108 -0
  295. data/third_party/boringssl/crypto/bio/pair.c +803 -0
  296. data/third_party/boringssl/crypto/bio/printf.c +119 -0
  297. data/third_party/boringssl/crypto/bio/socket.c +195 -0
  298. data/third_party/boringssl/crypto/bio/socket_helper.c +113 -0
  299. data/third_party/boringssl/crypto/bn/add.c +377 -0
  300. data/third_party/boringssl/crypto/bn/asm/x86_64-gcc.c +599 -0
  301. data/third_party/boringssl/crypto/bn/bn.c +341 -0
  302. data/third_party/boringssl/crypto/bn/bn_asn1.c +93 -0
  303. data/third_party/boringssl/crypto/bn/cmp.c +200 -0
  304. data/third_party/boringssl/crypto/bn/convert.c +597 -0
  305. data/third_party/boringssl/crypto/bn/ctx.c +311 -0
  306. data/third_party/boringssl/crypto/bn/div.c +625 -0
  307. data/third_party/boringssl/crypto/bn/exponentiation.c +1544 -0
  308. data/third_party/boringssl/crypto/bn/gcd.c +711 -0
  309. data/third_party/boringssl/crypto/bn/generic.c +1019 -0
  310. data/third_party/boringssl/crypto/bn/internal.h +294 -0
  311. data/third_party/boringssl/crypto/bn/kronecker.c +175 -0
  312. data/third_party/boringssl/crypto/bn/montgomery.c +561 -0
  313. data/third_party/boringssl/crypto/bn/mul.c +888 -0
  314. data/third_party/boringssl/crypto/bn/prime.c +845 -0
  315. data/third_party/boringssl/crypto/bn/random.c +326 -0
  316. data/third_party/boringssl/crypto/bn/rsaz_exp.c +326 -0
  317. data/third_party/boringssl/crypto/bn/rsaz_exp.h +56 -0
  318. data/third_party/boringssl/crypto/bn/shift.c +299 -0
  319. data/third_party/boringssl/crypto/bn/sqrt.c +505 -0
  320. data/third_party/boringssl/crypto/buf/buf.c +235 -0
  321. data/third_party/boringssl/crypto/bytestring/ber.c +221 -0
  322. data/third_party/boringssl/crypto/bytestring/cbb.c +411 -0
  323. data/third_party/boringssl/crypto/bytestring/cbs.c +415 -0
  324. data/third_party/boringssl/crypto/bytestring/internal.h +46 -0
  325. data/third_party/boringssl/crypto/chacha/chacha_generic.c +140 -0
  326. data/third_party/boringssl/crypto/chacha/chacha_vec.c +323 -0
  327. data/third_party/boringssl/crypto/cipher/aead.c +167 -0
  328. data/third_party/boringssl/crypto/cipher/cipher.c +652 -0
  329. data/third_party/boringssl/crypto/cipher/derive_key.c +154 -0
  330. data/third_party/boringssl/crypto/cipher/e_aes.c +1767 -0
  331. data/third_party/boringssl/crypto/cipher/e_chacha20poly1305.c +311 -0
  332. data/third_party/boringssl/crypto/cipher/e_des.c +207 -0
  333. data/third_party/boringssl/crypto/cipher/e_null.c +85 -0
  334. data/third_party/boringssl/crypto/cipher/e_rc2.c +443 -0
  335. data/third_party/boringssl/crypto/cipher/e_rc4.c +87 -0
  336. data/third_party/boringssl/crypto/cipher/e_ssl3.c +463 -0
  337. data/third_party/boringssl/crypto/cipher/e_tls.c +673 -0
  338. data/third_party/boringssl/crypto/cipher/internal.h +164 -0
  339. data/third_party/boringssl/crypto/cipher/tls_cbc.c +495 -0
  340. data/third_party/boringssl/crypto/cmac/cmac.c +239 -0
  341. data/third_party/boringssl/crypto/conf/conf.c +778 -0
  342. data/third_party/boringssl/crypto/conf/conf_def.h +127 -0
  343. data/third_party/boringssl/crypto/conf/internal.h +31 -0
  344. data/third_party/boringssl/crypto/cpu-arm.c +199 -0
  345. data/third_party/boringssl/crypto/cpu-intel.c +261 -0
  346. data/third_party/boringssl/crypto/crypto.c +140 -0
  347. data/third_party/boringssl/crypto/curve25519/curve25519.c +4897 -0
  348. data/third_party/boringssl/crypto/des/des.c +771 -0
  349. data/third_party/boringssl/crypto/des/internal.h +212 -0
  350. data/third_party/boringssl/crypto/dh/check.c +180 -0
  351. data/third_party/boringssl/crypto/dh/dh.c +463 -0
  352. data/third_party/boringssl/crypto/dh/dh_asn1.c +84 -0
  353. data/third_party/boringssl/crypto/dh/internal.h +80 -0
  354. data/third_party/boringssl/crypto/dh/params.c +301 -0
  355. data/third_party/boringssl/crypto/digest/digest.c +248 -0
  356. data/third_party/boringssl/crypto/digest/digests.c +321 -0
  357. data/third_party/boringssl/crypto/digest/internal.h +112 -0
  358. data/third_party/boringssl/crypto/digest/md32_common.h +322 -0
  359. data/third_party/boringssl/crypto/directory.h +66 -0
  360. data/third_party/boringssl/crypto/directory_posix.c +108 -0
  361. data/third_party/boringssl/crypto/directory_win.c +144 -0
  362. data/third_party/boringssl/crypto/dsa/dsa.c +908 -0
  363. data/third_party/boringssl/crypto/dsa/dsa_asn1.c +150 -0
  364. data/third_party/boringssl/crypto/dsa/internal.h +78 -0
  365. data/third_party/boringssl/crypto/ec/ec.c +889 -0
  366. data/third_party/boringssl/crypto/ec/ec_asn1.c +586 -0
  367. data/third_party/boringssl/crypto/ec/ec_key.c +482 -0
  368. data/third_party/boringssl/crypto/ec/ec_montgomery.c +280 -0
  369. data/third_party/boringssl/crypto/ec/internal.h +318 -0
  370. data/third_party/boringssl/crypto/ec/oct.c +416 -0
  371. data/third_party/boringssl/crypto/ec/p224-64.c +1305 -0
  372. data/third_party/boringssl/crypto/ec/p256-64.c +1878 -0
  373. data/third_party/boringssl/crypto/ec/p256-x86_64-table.h +9548 -0
  374. data/third_party/boringssl/crypto/ec/p256-x86_64.c +596 -0
  375. data/third_party/boringssl/crypto/ec/simple.c +1313 -0
  376. data/third_party/boringssl/crypto/ec/util-64.c +183 -0
  377. data/third_party/boringssl/crypto/ec/wnaf.c +449 -0
  378. data/third_party/boringssl/crypto/ecdh/ecdh.c +153 -0
  379. data/third_party/boringssl/crypto/ecdsa/ecdsa.c +496 -0
  380. data/third_party/boringssl/crypto/ecdsa/ecdsa_asn1.c +240 -0
  381. data/third_party/boringssl/crypto/engine/engine.c +96 -0
  382. data/third_party/boringssl/crypto/err/err.c +756 -0
  383. data/third_party/boringssl/crypto/evp/algorithm.c +153 -0
  384. data/third_party/boringssl/crypto/evp/digestsign.c +159 -0
  385. data/third_party/boringssl/crypto/evp/evp.c +411 -0
  386. data/third_party/boringssl/crypto/evp/evp_asn1.c +179 -0
  387. data/third_party/boringssl/crypto/evp/evp_ctx.c +477 -0
  388. data/third_party/boringssl/crypto/evp/internal.h +278 -0
  389. data/third_party/boringssl/crypto/evp/p_dsa_asn1.c +588 -0
  390. data/third_party/boringssl/crypto/evp/p_ec.c +283 -0
  391. data/third_party/boringssl/crypto/evp/p_ec_asn1.c +562 -0
  392. data/third_party/boringssl/crypto/evp/p_rsa.c +596 -0
  393. data/third_party/boringssl/crypto/evp/p_rsa_asn1.c +737 -0
  394. data/third_party/boringssl/crypto/evp/pbkdf.c +151 -0
  395. data/third_party/boringssl/crypto/evp/sign.c +151 -0
  396. data/third_party/boringssl/crypto/ex_data.c +294 -0
  397. data/third_party/boringssl/crypto/hkdf/hkdf.c +89 -0
  398. data/third_party/boringssl/crypto/hmac/hmac.c +213 -0
  399. data/third_party/boringssl/crypto/internal.h +532 -0
  400. data/third_party/boringssl/crypto/lhash/lhash.c +346 -0
  401. data/third_party/boringssl/crypto/md4/md4.c +225 -0
  402. data/third_party/boringssl/crypto/md5/md5.c +275 -0
  403. data/third_party/boringssl/crypto/mem.c +200 -0
  404. data/third_party/boringssl/crypto/modes/cbc.c +216 -0
  405. data/third_party/boringssl/crypto/modes/cfb.c +231 -0
  406. data/third_party/boringssl/crypto/modes/ctr.c +226 -0
  407. data/third_party/boringssl/crypto/modes/gcm.c +1252 -0
  408. data/third_party/boringssl/crypto/modes/internal.h +370 -0
  409. data/third_party/boringssl/crypto/modes/ofb.c +108 -0
  410. data/third_party/boringssl/crypto/obj/obj.c +664 -0
  411. data/third_party/boringssl/crypto/obj/obj_dat.h +5257 -0
  412. data/third_party/boringssl/crypto/obj/obj_xref.c +124 -0
  413. data/third_party/boringssl/crypto/obj/obj_xref.h +96 -0
  414. data/third_party/boringssl/crypto/pem/pem_all.c +281 -0
  415. data/third_party/boringssl/crypto/pem/pem_info.c +404 -0
  416. data/third_party/boringssl/crypto/pem/pem_lib.c +835 -0
  417. data/third_party/boringssl/crypto/pem/pem_oth.c +89 -0
  418. data/third_party/boringssl/crypto/pem/pem_pk8.c +244 -0
  419. data/third_party/boringssl/crypto/pem/pem_pkey.c +312 -0
  420. data/third_party/boringssl/crypto/pem/pem_x509.c +65 -0
  421. data/third_party/boringssl/crypto/pem/pem_xaux.c +66 -0
  422. data/third_party/boringssl/crypto/pkcs8/internal.h +83 -0
  423. data/third_party/boringssl/crypto/pkcs8/p5_pbe.c +150 -0
  424. data/third_party/boringssl/crypto/pkcs8/p5_pbev2.c +440 -0
  425. data/third_party/boringssl/crypto/pkcs8/p8_pkey.c +85 -0
  426. data/third_party/boringssl/crypto/pkcs8/pkcs8.c +1217 -0
  427. data/third_party/boringssl/crypto/poly1305/poly1305.c +331 -0
  428. data/third_party/boringssl/crypto/poly1305/poly1305_arm.c +301 -0
  429. data/third_party/boringssl/crypto/poly1305/poly1305_vec.c +892 -0
  430. data/third_party/boringssl/crypto/rand/internal.h +32 -0
  431. data/third_party/boringssl/crypto/rand/rand.c +239 -0
  432. data/third_party/boringssl/crypto/rand/urandom.c +223 -0
  433. data/third_party/boringssl/crypto/rand/windows.c +56 -0
  434. data/third_party/boringssl/crypto/rc4/rc4.c +283 -0
  435. data/third_party/boringssl/crypto/refcount_c11.c +67 -0
  436. data/third_party/boringssl/crypto/refcount_lock.c +53 -0
  437. data/third_party/boringssl/crypto/rsa/blinding.c +462 -0
  438. data/third_party/boringssl/crypto/rsa/internal.h +164 -0
  439. data/third_party/boringssl/crypto/rsa/padding.c +711 -0
  440. data/third_party/boringssl/crypto/rsa/rsa.c +808 -0
  441. data/third_party/boringssl/crypto/rsa/rsa_asn1.c +473 -0
  442. data/third_party/boringssl/crypto/rsa/rsa_impl.c +1138 -0
  443. data/third_party/boringssl/crypto/sha/sha1.c +337 -0
  444. data/third_party/boringssl/crypto/sha/sha256.c +327 -0
  445. data/third_party/boringssl/crypto/sha/sha512.c +607 -0
  446. data/third_party/boringssl/crypto/stack/stack.c +386 -0
  447. data/third_party/boringssl/crypto/test/scoped_types.h +137 -0
  448. data/third_party/boringssl/crypto/test/test_util.h +35 -0
  449. data/third_party/boringssl/crypto/thread.c +101 -0
  450. data/third_party/boringssl/crypto/thread_none.c +55 -0
  451. data/third_party/boringssl/crypto/thread_pthread.c +167 -0
  452. data/third_party/boringssl/crypto/thread_win.c +282 -0
  453. data/third_party/boringssl/crypto/time_support.c +212 -0
  454. data/third_party/boringssl/crypto/x509/a_digest.c +97 -0
  455. data/third_party/boringssl/crypto/x509/a_sign.c +136 -0
  456. data/third_party/boringssl/crypto/x509/a_strex.c +564 -0
  457. data/third_party/boringssl/crypto/x509/a_verify.c +133 -0
  458. data/third_party/boringssl/crypto/x509/asn1_gen.c +873 -0
  459. data/third_party/boringssl/crypto/x509/by_dir.c +491 -0
  460. data/third_party/boringssl/crypto/x509/by_file.c +295 -0
  461. data/third_party/boringssl/crypto/x509/charmap.h +15 -0
  462. data/third_party/boringssl/crypto/x509/i2d_pr.c +84 -0
  463. data/third_party/boringssl/crypto/x509/pkcs7.c +353 -0
  464. data/third_party/boringssl/crypto/x509/t_crl.c +129 -0
  465. data/third_party/boringssl/crypto/x509/t_req.c +246 -0
  466. data/third_party/boringssl/crypto/x509/t_x509.c +500 -0
  467. data/third_party/boringssl/crypto/x509/t_x509a.c +109 -0
  468. data/third_party/boringssl/crypto/x509/vpm_int.h +70 -0
  469. data/third_party/boringssl/crypto/x509/x509.c +152 -0
  470. data/third_party/boringssl/crypto/x509/x509_att.c +353 -0
  471. data/third_party/boringssl/crypto/x509/x509_cmp.c +490 -0
  472. data/third_party/boringssl/crypto/x509/x509_d2.c +105 -0
  473. data/third_party/boringssl/crypto/x509/x509_def.c +88 -0
  474. data/third_party/boringssl/crypto/x509/x509_ext.c +206 -0
  475. data/third_party/boringssl/crypto/x509/x509_lu.c +738 -0
  476. data/third_party/boringssl/crypto/x509/x509_obj.c +191 -0
  477. data/third_party/boringssl/crypto/x509/x509_r2x.c +113 -0
  478. data/third_party/boringssl/crypto/x509/x509_req.c +315 -0
  479. data/third_party/boringssl/crypto/x509/x509_set.c +154 -0
  480. data/third_party/boringssl/crypto/x509/x509_trs.c +304 -0
  481. data/third_party/boringssl/crypto/x509/x509_txt.c +209 -0
  482. data/third_party/boringssl/crypto/x509/x509_v3.c +271 -0
  483. data/third_party/boringssl/crypto/x509/x509_vfy.c +2456 -0
  484. data/third_party/boringssl/crypto/x509/x509_vpm.c +672 -0
  485. data/third_party/boringssl/crypto/x509/x509cset.c +172 -0
  486. data/third_party/boringssl/crypto/x509/x509name.c +381 -0
  487. data/third_party/boringssl/crypto/x509/x509rset.c +80 -0
  488. data/third_party/boringssl/crypto/x509/x509spki.c +135 -0
  489. data/third_party/boringssl/crypto/x509/x509type.c +128 -0
  490. data/third_party/boringssl/crypto/x509/x_algor.c +154 -0
  491. data/third_party/boringssl/crypto/x509/x_all.c +547 -0
  492. data/third_party/boringssl/crypto/x509/x_attrib.c +117 -0
  493. data/third_party/boringssl/crypto/x509/x_crl.c +560 -0
  494. data/third_party/boringssl/crypto/x509/x_exten.c +75 -0
  495. data/third_party/boringssl/crypto/x509/x_info.c +95 -0
  496. data/third_party/boringssl/crypto/x509/x_name.c +538 -0
  497. data/third_party/boringssl/crypto/x509/x_pkey.c +100 -0
  498. data/third_party/boringssl/crypto/x509/x_pubkey.c +384 -0
  499. data/third_party/boringssl/crypto/x509/x_req.c +112 -0
  500. data/third_party/boringssl/crypto/x509/x_sig.c +69 -0
  501. data/third_party/boringssl/crypto/x509/x_spki.c +78 -0
  502. data/third_party/boringssl/crypto/x509/x_val.c +69 -0
  503. data/third_party/boringssl/crypto/x509/x_x509.c +227 -0
  504. data/third_party/boringssl/crypto/x509/x_x509a.c +197 -0
  505. data/third_party/boringssl/crypto/x509v3/ext_dat.h +129 -0
  506. data/third_party/boringssl/crypto/x509v3/pcy_cache.c +299 -0
  507. data/third_party/boringssl/crypto/x509v3/pcy_data.c +137 -0
  508. data/third_party/boringssl/crypto/x509v3/pcy_int.h +212 -0
  509. data/third_party/boringssl/crypto/x509v3/pcy_lib.c +165 -0
  510. data/third_party/boringssl/crypto/x509v3/pcy_map.c +133 -0
  511. data/third_party/boringssl/crypto/x509v3/pcy_node.c +197 -0
  512. data/third_party/boringssl/crypto/x509v3/pcy_tree.c +876 -0
  513. data/third_party/boringssl/crypto/x509v3/v3_akey.c +212 -0
  514. data/third_party/boringssl/crypto/x509v3/v3_akeya.c +71 -0
  515. data/third_party/boringssl/crypto/x509v3/v3_alt.c +622 -0
  516. data/third_party/boringssl/crypto/x509v3/v3_bcons.c +126 -0
  517. data/third_party/boringssl/crypto/x509v3/v3_bitst.c +141 -0
  518. data/third_party/boringssl/crypto/x509v3/v3_conf.c +459 -0
  519. data/third_party/boringssl/crypto/x509v3/v3_cpols.c +475 -0
  520. data/third_party/boringssl/crypto/x509v3/v3_crld.c +616 -0
  521. data/third_party/boringssl/crypto/x509v3/v3_enum.c +98 -0
  522. data/third_party/boringssl/crypto/x509v3/v3_extku.c +145 -0
  523. data/third_party/boringssl/crypto/x509v3/v3_genn.c +252 -0
  524. data/third_party/boringssl/crypto/x509v3/v3_ia5.c +117 -0
  525. data/third_party/boringssl/crypto/x509v3/v3_info.c +200 -0
  526. data/third_party/boringssl/crypto/x509v3/v3_int.c +87 -0
  527. data/third_party/boringssl/crypto/x509v3/v3_lib.c +335 -0
  528. data/third_party/boringssl/crypto/x509v3/v3_ncons.c +510 -0
  529. data/third_party/boringssl/crypto/x509v3/v3_pci.c +335 -0
  530. data/third_party/boringssl/crypto/x509v3/v3_pcia.c +56 -0
  531. data/third_party/boringssl/crypto/x509v3/v3_pcons.c +142 -0
  532. data/third_party/boringssl/crypto/x509v3/v3_pku.c +109 -0
  533. data/third_party/boringssl/crypto/x509v3/v3_pmaps.c +156 -0
  534. data/third_party/boringssl/crypto/x509v3/v3_prn.c +207 -0
  535. data/third_party/boringssl/crypto/x509v3/v3_purp.c +805 -0
  536. data/third_party/boringssl/crypto/x509v3/v3_skey.c +148 -0
  537. data/third_party/boringssl/crypto/x509v3/v3_sxnet.c +266 -0
  538. data/third_party/boringssl/crypto/x509v3/v3_utl.c +1322 -0
  539. data/third_party/boringssl/include/openssl/aead.h +346 -0
  540. data/third_party/boringssl/include/openssl/aes.h +158 -0
  541. data/third_party/boringssl/include/openssl/arm_arch.h +127 -0
  542. data/third_party/boringssl/include/openssl/asn1.h +1168 -0
  543. data/third_party/boringssl/include/openssl/asn1_mac.h +75 -0
  544. data/third_party/boringssl/include/openssl/asn1t.h +906 -0
  545. data/third_party/boringssl/include/openssl/base.h +261 -0
  546. data/third_party/boringssl/include/openssl/base64.h +184 -0
  547. data/third_party/boringssl/include/openssl/bio.h +902 -0
  548. data/third_party/boringssl/include/openssl/blowfish.h +93 -0
  549. data/third_party/boringssl/include/openssl/bn.h +885 -0
  550. data/third_party/boringssl/include/openssl/buf.h +118 -0
  551. data/third_party/boringssl/include/openssl/buffer.h +18 -0
  552. data/third_party/boringssl/include/openssl/bytestring.h +360 -0
  553. data/third_party/boringssl/include/openssl/cast.h +96 -0
  554. data/third_party/boringssl/include/openssl/chacha.h +37 -0
  555. data/third_party/boringssl/include/openssl/cipher.h +571 -0
  556. data/third_party/boringssl/include/openssl/cmac.h +76 -0
  557. data/third_party/boringssl/include/openssl/conf.h +145 -0
  558. data/third_party/boringssl/include/openssl/cpu.h +184 -0
  559. data/third_party/boringssl/include/openssl/crypto.h +68 -0
  560. data/third_party/boringssl/include/openssl/curve25519.h +88 -0
  561. data/third_party/boringssl/include/openssl/des.h +177 -0
  562. data/third_party/boringssl/include/openssl/dh.h +238 -0
  563. data/third_party/boringssl/include/openssl/digest.h +258 -0
  564. data/third_party/boringssl/include/openssl/dsa.h +343 -0
  565. data/third_party/boringssl/include/openssl/dtls1.h +16 -0
  566. data/third_party/boringssl/include/openssl/ec.h +355 -0
  567. data/third_party/boringssl/include/openssl/ec_key.h +280 -0
  568. data/third_party/boringssl/include/openssl/ecdh.h +102 -0
  569. data/third_party/boringssl/include/openssl/ecdsa.h +206 -0
  570. data/third_party/boringssl/include/openssl/engine.h +98 -0
  571. data/third_party/boringssl/include/openssl/err.h +487 -0
  572. data/third_party/boringssl/include/openssl/evp.h +750 -0
  573. data/third_party/boringssl/include/openssl/ex_data.h +213 -0
  574. data/third_party/boringssl/include/openssl/hkdf.h +44 -0
  575. data/third_party/boringssl/include/openssl/hmac.h +160 -0
  576. data/third_party/boringssl/include/openssl/lhash.h +192 -0
  577. data/third_party/boringssl/include/openssl/lhash_macros.h +132 -0
  578. data/third_party/boringssl/include/openssl/md4.h +102 -0
  579. data/third_party/boringssl/include/openssl/md5.h +107 -0
  580. data/third_party/boringssl/include/openssl/mem.h +140 -0
  581. data/third_party/boringssl/include/openssl/obj.h +198 -0
  582. data/third_party/boringssl/include/openssl/obj_mac.h +4140 -0
  583. data/third_party/boringssl/include/openssl/objects.h +18 -0
  584. data/third_party/boringssl/include/openssl/opensslfeatures.h +60 -0
  585. data/third_party/boringssl/include/openssl/opensslv.h +18 -0
  586. data/third_party/boringssl/include/openssl/ossl_typ.h +18 -0
  587. data/third_party/boringssl/include/openssl/pem.h +521 -0
  588. data/third_party/boringssl/include/openssl/pkcs12.h +18 -0
  589. data/third_party/boringssl/include/openssl/pkcs7.h +16 -0
  590. data/third_party/boringssl/include/openssl/pkcs8.h +220 -0
  591. data/third_party/boringssl/include/openssl/poly1305.h +51 -0
  592. data/third_party/boringssl/include/openssl/pqueue.h +146 -0
  593. data/third_party/boringssl/include/openssl/rand.h +113 -0
  594. data/third_party/boringssl/include/openssl/rc4.h +90 -0
  595. data/third_party/boringssl/include/openssl/rsa.h +637 -0
  596. data/third_party/boringssl/include/openssl/safestack.h +16 -0
  597. data/third_party/boringssl/include/openssl/sha.h +256 -0
  598. data/third_party/boringssl/include/openssl/srtp.h +18 -0
  599. data/third_party/boringssl/include/openssl/ssl.h +4466 -0
  600. data/third_party/boringssl/include/openssl/ssl3.h +441 -0
  601. data/third_party/boringssl/include/openssl/stack.h +298 -0
  602. data/third_party/boringssl/include/openssl/stack_macros.h +4190 -0
  603. data/third_party/boringssl/include/openssl/thread.h +173 -0
  604. data/third_party/boringssl/include/openssl/time_support.h +90 -0
  605. data/third_party/boringssl/include/openssl/tls1.h +653 -0
  606. data/third_party/boringssl/include/openssl/type_check.h +91 -0
  607. data/third_party/boringssl/include/openssl/x509.h +1258 -0
  608. data/third_party/boringssl/include/openssl/x509_vfy.h +611 -0
  609. data/third_party/boringssl/include/openssl/x509v3.h +798 -0
  610. data/third_party/boringssl/ssl/custom_extensions.c +257 -0
  611. data/third_party/boringssl/ssl/d1_both.c +880 -0
  612. data/third_party/boringssl/ssl/d1_clnt.c +566 -0
  613. data/third_party/boringssl/ssl/d1_lib.c +340 -0
  614. data/third_party/boringssl/ssl/d1_meth.c +130 -0
  615. data/third_party/boringssl/ssl/d1_pkt.c +578 -0
  616. data/third_party/boringssl/ssl/d1_srtp.c +234 -0
  617. data/third_party/boringssl/ssl/d1_srvr.c +485 -0
  618. data/third_party/boringssl/ssl/dtls_record.c +308 -0
  619. data/third_party/boringssl/ssl/internal.h +1276 -0
  620. data/third_party/boringssl/ssl/pqueue/pqueue.c +197 -0
  621. data/third_party/boringssl/ssl/s3_both.c +571 -0
  622. data/third_party/boringssl/ssl/s3_clnt.c +2241 -0
  623. data/third_party/boringssl/ssl/s3_enc.c +494 -0
  624. data/third_party/boringssl/ssl/s3_lib.c +587 -0
  625. data/third_party/boringssl/ssl/s3_meth.c +166 -0
  626. data/third_party/boringssl/ssl/s3_pkt.c +732 -0
  627. data/third_party/boringssl/ssl/s3_srvr.c +2536 -0
  628. data/third_party/boringssl/ssl/ssl_aead_ctx.c +300 -0
  629. data/third_party/boringssl/ssl/ssl_asn1.c +718 -0
  630. data/third_party/boringssl/ssl/ssl_buffer.c +319 -0
  631. data/third_party/boringssl/ssl/ssl_cert.c +539 -0
  632. data/third_party/boringssl/ssl/ssl_cipher.c +2003 -0
  633. data/third_party/boringssl/ssl/ssl_file.c +633 -0
  634. data/third_party/boringssl/ssl/ssl_lib.c +2653 -0
  635. data/third_party/boringssl/ssl/ssl_rsa.c +423 -0
  636. data/third_party/boringssl/ssl/ssl_session.c +764 -0
  637. data/third_party/boringssl/ssl/ssl_stat.c +591 -0
  638. data/third_party/boringssl/ssl/t1_enc.c +708 -0
  639. data/third_party/boringssl/ssl/t1_lib.c +2905 -0
  640. data/third_party/boringssl/ssl/test/async_bio.h +45 -0
  641. data/third_party/boringssl/ssl/test/packeted_bio.h +44 -0
  642. data/third_party/boringssl/ssl/test/scoped_types.h +28 -0
  643. data/third_party/boringssl/ssl/test/test_config.h +108 -0
  644. data/third_party/boringssl/ssl/tls_record.c +342 -0
  645. data/third_party/zlib/adler32.c +179 -0
  646. data/third_party/zlib/compress.c +80 -0
  647. data/third_party/zlib/crc32.c +425 -0
  648. data/third_party/zlib/crc32.h +441 -0
  649. data/third_party/zlib/deflate.c +1967 -0
  650. data/third_party/zlib/deflate.h +346 -0
  651. data/third_party/zlib/gzclose.c +25 -0
  652. data/third_party/zlib/gzguts.h +209 -0
  653. data/third_party/zlib/gzlib.c +634 -0
  654. data/third_party/zlib/gzread.c +594 -0
  655. data/third_party/zlib/gzwrite.c +577 -0
  656. data/third_party/zlib/infback.c +640 -0
  657. data/third_party/zlib/inffast.c +340 -0
  658. data/third_party/zlib/inffast.h +11 -0
  659. data/third_party/zlib/inffixed.h +94 -0
  660. data/third_party/zlib/inflate.c +1512 -0
  661. data/third_party/zlib/inflate.h +122 -0
  662. data/third_party/zlib/inftrees.c +306 -0
  663. data/third_party/zlib/inftrees.h +62 -0
  664. data/third_party/zlib/trees.c +1226 -0
  665. data/third_party/zlib/trees.h +128 -0
  666. data/third_party/zlib/uncompr.c +59 -0
  667. data/third_party/zlib/zconf.h +511 -0
  668. data/third_party/zlib/zlib.h +1768 -0
  669. data/third_party/zlib/zutil.c +324 -0
  670. data/third_party/zlib/zutil.h +253 -0
  671. metadata +492 -25
  672. data/Rakefile +0 -63
  673. 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
+ }