Hex Artifact Content

Artifact 7f6303ee40fa69865fb6267422fcc7c881415901dfa1494d8deb1ecc7471a8ea:


0000: 2f 2a 0a 20 2a 20 43 6f 70 79 72 69 67 68 74 20  /*. * Copyright 
0010: 28 43 29 20 31 39 39 37 2d 32 30 30 30 20 4d 61  (C) 1997-2000 Ma
0020: 74 74 20 4e 65 77 6d 61 6e 20 3c 6d 61 74 74 40  tt Newman <matt@
0030: 6e 6f 76 61 64 69 67 6d 2e 63 6f 6d 3e 0a 20 2a  novadigm.com>. *
0040: 0a 20 2a 20 50 72 6f 76 69 64 65 73 20 42 49 4f  . * Provides BIO
0050: 20 6c 61 79 65 72 20 74 6f 20 69 6e 74 65 72 66   layer to interf
0060: 61 63 65 20 6f 70 65 6e 73 73 6c 20 74 6f 20 54  ace openssl to T
0070: 63 6c 2e 0a 20 2a 2f 0a 0a 23 69 6e 63 6c 75 64  cl.. */..#includ
0080: 65 20 22 74 6c 73 49 6e 74 2e 68 22 0a 0a 23 69  e "tlsInt.h"..#i
0090: 66 64 65 66 20 54 43 4c 54 4c 53 5f 4f 50 45 4e  fdef TCLTLS_OPEN
00a0: 53 53 4c 5f 50 52 45 5f 31 5f 31 5f 41 50 49 0a  SSL_PRE_1_1_API.
00b0: 23 64 65 66 69 6e 65 20 42 49 4f 5f 67 65 74 5f  #define BIO_get_
00c0: 64 61 74 61 28 62 69 6f 29 20 20 20 20 20 20 20  data(bio)       
00d0: 20 20 20 20 20 20 20 20 20 28 28 62 69 6f 29 2d           ((bio)-
00e0: 3e 70 74 72 29 0a 23 64 65 66 69 6e 65 20 42 49  >ptr).#define BI
00f0: 4f 5f 67 65 74 5f 69 6e 69 74 28 62 69 6f 29 20  O_get_init(bio) 
0100: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 28                 (
0110: 28 62 69 6f 29 2d 3e 69 6e 69 74 29 0a 23 64 65  (bio)->init).#de
0120: 66 69 6e 65 20 42 49 4f 5f 67 65 74 5f 73 68 75  fine BIO_get_shu
0130: 74 64 6f 77 6e 28 62 69 6f 29 20 20 20 20 20 20  tdown(bio)      
0140: 20 20 20 20 20 20 28 28 62 69 6f 29 2d 3e 73 68        ((bio)->sh
0150: 75 74 64 6f 77 6e 29 0a 23 64 65 66 69 6e 65 20  utdown).#define 
0160: 42 49 4f 5f 73 65 74 5f 64 61 74 61 28 62 69 6f  BIO_set_data(bio
0170: 2c 20 76 61 6c 29 20 20 20 20 20 20 20 20 20 20  , val)          
0180: 20 28 62 69 6f 29 2d 3e 70 74 72 20 3d 20 28 76   (bio)->ptr = (v
0190: 61 6c 29 0a 23 64 65 66 69 6e 65 20 42 49 4f 5f  al).#define BIO_
01a0: 73 65 74 5f 69 6e 69 74 28 62 69 6f 2c 20 76 61  set_init(bio, va
01b0: 6c 29 20 20 20 20 20 20 20 20 20 20 20 28 62 69  l)           (bi
01c0: 6f 29 2d 3e 69 6e 69 74 20 3d 20 28 76 61 6c 29  o)->init = (val)
01d0: 0a 23 64 65 66 69 6e 65 20 42 49 4f 5f 73 65 74  .#define BIO_set
01e0: 5f 73 68 75 74 64 6f 77 6e 28 62 69 6f 2c 20 76  _shutdown(bio, v
01f0: 61 6c 29 20 20 20 20 20 20 20 28 62 69 6f 29 2d  al)       (bio)-
0200: 3e 73 68 75 74 64 6f 77 6e 20 3d 20 28 76 61 6c  >shutdown = (val
0210: 29 0a 0a 2f 2a 20 58 58 58 3a 20 54 68 69 73 20  )../* XXX: This 
0220: 61 73 73 75 6d 65 73 20 74 68 65 20 76 61 72 69  assumes the vari
0230: 61 62 6c 65 20 62 65 69 6e 67 20 61 73 73 69 67  able being assig
0240: 6e 65 64 20 74 6f 20 69 73 20 42 69 6f 4d 65 74  ned to is BioMet
0250: 68 6f 64 73 20 2a 2f 0a 23 64 65 66 69 6e 65 20  hods */.#define 
0260: 42 49 4f 5f 6d 65 74 68 5f 6e 65 77 28 74 79 70  BIO_meth_new(typ
0270: 65 5f 2c 20 6e 61 6d 65 5f 29 20 20 20 20 20 20  e_, name_)      
0280: 20 28 42 49 4f 5f 4d 45 54 48 4f 44 20 2a 29 54   (BIO_METHOD *)T
0290: 63 6c 5f 41 6c 6c 6f 63 28 73 69 7a 65 6f 66 28  cl_Alloc(sizeof(
02a0: 42 49 4f 5f 4d 45 54 48 4f 44 29 29 3b 20 5c 0a  BIO_METHOD)); \.
02b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
02c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
02d0: 20 20 20 20 20 20 20 20 20 6d 65 6d 73 65 74 28           memset(
02e0: 42 69 6f 4d 65 74 68 6f 64 73 2c 20 30 2c 20 73  BioMethods, 0, s
02f0: 69 7a 65 6f 66 28 42 49 4f 5f 4d 45 54 48 4f 44  izeof(BIO_METHOD
0300: 29 29 3b 20 5c 0a 20 20 20 20 20 20 20 20 20 20  )); \.          
0310: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0320: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 42                 B
0330: 69 6f 4d 65 74 68 6f 64 73 2d 3e 74 79 70 65 20  ioMethods->type 
0340: 3d 20 74 79 70 65 5f 3b 20 5c 0a 20 20 20 20 20  = type_; \.     
0350: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0360: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0370: 20 20 20 20 42 69 6f 4d 65 74 68 6f 64 73 2d 3e      BioMethods->
0380: 6e 61 6d 65 20 3d 20 6e 61 6d 65 5f 3b 0a 23 64  name = name_;.#d
0390: 65 66 69 6e 65 20 42 49 4f 5f 6d 65 74 68 5f 73  efine BIO_meth_s
03a0: 65 74 5f 77 72 69 74 65 28 62 69 6f 2c 20 76 61  et_write(bio, va
03b0: 6c 29 20 20 20 20 20 28 62 69 6f 29 2d 3e 62 77  l)     (bio)->bw
03c0: 72 69 74 65 20 3d 20 76 61 6c 3b 0a 23 64 65 66  rite = val;.#def
03d0: 69 6e 65 20 42 49 4f 5f 6d 65 74 68 5f 73 65 74  ine BIO_meth_set
03e0: 5f 72 65 61 64 28 62 69 6f 2c 20 76 61 6c 29 20  _read(bio, val) 
03f0: 20 20 20 20 20 28 62 69 6f 29 2d 3e 62 72 65 61       (bio)->brea
0400: 64 20 3d 20 76 61 6c 3b 0a 23 64 65 66 69 6e 65  d = val;.#define
0410: 20 42 49 4f 5f 6d 65 74 68 5f 73 65 74 5f 70 75   BIO_meth_set_pu
0420: 74 73 28 62 69 6f 2c 20 76 61 6c 29 20 20 20 20  ts(bio, val)    
0430: 20 20 28 62 69 6f 29 2d 3e 62 70 75 74 73 20 3d    (bio)->bputs =
0440: 20 76 61 6c 3b 0a 23 64 65 66 69 6e 65 20 42 49   val;.#define BI
0450: 4f 5f 6d 65 74 68 5f 73 65 74 5f 63 74 72 6c 28  O_meth_set_ctrl(
0460: 62 69 6f 2c 20 76 61 6c 29 20 20 20 20 20 20 28  bio, val)      (
0470: 62 69 6f 29 2d 3e 63 74 72 6c 20 3d 20 76 61 6c  bio)->ctrl = val
0480: 3b 0a 23 64 65 66 69 6e 65 20 42 49 4f 5f 6d 65  ;.#define BIO_me
0490: 74 68 5f 73 65 74 5f 63 72 65 61 74 65 28 62 69  th_set_create(bi
04a0: 6f 2c 20 76 61 6c 29 20 20 20 20 28 62 69 6f 29  o, val)    (bio)
04b0: 2d 3e 63 72 65 61 74 65 20 3d 20 76 61 6c 3b 0a  ->create = val;.
04c0: 23 64 65 66 69 6e 65 20 42 49 4f 5f 6d 65 74 68  #define BIO_meth
04d0: 5f 73 65 74 5f 64 65 73 74 72 6f 79 28 62 69 6f  _set_destroy(bio
04e0: 2c 20 76 61 6c 29 20 20 20 28 62 69 6f 29 2d 3e  , val)   (bio)->
04f0: 64 65 73 74 72 6f 79 20 3d 20 76 61 6c 3b 0a 23  destroy = val;.#
0500: 65 6e 64 69 66 0a 0a 2f 2a 0a 20 2a 20 46 6f 72  endif../*. * For
0510: 77 61 72 64 20 64 65 63 6c 61 72 61 74 69 6f 6e  ward declaration
0520: 73 0a 20 2a 2f 0a 0a 73 74 61 74 69 63 20 69 6e  s. */..static in
0530: 74 20 42 69 6f 57 72 69 74 65 20 5f 41 4e 53 49  t BioWrite _ANSI
0540: 5f 41 52 47 53 5f 28 28 42 49 4f 20 2a 68 2c 20  _ARGS_((BIO *h, 
0550: 43 4f 4e 53 54 20 63 68 61 72 20 2a 62 75 66 2c  CONST char *buf,
0560: 20 69 6e 74 20 6e 75 6d 29 29 3b 0a 73 74 61 74   int num));.stat
0570: 69 63 20 69 6e 74 20 42 69 6f 52 65 61 64 20 20  ic int BioRead  
0580: 5f 41 4e 53 49 5f 41 52 47 53 5f 28 28 42 49 4f  _ANSI_ARGS_((BIO
0590: 20 2a 68 2c 20 63 68 61 72 20 2a 62 75 66 2c 20   *h, char *buf, 
05a0: 69 6e 74 20 6e 75 6d 29 29 3b 0a 73 74 61 74 69  int num));.stati
05b0: 63 20 69 6e 74 20 42 69 6f 50 75 74 73 20 20 5f  c int BioPuts  _
05c0: 41 4e 53 49 5f 41 52 47 53 5f 28 28 42 49 4f 20  ANSI_ARGS_((BIO 
05d0: 2a 68 2c 20 43 4f 4e 53 54 20 63 68 61 72 20 2a  *h, CONST char *
05e0: 73 74 72 29 29 3b 0a 73 74 61 74 69 63 20 6c 6f  str));.static lo
05f0: 6e 67 20 42 69 6f 43 74 72 6c 20 5f 41 4e 53 49  ng BioCtrl _ANSI
0600: 5f 41 52 47 53 5f 28 28 42 49 4f 20 2a 68 2c 20  _ARGS_((BIO *h, 
0610: 69 6e 74 20 63 6d 64 2c 20 6c 6f 6e 67 20 61 72  int cmd, long ar
0620: 67 31 2c 20 76 6f 69 64 20 2a 70 74 72 29 29 3b  g1, void *ptr));
0630: 0a 73 74 61 74 69 63 20 69 6e 74 20 42 69 6f 4e  .static int BioN
0640: 65 77 20 20 20 5f 41 4e 53 49 5f 41 52 47 53 5f  ew   _ANSI_ARGS_
0650: 28 28 42 49 4f 20 2a 68 29 29 3b 0a 73 74 61 74  ((BIO *h));.stat
0660: 69 63 20 69 6e 74 20 42 69 6f 46 72 65 65 20 20  ic int BioFree  
0670: 5f 41 4e 53 49 5f 41 52 47 53 5f 28 28 42 49 4f  _ANSI_ARGS_((BIO
0680: 20 2a 68 29 29 3b 0a 0a 42 49 4f 20 2a 42 49 4f   *h));..BIO *BIO
0690: 5f 6e 65 77 5f 74 63 6c 28 53 74 61 74 65 20 2a  _new_tcl(State *
06a0: 73 74 61 74 65 50 74 72 2c 20 69 6e 74 20 66 6c  statePtr, int fl
06b0: 61 67 73 29 20 7b 0a 09 42 49 4f 20 2a 62 69 6f  ags) {..BIO *bio
06c0: 3b 0a 09 73 74 61 74 69 63 20 42 49 4f 5f 4d 45  ;..static BIO_ME
06d0: 54 48 4f 44 20 2a 42 69 6f 4d 65 74 68 6f 64 73  THOD *BioMethods
06e0: 20 3d 20 4e 55 4c 4c 3b 0a 23 69 66 64 65 66 20   = NULL;.#ifdef 
06f0: 54 43 4c 54 4c 53 5f 53 53 4c 5f 55 53 45 5f 46  TCLTLS_SSL_USE_F
0700: 41 53 54 50 41 54 48 0a 09 54 63 6c 5f 43 68 61  ASTPATH..Tcl_Cha
0710: 6e 6e 65 6c 20 70 61 72 65 6e 74 43 68 61 6e 6e  nnel parentChann
0720: 65 6c 3b 0a 09 63 6f 6e 73 74 20 54 63 6c 5f 43  el;..const Tcl_C
0730: 68 61 6e 6e 65 6c 54 79 70 65 20 2a 70 61 72 65  hannelType *pare
0740: 6e 74 43 68 61 6e 6e 65 6c 54 79 70 65 3b 0a 09  ntChannelType;..
0750: 76 6f 69 64 20 2a 70 61 72 65 6e 74 43 68 61 6e  void *parentChan
0760: 6e 65 6c 46 64 49 6e 5f 70 2c 20 2a 70 61 72 65  nelFdIn_p, *pare
0770: 6e 74 43 68 61 6e 6e 65 6c 46 64 4f 75 74 5f 70  ntChannelFdOut_p
0780: 3b 0a 09 69 6e 74 20 70 61 72 65 6e 74 43 68 61  ;..int parentCha
0790: 6e 6e 65 6c 46 64 49 6e 2c 20 70 61 72 65 6e 74  nnelFdIn, parent
07a0: 43 68 61 6e 6e 65 6c 46 64 4f 75 74 2c 20 70 61  ChannelFdOut, pa
07b0: 72 65 6e 74 43 68 61 6e 6e 65 6c 46 64 3b 0a 09  rentChannelFd;..
07c0: 69 6e 74 20 76 61 6c 69 64 50 61 72 65 6e 74 43  int validParentC
07d0: 68 61 6e 6e 65 6c 46 64 3b 0a 09 69 6e 74 20 74  hannelFd;..int t
07e0: 63 6c 47 65 74 43 68 61 6e 6e 65 6c 48 61 6e 64  clGetChannelHand
07f0: 6c 65 52 65 74 3b 0a 23 65 6e 64 69 66 0a 0a 09  leRet;.#endif...
0800: 64 70 72 69 6e 74 66 28 22 42 49 4f 5f 6e 65 77  dprintf("BIO_new
0810: 5f 74 63 6c 28 29 20 63 61 6c 6c 65 64 22 29 3b  _tcl() called");
0820: 0a 0a 09 69 66 20 28 42 69 6f 4d 65 74 68 6f 64  ...if (BioMethod
0830: 73 20 3d 3d 20 4e 55 4c 4c 29 20 7b 0a 09 09 42  s == NULL) {...B
0840: 69 6f 4d 65 74 68 6f 64 73 20 3d 20 42 49 4f 5f  ioMethods = BIO_
0850: 6d 65 74 68 5f 6e 65 77 28 42 49 4f 5f 54 59 50  meth_new(BIO_TYP
0860: 45 5f 54 43 4c 2c 20 22 74 63 6c 22 29 3b 0a 09  E_TCL, "tcl");..
0870: 09 42 49 4f 5f 6d 65 74 68 5f 73 65 74 5f 77 72  .BIO_meth_set_wr
0880: 69 74 65 28 42 69 6f 4d 65 74 68 6f 64 73 2c 20  ite(BioMethods, 
0890: 42 69 6f 57 72 69 74 65 29 3b 0a 09 09 42 49 4f  BioWrite);...BIO
08a0: 5f 6d 65 74 68 5f 73 65 74 5f 72 65 61 64 28 42  _meth_set_read(B
08b0: 69 6f 4d 65 74 68 6f 64 73 2c 20 42 69 6f 52 65  ioMethods, BioRe
08c0: 61 64 29 3b 0a 09 09 42 49 4f 5f 6d 65 74 68 5f  ad);...BIO_meth_
08d0: 73 65 74 5f 70 75 74 73 28 42 69 6f 4d 65 74 68  set_puts(BioMeth
08e0: 6f 64 73 2c 20 42 69 6f 50 75 74 73 29 3b 0a 09  ods, BioPuts);..
08f0: 09 42 49 4f 5f 6d 65 74 68 5f 73 65 74 5f 63 74  .BIO_meth_set_ct
0900: 72 6c 28 42 69 6f 4d 65 74 68 6f 64 73 2c 20 42  rl(BioMethods, B
0910: 69 6f 43 74 72 6c 29 3b 0a 09 09 42 49 4f 5f 6d  ioCtrl);...BIO_m
0920: 65 74 68 5f 73 65 74 5f 63 72 65 61 74 65 28 42  eth_set_create(B
0930: 69 6f 4d 65 74 68 6f 64 73 2c 20 42 69 6f 4e 65  ioMethods, BioNe
0940: 77 29 3b 0a 09 09 42 49 4f 5f 6d 65 74 68 5f 73  w);...BIO_meth_s
0950: 65 74 5f 64 65 73 74 72 6f 79 28 42 69 6f 4d 65  et_destroy(BioMe
0960: 74 68 6f 64 73 2c 20 42 69 6f 46 72 65 65 29 3b  thods, BioFree);
0970: 0a 09 7d 0a 0a 09 69 66 20 28 73 74 61 74 65 50  ..}...if (stateP
0980: 74 72 20 3d 3d 20 4e 55 4c 4c 29 20 7b 0a 09 09  tr == NULL) {...
0990: 64 70 72 69 6e 74 66 28 22 41 73 6b 65 64 20 74  dprintf("Asked t
09a0: 6f 20 73 65 74 75 70 20 61 20 4e 55 4c 4c 20 73  o setup a NULL s
09b0: 74 61 74 65 2c 20 6a 75 73 74 20 63 72 65 61 74  tate, just creat
09c0: 69 6e 67 20 74 68 65 20 69 6e 69 74 69 61 6c 20  ing the initial 
09d0: 63 6f 6e 66 69 67 75 72 61 74 69 6f 6e 22 29 3b  configuration");
09e0: 0a 0a 09 09 72 65 74 75 72 6e 28 4e 55 4c 4c 29  ....return(NULL)
09f0: 3b 0a 09 7d 0a 0a 23 69 66 64 65 66 20 54 43 4c  ;..}..#ifdef TCL
0a00: 54 4c 53 5f 53 53 4c 5f 55 53 45 5f 46 41 53 54  TLS_SSL_USE_FAST
0a10: 50 41 54 48 0a 09 2f 2a 0a 09 20 2a 20 49 66 20  PATH../*.. * If 
0a20: 74 68 65 20 63 68 61 6e 6e 65 6c 20 63 61 6e 20  the channel can 
0a30: 62 65 20 6d 61 70 70 65 64 20 62 61 63 6b 20 74  be mapped back t
0a40: 6f 20 61 20 66 69 6c 65 20 64 65 73 63 72 69 70  o a file descrip
0a50: 74 6f 72 2c 20 6a 75 73 74 20 75 73 65 20 74 68  tor, just use th
0a60: 65 20 66 69 6c 65 20 64 65 73 63 72 69 70 74 6f  e file descripto
0a70: 72 0a 09 20 2a 20 77 69 74 68 20 74 68 65 20 53  r.. * with the S
0a80: 53 4c 20 6c 69 62 72 61 72 79 20 73 69 6e 63 65  SL library since
0a90: 20 69 74 20 77 69 6c 6c 20 6c 69 6b 65 6c 79 20   it will likely 
0aa0: 62 65 20 6f 70 74 69 6d 69 7a 65 64 20 66 6f 72  be optimized for
0ab0: 20 74 68 69 73 2e 0a 09 20 2a 2f 0a 09 70 61 72   this... */..par
0ac0: 65 6e 74 43 68 61 6e 6e 65 6c 20 3d 20 54 6c 73  entChannel = Tls
0ad0: 5f 47 65 74 50 61 72 65 6e 74 28 73 74 61 74 65  _GetParent(state
0ae0: 50 74 72 2c 20 30 29 3b 0a 09 70 61 72 65 6e 74  Ptr, 0);..parent
0af0: 43 68 61 6e 6e 65 6c 54 79 70 65 20 3d 20 54 63  ChannelType = Tc
0b00: 6c 5f 47 65 74 43 68 61 6e 6e 65 6c 54 79 70 65  l_GetChannelType
0b10: 28 70 61 72 65 6e 74 43 68 61 6e 6e 65 6c 29 3b  (parentChannel);
0b20: 0a 0a 09 76 61 6c 69 64 50 61 72 65 6e 74 43 68  ...validParentCh
0b30: 61 6e 6e 65 6c 46 64 20 3d 20 30 3b 0a 09 69 66  annelFd = 0;..if
0b40: 20 28 73 74 72 63 6d 70 28 70 61 72 65 6e 74 43   (strcmp(parentC
0b50: 68 61 6e 6e 65 6c 54 79 70 65 2d 3e 74 79 70 65  hannelType->type
0b60: 4e 61 6d 65 2c 20 22 74 63 70 22 29 20 3d 3d 20  Name, "tcp") == 
0b70: 30 29 20 7b 0a 09 09 74 63 6c 47 65 74 43 68 61  0) {...tclGetCha
0b80: 6e 6e 65 6c 48 61 6e 64 6c 65 52 65 74 20 3d 20  nnelHandleRet = 
0b90: 54 63 6c 5f 47 65 74 43 68 61 6e 6e 65 6c 48 61  Tcl_GetChannelHa
0ba0: 6e 64 6c 65 28 70 61 72 65 6e 74 43 68 61 6e 6e  ndle(parentChann
0bb0: 65 6c 2c 20 54 43 4c 5f 52 45 41 44 41 42 4c 45  el, TCL_READABLE
0bc0: 2c 20 28 43 6c 69 65 6e 74 44 61 74 61 29 20 26  , (ClientData) &
0bd0: 70 61 72 65 6e 74 43 68 61 6e 6e 65 6c 46 64 49  parentChannelFdI
0be0: 6e 5f 70 29 3b 0a 09 09 69 66 20 28 74 63 6c 47  n_p);...if (tclG
0bf0: 65 74 43 68 61 6e 6e 65 6c 48 61 6e 64 6c 65 52  etChannelHandleR
0c00: 65 74 20 3d 3d 20 54 43 4c 5f 4f 4b 29 20 7b 0a  et == TCL_OK) {.
0c10: 09 09 09 74 63 6c 47 65 74 43 68 61 6e 6e 65 6c  ...tclGetChannel
0c20: 48 61 6e 64 6c 65 52 65 74 20 3d 20 54 63 6c 5f  HandleRet = Tcl_
0c30: 47 65 74 43 68 61 6e 6e 65 6c 48 61 6e 64 6c 65  GetChannelHandle
0c40: 28 70 61 72 65 6e 74 43 68 61 6e 6e 65 6c 2c 20  (parentChannel, 
0c50: 54 43 4c 5f 57 52 49 54 41 42 4c 45 2c 20 28 43  TCL_WRITABLE, (C
0c60: 6c 69 65 6e 74 44 61 74 61 29 20 26 70 61 72 65  lientData) &pare
0c70: 6e 74 43 68 61 6e 6e 65 6c 46 64 4f 75 74 5f 70  ntChannelFdOut_p
0c80: 29 3b 0a 09 09 09 69 66 20 28 74 63 6c 47 65 74  );....if (tclGet
0c90: 43 68 61 6e 6e 65 6c 48 61 6e 64 6c 65 52 65 74  ChannelHandleRet
0ca0: 20 3d 3d 20 54 43 4c 5f 4f 4b 29 20 7b 0a 09 09   == TCL_OK) {...
0cb0: 09 09 70 61 72 65 6e 74 43 68 61 6e 6e 65 6c 46  ..parentChannelF
0cc0: 64 49 6e 20 3d 20 50 54 52 32 49 4e 54 28 70 61  dIn = PTR2INT(pa
0cd0: 72 65 6e 74 43 68 61 6e 6e 65 6c 46 64 49 6e 5f  rentChannelFdIn_
0ce0: 70 29 3b 0a 09 09 09 09 70 61 72 65 6e 74 43 68  p);.....parentCh
0cf0: 61 6e 6e 65 6c 46 64 4f 75 74 20 3d 20 50 54 52  annelFdOut = PTR
0d00: 32 49 4e 54 28 70 61 72 65 6e 74 43 68 61 6e 6e  2INT(parentChann
0d10: 65 6c 46 64 4f 75 74 5f 70 29 3b 0a 09 09 09 09  elFdOut_p);.....
0d20: 69 66 20 28 70 61 72 65 6e 74 43 68 61 6e 6e 65  if (parentChanne
0d30: 6c 46 64 49 6e 20 3d 3d 20 70 61 72 65 6e 74 43  lFdIn == parentC
0d40: 68 61 6e 6e 65 6c 46 64 4f 75 74 29 20 7b 0a 09  hannelFdOut) {..
0d50: 09 09 09 09 70 61 72 65 6e 74 43 68 61 6e 6e 65  ....parentChanne
0d60: 6c 46 64 20 3d 20 70 61 72 65 6e 74 43 68 61 6e  lFd = parentChan
0d70: 6e 65 6c 46 64 49 6e 3b 0a 09 09 09 09 09 76 61  nelFdIn;......va
0d80: 6c 69 64 50 61 72 65 6e 74 43 68 61 6e 6e 65 6c  lidParentChannel
0d90: 46 64 20 3d 20 31 3b 0a 09 09 09 09 7d 0a 09 09  Fd = 1;.....}...
0da0: 09 7d 0a 09 09 7d 0a 09 7d 0a 0a 09 69 66 20 28  .}...}..}...if (
0db0: 76 61 6c 69 64 50 61 72 65 6e 74 43 68 61 6e 6e  validParentChann
0dc0: 65 6c 46 64 29 20 7b 0a 09 09 64 70 72 69 6e 74  elFd) {...dprint
0dd0: 66 28 22 57 65 20 66 6f 75 6e 64 20 61 20 73 68  f("We found a sh
0de0: 6f 72 74 63 75 74 2c 20 74 68 69 73 20 63 68 61  ortcut, this cha
0df0: 6e 6e 65 6c 20 69 73 20 62 61 63 6b 65 64 20 62  nnel is backed b
0e00: 79 20 61 20 73 6f 63 6b 65 74 3a 20 25 69 22 2c  y a socket: %i",
0e10: 20 70 61 72 65 6e 74 43 68 61 6e 6e 65 6c 46 64   parentChannelFd
0e20: 49 6e 29 3b 0a 09 09 62 69 6f 20 3d 20 42 49 4f  In);...bio = BIO
0e30: 5f 6e 65 77 5f 73 6f 63 6b 65 74 28 70 61 72 65  _new_socket(pare
0e40: 6e 74 43 68 61 6e 6e 65 6c 46 64 2c 20 66 6c 61  ntChannelFd, fla
0e50: 67 73 29 3b 0a 09 09 73 74 61 74 65 50 74 72 2d  gs);...statePtr-
0e60: 3e 66 6c 61 67 73 20 7c 3d 20 54 4c 53 5f 54 43  >flags |= TLS_TC
0e70: 4c 5f 46 41 53 54 50 41 54 48 3b 0a 09 09 72 65  L_FASTPATH;...re
0e80: 74 75 72 6e 28 62 69 6f 29 3b 0a 09 7d 0a 0a 09  turn(bio);..}...
0e90: 64 70 72 69 6e 74 66 28 22 46 61 6c 6c 69 6e 67  dprintf("Falling
0ea0: 20 62 61 63 6b 20 74 6f 20 54 63 6c 20 49 2f 4f   back to Tcl I/O
0eb0: 20 66 6f 72 20 74 68 69 73 20 63 68 61 6e 6e 65   for this channe
0ec0: 6c 22 29 3b 0a 23 65 6e 64 69 66 0a 0a 09 62 69  l");.#endif...bi
0ed0: 6f 20 3d 20 42 49 4f 5f 6e 65 77 28 42 69 6f 4d  o = BIO_new(BioM
0ee0: 65 74 68 6f 64 73 29 3b 0a 09 42 49 4f 5f 73 65  ethods);..BIO_se
0ef0: 74 5f 64 61 74 61 28 62 69 6f 2c 20 73 74 61 74  t_data(bio, stat
0f00: 65 50 74 72 29 3b 0a 09 42 49 4f 5f 73 65 74 5f  ePtr);..BIO_set_
0f10: 73 68 75 74 64 6f 77 6e 28 62 69 6f 2c 20 66 6c  shutdown(bio, fl
0f20: 61 67 73 29 3b 0a 09 42 49 4f 5f 73 65 74 5f 69  ags);..BIO_set_i
0f30: 6e 69 74 28 62 69 6f 2c 20 31 29 3b 0a 0a 09 72  nit(bio, 1);...r
0f40: 65 74 75 72 6e 28 62 69 6f 29 3b 0a 7d 0a 0a 73  eturn(bio);.}..s
0f50: 74 61 74 69 63 20 69 6e 74 20 42 69 6f 57 72 69  tatic int BioWri
0f60: 74 65 28 42 49 4f 20 2a 62 69 6f 2c 20 43 4f 4e  te(BIO *bio, CON
0f70: 53 54 20 63 68 61 72 20 2a 62 75 66 2c 20 69 6e  ST char *buf, in
0f80: 74 20 62 75 66 4c 65 6e 29 20 7b 0a 09 54 63 6c  t bufLen) {..Tcl
0f90: 5f 43 68 61 6e 6e 65 6c 20 63 68 61 6e 3b 0a 09  _Channel chan;..
0fa0: 69 6e 74 20 72 65 74 3b 0a 09 69 6e 74 20 74 63  int ret;..int tc
0fb0: 6c 45 6f 66 43 68 61 6e 2c 20 74 63 6c 45 72 72  lEofChan, tclErr
0fc0: 6e 6f 3b 0a 0a 09 63 68 61 6e 20 3d 20 54 6c 73  no;...chan = Tls
0fd0: 5f 47 65 74 50 61 72 65 6e 74 28 28 53 74 61 74  _GetParent((Stat
0fe0: 65 20 2a 29 20 42 49 4f 5f 67 65 74 5f 64 61 74  e *) BIO_get_dat
0ff0: 61 28 62 69 6f 29 2c 20 30 29 3b 0a 0a 09 64 70  a(bio), 0);...dp
1000: 72 69 6e 74 66 28 22 5b 63 68 61 6e 3d 25 70 5d  rintf("[chan=%p]
1010: 20 42 69 6f 57 72 69 74 65 28 25 70 2c 20 3c 62   BioWrite(%p, <b
1020: 75 66 3e 2c 20 25 64 29 22 2c 20 28 76 6f 69 64  uf>, %d)", (void
1030: 20 2a 29 63 68 61 6e 2c 20 28 76 6f 69 64 20 2a   *)chan, (void *
1040: 29 20 62 69 6f 2c 20 62 75 66 4c 65 6e 29 3b 0a  ) bio, bufLen);.
1050: 0a 09 72 65 74 20 3d 20 54 63 6c 5f 57 72 69 74  ..ret = Tcl_Writ
1060: 65 52 61 77 28 63 68 61 6e 2c 20 62 75 66 2c 20  eRaw(chan, buf, 
1070: 62 75 66 4c 65 6e 29 3b 0a 0a 09 74 63 6c 45 6f  bufLen);...tclEo
1080: 66 43 68 61 6e 20 3d 20 54 63 6c 5f 45 6f 66 28  fChan = Tcl_Eof(
1090: 63 68 61 6e 29 3b 0a 09 74 63 6c 45 72 72 6e 6f  chan);..tclErrno
10a0: 20 3d 20 54 63 6c 5f 47 65 74 45 72 72 6e 6f 28   = Tcl_GetErrno(
10b0: 29 3b 0a 0a 09 64 70 72 69 6e 74 66 28 22 5b 63  );...dprintf("[c
10c0: 68 61 6e 3d 25 70 5d 20 42 69 6f 57 72 69 74 65  han=%p] BioWrite
10d0: 28 25 64 29 20 2d 3e 20 25 64 20 5b 74 63 6c 45  (%d) -> %d [tclE
10e0: 6f 66 3d 25 64 3b 20 74 63 6c 45 72 72 6e 6f 3d  of=%d; tclErrno=
10f0: 25 64 5d 22 2c 20 28 76 6f 69 64 20 2a 29 20 63  %d]", (void *) c
1100: 68 61 6e 2c 20 62 75 66 4c 65 6e 2c 20 72 65 74  han, bufLen, ret
1110: 2c 20 74 63 6c 45 6f 66 43 68 61 6e 2c 20 54 63  , tclEofChan, Tc
1120: 6c 5f 47 65 74 45 72 72 6e 6f 28 29 29 3b 0a 0a  l_GetErrno());..
1130: 09 42 49 4f 5f 63 6c 65 61 72 5f 66 6c 61 67 73  .BIO_clear_flags
1140: 28 62 69 6f 2c 20 42 49 4f 5f 46 4c 41 47 53 5f  (bio, BIO_FLAGS_
1150: 57 52 49 54 45 20 7c 20 42 49 4f 5f 46 4c 41 47  WRITE | BIO_FLAG
1160: 53 5f 53 48 4f 55 4c 44 5f 52 45 54 52 59 29 3b  S_SHOULD_RETRY);
1170: 0a 0a 09 69 66 20 28 74 63 6c 45 6f 66 43 68 61  ...if (tclEofCha
1180: 6e 20 26 26 20 72 65 74 20 3c 3d 20 30 29 20 7b  n && ret <= 0) {
1190: 0a 09 09 64 70 72 69 6e 74 66 28 22 47 6f 74 20  ...dprintf("Got 
11a0: 45 4f 46 20 77 68 69 6c 65 20 72 65 61 64 69 6e  EOF while readin
11b0: 67 2c 20 72 65 74 75 72 6e 69 6e 67 20 61 20 43  g, returning a C
11c0: 6f 6e 6e 65 63 74 69 6f 6e 20 52 65 73 65 74 20  onnection Reset 
11d0: 65 72 72 6f 72 20 77 68 69 63 68 20 6d 61 70 73  error which maps
11e0: 20 74 6f 20 53 6f 66 74 20 45 4f 46 22 29 3b 0a   to Soft EOF");.
11f0: 09 09 54 63 6c 5f 53 65 74 45 72 72 6e 6f 28 45  ..Tcl_SetErrno(E
1200: 43 4f 4e 4e 52 45 53 45 54 29 3b 0a 09 09 72 65  CONNRESET);...re
1210: 74 20 3d 20 30 3b 0a 09 7d 20 65 6c 73 65 20 69  t = 0;..} else i
1220: 66 20 28 72 65 74 20 3d 3d 20 30 29 20 7b 0a 09  f (ret == 0) {..
1230: 09 64 70 72 69 6e 74 66 28 22 47 6f 74 20 30 20  .dprintf("Got 0 
1240: 66 72 6f 6d 20 54 63 6c 5f 57 72 69 74 65 52 61  from Tcl_WriteRa
1250: 77 2c 20 61 6e 64 20 45 4f 46 20 69 73 20 6e 6f  w, and EOF is no
1260: 74 20 73 65 74 3b 20 72 65 74 20 3d 20 30 22 29  t set; ret = 0")
1270: 3b 0a 09 09 64 70 72 69 6e 74 66 28 22 53 65 74  ;...dprintf("Set
1280: 74 69 6e 67 20 72 65 74 72 79 20 72 65 61 64 20  ting retry read 
1290: 66 6c 61 67 22 29 3b 0a 09 09 42 49 4f 5f 73 65  flag");...BIO_se
12a0: 74 5f 72 65 74 72 79 5f 72 65 61 64 28 62 69 6f  t_retry_read(bio
12b0: 29 3b 0a 09 7d 20 65 6c 73 65 20 69 66 20 28 72  );..} else if (r
12c0: 65 74 20 3c 20 30 29 20 7b 0a 09 09 64 70 72 69  et < 0) {...dpri
12d0: 6e 74 66 28 22 57 65 20 67 6f 74 20 73 6f 6d 65  ntf("We got some
12e0: 20 6b 69 6e 64 20 6f 66 20 49 2f 4f 20 65 72 72   kind of I/O err
12f0: 6f 72 22 29 3b 0a 0a 09 09 69 66 20 28 74 63 6c  or");....if (tcl
1300: 45 72 72 6e 6f 20 3d 3d 20 45 41 47 41 49 4e 29  Errno == EAGAIN)
1310: 20 7b 0a 09 09 09 64 70 72 69 6e 74 66 28 22 49   {....dprintf("I
1320: 74 27 73 20 45 41 47 41 49 4e 22 29 3b 0a 09 09  t's EAGAIN");...
1330: 7d 20 65 6c 73 65 20 7b 0a 09 09 09 64 70 72 69  } else {....dpri
1340: 6e 74 66 28 22 49 74 27 73 20 61 6e 20 75 6e 65  ntf("It's an une
1350: 70 78 65 63 74 65 64 20 65 72 72 6f 72 3a 20 25  pxected error: %
1360: 73 2f 25 69 22 2c 20 54 63 6c 5f 45 72 72 6e 6f  s/%i", Tcl_Errno
1370: 4d 73 67 28 74 63 6c 45 72 72 6e 6f 29 2c 20 74  Msg(tclErrno), t
1380: 63 6c 45 72 72 6e 6f 29 3b 0a 09 09 7d 0a 09 7d  clErrno);...}..}
1390: 20 65 6c 73 65 20 7b 0a 09 09 64 70 72 69 6e 74   else {...dprint
13a0: 66 28 22 53 75 63 63 65 73 73 66 75 6c 6c 79 20  f("Successfully 
13b0: 77 72 6f 74 65 20 73 6f 6d 65 20 64 61 74 61 22  wrote some data"
13c0: 29 3b 0a 09 7d 0a 0a 09 69 66 20 28 72 65 74 20  );..}...if (ret 
13d0: 21 3d 20 2d 31 20 7c 7c 20 28 72 65 74 20 3d 3d  != -1 || (ret ==
13e0: 20 2d 31 20 26 26 20 74 63 6c 45 72 72 6e 6f 20   -1 && tclErrno 
13f0: 3d 3d 20 45 41 47 41 49 4e 29 29 20 7b 0a 09 09  == EAGAIN)) {...
1400: 69 66 20 28 42 49 4f 5f 73 68 6f 75 6c 64 5f 72  if (BIO_should_r
1410: 65 61 64 28 62 69 6f 29 29 20 7b 0a 09 09 09 64  ead(bio)) {....d
1420: 70 72 69 6e 74 66 28 22 53 65 74 74 69 6e 67 20  printf("Setting 
1430: 73 68 6f 75 6c 64 20 72 65 74 72 79 20 72 65 61  should retry rea
1440: 64 20 66 6c 61 67 22 29 3b 0a 0a 09 09 09 42 49  d flag");.....BI
1450: 4f 5f 73 65 74 5f 72 65 74 72 79 5f 72 65 61 64  O_set_retry_read
1460: 28 62 69 6f 29 3b 0a 09 09 7d 0a 09 7d 0a 0a 09  (bio);...}..}...
1470: 72 65 74 75 72 6e 28 72 65 74 29 3b 0a 7d 0a 0a  return(ret);.}..
1480: 73 74 61 74 69 63 20 69 6e 74 20 42 69 6f 52 65  static int BioRe
1490: 61 64 28 42 49 4f 20 2a 62 69 6f 2c 20 63 68 61  ad(BIO *bio, cha
14a0: 72 20 2a 62 75 66 2c 20 69 6e 74 20 62 75 66 4c  r *buf, int bufL
14b0: 65 6e 29 20 7b 0a 09 54 63 6c 5f 43 68 61 6e 6e  en) {..Tcl_Chann
14c0: 65 6c 20 63 68 61 6e 3b 0a 09 69 6e 74 20 72 65  el chan;..int re
14d0: 74 20 3d 20 30 3b 0a 09 69 6e 74 20 74 63 6c 45  t = 0;..int tclE
14e0: 6f 66 43 68 61 6e 2c 20 74 63 6c 45 72 72 6e 6f  ofChan, tclErrno
14f0: 3b 0a 0a 09 63 68 61 6e 20 3d 20 54 6c 73 5f 47  ;...chan = Tls_G
1500: 65 74 50 61 72 65 6e 74 28 28 53 74 61 74 65 20  etParent((State 
1510: 2a 29 20 42 49 4f 5f 67 65 74 5f 64 61 74 61 28  *) BIO_get_data(
1520: 62 69 6f 29 2c 20 30 29 3b 0a 0a 09 64 70 72 69  bio), 0);...dpri
1530: 6e 74 66 28 22 5b 63 68 61 6e 3d 25 70 5d 20 42  ntf("[chan=%p] B
1540: 69 6f 52 65 61 64 28 25 70 2c 20 3c 62 75 66 3e  ioRead(%p, <buf>
1550: 2c 20 25 64 29 22 2c 20 28 76 6f 69 64 20 2a 29  , %d)", (void *)
1560: 20 63 68 61 6e 2c 20 28 76 6f 69 64 20 2a 29 20   chan, (void *) 
1570: 62 69 6f 2c 20 62 75 66 4c 65 6e 29 3b 0a 0a 09  bio, bufLen);...
1580: 69 66 20 28 62 75 66 20 3d 3d 20 4e 55 4c 4c 29  if (buf == NULL)
1590: 20 7b 0a 09 09 72 65 74 75 72 6e 20 30 3b 0a 09   {...return 0;..
15a0: 7d 0a 0a 09 72 65 74 20 3d 20 54 63 6c 5f 52 65  }...ret = Tcl_Re
15b0: 61 64 52 61 77 28 63 68 61 6e 2c 20 62 75 66 2c  adRaw(chan, buf,
15c0: 20 62 75 66 4c 65 6e 29 3b 0a 0a 09 74 63 6c 45   bufLen);...tclE
15d0: 6f 66 43 68 61 6e 20 3d 20 54 63 6c 5f 45 6f 66  ofChan = Tcl_Eof
15e0: 28 63 68 61 6e 29 3b 0a 09 74 63 6c 45 72 72 6e  (chan);..tclErrn
15f0: 6f 20 3d 20 54 63 6c 5f 47 65 74 45 72 72 6e 6f  o = Tcl_GetErrno
1600: 28 29 3b 0a 0a 09 64 70 72 69 6e 74 66 28 22 5b  ();...dprintf("[
1610: 63 68 61 6e 3d 25 70 5d 20 42 69 6f 52 65 61 64  chan=%p] BioRead
1620: 28 25 64 29 20 2d 3e 20 25 64 20 5b 74 63 6c 45  (%d) -> %d [tclE
1630: 6f 66 3d 25 64 3b 20 74 63 6c 45 72 72 6e 6f 3d  of=%d; tclErrno=
1640: 25 64 5d 22 2c 20 28 76 6f 69 64 20 2a 29 20 63  %d]", (void *) c
1650: 68 61 6e 2c 20 62 75 66 4c 65 6e 2c 20 72 65 74  han, bufLen, ret
1660: 2c 20 74 63 6c 45 6f 66 43 68 61 6e 2c 20 74 63  , tclEofChan, tc
1670: 6c 45 72 72 6e 6f 29 3b 0a 0a 09 42 49 4f 5f 63  lErrno);...BIO_c
1680: 6c 65 61 72 5f 66 6c 61 67 73 28 62 69 6f 2c 20  lear_flags(bio, 
1690: 42 49 4f 5f 46 4c 41 47 53 5f 52 45 41 44 20 7c  BIO_FLAGS_READ |
16a0: 20 42 49 4f 5f 46 4c 41 47 53 5f 53 48 4f 55 4c   BIO_FLAGS_SHOUL
16b0: 44 5f 52 45 54 52 59 29 3b 0a 0a 09 69 66 20 28  D_RETRY);...if (
16c0: 74 63 6c 45 6f 66 43 68 61 6e 20 26 26 20 72 65  tclEofChan && re
16d0: 74 20 3c 3d 20 30 29 20 7b 0a 09 09 64 70 72 69  t <= 0) {...dpri
16e0: 6e 74 66 28 22 47 6f 74 20 45 4f 46 20 77 68 69  ntf("Got EOF whi
16f0: 6c 65 20 72 65 61 64 69 6e 67 2c 20 72 65 74 75  le reading, retu
1700: 72 6e 69 6e 67 20 61 20 43 6f 6e 6e 65 63 74 69  rning a Connecti
1710: 6f 6e 20 52 65 73 65 74 20 65 72 72 6f 72 20 77  on Reset error w
1720: 68 69 63 68 20 6d 61 70 73 20 74 6f 20 53 6f 66  hich maps to Sof
1730: 74 20 45 4f 46 22 29 3b 0a 09 09 54 63 6c 5f 53  t EOF");...Tcl_S
1740: 65 74 45 72 72 6e 6f 28 45 43 4f 4e 4e 52 45 53  etErrno(ECONNRES
1750: 45 54 29 3b 0a 09 09 72 65 74 20 3d 20 30 3b 0a  ET);...ret = 0;.
1760: 09 7d 20 65 6c 73 65 20 69 66 20 28 72 65 74 20  .} else if (ret 
1770: 3d 3d 20 30 29 20 7b 0a 09 09 64 70 72 69 6e 74  == 0) {...dprint
1780: 66 28 22 47 6f 74 20 30 20 66 72 6f 6d 20 54 63  f("Got 0 from Tc
1790: 6c 5f 52 65 61 64 20 6f 72 20 54 63 6c 5f 52 65  l_Read or Tcl_Re
17a0: 61 64 52 61 77 2c 20 61 6e 64 20 45 4f 46 20 69  adRaw, and EOF i
17b0: 73 20 6e 6f 74 20 73 65 74 3b 20 72 65 74 20 3d  s not set; ret =
17c0: 20 30 22 29 3b 0a 09 09 64 70 72 69 6e 74 66 28   0");...dprintf(
17d0: 22 53 65 74 74 69 6e 67 20 72 65 74 72 79 20 72  "Setting retry r
17e0: 65 61 64 20 66 6c 61 67 22 29 3b 0a 09 09 42 49  ead flag");...BI
17f0: 4f 5f 73 65 74 5f 72 65 74 72 79 5f 72 65 61 64  O_set_retry_read
1800: 28 62 69 6f 29 3b 0a 09 7d 20 65 6c 73 65 20 69  (bio);..} else i
1810: 66 20 28 72 65 74 20 3c 20 30 29 20 7b 0a 09 09  f (ret < 0) {...
1820: 64 70 72 69 6e 74 66 28 22 57 65 20 67 6f 74 20  dprintf("We got 
1830: 73 6f 6d 65 20 6b 69 6e 64 20 6f 66 20 49 2f 4f  some kind of I/O
1840: 20 65 72 72 6f 72 22 29 3b 0a 0a 09 09 69 66 20   error");....if 
1850: 28 74 63 6c 45 72 72 6e 6f 20 3d 3d 20 45 41 47  (tclErrno == EAG
1860: 41 49 4e 29 20 7b 0a 09 09 09 64 70 72 69 6e 74  AIN) {....dprint
1870: 66 28 22 49 74 27 73 20 45 41 47 41 49 4e 22 29  f("It's EAGAIN")
1880: 3b 0a 09 09 7d 20 65 6c 73 65 20 7b 0a 09 09 09  ;...} else {....
1890: 64 70 72 69 6e 74 66 28 22 49 74 27 73 20 61 6e  dprintf("It's an
18a0: 20 75 6e 65 70 78 65 63 74 65 64 20 65 72 72 6f   unepxected erro
18b0: 72 3a 20 25 73 2f 25 69 22 2c 20 54 63 6c 5f 45  r: %s/%i", Tcl_E
18c0: 72 72 6e 6f 4d 73 67 28 74 63 6c 45 72 72 6e 6f  rrnoMsg(tclErrno
18d0: 29 2c 20 74 63 6c 45 72 72 6e 6f 29 3b 0a 09 09  ), tclErrno);...
18e0: 7d 0a 09 7d 20 65 6c 73 65 20 7b 0a 09 09 64 70  }..} else {...dp
18f0: 72 69 6e 74 66 28 22 53 75 63 63 65 73 73 66 75  rintf("Successfu
1900: 6c 6c 79 20 72 65 61 64 20 73 6f 6d 65 20 64 61  lly read some da
1910: 74 61 22 29 3b 0a 09 7d 0a 0a 09 69 66 20 28 72  ta");..}...if (r
1920: 65 74 20 21 3d 20 2d 31 20 7c 7c 20 28 72 65 74  et != -1 || (ret
1930: 20 3d 3d 20 2d 31 20 26 26 20 74 63 6c 45 72 72   == -1 && tclErr
1940: 6e 6f 20 3d 3d 20 45 41 47 41 49 4e 29 29 20 7b  no == EAGAIN)) {
1950: 0a 09 09 69 66 20 28 42 49 4f 5f 73 68 6f 75 6c  ...if (BIO_shoul
1960: 64 5f 77 72 69 74 65 28 62 69 6f 29 29 20 7b 0a  d_write(bio)) {.
1970: 09 09 09 64 70 72 69 6e 74 66 28 22 53 65 74 74  ...dprintf("Sett
1980: 69 6e 67 20 73 68 6f 75 6c 64 20 72 65 74 72 79  ing should retry
1990: 20 77 72 69 74 65 20 66 6c 61 67 22 29 3b 0a 0a   write flag");..
19a0: 09 09 09 42 49 4f 5f 73 65 74 5f 72 65 74 72 79  ...BIO_set_retry
19b0: 5f 77 72 69 74 65 28 62 69 6f 29 3b 0a 09 09 7d  _write(bio);...}
19c0: 0a 09 7d 0a 0a 09 64 70 72 69 6e 74 66 28 22 42  ..}...dprintf("B
19d0: 69 6f 52 65 61 64 28 25 70 2c 20 3c 62 75 66 3e  ioRead(%p, <buf>
19e0: 2c 20 25 64 29 20 5b 25 70 5d 20 72 65 74 75 72  , %d) [%p] retur
19f0: 6e 69 6e 67 20 25 69 22 2c 20 28 76 6f 69 64 20  ning %i", (void 
1a00: 2a 29 20 62 69 6f 2c 20 62 75 66 4c 65 6e 2c 20  *) bio, bufLen, 
1a10: 28 76 6f 69 64 20 2a 29 20 63 68 61 6e 2c 20 72  (void *) chan, r
1a20: 65 74 29 3b 0a 0a 09 72 65 74 75 72 6e 28 72 65  et);...return(re
1a30: 74 29 3b 0a 7d 0a 0a 73 74 61 74 69 63 20 69 6e  t);.}..static in
1a40: 74 20 42 69 6f 50 75 74 73 28 42 49 4f 20 2a 62  t BioPuts(BIO *b
1a50: 69 6f 2c 20 43 4f 4e 53 54 20 63 68 61 72 20 2a  io, CONST char *
1a60: 73 74 72 29 20 7b 0a 09 64 70 72 69 6e 74 66 28  str) {..dprintf(
1a70: 22 42 69 6f 50 75 74 73 28 25 70 2c 20 3c 73 74  "BioPuts(%p, <st
1a80: 72 69 6e 67 3a 25 70 3e 29 20 63 61 6c 6c 65 64  ring:%p>) called
1a90: 22 2c 20 62 69 6f 2c 20 73 74 72 29 3b 0a 0a 09  ", bio, str);...
1aa0: 72 65 74 75 72 6e 20 42 69 6f 57 72 69 74 65 28  return BioWrite(
1ab0: 62 69 6f 2c 20 73 74 72 2c 20 28 69 6e 74 29 20  bio, str, (int) 
1ac0: 73 74 72 6c 65 6e 28 73 74 72 29 29 3b 0a 7d 0a  strlen(str));.}.
1ad0: 0a 73 74 61 74 69 63 20 6c 6f 6e 67 20 42 69 6f  .static long Bio
1ae0: 43 74 72 6c 28 42 49 4f 20 2a 62 69 6f 2c 20 69  Ctrl(BIO *bio, i
1af0: 6e 74 20 63 6d 64 2c 20 6c 6f 6e 67 20 6e 75 6d  nt cmd, long num
1b00: 2c 20 76 6f 69 64 20 2a 70 74 72 29 20 7b 0a 09  , void *ptr) {..
1b10: 54 63 6c 5f 43 68 61 6e 6e 65 6c 20 63 68 61 6e  Tcl_Channel chan
1b20: 3b 0a 09 6c 6f 6e 67 20 72 65 74 20 3d 20 31 3b  ;..long ret = 1;
1b30: 0a 0a 09 63 68 61 6e 20 3d 20 54 6c 73 5f 47 65  ...chan = Tls_Ge
1b40: 74 50 61 72 65 6e 74 28 28 53 74 61 74 65 20 2a  tParent((State *
1b50: 29 20 42 49 4f 5f 67 65 74 5f 64 61 74 61 28 62  ) BIO_get_data(b
1b60: 69 6f 29 2c 20 30 29 3b 0a 0a 09 64 70 72 69 6e  io), 0);...dprin
1b70: 74 66 28 22 42 69 6f 43 74 72 6c 28 25 70 2c 20  tf("BioCtrl(%p, 
1b80: 30 78 25 78 2c 20 30 78 25 78 2c 20 25 70 29 22  0x%x, 0x%x, %p)"
1b90: 2c 20 28 76 6f 69 64 20 2a 29 20 62 69 6f 2c 20  , (void *) bio, 
1ba0: 28 75 6e 73 69 67 6e 65 64 20 69 6e 74 29 20 63  (unsigned int) c
1bb0: 6d 64 2c 20 28 75 6e 73 69 67 6e 65 64 20 69 6e  md, (unsigned in
1bc0: 74 29 20 6e 75 6d 2c 20 28 76 6f 69 64 20 2a 29  t) num, (void *)
1bd0: 20 70 74 72 29 3b 0a 0a 09 73 77 69 74 63 68 20   ptr);...switch 
1be0: 28 63 6d 64 29 20 7b 0a 09 09 63 61 73 65 20 42  (cmd) {...case B
1bf0: 49 4f 5f 43 54 52 4c 5f 52 45 53 45 54 3a 0a 09  IO_CTRL_RESET:..
1c00: 09 09 64 70 72 69 6e 74 66 28 22 47 6f 74 20 42  ..dprintf("Got B
1c10: 49 4f 5f 43 54 52 4c 5f 52 45 53 45 54 22 29 3b  IO_CTRL_RESET");
1c20: 0a 09 09 09 6e 75 6d 20 3d 20 30 3b 0a 09 09 63  ....num = 0;...c
1c30: 61 73 65 20 42 49 4f 5f 43 5f 46 49 4c 45 5f 53  ase BIO_C_FILE_S
1c40: 45 45 4b 3a 0a 09 09 09 64 70 72 69 6e 74 66 28  EEK:....dprintf(
1c50: 22 47 6f 74 20 42 49 4f 5f 43 5f 46 49 4c 45 5f  "Got BIO_C_FILE_
1c60: 53 45 45 4b 22 29 3b 0a 09 09 63 61 73 65 20 42  SEEK");...case B
1c70: 49 4f 5f 43 5f 46 49 4c 45 5f 54 45 4c 4c 3a 0a  IO_C_FILE_TELL:.
1c80: 09 09 09 64 70 72 69 6e 74 66 28 22 47 6f 74 20  ...dprintf("Got 
1c90: 42 49 4f 5f 43 5f 46 49 4c 45 5f 54 45 4c 4c 22  BIO_C_FILE_TELL"
1ca0: 29 3b 0a 09 09 09 72 65 74 20 3d 20 30 3b 0a 09  );....ret = 0;..
1cb0: 09 09 62 72 65 61 6b 3b 0a 09 09 63 61 73 65 20  ..break;...case 
1cc0: 42 49 4f 5f 43 54 52 4c 5f 49 4e 46 4f 3a 0a 09  BIO_CTRL_INFO:..
1cd0: 09 09 64 70 72 69 6e 74 66 28 22 47 6f 74 20 42  ..dprintf("Got B
1ce0: 49 4f 5f 43 54 52 4c 5f 49 4e 46 4f 22 29 3b 0a  IO_CTRL_INFO");.
1cf0: 09 09 09 72 65 74 20 3d 20 31 3b 0a 09 09 09 62  ...ret = 1;....b
1d00: 72 65 61 6b 3b 0a 09 09 63 61 73 65 20 42 49 4f  reak;...case BIO
1d10: 5f 43 5f 53 45 54 5f 46 44 3a 0a 09 09 09 64 70  _C_SET_FD:....dp
1d20: 72 69 6e 74 66 28 22 55 6e 73 75 70 70 6f 72 74  rintf("Unsupport
1d30: 65 64 20 63 61 6c 6c 3a 20 42 49 4f 5f 43 5f 53  ed call: BIO_C_S
1d40: 45 54 5f 46 44 22 29 3b 0a 09 09 09 72 65 74 20  ET_FD");....ret 
1d50: 3d 20 2d 31 3b 0a 09 09 09 62 72 65 61 6b 3b 0a  = -1;....break;.
1d60: 09 09 63 61 73 65 20 42 49 4f 5f 43 5f 47 45 54  ..case BIO_C_GET
1d70: 5f 46 44 3a 0a 09 09 09 64 70 72 69 6e 74 66 28  _FD:....dprintf(
1d80: 22 55 6e 73 75 70 70 6f 72 74 65 64 20 63 61 6c  "Unsupported cal
1d90: 6c 3a 20 42 49 4f 5f 43 5f 47 45 54 5f 46 44 22  l: BIO_C_GET_FD"
1da0: 29 3b 0a 09 09 09 72 65 74 20 3d 20 2d 31 3b 0a  );....ret = -1;.
1db0: 09 09 09 62 72 65 61 6b 3b 0a 09 09 63 61 73 65  ...break;...case
1dc0: 20 42 49 4f 5f 43 54 52 4c 5f 47 45 54 5f 43 4c   BIO_CTRL_GET_CL
1dd0: 4f 53 45 3a 0a 09 09 09 64 70 72 69 6e 74 66 28  OSE:....dprintf(
1de0: 22 47 6f 74 20 42 49 4f 5f 43 54 52 4c 5f 43 4c  "Got BIO_CTRL_CL
1df0: 4f 53 45 22 29 3b 0a 09 09 09 72 65 74 20 3d 20  OSE");....ret = 
1e00: 42 49 4f 5f 67 65 74 5f 73 68 75 74 64 6f 77 6e  BIO_get_shutdown
1e10: 28 62 69 6f 29 3b 0a 09 09 09 62 72 65 61 6b 3b  (bio);....break;
1e20: 0a 09 09 63 61 73 65 20 42 49 4f 5f 43 54 52 4c  ...case BIO_CTRL
1e30: 5f 53 45 54 5f 43 4c 4f 53 45 3a 0a 09 09 09 64  _SET_CLOSE:....d
1e40: 70 72 69 6e 74 66 28 22 47 6f 74 20 42 49 4f 5f  printf("Got BIO_
1e50: 53 45 54 5f 43 4c 4f 53 45 22 29 3b 0a 09 09 09  SET_CLOSE");....
1e60: 42 49 4f 5f 73 65 74 5f 73 68 75 74 64 6f 77 6e  BIO_set_shutdown
1e70: 28 62 69 6f 2c 20 6e 75 6d 29 3b 0a 09 09 09 62  (bio, num);....b
1e80: 72 65 61 6b 3b 0a 09 09 63 61 73 65 20 42 49 4f  reak;...case BIO
1e90: 5f 43 54 52 4c 5f 45 4f 46 3a 0a 09 09 09 64 70  _CTRL_EOF:....dp
1ea0: 72 69 6e 74 66 28 22 47 6f 74 20 42 49 4f 5f 43  rintf("Got BIO_C
1eb0: 54 52 4c 5f 45 4f 46 22 29 3b 0a 09 09 09 72 65  TRL_EOF");....re
1ec0: 74 20 3d 20 54 63 6c 5f 45 6f 66 28 63 68 61 6e  t = Tcl_Eof(chan
1ed0: 29 3b 0a 09 09 09 62 72 65 61 6b 3b 0a 09 09 63  );....break;...c
1ee0: 61 73 65 20 42 49 4f 5f 43 54 52 4c 5f 50 45 4e  ase BIO_CTRL_PEN
1ef0: 44 49 4e 47 3a 0a 09 09 09 64 70 72 69 6e 74 66  DING:....dprintf
1f00: 28 22 47 6f 74 20 42 49 4f 5f 43 54 52 4c 5f 50  ("Got BIO_CTRL_P
1f10: 45 4e 44 49 4e 47 22 29 3b 0a 09 09 09 72 65 74  ENDING");....ret
1f20: 20 3d 20 28 28 63 68 61 6e 29 20 3f 20 54 63 6c   = ((chan) ? Tcl
1f30: 5f 49 6e 70 75 74 42 75 66 66 65 72 65 64 28 63  _InputBuffered(c
1f40: 68 61 6e 29 20 3a 20 30 29 3b 0a 09 09 09 64 70  han) : 0);....dp
1f50: 72 69 6e 74 66 28 22 42 49 4f 5f 43 54 52 4c 5f  rintf("BIO_CTRL_
1f60: 50 45 4e 44 49 4e 47 28 25 64 29 22 2c 20 28 69  PENDING(%d)", (i
1f70: 6e 74 29 20 72 65 74 29 3b 0a 09 09 09 62 72 65  nt) ret);....bre
1f80: 61 6b 3b 0a 09 09 63 61 73 65 20 42 49 4f 5f 43  ak;...case BIO_C
1f90: 54 52 4c 5f 57 50 45 4e 44 49 4e 47 3a 0a 09 09  TRL_WPENDING:...
1fa0: 09 64 70 72 69 6e 74 66 28 22 47 6f 74 20 42 49  .dprintf("Got BI
1fb0: 4f 5f 43 54 52 4c 5f 57 50 45 4e 44 49 4e 47 22  O_CTRL_WPENDING"
1fc0: 29 3b 0a 09 09 09 72 65 74 20 3d 20 30 3b 0a 09  );....ret = 0;..
1fd0: 09 09 62 72 65 61 6b 3b 0a 09 09 63 61 73 65 20  ..break;...case 
1fe0: 42 49 4f 5f 43 54 52 4c 5f 44 55 50 3a 0a 09 09  BIO_CTRL_DUP:...
1ff0: 09 64 70 72 69 6e 74 66 28 22 47 6f 74 20 42 49  .dprintf("Got BI
2000: 4f 5f 43 54 52 4c 5f 44 55 50 22 29 3b 0a 09 09  O_CTRL_DUP");...
2010: 09 62 72 65 61 6b 3b 0a 09 09 63 61 73 65 20 42  .break;...case B
2020: 49 4f 5f 43 54 52 4c 5f 46 4c 55 53 48 3a 0a 09  IO_CTRL_FLUSH:..
2030: 09 09 64 70 72 69 6e 74 66 28 22 47 6f 74 20 42  ..dprintf("Got B
2040: 49 4f 5f 43 54 52 4c 5f 46 4c 55 53 48 22 29 3b  IO_CTRL_FLUSH");
2050: 0a 09 09 09 72 65 74 20 3d 20 28 28 54 63 6c 5f  ....ret = ((Tcl_
2060: 57 72 69 74 65 52 61 77 28 63 68 61 6e 2c 20 22  WriteRaw(chan, "
2070: 22 2c 20 30 29 20 3e 3d 20 30 29 20 3f 20 31 20  ", 0) >= 0) ? 1 
2080: 3a 20 2d 31 29 3b 0a 09 09 09 64 70 72 69 6e 74  : -1);....dprint
2090: 66 28 22 42 49 4f 5f 43 54 52 4c 5f 46 4c 55 53  f("BIO_CTRL_FLUS
20a0: 48 20 72 65 74 75 72 6e 69 6e 67 20 76 61 6c 75  H returning valu
20b0: 65 20 25 6c 69 22 2c 20 72 65 74 29 3b 0a 09 09  e %li", ret);...
20c0: 09 62 72 65 61 6b 3b 0a 09 09 64 65 66 61 75 6c  .break;...defaul
20d0: 74 3a 0a 09 09 09 64 70 72 69 6e 74 66 28 22 47  t:....dprintf("G
20e0: 6f 74 20 75 6e 6b 6e 6f 77 6e 20 63 6f 6e 74 72  ot unknown contr
20f0: 6f 6c 20 63 6f 6d 6d 61 6e 64 20 28 25 69 29 22  ol command (%i)"
2100: 2c 20 63 6d 64 29 3b 0a 09 09 09 72 65 74 20 3d  , cmd);....ret =
2110: 20 2d 32 3b 0a 09 09 09 62 72 65 61 6b 3b 0a 09   -2;....break;..
2120: 7d 0a 0a 09 72 65 74 75 72 6e 28 72 65 74 29 3b  }...return(ret);
2130: 0a 7d 0a 0a 73 74 61 74 69 63 20 69 6e 74 20 42  .}..static int B
2140: 69 6f 4e 65 77 28 42 49 4f 20 2a 62 69 6f 29 20  ioNew(BIO *bio) 
2150: 7b 0a 09 64 70 72 69 6e 74 66 28 22 42 69 6f 4e  {..dprintf("BioN
2160: 65 77 28 25 70 29 20 63 61 6c 6c 65 64 22 2c 20  ew(%p) called", 
2170: 62 69 6f 29 3b 0a 0a 09 42 49 4f 5f 73 65 74 5f  bio);...BIO_set_
2180: 69 6e 69 74 28 62 69 6f 2c 20 30 29 3b 0a 09 42  init(bio, 0);..B
2190: 49 4f 5f 73 65 74 5f 64 61 74 61 28 62 69 6f 2c  IO_set_data(bio,
21a0: 20 4e 55 4c 4c 29 3b 0a 09 42 49 4f 5f 63 6c 65   NULL);..BIO_cle
21b0: 61 72 5f 66 6c 61 67 73 28 62 69 6f 2c 20 2d 31  ar_flags(bio, -1
21c0: 29 3b 0a 0a 09 72 65 74 75 72 6e 28 31 29 3b 0a  );...return(1);.
21d0: 7d 0a 0a 73 74 61 74 69 63 20 69 6e 74 20 42 69  }..static int Bi
21e0: 6f 46 72 65 65 28 42 49 4f 20 2a 62 69 6f 29 20  oFree(BIO *bio) 
21f0: 7b 0a 09 69 66 20 28 62 69 6f 20 3d 3d 20 4e 55  {..if (bio == NU
2200: 4c 4c 29 20 7b 0a 09 09 72 65 74 75 72 6e 28 30  LL) {...return(0
2210: 29 3b 0a 09 7d 0a 0a 09 64 70 72 69 6e 74 66 28  );..}...dprintf(
2220: 22 42 69 6f 46 72 65 65 28 25 70 29 20 63 61 6c  "BioFree(%p) cal
2230: 6c 65 64 22 2c 20 62 69 6f 29 3b 0a 0a 09 69 66  led", bio);...if
2240: 20 28 42 49 4f 5f 67 65 74 5f 73 68 75 74 64 6f   (BIO_get_shutdo
2250: 77 6e 28 62 69 6f 29 29 20 7b 0a 09 09 69 66 20  wn(bio)) {...if 
2260: 28 42 49 4f 5f 67 65 74 5f 69 6e 69 74 28 62 69  (BIO_get_init(bi
2270: 6f 29 29 20 7b 0a 09 09 09 2f 2a 73 68 75 74 64  o)) {..../*shutd
2280: 6f 77 6e 28 62 69 6f 2d 3e 6e 75 6d 2c 20 32 29  own(bio->num, 2)
2290: 20 2a 2f 0a 09 09 09 2f 2a 63 6c 6f 73 65 73 6f   */..../*closeso
22a0: 63 6b 65 74 28 62 69 6f 2d 3e 6e 75 6d 29 20 2a  cket(bio->num) *
22b0: 2f 0a 09 09 7d 0a 0a 09 09 42 49 4f 5f 73 65 74  /...}....BIO_set
22c0: 5f 69 6e 69 74 28 62 69 6f 2c 20 30 29 3b 0a 09  _init(bio, 0);..
22d0: 09 42 49 4f 5f 63 6c 65 61 72 5f 66 6c 61 67 73  .BIO_clear_flags
22e0: 28 62 69 6f 2c 20 2d 31 29 3b 0a 09 7d 0a 0a 09  (bio, -1);..}...
22f0: 72 65 74 75 72 6e 28 31 29 3b 0a 7d 0a           return(1);.}.