Hex Artifact Content

Artifact 388e7798264bfbda52e49561634d8d5a912c78bb40de975c4013d2ce84ed4f8b:


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 20 20 20 20 74 63 6c 53 53 4c 20 28  :. *    tclSSL (
0250: 43 6f 6c 69 6e 20 4d 63 43 6f 72 6d 61 63 6b 2c  Colin McCormack,
0260: 20 53 68 61 72 65 64 20 54 65 63 68 6e 6f 6c 6f   Shared Technolo
0270: 67 79 29 0a 20 2a 20 20 20 20 53 53 4c 74 63 6c  gy). *    SSLtcl
0280: 20 28 50 65 74 65 72 20 41 6e 74 6d 61 6e 29 0a   (Peter Antman).
0290: 20 2a 0a 20 2a 2f 0a 0a 23 69 6e 63 6c 75 64 65   *. */..#include
02a0: 20 22 74 6c 73 49 6e 74 2e 68 22 0a 23 69 6e 63   "tlsInt.h".#inc
02b0: 6c 75 64 65 20 3c 65 72 72 6e 6f 2e 68 3e 0a 0a  lude <errno.h>..
02c0: 2f 2a 0a 20 2a 20 46 6f 72 77 61 72 64 20 64 65  /*. * Forward de
02d0: 63 6c 61 72 61 74 69 6f 6e 73 0a 20 2a 2f 0a 73  clarations. */.s
02e0: 74 61 74 69 63 20 76 6f 69 64 20 54 6c 73 43 68  tatic void TlsCh
02f0: 61 6e 6e 65 6c 48 61 6e 64 6c 65 72 54 69 6d 65  annelHandlerTime
0300: 72 28 43 6c 69 65 6e 74 44 61 74 61 20 63 6c 69  r(ClientData cli
0310: 65 6e 74 44 61 74 61 29 3b 0a 0a 2f 2a 0a 20 2a  entData);../*. *
0320: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0330: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0340: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0350: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0360: 2d 2d 2d 0a 20 2a 0a 20 2a 20 54 6c 73 42 6c 6f  ---. *. * TlsBlo
0370: 63 6b 4d 6f 64 65 50 72 6f 63 20 2d 2d 0a 20 2a  ckModeProc --. *
0380: 0a 20 2a 20 20 20 20 54 68 69 73 20 70 72 6f 63  . *    This proc
0390: 65 64 75 72 65 20 69 73 20 69 6e 76 6f 6b 65 64  edure is invoked
03a0: 20 62 79 20 74 68 65 20 67 65 6e 65 72 69 63 20   by the generic 
03b0: 49 4f 20 6c 65 76 65 6c 0a 20 2a 20 20 20 20 20  IO level. *     
03c0: 20 20 74 6f 20 73 65 74 20 62 6c 6f 63 6b 69 6e    to set blockin
03d0: 67 20 61 6e 64 20 6e 6f 6e 62 6c 6f 63 6b 69 6e  g and nonblockin
03e0: 67 20 6d 6f 64 65 73 0a 20 2a 0a 20 2a 20 52 65  g modes. *. * Re
03f0: 73 75 6c 74 73 3a 0a 20 2a 20 20 20 20 30 20 69  sults:. *    0 i
0400: 66 20 73 75 63 63 65 73 73 66 75 6c 20 6f 72 20  f successful or 
0410: 50 4f 53 49 58 20 65 72 72 6f 72 20 63 6f 64 65  POSIX error code
0420: 20 69 66 20 66 61 69 6c 65 64 2e 0a 20 2a 0a 20   if failed.. *. 
0430: 2a 20 53 69 64 65 20 65 66 66 65 63 74 73 3a 0a  * Side effects:.
0440: 20 2a 20 20 20 20 53 65 74 73 20 74 68 65 20 64   *    Sets the d
0450: 65 76 69 63 65 20 69 6e 74 6f 20 62 6c 6f 63 6b  evice into block
0460: 69 6e 67 20 6f 72 20 6e 6f 6e 62 6c 6f 63 6b 69  ing or nonblocki
0470: 6e 67 20 6d 6f 64 65 2e 0a 20 2a 0a 20 2a 2d 2d  ng mode.. *. *--
0480: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0490: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
04a0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
04b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
04c0: 2d 0a 20 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74  -. */.static int
04d0: 20 54 6c 73 42 6c 6f 63 6b 4d 6f 64 65 50 72 6f   TlsBlockModePro
04e0: 63 28 43 6c 69 65 6e 74 44 61 74 61 20 69 6e 73  c(ClientData ins
04f0: 74 61 6e 63 65 44 61 74 61 2c 20 69 6e 74 20 6d  tanceData, int m
0500: 6f 64 65 29 20 7b 0a 20 20 20 20 53 74 61 74 65  ode) {.    State
0510: 20 2a 73 74 61 74 65 50 74 72 20 3d 20 28 53 74   *statePtr = (St
0520: 61 74 65 20 2a 29 20 69 6e 73 74 61 6e 63 65 44  ate *) instanceD
0530: 61 74 61 3b 0a 0a 20 20 20 20 69 66 20 28 6d 6f  ata;..    if (mo
0540: 64 65 20 3d 3d 20 54 43 4c 5f 4d 4f 44 45 5f 4e  de == TCL_MODE_N
0550: 4f 4e 42 4c 4f 43 4b 49 4e 47 29 20 7b 0a 09 73  ONBLOCKING) {..s
0560: 74 61 74 65 50 74 72 2d 3e 66 6c 61 67 73 20 7c  tatePtr->flags |
0570: 3d 20 54 4c 53 5f 54 43 4c 5f 41 53 59 4e 43 3b  = TLS_TCL_ASYNC;
0580: 0a 20 20 20 20 7d 20 65 6c 73 65 20 7b 0a 09 73  .    } else {..s
0590: 74 61 74 65 50 74 72 2d 3e 66 6c 61 67 73 20 26  tatePtr->flags &
05a0: 3d 20 7e 28 54 4c 53 5f 54 43 4c 5f 41 53 59 4e  = ~(TLS_TCL_ASYN
05b0: 43 29 3b 0a 20 20 20 20 7d 0a 20 20 20 20 72 65  C);.    }.    re
05c0: 74 75 72 6e 28 30 29 3b 0a 7d 0a 0a 2f 2a 0a 20  turn(0);.}../*. 
05d0: 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  *---------------
05e0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
05f0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0600: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0610: 2d 2d 2d 2d 0a 20 2a 0a 20 2a 20 54 6c 73 43 6c  ----. *. * TlsCl
0620: 6f 73 65 50 72 6f 63 20 2d 2d 0a 20 2a 0a 20 2a  oseProc --. *. *
0630: 20 20 20 20 54 68 69 73 20 70 72 6f 63 65 64 75      This procedu
0640: 72 65 20 69 73 20 69 6e 76 6f 6b 65 64 20 62 79  re is invoked by
0650: 20 74 68 65 20 67 65 6e 65 72 69 63 20 49 4f 20   the generic IO 
0660: 6c 65 76 65 6c 20 74 6f 20 70 65 72 66 6f 72 6d  level to perform
0670: 0a 20 2a 20 20 20 20 63 68 61 6e 6e 65 6c 2d 74  . *    channel-t
0680: 79 70 65 2d 73 70 65 63 69 66 69 63 20 63 6c 65  ype-specific cle
0690: 61 6e 75 70 20 77 68 65 6e 20 61 20 53 53 4c 20  anup when a SSL 
06a0: 73 6f 63 6b 65 74 20 62 61 73 65 64 20 63 68 61  socket based cha
06b0: 6e 6e 65 6c 0a 20 2a 20 20 20 20 69 73 20 63 6c  nnel. *    is cl
06c0: 6f 73 65 64 2e 0a 20 2a 0a 20 2a 20 20 20 20 4e  osed.. *. *    N
06d0: 6f 74 65 3a 20 77 65 20 6c 65 61 76 65 20 74 68  ote: we leave th
06e0: 65 20 75 6e 64 65 72 6c 79 69 6e 67 20 73 6f 63  e underlying soc
06f0: 6b 65 74 20 61 6c 6f 6e 65 2c 20 69 73 20 74 68  ket alone, is th
0700: 69 73 20 72 69 67 68 74 3f 0a 20 2a 0a 20 2a 20  is right?. *. * 
0710: 52 65 73 75 6c 74 73 3a 0a 20 2a 20 20 20 20 30  Results:. *    0
0720: 20 69 66 20 73 75 63 63 65 73 73 66 75 6c 20 6f   if successful o
0730: 72 20 50 4f 53 49 58 20 65 72 72 6f 72 20 63 6f  r POSIX error co
0740: 64 65 20 69 66 20 66 61 69 6c 65 64 2e 0a 20 2a  de if failed.. *
0750: 0a 20 2a 20 53 69 64 65 20 65 66 66 65 63 74 73  . * Side effects
0760: 3a 0a 20 2a 20 20 20 20 43 6c 6f 73 65 73 20 74  :. *    Closes t
0770: 68 65 20 73 6f 63 6b 65 74 20 6f 66 20 74 68 65  he socket of the
0780: 20 63 68 61 6e 6e 65 6c 2e 0a 20 2a 0a 20 2a 2d   channel.. *. *-
0790: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
07a0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
07b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
07c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
07d0: 2d 2d 0a 20 2a 2f 0a 73 74 61 74 69 63 20 69 6e  --. */.static in
07e0: 74 20 54 6c 73 43 6c 6f 73 65 50 72 6f 63 28 43  t TlsCloseProc(C
07f0: 6c 69 65 6e 74 44 61 74 61 20 69 6e 73 74 61 6e  lientData instan
0800: 63 65 44 61 74 61 2c 20 54 63 6c 5f 49 6e 74 65  ceData, Tcl_Inte
0810: 72 70 20 2a 69 6e 74 65 72 70 29 20 7b 0a 20 20  rp *interp) {.  
0820: 20 20 53 74 61 74 65 20 2a 73 74 61 74 65 50 74    State *statePt
0830: 72 20 3d 20 28 53 74 61 74 65 20 2a 29 20 69 6e  r = (State *) in
0840: 73 74 61 6e 63 65 44 61 74 61 3b 0a 0a 20 20 20  stanceData;..   
0850: 20 64 70 72 69 6e 74 66 28 22 54 6c 73 43 6c 6f   dprintf("TlsClo
0860: 73 65 50 72 6f 63 28 25 70 29 22 2c 20 28 76 6f  seProc(%p)", (vo
0870: 69 64 20 2a 29 20 73 74 61 74 65 50 74 72 29 3b  id *) statePtr);
0880: 0a 0a 20 20 20 20 54 6c 73 5f 43 6c 65 61 6e 28  ..    Tls_Clean(
0890: 73 74 61 74 65 50 74 72 29 3b 0a 20 20 20 20 54  statePtr);.    T
08a0: 63 6c 5f 45 76 65 6e 74 75 61 6c 6c 79 46 72 65  cl_EventuallyFre
08b0: 65 28 28 43 6c 69 65 6e 74 44 61 74 61 29 73 74  e((ClientData)st
08c0: 61 74 65 50 74 72 2c 20 54 6c 73 5f 46 72 65 65  atePtr, Tls_Free
08d0: 29 3b 0a 20 20 20 20 72 65 74 75 72 6e 28 30 29  );.    return(0)
08e0: 3b 0a 7d 0a 0a 73 74 61 74 69 63 20 69 6e 74 20  ;.}..static int 
08f0: 54 6c 73 43 6c 6f 73 65 32 50 72 6f 63 28 43 6c  TlsClose2Proc(Cl
0900: 69 65 6e 74 44 61 74 61 20 69 6e 73 74 61 6e 63  ientData instanc
0910: 65 44 61 74 61 2c 20 20 20 20 2f 2a 20 54 68 65  eData,    /* The
0920: 20 73 6f 63 6b 65 74 20 73 74 61 74 65 2e 20 2a   socket state. *
0930: 2f 0a 20 20 20 20 54 63 6c 5f 49 6e 74 65 72 70  /.    Tcl_Interp
0940: 20 2a 69 6e 74 65 72 70 2c 09 09 2f 2a 20 46 6f   *interp,../* Fo
0950: 72 20 65 72 72 6f 72 73 20 2d 20 63 61 6e 20 62  r errors - can b
0960: 65 20 4e 55 4c 4c 2e 20 2a 2f 0a 20 20 20 20 69  e NULL. */.    i
0970: 6e 74 20 66 6c 61 67 73 29 09 09 09 2f 2a 20 46  nt flags).../* F
0980: 6c 61 67 73 20 74 6f 20 63 6c 6f 73 65 20 72 65  lags to close re
0990: 61 64 20 61 6e 64 2f 6f 72 20 77 72 69 74 65 20  ad and/or write 
09a0: 73 69 64 65 20 6f 66 20 63 68 61 6e 6e 65 6c 20  side of channel 
09b0: 2a 2f 0a 7b 0a 20 20 20 20 53 74 61 74 65 20 2a  */.{.    State *
09c0: 73 74 61 74 65 50 74 72 20 3d 20 28 53 74 61 74  statePtr = (Stat
09d0: 65 20 2a 29 20 69 6e 73 74 61 6e 63 65 44 61 74  e *) instanceDat
09e0: 61 3b 0a 0a 20 20 20 20 64 70 72 69 6e 74 66 28  a;..    dprintf(
09f0: 22 54 6c 73 43 6c 6f 73 65 32 50 72 6f 63 28 25  "TlsClose2Proc(%
0a00: 70 29 22 2c 20 28 76 6f 69 64 20 2a 29 20 73 74  p)", (void *) st
0a10: 61 74 65 50 74 72 29 3b 0a 0a 20 20 20 20 69 66  atePtr);..    if
0a20: 20 28 28 66 6c 61 67 73 20 26 20 28 54 43 4c 5f   ((flags & (TCL_
0a30: 43 4c 4f 53 45 5f 52 45 41 44 7c 54 43 4c 5f 43  CLOSE_READ|TCL_C
0a40: 4c 4f 53 45 5f 57 52 49 54 45 29 29 20 3d 3d 20  LOSE_WRITE)) == 
0a50: 30 29 20 7b 0a 09 72 65 74 75 72 6e 20 54 6c 73  0) {..return Tls
0a60: 43 6c 6f 73 65 50 72 6f 63 28 69 6e 73 74 61 6e  CloseProc(instan
0a70: 63 65 44 61 74 61 2c 20 69 6e 74 65 72 70 29 3b  ceData, interp);
0a80: 0a 20 20 20 20 7d 0a 20 20 20 20 72 65 74 75 72  .    }.    retur
0a90: 6e 20 45 49 4e 56 41 4c 3b 0a 7d 0a 0a 2f 2a 0a  n EINVAL;.}../*.
0aa0: 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d   *--------------
0ab0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0ac0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0ad0: 2d 2d 2d 2d 2d 2d 2d 2d 2a 0a 20 2a 0a 20 2a 20  --------*. *. * 
0ae0: 54 6c 73 5f 57 61 69 74 46 6f 72 43 6f 6e 6e 65  Tls_WaitForConne
0af0: 63 74 20 2d 2d 0a 20 2a 0a 20 2a 20 52 65 73 75  ct --. *. * Resu
0b00: 6c 74 3a 0a 20 2a 20 20 20 20 30 20 69 66 20 73  lt:. *    0 if s
0b10: 75 63 63 65 73 73 66 75 6c 2c 20 2d 31 20 69 66  uccessful, -1 if
0b20: 20 66 61 69 6c 65 64 2e 0a 20 2a 0a 20 2a 20 53   failed.. *. * S
0b30: 69 64 65 20 65 66 66 65 63 74 73 3a 0a 20 2a 20  ide effects:. * 
0b40: 20 20 20 49 73 73 75 65 73 20 53 53 4c 5f 61 63     Issues SSL_ac
0b50: 63 65 70 74 20 6f 72 20 53 53 4c 5f 63 6f 6e 6e  cept or SSL_conn
0b60: 65 63 74 0a 20 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d  ect. *. *-------
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 2a  ---------------*
0ba0: 0a 20 2a 2f 0a 69 6e 74 20 54 6c 73 5f 57 61 69  . */.int Tls_Wai
0bb0: 74 46 6f 72 43 6f 6e 6e 65 63 74 28 53 74 61 74  tForConnect(Stat
0bc0: 65 20 2a 73 74 61 74 65 50 74 72 2c 20 69 6e 74  e *statePtr, int
0bd0: 20 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 2c 20   *errorCodePtr, 
0be0: 69 6e 74 20 68 61 6e 64 73 68 61 6b 65 46 61 69  int handshakeFai
0bf0: 6c 75 72 65 49 73 50 65 72 6d 61 6e 65 6e 74 29  lureIsPermanent)
0c00: 20 7b 0a 20 20 20 20 75 6e 73 69 67 6e 65 64 20   {.    unsigned 
0c10: 6c 6f 6e 67 20 62 61 63 6b 69 6e 67 45 72 72 6f  long backingErro
0c20: 72 3b 0a 20 20 20 20 69 6e 74 20 65 72 72 2c 20  r;.    int err, 
0c30: 72 63 3b 0a 20 20 20 20 69 6e 74 20 62 69 6f 53  rc;.    int bioS
0c40: 68 6f 75 6c 64 52 65 74 72 79 3b 0a 20 20 20 20  houldRetry;.    
0c50: 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 20 3d 20  *errorCodePtr = 
0c60: 30 3b 0a 0a 20 20 20 20 64 70 72 69 6e 74 66 28  0;..    dprintf(
0c70: 22 57 61 69 74 46 6f 72 43 6f 6e 6e 65 63 74 28  "WaitForConnect(
0c80: 25 70 29 22 2c 20 28 76 6f 69 64 20 2a 29 20 73  %p)", (void *) s
0c90: 74 61 74 65 50 74 72 29 3b 0a 20 20 20 20 64 70  tatePtr);.    dp
0ca0: 72 69 6e 74 46 6c 61 67 73 28 73 74 61 74 65 50  rintFlags(stateP
0cb0: 74 72 29 3b 0a 0a 20 20 20 20 69 66 20 28 21 28  tr);..    if (!(
0cc0: 73 74 61 74 65 50 74 72 2d 3e 66 6c 61 67 73 20  statePtr->flags 
0cd0: 26 20 54 4c 53 5f 54 43 4c 5f 49 4e 49 54 29 29  & TLS_TCL_INIT))
0ce0: 20 7b 0a 09 64 70 72 69 6e 74 66 28 22 54 6c 73   {..dprintf("Tls
0cf0: 5f 57 61 69 74 46 6f 72 43 6f 6e 6e 65 63 74 20  _WaitForConnect 
0d00: 63 61 6c 6c 65 64 20 6f 6e 20 61 6c 72 65 61 64  called on alread
0d10: 79 20 69 6e 69 74 69 61 6c 69 7a 65 64 20 63 68  y initialized ch
0d20: 61 6e 6e 65 6c 20 2d 2d 20 72 65 74 75 72 6e 69  annel -- returni
0d30: 6e 67 20 77 69 74 68 20 69 6d 6d 65 64 69 61 74  ng with immediat
0d40: 65 20 73 75 63 63 65 73 73 22 29 3b 0a 09 72 65  e success");..re
0d50: 74 75 72 6e 28 30 29 3b 0a 20 20 20 20 7d 0a 0a  turn(0);.    }..
0d60: 20 20 20 20 69 66 20 28 73 74 61 74 65 50 74 72      if (statePtr
0d70: 2d 3e 66 6c 61 67 73 20 26 20 54 4c 53 5f 54 43  ->flags & TLS_TC
0d80: 4c 5f 48 41 4e 44 53 48 41 4b 45 5f 46 41 49 4c  L_HANDSHAKE_FAIL
0d90: 45 44 29 20 7b 0a 09 2f 2a 0a 09 20 2a 20 44 69  ED) {../*.. * Di
0da0: 66 66 65 72 65 6e 74 20 74 79 70 65 73 20 6f 66  fferent types of
0db0: 20 6f 70 65 72 61 74 69 6f 6e 73 20 68 61 76 65   operations have
0dc0: 20 64 69 66 66 65 72 65 6e 74 20 72 65 71 75 69   different requi
0dd0: 72 65 6d 65 6e 74 73 0a 09 20 2a 20 53 53 4c 20  rements.. * SSL 
0de0: 62 65 69 6e 67 20 65 73 74 61 62 6c 69 73 68 65  being establishe
0df0: 64 0a 09 20 2a 2f 0a 09 69 66 20 28 68 61 6e 64  d.. */..if (hand
0e00: 73 68 61 6b 65 46 61 69 6c 75 72 65 49 73 50 65  shakeFailureIsPe
0e10: 72 6d 61 6e 65 6e 74 29 20 7b 0a 09 20 20 20 20  rmanent) {..    
0e20: 64 70 72 69 6e 74 66 28 22 41 73 6b 65 64 20 74  dprintf("Asked t
0e30: 6f 20 77 61 69 74 20 66 6f 72 20 61 20 54 4c 53  o wait for a TLS
0e40: 20 68 61 6e 64 73 68 61 6b 65 20 74 68 61 74 20   handshake that 
0e50: 68 61 73 20 61 6c 72 65 61 64 79 20 66 61 69 6c  has already fail
0e60: 65 64 2e 20 20 52 65 74 75 72 6e 69 6e 67 20 66  ed.  Returning f
0e70: 61 74 61 6c 20 65 72 72 6f 72 22 29 3b 0a 09 20  atal error");.. 
0e80: 20 20 20 2a 65 72 72 6f 72 43 6f 64 65 50 74 72     *errorCodePtr
0e90: 20 3d 20 45 43 4f 4e 4e 41 42 4f 52 54 45 44 3b   = ECONNABORTED;
0ea0: 0a 09 7d 20 65 6c 73 65 20 7b 0a 09 20 20 20 20  ..} else {..    
0eb0: 64 70 72 69 6e 74 66 28 22 41 73 6b 65 64 20 74  dprintf("Asked t
0ec0: 6f 20 77 61 69 74 20 66 6f 72 20 61 20 54 4c 53  o wait for a TLS
0ed0: 20 68 61 6e 64 73 68 61 6b 65 20 74 68 61 74 20   handshake that 
0ee0: 68 61 73 20 61 6c 72 65 61 64 79 20 66 61 69 6c  has already fail
0ef0: 65 64 2e 20 20 52 65 74 75 72 6e 69 6e 67 20 73  ed.  Returning s
0f00: 6f 66 74 20 65 72 72 6f 72 22 29 3b 0a 09 20 20  oft error");..  
0f10: 20 20 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 20    *errorCodePtr 
0f20: 3d 20 45 43 4f 4e 4e 52 45 53 45 54 3b 0a 09 7d  = ECONNRESET;..}
0f30: 0a 09 54 6c 73 5f 45 72 72 6f 72 28 73 74 61 74  ..Tls_Error(stat
0f40: 65 50 74 72 2c 20 22 57 61 69 74 20 66 6f 72 20  ePtr, "Wait for 
0f50: 66 61 69 6c 65 64 20 68 61 6e 64 73 68 61 6b 65  failed handshake
0f60: 22 29 3b 0a 09 72 65 74 75 72 6e 28 2d 31 29 3b  ");..return(-1);
0f70: 0a 20 20 20 20 7d 0a 0a 20 20 20 20 66 6f 72 20  .    }..    for 
0f80: 28 3b 3b 29 20 7b 0a 09 45 52 52 5f 63 6c 65 61  (;;) {..ERR_clea
0f90: 72 5f 65 72 72 6f 72 28 29 3b 0a 0a 09 2f 2a 20  r_error();.../* 
0fa0: 4e 6f 74 20 69 6e 69 74 69 61 6c 69 7a 65 64 20  Not initialized 
0fb0: 79 65 74 21 20 41 6c 73 6f 20 63 61 6c 6c 73 20  yet! Also calls 
0fc0: 53 53 4c 5f 64 6f 5f 68 61 6e 64 73 68 61 6b 65  SSL_do_handshake
0fd0: 2e 20 2a 2f 0a 09 69 66 20 28 73 74 61 74 65 50  . */..if (stateP
0fe0: 74 72 2d 3e 66 6c 61 67 73 20 26 20 54 4c 53 5f  tr->flags & TLS_
0ff0: 54 43 4c 5f 53 45 52 56 45 52 29 20 7b 0a 09 20  TCL_SERVER) {.. 
1000: 20 20 20 64 70 72 69 6e 74 66 28 22 43 61 6c 6c     dprintf("Call
1010: 69 6e 67 20 53 53 4c 5f 61 63 63 65 70 74 28 29  ing SSL_accept()
1020: 22 29 3b 0a 09 20 20 20 20 65 72 72 20 3d 20 53  ");..    err = S
1030: 53 4c 5f 61 63 63 65 70 74 28 73 74 61 74 65 50  SL_accept(stateP
1040: 74 72 2d 3e 73 73 6c 29 3b 0a 0a 09 7d 20 65 6c  tr->ssl);...} el
1050: 73 65 20 7b 0a 09 20 20 20 20 64 70 72 69 6e 74  se {..    dprint
1060: 66 28 22 43 61 6c 6c 69 6e 67 20 53 53 4c 5f 63  f("Calling SSL_c
1070: 6f 6e 6e 65 63 74 28 29 22 29 3b 0a 09 20 20 20  onnect()");..   
1080: 20 65 72 72 20 3d 20 53 53 4c 5f 63 6f 6e 6e 65   err = SSL_conne
1090: 63 74 28 73 74 61 74 65 50 74 72 2d 3e 73 73 6c  ct(statePtr->ssl
10a0: 29 3b 0a 09 7d 0a 0a 09 69 66 20 28 65 72 72 20  );..}...if (err 
10b0: 3e 20 30 29 20 7b 0a 09 20 20 20 20 64 70 72 69  > 0) {..    dpri
10c0: 6e 74 66 28 22 41 63 63 65 70 74 20 6f 72 20 63  ntf("Accept or c
10d0: 6f 6e 6e 65 63 74 20 77 61 73 20 73 75 63 63 65  onnect was succe
10e0: 73 73 66 75 6c 22 29 3b 0a 0a 09 20 20 20 20 65  ssful");...    e
10f0: 72 72 20 3d 20 42 49 4f 5f 66 6c 75 73 68 28 73  rr = BIO_flush(s
1100: 74 61 74 65 50 74 72 2d 3e 62 69 6f 29 3b 0a 09  tatePtr->bio);..
1110: 20 20 20 20 69 66 20 28 65 72 72 20 3c 3d 20 30      if (err <= 0
1120: 29 20 7b 0a 09 09 64 70 72 69 6e 74 66 28 22 46  ) {...dprintf("F
1130: 6c 75 73 68 69 6e 67 20 74 68 65 20 6c 6f 77 65  lushing the lowe
1140: 72 20 6c 61 79 65 72 73 20 66 61 69 6c 65 64 2c  r layers failed,
1150: 20 74 68 69 73 20 77 69 6c 6c 20 70 72 6f 62 61   this will proba
1160: 62 6c 79 20 74 65 72 6d 69 6e 61 74 65 20 74 68  bly terminate th
1170: 69 73 20 73 65 73 73 69 6f 6e 22 29 3b 0a 09 20  is session");.. 
1180: 20 20 20 7d 0a 09 7d 20 65 6c 73 65 20 7b 0a 09     }..} else {..
1190: 20 20 20 20 64 70 72 69 6e 74 66 28 22 41 63 63      dprintf("Acc
11a0: 65 70 74 20 6f 72 20 63 6f 6e 6e 65 63 74 20 66  ept or connect f
11b0: 61 69 6c 65 64 22 29 3b 0a 09 7d 0a 0a 09 72 63  ailed");..}...rc
11c0: 20 3d 20 53 53 4c 5f 67 65 74 5f 65 72 72 6f 72   = SSL_get_error
11d0: 28 73 74 61 74 65 50 74 72 2d 3e 73 73 6c 2c 20  (statePtr->ssl, 
11e0: 65 72 72 29 3b 0a 09 62 61 63 6b 69 6e 67 45 72  err);..backingEr
11f0: 72 6f 72 20 3d 20 45 52 52 5f 67 65 74 5f 65 72  ror = ERR_get_er
1200: 72 6f 72 28 29 3b 0a 09 69 66 20 28 72 63 20 21  ror();..if (rc !
1210: 3d 20 53 53 4c 5f 45 52 52 4f 52 5f 4e 4f 4e 45  = SSL_ERROR_NONE
1220: 29 20 7b 0a 09 20 20 20 20 64 70 72 69 6e 74 66  ) {..    dprintf
1230: 28 22 47 6f 74 20 65 72 72 6f 72 3a 20 25 69 20  ("Got error: %i 
1240: 28 72 63 20 3d 20 25 69 29 22 2c 20 65 72 72 2c  (rc = %i)", err,
1250: 20 72 63 29 3b 0a 09 20 20 20 20 64 70 72 69 6e   rc);..    dprin
1260: 74 66 28 22 47 6f 74 20 65 72 72 6f 72 3a 20 25  tf("Got error: %
1270: 73 22 2c 20 45 52 52 5f 72 65 61 73 6f 6e 5f 65  s", ERR_reason_e
1280: 72 72 6f 72 5f 73 74 72 69 6e 67 28 62 61 63 6b  rror_string(back
1290: 69 6e 67 45 72 72 6f 72 29 29 3b 0a 09 7d 0a 0a  ingError));..}..
12a0: 09 62 69 6f 53 68 6f 75 6c 64 52 65 74 72 79 20  .bioShouldRetry 
12b0: 3d 20 30 3b 0a 09 69 66 20 28 65 72 72 20 3c 3d  = 0;..if (err <=
12c0: 20 30 29 20 7b 0a 09 20 20 20 20 69 66 20 28 72   0) {..    if (r
12d0: 63 20 3d 3d 20 53 53 4c 5f 45 52 52 4f 52 5f 57  c == SSL_ERROR_W
12e0: 41 4e 54 5f 43 4f 4e 4e 45 43 54 20 7c 7c 20 72  ANT_CONNECT || r
12f0: 63 20 3d 3d 20 53 53 4c 5f 45 52 52 4f 52 5f 57  c == SSL_ERROR_W
1300: 41 4e 54 5f 41 43 43 45 50 54 20 7c 7c 20 72 63  ANT_ACCEPT || rc
1310: 20 3d 3d 20 53 53 4c 5f 45 52 52 4f 52 5f 57 41   == SSL_ERROR_WA
1320: 4e 54 5f 52 45 41 44 20 7c 7c 20 72 63 20 3d 3d  NT_READ || rc ==
1330: 20 53 53 4c 5f 45 52 52 4f 52 5f 57 41 4e 54 5f   SSL_ERROR_WANT_
1340: 57 52 49 54 45 29 20 7b 0a 09 09 62 69 6f 53 68  WRITE) {...bioSh
1350: 6f 75 6c 64 52 65 74 72 79 20 3d 20 31 3b 0a 09  ouldRetry = 1;..
1360: 20 20 20 20 7d 20 65 6c 73 65 20 69 66 20 28 42      } else if (B
1370: 49 4f 5f 73 68 6f 75 6c 64 5f 72 65 74 72 79 28  IO_should_retry(
1380: 73 74 61 74 65 50 74 72 2d 3e 62 69 6f 29 29 20  statePtr->bio)) 
1390: 7b 0a 09 09 62 69 6f 53 68 6f 75 6c 64 52 65 74  {...bioShouldRet
13a0: 72 79 20 3d 20 31 3b 0a 09 20 20 20 20 7d 20 65  ry = 1;..    } e
13b0: 6c 73 65 20 69 66 20 28 72 63 20 3d 3d 20 53 53  lse if (rc == SS
13c0: 4c 5f 45 52 52 4f 52 5f 53 59 53 43 41 4c 4c 20  L_ERROR_SYSCALL 
13d0: 26 26 20 54 63 6c 5f 47 65 74 45 72 72 6e 6f 28  && Tcl_GetErrno(
13e0: 29 20 3d 3d 20 45 41 47 41 49 4e 29 20 7b 0a 09  ) == EAGAIN) {..
13f0: 09 62 69 6f 53 68 6f 75 6c 64 52 65 74 72 79 20  .bioShouldRetry 
1400: 3d 20 31 3b 0a 09 20 20 20 20 7d 0a 09 7d 20 65  = 1;..    }..} e
1410: 6c 73 65 20 7b 0a 09 20 20 20 20 69 66 20 28 21  lse {..    if (!
1420: 53 53 4c 5f 69 73 5f 69 6e 69 74 5f 66 69 6e 69  SSL_is_init_fini
1430: 73 68 65 64 28 73 74 61 74 65 50 74 72 2d 3e 73  shed(statePtr->s
1440: 73 6c 29 29 20 7b 0a 09 09 62 69 6f 53 68 6f 75  sl)) {...bioShou
1450: 6c 64 52 65 74 72 79 20 3d 20 31 3b 0a 09 20 20  ldRetry = 1;..  
1460: 20 20 7d 0a 09 7d 0a 0a 09 69 66 20 28 62 69 6f    }..}...if (bio
1470: 53 68 6f 75 6c 64 52 65 74 72 79 29 20 7b 0a 09  ShouldRetry) {..
1480: 20 20 20 20 64 70 72 69 6e 74 66 28 22 54 68 65      dprintf("The
1490: 20 49 2f 4f 20 64 69 64 20 6e 6f 74 20 63 6f 6d   I/O did not com
14a0: 70 6c 65 74 65 20 2d 2d 20 62 75 74 20 77 65 20  plete -- but we 
14b0: 73 68 6f 75 6c 64 20 74 72 79 20 69 74 20 61 67  should try it ag
14c0: 61 69 6e 22 29 3b 0a 0a 09 20 20 20 20 69 66 20  ain");...    if 
14d0: 28 73 74 61 74 65 50 74 72 2d 3e 66 6c 61 67 73  (statePtr->flags
14e0: 20 26 20 54 4c 53 5f 54 43 4c 5f 41 53 59 4e 43   & TLS_TCL_ASYNC
14f0: 29 20 7b 0a 09 09 64 70 72 69 6e 74 66 28 22 52  ) {...dprintf("R
1500: 65 74 75 72 6e 69 6e 67 20 45 41 47 41 49 4e 20  eturning EAGAIN 
1510: 73 6f 20 74 68 61 74 20 69 74 20 63 61 6e 20 62  so that it can b
1520: 65 20 72 65 74 72 69 65 64 20 6c 61 74 65 72 22  e retried later"
1530: 29 3b 0a 09 09 2a 65 72 72 6f 72 43 6f 64 65 50  );...*errorCodeP
1540: 74 72 20 3d 20 45 41 47 41 49 4e 3b 0a 09 09 54  tr = EAGAIN;...T
1550: 6c 73 5f 45 72 72 6f 72 28 73 74 61 74 65 50 74  ls_Error(statePt
1560: 72 2c 20 22 48 61 6e 64 73 68 61 6b 65 20 6e 6f  r, "Handshake no
1570: 74 20 63 6f 6d 70 6c 65 74 65 2c 20 77 69 6c 6c  t complete, will
1580: 20 72 65 74 72 79 20 6c 61 74 65 72 22 29 3b 0a   retry later");.
1590: 09 09 72 65 74 75 72 6e 28 2d 31 29 3b 0a 09 20  ..return(-1);.. 
15a0: 20 20 20 7d 20 65 6c 73 65 20 7b 0a 09 09 64 70     } else {...dp
15b0: 72 69 6e 74 66 28 22 44 6f 69 6e 67 20 73 6f 20  rintf("Doing so 
15c0: 6e 6f 77 22 29 3b 0a 09 09 63 6f 6e 74 69 6e 75  now");...continu
15d0: 65 3b 0a 09 20 20 20 20 7d 0a 09 7d 0a 0a 09 64  e;..    }..}...d
15e0: 70 72 69 6e 74 66 28 22 57 65 20 68 61 76 65 20  printf("We have 
15f0: 65 69 74 68 65 72 20 63 6f 6d 70 6c 65 74 65 6c  either completel
1600: 79 20 65 73 74 61 62 6c 69 73 68 65 64 20 74 68  y established th
1610: 65 20 73 65 73 73 69 6f 6e 20 6f 72 20 63 6f 6d  e session or com
1620: 70 6c 65 74 65 6c 79 20 66 61 69 6c 65 64 20 69  pletely failed i
1630: 74 20 2d 2d 20 74 68 65 72 65 20 69 73 20 6e 6f  t -- there is no
1640: 20 6d 6f 72 65 20 6e 65 65 64 20 74 6f 20 65 76   more need to ev
1650: 65 72 20 72 65 74 72 79 20 69 74 20 74 68 6f 75  er retry it thou
1660: 67 68 22 29 3b 0a 09 62 72 65 61 6b 3b 0a 20 20  gh");..break;.  
1670: 20 20 7d 0a 0a 20 20 20 20 73 77 69 74 63 68 20    }..    switch 
1680: 28 72 63 29 20 7b 0a 09 63 61 73 65 20 53 53 4c  (rc) {..case SSL
1690: 5f 45 52 52 4f 52 5f 4e 4f 4e 45 3a 0a 09 20 20  _ERROR_NONE:..  
16a0: 20 20 2f 2a 20 54 68 65 20 54 4c 53 2f 53 53 4c    /* The TLS/SSL
16b0: 20 49 2f 4f 20 6f 70 65 72 61 74 69 6f 6e 20 63   I/O operation c
16c0: 6f 6d 70 6c 65 74 65 64 20 2a 2f 0a 09 20 20 20  ompleted */..   
16d0: 20 64 70 72 69 6e 74 66 28 22 54 68 65 20 63 6f   dprintf("The co
16e0: 6e 6e 65 63 74 69 6f 6e 20 69 73 20 67 6f 6f 64  nnection is good
16f0: 22 29 3b 0a 09 20 20 20 20 2a 65 72 72 6f 72 43  ");..    *errorC
1700: 6f 64 65 50 74 72 20 3d 20 30 3b 0a 09 20 20 20  odePtr = 0;..   
1710: 20 62 72 65 61 6b 3b 0a 0a 09 63 61 73 65 20 53   break;...case S
1720: 53 4c 5f 45 52 52 4f 52 5f 5a 45 52 4f 5f 52 45  SL_ERROR_ZERO_RE
1730: 54 55 52 4e 3a 0a 09 20 20 20 20 2f 2a 20 54 68  TURN:..    /* Th
1740: 65 20 54 4c 53 2f 53 53 4c 20 70 65 65 72 20 68  e TLS/SSL peer h
1750: 61 73 20 63 6c 6f 73 65 64 20 74 68 65 20 63 6f  as closed the co
1760: 6e 6e 65 63 74 69 6f 6e 20 66 6f 72 20 77 72 69  nnection for wri
1770: 74 69 6e 67 20 62 79 20 73 65 6e 64 69 6e 67 20  ting by sending 
1780: 74 68 65 20 63 6c 6f 73 65 5f 6e 6f 74 69 66 79  the close_notify
1790: 20 61 6c 65 72 74 20 2a 2f 0a 09 20 20 20 20 64   alert */..    d
17a0: 70 72 69 6e 74 66 28 22 53 53 4c 5f 45 52 52 4f  printf("SSL_ERRO
17b0: 52 5f 5a 45 52 4f 5f 52 45 54 55 52 4e 3a 20 43  R_ZERO_RETURN: C
17c0: 6f 6e 6e 65 63 74 20 72 65 74 75 72 6e 65 64 20  onnect returned 
17d0: 61 6e 20 69 6e 76 61 6c 69 64 20 76 61 6c 75 65  an invalid value
17e0: 2e 2e 2e 22 29 3b 0a 09 20 20 20 20 2a 65 72 72  ...");..    *err
17f0: 6f 72 43 6f 64 65 50 74 72 20 3d 20 45 49 4e 56  orCodePtr = EINV
1800: 41 4c 3b 0a 09 20 20 20 20 54 6c 73 5f 45 72 72  AL;..    Tls_Err
1810: 6f 72 28 73 74 61 74 65 50 74 72 2c 20 22 50 65  or(statePtr, "Pe
1820: 65 72 20 68 61 73 20 63 6c 6f 73 65 64 20 74 68  er has closed th
1830: 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 66 6f 72  e connection for
1840: 20 77 72 69 74 69 6e 67 20 62 79 20 73 65 6e 64   writing by send
1850: 69 6e 67 20 74 68 65 20 63 6c 6f 73 65 5f 6e 6f  ing the close_no
1860: 74 69 66 79 20 61 6c 65 72 74 22 29 3b 0a 09 20  tify alert");.. 
1870: 20 20 20 72 65 74 75 72 6e 28 2d 31 29 3b 0a 0a     return(-1);..
1880: 09 63 61 73 65 20 53 53 4c 5f 45 52 52 4f 52 5f  .case SSL_ERROR_
1890: 53 59 53 43 41 4c 4c 3a 0a 09 20 20 20 20 2f 2a  SYSCALL:..    /*
18a0: 20 53 6f 6d 65 20 6e 6f 6e 2d 72 65 63 6f 76 65   Some non-recove
18b0: 72 61 62 6c 65 2c 20 66 61 74 61 6c 20 49 2f 4f  rable, fatal I/O
18c0: 20 65 72 72 6f 72 20 6f 63 63 75 72 72 65 64 20   error occurred 
18d0: 2a 2f 0a 09 20 20 20 20 64 70 72 69 6e 74 66 28  */..    dprintf(
18e0: 22 53 53 4c 5f 45 52 52 4f 52 5f 53 59 53 43 41  "SSL_ERROR_SYSCA
18f0: 4c 4c 22 29 3b 0a 0a 09 20 20 20 20 69 66 20 28  LL");...    if (
1900: 62 61 63 6b 69 6e 67 45 72 72 6f 72 20 3d 3d 20  backingError == 
1910: 30 20 26 26 20 65 72 72 20 3d 3d 20 30 29 20 7b  0 && err == 0) {
1920: 0a 09 09 64 70 72 69 6e 74 66 28 22 45 4f 46 20  ...dprintf("EOF 
1930: 72 65 61 63 68 65 64 22 29 0a 09 09 2a 65 72 72  reached")...*err
1940: 6f 72 43 6f 64 65 50 74 72 20 3d 20 45 43 4f 4e  orCodePtr = ECON
1950: 4e 52 45 53 45 54 3b 0a 09 09 54 6c 73 5f 45 72  NRESET;...Tls_Er
1960: 72 6f 72 28 73 74 61 74 65 50 74 72 2c 20 22 28  ror(statePtr, "(
1970: 75 6e 65 78 70 65 63 74 65 64 29 20 45 4f 46 20  unexpected) EOF 
1980: 72 65 61 63 68 65 64 22 29 3b 0a 0a 09 20 20 20  reached");...   
1990: 20 7d 20 65 6c 73 65 20 69 66 20 28 62 61 63 6b   } else if (back
19a0: 69 6e 67 45 72 72 6f 72 20 3d 3d 20 30 20 26 26  ingError == 0 &&
19b0: 20 65 72 72 20 3d 3d 20 2d 31 29 20 7b 0a 09 09   err == -1) {...
19c0: 64 70 72 69 6e 74 66 28 22 49 2f 4f 20 65 72 72  dprintf("I/O err
19d0: 6f 72 20 6f 63 63 75 72 72 65 64 20 28 65 72 72  or occurred (err
19e0: 6e 6f 20 3d 20 25 6c 75 29 22 2c 20 28 75 6e 73  no = %lu)", (uns
19f0: 69 67 6e 65 64 20 6c 6f 6e 67 29 20 54 63 6c 5f  igned long) Tcl_
1a00: 47 65 74 45 72 72 6e 6f 28 29 29 3b 0a 09 09 2a  GetErrno());...*
1a10: 65 72 72 6f 72 43 6f 64 65 50 74 72 20 3d 20 54  errorCodePtr = T
1a20: 63 6c 5f 47 65 74 45 72 72 6e 6f 28 29 3b 0a 09  cl_GetErrno();..
1a30: 09 69 66 20 28 2a 65 72 72 6f 72 43 6f 64 65 50  .if (*errorCodeP
1a40: 74 72 20 3d 3d 20 45 43 4f 4e 4e 52 45 53 45 54  tr == ECONNRESET
1a50: 29 20 7b 0a 09 09 20 20 20 20 2a 65 72 72 6f 72  ) {...    *error
1a60: 43 6f 64 65 50 74 72 20 3d 20 45 43 4f 4e 4e 41  CodePtr = ECONNA
1a70: 42 4f 52 54 45 44 3b 0a 09 09 7d 0a 09 09 54 6c  BORTED;...}...Tl
1a80: 73 5f 45 72 72 6f 72 28 73 74 61 74 65 50 74 72  s_Error(statePtr
1a90: 2c 20 28 63 68 61 72 20 2a 29 20 54 63 6c 5f 45  , (char *) Tcl_E
1aa0: 72 72 6e 6f 4d 73 67 28 2a 65 72 72 6f 72 43 6f  rrnoMsg(*errorCo
1ab0: 64 65 50 74 72 29 29 3b 0a 0a 09 20 20 20 20 7d  dePtr));...    }
1ac0: 20 65 6c 73 65 20 7b 0a 09 09 64 70 72 69 6e 74   else {...dprint
1ad0: 66 28 22 49 2f 4f 20 65 72 72 6f 72 20 6f 63 63  f("I/O error occ
1ae0: 75 72 72 65 64 20 28 62 61 63 6b 69 6e 67 45 72  urred (backingEr
1af0: 72 6f 72 20 3d 20 25 6c 75 29 22 2c 20 62 61 63  ror = %lu)", bac
1b00: 6b 69 6e 67 45 72 72 6f 72 29 3b 0a 09 09 2a 65  kingError);...*e
1b10: 72 72 6f 72 43 6f 64 65 50 74 72 20 3d 20 54 63  rrorCodePtr = Tc
1b20: 6c 5f 47 65 74 45 72 72 6e 6f 28 29 3b 0a 09 09  l_GetErrno();...
1b30: 69 66 20 28 2a 65 72 72 6f 72 43 6f 64 65 50 74  if (*errorCodePt
1b40: 72 20 3d 3d 20 45 43 4f 4e 4e 52 45 53 45 54 29  r == ECONNRESET)
1b50: 20 7b 0a 09 09 20 20 20 20 2a 65 72 72 6f 72 43   {...    *errorC
1b60: 6f 64 65 50 74 72 20 3d 20 45 43 4f 4e 4e 41 42  odePtr = ECONNAB
1b70: 4f 52 54 45 44 3b 0a 09 09 7d 0a 09 09 54 6c 73  ORTED;...}...Tls
1b80: 5f 45 72 72 6f 72 28 73 74 61 74 65 50 74 72 2c  _Error(statePtr,
1b90: 20 28 63 68 61 72 20 2a 29 20 45 52 52 5f 72 65   (char *) ERR_re
1ba0: 61 73 6f 6e 5f 65 72 72 6f 72 5f 73 74 72 69 6e  ason_error_strin
1bb0: 67 28 62 61 63 6b 69 6e 67 45 72 72 6f 72 29 29  g(backingError))
1bc0: 3b 0a 09 20 20 20 20 7d 0a 0a 09 20 20 20 20 73  ;..    }...    s
1bd0: 74 61 74 65 50 74 72 2d 3e 66 6c 61 67 73 20 7c  tatePtr->flags |
1be0: 3d 20 54 4c 53 5f 54 43 4c 5f 48 41 4e 44 53 48  = TLS_TCL_HANDSH
1bf0: 41 4b 45 5f 46 41 49 4c 45 44 3b 0a 09 20 20 20  AKE_FAILED;..   
1c00: 20 72 65 74 75 72 6e 28 2d 31 29 3b 0a 0a 09 63   return(-1);...c
1c10: 61 73 65 20 53 53 4c 5f 45 52 52 4f 52 5f 53 53  ase SSL_ERROR_SS
1c20: 4c 3a 0a 09 20 20 20 20 2f 2a 20 41 20 6e 6f 6e  L:..    /* A non
1c30: 2d 72 65 63 6f 76 65 72 61 62 6c 65 2c 20 66 61  -recoverable, fa
1c40: 74 61 6c 20 65 72 72 6f 72 20 69 6e 20 74 68 65  tal error in the
1c50: 20 53 53 4c 20 6c 69 62 72 61 72 79 20 6f 63 63   SSL library occ
1c60: 75 72 72 65 64 2c 20 75 73 75 61 6c 6c 79 20 61  urred, usually a
1c70: 20 70 72 6f 74 6f 63 6f 6c 20 65 72 72 6f 72 20   protocol error 
1c80: 2a 2f 0a 09 20 20 20 20 64 70 72 69 6e 74 66 28  */..    dprintf(
1c90: 22 53 53 4c 5f 45 52 52 4f 52 5f 53 53 4c 3a 20  "SSL_ERROR_SSL: 
1ca0: 47 6f 74 20 70 65 72 6d 61 6e 65 6e 74 20 66 61  Got permanent fa
1cb0: 74 61 6c 20 53 53 4c 20 65 72 72 6f 72 2c 20 61  tal SSL error, a
1cc0: 62 6f 72 74 69 6e 67 20 69 6d 6d 65 64 69 61 74  borting immediat
1cd0: 65 6c 79 22 29 3b 0a 09 20 20 20 20 69 66 20 28  ely");..    if (
1ce0: 53 53 4c 5f 67 65 74 5f 76 65 72 69 66 79 5f 72  SSL_get_verify_r
1cf0: 65 73 75 6c 74 28 73 74 61 74 65 50 74 72 2d 3e  esult(statePtr->
1d00: 73 73 6c 29 20 21 3d 20 58 35 30 39 5f 56 5f 4f  ssl) != X509_V_O
1d10: 4b 29 20 7b 0a 09 09 54 6c 73 5f 45 72 72 6f 72  K) {...Tls_Error
1d20: 28 73 74 61 74 65 50 74 72 2c 20 28 63 68 61 72  (statePtr, (char
1d30: 20 2a 29 20 58 35 30 39 5f 76 65 72 69 66 79 5f   *) X509_verify_
1d40: 63 65 72 74 5f 65 72 72 6f 72 5f 73 74 72 69 6e  cert_error_strin
1d50: 67 28 53 53 4c 5f 67 65 74 5f 76 65 72 69 66 79  g(SSL_get_verify
1d60: 5f 72 65 73 75 6c 74 28 73 74 61 74 65 50 74 72  _result(statePtr
1d70: 2d 3e 73 73 6c 29 29 29 3b 0a 09 20 20 20 20 7d  ->ssl)));..    }
1d80: 0a 09 20 20 20 20 69 66 20 28 62 61 63 6b 69 6e  ..    if (backin
1d90: 67 45 72 72 6f 72 20 21 3d 20 30 29 20 7b 0a 09  gError != 0) {..
1da0: 09 54 6c 73 5f 45 72 72 6f 72 28 73 74 61 74 65  .Tls_Error(state
1db0: 50 74 72 2c 20 28 63 68 61 72 20 2a 29 20 45 52  Ptr, (char *) ER
1dc0: 52 5f 72 65 61 73 6f 6e 5f 65 72 72 6f 72 5f 73  R_reason_error_s
1dd0: 74 72 69 6e 67 28 62 61 63 6b 69 6e 67 45 72 72  tring(backingErr
1de0: 6f 72 29 29 3b 0a 09 20 20 20 20 7d 0a 09 20 20  or));..    }..  
1df0: 20 20 73 74 61 74 65 50 74 72 2d 3e 66 6c 61 67    statePtr->flag
1e00: 73 20 7c 3d 20 54 4c 53 5f 54 43 4c 5f 48 41 4e  s |= TLS_TCL_HAN
1e10: 44 53 48 41 4b 45 5f 46 41 49 4c 45 44 3b 0a 09  DSHAKE_FAILED;..
1e20: 20 20 20 20 2a 65 72 72 6f 72 43 6f 64 65 50 74      *errorCodePt
1e30: 72 20 3d 20 45 43 4f 4e 4e 41 42 4f 52 54 45 44  r = ECONNABORTED
1e40: 3b 0a 09 20 20 20 20 72 65 74 75 72 6e 28 2d 31  ;..    return(-1
1e50: 29 3b 0a 0a 09 63 61 73 65 20 53 53 4c 5f 45 52  );...case SSL_ER
1e60: 52 4f 52 5f 57 41 4e 54 5f 52 45 41 44 3a 0a 09  ROR_WANT_READ:..
1e70: 63 61 73 65 20 53 53 4c 5f 45 52 52 4f 52 5f 57  case SSL_ERROR_W
1e80: 41 4e 54 5f 57 52 49 54 45 3a 0a 09 63 61 73 65  ANT_WRITE:..case
1e90: 20 53 53 4c 5f 45 52 52 4f 52 5f 57 41 4e 54 5f   SSL_ERROR_WANT_
1ea0: 58 35 30 39 5f 4c 4f 4f 4b 55 50 3a 0a 09 63 61  X509_LOOKUP:..ca
1eb0: 73 65 20 53 53 4c 5f 45 52 52 4f 52 5f 57 41 4e  se SSL_ERROR_WAN
1ec0: 54 5f 43 4f 4e 4e 45 43 54 3a 0a 09 63 61 73 65  T_CONNECT:..case
1ed0: 20 53 53 4c 5f 45 52 52 4f 52 5f 57 41 4e 54 5f   SSL_ERROR_WANT_
1ee0: 41 43 43 45 50 54 3a 0a 09 63 61 73 65 20 53 53  ACCEPT:..case SS
1ef0: 4c 5f 45 52 52 4f 52 5f 57 41 4e 54 5f 41 53 59  L_ERROR_WANT_ASY
1f00: 4e 43 3a 0a 09 63 61 73 65 20 53 53 4c 5f 45 52  NC:..case SSL_ER
1f10: 52 4f 52 5f 57 41 4e 54 5f 41 53 59 4e 43 5f 4a  ROR_WANT_ASYNC_J
1f20: 4f 42 3a 0a 09 63 61 73 65 20 53 53 4c 5f 45 52  OB:..case SSL_ER
1f30: 52 4f 52 5f 57 41 4e 54 5f 43 4c 49 45 4e 54 5f  ROR_WANT_CLIENT_
1f40: 48 45 4c 4c 4f 5f 43 42 3a 0a 09 64 65 66 61 75  HELLO_CB:..defau
1f50: 6c 74 3a 0a 09 20 20 20 20 2f 2a 20 54 68 65 20  lt:..    /* The 
1f60: 6f 70 65 72 61 74 69 6f 6e 20 64 69 64 20 6e 6f  operation did no
1f70: 74 20 63 6f 6d 70 6c 65 74 65 20 61 6e 64 20 73  t complete and s
1f80: 68 6f 75 6c 64 20 62 65 20 72 65 74 72 69 65 64  hould be retried
1f90: 20 6c 61 74 65 72 2e 20 2a 2f 0a 09 20 20 20 20   later. */..    
1fa0: 64 70 72 69 6e 74 66 28 22 4f 70 65 72 61 74 69  dprintf("Operati
1fb0: 6f 6e 20 64 69 64 20 6e 6f 74 20 63 6f 6d 70 6c  on did not compl
1fc0: 65 74 65 2c 20 63 61 6c 6c 20 66 75 6e 63 74 69  ete, call functi
1fd0: 6f 6e 20 61 67 61 69 6e 20 6c 61 74 65 72 3a 20  on again later: 
1fe0: 25 69 22 2c 20 72 63 29 3b 0a 09 20 20 20 20 2a  %i", rc);..    *
1ff0: 65 72 72 6f 72 43 6f 64 65 50 74 72 20 3d 20 45  errorCodePtr = E
2000: 41 47 41 49 4e 3b 0a 09 20 20 20 20 64 70 72 69  AGAIN;..    dpri
2010: 6e 74 66 28 22 45 52 52 28 25 64 2c 20 25 64 29  ntf("ERR(%d, %d)
2020: 20 22 2c 20 72 63 2c 20 2a 65 72 72 6f 72 43 6f   ", rc, *errorCo
2030: 64 65 50 74 72 29 3b 0a 09 20 20 20 20 54 6c 73  dePtr);..    Tls
2040: 5f 45 72 72 6f 72 28 73 74 61 74 65 50 74 72 2c  _Error(statePtr,
2050: 20 22 4f 70 65 72 61 74 69 6f 6e 20 64 69 64 20   "Operation did 
2060: 6e 6f 74 20 63 6f 6d 70 6c 65 74 65 2c 20 63 61  not complete, ca
2070: 6c 6c 20 66 75 6e 63 74 69 6f 6e 20 61 67 61 69  ll function agai
2080: 6e 20 6c 61 74 65 72 22 29 3b 0a 09 20 20 20 20  n later");..    
2090: 72 65 74 75 72 6e 28 2d 31 29 3b 0a 20 20 20 20  return(-1);.    
20a0: 7d 0a 0a 20 20 20 20 64 70 72 69 6e 74 66 28 22  }..    dprintf("
20b0: 52 65 6d 6f 76 69 6e 67 20 74 68 65 20 5c 22 54  Removing the \"T
20c0: 4c 53 5f 54 43 4c 5f 49 4e 49 54 5c 22 20 66 6c  LS_TCL_INIT\" fl
20d0: 61 67 20 73 69 6e 63 65 20 77 65 20 68 61 76 65  ag since we have
20e0: 20 63 6f 6d 70 6c 65 74 65 64 20 74 68 65 20 68   completed the h
20f0: 61 6e 64 73 68 61 6b 65 22 29 3b 0a 20 20 20 20  andshake");.    
2100: 73 74 61 74 65 50 74 72 2d 3e 66 6c 61 67 73 20  statePtr->flags 
2110: 26 3d 20 7e 54 4c 53 5f 54 43 4c 5f 49 4e 49 54  &= ~TLS_TCL_INIT
2120: 3b 0a 0a 20 20 20 20 64 70 72 69 6e 74 66 28 22  ;..    dprintf("
2130: 52 65 74 75 72 6e 69 6e 67 20 69 6e 20 73 75 63  Returning in suc
2140: 63 65 73 73 22 29 3b 0a 20 20 20 20 2a 65 72 72  cess");.    *err
2150: 6f 72 43 6f 64 65 50 74 72 20 3d 20 30 3b 0a 20  orCodePtr = 0;. 
2160: 20 20 20 72 65 74 75 72 6e 28 30 29 3b 0a 7d 0a     return(0);.}.
2170: 0a 2f 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ./*. *----------
2180: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2190: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
21a0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
21b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 0a 20 2a 20  ---------. *. * 
21c0: 54 6c 73 49 6e 70 75 74 50 72 6f 63 20 2d 2d 0a  TlsInputProc --.
21d0: 20 2a 0a 20 2a 20 20 20 20 54 68 69 73 20 70 72   *. *    This pr
21e0: 6f 63 65 64 75 72 65 20 69 73 20 69 6e 76 6f 6b  ocedure is invok
21f0: 65 64 20 62 79 20 74 68 65 20 67 65 6e 65 72 69  ed by the generi
2200: 63 20 49 4f 20 6c 65 76 65 6c 0a 20 2a 20 20 20  c IO level. *   
2210: 20 20 20 20 74 6f 20 72 65 61 64 20 69 6e 70 75      to read inpu
2220: 74 20 66 72 6f 6d 20 61 20 53 53 4c 20 73 6f 63  t from a SSL soc
2230: 6b 65 74 20 62 61 73 65 64 20 63 68 61 6e 6e 65  ket based channe
2240: 6c 2e 0a 20 2a 0a 20 2a 20 52 65 73 75 6c 74 73  l.. *. * Results
2250: 3a 0a 20 2a 20 20 20 20 52 65 74 75 72 6e 73 20  :. *    Returns 
2260: 74 68 65 20 6e 75 6d 62 65 72 20 6f 66 20 62 79  the number of by
2270: 74 65 73 20 72 65 61 64 20 6f 72 20 2d 31 20 6f  tes read or -1 o
2280: 6e 20 65 72 72 6f 72 2e 20 53 65 74 73 20 65 72  n error. Sets er
2290: 72 6f 72 43 6f 64 65 50 74 72 0a 20 2a 20 20 20  rorCodePtr. *   
22a0: 20 74 6f 20 61 20 50 4f 53 49 58 20 65 72 72 6f   to a POSIX erro
22b0: 72 20 63 6f 64 65 20 69 66 20 61 6e 20 65 72 72  r code if an err
22c0: 6f 72 20 6f 63 63 75 72 72 65 64 2c 20 6f 72 20  or occurred, or 
22d0: 30 20 69 66 20 6e 6f 6e 65 2e 0a 20 2a 0a 20 2a  0 if none.. *. *
22e0: 20 53 69 64 65 20 65 66 66 65 63 74 73 3a 0a 20   Side effects:. 
22f0: 2a 20 20 20 20 52 65 61 64 73 20 69 6e 70 75 74  *    Reads input
2300: 20 66 72 6f 6d 20 74 68 65 20 69 6e 70 75 74 20   from the input 
2310: 64 65 76 69 63 65 20 6f 66 20 74 68 65 20 63 68  device of the ch
2320: 61 6e 6e 65 6c 2e 0a 20 2a 0a 20 2a 2d 2d 2d 2d  annel.. *. *----
2330: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2340: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2350: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2360: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a  ---------------.
2370: 20 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 54   */.static int T
2380: 6c 73 49 6e 70 75 74 50 72 6f 63 28 43 6c 69 65  lsInputProc(Clie
2390: 6e 74 44 61 74 61 20 69 6e 73 74 61 6e 63 65 44  ntData instanceD
23a0: 61 74 61 2c 20 63 68 61 72 20 2a 62 75 66 2c 20  ata, char *buf, 
23b0: 69 6e 74 20 62 75 66 53 69 7a 65 2c 20 69 6e 74  int bufSize, int
23c0: 20 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 29 20   *errorCodePtr) 
23d0: 7b 0a 20 20 20 20 75 6e 73 69 67 6e 65 64 20 6c  {.    unsigned l
23e0: 6f 6e 67 20 62 61 63 6b 69 6e 67 45 72 72 6f 72  ong backingError
23f0: 3b 0a 20 20 20 20 53 74 61 74 65 20 2a 73 74 61  ;.    State *sta
2400: 74 65 50 74 72 20 3d 20 28 53 74 61 74 65 20 2a  tePtr = (State *
2410: 29 20 69 6e 73 74 61 6e 63 65 44 61 74 61 3b 0a  ) instanceData;.
2420: 20 20 20 20 69 6e 74 20 62 79 74 65 73 52 65 61      int bytesRea
2430: 64 3b 0a 20 20 20 20 69 6e 74 20 74 6c 73 43 6f  d;.    int tlsCo
2440: 6e 6e 65 63 74 3b 0a 20 20 20 20 69 6e 74 20 65  nnect;.    int e
2450: 72 72 3b 0a 0a 20 20 20 20 2a 65 72 72 6f 72 43  rr;..    *errorC
2460: 6f 64 65 50 74 72 20 3d 20 30 3b 0a 0a 20 20 20  odePtr = 0;..   
2470: 20 64 70 72 69 6e 74 66 28 22 42 49 4f 5f 72 65   dprintf("BIO_re
2480: 61 64 28 25 64 29 22 2c 20 62 75 66 53 69 7a 65  ad(%d)", bufSize
2490: 29 3b 0a 0a 20 20 20 20 69 66 20 28 73 74 61 74  );..    if (stat
24a0: 65 50 74 72 2d 3e 66 6c 61 67 73 20 26 20 54 4c  ePtr->flags & TL
24b0: 53 5f 54 43 4c 5f 43 41 4c 4c 42 41 43 4b 29 20  S_TCL_CALLBACK) 
24c0: 7b 0a 09 2f 2a 20 64 6f 6e 27 74 20 70 72 6f 63  {../* don't proc
24d0: 65 73 73 20 61 6e 79 20 62 79 74 65 73 20 77 68  ess any bytes wh
24e0: 69 6c 65 20 76 65 72 69 66 79 20 63 61 6c 6c 62  ile verify callb
24f0: 61 63 6b 20 69 73 20 72 75 6e 6e 69 6e 67 20 2a  ack is running *
2500: 2f 0a 09 64 70 72 69 6e 74 66 28 22 43 61 6c 6c  /..dprintf("Call
2510: 62 61 63 6b 20 69 73 20 72 75 6e 6e 69 6e 67 2c  back is running,
2520: 20 72 65 61 64 69 6e 67 20 30 20 62 79 74 65 73   reading 0 bytes
2530: 22 29 3b 0a 09 72 65 74 75 72 6e 28 30 29 3b 0a  ");..return(0);.
2540: 20 20 20 20 7d 0a 0a 20 20 20 20 64 70 72 69 6e      }..    dprin
2550: 74 66 28 22 43 61 6c 6c 69 6e 67 20 54 6c 73 5f  tf("Calling Tls_
2560: 57 61 69 74 46 6f 72 43 6f 6e 6e 65 63 74 22 29  WaitForConnect")
2570: 3b 0a 20 20 20 20 74 6c 73 43 6f 6e 6e 65 63 74  ;.    tlsConnect
2580: 20 3d 20 54 6c 73 5f 57 61 69 74 46 6f 72 43 6f   = Tls_WaitForCo
2590: 6e 6e 65 63 74 28 73 74 61 74 65 50 74 72 2c 20  nnect(statePtr, 
25a0: 65 72 72 6f 72 43 6f 64 65 50 74 72 2c 20 30 29  errorCodePtr, 0)
25b0: 3b 0a 20 20 20 20 69 66 20 28 74 6c 73 43 6f 6e  ;.    if (tlsCon
25c0: 6e 65 63 74 20 3c 20 30 29 20 7b 0a 09 64 70 72  nect < 0) {..dpr
25d0: 69 6e 74 66 28 22 47 6f 74 20 61 6e 20 65 72 72  intf("Got an err
25e0: 6f 72 20 77 61 69 74 69 6e 67 20 74 6f 20 63 6f  or waiting to co
25f0: 6e 6e 65 63 74 20 28 74 6c 73 43 6f 6e 6e 65 63  nnect (tlsConnec
2600: 74 20 3d 20 25 69 2c 20 2a 65 72 72 6f 72 43 6f  t = %i, *errorCo
2610: 64 65 50 74 72 20 3d 20 25 69 29 22 2c 20 74 6c  dePtr = %i)", tl
2620: 73 43 6f 6e 6e 65 63 74 2c 20 2a 65 72 72 6f 72  sConnect, *error
2630: 43 6f 64 65 50 74 72 29 3b 0a 09 54 6c 73 5f 45  CodePtr);..Tls_E
2640: 72 72 6f 72 28 73 74 61 74 65 50 74 72 2c 20 73  rror(statePtr, s
2650: 74 72 65 72 72 6f 72 28 2a 65 72 72 6f 72 43 6f  trerror(*errorCo
2660: 64 65 50 74 72 29 29 3b 0a 0a 09 62 79 74 65 73  dePtr));...bytes
2670: 52 65 61 64 20 3d 20 2d 31 3b 0a 09 69 66 20 28  Read = -1;..if (
2680: 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 20 3d 3d  *errorCodePtr ==
2690: 20 45 43 4f 4e 4e 52 45 53 45 54 29 20 7b 0a 09   ECONNRESET) {..
26a0: 20 20 20 20 64 70 72 69 6e 74 66 28 22 47 6f 74      dprintf("Got
26b0: 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 72 65 73 65   connection rese
26c0: 74 22 29 3b 0a 09 20 20 20 20 2f 2a 20 53 6f 66  t");..    /* Sof
26d0: 74 20 45 4f 46 20 2a 2f 0a 09 20 20 20 20 2a 65  t EOF */..    *e
26e0: 72 72 6f 72 43 6f 64 65 50 74 72 20 3d 20 30 3b  rrorCodePtr = 0;
26f0: 0a 09 20 20 20 20 62 79 74 65 73 52 65 61 64 20  ..    bytesRead 
2700: 3d 20 30 3b 0a 09 7d 0a 09 72 65 74 75 72 6e 28  = 0;..}..return(
2710: 62 79 74 65 73 52 65 61 64 29 3b 0a 20 20 20 20  bytesRead);.    
2720: 7d 0a 0a 20 20 20 20 2f 2a 0a 20 20 20 20 20 2a  }..    /*.     *
2730: 20 57 65 20 6e 65 65 64 20 74 6f 20 63 6c 65 61   We need to clea
2740: 72 20 74 68 65 20 53 53 4c 20 65 72 72 6f 72 20  r the SSL error 
2750: 73 74 61 63 6b 20 6e 6f 77 20 62 65 63 61 75 73  stack now becaus
2760: 65 20 77 65 20 73 6f 6d 65 74 69 6d 65 73 20 72  e we sometimes r
2770: 65 61 63 68 0a 20 20 20 20 20 2a 20 74 68 69 73  each.     * this
2780: 20 66 75 6e 63 74 69 6f 6e 20 77 69 74 68 20 6c   function with l
2790: 65 66 74 6f 76 65 72 20 65 72 72 6f 72 73 20 69  eftover errors i
27a0: 6e 20 74 68 65 20 73 74 61 63 6b 2e 20 20 49 66  n the stack.  If
27b0: 20 42 49 4f 5f 72 65 61 64 0a 20 20 20 20 20 2a   BIO_read.     *
27c0: 20 72 65 74 75 72 6e 73 20 2d 31 20 61 6e 64 20   returns -1 and 
27d0: 69 6e 74 65 6e 64 73 20 45 41 47 41 49 4e 2c 20  intends EAGAIN, 
27e0: 74 68 65 72 65 20 69 73 20 61 20 6c 65 66 74 6f  there is a lefto
27f0: 76 65 72 20 65 72 72 6f 72 2c 20 69 74 20 77 69  ver error, it wi
2800: 6c 6c 20 62 65 0a 20 20 20 20 20 2a 20 6d 69 73  ll be.     * mis
2810: 63 6f 6e 73 74 72 75 65 64 20 61 73 20 61 6e 20  construed as an 
2820: 65 72 72 6f 72 2c 20 6e 6f 74 20 45 41 47 41 49  error, not EAGAI
2830: 4e 2e 0a 20 20 20 20 20 2a 0a 20 20 20 20 20 2a  N..     *.     *
2840: 20 41 6c 74 65 72 6e 61 74 69 76 65 6c 79 2c 20   Alternatively, 
2850: 77 65 20 6d 61 79 20 77 61 6e 74 20 74 6f 20 68  we may want to h
2860: 61 6e 64 6c 65 20 74 68 65 20 3c 30 20 72 65 74  andle the <0 ret
2870: 75 72 6e 20 63 6f 64 65 73 20 66 72 6f 6d 0a 20  urn codes from. 
2880: 20 20 20 20 2a 20 42 49 4f 5f 72 65 61 64 20 73      * BIO_read s
2890: 70 65 63 69 61 6c 6c 79 20 28 61 73 20 61 64 76  pecially (as adv
28a0: 69 73 65 64 20 69 6e 20 74 68 65 20 52 53 41 20  ised in the RSA 
28b0: 64 6f 63 73 29 2e 20 20 54 4c 53 27 73 20 6c 6f  docs).  TLS's lo
28c0: 77 65 72 20 6c 65 76 65 6c 20 42 49 4f 0a 20 20  wer level BIO.  
28d0: 20 20 20 2a 20 66 75 6e 63 74 69 6f 6e 73 20 70     * functions p
28e0: 6c 61 79 20 77 69 74 68 20 74 68 65 20 72 65 74  lay with the ret
28f0: 72 79 20 66 6c 61 67 73 20 74 68 6f 75 67 68 2c  ry flags though,
2900: 20 61 6e 64 20 74 68 69 73 20 73 65 65 6d 73 20   and this seems 
2910: 74 6f 20 77 6f 72 6b 0a 20 20 20 20 20 2a 20 63  to work.     * c
2920: 6f 72 72 65 63 74 6c 79 2e 20 20 53 69 6d 69 6c  orrectly.  Simil
2930: 61 72 20 66 69 78 20 69 6e 20 54 6c 73 4f 75 74  ar fix in TlsOut
2940: 70 75 74 50 72 6f 63 2e 20 2d 20 68 6f 62 62 73  putProc. - hobbs
2950: 0a 20 20 20 20 20 2a 2f 0a 20 20 20 20 45 52 52  .     */.    ERR
2960: 5f 63 6c 65 61 72 5f 65 72 72 6f 72 28 29 3b 0a  _clear_error();.
2970: 20 20 20 20 62 79 74 65 73 52 65 61 64 20 3d 20      bytesRead = 
2980: 42 49 4f 5f 72 65 61 64 28 73 74 61 74 65 50 74  BIO_read(statePt
2990: 72 2d 3e 62 69 6f 2c 20 62 75 66 2c 20 62 75 66  r->bio, buf, buf
29a0: 53 69 7a 65 29 3b 0a 20 20 20 20 64 70 72 69 6e  Size);.    dprin
29b0: 74 66 28 22 42 49 4f 5f 72 65 61 64 20 2d 3e 20  tf("BIO_read -> 
29c0: 25 64 22 2c 20 62 79 74 65 73 52 65 61 64 29 3b  %d", bytesRead);
29d0: 0a 0a 20 20 20 20 65 72 72 20 3d 20 53 53 4c 5f  ..    err = SSL_
29e0: 67 65 74 5f 65 72 72 6f 72 28 73 74 61 74 65 50  get_error(stateP
29f0: 74 72 2d 3e 73 73 6c 2c 20 62 79 74 65 73 52 65  tr->ssl, bytesRe
2a00: 61 64 29 3b 0a 20 20 20 20 62 61 63 6b 69 6e 67  ad);.    backing
2a10: 45 72 72 6f 72 20 3d 20 45 52 52 5f 67 65 74 5f  Error = ERR_get_
2a20: 65 72 72 6f 72 28 29 3b 0a 0a 23 69 66 20 30 0a  error();..#if 0.
2a30: 20 20 20 20 69 66 20 28 62 79 74 65 73 52 65 61      if (bytesRea
2a40: 64 20 3c 3d 20 30 29 20 7b 0a 09 69 66 20 28 42  d <= 0) {..if (B
2a50: 49 4f 5f 73 68 6f 75 6c 64 5f 72 65 74 72 79 28  IO_should_retry(
2a60: 73 74 61 74 65 50 74 72 2d 3e 62 69 6f 29 29 20  statePtr->bio)) 
2a70: 7b 0a 09 20 20 20 20 64 70 72 69 6e 74 66 28 22  {..    dprintf("
2a80: 49 2f 4f 20 66 61 69 6c 65 64 2c 20 77 69 6c 6c  I/O failed, will
2a90: 20 72 65 74 72 79 20 62 61 73 65 64 20 6f 6e 20   retry based on 
2aa0: 45 41 47 41 49 4e 22 29 3b 0a 09 20 20 20 20 2a  EAGAIN");..    *
2ab0: 65 72 72 6f 72 43 6f 64 65 50 74 72 20 3d 20 45  errorCodePtr = E
2ac0: 41 47 41 49 4e 3b 0a 09 7d 0a 20 20 20 20 7d 0a  AGAIN;..}.    }.
2ad0: 23 65 6e 64 69 66 0a 0a 20 20 20 20 73 77 69 74  #endif..    swit
2ae0: 63 68 20 28 65 72 72 29 20 7b 0a 09 63 61 73 65  ch (err) {..case
2af0: 20 53 53 4c 5f 45 52 52 4f 52 5f 4e 4f 4e 45 3a   SSL_ERROR_NONE:
2b00: 0a 09 20 20 20 20 64 70 72 69 6e 74 42 75 66 66  ..    dprintBuff
2b10: 65 72 28 62 75 66 2c 20 62 79 74 65 73 52 65 61  er(buf, bytesRea
2b20: 64 29 3b 0a 09 20 20 20 20 62 72 65 61 6b 3b 0a  d);..    break;.
2b30: 0a 09 63 61 73 65 20 53 53 4c 5f 45 52 52 4f 52  ..case SSL_ERROR
2b40: 5f 53 53 4c 3a 0a 09 20 20 20 20 2f 2a 20 41 20  _SSL:..    /* A 
2b50: 6e 6f 6e 2d 72 65 63 6f 76 65 72 61 62 6c 65 2c  non-recoverable,
2b60: 20 66 61 74 61 6c 20 65 72 72 6f 72 20 69 6e 20   fatal error in 
2b70: 74 68 65 20 53 53 4c 20 6c 69 62 72 61 72 79 20  the SSL library 
2b80: 6f 63 63 75 72 72 65 64 2c 20 75 73 75 61 6c 6c  occurred, usuall
2b90: 79 20 61 20 70 72 6f 74 6f 63 6f 6c 20 65 72 72  y a protocol err
2ba0: 6f 72 20 2a 2f 0a 09 20 20 20 20 64 70 72 69 6e  or */..    dprin
2bb0: 74 66 28 22 53 53 4c 20 65 72 72 6f 72 2c 20 69  tf("SSL error, i
2bc0: 6e 64 69 63 61 74 69 6e 67 20 74 68 61 74 20 74  ndicating that t
2bd0: 68 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 68 61  he connection ha
2be0: 73 20 62 65 65 6e 20 61 62 6f 72 74 65 64 22 29  s been aborted")
2bf0: 3b 0a 09 20 20 20 20 69 66 20 28 62 61 63 6b 69  ;..    if (backi
2c00: 6e 67 45 72 72 6f 72 20 21 3d 20 30 29 20 7b 0a  ngError != 0) {.
2c10: 09 09 54 6c 73 5f 45 72 72 6f 72 28 73 74 61 74  ..Tls_Error(stat
2c20: 65 50 74 72 2c 20 28 63 68 61 72 20 2a 29 20 45  ePtr, (char *) E
2c30: 52 52 5f 72 65 61 73 6f 6e 5f 65 72 72 6f 72 5f  RR_reason_error_
2c40: 73 74 72 69 6e 67 28 62 61 63 6b 69 6e 67 45 72  string(backingEr
2c50: 72 6f 72 29 29 3b 0a 09 20 20 20 20 7d 20 65 6c  ror));..    } el
2c60: 73 65 20 7b 0a 09 09 54 6c 73 5f 45 72 72 6f 72  se {...Tls_Error
2c70: 28 73 74 61 74 65 50 74 72 2c 20 22 55 6e 6b 6e  (statePtr, "Unkn
2c80: 6f 77 6e 20 53 53 4c 20 65 72 72 6f 72 22 29 3b  own SSL error");
2c90: 0a 09 20 20 20 20 7d 0a 09 20 20 20 20 2a 65 72  ..    }..    *er
2ca0: 72 6f 72 43 6f 64 65 50 74 72 20 3d 20 45 43 4f  rorCodePtr = ECO
2cb0: 4e 4e 41 42 4f 52 54 45 44 3b 0a 09 20 20 20 20  NNABORTED;..    
2cc0: 62 79 74 65 73 52 65 61 64 20 3d 20 2d 31 3b 0a  bytesRead = -1;.
2cd0: 0a 23 69 66 20 4f 50 45 4e 53 53 4c 5f 56 45 52  .#if OPENSSL_VER
2ce0: 53 49 4f 4e 5f 4e 55 4d 42 45 52 20 3e 3d 20 30  SION_NUMBER >= 0
2cf0: 78 33 30 30 30 30 30 30 30 4c 0a 09 20 20 20 20  x30000000L..    
2d00: 2f 2a 20 55 6e 65 78 70 65 63 74 65 64 20 45 4f  /* Unexpected EO
2d10: 46 20 66 72 6f 6d 20 74 68 65 20 70 65 65 72 20  F from the peer 
2d20: 66 6f 72 20 4f 70 65 6e 53 53 4c 20 33 2e 30 2b  for OpenSSL 3.0+
2d30: 20 2a 2f 0a 09 20 20 20 20 69 66 20 28 45 52 52   */..    if (ERR
2d40: 5f 47 45 54 5f 52 45 41 53 4f 4e 28 62 61 63 6b  _GET_REASON(back
2d50: 69 6e 67 45 72 72 6f 72 29 20 3d 3d 20 53 53 4c  ingError) == SSL
2d60: 5f 52 5f 55 4e 45 58 50 45 43 54 45 44 5f 45 4f  _R_UNEXPECTED_EO
2d70: 46 5f 57 48 49 4c 45 5f 52 45 41 44 49 4e 47 29  F_WHILE_READING)
2d80: 20 7b 0a 09 09 64 70 72 69 6e 74 66 28 22 28 55   {...dprintf("(U
2d90: 6e 65 78 70 65 63 74 65 64 29 20 45 4f 46 20 72  nexpected) EOF r
2da0: 65 61 63 68 65 64 22 29 0a 09 09 2a 65 72 72 6f  eached")...*erro
2db0: 72 43 6f 64 65 50 74 72 20 3d 20 30 3b 0a 09 09  rCodePtr = 0;...
2dc0: 62 79 74 65 73 52 65 61 64 20 3d 20 30 3b 0a 09  bytesRead = 0;..
2dd0: 09 54 6c 73 5f 45 72 72 6f 72 28 73 74 61 74 65  .Tls_Error(state
2de0: 50 74 72 2c 20 22 45 4f 46 20 72 65 61 63 68 65  Ptr, "EOF reache
2df0: 64 22 29 3b 0a 09 20 20 20 20 7d 20 20 20 20 0a  d");..    }    .
2e00: 23 65 6e 64 69 66 0a 09 20 20 20 20 62 72 65 61  #endif..    brea
2e10: 6b 3b 0a 0a 09 63 61 73 65 20 53 53 4c 5f 45 52  k;...case SSL_ER
2e20: 52 4f 52 5f 53 59 53 43 41 4c 4c 3a 0a 09 20 20  ROR_SYSCALL:..  
2e30: 20 20 2f 2a 20 53 6f 6d 65 20 6e 6f 6e 2d 72 65    /* Some non-re
2e40: 63 6f 76 65 72 61 62 6c 65 2c 20 66 61 74 61 6c  coverable, fatal
2e50: 20 49 2f 4f 20 65 72 72 6f 72 20 6f 63 63 75 72   I/O error occur
2e60: 72 65 64 20 2a 2f 0a 0a 09 20 20 20 20 69 66 20  red */...    if 
2e70: 28 62 61 63 6b 69 6e 67 45 72 72 6f 72 20 3d 3d  (backingError ==
2e80: 20 30 20 26 26 20 62 79 74 65 73 52 65 61 64 20   0 && bytesRead 
2e90: 3d 3d 20 30 29 20 7b 0a 09 09 2f 2a 20 55 6e 65  == 0) {.../* Une
2ea0: 78 70 65 63 74 65 64 20 45 4f 46 20 66 72 6f 6d  xpected EOF from
2eb0: 20 74 68 65 20 70 65 65 72 20 66 6f 72 20 4f 70   the peer for Op
2ec0: 65 6e 53 53 4c 20 31 2e 31 20 2a 2f 0a 09 09 64  enSSL 1.1 */...d
2ed0: 70 72 69 6e 74 66 28 22 28 55 6e 65 78 70 65 63  printf("(Unexpec
2ee0: 74 65 64 29 20 45 4f 46 20 72 65 61 63 68 65 64  ted) EOF reached
2ef0: 22 29 0a 09 09 2a 65 72 72 6f 72 43 6f 64 65 50  ")...*errorCodeP
2f00: 74 72 20 3d 20 30 3b 0a 09 09 62 79 74 65 73 52  tr = 0;...bytesR
2f10: 65 61 64 20 3d 20 30 3b 0a 09 09 54 6c 73 5f 45  ead = 0;...Tls_E
2f20: 72 72 6f 72 28 73 74 61 74 65 50 74 72 2c 20 22  rror(statePtr, "
2f30: 45 4f 46 20 72 65 61 63 68 65 64 22 29 3b 0a 0a  EOF reached");..
2f40: 09 20 20 20 20 7d 20 65 6c 73 65 20 69 66 20 28  .    } else if (
2f50: 62 61 63 6b 69 6e 67 45 72 72 6f 72 20 3d 3d 20  backingError == 
2f60: 30 20 26 26 20 62 79 74 65 73 52 65 61 64 20 3d  0 && bytesRead =
2f70: 3d 20 2d 31 29 20 7b 0a 09 09 64 70 72 69 6e 74  = -1) {...dprint
2f80: 66 28 22 49 2f 4f 20 65 72 72 6f 72 20 6f 63 63  f("I/O error occ
2f90: 75 72 72 65 64 20 28 65 72 72 6e 6f 20 3d 20 25  urred (errno = %
2fa0: 6c 75 29 22 2c 20 28 75 6e 73 69 67 6e 65 64 20  lu)", (unsigned 
2fb0: 6c 6f 6e 67 29 20 54 63 6c 5f 47 65 74 45 72 72  long) Tcl_GetErr
2fc0: 6e 6f 28 29 29 3b 0a 09 09 2a 65 72 72 6f 72 43  no());...*errorC
2fd0: 6f 64 65 50 74 72 20 3d 20 54 63 6c 5f 47 65 74  odePtr = Tcl_Get
2fe0: 45 72 72 6e 6f 28 29 3b 0a 09 09 62 79 74 65 73  Errno();...bytes
2ff0: 52 65 61 64 20 3d 20 2d 31 3b 0a 09 09 54 6c 73  Read = -1;...Tls
3000: 5f 45 72 72 6f 72 28 73 74 61 74 65 50 74 72 2c  _Error(statePtr,
3010: 20 28 63 68 61 72 20 2a 29 20 54 63 6c 5f 45 72   (char *) Tcl_Er
3020: 72 6e 6f 4d 73 67 28 2a 65 72 72 6f 72 43 6f 64  rnoMsg(*errorCod
3030: 65 50 74 72 29 29 3b 0a 0a 09 20 20 20 20 7d 20  ePtr));...    } 
3040: 65 6c 73 65 20 7b 0a 09 09 64 70 72 69 6e 74 66  else {...dprintf
3050: 28 22 49 2f 4f 20 65 72 72 6f 72 20 6f 63 63 75  ("I/O error occu
3060: 72 72 65 64 20 28 62 61 63 6b 69 6e 67 45 72 72  rred (backingErr
3070: 6f 72 20 3d 20 25 6c 75 29 22 2c 20 62 61 63 6b  or = %lu)", back
3080: 69 6e 67 45 72 72 6f 72 29 3b 0a 09 09 2a 65 72  ingError);...*er
3090: 72 6f 72 43 6f 64 65 50 74 72 20 3d 20 54 63 6c  rorCodePtr = Tcl
30a0: 5f 47 65 74 45 72 72 6e 6f 28 29 3b 0a 09 09 62  _GetErrno();...b
30b0: 79 74 65 73 52 65 61 64 20 3d 20 2d 31 3b 0a 09  ytesRead = -1;..
30c0: 09 54 6c 73 5f 45 72 72 6f 72 28 73 74 61 74 65  .Tls_Error(state
30d0: 50 74 72 2c 20 28 63 68 61 72 20 2a 29 20 45 52  Ptr, (char *) ER
30e0: 52 5f 72 65 61 73 6f 6e 5f 65 72 72 6f 72 5f 73  R_reason_error_s
30f0: 74 72 69 6e 67 28 62 61 63 6b 69 6e 67 45 72 72  tring(backingErr
3100: 6f 72 29 29 3b 0a 09 20 20 20 20 7d 0a 09 20 20  or));..    }..  
3110: 20 20 62 72 65 61 6b 3b 0a 0a 09 63 61 73 65 20    break;...case 
3120: 53 53 4c 5f 45 52 52 4f 52 5f 5a 45 52 4f 5f 52  SSL_ERROR_ZERO_R
3130: 45 54 55 52 4e 3a 0a 09 20 20 20 20 64 70 72 69  ETURN:..    dpri
3140: 6e 74 66 28 22 47 6f 74 20 53 53 4c 5f 45 52 52  ntf("Got SSL_ERR
3150: 4f 52 5f 5a 45 52 4f 5f 52 45 54 55 52 4e 2c 20  OR_ZERO_RETURN, 
3160: 74 68 69 73 20 6d 65 61 6e 73 20 61 6e 20 45 4f  this means an EO
3170: 46 20 68 61 73 20 62 65 65 6e 20 72 65 61 63 68  F has been reach
3180: 65 64 22 29 3b 0a 09 20 20 20 20 62 79 74 65 73  ed");..    bytes
3190: 52 65 61 64 20 3d 20 30 3b 0a 09 20 20 20 20 2a  Read = 0;..    *
31a0: 65 72 72 6f 72 43 6f 64 65 50 74 72 20 3d 20 30  errorCodePtr = 0
31b0: 3b 0a 09 20 20 20 20 54 6c 73 5f 45 72 72 6f 72  ;..    Tls_Error
31c0: 28 73 74 61 74 65 50 74 72 2c 20 22 50 65 65 72  (statePtr, "Peer
31d0: 20 68 61 73 20 63 6c 6f 73 65 64 20 74 68 65 20   has closed the 
31e0: 63 6f 6e 6e 65 63 74 69 6f 6e 20 66 6f 72 20 77  connection for w
31f0: 72 69 74 69 6e 67 20 62 79 20 73 65 6e 64 69 6e  riting by sendin
3200: 67 20 74 68 65 20 63 6c 6f 73 65 5f 6e 6f 74 69  g the close_noti
3210: 66 79 20 61 6c 65 72 74 22 29 3b 0a 09 20 20 20  fy alert");..   
3220: 20 62 72 65 61 6b 3b 0a 0a 09 63 61 73 65 20 53   break;...case S
3230: 53 4c 5f 45 52 52 4f 52 5f 57 41 4e 54 5f 52 45  SL_ERROR_WANT_RE
3240: 41 44 3a 0a 09 20 20 20 20 64 70 72 69 6e 74 66  AD:..    dprintf
3250: 28 22 47 6f 74 20 53 53 4c 5f 45 52 52 4f 52 5f  ("Got SSL_ERROR_
3260: 57 41 4e 54 5f 52 45 41 44 2c 20 6d 61 70 70 69  WANT_READ, mappi
3270: 6e 67 20 74 68 69 73 20 74 6f 20 45 41 47 41 49  ng this to EAGAI
3280: 4e 22 29 3b 0a 09 20 20 20 20 62 79 74 65 73 52  N");..    bytesR
3290: 65 61 64 20 3d 20 2d 31 3b 0a 09 20 20 20 20 2a  ead = -1;..    *
32a0: 65 72 72 6f 72 43 6f 64 65 50 74 72 20 3d 20 45  errorCodePtr = E
32b0: 41 47 41 49 4e 3b 0a 09 20 20 20 20 54 6c 73 5f  AGAIN;..    Tls_
32c0: 45 72 72 6f 72 28 73 74 61 74 65 50 74 72 2c 20  Error(statePtr, 
32d0: 22 53 53 4c 5f 45 52 52 4f 52 5f 57 41 4e 54 5f  "SSL_ERROR_WANT_
32e0: 52 45 41 44 22 29 3b 0a 09 20 20 20 20 62 72 65  READ");..    bre
32f0: 61 6b 3b 0a 0a 09 64 65 66 61 75 6c 74 3a 0a 09  ak;...default:..
3300: 20 20 20 20 64 70 72 69 6e 74 66 28 22 55 6e 6b      dprintf("Unk
3310: 6e 6f 77 6e 20 65 72 72 6f 72 20 28 65 72 72 20  nown error (err 
3320: 3d 20 25 69 29 2c 20 6d 61 70 70 69 6e 67 20 74  = %i), mapping t
3330: 6f 20 45 4f 46 22 2c 20 65 72 72 29 3b 0a 09 20  o EOF", err);.. 
3340: 20 20 20 2a 65 72 72 6f 72 43 6f 64 65 50 74 72     *errorCodePtr
3350: 20 3d 20 30 3b 0a 09 20 20 20 20 62 79 74 65 73   = 0;..    bytes
3360: 52 65 61 64 20 3d 20 30 3b 0a 09 20 20 20 20 54  Read = 0;..    T
3370: 6c 73 5f 45 72 72 6f 72 28 73 74 61 74 65 50 74  ls_Error(statePt
3380: 72 2c 20 22 55 6e 6b 6e 6f 77 6e 20 65 72 72 6f  r, "Unknown erro
3390: 72 22 29 3b 0a 09 20 20 20 20 62 72 65 61 6b 3b  r");..    break;
33a0: 0a 20 20 20 20 7d 0a 0a 20 20 20 20 64 70 72 69  .    }..    dpri
33b0: 6e 74 66 28 22 49 6e 70 75 74 28 25 64 29 20 2d  ntf("Input(%d) -
33c0: 3e 20 25 64 20 5b 25 64 5d 22 2c 20 62 75 66 53  > %d [%d]", bufS
33d0: 69 7a 65 2c 20 62 79 74 65 73 52 65 61 64 2c 20  ize, bytesRead, 
33e0: 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 29 3b 0a  *errorCodePtr);.
33f0: 20 20 20 20 72 65 74 75 72 6e 28 62 79 74 65 73      return(bytes
3400: 52 65 61 64 29 3b 0a 7d 0a 0a 2f 2a 0a 20 2a 2d  Read);.}../*. *-
3410: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3420: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3430: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3440: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3450: 2d 2d 0a 20 2a 0a 20 2a 20 54 6c 73 4f 75 74 70  --. *. * TlsOutp
3460: 75 74 50 72 6f 63 20 2d 2d 0a 20 2a 0a 20 2a 20  utProc --. *. * 
3470: 20 20 20 54 68 69 73 20 70 72 6f 63 65 64 75 72     This procedur
3480: 65 20 69 73 20 69 6e 76 6f 6b 65 64 20 62 79 20  e is invoked by 
3490: 74 68 65 20 67 65 6e 65 72 69 63 20 49 4f 20 6c  the generic IO l
34a0: 65 76 65 6c 0a 20 2a 20 20 20 20 20 20 20 74 6f  evel. *       to
34b0: 20 77 72 69 74 65 20 6f 75 74 70 75 74 20 74 6f   write output to
34c0: 20 61 20 53 53 4c 20 73 6f 63 6b 65 74 20 62 61   a SSL socket ba
34d0: 73 65 64 20 63 68 61 6e 6e 65 6c 2e 0a 20 2a 0a  sed channel.. *.
34e0: 20 2a 20 52 65 73 75 6c 74 73 3a 0a 20 2a 20 20   * Results:. *  
34f0: 20 20 52 65 74 75 72 6e 73 20 74 68 65 20 6e 75    Returns the nu
3500: 6d 62 65 72 20 6f 66 20 62 79 74 65 73 20 77 72  mber of bytes wr
3510: 69 74 74 65 6e 20 6f 72 20 2d 31 20 6f 6e 20 65  itten or -1 on e
3520: 72 72 6f 72 2e 20 53 65 74 73 20 65 72 72 6f 72  rror. Sets error
3530: 43 6f 64 65 50 74 72 0a 20 2a 20 20 20 20 74 6f  CodePtr. *    to
3540: 20 61 20 50 4f 53 49 58 20 65 72 72 6f 72 20 63   a POSIX error c
3550: 6f 64 65 20 69 66 20 61 6e 20 65 72 72 6f 72 20  ode if an error 
3560: 6f 63 63 75 72 72 65 64 2c 20 6f 72 20 30 20 69  occurred, or 0 i
3570: 66 20 6e 6f 6e 65 2e 0a 20 2a 0a 20 2a 20 53 69  f none.. *. * Si
3580: 64 65 20 65 66 66 65 63 74 73 3a 0a 20 2a 20 20  de effects:. *  
3590: 20 20 57 72 69 74 65 73 20 6f 75 74 70 75 74 20    Writes output 
35a0: 6f 6e 20 74 68 65 20 6f 75 74 70 75 74 20 64 65  on the output de
35b0: 76 69 63 65 20 6f 66 20 74 68 65 20 63 68 61 6e  vice of the chan
35c0: 6e 65 6c 2e 0a 20 2a 0a 20 2a 2d 2d 2d 2d 2d 2d  nel.. *. *------
35d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
35e0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
35f0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3600: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a  -------------. *
3610: 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 54 6c 73  /.static int Tls
3620: 4f 75 74 70 75 74 50 72 6f 63 28 43 6c 69 65 6e  OutputProc(Clien
3630: 74 44 61 74 61 20 69 6e 73 74 61 6e 63 65 44 61  tData instanceDa
3640: 74 61 2c 20 63 6f 6e 73 74 20 63 68 61 72 20 2a  ta, const char *
3650: 62 75 66 2c 20 69 6e 74 20 74 6f 57 72 69 74 65  buf, int toWrite
3660: 2c 20 69 6e 74 20 2a 65 72 72 6f 72 43 6f 64 65  , int *errorCode
3670: 50 74 72 29 20 7b 0a 20 20 20 20 75 6e 73 69 67  Ptr) {.    unsig
3680: 6e 65 64 20 6c 6f 6e 67 20 62 61 63 6b 69 6e 67  ned long backing
3690: 45 72 72 6f 72 3b 0a 20 20 20 20 53 74 61 74 65  Error;.    State
36a0: 20 2a 73 74 61 74 65 50 74 72 20 3d 20 28 53 74   *statePtr = (St
36b0: 61 74 65 20 2a 29 20 69 6e 73 74 61 6e 63 65 44  ate *) instanceD
36c0: 61 74 61 3b 0a 20 20 20 20 69 6e 74 20 77 72 69  ata;.    int wri
36d0: 74 74 65 6e 2c 20 65 72 72 3b 0a 20 20 20 20 69  tten, err;.    i
36e0: 6e 74 20 74 6c 73 43 6f 6e 6e 65 63 74 3b 0a 0a  nt tlsConnect;..
36f0: 20 20 20 20 2a 65 72 72 6f 72 43 6f 64 65 50 74      *errorCodePt
3700: 72 20 3d 20 30 3b 0a 0a 20 20 20 20 64 70 72 69  r = 0;..    dpri
3710: 6e 74 66 28 22 42 49 4f 5f 77 72 69 74 65 28 25  ntf("BIO_write(%
3720: 70 2c 20 25 64 29 22 2c 20 28 76 6f 69 64 20 2a  p, %d)", (void *
3730: 29 20 73 74 61 74 65 50 74 72 2c 20 74 6f 57 72  ) statePtr, toWr
3740: 69 74 65 29 3b 0a 20 20 20 20 64 70 72 69 6e 74  ite);.    dprint
3750: 42 75 66 66 65 72 28 62 75 66 2c 20 74 6f 57 72  Buffer(buf, toWr
3760: 69 74 65 29 3b 0a 0a 20 20 20 20 69 66 20 28 73  ite);..    if (s
3770: 74 61 74 65 50 74 72 2d 3e 66 6c 61 67 73 20 26  tatePtr->flags &
3780: 20 54 4c 53 5f 54 43 4c 5f 43 41 4c 4c 42 41 43   TLS_TCL_CALLBAC
3790: 4b 29 20 7b 0a 09 64 70 72 69 6e 74 66 28 22 44  K) {..dprintf("D
37a0: 6f 6e 27 74 20 70 72 6f 63 65 73 73 20 6f 75 74  on't process out
37b0: 70 75 74 20 77 68 69 6c 65 20 63 61 6c 6c 62 61  put while callba
37c0: 63 6b 73 20 61 72 65 20 72 75 6e 6e 69 6e 67 22  cks are running"
37d0: 29 3b 0a 09 77 72 69 74 74 65 6e 20 3d 20 2d 31  );..written = -1
37e0: 3b 0a 09 2a 65 72 72 6f 72 43 6f 64 65 50 74 72  ;..*errorCodePtr
37f0: 20 3d 20 45 41 47 41 49 4e 3b 0a 09 72 65 74 75   = EAGAIN;..retu
3800: 72 6e 28 2d 31 29 3b 0a 20 20 20 20 7d 0a 0a 20  rn(-1);.    }.. 
3810: 20 20 20 64 70 72 69 6e 74 66 28 22 43 61 6c 6c     dprintf("Call
3820: 69 6e 67 20 54 6c 73 5f 57 61 69 74 46 6f 72 43  ing Tls_WaitForC
3830: 6f 6e 6e 65 63 74 22 29 3b 0a 20 20 20 20 74 6c  onnect");.    tl
3840: 73 43 6f 6e 6e 65 63 74 20 3d 20 54 6c 73 5f 57  sConnect = Tls_W
3850: 61 69 74 46 6f 72 43 6f 6e 6e 65 63 74 28 73 74  aitForConnect(st
3860: 61 74 65 50 74 72 2c 20 65 72 72 6f 72 43 6f 64  atePtr, errorCod
3870: 65 50 74 72 2c 20 31 29 3b 0a 20 20 20 20 69 66  ePtr, 1);.    if
3880: 20 28 74 6c 73 43 6f 6e 6e 65 63 74 20 3c 20 30   (tlsConnect < 0
3890: 29 20 7b 0a 09 64 70 72 69 6e 74 66 28 22 47 6f  ) {..dprintf("Go
38a0: 74 20 61 6e 20 65 72 72 6f 72 20 77 61 69 74 69  t an error waiti
38b0: 6e 67 20 74 6f 20 63 6f 6e 6e 65 63 74 20 28 74  ng to connect (t
38c0: 6c 73 43 6f 6e 6e 65 63 74 20 3d 20 25 69 2c 20  lsConnect = %i, 
38d0: 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 20 3d 20  *errorCodePtr = 
38e0: 25 69 29 22 2c 20 74 6c 73 43 6f 6e 6e 65 63 74  %i)", tlsConnect
38f0: 2c 20 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 29  , *errorCodePtr)
3900: 3b 0a 09 54 6c 73 5f 45 72 72 6f 72 28 73 74 61  ;..Tls_Error(sta
3910: 74 65 50 74 72 2c 20 73 74 72 65 72 72 6f 72 28  tePtr, strerror(
3920: 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 29 29 3b  *errorCodePtr));
3930: 0a 0a 09 77 72 69 74 74 65 6e 20 3d 20 2d 31 3b  ...written = -1;
3940: 0a 09 69 66 20 28 2a 65 72 72 6f 72 43 6f 64 65  ..if (*errorCode
3950: 50 74 72 20 3d 3d 20 45 43 4f 4e 4e 52 45 53 45  Ptr == ECONNRESE
3960: 54 29 20 7b 0a 09 20 20 20 20 64 70 72 69 6e 74  T) {..    dprint
3970: 66 28 22 47 6f 74 20 63 6f 6e 6e 65 63 74 69 6f  f("Got connectio
3980: 6e 20 72 65 73 65 74 22 29 3b 0a 09 20 20 20 20  n reset");..    
3990: 2f 2a 20 53 6f 66 74 20 45 4f 46 20 2a 2f 0a 09  /* Soft EOF */..
39a0: 20 20 20 20 2a 65 72 72 6f 72 43 6f 64 65 50 74      *errorCodePt
39b0: 72 20 3d 20 30 3b 0a 09 20 20 20 20 77 72 69 74  r = 0;..    writ
39c0: 74 65 6e 20 3d 20 30 3b 0a 09 7d 0a 09 72 65 74  ten = 0;..}..ret
39d0: 75 72 6e 28 77 72 69 74 74 65 6e 29 3b 0a 20 20  urn(written);.  
39e0: 20 20 7d 0a 0a 20 20 20 20 69 66 20 28 74 6f 57    }..    if (toW
39f0: 72 69 74 65 20 3d 3d 20 30 29 20 7b 0a 09 64 70  rite == 0) {..dp
3a00: 72 69 6e 74 66 28 22 7a 65 72 6f 2d 77 72 69 74  rintf("zero-writ
3a10: 65 22 29 3b 0a 09 65 72 72 20 3d 20 42 49 4f 5f  e");..err = BIO_
3a20: 66 6c 75 73 68 28 73 74 61 74 65 50 74 72 2d 3e  flush(statePtr->
3a30: 62 69 6f 29 3b 0a 0a 09 69 66 20 28 65 72 72 20  bio);...if (err 
3a40: 3c 3d 20 30 29 20 7b 0a 09 20 20 20 20 64 70 72  <= 0) {..    dpr
3a50: 69 6e 74 66 28 22 46 6c 75 73 68 69 6e 67 20 66  intf("Flushing f
3a60: 61 69 6c 65 64 22 29 3b 0a 09 20 20 20 20 54 6c  ailed");..    Tl
3a70: 73 5f 45 72 72 6f 72 28 73 74 61 74 65 50 74 72  s_Error(statePtr
3a80: 2c 20 22 46 6c 75 73 68 20 66 61 69 6c 65 64 22  , "Flush failed"
3a90: 29 3b 0a 0a 09 20 20 20 20 2a 65 72 72 6f 72 43  );...    *errorC
3aa0: 6f 64 65 50 74 72 20 3d 20 45 49 4f 3b 0a 09 20  odePtr = EIO;.. 
3ab0: 20 20 20 77 72 69 74 74 65 6e 20 3d 20 30 3b 0a     written = 0;.
3ac0: 09 20 20 20 20 72 65 74 75 72 6e 28 2d 31 29 3b  .    return(-1);
3ad0: 0a 09 7d 0a 0a 09 77 72 69 74 74 65 6e 20 3d 20  ..}...written = 
3ae0: 30 3b 0a 09 2a 65 72 72 6f 72 43 6f 64 65 50 74  0;..*errorCodePt
3af0: 72 20 3d 20 30 3b 0a 09 72 65 74 75 72 6e 28 30  r = 0;..return(0
3b00: 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2a  );.    }..    /*
3b10: 0a 20 20 20 20 20 2a 20 57 65 20 6e 65 65 64 20  .     * We need 
3b20: 74 6f 20 63 6c 65 61 72 20 74 68 65 20 53 53 4c  to clear the SSL
3b30: 20 65 72 72 6f 72 20 73 74 61 63 6b 20 6e 6f 77   error stack now
3b40: 20 62 65 63 61 75 73 65 20 77 65 20 73 6f 6d 65   because we some
3b50: 74 69 6d 65 73 20 72 65 61 63 68 0a 20 20 20 20  times reach.    
3b60: 20 2a 20 74 68 69 73 20 66 75 6e 63 74 69 6f 6e   * this function
3b70: 20 77 69 74 68 20 6c 65 66 74 6f 76 65 72 20 65   with leftover e
3b80: 72 72 6f 72 73 20 69 6e 20 74 68 65 20 73 74 61  rrors in the sta
3b90: 63 6b 2e 20 20 49 66 20 42 49 4f 5f 77 72 69 74  ck.  If BIO_writ
3ba0: 65 0a 20 20 20 20 20 2a 20 72 65 74 75 72 6e 73  e.     * returns
3bb0: 20 2d 31 20 61 6e 64 20 69 6e 74 65 6e 64 73 20   -1 and intends 
3bc0: 45 41 47 41 49 4e 2c 20 74 68 65 72 65 20 69 73  EAGAIN, there is
3bd0: 20 61 20 6c 65 66 74 6f 76 65 72 20 65 72 72 6f   a leftover erro
3be0: 72 2c 20 69 74 20 77 69 6c 6c 20 62 65 0a 20 20  r, it will be.  
3bf0: 20 20 20 2a 20 6d 69 73 63 6f 6e 73 74 72 75 65     * misconstrue
3c00: 64 20 61 73 20 61 6e 20 65 72 72 6f 72 2c 20 6e  d as an error, n
3c10: 6f 74 20 45 41 47 41 49 4e 2e 0a 20 20 20 20 20  ot EAGAIN..     
3c20: 2a 0a 20 20 20 20 20 2a 20 41 6c 74 65 72 6e 61  *.     * Alterna
3c30: 74 69 76 65 6c 79 2c 20 77 65 20 6d 61 79 20 77  tively, we may w
3c40: 61 6e 74 20 74 6f 20 68 61 6e 64 6c 65 20 74 68  ant to handle th
3c50: 65 20 3c 30 20 72 65 74 75 72 6e 20 63 6f 64 65  e <0 return code
3c60: 73 20 66 72 6f 6d 0a 20 20 20 20 20 2a 20 42 49  s from.     * BI
3c70: 4f 5f 77 72 69 74 65 20 73 70 65 63 69 61 6c 6c  O_write speciall
3c80: 79 20 28 61 73 20 61 64 76 69 73 65 64 20 69 6e  y (as advised in
3c90: 20 74 68 65 20 52 53 41 20 64 6f 63 73 29 2e 20   the RSA docs). 
3ca0: 20 54 4c 53 27 73 20 6c 6f 77 65 72 20 6c 65 76   TLS's lower lev
3cb0: 65 6c 0a 20 20 20 20 20 2a 20 42 49 4f 20 66 75  el.     * BIO fu
3cc0: 6e 63 74 69 6f 6e 73 20 70 6c 61 79 20 77 69 74  nctions play wit
3cd0: 68 20 74 68 65 20 72 65 74 72 79 20 66 6c 61 67  h the retry flag
3ce0: 73 20 74 68 6f 75 67 68 2c 20 61 6e 64 20 74 68  s though, and th
3cf0: 69 73 20 73 65 65 6d 73 20 74 6f 0a 20 20 20 20  is seems to.    
3d00: 20 2a 20 77 6f 72 6b 20 63 6f 72 72 65 63 74 6c   * work correctl
3d10: 79 2e 20 20 53 69 6d 69 6c 61 72 20 66 69 78 20  y.  Similar fix 
3d20: 69 6e 20 54 6c 73 49 6e 70 75 74 50 72 6f 63 2e  in TlsInputProc.
3d30: 20 2d 20 68 6f 62 62 73 0a 20 20 20 20 20 2a 2f   - hobbs.     */
3d40: 0a 20 20 20 20 45 52 52 5f 63 6c 65 61 72 5f 65  .    ERR_clear_e
3d50: 72 72 6f 72 28 29 3b 0a 20 20 20 20 77 72 69 74  rror();.    writ
3d60: 74 65 6e 20 3d 20 42 49 4f 5f 77 72 69 74 65 28  ten = BIO_write(
3d70: 73 74 61 74 65 50 74 72 2d 3e 62 69 6f 2c 20 62  statePtr->bio, b
3d80: 75 66 2c 20 74 6f 57 72 69 74 65 29 3b 0a 20 20  uf, toWrite);.  
3d90: 20 20 64 70 72 69 6e 74 66 28 22 42 49 4f 5f 77    dprintf("BIO_w
3da0: 72 69 74 65 28 25 70 2c 20 25 64 29 20 2d 3e 20  rite(%p, %d) -> 
3db0: 5b 25 64 5d 22 2c 20 28 76 6f 69 64 20 2a 29 20  [%d]", (void *) 
3dc0: 73 74 61 74 65 50 74 72 2c 20 74 6f 57 72 69 74  statePtr, toWrit
3dd0: 65 2c 20 77 72 69 74 74 65 6e 29 3b 0a 0a 20 20  e, written);..  
3de0: 20 20 65 72 72 20 3d 20 53 53 4c 5f 67 65 74 5f    err = SSL_get_
3df0: 65 72 72 6f 72 28 73 74 61 74 65 50 74 72 2d 3e  error(statePtr->
3e00: 73 73 6c 2c 20 77 72 69 74 74 65 6e 29 3b 0a 20  ssl, written);. 
3e10: 20 20 20 62 61 63 6b 69 6e 67 45 72 72 6f 72 20     backingError 
3e20: 3d 20 45 52 52 5f 67 65 74 5f 65 72 72 6f 72 28  = ERR_get_error(
3e30: 29 3b 0a 0a 20 20 20 20 73 77 69 74 63 68 20 28  );..    switch (
3e40: 65 72 72 29 20 7b 0a 09 63 61 73 65 20 53 53 4c  err) {..case SSL
3e50: 5f 45 52 52 4f 52 5f 4e 4f 4e 45 3a 0a 09 20 20  _ERROR_NONE:..  
3e60: 20 20 69 66 20 28 77 72 69 74 74 65 6e 20 3c 20    if (written < 
3e70: 30 29 20 7b 0a 09 09 77 72 69 74 74 65 6e 20 3d  0) {...written =
3e80: 20 30 3b 0a 09 20 20 20 20 7d 0a 09 20 20 20 20   0;..    }..    
3e90: 62 72 65 61 6b 3b 0a 0a 09 63 61 73 65 20 53 53  break;...case SS
3ea0: 4c 5f 45 52 52 4f 52 5f 57 41 4e 54 5f 57 52 49  L_ERROR_WANT_WRI
3eb0: 54 45 3a 0a 09 20 20 20 20 64 70 72 69 6e 74 66  TE:..    dprintf
3ec0: 28 22 47 6f 74 20 53 53 4c 5f 45 52 52 4f 52 5f  ("Got SSL_ERROR_
3ed0: 57 41 4e 54 5f 57 52 49 54 45 2c 20 6d 61 70 70  WANT_WRITE, mapp
3ee0: 69 6e 67 20 69 74 20 74 6f 20 45 41 47 41 49 4e  ing it to EAGAIN
3ef0: 22 29 3b 0a 09 20 20 20 20 2a 65 72 72 6f 72 43  ");..    *errorC
3f00: 6f 64 65 50 74 72 20 3d 20 45 41 47 41 49 4e 3b  odePtr = EAGAIN;
3f10: 0a 09 20 20 20 20 77 72 69 74 74 65 6e 20 3d 20  ..    written = 
3f20: 2d 31 3b 0a 09 20 20 20 20 54 6c 73 5f 45 72 72  -1;..    Tls_Err
3f30: 6f 72 28 73 74 61 74 65 50 74 72 2c 20 22 53 53  or(statePtr, "SS
3f40: 4c 5f 45 52 52 4f 52 5f 57 41 4e 54 5f 57 52 49  L_ERROR_WANT_WRI
3f50: 54 45 22 29 3b 0a 09 20 20 20 20 62 72 65 61 6b  TE");..    break
3f60: 3b 0a 0a 09 63 61 73 65 20 53 53 4c 5f 45 52 52  ;...case SSL_ERR
3f70: 4f 52 5f 57 41 4e 54 5f 52 45 41 44 3a 0a 09 20  OR_WANT_READ:.. 
3f80: 20 20 20 64 70 72 69 6e 74 66 28 22 20 77 72 69     dprintf(" wri
3f90: 74 65 20 52 20 42 4c 4f 43 4b 22 29 3b 0a 09 20  te R BLOCK");.. 
3fa0: 20 20 20 54 6c 73 5f 45 72 72 6f 72 28 73 74 61     Tls_Error(sta
3fb0: 74 65 50 74 72 2c 20 22 53 53 4c 5f 45 52 52 4f  tePtr, "SSL_ERRO
3fc0: 52 5f 57 41 4e 54 5f 52 45 41 44 22 29 3b 0a 09  R_WANT_READ");..
3fd0: 20 20 20 20 62 72 65 61 6b 3b 0a 0a 09 63 61 73      break;...cas
3fe0: 65 20 53 53 4c 5f 45 52 52 4f 52 5f 57 41 4e 54  e SSL_ERROR_WANT
3ff0: 5f 58 35 30 39 5f 4c 4f 4f 4b 55 50 3a 0a 09 20  _X509_LOOKUP:.. 
4000: 20 20 20 64 70 72 69 6e 74 66 28 22 20 77 72 69     dprintf(" wri
4010: 74 65 20 58 20 42 4c 4f 43 4b 22 29 3b 0a 09 20  te X BLOCK");.. 
4020: 20 20 20 54 6c 73 5f 45 72 72 6f 72 28 73 74 61     Tls_Error(sta
4030: 74 65 50 74 72 2c 20 22 53 53 4c 5f 45 52 52 4f  tePtr, "SSL_ERRO
4040: 52 5f 57 41 4e 54 5f 58 35 30 39 5f 4c 4f 4f 4b  R_WANT_X509_LOOK
4050: 55 50 22 29 3b 0a 09 20 20 20 20 62 72 65 61 6b  UP");..    break
4060: 3b 0a 0a 09 63 61 73 65 20 53 53 4c 5f 45 52 52  ;...case SSL_ERR
4070: 4f 52 5f 5a 45 52 4f 5f 52 45 54 55 52 4e 3a 0a  OR_ZERO_RETURN:.
4080: 09 20 20 20 20 64 70 72 69 6e 74 66 28 22 20 63  .    dprintf(" c
4090: 6c 6f 73 65 64 22 29 3b 0a 09 20 20 20 20 77 72  losed");..    wr
40a0: 69 74 74 65 6e 20 3d 20 30 3b 0a 09 20 20 20 20  itten = 0;..    
40b0: 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 20 3d 20  *errorCodePtr = 
40c0: 30 3b 0a 09 20 20 20 20 54 6c 73 5f 45 72 72 6f  0;..    Tls_Erro
40d0: 72 28 73 74 61 74 65 50 74 72 2c 20 22 50 65 65  r(statePtr, "Pee
40e0: 72 20 68 61 73 20 63 6c 6f 73 65 64 20 74 68 65  r has closed the
40f0: 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 66 6f 72 20   connection for 
4100: 77 72 69 74 69 6e 67 20 62 79 20 73 65 6e 64 69  writing by sendi
4110: 6e 67 20 74 68 65 20 63 6c 6f 73 65 5f 6e 6f 74  ng the close_not
4120: 69 66 79 20 61 6c 65 72 74 22 29 3b 0a 09 20 20  ify alert");..  
4130: 20 20 62 72 65 61 6b 3b 0a 0a 09 63 61 73 65 20    break;...case 
4140: 53 53 4c 5f 45 52 52 4f 52 5f 53 59 53 43 41 4c  SSL_ERROR_SYSCAL
4150: 4c 3a 0a 09 20 20 20 20 2f 2a 20 53 6f 6d 65 20  L:..    /* Some 
4160: 6e 6f 6e 2d 72 65 63 6f 76 65 72 61 62 6c 65 2c  non-recoverable,
4170: 20 66 61 74 61 6c 20 49 2f 4f 20 65 72 72 6f 72   fatal I/O error
4180: 20 6f 63 63 75 72 72 65 64 20 2a 2f 0a 0a 09 20   occurred */... 
4190: 20 20 20 69 66 20 28 62 61 63 6b 69 6e 67 45 72     if (backingEr
41a0: 72 6f 72 20 3d 3d 20 30 20 26 26 20 77 72 69 74  ror == 0 && writ
41b0: 74 65 6e 20 3d 3d 20 30 29 20 7b 0a 09 09 64 70  ten == 0) {...dp
41c0: 72 69 6e 74 66 28 22 45 4f 46 20 72 65 61 63 68  rintf("EOF reach
41d0: 65 64 22 29 0a 09 09 2a 65 72 72 6f 72 43 6f 64  ed")...*errorCod
41e0: 65 50 74 72 20 3d 20 30 3b 0a 09 09 77 72 69 74  ePtr = 0;...writ
41f0: 74 65 6e 20 3d 20 30 3b 0a 09 09 54 6c 73 5f 45  ten = 0;...Tls_E
4200: 72 72 6f 72 28 73 74 61 74 65 50 74 72 2c 20 22  rror(statePtr, "
4210: 45 4f 46 20 72 65 61 63 68 65 64 22 29 3b 0a 0a  EOF reached");..
4220: 09 20 20 20 20 7d 20 65 6c 73 65 20 69 66 20 28  .    } else if (
4230: 62 61 63 6b 69 6e 67 45 72 72 6f 72 20 3d 3d 20  backingError == 
4240: 30 20 26 26 20 77 72 69 74 74 65 6e 20 3d 3d 20  0 && written == 
4250: 2d 31 29 20 7b 0a 09 09 64 70 72 69 6e 74 66 28  -1) {...dprintf(
4260: 22 49 2f 4f 20 65 72 72 6f 72 20 6f 63 63 75 72  "I/O error occur
4270: 72 65 64 20 28 65 72 72 6e 6f 20 3d 20 25 6c 75  red (errno = %lu
4280: 29 22 2c 20 28 75 6e 73 69 67 6e 65 64 20 6c 6f  )", (unsigned lo
4290: 6e 67 29 20 54 63 6c 5f 47 65 74 45 72 72 6e 6f  ng) Tcl_GetErrno
42a0: 28 29 29 3b 0a 09 09 2a 65 72 72 6f 72 43 6f 64  ());...*errorCod
42b0: 65 50 74 72 20 3d 20 54 63 6c 5f 47 65 74 45 72  ePtr = Tcl_GetEr
42c0: 72 6e 6f 28 29 3b 0a 09 09 77 72 69 74 74 65 6e  rno();...written
42d0: 20 3d 20 2d 31 3b 0a 09 09 54 6c 73 5f 45 72 72   = -1;...Tls_Err
42e0: 6f 72 28 73 74 61 74 65 50 74 72 2c 20 28 63 68  or(statePtr, (ch
42f0: 61 72 20 2a 29 20 54 63 6c 5f 45 72 72 6e 6f 4d  ar *) Tcl_ErrnoM
4300: 73 67 28 2a 65 72 72 6f 72 43 6f 64 65 50 74 72  sg(*errorCodePtr
4310: 29 29 3b 0a 0a 09 20 20 20 20 7d 20 65 6c 73 65  ));...    } else
4320: 20 7b 0a 09 09 64 70 72 69 6e 74 66 28 22 49 2f   {...dprintf("I/
4330: 4f 20 65 72 72 6f 72 20 6f 63 63 75 72 72 65 64  O error occurred
4340: 20 28 62 61 63 6b 69 6e 67 45 72 72 6f 72 20 3d   (backingError =
4350: 20 25 6c 75 29 22 2c 20 62 61 63 6b 69 6e 67 45   %lu)", backingE
4360: 72 72 6f 72 29 3b 0a 09 09 2a 65 72 72 6f 72 43  rror);...*errorC
4370: 6f 64 65 50 74 72 20 3d 20 54 63 6c 5f 47 65 74  odePtr = Tcl_Get
4380: 45 72 72 6e 6f 28 29 3b 0a 09 09 77 72 69 74 74  Errno();...writt
4390: 65 6e 20 3d 20 2d 31 3b 0a 09 09 54 6c 73 5f 45  en = -1;...Tls_E
43a0: 72 72 6f 72 28 73 74 61 74 65 50 74 72 2c 20 28  rror(statePtr, (
43b0: 63 68 61 72 20 2a 29 20 45 52 52 5f 72 65 61 73  char *) ERR_reas
43c0: 6f 6e 5f 65 72 72 6f 72 5f 73 74 72 69 6e 67 28  on_error_string(
43d0: 62 61 63 6b 69 6e 67 45 72 72 6f 72 29 29 3b 0a  backingError));.
43e0: 09 20 20 20 20 7d 0a 09 20 20 20 20 62 72 65 61  .    }..    brea
43f0: 6b 3b 0a 0a 09 63 61 73 65 20 53 53 4c 5f 45 52  k;...case SSL_ER
4400: 52 4f 52 5f 53 53 4c 3a 0a 09 20 20 20 20 2f 2a  ROR_SSL:..    /*
4410: 20 41 20 6e 6f 6e 2d 72 65 63 6f 76 65 72 61 62   A non-recoverab
4420: 6c 65 2c 20 66 61 74 61 6c 20 65 72 72 6f 72 20  le, fatal error 
4430: 69 6e 20 74 68 65 20 53 53 4c 20 6c 69 62 72 61  in the SSL libra
4440: 72 79 20 6f 63 63 75 72 72 65 64 2c 20 75 73 75  ry occurred, usu
4450: 61 6c 6c 79 20 61 20 70 72 6f 74 6f 63 6f 6c 20  ally a protocol 
4460: 65 72 72 6f 72 20 2a 2f 0a 09 20 20 20 20 64 70  error */..    dp
4470: 72 69 6e 74 66 28 22 53 53 4c 20 65 72 72 6f 72  rintf("SSL error
4480: 2c 20 69 6e 64 69 63 61 74 69 6e 67 20 74 68 61  , indicating tha
4490: 74 20 74 68 65 20 63 6f 6e 6e 65 63 74 69 6f 6e  t the connection
44a0: 20 68 61 73 20 62 65 65 6e 20 61 62 6f 72 74 65   has been aborte
44b0: 64 22 29 3b 0a 09 20 20 20 20 69 66 20 28 62 61  d");..    if (ba
44c0: 63 6b 69 6e 67 45 72 72 6f 72 20 21 3d 20 30 29  ckingError != 0)
44d0: 20 7b 0a 09 09 54 6c 73 5f 45 72 72 6f 72 28 73   {...Tls_Error(s
44e0: 74 61 74 65 50 74 72 2c 20 28 63 68 61 72 20 2a  tatePtr, (char *
44f0: 29 20 45 52 52 5f 72 65 61 73 6f 6e 5f 65 72 72  ) ERR_reason_err
4500: 6f 72 5f 73 74 72 69 6e 67 28 62 61 63 6b 69 6e  or_string(backin
4510: 67 45 72 72 6f 72 29 29 3b 0a 09 20 20 20 20 7d  gError));..    }
4520: 20 65 6c 73 65 20 7b 0a 09 09 54 6c 73 5f 45 72   else {...Tls_Er
4530: 72 6f 72 28 73 74 61 74 65 50 74 72 2c 20 22 55  ror(statePtr, "U
4540: 6e 6b 6e 6f 77 6e 20 53 53 4c 20 65 72 72 6f 72  nknown SSL error
4550: 22 29 3b 0a 09 20 20 20 20 7d 0a 09 20 20 20 20  ");..    }..    
4560: 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 20 3d 20  *errorCodePtr = 
4570: 45 43 4f 4e 4e 41 42 4f 52 54 45 44 3b 0a 09 20  ECONNABORTED;.. 
4580: 20 20 20 77 72 69 74 74 65 6e 20 3d 20 2d 31 3b     written = -1;
4590: 0a 09 20 20 20 20 62 72 65 61 6b 3b 0a 0a 09 64  ..    break;...d
45a0: 65 66 61 75 6c 74 3a 0a 09 20 20 20 20 64 70 72  efault:..    dpr
45b0: 69 6e 74 66 28 22 75 6e 6b 6e 6f 77 6e 20 65 72  intf("unknown er
45c0: 72 6f 72 3a 20 25 64 22 2c 20 65 72 72 29 3b 0a  ror: %d", err);.
45d0: 09 20 20 20 20 54 6c 73 5f 45 72 72 6f 72 28 73  .    Tls_Error(s
45e0: 74 61 74 65 50 74 72 2c 20 22 55 6e 6b 6e 6f 77  tatePtr, "Unknow
45f0: 6e 20 65 72 72 6f 72 22 29 3b 0a 09 20 20 20 20  n error");..    
4600: 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a 0a 20 20  break;.    }..  
4610: 20 20 64 70 72 69 6e 74 66 28 22 4f 75 74 70 75    dprintf("Outpu
4620: 74 28 25 64 29 20 2d 3e 20 25 64 22 2c 20 74 6f  t(%d) -> %d", to
4630: 57 72 69 74 65 2c 20 77 72 69 74 74 65 6e 29 3b  Write, written);
4640: 0a 20 20 20 20 72 65 74 75 72 6e 28 77 72 69 74  .    return(writ
4650: 74 65 6e 29 3b 0a 7d 0a 0a 2f 2a 0a 20 2a 2d 2d  ten);.}../*. *--
4660: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4670: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4680: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4690: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
46a0: 2d 0a 20 2a 0a 20 2a 20 54 6c 73 53 65 74 4f 70  -. *. * TlsSetOp
46b0: 74 69 6f 6e 50 72 6f 63 20 2d 2d 0a 20 2a 0a 20  tionProc --. *. 
46c0: 2a 20 20 20 20 53 65 74 73 20 61 6e 20 6f 70 74  *    Sets an opt
46d0: 69 6f 6e 20 76 61 6c 75 65 20 66 6f 72 20 61 20  ion value for a 
46e0: 53 53 4c 20 73 6f 63 6b 65 74 20 62 61 73 65 64  SSL socket based
46f0: 20 63 68 61 6e 6e 65 6c 2c 20 6f 72 20 61 0a 20   channel, or a. 
4700: 2a 20 20 20 20 6c 69 73 74 20 6f 66 20 61 6c 6c  *    list of all
4710: 20 6f 70 74 69 6f 6e 73 20 61 6e 64 20 74 68 65   options and the
4720: 69 72 20 76 61 6c 75 65 73 2e 0a 20 2a 0a 20 2a  ir values.. *. *
4730: 20 52 65 73 75 6c 74 73 3a 0a 20 2a 20 20 20 20   Results:. *    
4740: 54 43 4c 5f 4f 4b 20 69 66 20 73 75 63 63 65 73  TCL_OK if succes
4750: 73 66 75 6c 20 6f 72 20 54 43 4c 5f 45 52 52 4f  sful or TCL_ERRO
4760: 52 20 69 66 20 66 61 69 6c 65 64 2e 0a 20 2a 0a  R if failed.. *.
4770: 20 2a 20 53 69 64 65 20 65 66 66 65 63 74 73 3a   * Side effects:
4780: 0a 20 2a 20 20 20 20 55 70 64 61 74 65 73 20 63  . *    Updates c
4790: 68 61 6e 6e 65 6c 20 6f 70 74 69 6f 6e 20 74 6f  hannel option to
47a0: 20 6e 65 77 20 76 61 6c 75 65 2e 0a 20 2a 0a 20   new value.. *. 
47b0: 2a 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 2d 2d 2d  ----------------
47f0: 2d 2d 2d 2d 0a 20 2a 2f 0a 73 74 61 74 69 63 20  ----. */.static 
4800: 69 6e 74 0a 54 6c 73 53 65 74 4f 70 74 69 6f 6e  int.TlsSetOption
4810: 50 72 6f 63 28 43 6c 69 65 6e 74 44 61 74 61 20  Proc(ClientData 
4820: 69 6e 73 74 61 6e 63 65 44 61 74 61 2c 20 20 20  instanceData,   
4830: 20 2f 2a 20 53 6f 63 6b 65 74 20 73 74 61 74 65   /* Socket state
4840: 2e 20 2a 2f 0a 20 20 20 20 54 63 6c 5f 49 6e 74  . */.    Tcl_Int
4850: 65 72 70 20 2a 69 6e 74 65 72 70 2c 09 09 2f 2a  erp *interp,../*
4860: 20 46 6f 72 20 65 72 72 6f 72 73 20 2d 20 63 61   For errors - ca
4870: 6e 20 62 65 20 4e 55 4c 4c 2e 20 2a 2f 0a 20 20  n be NULL. */.  
4880: 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 6f 70    const char *op
4890: 74 69 6f 6e 4e 61 6d 65 2c 09 2f 2a 20 4e 61 6d  tionName,./* Nam
48a0: 65 20 6f 66 20 74 68 65 20 6f 70 74 69 6f 6e 20  e of the option 
48b0: 74 6f 20 73 65 74 20 74 68 65 20 76 61 6c 75 65  to set the value
48c0: 20 66 6f 72 2c 20 6f 72 0a 09 09 09 09 20 2a 20   for, or..... * 
48d0: 4e 55 4c 4c 20 74 6f 20 67 65 74 20 61 6c 6c 20  NULL to get all 
48e0: 6f 70 74 69 6f 6e 73 20 61 6e 64 20 74 68 65 69  options and thei
48f0: 72 20 76 61 6c 75 65 73 2e 20 2a 2f 0a 20 20 20  r values. */.   
4900: 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 6f 70 74   const char *opt
4910: 69 6f 6e 56 61 6c 75 65 29 09 2f 2a 20 56 61 6c  ionValue)./* Val
4920: 75 65 20 66 6f 72 20 6f 70 74 69 6f 6e 2e 20 2a  ue for option. *
4930: 2f 0a 7b 0a 20 20 20 20 53 74 61 74 65 20 2a 73  /.{.    State *s
4940: 74 61 74 65 50 74 72 20 3d 20 28 53 74 61 74 65  tatePtr = (State
4950: 20 2a 29 20 69 6e 73 74 61 6e 63 65 44 61 74 61   *) instanceData
4960: 3b 0a 0a 20 20 20 20 54 63 6c 5f 43 68 61 6e 6e  ;..    Tcl_Chann
4970: 65 6c 20 64 6f 77 6e 43 68 61 6e 20 3d 20 54 6c  el downChan = Tl
4980: 73 5f 47 65 74 50 61 72 65 6e 74 28 73 74 61 74  s_GetParent(stat
4990: 65 50 74 72 2c 20 54 4c 53 5f 54 43 4c 5f 46 41  ePtr, TLS_TCL_FA
49a0: 53 54 50 41 54 48 29 3b 0a 20 20 20 20 54 63 6c  STPATH);.    Tcl
49b0: 5f 44 72 69 76 65 72 53 65 74 4f 70 74 69 6f 6e  _DriverSetOption
49c0: 50 72 6f 63 20 2a 73 65 74 4f 70 74 69 6f 6e 50  Proc *setOptionP
49d0: 72 6f 63 3b 0a 0a 20 20 20 20 73 65 74 4f 70 74  roc;..    setOpt
49e0: 69 6f 6e 50 72 6f 63 20 3d 20 54 63 6c 5f 43 68  ionProc = Tcl_Ch
49f0: 61 6e 6e 65 6c 53 65 74 4f 70 74 69 6f 6e 50 72  annelSetOptionPr
4a00: 6f 63 28 54 63 6c 5f 47 65 74 43 68 61 6e 6e 65  oc(Tcl_GetChanne
4a10: 6c 54 79 70 65 28 64 6f 77 6e 43 68 61 6e 29 29  lType(downChan))
4a20: 3b 0a 20 20 20 20 69 66 20 28 73 65 74 4f 70 74  ;.    if (setOpt
4a30: 69 6f 6e 50 72 6f 63 20 21 3d 20 4e 55 4c 4c 29  ionProc != NULL)
4a40: 20 7b 0a 09 72 65 74 75 72 6e 20 28 2a 73 65 74   {..return (*set
4a50: 4f 70 74 69 6f 6e 50 72 6f 63 29 28 54 63 6c 5f  OptionProc)(Tcl_
4a60: 47 65 74 43 68 61 6e 6e 65 6c 49 6e 73 74 61 6e  GetChannelInstan
4a70: 63 65 44 61 74 61 28 64 6f 77 6e 43 68 61 6e 29  ceData(downChan)
4a80: 2c 20 69 6e 74 65 72 70 2c 20 6f 70 74 69 6f 6e  , interp, option
4a90: 4e 61 6d 65 2c 20 6f 70 74 69 6f 6e 56 61 6c 75  Name, optionValu
4aa0: 65 29 3b 0a 20 20 20 20 7d 20 65 6c 73 65 20 69  e);.    } else i
4ab0: 66 20 28 6f 70 74 69 6f 6e 4e 61 6d 65 20 3d 3d  f (optionName ==
4ac0: 20 28 63 68 61 72 2a 29 20 4e 55 4c 4c 29 20 7b   (char*) NULL) {
4ad0: 0a 09 2f 2a 0a 09 20 2a 20 52 65 71 75 65 73 74  ../*.. * Request
4ae0: 20 69 73 20 71 75 65 72 79 20 66 6f 72 20 61 6c   is query for al
4af0: 6c 20 6f 70 74 69 6f 6e 73 2c 20 74 68 69 73 20  l options, this 
4b00: 69 73 20 6f 6b 2e 0a 09 20 2a 2f 0a 09 72 65 74  is ok... */..ret
4b10: 75 72 6e 20 54 43 4c 5f 4f 4b 3b 0a 20 20 20 20  urn TCL_OK;.    
4b20: 7d 0a 20 20 20 20 2f 2a 0a 20 20 20 20 20 2a 20  }.    /*.     * 
4b30: 52 65 71 75 65 73 74 20 66 6f 72 20 61 20 73 70  Request for a sp
4b40: 65 63 69 66 69 63 20 6f 70 74 69 6f 6e 20 68 61  ecific option ha
4b50: 73 20 74 6f 20 66 61 69 6c 2c 20 77 65 20 64 6f  s to fail, we do
4b60: 6e 27 74 20 68 61 76 65 20 61 6e 79 2e 0a 20 20  n't have any..  
4b70: 20 20 20 2a 2f 0a 20 20 20 20 72 65 74 75 72 6e     */.    return
4b80: 20 54 63 6c 5f 42 61 64 43 68 61 6e 6e 65 6c 4f   Tcl_BadChannelO
4b90: 70 74 69 6f 6e 28 69 6e 74 65 72 70 2c 20 6f 70  ption(interp, op
4ba0: 74 69 6f 6e 4e 61 6d 65 2c 20 22 22 29 3b 0a 7d  tionName, "");.}
4bb0: 0a 0a 2f 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d  ../*. *---------
4bc0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4bd0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4be0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4bf0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 0a 20 2a  ----------. *. *
4c00: 20 54 6c 73 47 65 74 4f 70 74 69 6f 6e 50 72 6f   TlsGetOptionPro
4c10: 63 20 2d 2d 0a 20 2a 0a 20 2a 20 20 20 20 47 65  c --. *. *    Ge
4c20: 74 73 20 61 6e 20 6f 70 74 69 6f 6e 20 76 61 6c  ts an option val
4c30: 75 65 20 66 6f 72 20 61 20 53 53 4c 20 73 6f 63  ue for a SSL soc
4c40: 6b 65 74 20 62 61 73 65 64 20 63 68 61 6e 6e 65  ket based channe
4c50: 6c 2c 20 6f 72 20 61 0a 20 2a 20 20 20 20 6c 69  l, or a. *    li
4c60: 73 74 20 6f 66 20 61 6c 6c 20 6f 70 74 69 6f 6e  st of all option
4c70: 73 20 61 6e 64 20 74 68 65 69 72 20 76 61 6c 75  s and their valu
4c80: 65 73 2e 0a 20 2a 0a 20 2a 20 52 65 73 75 6c 74  es.. *. * Result
4c90: 73 3a 0a 20 2a 20 20 20 20 41 20 73 74 61 6e 64  s:. *    A stand
4ca0: 61 72 64 20 54 63 6c 20 72 65 73 75 6c 74 2e 20  ard Tcl result. 
4cb0: 54 68 65 20 76 61 6c 75 65 20 6f 66 20 74 68 65  The value of the
4cc0: 20 73 70 65 63 69 66 69 65 64 20 6f 70 74 69 6f   specified optio
4cd0: 6e 20 6f 72 20 61 0a 20 2a 20 20 20 20 6c 69 73  n or a. *    lis
4ce0: 74 20 6f 66 20 61 6c 6c 20 6f 70 74 69 6f 6e 73  t of all options
4cf0: 20 61 6e 64 20 74 68 65 69 72 20 76 61 6c 75 65   and their value
4d00: 73 20 69 73 20 72 65 74 75 72 6e 65 64 20 69 6e  s is returned in
4d10: 20 74 68 65 0a 20 2a 20 20 20 20 73 75 70 70 6c   the. *    suppl
4d20: 69 65 64 20 44 53 74 72 69 6e 67 2e 0a 20 2a 0a  ied DString.. *.
4d30: 20 2a 20 53 69 64 65 20 65 66 66 65 63 74 73 3a   * Side effects:
4d40: 0a 20 2a 20 20 20 20 4e 6f 6e 65 2e 0a 20 2a 0a  . *    None.. *.
4d50: 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d   *--------------
4d60: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4d70: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4d80: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4d90: 2d 2d 2d 2d 2d 0a 20 2a 2f 0a 73 74 61 74 69 63  -----. */.static
4da0: 20 69 6e 74 0a 54 6c 73 47 65 74 4f 70 74 69 6f   int.TlsGetOptio
4db0: 6e 50 72 6f 63 28 43 6c 69 65 6e 74 44 61 74 61  nProc(ClientData
4dc0: 20 69 6e 73 74 61 6e 63 65 44 61 74 61 2c 20 20   instanceData,  
4dd0: 20 20 2f 2a 20 53 6f 63 6b 65 74 20 73 74 61 74    /* Socket stat
4de0: 65 2e 20 2a 2f 0a 20 20 20 20 54 63 6c 5f 49 6e  e. */.    Tcl_In
4df0: 74 65 72 70 20 2a 69 6e 74 65 72 70 2c 09 09 2f  terp *interp,../
4e00: 2a 20 46 6f 72 20 65 72 72 6f 72 73 20 2d 20 63  * For errors - c
4e10: 61 6e 20 62 65 20 4e 55 4c 4c 2e 20 2a 2f 0a 20  an be NULL. */. 
4e20: 20 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 6f     const char *o
4e30: 70 74 69 6f 6e 4e 61 6d 65 2c 09 2f 2a 20 4e 61  ptionName,./* Na
4e40: 6d 65 20 6f 66 20 74 68 65 20 6f 70 74 69 6f 6e  me of the option
4e50: 20 74 6f 20 72 65 74 72 69 65 76 65 20 74 68 65   to retrieve the
4e60: 20 76 61 6c 75 65 20 66 6f 72 2c 20 6f 72 0a 09   value for, or..
4e70: 09 09 09 20 2a 20 4e 55 4c 4c 20 74 6f 20 67 65  ... * NULL to ge
4e80: 74 20 61 6c 6c 20 6f 70 74 69 6f 6e 73 20 61 6e  t all options an
4e90: 64 20 74 68 65 69 72 20 76 61 6c 75 65 73 2e 20  d their values. 
4ea0: 2a 2f 0a 20 20 20 20 54 63 6c 5f 44 53 74 72 69  */.    Tcl_DStri
4eb0: 6e 67 20 2a 6f 70 74 69 6f 6e 56 61 6c 75 65 29  ng *optionValue)
4ec0: 09 2f 2a 20 57 68 65 72 65 20 74 6f 20 73 74 6f  ./* Where to sto
4ed0: 72 65 20 74 68 65 20 63 6f 6d 70 75 74 65 64 20  re the computed 
4ee0: 76 61 6c 75 65 20 69 6e 69 74 69 61 6c 69 7a 65  value initialize
4ef0: 64 20 62 79 20 63 61 6c 6c 65 72 2e 20 2a 2f 0a  d by caller. */.
4f00: 7b 0a 20 20 20 20 53 74 61 74 65 20 2a 73 74 61  {.    State *sta
4f10: 74 65 50 74 72 20 3d 20 28 53 74 61 74 65 20 2a  tePtr = (State *
4f20: 29 20 69 6e 73 74 61 6e 63 65 44 61 74 61 3b 0a  ) instanceData;.
4f30: 0a 20 20 20 20 54 63 6c 5f 43 68 61 6e 6e 65 6c  .    Tcl_Channel
4f40: 20 64 6f 77 6e 43 68 61 6e 20 3d 20 54 6c 73 5f   downChan = Tls_
4f50: 47 65 74 50 61 72 65 6e 74 28 73 74 61 74 65 50  GetParent(stateP
4f60: 74 72 2c 20 54 4c 53 5f 54 43 4c 5f 46 41 53 54  tr, TLS_TCL_FAST
4f70: 50 41 54 48 29 3b 0a 20 20 20 20 54 63 6c 5f 44  PATH);.    Tcl_D
4f80: 72 69 76 65 72 47 65 74 4f 70 74 69 6f 6e 50 72  riverGetOptionPr
4f90: 6f 63 20 2a 67 65 74 4f 70 74 69 6f 6e 50 72 6f  oc *getOptionPro
4fa0: 63 3b 0a 0a 20 20 20 20 67 65 74 4f 70 74 69 6f  c;..    getOptio
4fb0: 6e 50 72 6f 63 20 3d 20 54 63 6c 5f 43 68 61 6e  nProc = Tcl_Chan
4fc0: 6e 65 6c 47 65 74 4f 70 74 69 6f 6e 50 72 6f 63  nelGetOptionProc
4fd0: 28 54 63 6c 5f 47 65 74 43 68 61 6e 6e 65 6c 54  (Tcl_GetChannelT
4fe0: 79 70 65 28 64 6f 77 6e 43 68 61 6e 29 29 3b 0a  ype(downChan));.
4ff0: 20 20 20 20 69 66 20 28 67 65 74 4f 70 74 69 6f      if (getOptio
5000: 6e 50 72 6f 63 20 21 3d 20 4e 55 4c 4c 29 20 7b  nProc != NULL) {
5010: 0a 09 72 65 74 75 72 6e 20 28 2a 67 65 74 4f 70  ..return (*getOp
5020: 74 69 6f 6e 50 72 6f 63 29 28 54 63 6c 5f 47 65  tionProc)(Tcl_Ge
5030: 74 43 68 61 6e 6e 65 6c 49 6e 73 74 61 6e 63 65  tChannelInstance
5040: 44 61 74 61 28 64 6f 77 6e 43 68 61 6e 29 2c 20  Data(downChan), 
5050: 69 6e 74 65 72 70 2c 20 6f 70 74 69 6f 6e 4e 61  interp, optionNa
5060: 6d 65 2c 20 6f 70 74 69 6f 6e 56 61 6c 75 65 29  me, optionValue)
5070: 3b 0a 20 20 20 20 7d 20 65 6c 73 65 20 69 66 20  ;.    } else if 
5080: 28 6f 70 74 69 6f 6e 4e 61 6d 65 20 3d 3d 20 28  (optionName == (
5090: 63 68 61 72 2a 29 20 4e 55 4c 4c 29 20 7b 0a 09  char*) NULL) {..
50a0: 2f 2a 0a 09 20 2a 20 52 65 71 75 65 73 74 20 69  /*.. * Request i
50b0: 73 20 71 75 65 72 79 20 66 6f 72 20 61 6c 6c 20  s query for all 
50c0: 6f 70 74 69 6f 6e 73 2c 20 74 68 69 73 20 69 73  options, this is
50d0: 20 6f 6b 2e 0a 09 20 2a 2f 0a 09 72 65 74 75 72   ok... */..retur
50e0: 6e 20 54 43 4c 5f 4f 4b 3b 0a 20 20 20 20 7d 0a  n TCL_OK;.    }.
50f0: 20 20 20 20 2f 2a 0a 20 20 20 20 20 2a 20 52 65      /*.     * Re
5100: 71 75 65 73 74 20 66 6f 72 20 61 20 73 70 65 63  quest for a spec
5110: 69 66 69 63 20 6f 70 74 69 6f 6e 20 68 61 73 20  ific option has 
5120: 74 6f 20 66 61 69 6c 2c 20 77 65 20 64 6f 6e 27  to fail, we don'
5130: 74 20 68 61 76 65 20 61 6e 79 2e 0a 20 20 20 20  t have any..    
5140: 20 2a 2f 0a 20 20 20 20 72 65 74 75 72 6e 20 54   */.    return T
5150: 63 6c 5f 42 61 64 43 68 61 6e 6e 65 6c 4f 70 74  cl_BadChannelOpt
5160: 69 6f 6e 28 69 6e 74 65 72 70 2c 20 6f 70 74 69  ion(interp, opti
5170: 6f 6e 4e 61 6d 65 2c 20 22 22 29 3b 0a 7d 0a 0a  onName, "");.}..
5180: 2f 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  /*. *-----------
5190: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
51a0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
51b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
51c0: 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 0a 20 2a 20 54  --------. *. * T
51d0: 6c 73 57 61 74 63 68 50 72 6f 63 20 2d 2d 0a 20  lsWatchProc --. 
51e0: 2a 0a 20 2a 20 20 20 20 49 6e 69 74 69 61 6c 69  *. *    Initiali
51f0: 7a 65 20 74 68 65 20 6e 6f 74 69 66 69 65 72 20  ze the notifier 
5200: 74 6f 20 77 61 74 63 68 20 54 63 6c 5f 46 69 6c  to watch Tcl_Fil
5210: 65 73 20 66 72 6f 6d 20 74 68 69 73 20 63 68 61  es from this cha
5220: 6e 6e 65 6c 2e 0a 20 2a 0a 20 2a 20 52 65 73 75  nnel.. *. * Resu
5230: 6c 74 73 3a 0a 20 2a 20 20 20 20 4e 6f 6e 65 2e  lts:. *    None.
5240: 0a 20 2a 0a 20 2a 20 53 69 64 65 20 65 66 66 65  . *. * Side effe
5250: 63 74 73 3a 0a 20 2a 20 20 20 20 53 65 74 73 20  cts:. *    Sets 
5260: 75 70 20 74 68 65 20 6e 6f 74 69 66 69 65 72 20  up the notifier 
5270: 73 6f 20 74 68 61 74 20 61 20 66 75 74 75 72 65  so that a future
5280: 20 65 76 65 6e 74 20 6f 6e 20 74 68 65 20 63 68   event on the ch
5290: 61 6e 6e 65 6c 0a 20 2a 20 20 20 20 77 69 6c 6c  annel. *    will
52a0: 20 62 65 20 73 65 65 6e 20 62 79 20 54 63 6c 2e   be seen by Tcl.
52b0: 0a 20 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  . *. *----------
52c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
52d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
52e0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
52f0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 2f 0a 73 74  ---------. */.st
5300: 61 74 69 63 20 76 6f 69 64 0a 54 6c 73 57 61 74  atic void.TlsWat
5310: 63 68 50 72 6f 63 28 43 6c 69 65 6e 74 44 61 74  chProc(ClientDat
5320: 61 20 69 6e 73 74 61 6e 63 65 44 61 74 61 2c 20  a instanceData, 
5330: 20 20 20 2f 2a 20 54 68 65 20 73 6f 63 6b 65 74     /* The socket
5340: 20 73 74 61 74 65 2e 20 2a 2f 0a 20 20 20 20 69   state. */.    i
5350: 6e 74 20 6d 61 73 6b 29 09 09 09 2f 2a 20 45 76  nt mask).../* Ev
5360: 65 6e 74 73 20 6f 66 20 69 6e 74 65 72 65 73 74  ents of interest
5370: 3b 20 61 6e 20 4f 52 2d 65 64 20 63 6f 6d 62 69  ; an OR-ed combi
5380: 6e 61 74 69 6f 6e 20 6f 66 0a 09 09 09 09 20 2a  nation of..... *
5390: 20 54 43 4c 5f 52 45 41 44 41 42 4c 45 2c 20 54   TCL_READABLE, T
53a0: 43 4c 5f 57 52 49 54 41 42 4c 45 20 61 6e 64 20  CL_WRITABLE and 
53b0: 54 43 4c 5f 45 58 43 45 50 54 49 4f 4e 2e 20 2a  TCL_EXCEPTION. *
53c0: 2f 0a 7b 0a 20 20 20 20 54 63 6c 5f 43 68 61 6e  /.{.    Tcl_Chan
53d0: 6e 65 6c 20 20 20 20 20 64 6f 77 6e 43 68 61 6e  nel     downChan
53e0: 3b 0a 20 20 20 20 53 74 61 74 65 20 2a 73 74 61  ;.    State *sta
53f0: 74 65 50 74 72 20 3d 20 28 53 74 61 74 65 20 2a  tePtr = (State *
5400: 29 20 69 6e 73 74 61 6e 63 65 44 61 74 61 3b 0a  ) instanceData;.
5410: 20 20 20 20 54 63 6c 5f 44 72 69 76 65 72 57 61      Tcl_DriverWa
5420: 74 63 68 50 72 6f 63 20 2a 77 61 74 63 68 50 72  tchProc *watchPr
5430: 6f 63 3b 0a 0a 20 20 20 20 64 70 72 69 6e 74 66  oc;..    dprintf
5440: 28 22 54 6c 73 57 61 74 63 68 50 72 6f 63 28 30  ("TlsWatchProc(0
5450: 78 25 78 29 22 2c 20 6d 61 73 6b 29 3b 0a 0a 20  x%x)", mask);.. 
5460: 20 20 20 2f 2a 20 50 72 65 74 65 6e 64 20 74 6f     /* Pretend to
5470: 20 62 65 20 64 65 61 64 20 61 73 20 6c 6f 6e 67   be dead as long
5480: 20 61 73 20 74 68 65 20 76 65 72 69 66 79 20 63   as the verify c
5490: 61 6c 6c 62 61 63 6b 20 69 73 20 72 75 6e 6e 69  allback is runni
54a0: 6e 67 2e 0a 20 20 20 20 20 2a 20 4f 74 68 65 72  ng..     * Other
54b0: 77 69 73 65 20 74 68 61 74 20 63 61 6c 6c 62 61  wise that callba
54c0: 63 6b 20 63 6f 75 6c 64 20 62 65 20 69 6e 76 6f  ck could be invo
54d0: 6b 65 64 20 72 65 63 75 72 73 69 76 65 6c 79 2e  ked recursively.
54e0: 20 2a 2f 0a 20 20 20 20 69 66 20 28 73 74 61 74   */.    if (stat
54f0: 65 50 74 72 2d 3e 66 6c 61 67 73 20 26 20 54 4c  ePtr->flags & TL
5500: 53 5f 54 43 4c 5f 43 41 4c 4c 42 41 43 4b 29 20  S_TCL_CALLBACK) 
5510: 7b 0a 09 64 70 72 69 6e 74 66 28 22 43 61 6c 6c  {..dprintf("Call
5520: 62 61 63 6b 20 69 73 20 6f 6e 2d 67 6f 69 6e 67  back is on-going
5530: 2c 20 64 6f 69 6e 67 20 6e 6f 74 68 69 6e 67 22  , doing nothing"
5540: 29 3b 0a 09 72 65 74 75 72 6e 3b 0a 20 20 20 20  );..return;.    
5550: 7d 0a 0a 20 20 20 20 64 70 72 69 6e 74 46 6c 61  }..    dprintFla
5560: 67 73 28 73 74 61 74 65 50 74 72 29 3b 0a 0a 20  gs(statePtr);.. 
5570: 20 20 20 64 6f 77 6e 43 68 61 6e 20 3d 20 54 6c     downChan = Tl
5580: 73 5f 47 65 74 50 61 72 65 6e 74 28 73 74 61 74  s_GetParent(stat
5590: 65 50 74 72 2c 20 54 4c 53 5f 54 43 4c 5f 46 41  ePtr, TLS_TCL_FA
55a0: 53 54 50 41 54 48 29 3b 0a 0a 20 20 20 20 69 66  STPATH);..    if
55b0: 20 28 73 74 61 74 65 50 74 72 2d 3e 66 6c 61 67   (statePtr->flag
55c0: 73 20 26 20 54 4c 53 5f 54 43 4c 5f 48 41 4e 44  s & TLS_TCL_HAND
55d0: 53 48 41 4b 45 5f 46 41 49 4c 45 44 29 20 7b 0a  SHAKE_FAILED) {.
55e0: 09 64 70 72 69 6e 74 66 28 22 41 73 6b 65 64 20  .dprintf("Asked 
55f0: 74 6f 20 77 61 74 63 68 20 61 20 73 6f 63 6b 65  to watch a socke
5600: 74 20 77 69 74 68 20 61 20 66 61 69 6c 65 64 20  t with a failed 
5610: 68 61 6e 64 73 68 61 6b 65 20 2d 2d 20 6e 6f 74  handshake -- not
5620: 68 69 6e 67 20 63 61 6e 20 68 61 70 70 65 6e 20  hing can happen 
5630: 68 65 72 65 22 29 3b 0a 09 64 70 72 69 6e 74 66  here");..dprintf
5640: 28 22 55 6e 72 65 67 69 73 74 65 72 69 6e 67 20  ("Unregistering 
5650: 69 6e 74 65 72 65 73 74 20 69 6e 20 74 68 65 20  interest in the 
5660: 6c 6f 77 65 72 20 63 68 61 6e 6e 65 6c 22 29 3b  lower channel");
5670: 0a 0a 09 77 61 74 63 68 50 72 6f 63 20 3d 20 54  ...watchProc = T
5680: 63 6c 5f 43 68 61 6e 6e 65 6c 57 61 74 63 68 50  cl_ChannelWatchP
5690: 72 6f 63 28 54 63 6c 5f 47 65 74 43 68 61 6e 6e  roc(Tcl_GetChann
56a0: 65 6c 54 79 70 65 28 64 6f 77 6e 43 68 61 6e 29  elType(downChan)
56b0: 29 3b 0a 09 77 61 74 63 68 50 72 6f 63 28 54 63  );..watchProc(Tc
56c0: 6c 5f 47 65 74 43 68 61 6e 6e 65 6c 49 6e 73 74  l_GetChannelInst
56d0: 61 6e 63 65 44 61 74 61 28 64 6f 77 6e 43 68 61  anceData(downCha
56e0: 6e 29 2c 20 30 29 3b 0a 09 73 74 61 74 65 50 74  n), 0);..statePt
56f0: 72 2d 3e 77 61 74 63 68 4d 61 73 6b 20 3d 20 30  r->watchMask = 0
5700: 3b 0a 09 72 65 74 75 72 6e 3b 0a 20 20 20 20 7d  ;..return;.    }
5710: 0a 0a 20 20 20 20 73 74 61 74 65 50 74 72 2d 3e  ..    statePtr->
5720: 77 61 74 63 68 4d 61 73 6b 20 3d 20 6d 61 73 6b  watchMask = mask
5730: 3b 0a 0a 20 20 20 20 2f 2a 20 4e 6f 20 63 68 61  ;..    /* No cha
5740: 6e 6e 65 6c 20 68 61 6e 64 6c 65 72 73 20 61 6e  nnel handlers an
5750: 79 20 6d 6f 72 65 2e 20 57 65 20 77 69 6c 6c 20  y more. We will 
5760: 62 65 20 6e 6f 74 69 66 69 65 64 20 61 75 74 6f  be notified auto
5770: 6d 61 74 69 63 61 6c 6c 79 0a 20 20 20 20 20 2a  matically.     *
5780: 20 61 62 6f 75 74 20 65 76 65 6e 74 73 20 6f 6e   about events on
5790: 20 74 68 65 20 63 68 61 6e 6e 65 6c 20 62 65 6c   the channel bel
57a0: 6f 77 20 76 69 61 20 61 20 63 61 6c 6c 20 74 6f  ow via a call to
57b0: 20 6f 75 72 0a 20 20 20 20 20 2a 20 27 54 72 61   our.     * 'Tra
57c0: 6e 73 66 6f 72 6d 4e 6f 74 69 66 79 50 72 6f 63  nsformNotifyProc
57d0: 27 2e 20 42 75 74 20 77 65 20 68 61 76 65 20 74  '. But we have t
57e0: 6f 20 70 61 73 73 20 74 68 65 20 69 6e 74 65 72  o pass the inter
57f0: 65 73 74 20 64 6f 77 6e 20 6e 6f 77 2e 0a 20 20  est down now..  
5800: 20 20 20 2a 20 57 65 20 61 72 65 20 61 6c 6c 6f     * We are allo
5810: 77 65 64 20 74 6f 20 61 64 64 20 61 64 64 69 74  wed to add addit
5820: 69 6f 6e 61 6c 20 27 69 6e 74 65 72 65 73 74 27  ional 'interest'
5830: 20 74 6f 20 74 68 65 20 6d 61 73 6b 20 69 66 20   to the mask if 
5840: 77 65 20 77 61 6e 74 0a 20 20 20 20 20 2a 20 74  we want.     * t
5850: 6f 2e 20 42 75 74 20 74 68 69 73 20 74 72 61 6e  o. But this tran
5860: 73 66 6f 72 6d 61 74 69 6f 6e 20 68 61 73 20 6e  sformation has n
5870: 6f 20 73 75 63 68 20 69 6e 74 65 72 65 73 74 2e  o such interest.
5880: 20 49 74 20 6a 75 73 74 20 70 61 73 73 65 73 0a   It just passes.
5890: 20 20 20 20 20 2a 20 74 68 65 20 72 65 71 75 65       * the reque
58a0: 73 74 20 64 6f 77 6e 2c 20 75 6e 63 68 61 6e 67  st down, unchang
58b0: 65 64 2e 0a 20 20 20 20 20 2a 2f 0a 20 20 20 20  ed..     */.    
58c0: 64 70 72 69 6e 74 66 28 22 52 65 67 69 73 74 65  dprintf("Registe
58d0: 72 69 6e 67 20 6f 75 72 20 69 6e 74 65 72 65 73  ring our interes
58e0: 74 20 69 6e 20 74 68 65 20 6c 6f 77 65 72 20 63  t in the lower c
58f0: 68 61 6e 6e 65 6c 20 28 63 68 61 6e 3d 25 70 29  hannel (chan=%p)
5900: 22 2c 20 28 76 6f 69 64 20 2a 29 20 64 6f 77 6e  ", (void *) down
5910: 43 68 61 6e 29 3b 0a 20 20 20 20 77 61 74 63 68  Chan);.    watch
5920: 50 72 6f 63 20 3d 20 54 63 6c 5f 43 68 61 6e 6e  Proc = Tcl_Chann
5930: 65 6c 57 61 74 63 68 50 72 6f 63 28 54 63 6c 5f  elWatchProc(Tcl_
5940: 47 65 74 43 68 61 6e 6e 65 6c 54 79 70 65 28 64  GetChannelType(d
5950: 6f 77 6e 43 68 61 6e 29 29 3b 0a 20 20 20 20 77  ownChan));.    w
5960: 61 74 63 68 50 72 6f 63 28 54 63 6c 5f 47 65 74  atchProc(Tcl_Get
5970: 43 68 61 6e 6e 65 6c 49 6e 73 74 61 6e 63 65 44  ChannelInstanceD
5980: 61 74 61 28 64 6f 77 6e 43 68 61 6e 29 2c 20 6d  ata(downChan), m
5990: 61 73 6b 29 3b 0a 0a 0a 20 20 20 20 2f 2a 0a 20  ask);...    /*. 
59a0: 20 20 20 20 2a 20 4d 61 6e 61 67 65 6d 65 6e 74      * Management
59b0: 20 6f 66 20 74 68 65 20 69 6e 74 65 72 6e 61 6c   of the internal
59c0: 20 74 69 6d 65 72 2e 0a 20 20 20 20 20 2a 2f 0a   timer..     */.
59d0: 20 20 20 20 69 66 20 28 73 74 61 74 65 50 74 72      if (statePtr
59e0: 2d 3e 74 69 6d 65 72 20 21 3d 20 28 54 63 6c 5f  ->timer != (Tcl_
59f0: 54 69 6d 65 72 54 6f 6b 65 6e 29 20 4e 55 4c 4c  TimerToken) NULL
5a00: 29 20 7b 0a 09 64 70 72 69 6e 74 66 28 22 41 20  ) {..dprintf("A 
5a10: 74 69 6d 65 72 20 77 61 73 20 66 6f 75 6e 64 2c  timer was found,
5a20: 20 64 65 6c 65 74 69 6e 67 20 69 74 22 29 3b 0a   deleting it");.
5a30: 09 54 63 6c 5f 44 65 6c 65 74 65 54 69 6d 65 72  .Tcl_DeleteTimer
5a40: 48 61 6e 64 6c 65 72 28 73 74 61 74 65 50 74 72  Handler(statePtr
5a50: 2d 3e 74 69 6d 65 72 29 3b 0a 09 73 74 61 74 65  ->timer);..state
5a60: 50 74 72 2d 3e 74 69 6d 65 72 20 3d 20 28 54 63  Ptr->timer = (Tc
5a70: 6c 5f 54 69 6d 65 72 54 6f 6b 65 6e 29 20 4e 55  l_TimerToken) NU
5a80: 4c 4c 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69  LL;.    }..    i
5a90: 66 20 28 28 6d 61 73 6b 20 26 20 54 43 4c 5f 52  f ((mask & TCL_R
5aa0: 45 41 44 41 42 4c 45 29 20 26 26 0a 09 28 28 54  EADABLE) &&..((T
5ab0: 63 6c 5f 49 6e 70 75 74 42 75 66 66 65 72 65 64  cl_InputBuffered
5ac0: 28 73 74 61 74 65 50 74 72 2d 3e 73 65 6c 66 29  (statePtr->self)
5ad0: 20 3e 20 30 29 20 7c 7c 20 28 42 49 4f 5f 63 74   > 0) || (BIO_ct
5ae0: 72 6c 5f 70 65 6e 64 69 6e 67 28 73 74 61 74 65  rl_pending(state
5af0: 50 74 72 2d 3e 62 69 6f 29 20 3e 20 30 29 29 29  Ptr->bio) > 0)))
5b00: 20 7b 0a 09 2f 2a 0a 09 20 2a 20 54 68 65 72 65   {../*.. * There
5b10: 20 69 73 20 69 6e 74 65 72 65 73 74 20 69 6e 20   is interest in 
5b20: 72 65 61 64 61 62 6c 65 20 65 76 65 6e 74 73 20  readable events 
5b30: 61 6e 64 20 77 65 20 61 63 74 75 61 6c 6c 79 20  and we actually 
5b40: 68 61 76 65 0a 09 20 2a 20 64 61 74 61 20 77 61  have.. * data wa
5b50: 69 74 69 6e 67 2c 20 73 6f 20 67 65 6e 65 72 61  iting, so genera
5b60: 74 65 20 61 20 74 69 6d 65 72 20 74 6f 20 66 6c  te a timer to fl
5b70: 75 73 68 20 74 68 61 74 2e 0a 09 20 2a 2f 0a 09  ush that... */..
5b80: 64 70 72 69 6e 74 66 28 22 43 72 65 61 74 69 6e  dprintf("Creatin
5b90: 67 20 61 20 6e 65 77 20 74 69 6d 65 72 20 73 69  g a new timer si
5ba0: 6e 63 65 20 64 61 74 61 20 61 70 70 65 61 72 73  nce data appears
5bb0: 20 74 6f 20 62 65 20 77 61 69 74 69 6e 67 22 29   to be waiting")
5bc0: 3b 0a 09 73 74 61 74 65 50 74 72 2d 3e 74 69 6d  ;..statePtr->tim
5bd0: 65 72 20 3d 20 54 63 6c 5f 43 72 65 61 74 65 54  er = Tcl_CreateT
5be0: 69 6d 65 72 48 61 6e 64 6c 65 72 28 54 4c 53 5f  imerHandler(TLS_
5bf0: 54 43 4c 5f 44 45 4c 41 59 2c 20 54 6c 73 43 68  TCL_DELAY, TlsCh
5c00: 61 6e 6e 65 6c 48 61 6e 64 6c 65 72 54 69 6d 65  annelHandlerTime
5c10: 72 2c 20 28 43 6c 69 65 6e 74 44 61 74 61 29 20  r, (ClientData) 
5c20: 73 74 61 74 65 50 74 72 29 3b 0a 20 20 20 20 7d  statePtr);.    }
5c30: 0a 7d 0a 0a 2f 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d  .}../*. *-------
5c40: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5c50: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5c60: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5c70: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 0a  ------------. *.
5c80: 20 2a 20 54 6c 73 47 65 74 48 61 6e 64 6c 65 50   * TlsGetHandleP
5c90: 72 6f 63 20 2d 2d 0a 20 2a 0a 20 2a 20 20 20 20  roc --. *. *    
5ca0: 43 61 6c 6c 65 64 20 66 72 6f 6d 20 54 63 6c 5f  Called from Tcl_
5cb0: 47 65 74 43 68 61 6e 6e 65 6c 46 69 6c 65 20 74  GetChannelFile t
5cc0: 6f 20 72 65 74 72 69 65 76 65 20 6f 2f 73 20 66  o retrieve o/s f
5cd0: 69 6c 65 20 68 61 6e 64 6c 65 72 0a 20 2a 20 20  ile handler. *  
5ce0: 20 20 66 72 6f 6d 20 74 68 65 20 53 53 4c 20 73    from the SSL s
5cf0: 6f 63 6b 65 74 20 62 61 73 65 64 20 63 68 61 6e  ocket based chan
5d00: 6e 65 6c 2e 0a 20 2a 0a 20 2a 20 52 65 73 75 6c  nel.. *. * Resul
5d10: 74 73 3a 0a 20 2a 20 20 20 20 54 68 65 20 61 70  ts:. *    The ap
5d20: 70 72 6f 70 72 69 61 74 65 20 54 63 6c 5f 46 69  propriate Tcl_Fi
5d30: 6c 65 20 68 61 6e 64 6c 65 20 6f 72 20 4e 55 4c  le handle or NUL
5d40: 4c 20 69 66 20 6e 6f 6e 65 2e 0a 20 2a 0a 20 2a  L if none.. *. *
5d50: 20 53 69 64 65 20 65 66 66 65 63 74 73 3a 0a 20   Side effects:. 
5d60: 2a 20 20 20 20 4e 6f 6e 65 2e 0a 20 2a 0a 20 2a  *    None.. *. *
5d70: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5d80: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5d90: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5da0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5db0: 2d 2d 2d 0a 20 2a 2f 0a 73 74 61 74 69 63 20 69  ---. */.static i
5dc0: 6e 74 20 54 6c 73 47 65 74 48 61 6e 64 6c 65 50  nt TlsGetHandleP
5dd0: 72 6f 63 28 43 6c 69 65 6e 74 44 61 74 61 20 69  roc(ClientData i
5de0: 6e 73 74 61 6e 63 65 44 61 74 61 2c 20 20 20 20  nstanceData,    
5df0: 2f 2a 20 53 6f 63 6b 65 74 20 73 74 61 74 65 2e  /* Socket state.
5e00: 20 2a 2f 0a 20 20 20 20 69 6e 74 20 64 69 72 65   */.    int dire
5e10: 63 74 69 6f 6e 2c 09 09 2f 2a 20 54 43 4c 5f 52  ction,../* TCL_R
5e20: 45 41 44 41 42 4c 45 20 6f 72 20 54 43 4c 5f 57  EADABLE or TCL_W
5e30: 52 49 54 41 42 4c 45 20 2a 2f 0a 20 20 20 20 43  RITABLE */.    C
5e40: 6c 69 65 6e 74 44 61 74 61 20 2a 68 61 6e 64 6c  lientData *handl
5e50: 65 50 74 72 29 09 2f 2a 20 48 61 6e 64 6c 65 20  ePtr)./* Handle 
5e60: 61 73 73 6f 63 69 61 74 65 64 20 77 69 74 68 20  associated with 
5e70: 74 68 65 20 63 68 61 6e 6e 65 6c 20 2a 2f 0a 7b  the channel */.{
5e80: 0a 20 20 20 20 53 74 61 74 65 20 2a 73 74 61 74  .    State *stat
5e90: 65 50 74 72 20 3d 20 28 53 74 61 74 65 20 2a 29  ePtr = (State *)
5ea0: 20 69 6e 73 74 61 6e 63 65 44 61 74 61 3b 0a 0a   instanceData;..
5eb0: 20 20 20 20 72 65 74 75 72 6e 28 54 63 6c 5f 47      return(Tcl_G
5ec0: 65 74 43 68 61 6e 6e 65 6c 48 61 6e 64 6c 65 28  etChannelHandle(
5ed0: 54 6c 73 5f 47 65 74 50 61 72 65 6e 74 28 73 74  Tls_GetParent(st
5ee0: 61 74 65 50 74 72 2c 20 54 4c 53 5f 54 43 4c 5f  atePtr, TLS_TCL_
5ef0: 46 41 53 54 50 41 54 48 29 2c 20 64 69 72 65 63  FASTPATH), direc
5f00: 74 69 6f 6e 2c 20 68 61 6e 64 6c 65 50 74 72 29  tion, handlePtr)
5f10: 29 3b 0a 7d 0a 0a 2f 2a 0a 20 2a 2d 2d 2d 2d 2d  );.}../*. *-----
5f20: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5f30: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5f40: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5f50: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20  --------------. 
5f60: 2a 0a 20 2a 20 54 6c 73 4e 6f 74 69 66 79 50 72  *. * TlsNotifyPr
5f70: 6f 63 20 2d 2d 0a 20 2a 0a 20 2a 20 20 20 20 48  oc --. *. *    H
5f80: 61 6e 64 6c 65 72 20 63 61 6c 6c 65 64 20 62 79  andler called by
5f90: 20 54 63 6c 20 74 6f 20 69 6e 66 6f 72 6d 20 75   Tcl to inform u
5fa0: 73 20 6f 66 20 61 63 74 69 76 69 74 79 0a 20 2a  s of activity. *
5fb0: 20 20 20 20 6f 6e 20 74 68 65 20 75 6e 64 65 72      on the under
5fc0: 6c 79 69 6e 67 20 63 68 61 6e 6e 65 6c 2e 0a 20  lying channel.. 
5fd0: 2a 0a 20 2a 20 52 65 73 75 6c 74 73 3a 0a 20 2a  *. * Results:. *
5fe0: 20 20 20 20 54 79 70 65 20 6f 66 20 65 76 65 6e      Type of even
5ff0: 74 20 6f 72 20 30 20 69 66 20 66 61 69 6c 65 64  t or 0 if failed
6000: 0a 20 2a 0a 20 2a 20 53 69 64 65 20 65 66 66 65  . *. * Side effe
6010: 63 74 73 3a 0a 20 2a 20 20 20 20 4d 61 79 20 70  cts:. *    May p
6020: 72 6f 63 65 73 73 20 74 68 65 20 69 6e 63 6f 6d  rocess the incom
6030: 69 6e 67 20 65 76 65 6e 74 20 62 79 20 69 74 73  ing event by its
6040: 65 6c 66 2e 0a 20 2a 0a 20 2a 2d 2d 2d 2d 2d 2d  elf.. *. *------
6050: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6060: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6070: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6080: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a  -------------. *
6090: 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 54 6c 73  /.static int Tls
60a0: 4e 6f 74 69 66 79 50 72 6f 63 28 43 6c 69 65 6e  NotifyProc(Clien
60b0: 74 44 61 74 61 20 69 6e 73 74 61 6e 63 65 44 61  tData instanceDa
60c0: 74 61 2c 20 20 20 20 2f 2a 20 53 6f 63 6b 65 74  ta,    /* Socket
60d0: 20 73 74 61 74 65 2e 20 2a 2f 0a 20 20 20 20 69   state. */.    i
60e0: 6e 74 20 6d 61 73 6b 29 09 09 09 2f 2a 20 74 79  nt mask).../* ty
60f0: 70 65 20 6f 66 20 65 76 65 6e 74 20 74 68 61 74  pe of event that
6100: 20 6f 63 63 75 72 72 65 64 3a 0a 09 09 09 09 20   occurred:..... 
6110: 2a 20 4f 52 2d 65 64 20 63 6f 6d 62 69 6e 61 74  * OR-ed combinat
6120: 69 6f 6e 20 6f 66 20 54 43 4c 5f 52 45 41 44 41  ion of TCL_READA
6130: 42 4c 45 20 6f 72 20 54 43 4c 5f 57 52 49 54 41  BLE or TCL_WRITA
6140: 42 4c 45 20 2a 2f 0a 7b 0a 20 20 20 20 53 74 61  BLE */.{.    Sta
6150: 74 65 20 2a 73 74 61 74 65 50 74 72 20 3d 20 28  te *statePtr = (
6160: 53 74 61 74 65 20 2a 29 20 69 6e 73 74 61 6e 63  State *) instanc
6170: 65 44 61 74 61 3b 0a 20 20 20 20 69 6e 74 20 65  eData;.    int e
6180: 72 72 6f 72 43 6f 64 65 3b 0a 0a 20 20 20 20 2f  rrorCode;..    /
6190: 2a 0a 20 20 20 20 20 2a 20 41 6e 20 65 76 65 6e  *.     * An even
61a0: 74 20 6f 63 63 75 72 72 65 64 20 69 6e 20 74 68  t occurred in th
61b0: 65 20 75 6e 64 65 72 6c 79 69 6e 67 20 63 68 61  e underlying cha
61c0: 6e 6e 65 6c 2e 20 20 54 68 69 73 0a 20 20 20 20  nnel.  This.    
61d0: 20 2a 20 74 72 61 6e 73 66 6f 72 6d 61 74 69 6f   * transformatio
61e0: 6e 20 64 6f 65 73 6e 27 74 20 70 72 6f 63 65 73  n doesn't proces
61f0: 73 20 73 75 63 68 20 65 76 65 6e 74 73 20 74 68  s such events th
6200: 75 73 20 72 65 74 75 72 6e 73 20 74 68 65 0a 20  us returns the. 
6210: 20 20 20 20 2a 20 69 6e 63 6f 6d 69 6e 67 20 6d      * incoming m
6220: 61 73 6b 20 75 6e 63 68 61 6e 67 65 64 2e 0a 20  ask unchanged.. 
6230: 20 20 20 20 2a 2f 0a 20 20 20 20 69 66 20 28 73      */.    if (s
6240: 74 61 74 65 50 74 72 2d 3e 74 69 6d 65 72 20 21  tatePtr->timer !
6250: 3d 20 28 54 63 6c 5f 54 69 6d 65 72 54 6f 6b 65  = (Tcl_TimerToke
6260: 6e 29 20 4e 55 4c 4c 29 20 7b 0a 09 2f 2a 0a 09  n) NULL) {../*..
6270: 20 2a 20 44 65 6c 65 74 65 20 61 6e 20 65 78 69   * Delete an exi
6280: 73 74 69 6e 67 20 74 69 6d 65 72 2e 20 49 74 20  sting timer. It 
6290: 77 61 73 20 6e 6f 74 20 66 69 72 65 64 2c 20 79  was not fired, y
62a0: 65 74 20 77 65 20 61 72 65 0a 09 20 2a 20 68 65  et we are.. * he
62b0: 72 65 2c 20 73 6f 20 74 68 65 20 63 68 61 6e 6e  re, so the chann
62c0: 65 6c 20 62 65 6c 6f 77 20 67 65 6e 65 72 61 74  el below generat
62d0: 65 64 20 73 75 63 68 20 61 6e 20 65 76 65 6e 74  ed such an event
62e0: 20 61 6e 64 20 77 65 0a 09 20 2a 20 64 6f 6e 27   and we.. * don'
62f0: 74 20 68 61 76 65 20 74 6f 2e 20 54 68 65 20 72  t have to. The r
6300: 65 6e 65 77 61 6c 20 6f 66 20 74 68 65 20 69 6e  enewal of the in
6310: 74 65 72 65 73 74 20 61 66 74 65 72 20 74 68 65  terest after the
6320: 0a 09 20 2a 20 65 78 65 63 75 74 69 6f 6e 20 6f  .. * execution o
6330: 66 20 63 68 61 6e 6e 65 6c 20 68 61 6e 64 6c 65  f channel handle
6340: 72 73 20 77 69 6c 6c 20 65 76 65 6e 74 75 61 6c  rs will eventual
6350: 6c 79 20 63 61 75 73 65 20 75 73 20 74 6f 0a 09  ly cause us to..
6360: 20 2a 20 72 65 63 72 65 61 74 65 20 74 68 65 20   * recreate the 
6370: 74 69 6d 65 72 20 28 69 6e 20 57 61 74 63 68 50  timer (in WatchP
6380: 72 6f 63 29 2e 0a 09 20 2a 2f 0a 09 54 63 6c 5f  roc)... */..Tcl_
6390: 44 65 6c 65 74 65 54 69 6d 65 72 48 61 6e 64 6c  DeleteTimerHandl
63a0: 65 72 28 73 74 61 74 65 50 74 72 2d 3e 74 69 6d  er(statePtr->tim
63b0: 65 72 29 3b 0a 09 73 74 61 74 65 50 74 72 2d 3e  er);..statePtr->
63c0: 74 69 6d 65 72 20 3d 20 28 54 63 6c 5f 54 69 6d  timer = (Tcl_Tim
63d0: 65 72 54 6f 6b 65 6e 29 20 4e 55 4c 4c 3b 0a 20  erToken) NULL;. 
63e0: 20 20 20 7d 0a 0a 20 20 20 20 69 66 20 28 73 74     }..    if (st
63f0: 61 74 65 50 74 72 2d 3e 66 6c 61 67 73 20 26 20  atePtr->flags & 
6400: 54 4c 53 5f 54 43 4c 5f 43 41 4c 4c 42 41 43 4b  TLS_TCL_CALLBACK
6410: 29 20 7b 0a 09 64 70 72 69 6e 74 66 28 22 52 65  ) {..dprintf("Re
6420: 74 75 72 6e 69 6e 67 20 30 20 64 75 65 20 74 6f  turning 0 due to
6430: 20 63 61 6c 6c 62 61 63 6b 22 29 3b 0a 09 72 65   callback");..re
6440: 74 75 72 6e 20 30 3b 0a 20 20 20 20 7d 0a 0a 20  turn 0;.    }.. 
6450: 20 20 20 64 70 72 69 6e 74 66 28 22 43 61 6c 6c     dprintf("Call
6460: 69 6e 67 20 54 6c 73 5f 57 61 69 74 46 6f 72 43  ing Tls_WaitForC
6470: 6f 6e 6e 65 63 74 22 29 3b 0a 20 20 20 20 65 72  onnect");.    er
6480: 72 6f 72 43 6f 64 65 20 3d 20 30 3b 0a 20 20 20  rorCode = 0;.   
6490: 20 69 66 20 28 54 6c 73 5f 57 61 69 74 46 6f 72   if (Tls_WaitFor
64a0: 43 6f 6e 6e 65 63 74 28 73 74 61 74 65 50 74 72  Connect(statePtr
64b0: 2c 20 26 65 72 72 6f 72 43 6f 64 65 2c 20 31 29  , &errorCode, 1)
64c0: 20 3c 20 30 29 20 7b 0a 09 54 6c 73 5f 45 72 72   < 0) {..Tls_Err
64d0: 6f 72 28 73 74 61 74 65 50 74 72 2c 20 73 74 72  or(statePtr, str
64e0: 65 72 72 6f 72 28 65 72 72 6f 72 43 6f 64 65 29  error(errorCode)
64f0: 29 3b 0a 09 69 66 20 28 65 72 72 6f 72 43 6f 64  );..if (errorCod
6500: 65 20 3d 3d 20 45 41 47 41 49 4e 29 20 7b 0a 09  e == EAGAIN) {..
6510: 20 20 20 20 64 70 72 69 6e 74 66 28 22 41 73 79      dprintf("Asy
6520: 6e 63 20 66 6c 61 67 20 63 6f 75 6c 64 20 62 65  nc flag could be
6530: 20 73 65 74 20 28 64 69 64 6e 27 74 20 63 68 65   set (didn't che
6540: 63 6b 29 20 61 6e 64 20 65 72 72 6f 72 43 6f 64  ck) and errorCod
6550: 65 20 3d 3d 20 45 41 47 41 49 4e 3a 20 20 52 65  e == EAGAIN:  Re
6560: 74 75 72 6e 69 6e 67 20 30 22 29 3b 0a 0a 09 20  turning 0");... 
6570: 20 20 20 72 65 74 75 72 6e 20 30 3b 0a 09 7d 0a     return 0;..}.
6580: 0a 09 64 70 72 69 6e 74 66 28 22 54 6c 73 5f 57  ..dprintf("Tls_W
6590: 61 69 74 46 6f 72 43 6f 6e 6e 65 63 74 20 72 65  aitForConnect re
65a0: 74 75 72 6e 65 64 20 61 6e 20 65 72 72 6f 72 22  turned an error"
65b0: 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 64 70  );.    }..    dp
65c0: 72 69 6e 74 66 28 22 52 65 74 75 72 6e 69 6e 67  rintf("Returning
65d0: 20 25 69 22 2c 20 6d 61 73 6b 29 3b 0a 0a 20 20   %i", mask);..  
65e0: 20 20 72 65 74 75 72 6e 28 6d 61 73 6b 29 3b 0a    return(mask);.
65f0: 7d 0a 0a 2f 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d  }../*. *--------
6600: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6610: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6620: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2a 0a  --------------*.
6630: 20 2a 0a 20 2a 20 20 20 20 54 6c 73 43 68 61 6e   *. *    TlsChan
6640: 6e 65 6c 48 61 6e 64 6c 65 72 54 69 6d 65 72 20  nelHandlerTimer 
6650: 2d 2d 0a 20 2a 0a 20 2a 20 20 20 20 2d 2d 2d 2d  --. *. *    ----
6660: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6670: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6680: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2a 0a 20 2a  ------------*. *
6690: 20 20 20 20 43 61 6c 6c 65 64 20 62 79 20 74 68      Called by th
66a0: 65 20 6e 6f 74 69 66 69 65 72 20 28 2d 3e 20 74  e notifier (-> t
66b0: 69 6d 65 72 29 20 74 6f 20 66 6c 75 73 68 20 6f  imer) to flush o
66c0: 75 74 0a 20 2a 20 20 20 20 69 6e 66 6f 72 6d 61  ut. *    informa
66d0: 74 69 6f 6e 20 77 61 69 74 69 6e 67 20 69 6e 20  tion waiting in 
66e0: 63 68 61 6e 6e 65 6c 20 62 75 66 66 65 72 73 2e  channel buffers.
66f0: 0a 20 2a 20 20 20 20 2d 2d 2d 2d 2d 2d 2d 2d 2d  . *    ---------
6700: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6710: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6720: 2d 2d 2d 2d 2d 2d 2d 2a 0a 20 2a 0a 20 2a 20 20  -------*. *. *  
6730: 20 20 53 69 64 65 20 65 66 66 65 63 74 73 3a 0a    Side effects:.
6740: 20 2a 20 20 20 20 20 20 20 20 41 73 20 6f 66 20   *        As of 
6750: 27 54 6c 73 43 68 61 6e 6e 65 6c 48 61 6e 64 6c  'TlsChannelHandl
6760: 65 72 27 2e 0a 20 2a 0a 20 2a 20 20 20 20 52 65  er'.. *. *    Re
6770: 73 75 6c 74 3a 0a 20 2a 20 20 20 20 20 20 20 20  sult:. *        
6780: 4e 6f 6e 65 2e 0a 20 2a 0a 20 2a 2d 2d 2d 2d 2d  None.. *. *-----
6790: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
67a0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
67b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
67c0: 2d 2a 0a 20 2a 2f 0a 73 74 61 74 69 63 20 76 6f  -*. */.static vo
67d0: 69 64 20 54 6c 73 43 68 61 6e 6e 65 6c 48 61 6e  id TlsChannelHan
67e0: 64 6c 65 72 54 69 6d 65 72 28 43 6c 69 65 6e 74  dlerTimer(Client
67f0: 44 61 74 61 20 63 6c 69 65 6e 74 44 61 74 61 29  Data clientData)
6800: 20 7b 0a 20 20 20 20 53 74 61 74 65 20 2a 73 74   {.    State *st
6810: 61 74 65 50 74 72 20 3d 20 28 53 74 61 74 65 20  atePtr = (State 
6820: 2a 29 20 63 6c 69 65 6e 74 44 61 74 61 3b 0a 20  *) clientData;. 
6830: 20 20 20 69 6e 74 20 6d 61 73 6b 20 3d 20 30 3b     int mask = 0;
6840: 0a 0a 20 20 20 20 64 70 72 69 6e 74 66 28 22 43  ..    dprintf("C
6850: 61 6c 6c 65 64 22 29 3b 0a 0a 20 20 20 20 73 74  alled");..    st
6860: 61 74 65 50 74 72 2d 3e 74 69 6d 65 72 20 3d 20  atePtr->timer = 
6870: 28 54 63 6c 5f 54 69 6d 65 72 54 6f 6b 65 6e 29  (Tcl_TimerToken)
6880: 20 4e 55 4c 4c 3b 0a 0a 20 20 20 20 69 66 20 28   NULL;..    if (
6890: 42 49 4f 5f 77 70 65 6e 64 69 6e 67 28 73 74 61  BIO_wpending(sta
68a0: 74 65 50 74 72 2d 3e 62 69 6f 29 29 20 7b 0a 09  tePtr->bio)) {..
68b0: 64 70 72 69 6e 74 66 28 22 5b 63 68 61 6e 3d 25  dprintf("[chan=%
68c0: 70 5d 20 42 49 4f 20 77 72 69 74 61 62 6c 65 22  p] BIO writable"
68d0: 2c 20 73 74 61 74 65 50 74 72 2d 3e 73 65 6c 66  , statePtr->self
68e0: 29 3b 0a 0a 09 6d 61 73 6b 20 7c 3d 20 54 43 4c  );...mask |= TCL
68f0: 5f 57 52 49 54 41 42 4c 45 3b 0a 20 20 20 20 7d  _WRITABLE;.    }
6900: 0a 0a 20 20 20 20 69 66 20 28 42 49 4f 5f 70 65  ..    if (BIO_pe
6910: 6e 64 69 6e 67 28 73 74 61 74 65 50 74 72 2d 3e  nding(statePtr->
6920: 62 69 6f 29 29 20 7b 0a 09 64 70 72 69 6e 74 66  bio)) {..dprintf
6930: 28 22 5b 63 68 61 6e 3d 25 70 5d 20 42 49 4f 20  ("[chan=%p] BIO 
6940: 72 65 61 64 61 62 6c 65 22 2c 20 73 74 61 74 65  readable", state
6950: 50 74 72 2d 3e 73 65 6c 66 29 3b 0a 0a 09 6d 61  Ptr->self);...ma
6960: 73 6b 20 7c 3d 20 54 43 4c 5f 52 45 41 44 41 42  sk |= TCL_READAB
6970: 4c 45 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 64  LE;.    }..    d
6980: 70 72 69 6e 74 66 28 22 4e 6f 74 69 66 79 69 6e  printf("Notifyin
6990: 67 20 6f 75 72 73 65 6c 76 65 73 22 29 3b 0a 20  g ourselves");. 
69a0: 20 20 20 54 63 6c 5f 4e 6f 74 69 66 79 43 68 61     Tcl_NotifyCha
69b0: 6e 6e 65 6c 28 73 74 61 74 65 50 74 72 2d 3e 73  nnel(statePtr->s
69c0: 65 6c 66 2c 20 6d 61 73 6b 29 3b 0a 0a 20 20 20  elf, mask);..   
69d0: 20 64 70 72 69 6e 74 66 28 22 52 65 74 75 72 6e   dprintf("Return
69e0: 69 6e 67 22 29 3b 0a 0a 20 20 20 20 72 65 74 75  ing");..    retu
69f0: 72 6e 3b 0a 7d 0a 0a 54 63 6c 5f 43 68 61 6e 6e  rn;.}..Tcl_Chann
6a00: 65 6c 20 54 6c 73 5f 47 65 74 50 61 72 65 6e 74  el Tls_GetParent
6a10: 28 53 74 61 74 65 20 2a 73 74 61 74 65 50 74 72  (State *statePtr
6a20: 2c 20 69 6e 74 20 6d 61 73 6b 46 6c 61 67 73 29  , int maskFlags)
6a30: 20 7b 0a 20 20 20 20 64 70 72 69 6e 74 66 28 22   {.    dprintf("
6a40: 52 65 71 75 65 73 74 65 64 20 74 6f 20 67 65 74  Requested to get
6a50: 20 70 61 72 65 6e 74 20 6f 66 20 63 68 61 6e 6e   parent of chann
6a60: 65 6c 20 25 70 22 2c 20 73 74 61 74 65 50 74 72  el %p", statePtr
6a70: 2d 3e 73 65 6c 66 29 3b 0a 0a 20 20 20 20 69 66  ->self);..    if
6a80: 20 28 28 73 74 61 74 65 50 74 72 2d 3e 66 6c 61   ((statePtr->fla
6a90: 67 73 20 26 20 7e 6d 61 73 6b 46 6c 61 67 73 29  gs & ~maskFlags)
6aa0: 20 26 20 54 4c 53 5f 54 43 4c 5f 46 41 53 54 50   & TLS_TCL_FASTP
6ab0: 41 54 48 29 20 7b 0a 09 64 70 72 69 6e 74 66 28  ATH) {..dprintf(
6ac0: 22 41 73 6b 65 64 20 74 6f 20 67 65 74 20 74 68  "Asked to get th
6ad0: 65 20 70 61 72 65 6e 74 20 63 68 61 6e 6e 65 6c  e parent channel
6ae0: 20 77 68 69 6c 65 20 77 65 20 61 72 65 20 75 73   while we are us
6af0: 69 6e 67 20 46 61 73 74 50 61 74 68 20 2d 2d 20  ing FastPath -- 
6b00: 72 65 74 75 72 6e 69 6e 67 20 4e 55 4c 4c 22 29  returning NULL")
6b10: 3b 0a 09 72 65 74 75 72 6e 28 4e 55 4c 4c 29 3b  ;..return(NULL);
6b20: 0a 20 20 20 20 7d 0a 20 20 20 20 72 65 74 75 72  .    }.    retur
6b30: 6e 28 54 63 6c 5f 47 65 74 53 74 61 63 6b 65 64  n(Tcl_GetStacked
6b40: 43 68 61 6e 6e 65 6c 28 73 74 61 74 65 50 74 72  Channel(statePtr
6b50: 2d 3e 73 65 6c 66 29 29 3b 0a 7d 0a 0a 2f 2a 0a  ->self));.}../*.
6b60: 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d   *--------------
6b70: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6b80: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6b90: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6ba0: 2d 2d 2d 2d 2d 0a 20 2a 0a 20 2a 20 54 6c 73 5f  -----. *. * Tls_
6bb0: 43 68 61 6e 6e 65 6c 54 79 70 65 20 2d 2d 0a 20  ChannelType --. 
6bc0: 2a 0a 20 2a 20 20 20 20 52 65 74 75 72 6e 20 74  *. *    Return t
6bd0: 68 65 20 63 6f 72 72 65 63 74 20 54 4c 53 20 63  he correct TLS c
6be0: 68 61 6e 6e 65 6c 20 64 72 69 76 65 72 20 69 6e  hannel driver in
6bf0: 66 6f 0a 20 2a 0a 20 2a 20 52 65 73 75 6c 74 73  fo. *. * Results
6c00: 3a 0a 20 2a 20 20 20 20 54 68 65 20 63 6f 72 72  :. *    The corr
6c10: 65 63 74 20 63 68 61 6e 6e 65 6c 20 64 72 69 76  ect channel driv
6c20: 65 72 20 66 6f 72 20 74 68 65 20 63 75 72 72 65  er for the curre
6c30: 6e 74 20 76 65 72 73 69 6f 6e 20 6f 66 20 54 63  nt version of Tc
6c40: 6c 2e 0a 20 2a 0a 20 2a 20 53 69 64 65 20 65 66  l.. *. * Side ef
6c50: 66 65 63 74 73 3a 0a 20 2a 20 20 20 20 4e 6f 6e  fects:. *    Non
6c60: 65 2e 0a 20 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d  e.. *. *--------
6c70: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6c80: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6c90: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6ca0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 2f 0a  -----------. */.
6cb0: 73 74 61 74 69 63 20 63 6f 6e 73 74 20 54 63 6c  static const Tcl
6cc0: 5f 43 68 61 6e 6e 65 6c 54 79 70 65 20 74 6c 73  _ChannelType tls
6cd0: 43 68 61 6e 6e 65 6c 54 79 70 65 20 3d 20 7b 0a  ChannelType = {.
6ce0: 20 20 20 20 22 74 6c 73 22 2c 09 09 09 2f 2a 20      "tls",.../* 
6cf0: 54 79 70 65 20 6e 61 6d 65 20 2a 2f 0a 20 20 20  Type name */.   
6d00: 20 54 43 4c 5f 43 48 41 4e 4e 45 4c 5f 56 45 52   TCL_CHANNEL_VER
6d10: 53 49 4f 4e 5f 35 2c 09 2f 2a 20 76 35 20 63 68  SION_5,./* v5 ch
6d20: 61 6e 6e 65 6c 20 2a 2f 0a 20 20 20 20 54 6c 73  annel */.    Tls
6d30: 43 6c 6f 73 65 50 72 6f 63 2c 09 09 2f 2a 20 43  CloseProc,../* C
6d40: 6c 6f 73 65 20 70 72 6f 63 20 2a 2f 0a 20 20 20  lose proc */.   
6d50: 20 54 6c 73 49 6e 70 75 74 50 72 6f 63 2c 09 09   TlsInputProc,..
6d60: 2f 2a 20 49 6e 70 75 74 20 70 72 6f 63 20 2a 2f  /* Input proc */
6d70: 0a 20 20 20 20 54 6c 73 4f 75 74 70 75 74 50 72  .    TlsOutputPr
6d80: 6f 63 2c 09 09 2f 2a 20 4f 75 74 70 75 74 20 70  oc,../* Output p
6d90: 72 6f 63 20 2a 2f 0a 20 20 20 20 4e 55 4c 4c 2c  roc */.    NULL,
6da0: 09 09 09 2f 2a 20 53 65 65 6b 20 70 72 6f 63 20  .../* Seek proc 
6db0: 2a 2f 0a 20 20 20 20 54 6c 73 53 65 74 4f 70 74  */.    TlsSetOpt
6dc0: 69 6f 6e 50 72 6f 63 2c 09 09 2f 2a 20 53 65 74  ionProc,../* Set
6dd0: 20 6f 70 74 69 6f 6e 20 70 72 6f 63 20 2a 2f 0a   option proc */.
6de0: 20 20 20 20 54 6c 73 47 65 74 4f 70 74 69 6f 6e      TlsGetOption
6df0: 50 72 6f 63 2c 09 09 2f 2a 20 47 65 74 20 6f 70  Proc,../* Get op
6e00: 74 69 6f 6e 20 70 72 6f 63 20 2a 2f 0a 20 20 20  tion proc */.   
6e10: 20 54 6c 73 57 61 74 63 68 50 72 6f 63 2c 09 09   TlsWatchProc,..
6e20: 2f 2a 20 49 6e 69 74 69 61 6c 69 7a 65 20 6e 6f  /* Initialize no
6e30: 74 69 66 69 65 72 20 2a 2f 0a 20 20 20 20 54 6c  tifier */.    Tl
6e40: 73 47 65 74 48 61 6e 64 6c 65 50 72 6f 63 2c 09  sGetHandleProc,.
6e50: 09 2f 2a 20 47 65 74 20 4f 53 20 68 61 6e 64 6c  ./* Get OS handl
6e60: 65 73 20 6f 75 74 20 6f 66 20 63 68 61 6e 6e 65  es out of channe
6e70: 6c 20 2a 2f 0a 20 20 20 20 54 6c 73 43 6c 6f 73  l */.    TlsClos
6e80: 65 32 50 72 6f 63 2c 09 09 2f 2a 20 63 6c 6f 73  e2Proc,../* clos
6e90: 65 32 70 72 6f 63 20 2a 2f 0a 20 20 20 20 54 6c  e2proc */.    Tl
6ea0: 73 42 6c 6f 63 6b 4d 6f 64 65 50 72 6f 63 2c 09  sBlockModeProc,.
6eb0: 09 2f 2a 20 53 65 74 20 62 6c 6f 63 6b 69 6e 67  ./* Set blocking
6ec0: 2f 6e 6f 6e 62 6c 6f 63 6b 69 6e 67 20 6d 6f 64  /nonblocking mod
6ed0: 65 2a 2f 0a 20 20 20 20 4e 55 4c 4c 2c 09 09 09  e*/.    NULL,...
6ee0: 2f 2a 20 46 6c 75 73 68 20 70 72 6f 63 20 2a 2f  /* Flush proc */
6ef0: 0a 20 20 20 20 54 6c 73 4e 6f 74 69 66 79 50 72  .    TlsNotifyPr
6f00: 6f 63 2c 09 09 2f 2a 20 48 61 6e 64 6c 69 6e 67  oc,../* Handling
6f10: 20 6f 66 20 65 76 65 6e 74 73 20 62 75 62 62 6c   of events bubbl
6f20: 69 6e 67 20 75 70 20 2a 2f 0a 20 20 20 20 4e 55  ing up */.    NU
6f30: 4c 4c 2c 09 09 09 2f 2a 20 57 69 64 65 20 73 65  LL,.../* Wide se
6f40: 65 6b 20 70 72 6f 63 20 2a 2f 0a 20 20 20 20 4e  ek proc */.    N
6f50: 55 4c 4c 2c 09 09 09 2f 2a 20 54 68 72 65 61 64  ULL,.../* Thread
6f60: 20 61 63 74 69 6f 6e 20 2a 2f 0a 20 20 20 20 4e   action */.    N
6f70: 55 4c 4c 09 09 09 2f 2a 20 54 72 75 6e 63 61 74  ULL.../* Truncat
6f80: 65 20 2a 2f 0a 7d 3b 0a 0a 63 6f 6e 73 74 20 54  e */.};..const T
6f90: 63 6c 5f 43 68 61 6e 6e 65 6c 54 79 70 65 20 2a  cl_ChannelType *
6fa0: 54 6c 73 5f 43 68 61 6e 6e 65 6c 54 79 70 65 28  Tls_ChannelType(
6fb0: 76 6f 69 64 29 20 7b 0a 20 20 20 20 72 65 74 75  void) {.    retu
6fc0: 72 6e 20 26 74 6c 73 43 68 61 6e 6e 65 6c 54 79  rn &tlsChannelTy
6fd0: 70 65 3b 0a 7d 0a                                pe;.}.