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);.}.