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: 20 43 6f 70 79 72 69 67 68 74 20 28 43 29 20 32 Copyright (C) 2
0050: 30 30 30 20 41 6a 75 62 61 20 53 6f 6c 75 74 69 000 Ajuba Soluti
0060: 6f 6e 73 0a 20 2a 0a 20 2a 20 54 4c 53 20 28 61 ons. *. * TLS (a
0070: 6b 61 20 53 53 4c 29 20 43 68 61 6e 6e 65 6c 20 ka SSL) Channel
0080: 2d 20 63 61 6e 20 62 65 20 6c 61 79 65 72 65 64 - can be layered
0090: 20 6f 6e 20 61 6e 79 20 62 69 2d 64 69 72 65 63 on any bi-direc
00a0: 74 69 6f 6e 61 6c 0a 20 2a 20 54 63 6c 5f 43 68 tional. * Tcl_Ch
00b0: 61 6e 6e 65 6c 20 28 4e 6f 74 65 3a 20 52 65 71 annel (Note: Req
00c0: 75 69 72 65 73 20 54 72 66 20 43 6f 72 65 20 50 uires Trf Core P
00d0: 61 74 63 68 29 0a 20 2a 0a 20 2a 20 54 68 69 73 atch). *. * This
00e0: 20 77 61 73 20 62 75 69 6c 74 20 66 72 6f 6d 20 was built from
00f0: 73 63 72 61 74 63 68 20 62 61 73 65 64 20 75 70 scratch based up
0100: 6f 6e 20 6f 62 73 65 72 76 61 74 69 6f 6e 20 6f on observation o
0110: 66 20 4f 70 65 6e 53 53 4c 20 30 2e 39 2e 32 42 f OpenSSL 0.9.2B
0120: 0a 20 2a 0a 20 2a 20 41 64 64 69 74 69 6f 6e 20 . *. * Addition
0130: 63 72 65 64 69 74 20 69 73 20 64 75 65 20 66 6f credit is due fo
0140: 72 20 41 6e 64 72 65 61 73 20 4b 75 70 72 69 65 r Andreas Kuprie
0150: 73 20 28 61 2e 6b 75 70 72 69 65 73 40 77 65 73 s (a.kupries@wes
0160: 74 65 6e 64 2e 63 6f 6d 29 2c 20 66 6f 72 0a 20 tend.com), for.
0170: 2a 20 70 72 6f 76 69 64 69 6e 67 20 74 68 65 20 * providing the
0180: 54 63 6c 5f 52 65 70 6c 61 63 65 43 68 61 6e 6e Tcl_ReplaceChann
0190: 65 6c 20 6d 65 63 68 61 6e 69 73 6d 20 61 6e 64 el mechanism and
01a0: 20 77 6f 72 6b 69 6e 67 20 63 6c 6f 73 65 6c 79 working closely
01b0: 20 77 69 74 68 20 6d 65 0a 20 2a 20 74 6f 20 65 with me. * to e
01c0: 6e 68 61 6e 63 65 20 69 74 20 74 6f 20 73 75 70 nhance it to sup
01d0: 70 6f 72 74 20 66 75 6c 6c 20 66 69 6c 65 65 76 port full fileev
01e0: 65 6e 74 20 73 65 6d 61 6e 74 69 63 73 2e 0a 20 ent semantics..
01f0: 2a 0a 20 2a 20 41 6c 73 6f 20 77 6f 72 6b 20 64 *. * Also work d
0200: 6f 6e 65 20 62 79 20 74 68 65 20 66 6f 6c 6c 6f one by the follo
0210: 77 20 70 65 6f 70 6c 65 20 70 72 6f 76 69 64 65 w people provide
0220: 64 20 74 68 65 20 69 6d 70 65 74 75 73 20 74 6f d the impetus to
0230: 20 64 6f 20 74 68 69 73 20 22 72 69 67 68 74 22 do this "right"
0240: 3a 0a 20 2a 09 74 63 6c 53 53 4c 20 28 43 6f 6c :. *.tclSSL (Col
0250: 69 6e 20 4d 63 43 6f 72 6d 61 63 6b 2c 20 53 68 in McCormack, Sh
0260: 61 72 65 64 20 54 65 63 68 6e 6f 6c 6f 67 79 29 ared Technology)
0270: 0a 20 2a 09 53 53 4c 74 63 6c 20 28 50 65 74 65 . *.SSLtcl (Pete
0280: 72 20 41 6e 74 6d 61 6e 29 0a 20 2a 0a 20 2a 2f r Antman). *. */
0290: 0a 0a 23 69 6e 63 6c 75 64 65 20 22 74 6c 73 49 ..#include "tlsI
02a0: 6e 74 2e 68 22 0a 0a 2f 2a 0a 20 2a 20 46 6f 72 nt.h"../*. * For
02b0: 77 61 72 64 20 64 65 63 6c 61 72 61 74 69 6f 6e ward declaration
02c0: 73 0a 20 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 s. */.static int
02d0: 20 20 54 6c 73 42 6c 6f 63 6b 4d 6f 64 65 50 72 TlsBlockModePr
02e0: 6f 63 20 28 76 6f 69 64 20 2a 69 6e 73 74 61 6e oc (void *instan
02f0: 63 65 44 61 74 61 2c 20 69 6e 74 20 6d 6f 64 65 ceData, int mode
0300: 29 3b 0a 73 74 61 74 69 63 20 69 6e 74 20 20 54 );.static int T
0310: 6c 73 43 6c 6f 73 65 50 72 6f 63 20 28 76 6f 69 lsCloseProc (voi
0320: 64 20 2a 69 6e 73 74 61 6e 63 65 44 61 74 61 2c d *instanceData,
0330: 20 54 63 6c 5f 49 6e 74 65 72 70 20 2a 69 6e 74 Tcl_Interp *int
0340: 65 72 70 29 3b 0a 73 74 61 74 69 63 20 69 6e 74 erp);.static int
0350: 20 20 54 6c 73 43 6c 6f 73 65 32 50 72 6f 63 20 TlsClose2Proc
0360: 28 76 6f 69 64 20 2a 69 6e 73 74 61 6e 63 65 44 (void *instanceD
0370: 61 74 61 2c 20 54 63 6c 5f 49 6e 74 65 72 70 20 ata, Tcl_Interp
0380: 2a 69 6e 74 65 72 70 2c 20 69 6e 74 20 66 6c 61 *interp, int fla
0390: 67 73 29 3b 0a 73 74 61 74 69 63 20 69 6e 74 20 gs);.static int
03a0: 20 54 6c 73 49 6e 70 75 74 50 72 6f 63 20 28 76 TlsInputProc (v
03b0: 6f 69 64 20 2a 69 6e 73 74 61 6e 63 65 44 61 74 oid *instanceDat
03c0: 61 2c 20 63 68 61 72 20 2a 62 75 66 2c 20 69 6e a, char *buf, in
03d0: 74 20 62 75 66 53 69 7a 65 2c 20 69 6e 74 20 2a t bufSize, int *
03e0: 65 72 72 6f 72 43 6f 64 65 50 74 72 29 3b 0a 73 errorCodePtr);.s
03f0: 74 61 74 69 63 20 69 6e 74 20 20 54 6c 73 4f 75 tatic int TlsOu
0400: 74 70 75 74 50 72 6f 63 20 28 76 6f 69 64 20 2a tputProc (void *
0410: 69 6e 73 74 61 6e 63 65 44 61 74 61 2c 20 63 6f instanceData, co
0420: 6e 73 74 20 63 68 61 72 20 2a 62 75 66 2c 20 69 nst char *buf, i
0430: 6e 74 20 74 6f 57 72 69 74 65 2c 20 69 6e 74 20 nt toWrite, int
0440: 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 29 3b 0a *errorCodePtr);.
0450: 73 74 61 74 69 63 20 69 6e 74 20 20 54 6c 73 47 static int TlsG
0460: 65 74 4f 70 74 69 6f 6e 50 72 6f 63 20 28 76 6f etOptionProc (vo
0470: 69 64 20 2a 69 6e 73 74 61 6e 63 65 44 61 74 61 id *instanceData
0480: 2c 20 54 63 6c 5f 49 6e 74 65 72 70 20 2a 69 6e , Tcl_Interp *in
0490: 74 65 72 70 2c 20 63 6f 6e 73 74 20 63 68 61 72 terp, const char
04a0: 20 2a 6f 70 74 69 6f 6e 4e 61 6d 65 2c 20 54 63 *optionName, Tc
04b0: 6c 5f 44 53 74 72 69 6e 67 20 2a 64 73 50 74 72 l_DString *dsPtr
04c0: 29 3b 0a 73 74 61 74 69 63 20 76 6f 69 64 20 54 );.static void T
04d0: 6c 73 57 61 74 63 68 50 72 6f 63 20 28 76 6f 69 lsWatchProc (voi
04e0: 64 20 2a 69 6e 73 74 61 6e 63 65 44 61 74 61 2c d *instanceData,
04f0: 20 69 6e 74 20 6d 61 73 6b 29 3b 0a 73 74 61 74 int mask);.stat
0500: 69 63 20 69 6e 74 20 20 54 6c 73 47 65 74 48 61 ic int TlsGetHa
0510: 6e 64 6c 65 50 72 6f 63 20 28 76 6f 69 64 20 2a ndleProc (void *
0520: 69 6e 73 74 61 6e 63 65 44 61 74 61 2c 20 69 6e instanceData, in
0530: 74 20 64 69 72 65 63 74 69 6f 6e 2c 20 76 6f 69 t direction, voi
0540: 64 20 2a 2a 68 61 6e 64 6c 65 50 74 72 29 3b 0a d **handlePtr);.
0550: 73 74 61 74 69 63 20 69 6e 74 20 20 54 6c 73 4e static int TlsN
0560: 6f 74 69 66 79 50 72 6f 63 20 28 76 6f 69 64 20 otifyProc (void
0570: 2a 69 6e 73 74 61 6e 63 65 44 61 74 61 2c 20 69 *instanceData, i
0580: 6e 74 20 6d 61 73 6b 29 3b 0a 73 74 61 74 69 63 nt mask);.static
0590: 20 76 6f 69 64 20 54 6c 73 43 68 61 6e 6e 65 6c void TlsChannel
05a0: 48 61 6e 64 6c 65 72 54 69 6d 65 72 20 28 76 6f HandlerTimer (vo
05b0: 69 64 20 2a 63 6c 69 65 6e 74 44 61 74 61 29 3b id *clientData);
05c0: 0a 0a 2f 2a 0a 20 2a 20 54 4c 53 20 43 68 61 6e ../*. * TLS Chan
05d0: 6e 65 6c 20 54 79 70 65 0a 20 2a 2f 0a 73 74 61 nel Type. */.sta
05e0: 74 69 63 20 63 6f 6e 73 74 20 54 63 6c 5f 43 68 tic const Tcl_Ch
05f0: 61 6e 6e 65 6c 54 79 70 65 20 74 6c 73 43 68 61 annelType tlsCha
0600: 6e 6e 65 6c 54 79 70 65 20 3d 20 7b 0a 20 20 22 nnelType = {. "
0610: 74 6c 73 22 2c 20 20 20 20 20 20 20 20 20 20 20 tls",
0620: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0630: 20 20 2f 2a 20 74 79 70 65 4e 61 6d 65 20 20 20 /* typeName
0640: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0650: 20 20 20 20 20 20 20 20 20 20 2a 2f 0a 20 20 54 */. T
0660: 43 4c 5f 43 48 41 4e 4e 45 4c 5f 56 45 52 53 49 CL_CHANNEL_VERSI
0670: 4f 4e 5f 35 2c 20 20 20 20 20 20 20 20 20 20 20 ON_5,
0680: 20 20 2f 2a 20 76 65 72 73 69 6f 6e 20 20 20 20 /* version
0690: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
06a0: 20 20 20 20 20 20 20 20 20 20 2a 2f 0a 20 20 54 */. T
06b0: 6c 73 43 6c 6f 73 65 50 72 6f 63 2c 20 20 20 20 lsCloseProc,
06c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
06d0: 20 20 2f 2a 20 63 6c 6f 73 65 50 72 6f 63 20 20 /* closeProc
06e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
06f0: 20 20 20 20 20 20 20 20 20 20 2a 2f 0a 20 20 54 */. T
0700: 6c 73 49 6e 70 75 74 50 72 6f 63 2c 20 20 20 20 lsInputProc,
0710: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0720: 20 20 2f 2a 20 69 6e 70 75 74 50 72 6f 63 20 20 /* inputProc
0730: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0740: 20 20 20 20 20 20 20 20 20 20 2a 2f 0a 20 20 54 */. T
0750: 6c 73 4f 75 74 70 75 74 50 72 6f 63 2c 20 20 20 lsOutputProc,
0760: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0770: 20 20 2f 2a 20 6f 75 74 70 75 74 50 72 6f 63 20 /* outputProc
0780: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0790: 20 20 20 20 20 20 20 20 20 20 2a 2f 0a 20 20 30 */. 0
07a0: 2c 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 ,
07b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
07c0: 20 20 2f 2a 20 73 65 65 6b 50 72 6f 63 20 20 20 /* seekProc
07d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
07e0: 20 20 20 20 20 20 20 20 20 20 2a 2f 0a 20 20 30 */. 0
07f0: 2c 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 ,
0800: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0810: 20 20 2f 2a 20 73 65 74 4f 70 74 69 6f 6e 50 72 /* setOptionPr
0820: 6f 63 20 20 20 20 20 20 20 20 20 20 20 20 20 20 oc
0830: 20 20 20 20 20 20 20 20 20 20 2a 2f 0a 20 20 54 */. T
0840: 6c 73 47 65 74 4f 70 74 69 6f 6e 50 72 6f 63 2c lsGetOptionProc,
0850: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0860: 20 20 2f 2a 20 67 65 74 4f 70 74 69 6f 6e 50 72 /* getOptionPr
0870: 6f 63 20 20 20 20 20 20 20 20 20 20 20 20 20 20 oc
0880: 20 20 20 20 20 20 20 20 20 20 2a 2f 0a 20 20 54 */. T
0890: 6c 73 57 61 74 63 68 50 72 6f 63 2c 20 20 20 20 lsWatchProc,
08a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
08b0: 20 20 2f 2a 20 77 61 74 63 68 50 72 6f 63 20 20 /* watchProc
08c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
08d0: 20 20 20 20 20 20 20 20 20 20 2a 2f 0a 20 20 54 */. T
08e0: 6c 73 47 65 74 48 61 6e 64 6c 65 50 72 6f 63 2c lsGetHandleProc,
08f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0900: 20 20 2f 2a 20 67 65 74 48 61 6e 64 6c 65 50 72 /* getHandlePr
0910: 6f 63 20 20 20 20 20 20 20 20 20 20 20 20 20 20 oc
0920: 20 20 20 20 20 20 20 20 20 20 2a 2f 0a 20 20 54 */. T
0930: 6c 73 43 6c 6f 73 65 32 50 72 6f 63 2c 20 20 20 lsClose2Proc,
0940: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0950: 20 20 2f 2a 20 63 6c 6f 73 65 32 50 72 6f 63 20 /* close2Proc
0960: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0970: 20 20 20 20 20 20 20 20 20 20 2a 2f 0a 20 20 54 */. T
0980: 6c 73 42 6c 6f 63 6b 4d 6f 64 65 50 72 6f 63 2c lsBlockModeProc,
0990: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
09a0: 20 20 2f 2a 20 62 6c 6f 63 6b 4d 6f 64 65 50 72 /* blockModePr
09b0: 6f 63 20 20 20 20 20 20 20 20 20 20 20 20 20 20 oc
09c0: 20 20 20 20 20 20 20 20 20 20 2a 2f 0a 20 20 30 */. 0
09d0: 2c 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 ,
09e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
09f0: 20 20 2f 2a 20 66 6c 75 73 68 50 72 6f 63 20 20 /* flushProc
0a00: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0a10: 20 20 20 20 20 20 20 20 20 20 2a 2f 0a 20 20 54 */. T
0a20: 6c 73 4e 6f 74 69 66 79 50 72 6f 63 2c 20 20 20 lsNotifyProc,
0a30: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0a40: 20 20 2f 2a 20 68 61 6e 64 6c 65 72 50 72 6f 63 /* handlerProc
0a50: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0a60: 20 20 20 20 20 20 20 20 20 20 2a 2f 0a 20 20 30 */. 0
0a70: 2c 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 ,
0a80: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0a90: 20 20 2f 2a 20 77 69 64 65 53 65 65 6b 50 72 6f /* wideSeekPro
0aa0: 63 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 c
0ab0: 20 20 20 20 20 20 20 20 20 20 2a 2f 0a 20 20 30 */. 0
0ac0: 2c 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 ,
0ad0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0ae0: 20 20 2f 2a 20 74 68 72 65 61 64 41 63 74 69 6f /* threadActio
0af0: 6e 50 72 6f 63 20 20 20 20 20 20 20 20 20 20 20 nProc
0b00: 20 20 20 20 20 20 20 20 20 20 2a 2f 0a 20 20 30 */. 0
0b10: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0b20: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0b30: 20 20 2f 2a 20 74 72 75 6e 63 61 74 65 50 72 6f /* truncatePro
0b40: 63 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 c
0b50: 20 20 20 20 20 20 20 20 20 20 2a 2f 0a 7d 3b 0a */.};.
0b60: 0a 0a 2f 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d ../*. *---------
0b70: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
0b80: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
0b90: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
0ba0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 0a 20 2a ----------. *. *
0bb0: 20 54 6c 73 5f 43 68 61 6e 6e 65 6c 54 79 70 65 Tls_ChannelType
0bc0: 20 2d 2d 0a 20 2a 0a 20 2a 09 52 65 74 75 72 6e --. *. *.Return
0bd0: 20 74 68 65 20 63 6f 72 72 65 63 74 20 54 4c 53 the correct TLS
0be0: 20 63 68 61 6e 6e 65 6c 20 64 72 69 76 65 72 20 channel driver
0bf0: 69 6e 66 6f 0a 20 2a 0a 20 2a 20 52 65 73 75 6c info. *. * Resul
0c00: 74 73 3a 0a 20 2a 09 54 68 65 20 63 6f 72 72 65 ts:. *.The corre
0c10: 63 74 20 63 68 61 6e 6e 65 6c 20 64 72 69 76 65 ct channel drive
0c20: 72 20 66 6f 72 20 74 68 65 20 63 75 72 72 65 6e r for the curren
0c30: 74 20 76 65 72 73 69 6f 6e 20 6f 66 20 54 63 6c t version of Tcl
0c40: 2e 0a 20 2a 0a 20 2a 20 53 69 64 65 20 65 66 66 .. *. * Side eff
0c50: 65 63 74 73 3a 0a 20 2a 09 4e 6f 6e 65 2e 0a 20 ects:. *.None..
0c60: 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d *. *------------
0c70: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
0c80: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
0c90: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
0ca0: 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 2f 0a 63 6f 6e 73 -------. */.cons
0cb0: 74 20 54 63 6c 5f 43 68 61 6e 6e 65 6c 54 79 70 t Tcl_ChannelTyp
0cc0: 65 20 2a 54 6c 73 5f 43 68 61 6e 6e 65 6c 54 79 e *Tls_ChannelTy
0cd0: 70 65 28 76 6f 69 64 29 20 7b 0a 09 72 65 74 75 pe(void) {..retu
0ce0: 72 6e 20 26 74 6c 73 43 68 61 6e 6e 65 6c 54 79 rn &tlsChannelTy
0cf0: 70 65 3b 0a 7d 0a 0a 2f 2a 0a 20 2a 2d 2d 2d 2d pe;.}../*. *----
0d00: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
0d10: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
0d20: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
0d30: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a ---------------.
0d40: 20 2a 0a 20 2a 20 54 6c 73 42 6c 6f 63 6b 4d 6f *. * TlsBlockMo
0d50: 64 65 50 72 6f 63 20 2d 2d 0a 20 2a 0a 20 2a 09 deProc --. *. *.
0d60: 54 68 69 73 20 70 72 6f 63 65 64 75 72 65 20 69 This procedure i
0d70: 73 20 69 6e 76 6f 6b 65 64 20 62 79 20 74 68 65 s invoked by the
0d80: 20 67 65 6e 65 72 69 63 20 49 4f 20 6c 65 76 65 generic IO leve
0d90: 6c 0a 20 2a 20 20 20 20 20 20 20 74 6f 20 73 65 l. * to se
0da0: 74 20 62 6c 6f 63 6b 69 6e 67 20 61 6e 64 20 6e t blocking and n
0db0: 6f 6e 62 6c 6f 63 6b 69 6e 67 20 6d 6f 64 65 73 onblocking modes
0dc0: 0a 20 2a 20 52 65 73 75 6c 74 73 3a 0a 20 2a 09 . * Results:. *.
0dd0: 30 20 69 66 20 73 75 63 63 65 73 73 66 75 6c 2c 0 if successful,
0de0: 20 65 72 72 6e 6f 20 77 68 65 6e 20 66 61 69 6c errno when fail
0df0: 65 64 2e 0a 20 2a 0a 20 2a 20 53 69 64 65 20 65 ed.. *. * Side e
0e00: 66 66 65 63 74 73 3a 0a 20 2a 09 53 65 74 73 20 ffects:. *.Sets
0e10: 74 68 65 20 64 65 76 69 63 65 20 69 6e 74 6f 20 the device into
0e20: 62 6c 6f 63 6b 69 6e 67 20 6f 72 20 6e 6f 6e 62 blocking or nonb
0e30: 6c 6f 63 6b 69 6e 67 20 6d 6f 64 65 2e 0a 20 2a locking mode.. *
0e40: 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d . *-------------
0e50: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
0e60: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
0e70: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
0e80: 2d 2d 2d 2d 2d 2d 0a 20 2a 2f 0a 73 74 61 74 69 ------. */.stati
0e90: 63 20 69 6e 74 20 54 6c 73 42 6c 6f 63 6b 4d 6f c int TlsBlockMo
0ea0: 64 65 50 72 6f 63 28 76 6f 69 64 20 2a 69 6e 73 deProc(void *ins
0eb0: 74 61 6e 63 65 44 61 74 61 2c 20 69 6e 74 20 6d tanceData, int m
0ec0: 6f 64 65 29 20 7b 0a 09 53 74 61 74 65 20 2a 73 ode) {..State *s
0ed0: 74 61 74 65 50 74 72 20 3d 20 28 53 74 61 74 65 tatePtr = (State
0ee0: 20 2a 29 20 69 6e 73 74 61 6e 63 65 44 61 74 61 *) instanceData
0ef0: 3b 0a 0a 09 69 66 20 28 6d 6f 64 65 20 3d 3d 20 ;...if (mode ==
0f00: 54 43 4c 5f 4d 4f 44 45 5f 4e 4f 4e 42 4c 4f 43 TCL_MODE_NONBLOC
0f10: 4b 49 4e 47 29 20 7b 0a 09 09 73 74 61 74 65 50 KING) {...stateP
0f20: 74 72 2d 3e 66 6c 61 67 73 20 7c 3d 20 54 4c 53 tr->flags |= TLS
0f30: 5f 54 43 4c 5f 41 53 59 4e 43 3b 0a 09 7d 20 65 _TCL_ASYNC;..} e
0f40: 6c 73 65 20 7b 0a 09 09 73 74 61 74 65 50 74 72 lse {...statePtr
0f50: 2d 3e 66 6c 61 67 73 20 26 3d 20 7e 28 54 4c 53 ->flags &= ~(TLS
0f60: 5f 54 43 4c 5f 41 53 59 4e 43 29 3b 0a 09 7d 0a _TCL_ASYNC);..}.
0f70: 0a 09 72 65 74 75 72 6e 28 30 29 3b 0a 7d 0a 0a ..return(0);.}..
0f80: 2f 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d /*. *-----------
0f90: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
0fa0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
0fb0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
0fc0: 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 0a 20 2a 20 54 --------. *. * T
0fd0: 6c 73 43 6c 6f 73 65 50 72 6f 63 20 2d 2d 0a 20 lsCloseProc --.
0fe0: 2a 0a 20 2a 09 54 68 69 73 20 70 72 6f 63 65 64 *. *.This proced
0ff0: 75 72 65 20 69 73 20 69 6e 76 6f 6b 65 64 20 62 ure is invoked b
1000: 79 20 74 68 65 20 67 65 6e 65 72 69 63 20 49 4f y the generic IO
1010: 20 6c 65 76 65 6c 20 74 6f 20 70 65 72 66 6f 72 level to perfor
1020: 6d 0a 20 2a 09 63 68 61 6e 6e 65 6c 2d 74 79 70 m. *.channel-typ
1030: 65 2d 73 70 65 63 69 66 69 63 20 63 6c 65 61 6e e-specific clean
1040: 75 70 20 77 68 65 6e 20 61 20 53 53 4c 20 73 6f up when a SSL so
1050: 63 6b 65 74 20 62 61 73 65 64 20 63 68 61 6e 6e cket based chann
1060: 65 6c 0a 20 2a 09 69 73 20 63 6c 6f 73 65 64 2e el. *.is closed.
1070: 0a 20 2a 0a 20 2a 09 4e 6f 74 65 3a 20 77 65 20 . *. *.Note: we
1080: 6c 65 61 76 65 20 74 68 65 20 75 6e 64 65 72 6c leave the underl
1090: 79 69 6e 67 20 73 6f 63 6b 65 74 20 61 6c 6f 6e ying socket alon
10a0: 65 2c 20 69 73 20 74 68 69 73 20 72 69 67 68 74 e, is this right
10b0: 3f 0a 20 2a 0a 20 2a 20 52 65 73 75 6c 74 73 3a ?. *. * Results:
10c0: 0a 20 2a 09 30 20 69 66 20 73 75 63 63 65 73 73 . *.0 if success
10d0: 66 75 6c 2c 20 74 68 65 20 76 61 6c 75 65 20 6f ful, the value o
10e0: 66 20 54 63 6c 5f 47 65 74 45 72 72 6e 6f 28 29 f Tcl_GetErrno()
10f0: 20 69 66 20 66 61 69 6c 65 64 2e 0a 20 2a 0a 20 if failed.. *.
1100: 2a 20 53 69 64 65 20 65 66 66 65 63 74 73 3a 0a * Side effects:.
1110: 20 2a 09 43 6c 6f 73 65 73 20 74 68 65 20 73 6f *.Closes the so
1120: 63 6b 65 74 20 6f 66 20 74 68 65 20 63 68 61 6e cket of the chan
1130: 6e 65 6c 2e 0a 20 2a 0a 20 2a 2d 2d 2d 2d 2d 2d nel.. *. *------
1140: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
1150: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
1160: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
1170: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a -------------. *
1180: 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 54 6c 73 /.static int Tls
1190: 43 6c 6f 73 65 50 72 6f 63 28 76 6f 69 64 20 2a CloseProc(void *
11a0: 69 6e 73 74 61 6e 63 65 44 61 74 61 2c 20 54 43 instanceData, TC
11b0: 4c 5f 55 4e 55 53 45 44 28 54 63 6c 5f 49 6e 74 L_UNUSED(Tcl_Int
11c0: 65 72 70 20 2a 29 29 20 7b 0a 09 53 74 61 74 65 erp *)) {..State
11d0: 20 2a 73 74 61 74 65 50 74 72 20 3d 20 28 53 74 *statePtr = (St
11e0: 61 74 65 20 2a 29 20 69 6e 73 74 61 6e 63 65 44 ate *) instanceD
11f0: 61 74 61 3b 0a 0a 09 64 70 72 69 6e 74 66 28 22 ata;...dprintf("
1200: 54 6c 73 43 6c 6f 73 65 50 72 6f 63 28 25 70 29 TlsCloseProc(%p)
1210: 22 2c 20 73 74 61 74 65 50 74 72 29 3b 0a 0a 09 ", statePtr);...
1220: 54 6c 73 5f 43 6c 65 61 6e 28 73 74 61 74 65 50 Tls_Clean(stateP
1230: 74 72 29 3b 0a 09 54 63 6c 5f 45 76 65 6e 74 75 tr);..Tcl_Eventu
1240: 61 6c 6c 79 46 72 65 65 28 73 74 61 74 65 50 74 allyFree(statePt
1250: 72 2c 20 54 6c 73 5f 46 72 65 65 29 3b 0a 0a 09 r, Tls_Free);...
1260: 64 70 72 69 6e 74 66 28 22 52 65 74 75 72 6e 69 dprintf("Returni
1270: 6e 67 20 54 43 4c 5f 4f 4b 22 29 3b 0a 0a 09 72 ng TCL_OK");...r
1280: 65 74 75 72 6e 28 54 43 4c 5f 4f 4b 29 3b 0a 7d eturn(TCL_OK);.}
1290: 0a 0a 73 74 61 74 69 63 20 69 6e 74 20 54 6c 73 ..static int Tls
12a0: 43 6c 6f 73 65 32 50 72 6f 63 28 76 6f 69 64 20 Close2Proc(void
12b0: 2a 69 6e 73 74 61 6e 63 65 44 61 74 61 2c 20 54 *instanceData, T
12c0: 63 6c 5f 49 6e 74 65 72 70 20 2a 69 6e 74 65 72 cl_Interp *inter
12d0: 70 2c 20 69 6e 74 20 66 6c 61 67 73 29 20 7b 0a p, int flags) {.
12e0: 09 69 66 20 28 21 28 66 6c 61 67 73 26 28 54 43 .if (!(flags&(TC
12f0: 4c 5f 43 4c 4f 53 45 5f 52 45 41 44 7c 54 43 4c L_CLOSE_READ|TCL
1300: 5f 43 4c 4f 53 45 5f 57 52 49 54 45 29 29 29 20 _CLOSE_WRITE)))
1310: 7b 0a 09 20 20 20 20 72 65 74 75 72 6e 20 54 6c {.. return Tl
1320: 73 43 6c 6f 73 65 50 72 6f 63 28 69 6e 73 74 61 sCloseProc(insta
1330: 6e 63 65 44 61 74 61 2c 20 69 6e 74 65 72 70 29 nceData, interp)
1340: 3b 0a 09 7d 0a 09 72 65 74 75 72 6e 20 45 49 4e ;..}..return EIN
1350: 56 41 4c 3b 0a 7d 0a 0a 2f 2a 0a 20 2a 2d 2d 2d VAL;.}../*. *---
1360: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
1370: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
1380: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
1390: 2d 2d 2d 2a 0a 20 2a 0a 20 2a 09 54 6c 73 5f 57 ---*. *. *.Tls_W
13a0: 61 69 74 46 6f 72 43 6f 6e 6e 65 63 74 20 2d 2d aitForConnect --
13b0: 0a 20 2a 0a 20 2a 09 53 69 64 65 65 66 66 65 63 . *. *.Sideeffec
13c0: 74 73 3a 0a 20 2a 09 09 49 73 73 75 65 73 20 53 ts:. *..Issues S
13d0: 53 4c 5f 61 63 63 65 70 74 20 6f 72 20 53 53 4c SL_accept or SSL
13e0: 5f 63 6f 6e 6e 65 63 74 0a 20 2a 0a 20 2a 09 52 _connect. *. *.R
13f0: 65 73 75 6c 74 3a 0a 20 2a 09 09 4e 6f 6e 65 2e esult:. *..None.
1400: 0a 20 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d . *. *----------
1410: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
1420: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
1430: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2a 0a 20 2a ------------*. *
1440: 2f 0a 69 6e 74 20 54 6c 73 5f 57 61 69 74 46 6f /.int Tls_WaitFo
1450: 72 43 6f 6e 6e 65 63 74 28 53 74 61 74 65 20 2a rConnect(State *
1460: 73 74 61 74 65 50 74 72 2c 20 69 6e 74 20 2a 65 statePtr, int *e
1470: 72 72 6f 72 43 6f 64 65 50 74 72 2c 20 69 6e 74 rrorCodePtr, int
1480: 20 68 61 6e 64 73 68 61 6b 65 46 61 69 6c 75 72 handshakeFailur
1490: 65 49 73 50 65 72 6d 61 6e 65 6e 74 29 20 7b 0a eIsPermanent) {.
14a0: 09 75 6e 73 69 67 6e 65 64 20 6c 6f 6e 67 20 62 .unsigned long b
14b0: 61 63 6b 69 6e 67 45 72 72 6f 72 3b 0a 09 69 6e ackingError;..in
14c0: 74 20 65 72 72 2c 20 72 63 3b 0a 09 69 6e 74 20 t err, rc;..int
14d0: 62 69 6f 53 68 6f 75 6c 64 52 65 74 72 79 3b 0a bioShouldRetry;.
14e0: 0a 09 64 70 72 69 6e 74 66 28 22 57 61 69 74 46 ..dprintf("WaitF
14f0: 6f 72 43 6f 6e 6e 65 63 74 28 25 70 29 22 2c 20 orConnect(%p)",
1500: 73 74 61 74 65 50 74 72 29 3b 0a 09 64 70 72 69 statePtr);..dpri
1510: 6e 74 46 6c 61 67 73 28 73 74 61 74 65 50 74 72 ntFlags(statePtr
1520: 29 3b 0a 0a 09 69 66 20 28 21 28 73 74 61 74 65 );...if (!(state
1530: 50 74 72 2d 3e 66 6c 61 67 73 20 26 20 54 4c 53 Ptr->flags & TLS
1540: 5f 54 43 4c 5f 49 4e 49 54 29 29 20 7b 0a 09 09 _TCL_INIT)) {...
1550: 64 70 72 69 6e 74 66 28 22 54 6c 73 5f 57 61 69 dprintf("Tls_Wai
1560: 74 46 6f 72 43 6f 6e 6e 65 63 74 20 63 61 6c 6c tForConnect call
1570: 65 64 20 6f 6e 20 61 6c 72 65 61 64 79 20 69 6e ed on already in
1580: 69 74 69 61 6c 69 7a 65 64 20 63 68 61 6e 6e 65 itialized channe
1590: 6c 20 2d 2d 20 72 65 74 75 72 6e 69 6e 67 20 77 l -- returning w
15a0: 69 74 68 20 69 6d 6d 65 64 69 61 74 65 20 73 75 ith immediate su
15b0: 63 63 65 73 73 22 29 3b 0a 09 09 2a 65 72 72 6f ccess");...*erro
15c0: 72 43 6f 64 65 50 74 72 20 3d 20 30 3b 0a 09 09 rCodePtr = 0;...
15d0: 72 65 74 75 72 6e 28 30 29 3b 0a 09 7d 0a 0a 09 return(0);..}...
15e0: 69 66 20 28 73 74 61 74 65 50 74 72 2d 3e 66 6c if (statePtr->fl
15f0: 61 67 73 20 26 20 54 4c 53 5f 54 43 4c 5f 48 41 ags & TLS_TCL_HA
1600: 4e 44 53 48 41 4b 45 5f 46 41 49 4c 45 44 29 20 NDSHAKE_FAILED)
1610: 7b 0a 09 09 2f 2a 0a 09 09 20 2a 20 44 69 66 66 {.../*... * Diff
1620: 65 72 65 6e 74 20 74 79 70 65 73 20 6f 66 20 6f erent types of o
1630: 70 65 72 61 74 69 6f 6e 73 20 68 61 76 65 20 64 perations have d
1640: 69 66 66 65 72 65 6e 74 20 72 65 71 75 69 72 65 ifferent require
1650: 6d 65 6e 74 73 0a 09 09 20 2a 20 53 53 4c 20 62 ments... * SSL b
1660: 65 69 6e 67 20 65 73 74 61 62 6c 69 73 68 65 64 eing established
1670: 0a 09 09 20 2a 2f 0a 09 09 69 66 20 28 68 61 6e ... */...if (han
1680: 64 73 68 61 6b 65 46 61 69 6c 75 72 65 49 73 50 dshakeFailureIsP
1690: 65 72 6d 61 6e 65 6e 74 29 20 7b 0a 09 09 09 64 ermanent) {....d
16a0: 70 72 69 6e 74 66 28 22 41 73 6b 65 64 20 74 6f printf("Asked to
16b0: 20 77 61 69 74 20 66 6f 72 20 61 20 54 4c 53 20 wait for a TLS
16c0: 68 61 6e 64 73 68 61 6b 65 20 74 68 61 74 20 68 handshake that h
16d0: 61 73 20 61 6c 72 65 61 64 79 20 66 61 69 6c 65 as already faile
16e0: 64 2e 20 20 52 65 74 75 72 6e 69 6e 67 20 66 61 d. Returning fa
16f0: 74 61 6c 20 65 72 72 6f 72 22 29 3b 0a 09 09 09 tal error");....
1700: 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 20 3d 20 *errorCodePtr =
1710: 45 43 4f 4e 4e 41 42 4f 52 54 45 44 3b 0a 09 09 ECONNABORTED;...
1720: 7d 20 65 6c 73 65 20 7b 0a 09 09 09 64 70 72 69 } else {....dpri
1730: 6e 74 66 28 22 41 73 6b 65 64 20 74 6f 20 77 61 ntf("Asked to wa
1740: 69 74 20 66 6f 72 20 61 20 54 4c 53 20 68 61 6e it for a TLS han
1750: 64 73 68 61 6b 65 20 74 68 61 74 20 68 61 73 20 dshake that has
1760: 61 6c 72 65 61 64 79 20 66 61 69 6c 65 64 2e 20 already failed.
1770: 20 52 65 74 75 72 6e 69 6e 67 20 73 6f 66 74 20 Returning soft
1780: 65 72 72 6f 72 22 29 3b 0a 09 09 09 2a 65 72 72 error");....*err
1790: 6f 72 43 6f 64 65 50 74 72 20 3d 20 45 43 4f 4e orCodePtr = ECON
17a0: 4e 52 45 53 45 54 3b 0a 09 09 7d 0a 09 09 72 65 NRESET;...}...re
17b0: 74 75 72 6e 28 2d 31 29 3b 0a 09 7d 0a 0a 09 66 turn(-1);..}...f
17c0: 6f 72 20 28 3b 3b 29 20 7b 0a 09 09 2f 2a 20 4e or (;;) {.../* N
17d0: 6f 74 20 69 6e 69 74 69 61 6c 69 7a 65 64 20 79 ot initialized y
17e0: 65 74 21 20 2a 2f 0a 09 09 69 66 20 28 73 74 61 et! */...if (sta
17f0: 74 65 50 74 72 2d 3e 66 6c 61 67 73 20 26 20 54 tePtr->flags & T
1800: 4c 53 5f 54 43 4c 5f 53 45 52 56 45 52 29 20 7b LS_TCL_SERVER) {
1810: 0a 09 09 09 64 70 72 69 6e 74 66 28 22 43 61 6c ....dprintf("Cal
1820: 6c 69 6e 67 20 53 53 4c 5f 61 63 63 65 70 74 28 ling SSL_accept(
1830: 29 22 29 3b 0a 0a 09 09 09 65 72 72 20 3d 20 53 )");.....err = S
1840: 53 4c 5f 61 63 63 65 70 74 28 73 74 61 74 65 50 SL_accept(stateP
1850: 74 72 2d 3e 73 73 6c 29 3b 0a 09 09 7d 20 65 6c tr->ssl);...} el
1860: 73 65 20 7b 0a 09 09 09 64 70 72 69 6e 74 66 28 se {....dprintf(
1870: 22 43 61 6c 6c 69 6e 67 20 53 53 4c 5f 63 6f 6e "Calling SSL_con
1880: 6e 65 63 74 28 29 22 29 3b 0a 0a 09 09 09 65 72 nect()");.....er
1890: 72 20 3d 20 53 53 4c 5f 63 6f 6e 6e 65 63 74 28 r = SSL_connect(
18a0: 73 74 61 74 65 50 74 72 2d 3e 73 73 6c 29 3b 0a statePtr->ssl);.
18b0: 09 09 7d 0a 0a 09 09 69 66 20 28 65 72 72 20 3e ..}....if (err >
18c0: 20 30 29 20 7b 0a 09 09 09 64 70 72 69 6e 74 66 0) {....dprintf
18d0: 28 22 54 68 61 74 20 73 65 65 6d 73 20 74 6f 20 ("That seems to
18e0: 68 61 76 65 20 67 6f 6e 65 20 6f 6b 61 79 22 29 have gone okay")
18f0: 3b 0a 0a 09 09 09 65 72 72 20 3d 20 42 49 4f 5f ;.....err = BIO_
1900: 66 6c 75 73 68 28 73 74 61 74 65 50 74 72 2d 3e flush(statePtr->
1910: 62 69 6f 29 3b 0a 0a 09 09 09 69 66 20 28 65 72 bio);.....if (er
1920: 72 20 3c 3d 20 30 29 20 7b 0a 09 09 09 09 64 70 r <= 0) {.....dp
1930: 72 69 6e 74 66 28 22 46 6c 75 73 68 69 6e 67 20 rintf("Flushing
1940: 74 68 65 20 6c 6f 77 65 72 20 6c 61 79 65 72 73 the lower layers
1950: 20 66 61 69 6c 65 64 2c 20 74 68 69 73 20 77 69 failed, this wi
1960: 6c 6c 20 70 72 6f 62 61 62 6c 79 20 74 65 72 6d ll probably term
1970: 69 6e 61 74 65 20 74 68 69 73 20 73 65 73 73 69 inate this sessi
1980: 6f 6e 22 29 3b 0a 09 09 09 7d 0a 09 09 7d 0a 0a on");....}...}..
1990: 09 09 72 63 20 3d 20 53 53 4c 5f 67 65 74 5f 65 ..rc = SSL_get_e
19a0: 72 72 6f 72 28 73 74 61 74 65 50 74 72 2d 3e 73 rror(statePtr->s
19b0: 73 6c 2c 20 65 72 72 29 3b 0a 0a 09 09 64 70 72 sl, err);....dpr
19c0: 69 6e 74 66 28 22 47 6f 74 20 65 72 72 6f 72 3a intf("Got error:
19d0: 20 25 69 20 28 72 63 20 3d 20 25 69 29 22 2c 20 %i (rc = %i)",
19e0: 65 72 72 2c 20 72 63 29 3b 0a 0a 09 09 62 69 6f err, rc);....bio
19f0: 53 68 6f 75 6c 64 52 65 74 72 79 20 3d 20 30 3b ShouldRetry = 0;
1a00: 0a 09 09 69 66 20 28 65 72 72 20 3c 3d 20 30 29 ...if (err <= 0)
1a10: 20 7b 0a 09 09 09 69 66 20 28 72 63 20 3d 3d 20 {....if (rc ==
1a20: 53 53 4c 5f 45 52 52 4f 52 5f 57 41 4e 54 5f 43 SSL_ERROR_WANT_C
1a30: 4f 4e 4e 45 43 54 20 7c 7c 20 72 63 20 3d 3d 20 ONNECT || rc ==
1a40: 53 53 4c 5f 45 52 52 4f 52 5f 57 41 4e 54 5f 41 SSL_ERROR_WANT_A
1a50: 43 43 45 50 54 20 7c 7c 20 72 63 20 3d 3d 20 53 CCEPT || rc == S
1a60: 53 4c 5f 45 52 52 4f 52 5f 57 41 4e 54 5f 52 45 SL_ERROR_WANT_RE
1a70: 41 44 20 7c 7c 20 72 63 20 3d 3d 20 53 53 4c 5f AD || rc == SSL_
1a80: 45 52 52 4f 52 5f 57 41 4e 54 5f 57 52 49 54 45 ERROR_WANT_WRITE
1a90: 29 20 7b 0a 09 09 09 09 62 69 6f 53 68 6f 75 6c ) {.....bioShoul
1aa0: 64 52 65 74 72 79 20 3d 20 31 3b 0a 09 09 09 7d dRetry = 1;....}
1ab0: 20 65 6c 73 65 20 69 66 20 28 42 49 4f 5f 73 68 else if (BIO_sh
1ac0: 6f 75 6c 64 5f 72 65 74 72 79 28 73 74 61 74 65 ould_retry(state
1ad0: 50 74 72 2d 3e 62 69 6f 29 29 20 7b 0a 09 09 09 Ptr->bio)) {....
1ae0: 09 62 69 6f 53 68 6f 75 6c 64 52 65 74 72 79 20 .bioShouldRetry
1af0: 3d 20 31 3b 0a 09 09 09 7d 20 65 6c 73 65 20 69 = 1;....} else i
1b00: 66 20 28 72 63 20 3d 3d 20 53 53 4c 5f 45 52 52 f (rc == SSL_ERR
1b10: 4f 52 5f 53 59 53 43 41 4c 4c 20 26 26 20 54 63 OR_SYSCALL && Tc
1b20: 6c 5f 47 65 74 45 72 72 6e 6f 28 29 20 3d 3d 20 l_GetErrno() ==
1b30: 45 41 47 41 49 4e 29 20 7b 0a 09 09 09 09 62 69 EAGAIN) {.....bi
1b40: 6f 53 68 6f 75 6c 64 52 65 74 72 79 20 3d 20 31 oShouldRetry = 1
1b50: 3b 0a 09 09 09 7d 0a 09 09 7d 20 65 6c 73 65 20 ;....}...} else
1b60: 7b 0a 09 09 09 69 66 20 28 21 53 53 4c 5f 69 73 {....if (!SSL_is
1b70: 5f 69 6e 69 74 5f 66 69 6e 69 73 68 65 64 28 73 _init_finished(s
1b80: 74 61 74 65 50 74 72 2d 3e 73 73 6c 29 29 20 7b tatePtr->ssl)) {
1b90: 0a 09 09 09 09 62 69 6f 53 68 6f 75 6c 64 52 65 .....bioShouldRe
1ba0: 74 72 79 20 3d 20 31 3b 0a 09 09 09 7d 0a 09 09 try = 1;....}...
1bb0: 7d 0a 0a 09 09 69 66 20 28 62 69 6f 53 68 6f 75 }....if (bioShou
1bc0: 6c 64 52 65 74 72 79 29 20 7b 0a 09 09 09 64 70 ldRetry) {....dp
1bd0: 72 69 6e 74 66 28 22 54 68 65 20 49 2f 4f 20 64 rintf("The I/O d
1be0: 69 64 20 6e 6f 74 20 63 6f 6d 70 6c 65 74 65 20 id not complete
1bf0: 2d 2d 20 62 75 74 20 77 65 20 73 68 6f 75 6c 64 -- but we should
1c00: 20 74 72 79 20 69 74 20 61 67 61 69 6e 22 29 3b try it again");
1c10: 0a 0a 09 09 09 69 66 20 28 73 74 61 74 65 50 74 .....if (statePt
1c20: 72 2d 3e 66 6c 61 67 73 20 26 20 54 4c 53 5f 54 r->flags & TLS_T
1c30: 43 4c 5f 41 53 59 4e 43 29 20 7b 0a 09 09 09 09 CL_ASYNC) {.....
1c40: 64 70 72 69 6e 74 66 28 22 52 65 74 75 72 6e 69 dprintf("Returni
1c50: 6e 67 20 45 41 47 41 49 4e 20 73 6f 20 74 68 61 ng EAGAIN so tha
1c60: 74 20 69 74 20 63 61 6e 20 62 65 20 72 65 74 72 t it can be retr
1c70: 69 65 64 20 6c 61 74 65 72 22 29 3b 0a 0a 09 09 ied later");....
1c80: 09 09 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 20 ..*errorCodePtr
1c90: 3d 20 45 41 47 41 49 4e 3b 0a 0a 09 09 09 09 72 = EAGAIN;......r
1ca0: 65 74 75 72 6e 28 2d 31 29 3b 0a 09 09 09 7d 20 eturn(-1);....}
1cb0: 65 6c 73 65 20 7b 0a 09 09 09 09 64 70 72 69 6e else {.....dprin
1cc0: 74 66 28 22 44 6f 69 6e 67 20 73 6f 20 6e 6f 77 tf("Doing so now
1cd0: 22 29 3b 0a 0a 09 09 09 09 63 6f 6e 74 69 6e 75 ");......continu
1ce0: 65 3b 0a 09 09 09 7d 0a 09 09 7d 0a 0a 09 09 64 e;....}...}....d
1cf0: 70 72 69 6e 74 66 28 22 57 65 20 68 61 76 65 20 printf("We have
1d00: 65 69 74 68 65 72 20 63 6f 6d 70 6c 65 74 65 6c either completel
1d10: 79 20 65 73 74 61 62 6c 69 73 68 65 64 20 74 68 y established th
1d20: 65 20 73 65 73 73 69 6f 6e 20 6f 72 20 63 6f 6d e session or com
1d30: 70 6c 65 74 65 6c 79 20 66 61 69 6c 65 64 20 69 pletely failed i
1d40: 74 20 2d 2d 20 74 68 65 72 65 20 69 73 20 6e 6f t -- there is no
1d50: 20 6d 6f 72 65 20 6e 65 65 64 20 74 6f 20 65 76 more need to ev
1d60: 65 72 20 72 65 74 72 79 20 69 74 20 74 68 6f 75 er retry it thou
1d70: 67 68 22 29 3b 0a 09 09 62 72 65 61 6b 3b 0a 09 gh");...break;..
1d80: 7d 0a 0a 0a 09 2a 65 72 72 6f 72 43 6f 64 65 50 }....*errorCodeP
1d90: 74 72 20 3d 20 45 49 4e 56 41 4c 3b 0a 0a 09 73 tr = EINVAL;...s
1da0: 77 69 74 63 68 20 28 72 63 29 20 7b 0a 09 09 63 witch (rc) {...c
1db0: 61 73 65 20 53 53 4c 5f 45 52 52 4f 52 5f 4e 4f ase SSL_ERROR_NO
1dc0: 4e 45 3a 0a 09 09 09 2f 2a 20 54 68 65 20 63 6f NE:..../* The co
1dd0: 6e 6e 65 63 74 69 6f 6e 20 69 73 20 75 70 2c 20 nnection is up,
1de0: 77 65 20 61 72 65 20 64 6f 6e 65 20 68 65 72 65 we are done here
1df0: 20 2a 2f 0a 09 09 09 64 70 72 69 6e 74 66 28 22 */....dprintf("
1e00: 54 68 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 69 The connection i
1e10: 73 20 75 70 22 29 3b 0a 09 09 09 62 72 65 61 6b s up");....break
1e20: 3b 0a 09 09 63 61 73 65 20 53 53 4c 5f 45 52 52 ;...case SSL_ERR
1e30: 4f 52 5f 5a 45 52 4f 5f 52 45 54 55 52 4e 3a 0a OR_ZERO_RETURN:.
1e40: 09 09 09 64 70 72 69 6e 74 66 28 22 53 53 4c 5f ...dprintf("SSL_
1e50: 45 52 52 4f 52 5f 5a 45 52 4f 5f 52 45 54 55 52 ERROR_ZERO_RETUR
1e60: 4e 3a 20 43 6f 6e 6e 65 63 74 20 72 65 74 75 72 N: Connect retur
1e70: 6e 65 64 20 61 6e 20 69 6e 76 61 6c 69 64 20 76 ned an invalid v
1e80: 61 6c 75 65 2e 2e 2e 22 29 0a 09 09 09 72 65 74 alue...")....ret
1e90: 75 72 6e 28 2d 31 29 3b 0a 09 09 63 61 73 65 20 urn(-1);...case
1ea0: 53 53 4c 5f 45 52 52 4f 52 5f 53 59 53 43 41 4c SSL_ERROR_SYSCAL
1eb0: 4c 3a 0a 09 09 09 62 61 63 6b 69 6e 67 45 72 72 L:....backingErr
1ec0: 6f 72 20 3d 20 45 52 52 5f 67 65 74 5f 65 72 72 or = ERR_get_err
1ed0: 6f 72 28 29 3b 0a 0a 09 09 09 69 66 20 28 62 61 or();.....if (ba
1ee0: 63 6b 69 6e 67 45 72 72 6f 72 20 3d 3d 20 30 20 ckingError == 0
1ef0: 26 26 20 65 72 72 20 3d 3d 20 30 29 20 7b 0a 09 && err == 0) {..
1f00: 09 09 09 64 70 72 69 6e 74 66 28 22 45 4f 46 20 ...dprintf("EOF
1f10: 72 65 61 63 68 65 64 22 29 0a 09 09 09 09 2a 65 reached").....*e
1f20: 72 72 6f 72 43 6f 64 65 50 74 72 20 3d 20 45 43 rrorCodePtr = EC
1f30: 4f 4e 4e 52 45 53 45 54 3b 0a 09 09 09 7d 20 65 ONNRESET;....} e
1f40: 6c 73 65 20 69 66 20 28 62 61 63 6b 69 6e 67 45 lse if (backingE
1f50: 72 72 6f 72 20 3d 3d 20 30 20 26 26 20 65 72 72 rror == 0 && err
1f60: 20 3d 3d 20 2d 31 29 20 7b 0a 09 09 09 09 64 70 == -1) {.....dp
1f70: 72 69 6e 74 66 28 22 49 2f 4f 20 65 72 72 6f 72 rintf("I/O error
1f80: 20 6f 63 63 75 72 65 64 20 28 65 72 72 6e 6f 20 occured (errno
1f90: 3d 20 25 6c 75 29 22 2c 20 28 75 6e 73 69 67 6e = %lu)", (unsign
1fa0: 65 64 20 6c 6f 6e 67 29 20 54 63 6c 5f 47 65 74 ed long) Tcl_Get
1fb0: 45 72 72 6e 6f 28 29 29 3b 0a 09 09 09 09 2a 65 Errno());.....*e
1fc0: 72 72 6f 72 43 6f 64 65 50 74 72 20 3d 20 54 63 rrorCodePtr = Tc
1fd0: 6c 5f 47 65 74 45 72 72 6e 6f 28 29 3b 0a 09 09 l_GetErrno();...
1fe0: 09 09 69 66 20 28 2a 65 72 72 6f 72 43 6f 64 65 ..if (*errorCode
1ff0: 50 74 72 20 3d 3d 20 45 43 4f 4e 4e 52 45 53 45 Ptr == ECONNRESE
2000: 54 29 20 7b 0a 09 09 09 09 09 2a 65 72 72 6f 72 T) {......*error
2010: 43 6f 64 65 50 74 72 20 3d 20 45 43 4f 4e 4e 41 CodePtr = ECONNA
2020: 42 4f 52 54 45 44 3b 0a 09 09 09 09 7d 0a 09 09 BORTED;.....}...
2030: 09 7d 20 65 6c 73 65 20 7b 0a 09 09 09 09 64 70 .} else {.....dp
2040: 72 69 6e 74 66 28 22 49 2f 4f 20 65 72 72 6f 72 rintf("I/O error
2050: 20 6f 63 63 75 72 65 64 20 28 62 61 63 6b 69 6e occured (backin
2060: 67 45 72 72 6f 72 20 3d 20 25 6c 75 29 22 2c 20 gError = %lu)",
2070: 62 61 63 6b 69 6e 67 45 72 72 6f 72 29 3b 0a 09 backingError);..
2080: 09 09 09 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 ...*errorCodePtr
2090: 20 3d 20 62 61 63 6b 69 6e 67 45 72 72 6f 72 3b = backingError;
20a0: 0a 09 09 09 09 69 66 20 28 2a 65 72 72 6f 72 43 .....if (*errorC
20b0: 6f 64 65 50 74 72 20 3d 3d 20 45 43 4f 4e 4e 52 odePtr == ECONNR
20c0: 45 53 45 54 29 20 7b 0a 09 09 09 09 09 2a 65 72 ESET) {......*er
20d0: 72 6f 72 43 6f 64 65 50 74 72 20 3d 20 45 43 4f rorCodePtr = ECO
20e0: 4e 4e 41 42 4f 52 54 45 44 3b 0a 09 09 09 09 7d NNABORTED;.....}
20f0: 0a 09 09 09 7d 0a 0a 09 09 09 73 74 61 74 65 50 ....}.....stateP
2100: 74 72 2d 3e 66 6c 61 67 73 20 7c 3d 20 54 4c 53 tr->flags |= TLS
2110: 5f 54 43 4c 5f 48 41 4e 44 53 48 41 4b 45 5f 46 _TCL_HANDSHAKE_F
2120: 41 49 4c 45 44 3b 0a 0a 09 09 09 72 65 74 75 72 AILED;.....retur
2130: 6e 28 2d 31 29 3b 0a 09 09 63 61 73 65 20 53 53 n(-1);...case SS
2140: 4c 5f 45 52 52 4f 52 5f 53 53 4c 3a 0a 09 09 09 L_ERROR_SSL:....
2150: 64 70 72 69 6e 74 66 28 22 47 6f 74 20 70 65 72 dprintf("Got per
2160: 6d 61 6e 65 6e 74 20 66 61 74 61 6c 20 53 53 4c manent fatal SSL
2170: 20 65 72 72 6f 72 2c 20 61 62 6f 72 74 69 6e 67 error, aborting
2180: 20 69 6d 6d 65 64 69 61 74 65 6c 79 22 29 3b 0a immediately");.
2190: 09 09 09 54 6c 73 5f 45 72 72 6f 72 28 73 74 61 ...Tls_Error(sta
21a0: 74 65 50 74 72 2c 20 28 63 68 61 72 20 2a 29 45 tePtr, (char *)E
21b0: 52 52 5f 72 65 61 73 6f 6e 5f 65 72 72 6f 72 5f RR_reason_error_
21c0: 73 74 72 69 6e 67 28 45 52 52 5f 67 65 74 5f 65 string(ERR_get_e
21d0: 72 72 6f 72 28 29 29 29 3b 0a 09 09 09 73 74 61 rror()));....sta
21e0: 74 65 50 74 72 2d 3e 66 6c 61 67 73 20 7c 3d 20 tePtr->flags |=
21f0: 54 4c 53 5f 54 43 4c 5f 48 41 4e 44 53 48 41 4b TLS_TCL_HANDSHAK
2200: 45 5f 46 41 49 4c 45 44 3b 0a 09 09 09 2a 65 72 E_FAILED;....*er
2210: 72 6f 72 43 6f 64 65 50 74 72 20 3d 20 45 43 4f rorCodePtr = ECO
2220: 4e 4e 41 42 4f 52 54 45 44 3b 0a 09 09 09 72 65 NNABORTED;....re
2230: 74 75 72 6e 28 2d 31 29 3b 0a 09 09 63 61 73 65 turn(-1);...case
2240: 20 53 53 4c 5f 45 52 52 4f 52 5f 57 41 4e 54 5f SSL_ERROR_WANT_
2250: 43 4f 4e 4e 45 43 54 3a 0a 09 09 63 61 73 65 20 CONNECT:...case
2260: 53 53 4c 5f 45 52 52 4f 52 5f 57 41 4e 54 5f 41 SSL_ERROR_WANT_A
2270: 43 43 45 50 54 3a 0a 09 09 63 61 73 65 20 53 53 CCEPT:...case SS
2280: 4c 5f 45 52 52 4f 52 5f 57 41 4e 54 5f 58 35 30 L_ERROR_WANT_X50
2290: 39 5f 4c 4f 4f 4b 55 50 3a 0a 09 09 64 65 66 61 9_LOOKUP:...defa
22a0: 75 6c 74 3a 0a 09 09 09 64 70 72 69 6e 74 66 28 ult:....dprintf(
22b0: 22 57 65 20 67 6f 74 20 61 20 63 6f 6e 66 75 73 "We got a confus
22c0: 69 6e 67 20 72 65 70 6c 79 3a 20 25 69 22 2c 20 ing reply: %i",
22d0: 72 63 29 3b 0a 09 09 09 2a 65 72 72 6f 72 43 6f rc);....*errorCo
22e0: 64 65 50 74 72 20 3d 20 54 63 6c 5f 47 65 74 45 dePtr = Tcl_GetE
22f0: 72 72 6e 6f 28 29 3b 0a 09 09 09 64 70 72 69 6e rrno();....dprin
2300: 74 66 28 22 45 52 52 28 25 64 2c 20 25 64 29 20 tf("ERR(%d, %d)
2310: 22 2c 20 72 63 2c 20 2a 65 72 72 6f 72 43 6f 64 ", rc, *errorCod
2320: 65 50 74 72 29 3b 0a 09 09 09 72 65 74 75 72 6e ePtr);....return
2330: 28 2d 31 29 3b 0a 09 7d 0a 0a 23 69 66 20 30 0a (-1);..}..#if 0.
2340: 09 69 66 20 28 73 74 61 74 65 50 74 72 2d 3e 66 .if (statePtr->f
2350: 6c 61 67 73 20 26 20 54 4c 53 5f 54 43 4c 5f 53 lags & TLS_TCL_S
2360: 45 52 56 45 52 29 20 7b 0a 09 09 64 70 72 69 6e ERVER) {...dprin
2370: 74 66 28 22 54 68 69 73 20 69 73 20 61 6e 20 54 tf("This is an T
2380: 4c 53 20 73 65 72 76 65 72 2c 20 63 68 65 63 6b LS server, check
2390: 69 6e 67 20 74 68 65 20 63 65 72 74 69 66 69 63 ing the certific
23a0: 61 74 65 20 66 6f 72 20 74 68 65 20 70 65 65 72 ate for the peer
23b0: 22 29 3b 0a 0a 09 09 65 72 72 20 3d 20 53 53 4c ");....err = SSL
23c0: 5f 67 65 74 5f 76 65 72 69 66 79 5f 72 65 73 75 _get_verify_resu
23d0: 6c 74 28 73 74 61 74 65 50 74 72 2d 3e 73 73 6c lt(statePtr->ssl
23e0: 29 3b 0a 09 09 69 66 20 28 65 72 72 20 21 3d 20 );...if (err !=
23f0: 58 35 30 39 5f 56 5f 4f 4b 29 20 7b 0a 09 09 09 X509_V_OK) {....
2400: 64 70 72 69 6e 74 66 28 22 49 6e 76 61 6c 69 64 dprintf("Invalid
2410: 20 63 65 72 74 69 66 69 63 61 74 65 2c 20 72 65 certificate, re
2420: 74 75 72 6e 69 6e 67 20 69 6e 20 66 61 69 6c 75 turning in failu
2430: 72 65 22 29 3b 0a 0a 09 09 09 54 6c 73 5f 45 72 re");.....Tls_Er
2440: 72 6f 72 28 73 74 61 74 65 50 74 72 2c 20 28 63 ror(statePtr, (c
2450: 68 61 72 20 2a 29 58 35 30 39 5f 76 65 72 69 66 har *)X509_verif
2460: 79 5f 63 65 72 74 5f 65 72 72 6f 72 5f 73 74 72 y_cert_error_str
2470: 69 6e 67 28 65 72 72 29 29 3b 0a 09 09 09 73 74 ing(err));....st
2480: 61 74 65 50 74 72 2d 3e 66 6c 61 67 73 20 7c 3d atePtr->flags |=
2490: 20 54 4c 53 5f 54 43 4c 5f 48 41 4e 44 53 48 41 TLS_TCL_HANDSHA
24a0: 4b 45 5f 46 41 49 4c 45 44 3b 0a 09 09 09 2a 65 KE_FAILED;....*e
24b0: 72 72 6f 72 43 6f 64 65 50 74 72 20 3d 20 45 43 rrorCodePtr = EC
24c0: 4f 4e 4e 41 42 4f 52 54 45 44 3b 0a 09 09 09 72 ONNABORTED;....r
24d0: 65 74 75 72 6e 28 2d 31 29 3b 0a 09 09 7d 0a 09 eturn(-1);...}..
24e0: 7d 0a 23 65 6e 64 69 66 0a 0a 09 64 70 72 69 6e }.#endif...dprin
24f0: 74 66 28 22 52 65 6d 6f 76 69 6e 67 20 74 68 65 tf("Removing the
2500: 20 5c 22 54 4c 53 5f 54 43 4c 5f 49 4e 49 54 5c \"TLS_TCL_INIT\
2510: 22 20 66 6c 61 67 20 73 69 6e 63 65 20 77 65 20 " flag since we
2520: 68 61 76 65 20 63 6f 6d 70 6c 65 74 65 64 20 74 have completed t
2530: 68 65 20 68 61 6e 64 73 68 61 6b 65 22 29 3b 0a he handshake");.
2540: 09 73 74 61 74 65 50 74 72 2d 3e 66 6c 61 67 73 .statePtr->flags
2550: 20 26 3d 20 7e 54 4c 53 5f 54 43 4c 5f 49 4e 49 &= ~TLS_TCL_INI
2560: 54 3b 0a 0a 09 64 70 72 69 6e 74 66 28 22 52 65 T;...dprintf("Re
2570: 74 75 72 6e 69 6e 67 20 69 6e 20 73 75 63 63 65 turning in succe
2580: 73 73 22 29 3b 0a 09 2a 65 72 72 6f 72 43 6f 64 ss");..*errorCod
2590: 65 50 74 72 20 3d 20 30 3b 0a 0a 09 72 65 74 75 ePtr = 0;...retu
25a0: 72 6e 28 30 29 3b 0a 7d 0a 0a 2f 2a 0a 20 2a 2d rn(0);.}../*. *-
25b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
25c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
25d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
25e0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
25f0: 2d 2d 0a 20 2a 0a 20 2a 20 54 6c 73 49 6e 70 75 --. *. * TlsInpu
2600: 74 50 72 6f 63 20 2d 2d 0a 20 2a 0a 20 2a 09 54 tProc --. *. *.T
2610: 68 69 73 20 70 72 6f 63 65 64 75 72 65 20 69 73 his procedure is
2620: 20 69 6e 76 6f 6b 65 64 20 62 79 20 74 68 65 20 invoked by the
2630: 67 65 6e 65 72 69 63 20 49 4f 20 6c 65 76 65 6c generic IO level
2640: 0a 20 2a 20 20 20 20 20 20 20 74 6f 20 72 65 61 . * to rea
2650: 64 20 69 6e 70 75 74 20 66 72 6f 6d 20 61 20 53 d input from a S
2660: 53 4c 20 73 6f 63 6b 65 74 20 62 61 73 65 64 20 SL socket based
2670: 63 68 61 6e 6e 65 6c 2e 0a 20 2a 0a 20 2a 20 52 channel.. *. * R
2680: 65 73 75 6c 74 73 3a 0a 20 2a 09 54 68 65 20 6e esults:. *.The n
2690: 75 6d 62 65 72 20 6f 66 20 62 79 74 65 73 20 72 umber of bytes r
26a0: 65 61 64 20 69 73 20 72 65 74 75 72 6e 65 64 20 ead is returned
26b0: 6f 72 20 2d 31 20 6f 6e 20 65 72 72 6f 72 2e 20 or -1 on error.
26c0: 41 6e 20 6f 75 74 70 75 74 0a 20 2a 09 61 72 67 An output. *.arg
26d0: 75 6d 65 6e 74 20 63 6f 6e 74 61 69 6e 73 20 74 ument contains t
26e0: 68 65 20 50 4f 53 49 58 20 65 72 72 6f 72 20 63 he POSIX error c
26f0: 6f 64 65 20 6f 6e 20 65 72 72 6f 72 2c 20 6f 72 ode on error, or
2700: 20 7a 65 72 6f 20 69 66 20 6e 6f 0a 20 2a 09 65 zero if no. *.e
2710: 72 72 6f 72 20 6f 63 63 75 72 72 65 64 2e 0a 20 rror occurred..
2720: 2a 0a 20 2a 20 53 69 64 65 20 65 66 66 65 63 74 *. * Side effect
2730: 73 3a 0a 20 2a 09 52 65 61 64 73 20 69 6e 70 75 s:. *.Reads inpu
2740: 74 20 66 72 6f 6d 20 74 68 65 20 69 6e 70 75 74 t from the input
2750: 20 64 65 76 69 63 65 20 6f 66 20 74 68 65 20 63 device of the c
2760: 68 61 6e 6e 65 6c 2e 0a 20 2a 0a 20 2a 2d 2d 2d hannel.. *. *---
2770: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
2780: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
2790: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
27a0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
27b0: 0a 20 2a 2f 0a 0a 73 74 61 74 69 63 20 69 6e 74 . */..static int
27c0: 20 54 6c 73 49 6e 70 75 74 50 72 6f 63 28 76 6f TlsInputProc(vo
27d0: 69 64 20 2a 69 6e 73 74 61 6e 63 65 44 61 74 61 id *instanceData
27e0: 2c 20 63 68 61 72 20 2a 62 75 66 2c 20 69 6e 74 , char *buf, int
27f0: 20 62 75 66 53 69 7a 65 2c 20 69 6e 74 20 2a 65 bufSize, int *e
2800: 72 72 6f 72 43 6f 64 65 50 74 72 29 20 7b 0a 09 rrorCodePtr) {..
2810: 75 6e 73 69 67 6e 65 64 20 6c 6f 6e 67 20 62 61 unsigned long ba
2820: 63 6b 69 6e 67 45 72 72 6f 72 3b 0a 09 53 74 61 ckingError;..Sta
2830: 74 65 20 2a 73 74 61 74 65 50 74 72 20 3d 20 28 te *statePtr = (
2840: 53 74 61 74 65 20 2a 29 20 69 6e 73 74 61 6e 63 State *) instanc
2850: 65 44 61 74 61 3b 0a 09 69 6e 74 20 62 79 74 65 eData;..int byte
2860: 73 52 65 61 64 3b 0a 09 69 6e 74 20 74 6c 73 43 sRead;..int tlsC
2870: 6f 6e 6e 65 63 74 3b 0a 09 69 6e 74 20 65 72 72 onnect;..int err
2880: 3b 0a 0a 09 2a 65 72 72 6f 72 43 6f 64 65 50 74 ;...*errorCodePt
2890: 72 20 3d 20 30 3b 0a 0a 09 64 70 72 69 6e 74 66 r = 0;...dprintf
28a0: 28 22 42 49 4f 5f 72 65 61 64 28 25 64 29 22 2c ("BIO_read(%d)",
28b0: 20 62 75 66 53 69 7a 65 29 3b 0a 0a 09 69 66 20 bufSize);...if
28c0: 28 73 74 61 74 65 50 74 72 2d 3e 66 6c 61 67 73 (statePtr->flags
28d0: 20 26 20 54 4c 53 5f 54 43 4c 5f 43 41 4c 4c 42 & TLS_TCL_CALLB
28e0: 41 43 4b 29 20 7b 0a 09 09 2f 2a 20 64 6f 6e 27 ACK) {.../* don'
28f0: 74 20 70 72 6f 63 65 73 73 20 61 6e 79 20 62 79 t process any by
2900: 74 65 73 20 77 68 69 6c 65 20 76 65 72 69 66 79 tes while verify
2910: 20 63 61 6c 6c 62 61 63 6b 20 69 73 20 72 75 6e callback is run
2920: 6e 69 6e 67 20 2a 2f 0a 09 09 64 70 72 69 6e 74 ning */...dprint
2930: 66 28 22 43 61 6c 6c 62 61 63 6b 20 69 73 20 72 f("Callback is r
2940: 75 6e 6e 69 6e 67 2c 20 72 65 61 64 69 6e 67 20 unning, reading
2950: 30 20 62 79 74 65 73 22 29 3b 0a 09 09 72 65 74 0 bytes");...ret
2960: 75 72 6e 28 30 29 3b 0a 09 7d 0a 0a 09 64 70 72 urn(0);..}...dpr
2970: 69 6e 74 66 28 22 43 61 6c 6c 69 6e 67 20 54 6c intf("Calling Tl
2980: 73 5f 57 61 69 74 46 6f 72 43 6f 6e 6e 65 63 74 s_WaitForConnect
2990: 22 29 3b 0a 09 74 6c 73 43 6f 6e 6e 65 63 74 20 ");..tlsConnect
29a0: 3d 20 54 6c 73 5f 57 61 69 74 46 6f 72 43 6f 6e = Tls_WaitForCon
29b0: 6e 65 63 74 28 73 74 61 74 65 50 74 72 2c 20 65 nect(statePtr, e
29c0: 72 72 6f 72 43 6f 64 65 50 74 72 2c 20 30 29 3b rrorCodePtr, 0);
29d0: 0a 09 69 66 20 28 74 6c 73 43 6f 6e 6e 65 63 74 ..if (tlsConnect
29e0: 20 3c 20 30 29 20 7b 0a 09 09 64 70 72 69 6e 74 < 0) {...dprint
29f0: 66 28 22 47 6f 74 20 61 6e 20 65 72 72 6f 72 20 f("Got an error
2a00: 77 61 69 74 69 6e 67 20 74 6f 20 63 6f 6e 6e 65 waiting to conne
2a10: 63 74 20 28 74 6c 73 43 6f 6e 6e 65 63 74 20 3d ct (tlsConnect =
2a20: 20 25 69 2c 20 2a 65 72 72 6f 72 43 6f 64 65 50 %i, *errorCodeP
2a30: 74 72 20 3d 20 25 69 29 22 2c 20 74 6c 73 43 6f tr = %i)", tlsCo
2a40: 6e 6e 65 63 74 2c 20 2a 65 72 72 6f 72 43 6f 64 nnect, *errorCod
2a50: 65 50 74 72 29 3b 0a 0a 09 09 62 79 74 65 73 52 ePtr);....bytesR
2a60: 65 61 64 20 3d 20 2d 31 3b 0a 09 09 69 66 20 28 ead = -1;...if (
2a70: 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 20 3d 3d *errorCodePtr ==
2a80: 20 45 43 4f 4e 4e 52 45 53 45 54 29 20 7b 0a 09 ECONNRESET) {..
2a90: 09 09 64 70 72 69 6e 74 66 28 22 47 6f 74 20 63 ..dprintf("Got c
2aa0: 6f 6e 6e 65 63 74 69 6f 6e 20 72 65 73 65 74 22 onnection reset"
2ab0: 29 3b 0a 09 09 09 2f 2a 20 53 6f 66 74 20 45 4f );..../* Soft EO
2ac0: 46 20 2a 2f 0a 09 09 09 2a 65 72 72 6f 72 43 6f F */....*errorCo
2ad0: 64 65 50 74 72 20 3d 20 30 3b 0a 09 09 09 62 79 dePtr = 0;....by
2ae0: 74 65 73 52 65 61 64 20 3d 20 30 3b 0a 09 09 7d tesRead = 0;...}
2af0: 0a 0a 09 09 72 65 74 75 72 6e 28 62 79 74 65 73 ....return(bytes
2b00: 52 65 61 64 29 3b 0a 09 7d 0a 0a 09 2f 2a 0a 09 Read);..}.../*..
2b10: 20 2a 20 57 65 20 6e 65 65 64 20 74 6f 20 63 6c * We need to cl
2b20: 65 61 72 20 74 68 65 20 53 53 4c 20 65 72 72 6f ear the SSL erro
2b30: 72 20 73 74 61 63 6b 20 6e 6f 77 20 62 65 63 61 r stack now beca
2b40: 75 73 65 20 77 65 20 73 6f 6d 65 74 69 6d 65 73 use we sometimes
2b50: 20 72 65 61 63 68 0a 09 20 2a 20 74 68 69 73 20 reach.. * this
2b60: 66 75 6e 63 74 69 6f 6e 20 77 69 74 68 20 6c 65 function with le
2b70: 66 74 6f 76 65 72 20 65 72 72 6f 72 73 20 69 6e ftover errors in
2b80: 20 74 68 65 20 73 74 61 63 6b 2e 20 20 49 66 20 the stack. If
2b90: 42 49 4f 5f 72 65 61 64 0a 09 20 2a 20 72 65 74 BIO_read.. * ret
2ba0: 75 72 6e 73 20 2d 31 20 61 6e 64 20 69 6e 74 65 urns -1 and inte
2bb0: 6e 64 73 20 45 41 47 41 49 4e 2c 20 74 68 65 72 nds EAGAIN, ther
2bc0: 65 20 69 73 20 61 20 6c 65 66 74 6f 76 65 72 20 e is a leftover
2bd0: 65 72 72 6f 72 2c 20 69 74 20 77 69 6c 6c 20 62 error, it will b
2be0: 65 0a 09 20 2a 20 6d 69 73 63 6f 6e 73 74 72 75 e.. * misconstru
2bf0: 65 64 20 61 73 20 61 6e 20 65 72 72 6f 72 2c 20 ed as an error,
2c00: 6e 6f 74 20 45 41 47 41 49 4e 2e 0a 09 20 2a 0a not EAGAIN... *.
2c10: 09 20 2a 20 41 6c 74 65 72 6e 61 74 69 76 65 6c . * Alternativel
2c20: 79 2c 20 77 65 20 6d 61 79 20 77 61 6e 74 20 74 y, we may want t
2c30: 6f 20 68 61 6e 64 6c 65 20 74 68 65 20 3c 30 20 o handle the <0
2c40: 72 65 74 75 72 6e 20 63 6f 64 65 73 20 66 72 6f return codes fro
2c50: 6d 0a 09 20 2a 20 42 49 4f 5f 72 65 61 64 20 73 m.. * BIO_read s
2c60: 70 65 63 69 61 6c 6c 79 20 28 61 73 20 61 64 76 pecially (as adv
2c70: 69 73 65 64 20 69 6e 20 74 68 65 20 52 53 41 20 ised in the RSA
2c80: 64 6f 63 73 29 2e 20 20 54 4c 53 27 73 20 6c 6f docs). TLS's lo
2c90: 77 65 72 20 6c 65 76 65 6c 20 42 49 4f 0a 09 20 wer level BIO..
2ca0: 2a 20 66 75 6e 63 74 69 6f 6e 73 20 70 6c 61 79 * functions play
2cb0: 20 77 69 74 68 20 74 68 65 20 72 65 74 72 79 20 with the retry
2cc0: 66 6c 61 67 73 20 74 68 6f 75 67 68 2c 20 61 6e flags though, an
2cd0: 64 20 74 68 69 73 20 73 65 65 6d 73 20 74 6f 20 d this seems to
2ce0: 77 6f 72 6b 0a 09 20 2a 20 63 6f 72 72 65 63 74 work.. * correct
2cf0: 6c 79 2e 20 20 53 69 6d 69 6c 61 72 20 66 69 78 ly. Similar fix
2d00: 20 69 6e 20 54 6c 73 4f 75 74 70 75 74 50 72 6f in TlsOutputPro
2d10: 63 2e 20 2d 20 68 6f 62 62 73 0a 09 20 2a 2f 0a c. - hobbs.. */.
2d20: 09 45 52 52 5f 63 6c 65 61 72 5f 65 72 72 6f 72 .ERR_clear_error
2d30: 28 29 3b 0a 09 62 79 74 65 73 52 65 61 64 20 3d ();..bytesRead =
2d40: 20 42 49 4f 5f 72 65 61 64 28 73 74 61 74 65 50 BIO_read(stateP
2d50: 74 72 2d 3e 62 69 6f 2c 20 62 75 66 2c 20 62 75 tr->bio, buf, bu
2d60: 66 53 69 7a 65 29 3b 0a 09 64 70 72 69 6e 74 66 fSize);..dprintf
2d70: 28 22 42 49 4f 5f 72 65 61 64 20 2d 3e 20 25 64 ("BIO_read -> %d
2d80: 22 2c 20 62 79 74 65 73 52 65 61 64 29 3b 0a 0a ", bytesRead);..
2d90: 09 65 72 72 20 3d 20 53 53 4c 5f 67 65 74 5f 65 .err = SSL_get_e
2da0: 72 72 6f 72 28 73 74 61 74 65 50 74 72 2d 3e 73 rror(statePtr->s
2db0: 73 6c 2c 20 62 79 74 65 73 52 65 61 64 29 3b 0a sl, bytesRead);.
2dc0: 0a 23 69 66 20 30 0a 09 69 66 20 28 62 79 74 65 .#if 0..if (byte
2dd0: 73 52 65 61 64 20 3c 3d 20 30 29 20 7b 0a 09 09 sRead <= 0) {...
2de0: 69 66 20 28 42 49 4f 5f 73 68 6f 75 6c 64 5f 72 if (BIO_should_r
2df0: 65 74 72 79 28 73 74 61 74 65 50 74 72 2d 3e 62 etry(statePtr->b
2e00: 69 6f 29 29 20 7b 0a 09 09 09 64 70 72 69 6e 74 io)) {....dprint
2e10: 66 28 22 49 2f 4f 20 66 61 69 6c 65 64 2c 20 77 f("I/O failed, w
2e20: 69 6c 6c 20 72 65 74 72 79 20 62 61 73 65 64 20 ill retry based
2e30: 6f 6e 20 45 41 47 41 49 4e 22 29 3b 0a 09 09 09 on EAGAIN");....
2e40: 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 20 3d 20 *errorCodePtr =
2e50: 45 41 47 41 49 4e 3b 0a 09 09 7d 0a 09 7d 0a 23 EAGAIN;...}..}.#
2e60: 65 6e 64 69 66 0a 0a 09 73 77 69 74 63 68 20 28 endif...switch (
2e70: 65 72 72 29 20 7b 0a 09 09 63 61 73 65 20 53 53 err) {...case SS
2e80: 4c 5f 45 52 52 4f 52 5f 4e 4f 4e 45 3a 0a 09 09 L_ERROR_NONE:...
2e90: 09 64 70 72 69 6e 74 42 75 66 66 65 72 28 62 75 .dprintBuffer(bu
2ea0: 66 2c 20 62 79 74 65 73 52 65 61 64 29 3b 0a 09 f, bytesRead);..
2eb0: 09 09 62 72 65 61 6b 3b 0a 09 09 63 61 73 65 20 ..break;...case
2ec0: 53 53 4c 5f 45 52 52 4f 52 5f 53 53 4c 3a 0a 09 SSL_ERROR_SSL:..
2ed0: 09 09 64 70 72 69 6e 74 66 28 22 53 53 4c 20 6e ..dprintf("SSL n
2ee0: 65 67 6f 74 69 61 74 69 6f 6e 20 65 72 72 6f 72 egotiation error
2ef0: 2c 20 69 6e 64 69 63 61 74 69 6e 67 20 74 68 61 , indicating tha
2f00: 74 20 74 68 65 20 63 6f 6e 6e 65 63 74 69 6f 6e t the connection
2f10: 20 68 61 73 20 62 65 65 6e 20 61 62 6f 72 74 65 has been aborte
2f20: 64 22 29 3b 0a 0a 09 09 09 54 6c 73 5f 45 72 72 d");.....Tls_Err
2f30: 6f 72 28 73 74 61 74 65 50 74 72 2c 20 54 43 4c or(statePtr, TCL
2f40: 54 4c 53 5f 53 53 4c 5f 45 52 52 4f 52 28 73 74 TLS_SSL_ERROR(st
2f50: 61 74 65 50 74 72 2d 3e 73 73 6c 2c 20 62 79 74 atePtr->ssl, byt
2f60: 65 73 52 65 61 64 29 29 3b 0a 09 09 09 2a 65 72 esRead));....*er
2f70: 72 6f 72 43 6f 64 65 50 74 72 20 3d 20 45 43 4f rorCodePtr = ECO
2f80: 4e 4e 41 42 4f 52 54 45 44 3b 0a 09 09 09 62 79 NNABORTED;....by
2f90: 74 65 73 52 65 61 64 20 3d 20 2d 31 3b 0a 0a 09 tesRead = -1;...
2fa0: 09 09 62 72 65 61 6b 3b 0a 09 09 63 61 73 65 20 ..break;...case
2fb0: 53 53 4c 5f 45 52 52 4f 52 5f 53 59 53 43 41 4c SSL_ERROR_SYSCAL
2fc0: 4c 3a 0a 09 09 09 62 61 63 6b 69 6e 67 45 72 72 L:....backingErr
2fd0: 6f 72 20 3d 20 45 52 52 5f 67 65 74 5f 65 72 72 or = ERR_get_err
2fe0: 6f 72 28 29 3b 0a 0a 09 09 09 69 66 20 28 62 61 or();.....if (ba
2ff0: 63 6b 69 6e 67 45 72 72 6f 72 20 3d 3d 20 30 20 ckingError == 0
3000: 26 26 20 62 79 74 65 73 52 65 61 64 20 3d 3d 20 && bytesRead ==
3010: 30 29 20 7b 0a 09 09 09 09 64 70 72 69 6e 74 66 0) {.....dprintf
3020: 28 22 45 4f 46 20 72 65 61 63 68 65 64 22 29 0a ("EOF reached").
3030: 09 09 09 09 2a 65 72 72 6f 72 43 6f 64 65 50 74 ....*errorCodePt
3040: 72 20 3d 20 30 3b 0a 09 09 09 09 62 79 74 65 73 r = 0;.....bytes
3050: 52 65 61 64 20 3d 20 30 3b 0a 09 09 09 7d 20 65 Read = 0;....} e
3060: 6c 73 65 20 69 66 20 28 62 61 63 6b 69 6e 67 45 lse if (backingE
3070: 72 72 6f 72 20 3d 3d 20 30 20 26 26 20 62 79 74 rror == 0 && byt
3080: 65 73 52 65 61 64 20 3d 3d 20 2d 31 29 20 7b 0a esRead == -1) {.
3090: 09 09 09 09 64 70 72 69 6e 74 66 28 22 49 2f 4f ....dprintf("I/O
30a0: 20 65 72 72 6f 72 20 6f 63 63 75 72 65 64 20 28 error occured (
30b0: 65 72 72 6e 6f 20 3d 20 25 6c 75 29 22 2c 20 28 errno = %lu)", (
30c0: 75 6e 73 69 67 6e 65 64 20 6c 6f 6e 67 29 20 54 unsigned long) T
30d0: 63 6c 5f 47 65 74 45 72 72 6e 6f 28 29 29 3b 0a cl_GetErrno());.
30e0: 09 09 09 09 2a 65 72 72 6f 72 43 6f 64 65 50 74 ....*errorCodePt
30f0: 72 20 3d 20 54 63 6c 5f 47 65 74 45 72 72 6e 6f r = Tcl_GetErrno
3100: 28 29 3b 0a 09 09 09 09 62 79 74 65 73 52 65 61 ();.....bytesRea
3110: 64 20 3d 20 2d 31 3b 0a 09 09 09 7d 20 65 6c 73 d = -1;....} els
3120: 65 20 7b 0a 09 09 09 09 64 70 72 69 6e 74 66 28 e {.....dprintf(
3130: 22 49 2f 4f 20 65 72 72 6f 72 20 6f 63 63 75 72 "I/O error occur
3140: 65 64 20 28 62 61 63 6b 69 6e 67 45 72 72 6f 72 ed (backingError
3150: 20 3d 20 25 6c 75 29 22 2c 20 62 61 63 6b 69 6e = %lu)", backin
3160: 67 45 72 72 6f 72 29 3b 0a 09 09 09 09 2a 65 72 gError);.....*er
3170: 72 6f 72 43 6f 64 65 50 74 72 20 3d 20 62 61 63 rorCodePtr = bac
3180: 6b 69 6e 67 45 72 72 6f 72 3b 0a 09 09 09 09 62 kingError;.....b
3190: 79 74 65 73 52 65 61 64 20 3d 20 2d 31 3b 0a 09 ytesRead = -1;..
31a0: 09 09 7d 0a 0a 09 09 09 62 72 65 61 6b 3b 0a 09 ..}.....break;..
31b0: 09 63 61 73 65 20 53 53 4c 5f 45 52 52 4f 52 5f .case SSL_ERROR_
31c0: 5a 45 52 4f 5f 52 45 54 55 52 4e 3a 0a 09 09 09 ZERO_RETURN:....
31d0: 64 70 72 69 6e 74 66 28 22 47 6f 74 20 53 53 4c dprintf("Got SSL
31e0: 5f 45 52 52 4f 52 5f 5a 45 52 4f 5f 52 45 54 55 _ERROR_ZERO_RETU
31f0: 52 4e 2c 20 74 68 69 73 20 6d 65 61 6e 73 20 61 RN, this means a
3200: 6e 20 45 4f 46 20 68 61 73 20 62 65 65 6e 20 72 n EOF has been r
3210: 65 61 63 68 65 64 22 29 3b 0a 09 09 09 62 79 74 eached");....byt
3220: 65 73 52 65 61 64 20 3d 20 30 3b 0a 09 09 09 2a esRead = 0;....*
3230: 65 72 72 6f 72 43 6f 64 65 50 74 72 20 3d 20 30 errorCodePtr = 0
3240: 3b 0a 09 09 09 62 72 65 61 6b 3b 0a 09 09 63 61 ;....break;...ca
3250: 73 65 20 53 53 4c 5f 45 52 52 4f 52 5f 57 41 4e se SSL_ERROR_WAN
3260: 54 5f 52 45 41 44 3a 0a 09 09 09 64 70 72 69 6e T_READ:....dprin
3270: 74 66 28 22 47 6f 74 20 53 53 4c 5f 45 52 52 4f tf("Got SSL_ERRO
3280: 52 5f 57 41 4e 54 5f 52 45 41 44 2c 20 6d 61 70 R_WANT_READ, map
3290: 70 69 6e 67 20 74 68 69 73 20 74 6f 20 45 41 47 ping this to EAG
32a0: 41 49 4e 22 29 3b 0a 09 09 09 62 79 74 65 73 52 AIN");....bytesR
32b0: 65 61 64 20 3d 20 2d 31 3b 0a 09 09 09 2a 65 72 ead = -1;....*er
32c0: 72 6f 72 43 6f 64 65 50 74 72 20 3d 20 45 41 47 rorCodePtr = EAG
32d0: 41 49 4e 3b 0a 09 09 09 62 72 65 61 6b 3b 0a 09 AIN;....break;..
32e0: 09 64 65 66 61 75 6c 74 3a 0a 09 09 09 64 70 72 .default:....dpr
32f0: 69 6e 74 66 28 22 55 6e 6b 6e 6f 77 6e 20 65 72 intf("Unknown er
3300: 72 6f 72 20 28 65 72 72 20 3d 20 25 69 29 2c 20 ror (err = %i),
3310: 6d 61 70 70 69 6e 67 20 74 6f 20 45 4f 46 22 2c mapping to EOF",
3320: 20 65 72 72 29 3b 0a 09 09 09 2a 65 72 72 6f 72 err);....*error
3330: 43 6f 64 65 50 74 72 20 3d 20 30 3b 0a 09 09 09 CodePtr = 0;....
3340: 62 79 74 65 73 52 65 61 64 20 3d 20 30 3b 0a 09 bytesRead = 0;..
3350: 09 09 62 72 65 61 6b 3b 0a 09 7d 0a 0a 09 64 70 ..break;..}...dp
3360: 72 69 6e 74 66 28 22 49 6e 70 75 74 28 25 64 29 rintf("Input(%d)
3370: 20 2d 3e 20 25 64 20 5b 25 64 5d 22 2c 20 62 75 -> %d [%d]", bu
3380: 66 53 69 7a 65 2c 20 62 79 74 65 73 52 65 61 64 fSize, bytesRead
3390: 2c 20 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 29 , *errorCodePtr)
33a0: 3b 0a 09 72 65 74 75 72 6e 28 62 79 74 65 73 52 ;..return(bytesR
33b0: 65 61 64 29 3b 0a 7d 0a 0a 2f 2a 0a 20 2a 2d 2d ead);.}../*. *--
33c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
33d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
33e0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
33f0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
3400: 2d 0a 20 2a 0a 20 2a 20 54 6c 73 4f 75 74 70 75 -. *. * TlsOutpu
3410: 74 50 72 6f 63 20 2d 2d 0a 20 2a 0a 20 2a 09 54 tProc --. *. *.T
3420: 68 69 73 20 70 72 6f 63 65 64 75 72 65 20 69 73 his procedure is
3430: 20 69 6e 76 6f 6b 65 64 20 62 79 20 74 68 65 20 invoked by the
3440: 67 65 6e 65 72 69 63 20 49 4f 20 6c 65 76 65 6c generic IO level
3450: 0a 20 2a 20 20 20 20 20 20 20 74 6f 20 77 72 69 . * to wri
3460: 74 65 20 6f 75 74 70 75 74 20 74 6f 20 61 20 53 te output to a S
3470: 53 4c 20 73 6f 63 6b 65 74 20 62 61 73 65 64 20 SL socket based
3480: 63 68 61 6e 6e 65 6c 2e 0a 20 2a 0a 20 2a 20 52 channel.. *. * R
3490: 65 73 75 6c 74 73 3a 0a 20 2a 09 54 68 65 20 6e esults:. *.The n
34a0: 75 6d 62 65 72 20 6f 66 20 62 79 74 65 73 20 77 umber of bytes w
34b0: 72 69 74 74 65 6e 20 69 73 20 72 65 74 75 72 6e ritten is return
34c0: 65 64 2e 20 41 6e 20 6f 75 74 70 75 74 20 61 72 ed. An output ar
34d0: 67 75 6d 65 6e 74 20 69 73 0a 20 2a 09 73 65 74 gument is. *.set
34e0: 20 74 6f 20 61 20 50 4f 53 49 58 20 65 72 72 6f to a POSIX erro
34f0: 72 20 63 6f 64 65 20 69 66 20 61 6e 20 65 72 72 r code if an err
3500: 6f 72 20 6f 63 63 75 72 72 65 64 2c 20 6f 72 20 or occurred, or
3510: 7a 65 72 6f 2e 0a 20 2a 0a 20 2a 20 53 69 64 65 zero.. *. * Side
3520: 20 65 66 66 65 63 74 73 3a 0a 20 2a 09 57 72 69 effects:. *.Wri
3530: 74 65 73 20 6f 75 74 70 75 74 20 6f 6e 20 74 68 tes output on th
3540: 65 20 6f 75 74 70 75 74 20 64 65 76 69 63 65 20 e output device
3550: 6f 66 20 74 68 65 20 63 68 61 6e 6e 65 6c 2e 0a of the channel..
3560: 20 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d *. *-----------
3570: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
3580: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
3590: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
35a0: 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 2f 0a 0a 73 74 --------. */..st
35b0: 61 74 69 63 20 69 6e 74 20 54 6c 73 4f 75 74 70 atic int TlsOutp
35c0: 75 74 50 72 6f 63 28 76 6f 69 64 20 2a 69 6e 73 utProc(void *ins
35d0: 74 61 6e 63 65 44 61 74 61 2c 20 63 6f 6e 73 74 tanceData, const
35e0: 20 63 68 61 72 20 2a 62 75 66 2c 20 69 6e 74 20 char *buf, int
35f0: 74 6f 57 72 69 74 65 2c 20 69 6e 74 20 2a 65 72 toWrite, int *er
3600: 72 6f 72 43 6f 64 65 50 74 72 29 20 7b 0a 09 75 rorCodePtr) {..u
3610: 6e 73 69 67 6e 65 64 20 6c 6f 6e 67 20 62 61 63 nsigned long bac
3620: 6b 69 6e 67 45 72 72 6f 72 3b 0a 09 53 74 61 74 kingError;..Stat
3630: 65 20 2a 73 74 61 74 65 50 74 72 20 3d 20 28 53 e *statePtr = (S
3640: 74 61 74 65 20 2a 29 20 69 6e 73 74 61 6e 63 65 tate *) instance
3650: 44 61 74 61 3b 0a 09 69 6e 74 20 77 72 69 74 74 Data;..int writt
3660: 65 6e 2c 20 65 72 72 3b 0a 09 69 6e 74 20 74 6c en, err;..int tl
3670: 73 43 6f 6e 6e 65 63 74 3b 0a 0a 09 2a 65 72 72 sConnect;...*err
3680: 6f 72 43 6f 64 65 50 74 72 20 3d 20 30 3b 0a 0a orCodePtr = 0;..
3690: 09 64 70 72 69 6e 74 66 28 22 42 49 4f 5f 77 72 .dprintf("BIO_wr
36a0: 69 74 65 28 25 70 2c 20 25 64 29 22 2c 20 28 76 ite(%p, %d)", (v
36b0: 6f 69 64 20 2a 29 20 73 74 61 74 65 50 74 72 2c oid *) statePtr,
36c0: 20 74 6f 57 72 69 74 65 29 3b 0a 09 64 70 72 69 toWrite);..dpri
36d0: 6e 74 42 75 66 66 65 72 28 62 75 66 2c 20 74 6f ntBuffer(buf, to
36e0: 57 72 69 74 65 29 3b 0a 0a 09 69 66 20 28 73 74 Write);...if (st
36f0: 61 74 65 50 74 72 2d 3e 66 6c 61 67 73 20 26 20 atePtr->flags &
3700: 54 4c 53 5f 54 43 4c 5f 43 41 4c 4c 42 41 43 4b TLS_TCL_CALLBACK
3710: 29 20 7b 0a 09 09 64 70 72 69 6e 74 66 28 22 44 ) {...dprintf("D
3720: 6f 6e 27 74 20 70 72 6f 63 65 73 73 20 6f 75 74 on't process out
3730: 70 75 74 20 77 68 69 6c 65 20 63 61 6c 6c 62 61 put while callba
3740: 63 6b 73 20 61 72 65 20 72 75 6e 6e 69 6e 67 22 cks are running"
3750: 29 0a 09 09 77 72 69 74 74 65 6e 20 3d 20 2d 31 )...written = -1
3760: 3b 0a 09 09 2a 65 72 72 6f 72 43 6f 64 65 50 74 ;...*errorCodePt
3770: 72 20 3d 20 45 41 47 41 49 4e 3b 0a 09 09 72 65 r = EAGAIN;...re
3780: 74 75 72 6e 28 2d 31 29 3b 0a 09 7d 0a 0a 09 64 turn(-1);..}...d
3790: 70 72 69 6e 74 66 28 22 43 61 6c 6c 69 6e 67 20 printf("Calling
37a0: 54 6c 73 5f 57 61 69 74 46 6f 72 43 6f 6e 6e 65 Tls_WaitForConne
37b0: 63 74 22 29 3b 0a 09 74 6c 73 43 6f 6e 6e 65 63 ct");..tlsConnec
37c0: 74 20 3d 20 54 6c 73 5f 57 61 69 74 46 6f 72 43 t = Tls_WaitForC
37d0: 6f 6e 6e 65 63 74 28 73 74 61 74 65 50 74 72 2c onnect(statePtr,
37e0: 20 65 72 72 6f 72 43 6f 64 65 50 74 72 2c 20 31 errorCodePtr, 1
37f0: 29 3b 0a 09 69 66 20 28 74 6c 73 43 6f 6e 6e 65 );..if (tlsConne
3800: 63 74 20 3c 20 30 29 20 7b 0a 09 09 64 70 72 69 ct < 0) {...dpri
3810: 6e 74 66 28 22 47 6f 74 20 61 6e 20 65 72 72 6f ntf("Got an erro
3820: 72 20 77 61 69 74 69 6e 67 20 74 6f 20 63 6f 6e r waiting to con
3830: 6e 65 63 74 20 28 74 6c 73 43 6f 6e 6e 65 63 74 nect (tlsConnect
3840: 20 3d 20 25 69 2c 20 2a 65 72 72 6f 72 43 6f 64 = %i, *errorCod
3850: 65 50 74 72 20 3d 20 25 69 29 22 2c 20 74 6c 73 ePtr = %i)", tls
3860: 43 6f 6e 6e 65 63 74 2c 20 2a 65 72 72 6f 72 43 Connect, *errorC
3870: 6f 64 65 50 74 72 29 3b 0a 0a 09 09 77 72 69 74 odePtr);....writ
3880: 74 65 6e 20 3d 20 2d 31 3b 0a 09 09 69 66 20 28 ten = -1;...if (
3890: 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 20 3d 3d *errorCodePtr ==
38a0: 20 45 43 4f 4e 4e 52 45 53 45 54 29 20 7b 0a 09 ECONNRESET) {..
38b0: 09 09 64 70 72 69 6e 74 66 28 22 47 6f 74 20 63 ..dprintf("Got c
38c0: 6f 6e 6e 65 63 74 69 6f 6e 20 72 65 73 65 74 22 onnection reset"
38d0: 29 3b 0a 09 09 09 2f 2a 20 53 6f 66 74 20 45 4f );..../* Soft EO
38e0: 46 20 2a 2f 0a 09 09 09 2a 65 72 72 6f 72 43 6f F */....*errorCo
38f0: 64 65 50 74 72 20 3d 20 30 3b 0a 09 09 09 77 72 dePtr = 0;....wr
3900: 69 74 74 65 6e 20 3d 20 30 3b 0a 09 09 7d 0a 0a itten = 0;...}..
3910: 09 09 72 65 74 75 72 6e 28 77 72 69 74 74 65 6e ..return(written
3920: 29 3b 0a 09 7d 0a 0a 09 69 66 20 28 74 6f 57 72 );..}...if (toWr
3930: 69 74 65 20 3d 3d 20 30 29 20 7b 0a 09 09 64 70 ite == 0) {...dp
3940: 72 69 6e 74 66 28 22 7a 65 72 6f 2d 77 72 69 74 rintf("zero-writ
3950: 65 22 29 3b 0a 09 09 65 72 72 20 3d 20 42 49 4f e");...err = BIO
3960: 5f 66 6c 75 73 68 28 73 74 61 74 65 50 74 72 2d _flush(statePtr-
3970: 3e 62 69 6f 29 3b 0a 0a 09 09 69 66 20 28 65 72 >bio);....if (er
3980: 72 20 3c 3d 20 30 29 20 7b 0a 09 09 09 64 70 72 r <= 0) {....dpr
3990: 69 6e 74 66 28 22 46 6c 75 73 68 69 6e 67 20 66 intf("Flushing f
39a0: 61 69 6c 65 64 22 29 3b 0a 0a 09 09 09 2a 65 72 ailed");.....*er
39b0: 72 6f 72 43 6f 64 65 50 74 72 20 3d 20 45 49 4f rorCodePtr = EIO
39c0: 3b 0a 09 09 09 77 72 69 74 74 65 6e 20 3d 20 30 ;....written = 0
39d0: 3b 0a 09 09 09 72 65 74 75 72 6e 28 2d 31 29 3b ;....return(-1);
39e0: 0a 09 09 7d 0a 0a 09 09 77 72 69 74 74 65 6e 20 ...}....written
39f0: 3d 20 30 3b 0a 09 09 2a 65 72 72 6f 72 43 6f 64 = 0;...*errorCod
3a00: 65 50 74 72 20 3d 20 30 3b 0a 09 09 72 65 74 75 ePtr = 0;...retu
3a10: 72 6e 28 30 29 3b 0a 09 7d 0a 0a 09 2f 2a 0a 09 rn(0);..}.../*..
3a20: 20 2a 20 57 65 20 6e 65 65 64 20 74 6f 20 63 6c * We need to cl
3a30: 65 61 72 20 74 68 65 20 53 53 4c 20 65 72 72 6f ear the SSL erro
3a40: 72 20 73 74 61 63 6b 20 6e 6f 77 20 62 65 63 61 r stack now beca
3a50: 75 73 65 20 77 65 20 73 6f 6d 65 74 69 6d 65 73 use we sometimes
3a60: 20 72 65 61 63 68 0a 09 20 2a 20 74 68 69 73 20 reach.. * this
3a70: 66 75 6e 63 74 69 6f 6e 20 77 69 74 68 20 6c 65 function with le
3a80: 66 74 6f 76 65 72 20 65 72 72 6f 72 73 20 69 6e ftover errors in
3a90: 20 74 68 65 20 73 74 61 63 6b 2e 20 20 49 66 20 the stack. If
3aa0: 42 49 4f 5f 77 72 69 74 65 0a 09 20 2a 20 72 65 BIO_write.. * re
3ab0: 74 75 72 6e 73 20 2d 31 20 61 6e 64 20 69 6e 74 turns -1 and int
3ac0: 65 6e 64 73 20 45 41 47 41 49 4e 2c 20 74 68 65 ends EAGAIN, the
3ad0: 72 65 20 69 73 20 61 20 6c 65 66 74 6f 76 65 72 re is a leftover
3ae0: 20 65 72 72 6f 72 2c 20 69 74 20 77 69 6c 6c 20 error, it will
3af0: 62 65 0a 09 20 2a 20 6d 69 73 63 6f 6e 73 74 72 be.. * misconstr
3b00: 75 65 64 20 61 73 20 61 6e 20 65 72 72 6f 72 2c ued as an error,
3b10: 20 6e 6f 74 20 45 41 47 41 49 4e 2e 0a 09 20 2a not EAGAIN... *
3b20: 0a 09 20 2a 20 41 6c 74 65 72 6e 61 74 69 76 65 .. * Alternative
3b30: 6c 79 2c 20 77 65 20 6d 61 79 20 77 61 6e 74 20 ly, we may want
3b40: 74 6f 20 68 61 6e 64 6c 65 20 74 68 65 20 3c 30 to handle the <0
3b50: 20 72 65 74 75 72 6e 20 63 6f 64 65 73 20 66 72 return codes fr
3b60: 6f 6d 0a 09 20 2a 20 42 49 4f 5f 77 72 69 74 65 om.. * BIO_write
3b70: 20 73 70 65 63 69 61 6c 6c 79 20 28 61 73 20 61 specially (as a
3b80: 64 76 69 73 65 64 20 69 6e 20 74 68 65 20 52 53 dvised in the RS
3b90: 41 20 64 6f 63 73 29 2e 20 20 54 4c 53 27 73 20 A docs). TLS's
3ba0: 6c 6f 77 65 72 20 6c 65 76 65 6c 0a 09 20 2a 20 lower level.. *
3bb0: 42 49 4f 20 66 75 6e 63 74 69 6f 6e 73 20 70 6c BIO functions pl
3bc0: 61 79 20 77 69 74 68 20 74 68 65 20 72 65 74 72 ay with the retr
3bd0: 79 20 66 6c 61 67 73 20 74 68 6f 75 67 68 2c 20 y flags though,
3be0: 61 6e 64 20 74 68 69 73 20 73 65 65 6d 73 20 74 and this seems t
3bf0: 6f 0a 09 20 2a 20 77 6f 72 6b 20 63 6f 72 72 65 o.. * work corre
3c00: 63 74 6c 79 2e 20 20 53 69 6d 69 6c 61 72 20 66 ctly. Similar f
3c10: 69 78 20 69 6e 20 54 6c 73 49 6e 70 75 74 50 72 ix in TlsInputPr
3c20: 6f 63 2e 20 2d 20 68 6f 62 62 73 0a 09 20 2a 2f oc. - hobbs.. */
3c30: 0a 09 45 52 52 5f 63 6c 65 61 72 5f 65 72 72 6f ..ERR_clear_erro
3c40: 72 28 29 3b 0a 09 77 72 69 74 74 65 6e 20 3d 20 r();..written =
3c50: 42 49 4f 5f 77 72 69 74 65 28 73 74 61 74 65 50 BIO_write(stateP
3c60: 74 72 2d 3e 62 69 6f 2c 20 62 75 66 2c 20 74 6f tr->bio, buf, to
3c70: 57 72 69 74 65 29 3b 0a 09 64 70 72 69 6e 74 66 Write);..dprintf
3c80: 28 22 42 49 4f 5f 77 72 69 74 65 28 25 70 2c 20 ("BIO_write(%p,
3c90: 25 64 29 20 2d 3e 20 5b 25 64 5d 22 2c 20 28 76 %d) -> [%d]", (v
3ca0: 6f 69 64 20 2a 29 20 73 74 61 74 65 50 74 72 2c oid *) statePtr,
3cb0: 20 74 6f 57 72 69 74 65 2c 20 77 72 69 74 74 65 toWrite, writte
3cc0: 6e 29 3b 0a 0a 09 65 72 72 20 3d 20 53 53 4c 5f n);...err = SSL_
3cd0: 67 65 74 5f 65 72 72 6f 72 28 73 74 61 74 65 50 get_error(stateP
3ce0: 74 72 2d 3e 73 73 6c 2c 20 77 72 69 74 74 65 6e tr->ssl, written
3cf0: 29 3b 0a 09 73 77 69 74 63 68 20 28 65 72 72 29 );..switch (err)
3d00: 20 7b 0a 09 09 63 61 73 65 20 53 53 4c 5f 45 52 {...case SSL_ER
3d10: 52 4f 52 5f 4e 4f 4e 45 3a 0a 09 09 09 69 66 20 ROR_NONE:....if
3d20: 28 77 72 69 74 74 65 6e 20 3c 20 30 29 20 7b 0a (written < 0) {.
3d30: 09 09 09 09 77 72 69 74 74 65 6e 20 3d 20 30 3b ....written = 0;
3d40: 0a 09 09 09 7d 0a 09 09 09 62 72 65 61 6b 3b 0a ....}....break;.
3d50: 09 09 63 61 73 65 20 53 53 4c 5f 45 52 52 4f 52 ..case SSL_ERROR
3d60: 5f 57 41 4e 54 5f 57 52 49 54 45 3a 0a 09 09 09 _WANT_WRITE:....
3d70: 64 70 72 69 6e 74 66 28 22 47 6f 74 20 53 53 4c dprintf("Got SSL
3d80: 5f 45 52 52 4f 52 5f 57 41 4e 54 5f 57 52 49 54 _ERROR_WANT_WRIT
3d90: 45 2c 20 6d 61 70 70 69 6e 67 20 69 74 20 74 6f E, mapping it to
3da0: 20 45 41 47 41 49 4e 22 29 3b 0a 09 09 09 2a 65 EAGAIN");....*e
3db0: 72 72 6f 72 43 6f 64 65 50 74 72 20 3d 20 45 41 rrorCodePtr = EA
3dc0: 47 41 49 4e 3b 0a 09 09 09 77 72 69 74 74 65 6e GAIN;....written
3dd0: 20 3d 20 2d 31 3b 0a 09 09 09 62 72 65 61 6b 3b = -1;....break;
3de0: 0a 09 09 63 61 73 65 20 53 53 4c 5f 45 52 52 4f ...case SSL_ERRO
3df0: 52 5f 57 41 4e 54 5f 52 45 41 44 3a 0a 09 09 09 R_WANT_READ:....
3e00: 64 70 72 69 6e 74 66 28 22 20 77 72 69 74 65 20 dprintf(" write
3e10: 52 20 42 4c 4f 43 4b 22 29 3b 0a 09 09 09 62 72 R BLOCK");....br
3e20: 65 61 6b 3b 0a 09 09 63 61 73 65 20 53 53 4c 5f eak;...case SSL_
3e30: 45 52 52 4f 52 5f 57 41 4e 54 5f 58 35 30 39 5f ERROR_WANT_X509_
3e40: 4c 4f 4f 4b 55 50 3a 0a 09 09 09 64 70 72 69 6e LOOKUP:....dprin
3e50: 74 66 28 22 20 77 72 69 74 65 20 58 20 42 4c 4f tf(" write X BLO
3e60: 43 4b 22 29 3b 0a 09 09 09 62 72 65 61 6b 3b 0a CK");....break;.
3e70: 09 09 63 61 73 65 20 53 53 4c 5f 45 52 52 4f 52 ..case SSL_ERROR
3e80: 5f 5a 45 52 4f 5f 52 45 54 55 52 4e 3a 0a 09 09 _ZERO_RETURN:...
3e90: 09 64 70 72 69 6e 74 66 28 22 20 63 6c 6f 73 65 .dprintf(" close
3ea0: 64 22 29 3b 0a 09 09 09 77 72 69 74 74 65 6e 20 d");....written
3eb0: 3d 20 30 3b 0a 09 09 09 2a 65 72 72 6f 72 43 6f = 0;....*errorCo
3ec0: 64 65 50 74 72 20 3d 20 30 3b 0a 09 09 09 62 72 dePtr = 0;....br
3ed0: 65 61 6b 3b 0a 09 09 63 61 73 65 20 53 53 4c 5f eak;...case SSL_
3ee0: 45 52 52 4f 52 5f 53 59 53 43 41 4c 4c 3a 0a 09 ERROR_SYSCALL:..
3ef0: 09 09 62 61 63 6b 69 6e 67 45 72 72 6f 72 20 3d ..backingError =
3f00: 20 45 52 52 5f 67 65 74 5f 65 72 72 6f 72 28 29 ERR_get_error()
3f10: 3b 0a 0a 09 09 09 69 66 20 28 62 61 63 6b 69 6e ;.....if (backin
3f20: 67 45 72 72 6f 72 20 3d 3d 20 30 20 26 26 20 77 gError == 0 && w
3f30: 72 69 74 74 65 6e 20 3d 3d 20 30 29 20 7b 0a 09 ritten == 0) {..
3f40: 09 09 09 64 70 72 69 6e 74 66 28 22 45 4f 46 20 ...dprintf("EOF
3f50: 72 65 61 63 68 65 64 22 29 0a 09 09 09 09 2a 65 reached").....*e
3f60: 72 72 6f 72 43 6f 64 65 50 74 72 20 3d 20 30 3b rrorCodePtr = 0;
3f70: 0a 09 09 09 09 77 72 69 74 74 65 6e 20 3d 20 30 .....written = 0
3f80: 3b 0a 09 09 09 7d 20 65 6c 73 65 20 69 66 20 28 ;....} else if (
3f90: 62 61 63 6b 69 6e 67 45 72 72 6f 72 20 3d 3d 20 backingError ==
3fa0: 30 20 26 26 20 77 72 69 74 74 65 6e 20 3d 3d 20 0 && written ==
3fb0: 2d 31 29 20 7b 0a 09 09 09 09 64 70 72 69 6e 74 -1) {.....dprint
3fc0: 66 28 22 49 2f 4f 20 65 72 72 6f 72 20 6f 63 63 f("I/O error occ
3fd0: 75 72 65 64 20 28 65 72 72 6e 6f 20 3d 20 25 6c ured (errno = %l
3fe0: 75 29 22 2c 20 28 75 6e 73 69 67 6e 65 64 20 6c u)", (unsigned l
3ff0: 6f 6e 67 29 20 54 63 6c 5f 47 65 74 45 72 72 6e ong) Tcl_GetErrn
4000: 6f 28 29 29 3b 0a 09 09 09 09 2a 65 72 72 6f 72 o());.....*error
4010: 43 6f 64 65 50 74 72 20 3d 20 54 63 6c 5f 47 65 CodePtr = Tcl_Ge
4020: 74 45 72 72 6e 6f 28 29 3b 0a 09 09 09 09 77 72 tErrno();.....wr
4030: 69 74 74 65 6e 20 3d 20 2d 31 3b 0a 09 09 09 7d itten = -1;....}
4040: 20 65 6c 73 65 20 7b 0a 09 09 09 09 64 70 72 69 else {.....dpri
4050: 6e 74 66 28 22 49 2f 4f 20 65 72 72 6f 72 20 6f ntf("I/O error o
4060: 63 63 75 72 65 64 20 28 62 61 63 6b 69 6e 67 45 ccured (backingE
4070: 72 72 6f 72 20 3d 20 25 6c 75 29 22 2c 20 62 61 rror = %lu)", ba
4080: 63 6b 69 6e 67 45 72 72 6f 72 29 3b 0a 09 09 09 ckingError);....
4090: 09 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 20 3d .*errorCodePtr =
40a0: 20 62 61 63 6b 69 6e 67 45 72 72 6f 72 3b 0a 09 backingError;..
40b0: 09 09 09 77 72 69 74 74 65 6e 20 3d 20 2d 31 3b ...written = -1;
40c0: 0a 09 09 09 7d 0a 0a 09 09 09 62 72 65 61 6b 3b ....}.....break;
40d0: 0a 09 09 63 61 73 65 20 53 53 4c 5f 45 52 52 4f ...case SSL_ERRO
40e0: 52 5f 53 53 4c 3a 0a 09 09 09 54 6c 73 5f 45 72 R_SSL:....Tls_Er
40f0: 72 6f 72 28 73 74 61 74 65 50 74 72 2c 20 54 43 ror(statePtr, TC
4100: 4c 54 4c 53 5f 53 53 4c 5f 45 52 52 4f 52 28 73 LTLS_SSL_ERROR(s
4110: 74 61 74 65 50 74 72 2d 3e 73 73 6c 2c 20 77 72 tatePtr->ssl, wr
4120: 69 74 74 65 6e 29 29 3b 0a 09 09 09 2a 65 72 72 itten));....*err
4130: 6f 72 43 6f 64 65 50 74 72 20 3d 20 45 43 4f 4e orCodePtr = ECON
4140: 4e 41 42 4f 52 54 45 44 3b 0a 09 09 09 77 72 69 NABORTED;....wri
4150: 74 74 65 6e 20 3d 20 2d 31 3b 0a 09 09 09 62 72 tten = -1;....br
4160: 65 61 6b 3b 0a 09 09 64 65 66 61 75 6c 74 3a 0a eak;...default:.
4170: 09 09 09 64 70 72 69 6e 74 66 28 22 20 75 6e 6b ...dprintf(" unk
4180: 6e 6f 77 6e 20 65 72 72 3a 20 25 64 22 2c 20 65 nown err: %d", e
4190: 72 72 29 3b 0a 09 09 09 62 72 65 61 6b 3b 0a 09 rr);....break;..
41a0: 7d 0a 0a 09 64 70 72 69 6e 74 66 28 22 4f 75 74 }...dprintf("Out
41b0: 70 75 74 28 25 64 29 20 2d 3e 20 25 64 22 2c 20 put(%d) -> %d",
41c0: 74 6f 57 72 69 74 65 2c 20 77 72 69 74 74 65 6e toWrite, written
41d0: 29 3b 0a 09 72 65 74 75 72 6e 28 77 72 69 74 74 );..return(writt
41e0: 65 6e 29 3b 0a 7d 0a 0a 2f 2a 0a 20 2a 2d 2d 2d en);.}../*. *---
41f0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
4200: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
4210: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
4220: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
4230: 0a 20 2a 0a 20 2a 20 54 6c 73 47 65 74 4f 70 74 . *. * TlsGetOpt
4240: 69 6f 6e 50 72 6f 63 20 2d 2d 0a 20 2a 0a 20 2a ionProc --. *. *
4250: 09 43 6f 6d 70 75 74 65 73 20 61 6e 20 6f 70 74 .Computes an opt
4260: 69 6f 6e 20 76 61 6c 75 65 20 66 6f 72 20 61 20 ion value for a
4270: 53 53 4c 20 73 6f 63 6b 65 74 20 62 61 73 65 64 SSL socket based
4280: 20 63 68 61 6e 6e 65 6c 2c 20 6f 72 20 61 0a 20 channel, or a.
4290: 2a 09 6c 69 73 74 20 6f 66 20 61 6c 6c 20 6f 70 *.list of all op
42a0: 74 69 6f 6e 73 20 61 6e 64 20 74 68 65 69 72 20 tions and their
42b0: 76 61 6c 75 65 73 2e 0a 20 2a 0a 20 2a 20 52 65 values.. *. * Re
42c0: 73 75 6c 74 73 3a 0a 20 2a 09 41 20 73 74 61 6e sults:. *.A stan
42d0: 64 61 72 64 20 54 63 6c 20 72 65 73 75 6c 74 2e dard Tcl result.
42e0: 20 54 68 65 20 76 61 6c 75 65 20 6f 66 20 74 68 The value of th
42f0: 65 20 73 70 65 63 69 66 69 65 64 20 6f 70 74 69 e specified opti
4300: 6f 6e 20 6f 72 20 61 0a 20 2a 09 6c 69 73 74 20 on or a. *.list
4310: 6f 66 20 61 6c 6c 20 6f 70 74 69 6f 6e 73 20 61 of all options a
4320: 6e 64 09 74 68 65 69 72 20 76 61 6c 75 65 73 20 nd.their values
4330: 69 73 20 72 65 74 75 72 6e 65 64 20 69 6e 20 74 is returned in t
4340: 68 65 0a 20 2a 09 73 75 70 70 6c 69 65 64 20 44 he. *.supplied D
4350: 53 74 72 69 6e 67 2e 0a 20 2a 0a 20 2a 20 53 69 String.. *. * Si
4360: 64 65 20 65 66 66 65 63 74 73 3a 0a 20 2a 09 4e de effects:. *.N
4370: 6f 6e 65 2e 0a 20 2a 0a 20 2a 2d 2d 2d 2d 2d 2d one.. *. *------
4380: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
4390: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
43a0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
43b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a -------------. *
43c0: 2f 0a 73 74 61 74 69 63 20 69 6e 74 0a 54 6c 73 /.static int.Tls
43d0: 47 65 74 4f 70 74 69 6f 6e 50 72 6f 63 28 76 6f GetOptionProc(vo
43e0: 69 64 20 2a 69 6e 73 74 61 6e 63 65 44 61 74 61 id *instanceData
43f0: 2c 09 2f 2a 20 53 6f 63 6b 65 74 20 73 74 61 74 ,./* Socket stat
4400: 65 2e 20 2a 2f 0a 09 54 63 6c 5f 49 6e 74 65 72 e. */..Tcl_Inter
4410: 70 20 2a 69 6e 74 65 72 70 2c 09 09 2f 2a 20 46 p *interp,../* F
4420: 6f 72 20 65 72 72 6f 72 73 20 2d 20 63 61 6e 20 or errors - can
4430: 62 65 20 4e 55 4c 4c 2e 20 2a 2f 0a 09 63 6f 6e be NULL. */..con
4440: 73 74 20 63 68 61 72 20 2a 6f 70 74 69 6f 6e 4e st char *optionN
4450: 61 6d 65 2c 09 09 2f 2a 20 4e 61 6d 65 20 6f 66 ame,../* Name of
4460: 20 74 68 65 20 6f 70 74 69 6f 6e 20 74 6f 0a 09 the option to..
4470: 09 09 09 09 20 2a 20 72 65 74 72 69 65 76 65 20 .... * retrieve
4480: 74 68 65 20 76 61 6c 75 65 20 66 6f 72 2c 20 6f the value for, o
4490: 72 0a 09 09 09 09 09 20 2a 20 4e 55 4c 4c 20 74 r...... * NULL t
44a0: 6f 20 67 65 74 20 61 6c 6c 20 6f 70 74 69 6f 6e o get all option
44b0: 73 20 61 6e 64 0a 09 09 09 09 09 20 2a 20 74 68 s and...... * th
44c0: 65 69 72 20 76 61 6c 75 65 73 2e 20 2a 2f 0a 09 eir values. */..
44d0: 54 63 6c 5f 44 53 74 72 69 6e 67 20 2a 64 73 50 Tcl_DString *dsP
44e0: 74 72 29 09 09 2f 2a 20 57 68 65 72 65 20 74 6f tr)../* Where to
44f0: 20 73 74 6f 72 65 20 74 68 65 20 63 6f 6d 70 75 store the compu
4500: 74 65 64 20 76 61 6c 75 65 0a 09 09 09 09 09 20 ted value......
4510: 2a 20 69 6e 69 74 69 61 6c 69 7a 65 64 20 62 79 * initialized by
4520: 20 63 61 6c 6c 65 72 2e 20 2a 2f 0a 7b 0a 20 20 caller. */.{.
4530: 20 20 53 74 61 74 65 20 2a 73 74 61 74 65 50 74 State *statePt
4540: 72 20 3d 20 28 53 74 61 74 65 20 2a 29 20 69 6e r = (State *) in
4550: 73 74 61 6e 63 65 44 61 74 61 3b 0a 0a 20 20 20 stanceData;..
4560: 54 63 6c 5f 43 68 61 6e 6e 65 6c 20 64 6f 77 6e Tcl_Channel down
4570: 43 68 61 6e 20 3d 20 54 6c 73 5f 47 65 74 50 61 Chan = Tls_GetPa
4580: 72 65 6e 74 28 73 74 61 74 65 50 74 72 2c 20 54 rent(statePtr, T
4590: 4c 53 5f 54 43 4c 5f 46 41 53 54 50 41 54 48 29 LS_TCL_FASTPATH)
45a0: 3b 0a 20 20 20 54 63 6c 5f 44 72 69 76 65 72 47 ;. Tcl_DriverG
45b0: 65 74 4f 70 74 69 6f 6e 50 72 6f 63 20 2a 67 65 etOptionProc *ge
45c0: 74 4f 70 74 69 6f 6e 50 72 6f 63 3b 0a 0a 20 20 tOptionProc;..
45d0: 20 20 67 65 74 4f 70 74 69 6f 6e 50 72 6f 63 20 getOptionProc
45e0: 3d 20 54 63 6c 5f 43 68 61 6e 6e 65 6c 47 65 74 = Tcl_ChannelGet
45f0: 4f 70 74 69 6f 6e 50 72 6f 63 28 54 63 6c 5f 47 OptionProc(Tcl_G
4600: 65 74 43 68 61 6e 6e 65 6c 54 79 70 65 28 64 6f etChannelType(do
4610: 77 6e 43 68 61 6e 29 29 3b 0a 20 20 20 20 69 66 wnChan));. if
4620: 20 28 67 65 74 4f 70 74 69 6f 6e 50 72 6f 63 20 (getOptionProc
4630: 21 3d 20 4e 55 4c 4c 29 20 7b 0a 20 20 20 20 20 != NULL) {.
4640: 20 20 20 72 65 74 75 72 6e 20 28 2a 67 65 74 4f return (*getO
4650: 70 74 69 6f 6e 50 72 6f 63 29 28 54 63 6c 5f 47 ptionProc)(Tcl_G
4660: 65 74 43 68 61 6e 6e 65 6c 49 6e 73 74 61 6e 63 etChannelInstanc
4670: 65 44 61 74 61 28 64 6f 77 6e 43 68 61 6e 29 2c eData(downChan),
4680: 20 69 6e 74 65 72 70 2c 20 6f 70 74 69 6f 6e 4e interp, optionN
4690: 61 6d 65 2c 20 64 73 50 74 72 29 3b 0a 20 20 20 ame, dsPtr);.
46a0: 20 7d 20 65 6c 73 65 20 69 66 20 28 6f 70 74 69 } else if (opti
46b0: 6f 6e 4e 61 6d 65 20 3d 3d 20 28 63 68 61 72 2a onName == (char*
46c0: 29 20 4e 55 4c 4c 29 20 7b 0a 20 20 20 20 20 20 ) NULL) {.
46d0: 20 20 2f 2a 0a 20 20 20 20 20 20 20 20 20 2a 20 /*. *
46e0: 52 65 71 75 65 73 74 20 69 73 20 71 75 65 72 79 Request is query
46f0: 20 66 6f 72 20 61 6c 6c 20 6f 70 74 69 6f 6e 73 for all options
4700: 2c 20 74 68 69 73 20 69 73 20 6f 6b 2e 0a 20 20 , this is ok..
4710: 20 20 20 20 20 20 20 2a 2f 0a 20 20 20 20 20 20 */.
4720: 20 20 20 72 65 74 75 72 6e 20 54 43 4c 5f 4f 4b return TCL_OK
4730: 3b 0a 20 20 20 20 7d 0a 20 20 20 20 2f 2a 0a 20 ;. }. /*.
4740: 20 20 20 20 2a 20 52 65 71 75 65 73 74 20 66 6f * Request fo
4750: 72 20 61 20 73 70 65 63 69 66 69 63 20 6f 70 74 r a specific opt
4760: 69 6f 6e 20 68 61 73 20 74 6f 20 66 61 69 6c 2c ion has to fail,
4770: 20 77 65 20 64 6f 6e 27 74 20 68 61 76 65 20 61 we don't have a
4780: 6e 79 2e 0a 20 20 20 20 20 2a 2f 0a 20 20 20 20 ny.. */.
4790: 72 65 74 75 72 6e 20 54 43 4c 5f 45 52 52 4f 52 return TCL_ERROR
47a0: 3b 0a 7d 0a 0a 2f 2a 0a 20 2a 2d 2d 2d 2d 2d 2d ;.}../*. *------
47b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
47c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
47d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
47e0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a -------------. *
47f0: 0a 20 2a 20 54 6c 73 57 61 74 63 68 50 72 6f 63 . * TlsWatchProc
4800: 20 2d 2d 0a 20 2a 0a 20 2a 09 49 6e 69 74 69 61 --. *. *.Initia
4810: 6c 69 7a 65 20 74 68 65 20 6e 6f 74 69 66 69 65 lize the notifie
4820: 72 20 74 6f 20 77 61 74 63 68 20 54 63 6c 5f 46 r to watch Tcl_F
4830: 69 6c 65 73 20 66 72 6f 6d 20 74 68 69 73 20 63 iles from this c
4840: 68 61 6e 6e 65 6c 2e 0a 20 2a 0a 20 2a 20 52 65 hannel.. *. * Re
4850: 73 75 6c 74 73 3a 0a 20 2a 09 4e 6f 6e 65 2e 0a sults:. *.None..
4860: 20 2a 0a 20 2a 20 53 69 64 65 20 65 66 66 65 63 *. * Side effec
4870: 74 73 3a 0a 20 2a 09 53 65 74 73 20 75 70 20 74 ts:. *.Sets up t
4880: 68 65 20 6e 6f 74 69 66 69 65 72 20 73 6f 20 74 he notifier so t
4890: 68 61 74 20 61 20 66 75 74 75 72 65 20 65 76 65 hat a future eve
48a0: 6e 74 20 6f 6e 20 74 68 65 20 63 68 61 6e 6e 65 nt on the channe
48b0: 6c 0a 20 2a 09 77 69 6c 6c 20 62 65 20 73 65 65 l. *.will be see
48c0: 6e 20 62 79 20 54 63 6c 2e 0a 20 2a 0a 20 2a 2d n by Tcl.. *. *-
48d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
48e0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
48f0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
4900: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
4910: 2d 2d 0a 20 2a 2f 0a 0a 73 74 61 74 69 63 20 76 --. */..static v
4920: 6f 69 64 0a 54 6c 73 57 61 74 63 68 50 72 6f 63 oid.TlsWatchProc
4930: 28 76 6f 69 64 20 2a 69 6e 73 74 61 6e 63 65 44 (void *instanceD
4940: 61 74 61 2c 09 2f 2a 20 54 68 65 20 73 6f 63 6b ata,./* The sock
4950: 65 74 20 73 74 61 74 65 2e 20 2a 2f 0a 20 20 20 et state. */.
4960: 20 20 20 20 20 20 20 20 20 20 69 6e 74 20 6d 61 int ma
4970: 73 6b 29 09 09 09 2f 2a 20 45 76 65 6e 74 73 20 sk).../* Events
4980: 6f 66 20 69 6e 74 65 72 65 73 74 3b 20 61 6e 20 of interest; an
4990: 4f 52 2d 65 64 0a 20 20 20 20 20 20 20 20 20 20 OR-ed.
49a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
49b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2a *
49c0: 20 63 6f 6d 62 69 6e 61 74 69 6f 6e 20 6f 66 20 combination of
49d0: 54 43 4c 5f 52 45 41 44 41 42 4c 45 2c 0a 20 20 TCL_READABLE,.
49e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
49f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
4a00: 20 20 20 20 20 20 20 2a 20 54 43 4c 5f 57 52 49 * TCL_WRI
4a10: 54 41 42 4c 45 20 61 6e 64 20 54 43 4c 5f 45 58 TABLE and TCL_EX
4a20: 43 45 50 54 49 4f 4e 2e 20 2a 2f 0a 7b 0a 20 20 CEPTION. */.{.
4a30: 20 20 54 63 6c 5f 43 68 61 6e 6e 65 6c 20 20 20 Tcl_Channel
4a40: 20 20 64 6f 77 6e 43 68 61 6e 3b 0a 20 20 20 20 downChan;.
4a50: 53 74 61 74 65 20 2a 73 74 61 74 65 50 74 72 20 State *statePtr
4a60: 3d 20 28 53 74 61 74 65 20 2a 29 20 69 6e 73 74 = (State *) inst
4a70: 61 6e 63 65 44 61 74 61 3b 0a 0a 20 20 20 20 64 anceData;.. d
4a80: 70 72 69 6e 74 66 28 22 54 6c 73 57 61 74 63 68 printf("TlsWatch
4a90: 50 72 6f 63 28 30 78 25 78 29 22 2c 20 6d 61 73 Proc(0x%x)", mas
4aa0: 6b 29 3b 0a 0a 20 20 20 20 2f 2a 20 50 72 65 74 k);.. /* Pret
4ab0: 65 6e 64 20 74 6f 20 62 65 20 64 65 61 64 20 61 end to be dead a
4ac0: 73 20 6c 6f 6e 67 20 61 73 20 74 68 65 20 76 65 s long as the ve
4ad0: 72 69 66 79 20 63 61 6c 6c 62 61 63 6b 20 69 73 rify callback is
4ae0: 20 72 75 6e 6e 69 6e 67 2e 0a 20 20 20 20 20 2a running.. *
4af0: 20 4f 74 68 65 72 77 69 73 65 20 74 68 61 74 20 Otherwise that
4b00: 63 61 6c 6c 62 61 63 6b 20 63 6f 75 6c 64 20 62 callback could b
4b10: 65 20 69 6e 76 6f 6b 65 64 20 72 65 63 75 72 73 e invoked recurs
4b20: 69 76 65 6c 79 2e 20 2a 2f 0a 20 20 20 20 69 66 ively. */. if
4b30: 20 28 73 74 61 74 65 50 74 72 2d 3e 66 6c 61 67 (statePtr->flag
4b40: 73 20 26 20 54 4c 53 5f 54 43 4c 5f 43 41 4c 4c s & TLS_TCL_CALL
4b50: 42 41 43 4b 29 20 7b 0a 20 20 20 20 20 20 20 20 BACK) {.
4b60: 64 70 72 69 6e 74 66 28 22 43 61 6c 6c 62 61 63 dprintf("Callbac
4b70: 6b 20 69 73 20 6f 6e 2d 67 6f 69 6e 67 2c 20 64 k is on-going, d
4b80: 6f 69 6e 67 20 6e 6f 74 68 69 6e 67 22 29 3b 0a oing nothing");.
4b90: 20 20 20 20 20 20 20 20 72 65 74 75 72 6e 3b 0a return;.
4ba0: 20 20 20 20 7d 0a 0a 20 20 20 20 64 70 72 69 6e }.. dprin
4bb0: 74 46 6c 61 67 73 28 73 74 61 74 65 50 74 72 29 tFlags(statePtr)
4bc0: 3b 0a 0a 20 20 20 20 64 6f 77 6e 43 68 61 6e 20 ;.. downChan
4bd0: 3d 20 54 6c 73 5f 47 65 74 50 61 72 65 6e 74 28 = Tls_GetParent(
4be0: 73 74 61 74 65 50 74 72 2c 20 54 4c 53 5f 54 43 statePtr, TLS_TC
4bf0: 4c 5f 46 41 53 54 50 41 54 48 29 3b 0a 0a 20 20 L_FASTPATH);..
4c00: 20 20 69 66 20 28 73 74 61 74 65 50 74 72 2d 3e if (statePtr->
4c10: 66 6c 61 67 73 20 26 20 54 4c 53 5f 54 43 4c 5f flags & TLS_TCL_
4c20: 48 41 4e 44 53 48 41 4b 45 5f 46 41 49 4c 45 44 HANDSHAKE_FAILED
4c30: 29 20 7b 0a 20 20 20 20 20 20 20 20 64 70 72 69 ) {. dpri
4c40: 6e 74 66 28 22 41 73 6b 65 64 20 74 6f 20 77 61 ntf("Asked to wa
4c50: 74 63 68 20 61 20 73 6f 63 6b 65 74 20 77 69 74 tch a socket wit
4c60: 68 20 61 20 66 61 69 6c 65 64 20 68 61 6e 64 73 h a failed hands
4c70: 68 61 6b 65 20 2d 2d 20 6e 6f 74 68 69 6e 67 20 hake -- nothing
4c80: 63 61 6e 20 68 61 70 70 65 6e 20 68 65 72 65 22 can happen here"
4c90: 29 3b 0a 0a 09 64 70 72 69 6e 74 66 28 22 55 6e );...dprintf("Un
4ca0: 72 65 67 69 73 74 65 72 69 6e 67 20 69 6e 74 65 registering inte
4cb0: 72 65 73 74 20 69 6e 20 74 68 65 20 6c 6f 77 65 rest in the lowe
4cc0: 72 20 63 68 61 6e 6e 65 6c 22 29 3b 0a 09 28 54 r channel");..(T
4cd0: 63 6c 5f 47 65 74 43 68 61 6e 6e 65 6c 54 79 70 cl_GetChannelTyp
4ce0: 65 28 64 6f 77 6e 43 68 61 6e 29 29 2d 3e 77 61 e(downChan))->wa
4cf0: 74 63 68 50 72 6f 63 28 54 63 6c 5f 47 65 74 43 tchProc(Tcl_GetC
4d00: 68 61 6e 6e 65 6c 49 6e 73 74 61 6e 63 65 44 61 hannelInstanceDa
4d10: 74 61 28 64 6f 77 6e 43 68 61 6e 29 2c 20 30 29 ta(downChan), 0)
4d20: 3b 0a 0a 09 73 74 61 74 65 50 74 72 2d 3e 77 61 ;...statePtr->wa
4d30: 74 63 68 4d 61 73 6b 20 3d 20 30 3b 0a 0a 20 20 tchMask = 0;..
4d40: 20 20 20 20 20 20 72 65 74 75 72 6e 3b 0a 20 20 return;.
4d50: 20 20 7d 0a 0a 09 73 74 61 74 65 50 74 72 2d 3e }...statePtr->
4d60: 77 61 74 63 68 4d 61 73 6b 20 3d 20 6d 61 73 6b watchMask = mask
4d70: 3b 0a 0a 09 2f 2a 20 4e 6f 20 63 68 61 6e 6e 65 ;.../* No channe
4d80: 6c 20 68 61 6e 64 6c 65 72 73 20 61 6e 79 20 6d l handlers any m
4d90: 6f 72 65 2e 20 57 65 20 77 69 6c 6c 20 62 65 20 ore. We will be
4da0: 6e 6f 74 69 66 69 65 64 20 61 75 74 6f 6d 61 74 notified automat
4db0: 69 63 61 6c 6c 79 0a 09 20 2a 20 61 62 6f 75 74 ically.. * about
4dc0: 20 65 76 65 6e 74 73 20 6f 6e 20 74 68 65 20 63 events on the c
4dd0: 68 61 6e 6e 65 6c 20 62 65 6c 6f 77 20 76 69 61 hannel below via
4de0: 20 61 20 63 61 6c 6c 20 74 6f 20 6f 75 72 0a 09 a call to our..
4df0: 20 2a 20 27 54 72 61 6e 73 66 6f 72 6d 4e 6f 74 * 'TransformNot
4e00: 69 66 79 50 72 6f 63 27 2e 20 42 75 74 20 77 65 ifyProc'. But we
4e10: 20 68 61 76 65 20 74 6f 20 70 61 73 73 20 74 68 have to pass th
4e20: 65 20 69 6e 74 65 72 65 73 74 20 64 6f 77 6e 20 e interest down
4e30: 6e 6f 77 2e 0a 09 20 2a 20 57 65 20 61 72 65 20 now... * We are
4e40: 61 6c 6c 6f 77 65 64 20 74 6f 20 61 64 64 20 61 allowed to add a
4e50: 64 64 69 74 69 6f 6e 61 6c 20 27 69 6e 74 65 72 dditional 'inter
4e60: 65 73 74 27 20 74 6f 20 74 68 65 20 6d 61 73 6b est' to the mask
4e70: 20 69 66 20 77 65 20 77 61 6e 74 0a 09 20 2a 20 if we want.. *
4e80: 74 6f 2e 20 42 75 74 20 74 68 69 73 20 74 72 61 to. But this tra
4e90: 6e 73 66 6f 72 6d 61 74 69 6f 6e 20 68 61 73 20 nsformation has
4ea0: 6e 6f 20 73 75 63 68 20 69 6e 74 65 72 65 73 74 no such interest
4eb0: 2e 20 49 74 20 6a 75 73 74 20 70 61 73 73 65 73 . It just passes
4ec0: 0a 09 20 2a 20 74 68 65 20 72 65 71 75 65 73 74 .. * the request
4ed0: 20 64 6f 77 6e 2c 20 75 6e 63 68 61 6e 67 65 64 down, unchanged
4ee0: 2e 0a 09 20 2a 2f 0a 0a 0a 20 20 20 20 20 20 20 ... */...
4ef0: 20 64 70 72 69 6e 74 66 28 22 52 65 67 69 73 74 dprintf("Regist
4f00: 65 72 69 6e 67 20 6f 75 72 20 69 6e 74 65 72 65 ering our intere
4f10: 73 74 20 69 6e 20 74 68 65 20 6c 6f 77 65 72 20 st in the lower
4f20: 63 68 61 6e 6e 65 6c 20 28 63 68 61 6e 3d 25 70 channel (chan=%p
4f30: 29 22 2c 20 28 76 6f 69 64 20 2a 29 20 64 6f 77 )", (void *) dow
4f40: 6e 43 68 61 6e 29 3b 0a 09 28 54 63 6c 5f 47 65 nChan);..(Tcl_Ge
4f50: 74 43 68 61 6e 6e 65 6c 54 79 70 65 28 64 6f 77 tChannelType(dow
4f60: 6e 43 68 61 6e 29 29 0a 09 20 20 20 20 2d 3e 77 nChan)).. ->w
4f70: 61 74 63 68 50 72 6f 63 28 54 63 6c 5f 47 65 74 atchProc(Tcl_Get
4f80: 43 68 61 6e 6e 65 6c 49 6e 73 74 61 6e 63 65 44 ChannelInstanceD
4f90: 61 74 61 28 64 6f 77 6e 43 68 61 6e 29 2c 20 6d ata(downChan), m
4fa0: 61 73 6b 29 3b 0a 0a 09 2f 2a 0a 09 20 2a 20 4d ask);.../*.. * M
4fb0: 61 6e 61 67 65 6d 65 6e 74 20 6f 66 20 74 68 65 anagement of the
4fc0: 20 69 6e 74 65 72 6e 61 6c 20 74 69 6d 65 72 2e internal timer.
4fd0: 0a 09 20 2a 2f 0a 0a 09 69 66 20 28 73 74 61 74 .. */...if (stat
4fe0: 65 50 74 72 2d 3e 74 69 6d 65 72 20 21 3d 20 28 ePtr->timer != (
4ff0: 54 63 6c 5f 54 69 6d 65 72 54 6f 6b 65 6e 29 20 Tcl_TimerToken)
5000: 4e 55 4c 4c 29 20 7b 0a 20 20 20 20 20 20 20 20 NULL) {.
5010: 20 20 20 20 64 70 72 69 6e 74 66 28 22 41 20 74 dprintf("A t
5020: 69 6d 65 72 20 77 61 73 20 66 6f 75 6e 64 2c 20 imer was found,
5030: 64 65 6c 65 74 69 6e 67 20 69 74 22 29 3b 0a 09 deleting it");..
5040: 20 20 20 20 54 63 6c 5f 44 65 6c 65 74 65 54 69 Tcl_DeleteTi
5050: 6d 65 72 48 61 6e 64 6c 65 72 28 73 74 61 74 65 merHandler(state
5060: 50 74 72 2d 3e 74 69 6d 65 72 29 3b 0a 09 20 20 Ptr->timer);..
5070: 20 20 73 74 61 74 65 50 74 72 2d 3e 74 69 6d 65 statePtr->time
5080: 72 20 3d 20 28 54 63 6c 5f 54 69 6d 65 72 54 6f r = (Tcl_TimerTo
5090: 6b 65 6e 29 20 4e 55 4c 4c 3b 0a 09 7d 0a 0a 09 ken) NULL;..}...
50a0: 69 66 20 28 6d 61 73 6b 20 26 20 54 43 4c 5f 52 if (mask & TCL_R
50b0: 45 41 44 41 42 4c 45 29 20 7b 0a 09 09 69 66 20 EADABLE) {...if
50c0: 28 54 63 6c 5f 49 6e 70 75 74 42 75 66 66 65 72 (Tcl_InputBuffer
50d0: 65 64 28 73 74 61 74 65 50 74 72 2d 3e 73 65 6c ed(statePtr->sel
50e0: 66 29 20 3e 20 30 20 7c 7c 20 42 49 4f 5f 63 74 f) > 0 || BIO_ct
50f0: 72 6c 5f 70 65 6e 64 69 6e 67 28 73 74 61 74 65 rl_pending(state
5100: 50 74 72 2d 3e 62 69 6f 29 20 3e 20 30 29 20 7b Ptr->bio) > 0) {
5110: 0a 09 09 09 2f 2a 0a 09 09 09 20 2a 20 54 68 65 ..../*.... * The
5120: 72 65 20 69 73 20 69 6e 74 65 72 65 73 74 20 69 re is interest i
5130: 6e 20 72 65 61 64 61 62 6c 65 20 65 76 65 6e 74 n readable event
5140: 73 20 61 6e 64 20 77 65 20 61 63 74 75 61 6c 6c s and we actuall
5150: 79 20 68 61 76 65 0a 09 09 09 20 2a 20 64 61 74 y have.... * dat
5160: 61 20 77 61 69 74 69 6e 67 2c 20 73 6f 20 67 65 a waiting, so ge
5170: 6e 65 72 61 74 65 20 61 20 74 69 6d 65 72 20 74 nerate a timer t
5180: 6f 20 66 6c 75 73 68 20 74 68 61 74 2e 0a 09 09 o flush that....
5190: 09 20 2a 2f 0a 09 09 09 64 70 72 69 6e 74 66 28 . */....dprintf(
51a0: 22 43 72 65 61 74 69 6e 67 20 61 20 6e 65 77 20 "Creating a new
51b0: 74 69 6d 65 72 20 73 69 6e 63 65 20 64 61 74 61 timer since data
51c0: 20 61 70 70 65 61 72 73 20 74 6f 20 62 65 20 77 appears to be w
51d0: 61 69 74 69 6e 67 22 29 3b 0a 09 09 09 73 74 61 aiting");....sta
51e0: 74 65 50 74 72 2d 3e 74 69 6d 65 72 20 3d 20 54 tePtr->timer = T
51f0: 63 6c 5f 43 72 65 61 74 65 54 69 6d 65 72 48 61 cl_CreateTimerHa
5200: 6e 64 6c 65 72 28 54 4c 53 5f 54 43 4c 5f 44 45 ndler(TLS_TCL_DE
5210: 4c 41 59 2c 20 54 6c 73 43 68 61 6e 6e 65 6c 48 LAY, TlsChannelH
5220: 61 6e 64 6c 65 72 54 69 6d 65 72 2c 20 73 74 61 andlerTimer, sta
5230: 74 65 50 74 72 29 3b 0a 09 09 7d 0a 09 7d 0a 7d tePtr);...}..}.}
5240: 0a 0a 2f 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d ../*. *---------
5250: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
5260: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
5270: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
5280: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 0a 20 2a ----------. *. *
5290: 20 54 6c 73 47 65 74 48 61 6e 64 6c 65 50 72 6f TlsGetHandlePro
52a0: 63 20 2d 2d 0a 20 2a 0a 20 2a 09 43 61 6c 6c 65 c --. *. *.Calle
52b0: 64 20 66 72 6f 6d 20 54 63 6c 5f 47 65 74 43 68 d from Tcl_GetCh
52c0: 61 6e 6e 65 6c 46 69 6c 65 20 74 6f 20 72 65 74 annelFile to ret
52d0: 72 69 65 76 65 20 6f 2f 73 20 66 69 6c 65 20 68 rieve o/s file h
52e0: 61 6e 64 6c 65 72 0a 20 2a 09 66 72 6f 6d 20 74 andler. *.from t
52f0: 68 65 20 53 53 4c 20 73 6f 63 6b 65 74 20 62 61 he SSL socket ba
5300: 73 65 64 20 63 68 61 6e 6e 65 6c 2e 0a 20 2a 0a sed channel.. *.
5310: 20 2a 20 52 65 73 75 6c 74 73 3a 0a 20 2a 09 54 * Results:. *.T
5320: 68 65 20 61 70 70 72 6f 70 72 69 61 74 65 20 54 he appropriate T
5330: 63 6c 5f 46 69 6c 65 20 6f 72 20 4e 55 4c 4c 20 cl_File or NULL
5340: 69 66 20 6e 6f 74 20 70 72 65 73 65 6e 74 2e 0a if not present..
5350: 20 2a 0a 20 2a 20 53 69 64 65 20 65 66 66 65 63 *. * Side effec
5360: 74 73 3a 0a 20 2a 09 4e 6f 6e 65 2e 0a 20 2a 0a ts:. *.None.. *.
5370: 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d *--------------
5380: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
5390: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
53a0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
53b0: 2d 2d 2d 2d 2d 0a 20 2a 2f 0a 73 74 61 74 69 63 -----. */.static
53c0: 20 69 6e 74 20 54 6c 73 47 65 74 48 61 6e 64 6c int TlsGetHandl
53d0: 65 50 72 6f 63 28 76 6f 69 64 20 2a 69 6e 73 74 eProc(void *inst
53e0: 61 6e 63 65 44 61 74 61 2c 20 69 6e 74 20 64 69 anceData, int di
53f0: 72 65 63 74 69 6f 6e 2c 20 76 6f 69 64 20 2a 2a rection, void **
5400: 68 61 6e 64 6c 65 50 74 72 29 20 7b 0a 09 53 74 handlePtr) {..St
5410: 61 74 65 20 2a 73 74 61 74 65 50 74 72 20 3d 20 ate *statePtr =
5420: 28 53 74 61 74 65 20 2a 29 20 69 6e 73 74 61 6e (State *) instan
5430: 63 65 44 61 74 61 3b 0a 0a 09 72 65 74 75 72 6e ceData;...return
5440: 28 54 63 6c 5f 47 65 74 43 68 61 6e 6e 65 6c 48 (Tcl_GetChannelH
5450: 61 6e 64 6c 65 28 54 6c 73 5f 47 65 74 50 61 72 andle(Tls_GetPar
5460: 65 6e 74 28 73 74 61 74 65 50 74 72 2c 20 54 4c ent(statePtr, TL
5470: 53 5f 54 43 4c 5f 46 41 53 54 50 41 54 48 29 2c S_TCL_FASTPATH),
5480: 20 64 69 72 65 63 74 69 6f 6e 2c 20 68 61 6e 64 direction, hand
5490: 6c 65 50 74 72 29 29 3b 0a 7d 0a 0a 2f 2a 0a 20 lePtr));.}../*.
54a0: 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d *---------------
54b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
54c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
54d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
54e0: 2d 2d 2d 2d 0a 20 2a 0a 20 2a 20 54 6c 73 4e 6f ----. *. * TlsNo
54f0: 74 69 66 79 50 72 6f 63 20 2d 2d 0a 20 2a 0a 20 tifyProc --. *.
5500: 2a 09 48 61 6e 64 6c 65 72 20 63 61 6c 6c 65 64 *.Handler called
5510: 20 62 79 20 54 63 6c 20 74 6f 20 69 6e 66 6f 72 by Tcl to infor
5520: 6d 20 75 73 20 6f 66 20 61 63 74 69 76 69 74 79 m us of activity
5530: 0a 20 2a 09 6f 6e 20 74 68 65 20 75 6e 64 65 72 . *.on the under
5540: 6c 79 69 6e 67 20 63 68 61 6e 6e 65 6c 2e 0a 20 lying channel..
5550: 2a 0a 20 2a 20 52 65 73 75 6c 74 73 3a 0a 20 2a *. * Results:. *
5560: 09 4e 6f 6e 65 2e 0a 20 2a 0a 20 2a 20 53 69 64 .None.. *. * Sid
5570: 65 20 65 66 66 65 63 74 73 3a 0a 20 2a 09 4d 61 e effects:. *.Ma
5580: 79 20 70 72 6f 63 65 73 73 20 74 68 65 20 69 6e y process the in
5590: 63 6f 6d 69 6e 67 20 65 76 65 6e 74 20 62 79 20 coming event by
55a0: 69 74 73 65 6c 66 2e 0a 20 2a 0a 20 2a 2d 2d 2d itself.. *. *---
55b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
55c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
55d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
55e0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
55f0: 0a 20 2a 2f 0a 0a 73 74 61 74 69 63 20 69 6e 74 . */..static int
5600: 20 54 6c 73 4e 6f 74 69 66 79 50 72 6f 63 28 76 TlsNotifyProc(v
5610: 6f 69 64 20 2a 69 6e 73 74 61 6e 63 65 44 61 74 oid *instanceDat
5620: 61 2c 20 69 6e 74 20 6d 61 73 6b 29 20 7b 0a 09 a, int mask) {..
5630: 53 74 61 74 65 20 2a 73 74 61 74 65 50 74 72 20 State *statePtr
5640: 3d 20 28 53 74 61 74 65 20 2a 29 20 69 6e 73 74 = (State *) inst
5650: 61 6e 63 65 44 61 74 61 3b 0a 09 69 6e 74 20 65 anceData;..int e
5660: 72 72 6f 72 43 6f 64 65 3b 0a 0a 09 2f 2a 0a 09 rrorCode;.../*..
5670: 20 2a 20 41 6e 20 65 76 65 6e 74 20 6f 63 63 75 * An event occu
5680: 72 65 64 20 69 6e 20 74 68 65 20 75 6e 64 65 72 red in the under
5690: 6c 79 69 6e 67 20 63 68 61 6e 6e 65 6c 2e 20 20 lying channel.
56a0: 54 68 69 73 0a 09 20 2a 20 74 72 61 6e 73 66 6f This.. * transfo
56b0: 72 6d 61 74 69 6f 6e 20 64 6f 65 73 6e 27 74 20 rmation doesn't
56c0: 70 72 6f 63 65 73 73 20 73 75 63 68 20 65 76 65 process such eve
56d0: 6e 74 73 20 74 68 75 73 20 72 65 74 75 72 6e 73 nts thus returns
56e0: 20 74 68 65 0a 09 20 2a 20 69 6e 63 6f 6d 69 6e the.. * incomin
56f0: 67 20 6d 61 73 6b 20 75 6e 63 68 61 6e 67 65 64 g mask unchanged
5700: 2e 0a 09 20 2a 2f 0a 09 69 66 20 28 73 74 61 74 ... */..if (stat
5710: 65 50 74 72 2d 3e 74 69 6d 65 72 20 21 3d 20 28 ePtr->timer != (
5720: 54 63 6c 5f 54 69 6d 65 72 54 6f 6b 65 6e 29 20 Tcl_TimerToken)
5730: 4e 55 4c 4c 29 20 7b 0a 09 09 2f 2a 0a 09 09 20 NULL) {.../*...
5740: 2a 20 44 65 6c 65 74 65 20 61 6e 20 65 78 69 73 * Delete an exis
5750: 74 69 6e 67 20 74 69 6d 65 72 2e 20 49 74 20 77 ting timer. It w
5760: 61 73 20 6e 6f 74 20 66 69 72 65 64 2c 20 79 65 as not fired, ye
5770: 74 20 77 65 20 61 72 65 0a 09 09 20 2a 20 68 65 t we are... * he
5780: 72 65 2c 20 73 6f 20 74 68 65 20 63 68 61 6e 6e re, so the chann
5790: 65 6c 20 62 65 6c 6f 77 20 67 65 6e 65 72 61 74 el below generat
57a0: 65 64 20 73 75 63 68 20 61 6e 20 65 76 65 6e 74 ed such an event
57b0: 20 61 6e 64 20 77 65 0a 09 09 20 2a 20 64 6f 6e and we... * don
57c0: 27 74 20 68 61 76 65 20 74 6f 2e 20 54 68 65 20 't have to. The
57d0: 72 65 6e 65 77 61 6c 20 6f 66 20 74 68 65 20 69 renewal of the i
57e0: 6e 74 65 72 65 73 74 20 61 66 74 65 72 20 74 68 nterest after th
57f0: 65 0a 09 09 20 2a 20 65 78 65 63 75 74 69 6f 6e e... * execution
5800: 20 6f 66 20 63 68 61 6e 6e 65 6c 20 68 61 6e 64 of channel hand
5810: 6c 65 72 73 20 77 69 6c 6c 20 65 76 65 6e 74 75 lers will eventu
5820: 61 6c 6c 79 20 63 61 75 73 65 20 75 73 20 74 6f ally cause us to
5830: 0a 09 09 20 2a 20 72 65 63 72 65 61 74 65 20 74 ... * recreate t
5840: 68 65 20 74 69 6d 65 72 20 28 69 6e 20 57 61 74 he timer (in Wat
5850: 63 68 50 72 6f 63 29 2e 0a 09 09 20 2a 2f 0a 09 chProc).... */..
5860: 09 54 63 6c 5f 44 65 6c 65 74 65 54 69 6d 65 72 .Tcl_DeleteTimer
5870: 48 61 6e 64 6c 65 72 28 73 74 61 74 65 50 74 72 Handler(statePtr
5880: 2d 3e 74 69 6d 65 72 29 3b 0a 09 09 73 74 61 74 ->timer);...stat
5890: 65 50 74 72 2d 3e 74 69 6d 65 72 20 3d 20 28 54 ePtr->timer = (T
58a0: 63 6c 5f 54 69 6d 65 72 54 6f 6b 65 6e 29 20 4e cl_TimerToken) N
58b0: 55 4c 4c 3b 0a 09 7d 0a 0a 09 69 66 20 28 73 74 ULL;..}...if (st
58c0: 61 74 65 50 74 72 2d 3e 66 6c 61 67 73 20 26 20 atePtr->flags &
58d0: 54 4c 53 5f 54 43 4c 5f 43 41 4c 4c 42 41 43 4b TLS_TCL_CALLBACK
58e0: 29 20 7b 0a 09 09 64 70 72 69 6e 74 66 28 22 52 ) {...dprintf("R
58f0: 65 74 75 72 6e 69 6e 67 20 30 20 64 75 65 20 74 eturning 0 due t
5900: 6f 20 63 61 6c 6c 62 61 63 6b 22 29 3b 0a 09 09 o callback");...
5910: 72 65 74 75 72 6e 20 30 3b 0a 09 7d 0a 0a 09 64 return 0;..}...d
5920: 70 72 69 6e 74 66 28 22 43 61 6c 6c 69 6e 67 20 printf("Calling
5930: 54 6c 73 5f 57 61 69 74 46 6f 72 43 6f 6e 6e 65 Tls_WaitForConne
5940: 63 74 22 29 3b 0a 09 65 72 72 6f 72 43 6f 64 65 ct");..errorCode
5950: 20 3d 20 30 3b 0a 09 69 66 20 28 54 6c 73 5f 57 = 0;..if (Tls_W
5960: 61 69 74 46 6f 72 43 6f 6e 6e 65 63 74 28 73 74 aitForConnect(st
5970: 61 74 65 50 74 72 2c 20 26 65 72 72 6f 72 43 6f atePtr, &errorCo
5980: 64 65 2c 20 31 29 20 3c 20 30 29 20 7b 0a 09 09 de, 1) < 0) {...
5990: 69 66 20 28 65 72 72 6f 72 43 6f 64 65 20 3d 3d if (errorCode ==
59a0: 20 45 41 47 41 49 4e 29 20 7b 0a 09 09 09 64 70 EAGAIN) {....dp
59b0: 72 69 6e 74 66 28 22 41 73 79 6e 63 20 66 6c 61 rintf("Async fla
59c0: 67 20 63 6f 75 6c 64 20 62 65 20 73 65 74 20 28 g could be set (
59d0: 64 69 64 6e 27 74 20 63 68 65 63 6b 29 20 61 6e didn't check) an
59e0: 64 20 65 72 72 6f 72 43 6f 64 65 20 3d 3d 20 45 d errorCode == E
59f0: 41 47 41 49 4e 3a 20 20 52 65 74 75 72 6e 69 6e AGAIN: Returnin
5a00: 67 20 30 22 29 3b 0a 0a 09 09 09 72 65 74 75 72 g 0");.....retur
5a10: 6e 20 30 3b 0a 09 09 7d 0a 0a 09 09 64 70 72 69 n 0;...}....dpri
5a20: 6e 74 66 28 22 54 6c 73 5f 57 61 69 74 46 6f 72 ntf("Tls_WaitFor
5a30: 43 6f 6e 6e 65 63 74 20 72 65 74 75 72 6e 65 64 Connect returned
5a40: 20 61 6e 20 65 72 72 6f 72 22 29 3b 0a 09 7d 0a an error");..}.
5a50: 0a 09 64 70 72 69 6e 74 66 28 22 52 65 74 75 72 ..dprintf("Retur
5a60: 6e 69 6e 67 20 25 69 22 2c 20 6d 61 73 6b 29 3b ning %i", mask);
5a70: 0a 0a 09 72 65 74 75 72 6e 28 6d 61 73 6b 29 3b ...return(mask);
5a80: 0a 7d 0a 0a 23 69 66 20 30 0a 2f 2a 0a 20 2a 2d .}..#if 0./*. *-
5a90: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
5aa0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
5ab0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
5ac0: 2d 2d 2d 2d 2d 2a 0a 20 2a 0a 20 2a 20 20 20 20 -----*. *. *
5ad0: 20 20 54 6c 73 43 68 61 6e 6e 65 6c 48 61 6e 64 TlsChannelHand
5ae0: 6c 65 72 20 2d 2d 0a 20 2a 0a 20 2a 20 20 20 20 ler --. *. *
5af0: 20 20 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d --------------
5b00: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
5b10: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
5b20: 2d 2d 2a 0a 20 2a 20 20 20 20 20 20 48 61 6e 64 --*. * Hand
5b30: 6c 65 72 20 63 61 6c 6c 65 64 20 62 79 20 54 63 ler called by Tc
5b40: 6c 20 61 73 20 61 20 72 65 73 75 6c 74 20 6f 66 l as a result of
5b50: 0a 20 2a 20 20 20 20 20 20 54 63 6c 5f 43 72 65 . * Tcl_Cre
5b60: 61 74 65 43 68 61 6e 6e 65 6c 48 61 6e 64 6c 65 ateChannelHandle
5b70: 72 20 2d 20 74 6f 20 69 6e 66 6f 72 6d 20 75 73 r - to inform us
5b80: 20 6f 66 20 61 63 74 69 76 69 74 79 0a 20 2a 20 of activity. *
5b90: 20 20 20 20 20 6f 6e 20 74 68 65 20 75 6e 64 65 on the unde
5ba0: 72 6c 79 69 6e 67 20 63 68 61 6e 6e 65 6c 2e 0a rlying channel..
5bb0: 20 2a 20 20 20 20 20 20 2d 2d 2d 2d 2d 2d 2d 2d * --------
5bc0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
5bd0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
5be0: 2d 2d 2d 2d 2d 2d 2d 2d 2a 0a 20 2a 0a 20 2a 20 --------*. *. *
5bf0: 20 20 20 20 20 53 69 64 65 65 66 66 65 63 74 73 Sideeffects
5c00: 3a 0a 20 2a 20 20 20 20 20 20 20 20 20 20 20 20 :. *
5c10: 20 20 4d 61 79 20 67 65 6e 65 72 61 74 65 20 73 May generate s
5c20: 75 62 73 65 71 75 65 6e 74 20 63 61 6c 6c 73 20 ubsequent calls
5c30: 74 6f 0a 20 2a 20 20 20 20 20 20 20 20 20 20 20 to. *
5c40: 20 20 20 54 63 6c 5f 4e 6f 74 69 66 79 43 68 61 Tcl_NotifyCha
5c50: 6e 6e 65 6c 2e 0a 20 2a 0a 20 2a 20 20 20 20 20 nnel.. *. *
5c60: 20 52 65 73 75 6c 74 3a 0a 20 2a 20 20 20 20 20 Result:. *
5c70: 20 20 20 20 20 20 20 20 20 4e 6f 6e 65 2e 0a 20 None..
5c80: 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d *. *------------
5c90: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
5ca0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
5cb0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2a 0a 20 2a 2f 0a ----------*. */.
5cc0: 0a 73 74 61 74 69 63 20 76 6f 69 64 0a 54 6c 73 .static void.Tls
5cd0: 43 68 61 6e 6e 65 6c 48 61 6e 64 6c 65 72 20 28 ChannelHandler (
5ce0: 63 6c 69 65 6e 74 44 61 74 61 2c 20 6d 61 73 6b clientData, mask
5cf0: 29 0a 20 20 20 20 76 6f 69 64 20 2a 20 20 20 20 ). void *
5d00: 63 6c 69 65 6e 74 44 61 74 61 3b 0a 20 20 20 20 clientData;.
5d10: 69 6e 74 20 20 20 20 20 20 20 20 20 20 20 20 6d int m
5d20: 61 73 6b 3b 0a 7b 0a 20 20 20 20 53 74 61 74 65 ask;.{. State
5d30: 20 2a 73 74 61 74 65 50 74 72 20 3d 20 28 53 74 *statePtr = (St
5d40: 61 74 65 20 2a 29 20 63 6c 69 65 6e 74 44 61 74 ate *) clientDat
5d50: 61 3b 0a 0a 20 20 20 20 64 70 72 69 6e 74 66 28 a;.. dprintf(
5d60: 22 48 41 4e 44 4c 45 52 28 30 78 25 78 29 22 2c "HANDLER(0x%x)",
5d70: 20 6d 61 73 6b 29 3b 0a 20 20 20 20 54 63 6c 5f mask);. Tcl_
5d80: 50 72 65 73 65 72 76 65 28 73 74 61 74 65 50 74 Preserve(statePt
5d90: 72 29 3b 0a 0a 20 20 20 20 69 66 20 28 6d 61 73 r);.. if (mas
5da0: 6b 20 26 20 54 43 4c 5f 52 45 41 44 41 42 4c 45 k & TCL_READABLE
5db0: 29 20 7b 0a 09 42 49 4f 5f 73 65 74 5f 66 6c 61 ) {..BIO_set_fla
5dc0: 67 73 28 73 74 61 74 65 50 74 72 2d 3e 70 5f 62 gs(statePtr->p_b
5dd0: 69 6f 2c 20 42 49 4f 5f 46 4c 41 47 53 5f 52 45 io, BIO_FLAGS_RE
5de0: 41 44 29 3b 0a 20 20 20 20 7d 20 65 6c 73 65 20 AD);. } else
5df0: 7b 0a 09 42 49 4f 5f 63 6c 65 61 72 5f 66 6c 61 {..BIO_clear_fla
5e00: 67 73 28 73 74 61 74 65 50 74 72 2d 3e 70 5f 62 gs(statePtr->p_b
5e10: 69 6f 2c 20 42 49 4f 5f 46 4c 41 47 53 5f 52 45 io, BIO_FLAGS_RE
5e20: 41 44 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 AD);. }..
5e30: 69 66 20 28 6d 61 73 6b 20 26 20 54 43 4c 5f 57 if (mask & TCL_W
5e40: 52 49 54 41 42 4c 45 29 20 7b 0a 09 42 49 4f 5f RITABLE) {..BIO_
5e50: 73 65 74 5f 66 6c 61 67 73 28 73 74 61 74 65 50 set_flags(stateP
5e60: 74 72 2d 3e 70 5f 62 69 6f 2c 20 42 49 4f 5f 46 tr->p_bio, BIO_F
5e70: 4c 41 47 53 5f 57 52 49 54 45 29 3b 0a 20 20 20 LAGS_WRITE);.
5e80: 20 7d 20 65 6c 73 65 20 7b 0a 09 42 49 4f 5f 63 } else {..BIO_c
5e90: 6c 65 61 72 5f 66 6c 61 67 73 28 73 74 61 74 65 lear_flags(state
5ea0: 50 74 72 2d 3e 70 5f 62 69 6f 2c 20 42 49 4f 5f Ptr->p_bio, BIO_
5eb0: 46 4c 41 47 53 5f 57 52 49 54 45 29 3b 0a 20 20 FLAGS_WRITE);.
5ec0: 20 20 7d 0a 0a 20 20 20 20 6d 61 73 6b 20 3d 20 }.. mask =
5ed0: 30 3b 0a 20 20 20 20 69 66 20 28 42 49 4f 5f 77 0;. if (BIO_w
5ee0: 70 65 6e 64 69 6e 67 28 73 74 61 74 65 50 74 72 pending(statePtr
5ef0: 2d 3e 62 69 6f 29 29 20 7b 0a 09 6d 61 73 6b 20 ->bio)) {..mask
5f00: 7c 3d 20 54 43 4c 5f 57 52 49 54 41 42 4c 45 3b |= TCL_WRITABLE;
5f10: 0a 20 20 20 20 7d 0a 20 20 20 20 69 66 20 28 42 . }. if (B
5f20: 49 4f 5f 70 65 6e 64 69 6e 67 28 73 74 61 74 65 IO_pending(state
5f30: 50 74 72 2d 3e 62 69 6f 29 29 20 7b 0a 09 6d 61 Ptr->bio)) {..ma
5f40: 73 6b 20 7c 3d 20 54 43 4c 5f 52 45 41 44 41 42 sk |= TCL_READAB
5f50: 4c 45 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f LE;. }.. /
5f60: 2a 0a 20 20 20 20 20 2a 20 54 68 65 20 66 6f 6c *. * The fol
5f70: 6c 6f 77 69 6e 67 20 4e 6f 74 69 66 79 43 68 61 lowing NotifyCha
5f80: 6e 6e 65 6c 20 63 61 6c 6c 73 20 73 65 65 6d 73 nnel calls seems
5f90: 20 74 6f 20 62 65 20 69 6d 70 6f 72 74 61 6e 74 to be important
5fa0: 2c 20 62 75 74 0a 20 20 20 20 20 2a 20 77 65 20 , but. * we
5fb0: 64 6f 6e 27 74 20 6b 6e 6f 77 20 77 68 79 2e 20 don't know why.
5fc0: 20 49 74 20 6c 6f 6f 6b 73 20 6c 69 6b 65 20 69 It looks like i
5fd0: 66 20 74 68 65 20 6d 61 73 6b 20 69 73 20 65 76 f the mask is ev
5fe0: 65 72 20 6e 6f 6e 2d 7a 65 72 6f 0a 20 20 20 20 er non-zero.
5ff0: 20 2a 20 74 68 61 74 20 69 74 20 77 69 6c 6c 20 * that it will
6000: 65 6e 74 65 72 20 61 6e 20 69 6e 66 69 6e 69 74 enter an infinit
6010: 65 20 6c 6f 6f 70 2e 0a 20 20 20 20 20 2a 0a 20 e loop.. *.
6020: 20 20 20 20 2a 20 4e 6f 74 69 66 79 20 74 68 65 * Notify the
6030: 20 75 70 70 65 72 20 63 68 61 6e 6e 65 6c 20 6f upper channel o
6040: 66 20 74 68 65 20 63 75 72 72 65 6e 74 20 42 49 f the current BI
6050: 4f 20 73 74 61 74 65 20 73 6f 20 74 68 65 20 65 O state so the e
6060: 76 65 6e 74 0a 20 20 20 20 20 2a 20 63 6f 6e 74 vent. * cont
6070: 69 6e 75 65 73 20 74 6f 20 70 72 6f 70 61 67 61 inues to propaga
6080: 74 65 20 75 70 20 74 68 65 20 63 68 61 69 6e 2e te up the chain.
6090: 0a 20 20 20 20 20 2a 0a 20 20 20 20 20 2a 20 73 . *. * s
60a0: 74 61 6e 74 6f 6e 3a 20 49 74 20 6c 6f 6f 6b 73 tanton: It looks
60b0: 20 6c 69 6b 65 20 74 68 69 73 20 63 6f 75 6c 64 like this could
60c0: 20 72 65 73 75 6c 74 20 69 6e 20 61 6e 20 69 6e result in an in
60d0: 66 69 6e 69 74 65 20 6c 6f 6f 70 20 69 66 0a 20 finite loop if.
60e0: 20 20 20 20 2a 20 74 68 65 20 75 70 70 65 72 20 * the upper
60f0: 63 68 61 6e 6e 65 6c 20 64 6f 65 73 6e 27 74 20 channel doesn't
6100: 63 61 75 73 65 20 43 68 61 6e 6e 65 6c 48 61 6e cause ChannelHan
6110: 64 6c 65 72 20 74 6f 20 62 65 20 72 65 6d 6f 76 dler to be remov
6120: 65 64 0a 20 20 20 20 20 2a 20 62 65 66 6f 72 65 ed. * before
6130: 20 54 63 6c 5f 4e 6f 74 69 66 79 43 68 61 6e 6e Tcl_NotifyChann
6140: 65 6c 20 63 61 6c 6c 73 20 63 68 61 6e 6e 65 6c el calls channel
6150: 20 68 61 6e 64 6c 65 72 73 20 6f 6e 20 74 68 65 handlers on the
6160: 20 6c 6f 77 65 72 20 63 68 61 6e 6e 65 6c 2e 0a lower channel..
6170: 20 20 20 20 20 2a 2f 0a 0a 20 20 20 20 54 63 6c */.. Tcl
6180: 5f 4e 6f 74 69 66 79 43 68 61 6e 6e 65 6c 28 73 _NotifyChannel(s
6190: 74 61 74 65 50 74 72 2d 3e 73 65 6c 66 2c 20 6d tatePtr->self, m
61a0: 61 73 6b 29 3b 0a 0a 20 20 20 20 69 66 20 28 73 ask);.. if (s
61b0: 74 61 74 65 50 74 72 2d 3e 74 69 6d 65 72 20 21 tatePtr->timer !
61c0: 3d 20 28 54 63 6c 5f 54 69 6d 65 72 54 6f 6b 65 = (Tcl_TimerToke
61d0: 6e 29 4e 55 4c 4c 29 20 7b 0a 09 54 63 6c 5f 44 n)NULL) {..Tcl_D
61e0: 65 6c 65 74 65 54 69 6d 65 72 48 61 6e 64 6c 65 eleteTimerHandle
61f0: 72 28 73 74 61 74 65 50 74 72 2d 3e 74 69 6d 65 r(statePtr->time
6200: 72 29 3b 0a 09 73 74 61 74 65 50 74 72 2d 3e 74 r);..statePtr->t
6210: 69 6d 65 72 20 3d 20 28 54 63 6c 5f 54 69 6d 65 imer = (Tcl_Time
6220: 72 54 6f 6b 65 6e 29 4e 55 4c 4c 3b 0a 20 20 20 rToken)NULL;.
6230: 20 7d 0a 20 20 20 20 69 66 20 28 28 6d 61 73 6b }. if ((mask
6240: 20 26 20 54 43 4c 5f 52 45 41 44 41 42 4c 45 29 & TCL_READABLE)
6250: 20 26 26 20 54 63 6c 5f 49 6e 70 75 74 42 75 66 && Tcl_InputBuf
6260: 66 65 72 65 64 28 73 74 61 74 65 50 74 72 2d 3e fered(statePtr->
6270: 73 65 6c 66 29 20 3e 20 30 29 20 7b 0a 09 2f 2a self) > 0) {../*
6280: 0a 09 20 2a 20 44 61 74 61 20 69 73 20 77 61 69 .. * Data is wai
6290: 74 69 6e 67 2c 20 66 6c 75 73 68 20 69 74 20 6f ting, flush it o
62a0: 75 74 20 69 6e 20 73 68 6f 72 74 20 74 69 6d 65 ut in short time
62b0: 0a 09 20 2a 2f 0a 09 73 74 61 74 65 50 74 72 2d .. */..statePtr-
62c0: 3e 74 69 6d 65 72 20 3d 20 54 63 6c 5f 43 72 65 >timer = Tcl_Cre
62d0: 61 74 65 54 69 6d 65 72 48 61 6e 64 6c 65 72 28 ateTimerHandler(
62e0: 54 4c 53 5f 54 43 4c 5f 44 45 4c 41 59 2c 0a 09 TLS_TCL_DELAY,..
62f0: 09 54 6c 73 43 68 61 6e 6e 65 6c 48 61 6e 64 6c .TlsChannelHandl
6300: 65 72 54 69 6d 65 72 2c 20 73 74 61 74 65 50 74 erTimer, statePt
6310: 72 29 3b 0a 20 20 20 20 7d 0a 20 20 20 20 54 63 r);. }. Tc
6320: 6c 5f 52 65 6c 65 61 73 65 28 73 74 61 74 65 50 l_Release(stateP
6330: 74 72 29 3b 0a 7d 0a 23 65 6e 64 69 66 0a 0a 2f tr);.}.#endif../
6340: 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d *. *------------
6350: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
6360: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
6370: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2a 0a 20 2a 0a 20 ----------*. *.
6380: 2a 09 54 6c 73 43 68 61 6e 6e 65 6c 48 61 6e 64 *.TlsChannelHand
6390: 6c 65 72 54 69 6d 65 72 20 2d 2d 0a 20 2a 0a 20 lerTimer --. *.
63a0: 2a 09 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d *.--------------
63b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
63c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
63d0: 2d 2d 2a 0a 20 2a 09 43 61 6c 6c 65 64 20 62 79 --*. *.Called by
63e0: 20 74 68 65 20 6e 6f 74 69 66 69 65 72 20 28 2d the notifier (-
63f0: 3e 20 74 69 6d 65 72 29 20 74 6f 20 66 6c 75 73 > timer) to flus
6400: 68 20 6f 75 74 0a 20 2a 09 69 6e 66 6f 72 6d 61 h out. *.informa
6410: 74 69 6f 6e 20 77 61 69 74 69 6e 67 20 69 6e 20 tion waiting in
6420: 63 68 61 6e 6e 65 6c 20 62 75 66 66 65 72 73 2e channel buffers.
6430: 0a 20 2a 09 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d . *.------------
6440: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
6450: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
6460: 2d 2d 2d 2d 2a 0a 20 2a 0a 20 2a 09 53 69 64 65 ----*. *. *.Side
6470: 65 66 66 65 63 74 73 3a 0a 20 2a 09 09 41 73 20 effects:. *..As
6480: 6f 66 20 27 54 6c 73 43 68 61 6e 6e 65 6c 48 61 of 'TlsChannelHa
6490: 6e 64 6c 65 72 27 2e 0a 20 2a 0a 20 2a 09 52 65 ndler'.. *. *.Re
64a0: 73 75 6c 74 3a 0a 20 2a 09 09 4e 6f 6e 65 2e 0a sult:. *..None..
64b0: 20 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d *. *-----------
64c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
64d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d ----------------
64e0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2a 0a 20 2a 2f -----------*. */
64f0: 0a 0a 73 74 61 74 69 63 20 76 6f 69 64 20 54 6c ..static void Tl
6500: 73 43 68 61 6e 6e 65 6c 48 61 6e 64 6c 65 72 54 sChannelHandlerT
6510: 69 6d 65 72 28 76 6f 69 64 20 2a 63 6c 69 65 6e imer(void *clien
6520: 74 44 61 74 61 29 20 7b 0a 09 53 74 61 74 65 20 tData) {..State
6530: 2a 73 74 61 74 65 50 74 72 20 3d 20 28 53 74 61 *statePtr = (Sta
6540: 74 65 20 2a 29 20 63 6c 69 65 6e 74 44 61 74 61 te *) clientData
6550: 3b 0a 09 69 6e 74 20 6d 61 73 6b 20 3d 20 30 3b ;..int mask = 0;
6560: 0a 0a 09 64 70 72 69 6e 74 66 28 22 43 61 6c 6c ...dprintf("Call
6570: 65 64 22 29 3b 0a 0a 09 73 74 61 74 65 50 74 72 ed");...statePtr
6580: 2d 3e 74 69 6d 65 72 20 3d 20 28 54 63 6c 5f 54 ->timer = (Tcl_T
6590: 69 6d 65 72 54 6f 6b 65 6e 29 20 4e 55 4c 4c 3b imerToken) NULL;
65a0: 0a 0a 09 69 66 20 28 42 49 4f 5f 77 70 65 6e 64 ...if (BIO_wpend
65b0: 69 6e 67 28 73 74 61 74 65 50 74 72 2d 3e 62 69 ing(statePtr->bi
65c0: 6f 29 29 20 7b 0a 09 09 64 70 72 69 6e 74 66 28 o)) {...dprintf(
65d0: 22 5b 63 68 61 6e 3d 25 70 5d 20 42 49 4f 20 77 "[chan=%p] BIO w
65e0: 72 69 74 61 62 6c 65 22 2c 20 73 74 61 74 65 50 ritable", stateP
65f0: 74 72 2d 3e 73 65 6c 66 29 3b 0a 0a 09 09 6d 61 tr->self);....ma
6600: 73 6b 20 7c 3d 20 54 43 4c 5f 57 52 49 54 41 42 sk |= TCL_WRITAB
6610: 4c 45 3b 0a 09 7d 0a 0a 09 69 66 20 28 42 49 4f LE;..}...if (BIO
6620: 5f 70 65 6e 64 69 6e 67 28 73 74 61 74 65 50 74 _pending(statePt
6630: 72 2d 3e 62 69 6f 29 29 20 7b 0a 09 09 64 70 72 r->bio)) {...dpr
6640: 69 6e 74 66 28 22 5b 63 68 61 6e 3d 25 70 5d 20 intf("[chan=%p]
6650: 42 49 4f 20 72 65 61 64 61 62 6c 65 22 2c 20 73 BIO readable", s
6660: 74 61 74 65 50 74 72 2d 3e 73 65 6c 66 29 3b 0a tatePtr->self);.
6670: 0a 09 09 6d 61 73 6b 20 7c 3d 20 54 43 4c 5f 52 ...mask |= TCL_R
6680: 45 41 44 41 42 4c 45 3b 0a 09 7d 0a 0a 09 64 70 EADABLE;..}...dp
6690: 72 69 6e 74 66 28 22 4e 6f 74 69 66 79 69 6e 67 rintf("Notifying
66a0: 20 6f 75 72 73 65 6c 76 65 73 22 29 3b 0a 09 54 ourselves");..T
66b0: 63 6c 5f 4e 6f 74 69 66 79 43 68 61 6e 6e 65 6c cl_NotifyChannel
66c0: 28 73 74 61 74 65 50 74 72 2d 3e 73 65 6c 66 2c (statePtr->self,
66d0: 20 6d 61 73 6b 29 3b 0a 0a 09 64 70 72 69 6e 74 mask);...dprint
66e0: 66 28 22 52 65 74 75 72 6e 69 6e 67 22 29 3b 0a f("Returning");.
66f0: 0a 09 72 65 74 75 72 6e 3b 0a 7d 0a 0a 54 63 6c ..return;.}..Tcl
6700: 5f 43 68 61 6e 6e 65 6c 20 54 6c 73 5f 47 65 74 _Channel Tls_Get
6710: 50 61 72 65 6e 74 28 53 74 61 74 65 20 2a 73 74 Parent(State *st
6720: 61 74 65 50 74 72 2c 20 69 6e 74 20 6d 61 73 6b atePtr, int mask
6730: 46 6c 61 67 73 29 20 7b 0a 09 64 70 72 69 6e 74 Flags) {..dprint
6740: 66 28 22 52 65 71 75 65 73 74 65 64 20 74 6f 20 f("Requested to
6750: 67 65 74 20 70 61 72 65 6e 74 20 6f 66 20 63 68 get parent of ch
6760: 61 6e 6e 65 6c 20 25 70 22 2c 20 73 74 61 74 65 annel %p", state
6770: 50 74 72 2d 3e 73 65 6c 66 29 3b 0a 0a 09 69 66 Ptr->self);...if
6780: 20 28 28 73 74 61 74 65 50 74 72 2d 3e 66 6c 61 ((statePtr->fla
6790: 67 73 20 26 20 7e 6d 61 73 6b 46 6c 61 67 73 29 gs & ~maskFlags)
67a0: 20 26 20 54 4c 53 5f 54 43 4c 5f 46 41 53 54 50 & TLS_TCL_FASTP
67b0: 41 54 48 29 20 7b 0a 09 09 64 70 72 69 6e 74 66 ATH) {...dprintf
67c0: 28 22 41 73 6b 65 64 20 74 6f 20 67 65 74 20 74 ("Asked to get t
67d0: 68 65 20 70 61 72 65 6e 74 20 63 68 61 6e 6e 65 he parent channe
67e0: 6c 20 77 68 69 6c 65 20 77 65 20 61 72 65 20 75 l while we are u
67f0: 73 69 6e 67 20 46 61 73 74 50 61 74 68 20 2d 2d sing FastPath --
6800: 20 72 65 74 75 72 6e 69 6e 67 20 4e 55 4c 4c 22 returning NULL"
6810: 29 3b 0a 09 09 72 65 74 75 72 6e 28 4e 55 4c 4c );...return(NULL
6820: 29 3b 0a 09 7d 0a 0a 09 72 65 74 75 72 6e 28 54 );..}...return(T
6830: 63 6c 5f 47 65 74 53 74 61 63 6b 65 64 43 68 61 cl_GetStackedCha
6840: 6e 6e 65 6c 28 73 74 61 74 65 50 74 72 2d 3e 73 nnel(statePtr->s
6850: 65 6c 66 29 29 3b 0a 7d 0a elf));.}.