Hex Artifact Content

Artifact 15faee591f150708ee410088d84dfe6db36e9cfbeb171cde478e5ea52995fcb1:


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