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 09 20 20 20 20 65 72  ssful");..    er
10f0: 72 20 3d 20 42 49 4f 5f 66 6c 75 73 68 28 73 74  r = BIO_flush(st
1100: 61 74 65 50 74 72 2d 3e 62 69 6f 29 3b 0a 09 20  atePtr->bio);.. 
1110: 20 20 20 69 66 20 28 65 72 72 20 3c 3d 20 30 29     if (err <= 0)
1120: 20 7b 0a 09 09 64 70 72 69 6e 74 66 28 22 46 6c   {...dprintf("Fl
1130: 75 73 68 69 6e 67 20 74 68 65 20 6c 6f 77 65 72  ushing the lower
1140: 20 6c 61 79 65 72 73 20 66 61 69 6c 65 64 2c 20   layers failed, 
1150: 74 68 69 73 20 77 69 6c 6c 20 70 72 6f 62 61 62  this will probab
1160: 6c 79 20 74 65 72 6d 69 6e 61 74 65 20 74 68 69  ly terminate thi
1170: 73 20 73 65 73 73 69 6f 6e 22 29 3b 0a 09 20 20  s session");..  
1180: 20 20 7d 0a 09 7d 20 65 6c 73 65 20 7b 0a 09 20    }..} else {.. 
1190: 20 20 20 64 70 72 69 6e 74 66 28 22 41 63 63 65     dprintf("Acce
11a0: 70 74 20 6f 72 20 63 6f 6e 6e 65 63 74 20 66 61  pt or connect fa
11b0: 69 6c 65 64 22 29 3b 0a 09 7d 0a 0a 09 72 63 20  iled");..}...rc 
11c0: 3d 20 53 53 4c 5f 67 65 74 5f 65 72 72 6f 72 28  = SSL_get_error(
11d0: 73 74 61 74 65 50 74 72 2d 3e 73 73 6c 2c 20 65  statePtr->ssl, e
11e0: 72 72 29 3b 0a 09 62 61 63 6b 69 6e 67 45 72 72  rr);..backingErr
11f0: 6f 72 20 3d 20 45 52 52 5f 67 65 74 5f 65 72 72  or = ERR_get_err
1200: 6f 72 28 29 3b 0a 09 69 66 20 28 72 63 20 21 3d  or();..if (rc !=
1210: 20 53 53 4c 5f 45 52 52 4f 52 5f 4e 4f 4e 45 29   SSL_ERROR_NONE)
1220: 20 7b 0a 09 20 20 20 20 64 70 72 69 6e 74 66 28   {..    dprintf(
1230: 22 47 6f 74 20 65 72 72 6f 72 3a 20 25 69 20 28  "Got error: %i (
1240: 72 63 20 3d 20 25 69 29 22 2c 20 65 72 72 2c 20  rc = %i)", err, 
1250: 72 63 29 3b 0a 09 20 20 20 20 64 70 72 69 6e 74  rc);..    dprint
1260: 66 28 22 47 6f 74 20 65 72 72 6f 72 3a 20 25 73  f("Got error: %s
1270: 22 2c 20 45 52 52 5f 72 65 61 73 6f 6e 5f 65 72  ", ERR_reason_er
1280: 72 6f 72 5f 73 74 72 69 6e 67 28 62 61 63 6b 69  ror_string(backi
1290: 6e 67 45 72 72 6f 72 29 29 3b 0a 09 7d 0a 0a 09  ngError));..}...
12a0: 62 69 6f 53 68 6f 75 6c 64 52 65 74 72 79 20 3d  bioShouldRetry =
12b0: 20 30 3b 0a 09 69 66 20 28 65 72 72 20 3c 3d 20   0;..if (err <= 
12c0: 30 29 20 7b 0a 09 20 20 20 20 69 66 20 28 72 63  0) {..    if (rc
12d0: 20 3d 3d 20 53 53 4c 5f 45 52 52 4f 52 5f 57 41   == SSL_ERROR_WA
12e0: 4e 54 5f 43 4f 4e 4e 45 43 54 20 7c 7c 20 72 63  NT_CONNECT || rc
12f0: 20 3d 3d 20 53 53 4c 5f 45 52 52 4f 52 5f 57 41   == SSL_ERROR_WA
1300: 4e 54 5f 41 43 43 45 50 54 20 7c 7c 20 72 63 20  NT_ACCEPT || rc 
1310: 3d 3d 20 53 53 4c 5f 45 52 52 4f 52 5f 57 41 4e  == SSL_ERROR_WAN
1320: 54 5f 52 45 41 44 20 7c 7c 20 72 63 20 3d 3d 20  T_READ || rc == 
1330: 53 53 4c 5f 45 52 52 4f 52 5f 57 41 4e 54 5f 57  SSL_ERROR_WANT_W
1340: 52 49 54 45 29 20 7b 0a 09 09 62 69 6f 53 68 6f  RITE) {...bioSho
1350: 75 6c 64 52 65 74 72 79 20 3d 20 31 3b 0a 09 20  uldRetry = 1;.. 
1360: 20 20 20 7d 20 65 6c 73 65 20 69 66 20 28 42 49     } else if (BI
1370: 4f 5f 73 68 6f 75 6c 64 5f 72 65 74 72 79 28 73  O_should_retry(s
1380: 74 61 74 65 50 74 72 2d 3e 62 69 6f 29 29 20 7b  tatePtr->bio)) {
1390: 0a 09 09 62 69 6f 53 68 6f 75 6c 64 52 65 74 72  ...bioShouldRetr
13a0: 79 20 3d 20 31 3b 0a 09 20 20 20 20 7d 20 65 6c  y = 1;..    } el
13b0: 73 65 20 69 66 20 28 72 63 20 3d 3d 20 53 53 4c  se if (rc == SSL
13c0: 5f 45 52 52 4f 52 5f 53 59 53 43 41 4c 4c 20 26  _ERROR_SYSCALL &
13d0: 26 20 54 63 6c 5f 47 65 74 45 72 72 6e 6f 28 29  & Tcl_GetErrno()
13e0: 20 3d 3d 20 45 41 47 41 49 4e 29 20 7b 0a 09 09   == EAGAIN) {...
13f0: 62 69 6f 53 68 6f 75 6c 64 52 65 74 72 79 20 3d  bioShouldRetry =
1400: 20 31 3b 0a 09 20 20 20 20 7d 0a 09 7d 20 65 6c   1;..    }..} el
1410: 73 65 20 7b 0a 09 20 20 20 20 69 66 20 28 21 53  se {..    if (!S
1420: 53 4c 5f 69 73 5f 69 6e 69 74 5f 66 69 6e 69 73  SL_is_init_finis
1430: 68 65 64 28 73 74 61 74 65 50 74 72 2d 3e 73 73  hed(statePtr->ss
1440: 6c 29 29 20 7b 0a 09 09 62 69 6f 53 68 6f 75 6c  l)) {...bioShoul
1450: 64 52 65 74 72 79 20 3d 20 31 3b 0a 09 20 20 20  dRetry = 1;..   
1460: 20 7d 0a 09 7d 0a 0a 09 69 66 20 28 62 69 6f 53   }..}...if (bioS
1470: 68 6f 75 6c 64 52 65 74 72 79 29 20 7b 0a 09 20  houldRetry) {.. 
1480: 20 20 20 64 70 72 69 6e 74 66 28 22 54 68 65 20     dprintf("The 
1490: 49 2f 4f 20 64 69 64 20 6e 6f 74 20 63 6f 6d 70  I/O did not comp
14a0: 6c 65 74 65 20 2d 2d 20 62 75 74 20 77 65 20 73  lete -- but we s
14b0: 68 6f 75 6c 64 20 74 72 79 20 69 74 20 61 67 61  hould try it aga
14c0: 69 6e 22 29 3b 0a 0a 09 20 20 20 20 69 66 20 28  in");...    if (
14d0: 73 74 61 74 65 50 74 72 2d 3e 66 6c 61 67 73 20  statePtr->flags 
14e0: 26 20 54 4c 53 5f 54 43 4c 5f 41 53 59 4e 43 29  & TLS_TCL_ASYNC)
14f0: 20 7b 0a 09 09 64 70 72 69 6e 74 66 28 22 52 65   {...dprintf("Re
1500: 74 75 72 6e 69 6e 67 20 45 41 47 41 49 4e 20 73  turning EAGAIN s
1510: 6f 20 74 68 61 74 20 69 74 20 63 61 6e 20 62 65  o that it can be
1520: 20 72 65 74 72 69 65 64 20 6c 61 74 65 72 22 29   retried later")
1530: 3b 0a 09 09 2a 65 72 72 6f 72 43 6f 64 65 50 74  ;...*errorCodePt
1540: 72 20 3d 20 45 41 47 41 49 4e 3b 0a 09 09 54 6c  r = EAGAIN;...Tl
1550: 73 5f 45 72 72 6f 72 28 73 74 61 74 65 50 74 72  s_Error(statePtr
1560: 2c 20 22 48 61 6e 64 73 68 61 6b 65 20 6e 6f 74  , "Handshake not
1570: 20 63 6f 6d 70 6c 65 74 65 2c 20 77 69 6c 6c 20   complete, will 
1580: 72 65 74 72 79 20 6c 61 74 65 72 22 29 3b 0a 09  retry later");..
1590: 09 72 65 74 75 72 6e 28 2d 31 29 3b 0a 09 20 20  .return(-1);..  
15a0: 20 20 7d 20 65 6c 73 65 20 7b 0a 09 09 64 70 72    } else {...dpr
15b0: 69 6e 74 66 28 22 44 6f 69 6e 67 20 73 6f 20 6e  intf("Doing so n
15c0: 6f 77 22 29 3b 0a 09 09 63 6f 6e 74 69 6e 75 65  ow");...continue
15d0: 3b 0a 09 20 20 20 20 7d 0a 09 7d 0a 0a 09 64 70  ;..    }..}...dp
15e0: 72 69 6e 74 66 28 22 57 65 20 68 61 76 65 20 65  rintf("We have e
15f0: 69 74 68 65 72 20 63 6f 6d 70 6c 65 74 65 6c 79  ither completely
1600: 20 65 73 74 61 62 6c 69 73 68 65 64 20 74 68 65   established the
1610: 20 73 65 73 73 69 6f 6e 20 6f 72 20 63 6f 6d 70   session or comp
1620: 6c 65 74 65 6c 79 20 66 61 69 6c 65 64 20 69 74  letely failed it
1630: 20 2d 2d 20 74 68 65 72 65 20 69 73 20 6e 6f 20   -- there is no 
1640: 6d 6f 72 65 20 6e 65 65 64 20 74 6f 20 65 76 65  more need to eve
1650: 72 20 72 65 74 72 79 20 69 74 20 74 68 6f 75 67  r retry it thoug
1660: 68 22 29 3b 0a 09 62 72 65 61 6b 3b 0a 20 20 20  h");..break;.   
1670: 20 7d 0a 0a 20 20 20 20 73 77 69 74 63 68 20 28   }..    switch (
1680: 72 63 29 20 7b 0a 09 63 61 73 65 20 53 53 4c 5f  rc) {..case SSL_
1690: 45 52 52 4f 52 5f 4e 4f 4e 45 3a 0a 09 20 20 20  ERROR_NONE:..   
16a0: 20 2f 2a 20 54 68 65 20 54 4c 53 2f 53 53 4c 20   /* The TLS/SSL 
16b0: 49 2f 4f 20 6f 70 65 72 61 74 69 6f 6e 20 63 6f  I/O operation co
16c0: 6d 70 6c 65 74 65 64 20 2a 2f 0a 09 20 20 20 20  mpleted */..    
16d0: 64 70 72 69 6e 74 66 28 22 54 68 65 20 63 6f 6e  dprintf("The con
16e0: 6e 65 63 74 69 6f 6e 20 69 73 20 67 6f 6f 64 22  nection is good"
16f0: 29 3b 0a 09 20 20 20 20 2a 65 72 72 6f 72 43 6f  );..    *errorCo
1700: 64 65 50 74 72 20 3d 20 30 3b 0a 09 20 20 20 20  dePtr = 0;..    
1710: 62 72 65 61 6b 3b 0a 0a 09 63 61 73 65 20 53 53  break;...case SS
1720: 4c 5f 45 52 52 4f 52 5f 5a 45 52 4f 5f 52 45 54  L_ERROR_ZERO_RET
1730: 55 52 4e 3a 0a 09 20 20 20 20 2f 2a 20 54 68 65  URN:..    /* The
1740: 20 54 4c 53 2f 53 53 4c 20 70 65 65 72 20 68 61   TLS/SSL peer ha
1750: 73 20 63 6c 6f 73 65 64 20 74 68 65 20 63 6f 6e  s closed the con
1760: 6e 65 63 74 69 6f 6e 20 66 6f 72 20 77 72 69 74  nection for writ
1770: 69 6e 67 20 62 79 20 73 65 6e 64 69 6e 67 20 74  ing by sending t
1780: 68 65 20 63 6c 6f 73 65 5f 6e 6f 74 69 66 79 20  he close_notify 
1790: 61 6c 65 72 74 20 2a 2f 0a 09 20 20 20 20 64 70  alert */..    dp
17a0: 72 69 6e 74 66 28 22 53 53 4c 5f 45 52 52 4f 52  rintf("SSL_ERROR
17b0: 5f 5a 45 52 4f 5f 52 45 54 55 52 4e 3a 20 43 6f  _ZERO_RETURN: Co
17c0: 6e 6e 65 63 74 20 72 65 74 75 72 6e 65 64 20 61  nnect returned a
17d0: 6e 20 69 6e 76 61 6c 69 64 20 76 61 6c 75 65 2e  n invalid value.
17e0: 2e 2e 22 29 3b 0a 09 20 20 20 20 2a 65 72 72 6f  ..");..    *erro
17f0: 72 43 6f 64 65 50 74 72 20 3d 20 45 49 4e 56 41  rCodePtr = EINVA
1800: 4c 3b 0a 09 20 20 20 20 54 6c 73 5f 45 72 72 6f  L;..    Tls_Erro
1810: 72 28 73 74 61 74 65 50 74 72 2c 20 22 50 65 65  r(statePtr, "Pee
1820: 72 20 68 61 73 20 63 6c 6f 73 65 64 20 74 68 65  r has closed the
1830: 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 66 6f 72 20   connection for 
1840: 77 72 69 74 69 6e 67 20 62 79 20 73 65 6e 64 69  writing by sendi
1850: 6e 67 20 74 68 65 20 63 6c 6f 73 65 5f 6e 6f 74  ng the close_not
1860: 69 66 79 20 61 6c 65 72 74 22 29 3b 0a 09 20 20  ify alert");..  
1870: 20 20 72 65 74 75 72 6e 28 2d 31 29 3b 0a 0a 09    return(-1);...
1880: 63 61 73 65 20 53 53 4c 5f 45 52 52 4f 52 5f 53  case SSL_ERROR_S
1890: 59 53 43 41 4c 4c 3a 0a 09 20 20 20 20 2f 2a 20  YSCALL:..    /* 
18a0: 53 6f 6d 65 20 6e 6f 6e 2d 72 65 63 6f 76 65 72  Some non-recover
18b0: 61 62 6c 65 2c 20 66 61 74 61 6c 20 49 2f 4f 20  able, fatal I/O 
18c0: 65 72 72 6f 72 20 6f 63 63 75 72 72 65 64 20 2a  error occurred *
18d0: 2f 0a 09 20 20 20 20 64 70 72 69 6e 74 66 28 22  /..    dprintf("
18e0: 53 53 4c 5f 45 52 52 4f 52 5f 53 59 53 43 41 4c  SSL_ERROR_SYSCAL
18f0: 4c 22 29 3b 0a 09 20 20 20 20 69 66 20 28 62 61  L");..    if (ba
1900: 63 6b 69 6e 67 45 72 72 6f 72 20 3d 3d 20 30 20  ckingError == 0 
1910: 26 26 20 65 72 72 20 3d 3d 20 30 29 20 7b 0a 09  && err == 0) {..
1920: 09 64 70 72 69 6e 74 66 28 22 45 4f 46 20 72 65  .dprintf("EOF re
1930: 61 63 68 65 64 22 29 0a 09 09 2a 65 72 72 6f 72  ached")...*error
1940: 43 6f 64 65 50 74 72 20 3d 20 45 43 4f 4e 4e 52  CodePtr = ECONNR
1950: 45 53 45 54 3b 0a 09 09 54 6c 73 5f 45 72 72 6f  ESET;...Tls_Erro
1960: 72 28 73 74 61 74 65 50 74 72 2c 20 22 28 75 6e  r(statePtr, "(un
1970: 65 78 70 65 63 74 65 64 29 20 45 4f 46 20 72 65  expected) EOF re
1980: 61 63 68 65 64 22 29 3b 0a 0a 09 20 20 20 20 7d  ached");...    }
1990: 20 65 6c 73 65 20 69 66 20 28 62 61 63 6b 69 6e   else if (backin
19a0: 67 45 72 72 6f 72 20 3d 3d 20 30 20 26 26 20 65  gError == 0 && e
19b0: 72 72 20 3d 3d 20 2d 31 29 20 7b 0a 09 09 64 70  rr == -1) {...dp
19c0: 72 69 6e 74 66 28 22 49 2f 4f 20 65 72 72 6f 72  rintf("I/O error
19d0: 20 6f 63 63 75 72 72 65 64 20 28 65 72 72 6e 6f   occurred (errno
19e0: 20 3d 20 25 6c 75 29 22 2c 20 28 75 6e 73 69 67   = %lu)", (unsig
19f0: 6e 65 64 20 6c 6f 6e 67 29 20 54 63 6c 5f 47 65  ned long) Tcl_Ge
1a00: 74 45 72 72 6e 6f 28 29 29 3b 0a 09 09 2a 65 72  tErrno());...*er
1a10: 72 6f 72 43 6f 64 65 50 74 72 20 3d 20 54 63 6c  rorCodePtr = Tcl
1a20: 5f 47 65 74 45 72 72 6e 6f 28 29 3b 0a 09 09 69  _GetErrno();...i
1a30: 66 20 28 2a 65 72 72 6f 72 43 6f 64 65 50 74 72  f (*errorCodePtr
1a40: 20 3d 3d 20 45 43 4f 4e 4e 52 45 53 45 54 29 20   == ECONNRESET) 
1a50: 7b 0a 09 09 20 20 20 20 2a 65 72 72 6f 72 43 6f  {...    *errorCo
1a60: 64 65 50 74 72 20 3d 20 45 43 4f 4e 4e 41 42 4f  dePtr = ECONNABO
1a70: 52 54 45 44 3b 0a 09 09 7d 0a 09 09 54 6c 73 5f  RTED;...}...Tls_
1a80: 45 72 72 6f 72 28 73 74 61 74 65 50 74 72 2c 20  Error(statePtr, 
1a90: 28 63 68 61 72 20 2a 29 20 54 63 6c 5f 45 72 72  (char *) Tcl_Err
1aa0: 6e 6f 4d 73 67 28 2a 65 72 72 6f 72 43 6f 64 65  noMsg(*errorCode
1ab0: 50 74 72 29 29 3b 0a 0a 09 20 20 20 20 7d 20 65  Ptr));...    } e
1ac0: 6c 73 65 20 7b 0a 09 09 64 70 72 69 6e 74 66 28  lse {...dprintf(
1ad0: 22 49 2f 4f 20 65 72 72 6f 72 20 6f 63 63 75 72  "I/O error occur
1ae0: 72 65 64 20 28 62 61 63 6b 69 6e 67 45 72 72 6f  red (backingErro
1af0: 72 20 3d 20 25 6c 75 29 22 2c 20 62 61 63 6b 69  r = %lu)", backi
1b00: 6e 67 45 72 72 6f 72 29 3b 0a 09 09 2a 65 72 72  ngError);...*err
1b10: 6f 72 43 6f 64 65 50 74 72 20 3d 20 54 63 6c 5f  orCodePtr = Tcl_
1b20: 47 65 74 45 72 72 6e 6f 28 29 3b 0a 09 09 69 66  GetErrno();...if
1b30: 20 28 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 20   (*errorCodePtr 
1b40: 3d 3d 20 45 43 4f 4e 4e 52 45 53 45 54 29 20 7b  == ECONNRESET) {
1b50: 0a 09 09 20 20 20 20 2a 65 72 72 6f 72 43 6f 64  ...    *errorCod
1b60: 65 50 74 72 20 3d 20 45 43 4f 4e 4e 41 42 4f 52  ePtr = ECONNABOR
1b70: 54 45 44 3b 0a 09 09 7d 0a 09 09 54 6c 73 5f 45  TED;...}...Tls_E
1b80: 72 72 6f 72 28 73 74 61 74 65 50 74 72 2c 20 28  rror(statePtr, (
1b90: 63 68 61 72 20 2a 29 20 45 52 52 5f 72 65 61 73  char *) ERR_reas
1ba0: 6f 6e 5f 65 72 72 6f 72 5f 73 74 72 69 6e 67 28  on_error_string(
1bb0: 62 61 63 6b 69 6e 67 45 72 72 6f 72 29 29 3b 0a  backingError));.
1bc0: 09 20 20 20 20 7d 0a 0a 09 20 20 20 20 73 74 61  .    }...    sta
1bd0: 74 65 50 74 72 2d 3e 66 6c 61 67 73 20 7c 3d 20  tePtr->flags |= 
1be0: 54 4c 53 5f 54 43 4c 5f 48 41 4e 44 53 48 41 4b  TLS_TCL_HANDSHAK
1bf0: 45 5f 46 41 49 4c 45 44 3b 0a 09 20 20 20 20 72  E_FAILED;..    r
1c00: 65 74 75 72 6e 28 2d 31 29 3b 0a 0a 09 63 61 73  eturn(-1);...cas
1c10: 65 20 53 53 4c 5f 45 52 52 4f 52 5f 53 53 4c 3a  e SSL_ERROR_SSL:
1c20: 0a 09 20 20 20 20 2f 2a 20 41 20 6e 6f 6e 2d 72  ..    /* A non-r
1c30: 65 63 6f 76 65 72 61 62 6c 65 2c 20 66 61 74 61  ecoverable, fata
1c40: 6c 20 65 72 72 6f 72 20 69 6e 20 74 68 65 20 53  l error in the S
1c50: 53 4c 20 6c 69 62 72 61 72 79 20 6f 63 63 75 72  SL library occur
1c60: 72 65 64 2c 20 75 73 75 61 6c 6c 79 20 61 20 70  red, usually a p
1c70: 72 6f 74 6f 63 6f 6c 20 65 72 72 6f 72 20 2a 2f  rotocol error */
1c80: 0a 09 20 20 20 20 64 70 72 69 6e 74 66 28 22 53  ..    dprintf("S
1c90: 53 4c 5f 45 52 52 4f 52 5f 53 53 4c 3a 20 47 6f  SL_ERROR_SSL: Go
1ca0: 74 20 70 65 72 6d 61 6e 65 6e 74 20 66 61 74 61  t permanent fata
1cb0: 6c 20 53 53 4c 20 65 72 72 6f 72 2c 20 61 62 6f  l SSL error, abo
1cc0: 72 74 69 6e 67 20 69 6d 6d 65 64 69 61 74 65 6c  rting immediatel
1cd0: 79 22 29 3b 0a 09 20 20 20 20 69 66 20 28 53 53  y");..    if (SS
1ce0: 4c 5f 67 65 74 5f 76 65 72 69 66 79 5f 72 65 73  L_get_verify_res
1cf0: 75 6c 74 28 73 74 61 74 65 50 74 72 2d 3e 73 73  ult(statePtr->ss
1d00: 6c 29 20 21 3d 20 58 35 30 39 5f 56 5f 4f 4b 29  l) != X509_V_OK)
1d10: 20 7b 0a 09 09 54 6c 73 5f 45 72 72 6f 72 28 73   {...Tls_Error(s
1d20: 74 61 74 65 50 74 72 2c 20 28 63 68 61 72 20 2a  tatePtr, (char *
1d30: 29 20 58 35 30 39 5f 76 65 72 69 66 79 5f 63 65  ) X509_verify_ce
1d40: 72 74 5f 65 72 72 6f 72 5f 73 74 72 69 6e 67 28  rt_error_string(
1d50: 53 53 4c 5f 67 65 74 5f 76 65 72 69 66 79 5f 72  SSL_get_verify_r
1d60: 65 73 75 6c 74 28 73 74 61 74 65 50 74 72 2d 3e  esult(statePtr->
1d70: 73 73 6c 29 29 29 3b 0a 09 20 20 20 20 7d 0a 09  ssl)));..    }..
1d80: 20 20 20 20 69 66 20 28 62 61 63 6b 69 6e 67 45      if (backingE
1d90: 72 72 6f 72 20 21 3d 20 30 29 20 7b 0a 09 09 54  rror != 0) {...T
1da0: 6c 73 5f 45 72 72 6f 72 28 73 74 61 74 65 50 74  ls_Error(statePt
1db0: 72 2c 20 28 63 68 61 72 20 2a 29 20 45 52 52 5f  r, (char *) ERR_
1dc0: 72 65 61 73 6f 6e 5f 65 72 72 6f 72 5f 73 74 72  reason_error_str
1dd0: 69 6e 67 28 62 61 63 6b 69 6e 67 45 72 72 6f 72  ing(backingError
1de0: 29 29 3b 0a 09 20 20 20 20 7d 0a 09 20 20 20 20  ));..    }..    
1df0: 73 74 61 74 65 50 74 72 2d 3e 66 6c 61 67 73 20  statePtr->flags 
1e00: 7c 3d 20 54 4c 53 5f 54 43 4c 5f 48 41 4e 44 53  |= TLS_TCL_HANDS
1e10: 48 41 4b 45 5f 46 41 49 4c 45 44 3b 0a 09 20 20  HAKE_FAILED;..  
1e20: 20 20 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 20    *errorCodePtr 
1e30: 3d 20 45 43 4f 4e 4e 41 42 4f 52 54 45 44 3b 0a  = ECONNABORTED;.
1e40: 09 20 20 20 20 72 65 74 75 72 6e 28 2d 31 29 3b  .    return(-1);
1e50: 0a 0a 09 63 61 73 65 20 53 53 4c 5f 45 52 52 4f  ...case SSL_ERRO
1e60: 52 5f 57 41 4e 54 5f 52 45 41 44 3a 0a 09 63 61  R_WANT_READ:..ca
1e70: 73 65 20 53 53 4c 5f 45 52 52 4f 52 5f 57 41 4e  se SSL_ERROR_WAN
1e80: 54 5f 57 52 49 54 45 3a 0a 09 63 61 73 65 20 53  T_WRITE:..case S
1e90: 53 4c 5f 45 52 52 4f 52 5f 57 41 4e 54 5f 58 35  SL_ERROR_WANT_X5
1ea0: 30 39 5f 4c 4f 4f 4b 55 50 3a 0a 09 63 61 73 65  09_LOOKUP:..case
1eb0: 20 53 53 4c 5f 45 52 52 4f 52 5f 57 41 4e 54 5f   SSL_ERROR_WANT_
1ec0: 43 4f 4e 4e 45 43 54 3a 0a 09 63 61 73 65 20 53  CONNECT:..case S
1ed0: 53 4c 5f 45 52 52 4f 52 5f 57 41 4e 54 5f 41 43  SL_ERROR_WANT_AC
1ee0: 43 45 50 54 3a 0a 09 63 61 73 65 20 53 53 4c 5f  CEPT:..case SSL_
1ef0: 45 52 52 4f 52 5f 57 41 4e 54 5f 41 53 59 4e 43  ERROR_WANT_ASYNC
1f00: 3a 0a 09 63 61 73 65 20 53 53 4c 5f 45 52 52 4f  :..case SSL_ERRO
1f10: 52 5f 57 41 4e 54 5f 41 53 59 4e 43 5f 4a 4f 42  R_WANT_ASYNC_JOB
1f20: 3a 0a 09 63 61 73 65 20 53 53 4c 5f 45 52 52 4f  :..case SSL_ERRO
1f30: 52 5f 57 41 4e 54 5f 43 4c 49 45 4e 54 5f 48 45  R_WANT_CLIENT_HE
1f40: 4c 4c 4f 5f 43 42 3a 0a 09 64 65 66 61 75 6c 74  LLO_CB:..default
1f50: 3a 0a 09 20 20 20 20 2f 2a 20 54 68 65 20 6f 70  :..    /* The op
1f60: 65 72 61 74 69 6f 6e 20 64 69 64 20 6e 6f 74 20  eration did not 
1f70: 63 6f 6d 70 6c 65 74 65 20 61 6e 64 20 73 68 6f  complete and sho
1f80: 75 6c 64 20 62 65 20 72 65 74 72 69 65 64 20 6c  uld be retried l
1f90: 61 74 65 72 2e 20 2a 2f 0a 09 20 20 20 20 64 70  ater. */..    dp
1fa0: 72 69 6e 74 66 28 22 4f 70 65 72 61 74 69 6f 6e  rintf("Operation
1fb0: 20 64 69 64 20 6e 6f 74 20 63 6f 6d 70 6c 65 74   did not complet
1fc0: 65 2c 20 63 61 6c 6c 20 66 75 6e 63 74 69 6f 6e  e, call function
1fd0: 20 61 67 61 69 6e 20 6c 61 74 65 72 3a 20 25 69   again later: %i
1fe0: 22 2c 20 72 63 29 3b 0a 09 20 20 20 20 2a 65 72  ", rc);..    *er
1ff0: 72 6f 72 43 6f 64 65 50 74 72 20 3d 20 45 41 47  rorCodePtr = EAG
2000: 41 49 4e 3b 0a 09 20 20 20 20 64 70 72 69 6e 74  AIN;..    dprint
2010: 66 28 22 45 52 52 28 25 64 2c 20 25 64 29 20 22  f("ERR(%d, %d) "
2020: 2c 20 72 63 2c 20 2a 65 72 72 6f 72 43 6f 64 65  , rc, *errorCode
2030: 50 74 72 29 3b 0a 09 20 20 20 20 54 6c 73 5f 45  Ptr);..    Tls_E
2040: 72 72 6f 72 28 73 74 61 74 65 50 74 72 2c 20 22  rror(statePtr, "
2050: 4f 70 65 72 61 74 69 6f 6e 20 64 69 64 20 6e 6f  Operation did no
2060: 74 20 63 6f 6d 70 6c 65 74 65 2c 20 63 61 6c 6c  t complete, call
2070: 20 66 75 6e 63 74 69 6f 6e 20 61 67 61 69 6e 20   function again 
2080: 6c 61 74 65 72 22 29 3b 0a 09 20 20 20 20 72 65  later");..    re
2090: 74 75 72 6e 28 2d 31 29 3b 0a 20 20 20 20 7d 0a  turn(-1);.    }.
20a0: 0a 20 20 20 20 64 70 72 69 6e 74 66 28 22 52 65  .    dprintf("Re
20b0: 6d 6f 76 69 6e 67 20 74 68 65 20 5c 22 54 4c 53  moving the \"TLS
20c0: 5f 54 43 4c 5f 49 4e 49 54 5c 22 20 66 6c 61 67  _TCL_INIT\" flag
20d0: 20 73 69 6e 63 65 20 77 65 20 68 61 76 65 20 63   since we have c
20e0: 6f 6d 70 6c 65 74 65 64 20 74 68 65 20 68 61 6e  ompleted the han
20f0: 64 73 68 61 6b 65 22 29 3b 0a 20 20 20 20 73 74  dshake");.    st
2100: 61 74 65 50 74 72 2d 3e 66 6c 61 67 73 20 26 3d  atePtr->flags &=
2110: 20 7e 54 4c 53 5f 54 43 4c 5f 49 4e 49 54 3b 0a   ~TLS_TCL_INIT;.
2120: 0a 20 20 20 20 64 70 72 69 6e 74 66 28 22 52 65  .    dprintf("Re
2130: 74 75 72 6e 69 6e 67 20 69 6e 20 73 75 63 63 65  turning in succe
2140: 73 73 22 29 3b 0a 20 20 20 20 2a 65 72 72 6f 72  ss");.    *error
2150: 43 6f 64 65 50 74 72 20 3d 20 30 3b 0a 20 20 20  CodePtr = 0;.   
2160: 20 72 65 74 75 72 6e 28 30 29 3b 0a 7d 0a 0a 2f   return(0);.}../
2170: 2a 0a 20 2a 2d 2d 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 0a 20 2a 0a 20 2a 20 54 6c  -------. *. * Tl
21c0: 73 49 6e 70 75 74 50 72 6f 63 20 2d 2d 0a 20 2a  sInputProc --. *
21d0: 0a 20 2a 20 20 20 20 54 68 69 73 20 70 72 6f 63  . *    This proc
21e0: 65 64 75 72 65 20 69 73 20 69 6e 76 6f 6b 65 64  edure is invoked
21f0: 20 62 79 20 74 68 65 20 67 65 6e 65 72 69 63 20   by the generic 
2200: 49 4f 20 6c 65 76 65 6c 0a 20 2a 20 20 20 20 20  IO level. *     
2210: 20 20 74 6f 20 72 65 61 64 20 69 6e 70 75 74 20    to read input 
2220: 66 72 6f 6d 20 61 20 53 53 4c 20 73 6f 63 6b 65  from a SSL socke
2230: 74 20 62 61 73 65 64 20 63 68 61 6e 6e 65 6c 2e  t based channel.
2240: 0a 20 2a 0a 20 2a 20 52 65 73 75 6c 74 73 3a 0a  . *. * Results:.
2250: 20 2a 20 20 20 20 52 65 74 75 72 6e 73 20 74 68   *    Returns th
2260: 65 20 6e 75 6d 62 65 72 20 6f 66 20 62 79 74 65  e number of byte
2270: 73 20 72 65 61 64 20 6f 72 20 2d 31 20 6f 6e 20  s read or -1 on 
2280: 65 72 72 6f 72 2e 20 53 65 74 73 20 65 72 72 6f  error. Sets erro
2290: 72 43 6f 64 65 50 74 72 0a 20 2a 20 20 20 20 74  rCodePtr. *    t
22a0: 6f 20 61 20 50 4f 53 49 58 20 65 72 72 6f 72 20  o a POSIX error 
22b0: 63 6f 64 65 20 69 66 20 61 6e 20 65 72 72 6f 72  code if an error
22c0: 20 6f 63 63 75 72 72 65 64 2c 20 6f 72 20 30 20   occurred, or 0 
22d0: 69 66 20 6e 6f 6e 65 2e 0a 20 2a 0a 20 2a 20 53  if none.. *. * S
22e0: 69 64 65 20 65 66 66 65 63 74 73 3a 0a 20 2a 20  ide effects:. * 
22f0: 20 20 20 52 65 61 64 73 20 69 6e 70 75 74 20 66     Reads input f
2300: 72 6f 6d 20 74 68 65 20 69 6e 70 75 74 20 64 65  rom the input de
2310: 76 69 63 65 20 6f 66 20 74 68 65 20 63 68 61 6e  vice of the chan
2320: 6e 65 6c 2e 0a 20 2a 0a 20 2a 2d 2d 2d 2d 2d 2d  nel.. *. *------
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 0a 20 2a  -------------. *
2370: 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 54 6c 73  /.static int Tls
2380: 49 6e 70 75 74 50 72 6f 63 28 43 6c 69 65 6e 74  InputProc(Client
2390: 44 61 74 61 20 69 6e 73 74 61 6e 63 65 44 61 74  Data instanceDat
23a0: 61 2c 20 63 68 61 72 20 2a 62 75 66 2c 20 69 6e  a, char *buf, in
23b0: 74 20 62 75 66 53 69 7a 65 2c 20 69 6e 74 20 2a  t bufSize, int *
23c0: 65 72 72 6f 72 43 6f 64 65 50 74 72 29 20 7b 0a  errorCodePtr) {.
23d0: 20 20 20 20 75 6e 73 69 67 6e 65 64 20 6c 6f 6e      unsigned lon
23e0: 67 20 62 61 63 6b 69 6e 67 45 72 72 6f 72 3b 0a  g backingError;.
23f0: 20 20 20 20 53 74 61 74 65 20 2a 73 74 61 74 65      State *state
2400: 50 74 72 20 3d 20 28 53 74 61 74 65 20 2a 29 20  Ptr = (State *) 
2410: 69 6e 73 74 61 6e 63 65 44 61 74 61 3b 0a 20 20  instanceData;.  
2420: 20 20 69 6e 74 20 62 79 74 65 73 52 65 61 64 3b    int bytesRead;
2430: 0a 20 20 20 20 69 6e 74 20 74 6c 73 43 6f 6e 6e  .    int tlsConn
2440: 65 63 74 3b 0a 20 20 20 20 69 6e 74 20 65 72 72  ect;.    int err
2450: 3b 0a 0a 20 20 20 20 2a 65 72 72 6f 72 43 6f 64  ;..    *errorCod
2460: 65 50 74 72 20 3d 20 30 3b 0a 0a 20 20 20 20 64  ePtr = 0;..    d
2470: 70 72 69 6e 74 66 28 22 42 49 4f 5f 72 65 61 64  printf("BIO_read
2480: 28 25 64 29 22 2c 20 62 75 66 53 69 7a 65 29 3b  (%d)", bufSize);
2490: 0a 0a 20 20 20 20 69 66 20 28 73 74 61 74 65 50  ..    if (stateP
24a0: 74 72 2d 3e 66 6c 61 67 73 20 26 20 54 4c 53 5f  tr->flags & TLS_
24b0: 54 43 4c 5f 43 41 4c 4c 42 41 43 4b 29 20 7b 0a  TCL_CALLBACK) {.
24c0: 09 2f 2a 20 64 6f 6e 27 74 20 70 72 6f 63 65 73  ./* don't proces
24d0: 73 20 61 6e 79 20 62 79 74 65 73 20 77 68 69 6c  s any bytes whil
24e0: 65 20 76 65 72 69 66 79 20 63 61 6c 6c 62 61 63  e verify callbac
24f0: 6b 20 69 73 20 72 75 6e 6e 69 6e 67 20 2a 2f 0a  k is running */.
2500: 09 64 70 72 69 6e 74 66 28 22 43 61 6c 6c 62 61  .dprintf("Callba
2510: 63 6b 20 69 73 20 72 75 6e 6e 69 6e 67 2c 20 72  ck is running, r
2520: 65 61 64 69 6e 67 20 30 20 62 79 74 65 73 22 29  eading 0 bytes")
2530: 3b 0a 09 72 65 74 75 72 6e 28 30 29 3b 0a 20 20  ;..return(0);.  
2540: 20 20 7d 0a 0a 20 20 20 20 64 70 72 69 6e 74 66    }..    dprintf
2550: 28 22 43 61 6c 6c 69 6e 67 20 54 6c 73 5f 57 61  ("Calling Tls_Wa
2560: 69 74 46 6f 72 43 6f 6e 6e 65 63 74 22 29 3b 0a  itForConnect");.
2570: 20 20 20 20 74 6c 73 43 6f 6e 6e 65 63 74 20 3d      tlsConnect =
2580: 20 54 6c 73 5f 57 61 69 74 46 6f 72 43 6f 6e 6e   Tls_WaitForConn
2590: 65 63 74 28 73 74 61 74 65 50 74 72 2c 20 65 72  ect(statePtr, er
25a0: 72 6f 72 43 6f 64 65 50 74 72 2c 20 30 29 3b 0a  rorCodePtr, 0);.
25b0: 20 20 20 20 69 66 20 28 74 6c 73 43 6f 6e 6e 65      if (tlsConne
25c0: 63 74 20 3c 20 30 29 20 7b 0a 09 64 70 72 69 6e  ct < 0) {..dprin
25d0: 74 66 28 22 47 6f 74 20 61 6e 20 65 72 72 6f 72  tf("Got an error
25e0: 20 77 61 69 74 69 6e 67 20 74 6f 20 63 6f 6e 6e   waiting to conn
25f0: 65 63 74 20 28 74 6c 73 43 6f 6e 6e 65 63 74 20  ect (tlsConnect 
2600: 3d 20 25 69 2c 20 2a 65 72 72 6f 72 43 6f 64 65  = %i, *errorCode
2610: 50 74 72 20 3d 20 25 69 29 22 2c 20 74 6c 73 43  Ptr = %i)", tlsC
2620: 6f 6e 6e 65 63 74 2c 20 2a 65 72 72 6f 72 43 6f  onnect, *errorCo
2630: 64 65 50 74 72 29 3b 0a 09 54 6c 73 5f 45 72 72  dePtr);..Tls_Err
2640: 6f 72 28 73 74 61 74 65 50 74 72 2c 20 73 74 72  or(statePtr, str
2650: 65 72 72 6f 72 28 2a 65 72 72 6f 72 43 6f 64 65  error(*errorCode
2660: 50 74 72 29 29 3b 0a 0a 09 62 79 74 65 73 52 65  Ptr));...bytesRe
2670: 61 64 20 3d 20 2d 31 3b 0a 09 69 66 20 28 2a 65  ad = -1;..if (*e
2680: 72 72 6f 72 43 6f 64 65 50 74 72 20 3d 3d 20 45  rrorCodePtr == E
2690: 43 4f 4e 4e 52 45 53 45 54 29 20 7b 0a 09 20 20  CONNRESET) {..  
26a0: 20 20 64 70 72 69 6e 74 66 28 22 47 6f 74 20 63    dprintf("Got c
26b0: 6f 6e 6e 65 63 74 69 6f 6e 20 72 65 73 65 74 22  onnection reset"
26c0: 29 3b 0a 09 20 20 20 20 2f 2a 20 53 6f 66 74 20  );..    /* Soft 
26d0: 45 4f 46 20 2a 2f 0a 09 20 20 20 20 2a 65 72 72  EOF */..    *err
26e0: 6f 72 43 6f 64 65 50 74 72 20 3d 20 30 3b 0a 09  orCodePtr = 0;..
26f0: 20 20 20 20 62 79 74 65 73 52 65 61 64 20 3d 20      bytesRead = 
2700: 30 3b 0a 09 7d 0a 09 72 65 74 75 72 6e 28 62 79  0;..}..return(by
2710: 74 65 73 52 65 61 64 29 3b 0a 20 20 20 20 7d 0a  tesRead);.    }.
2720: 0a 20 20 20 20 2f 2a 0a 20 20 20 20 20 2a 20 57  .    /*.     * W
2730: 65 20 6e 65 65 64 20 74 6f 20 63 6c 65 61 72 20  e need to clear 
2740: 74 68 65 20 53 53 4c 20 65 72 72 6f 72 20 73 74  the SSL error st
2750: 61 63 6b 20 6e 6f 77 20 62 65 63 61 75 73 65 20  ack now because 
2760: 77 65 20 73 6f 6d 65 74 69 6d 65 73 20 72 65 61  we sometimes rea
2770: 63 68 0a 20 20 20 20 20 2a 20 74 68 69 73 20 66  ch.     * this f
2780: 75 6e 63 74 69 6f 6e 20 77 69 74 68 20 6c 65 66  unction with lef
2790: 74 6f 76 65 72 20 65 72 72 6f 72 73 20 69 6e 20  tover errors in 
27a0: 74 68 65 20 73 74 61 63 6b 2e 20 20 49 66 20 42  the stack.  If B
27b0: 49 4f 5f 72 65 61 64 0a 20 20 20 20 20 2a 20 72  IO_read.     * r
27c0: 65 74 75 72 6e 73 20 2d 31 20 61 6e 64 20 69 6e  eturns -1 and in
27d0: 74 65 6e 64 73 20 45 41 47 41 49 4e 2c 20 74 68  tends EAGAIN, th
27e0: 65 72 65 20 69 73 20 61 20 6c 65 66 74 6f 76 65  ere is a leftove
27f0: 72 20 65 72 72 6f 72 2c 20 69 74 20 77 69 6c 6c  r error, it will
2800: 20 62 65 0a 20 20 20 20 20 2a 20 6d 69 73 63 6f   be.     * misco
2810: 6e 73 74 72 75 65 64 20 61 73 20 61 6e 20 65 72  nstrued as an er
2820: 72 6f 72 2c 20 6e 6f 74 20 45 41 47 41 49 4e 2e  ror, not EAGAIN.
2830: 0a 20 20 20 20 20 2a 0a 20 20 20 20 20 2a 20 41  .     *.     * A
2840: 6c 74 65 72 6e 61 74 69 76 65 6c 79 2c 20 77 65  lternatively, we
2850: 20 6d 61 79 20 77 61 6e 74 20 74 6f 20 68 61 6e   may want to han
2860: 64 6c 65 20 74 68 65 20 3c 30 20 72 65 74 75 72  dle the <0 retur
2870: 6e 20 63 6f 64 65 73 20 66 72 6f 6d 0a 20 20 20  n codes from.   
2880: 20 20 2a 20 42 49 4f 5f 72 65 61 64 20 73 70 65    * BIO_read spe
2890: 63 69 61 6c 6c 79 20 28 61 73 20 61 64 76 69 73  cially (as advis
28a0: 65 64 20 69 6e 20 74 68 65 20 52 53 41 20 64 6f  ed in the RSA do
28b0: 63 73 29 2e 20 20 54 4c 53 27 73 20 6c 6f 77 65  cs).  TLS's lowe
28c0: 72 20 6c 65 76 65 6c 20 42 49 4f 0a 20 20 20 20  r level BIO.    
28d0: 20 2a 20 66 75 6e 63 74 69 6f 6e 73 20 70 6c 61   * functions pla
28e0: 79 20 77 69 74 68 20 74 68 65 20 72 65 74 72 79  y with the retry
28f0: 20 66 6c 61 67 73 20 74 68 6f 75 67 68 2c 20 61   flags though, a
2900: 6e 64 20 74 68 69 73 20 73 65 65 6d 73 20 74 6f  nd this seems to
2910: 20 77 6f 72 6b 0a 20 20 20 20 20 2a 20 63 6f 72   work.     * cor
2920: 72 65 63 74 6c 79 2e 20 20 53 69 6d 69 6c 61 72  rectly.  Similar
2930: 20 66 69 78 20 69 6e 20 54 6c 73 4f 75 74 70 75   fix in TlsOutpu
2940: 74 50 72 6f 63 2e 20 2d 20 68 6f 62 62 73 0a 20  tProc. - hobbs. 
2950: 20 20 20 20 2a 2f 0a 20 20 20 20 45 52 52 5f 63      */.    ERR_c
2960: 6c 65 61 72 5f 65 72 72 6f 72 28 29 3b 0a 20 20  lear_error();.  
2970: 20 20 62 79 74 65 73 52 65 61 64 20 3d 20 42 49    bytesRead = BI
2980: 4f 5f 72 65 61 64 28 73 74 61 74 65 50 74 72 2d  O_read(statePtr-
2990: 3e 62 69 6f 2c 20 62 75 66 2c 20 62 75 66 53 69  >bio, buf, bufSi
29a0: 7a 65 29 3b 0a 20 20 20 20 64 70 72 69 6e 74 66  ze);.    dprintf
29b0: 28 22 42 49 4f 5f 72 65 61 64 20 2d 3e 20 25 64  ("BIO_read -> %d
29c0: 22 2c 20 62 79 74 65 73 52 65 61 64 29 3b 0a 0a  ", bytesRead);..
29d0: 20 20 20 20 65 72 72 20 3d 20 53 53 4c 5f 67 65      err = SSL_ge
29e0: 74 5f 65 72 72 6f 72 28 73 74 61 74 65 50 74 72  t_error(statePtr
29f0: 2d 3e 73 73 6c 2c 20 62 79 74 65 73 52 65 61 64  ->ssl, bytesRead
2a00: 29 3b 0a 20 20 20 20 62 61 63 6b 69 6e 67 45 72  );.    backingEr
2a10: 72 6f 72 20 3d 20 45 52 52 5f 67 65 74 5f 65 72  ror = ERR_get_er
2a20: 72 6f 72 28 29 3b 0a 0a 23 69 66 20 30 0a 20 20  ror();..#if 0.  
2a30: 20 20 69 66 20 28 62 79 74 65 73 52 65 61 64 20    if (bytesRead 
2a40: 3c 3d 20 30 29 20 7b 0a 09 69 66 20 28 42 49 4f  <= 0) {..if (BIO
2a50: 5f 73 68 6f 75 6c 64 5f 72 65 74 72 79 28 73 74  _should_retry(st
2a60: 61 74 65 50 74 72 2d 3e 62 69 6f 29 29 20 7b 0a  atePtr->bio)) {.
2a70: 09 20 20 20 20 64 70 72 69 6e 74 66 28 22 49 2f  .    dprintf("I/
2a80: 4f 20 66 61 69 6c 65 64 2c 20 77 69 6c 6c 20 72  O failed, will r
2a90: 65 74 72 79 20 62 61 73 65 64 20 6f 6e 20 45 41  etry based on EA
2aa0: 47 41 49 4e 22 29 3b 0a 09 20 20 20 20 2a 65 72  GAIN");..    *er
2ab0: 72 6f 72 43 6f 64 65 50 74 72 20 3d 20 45 41 47  rorCodePtr = EAG
2ac0: 41 49 4e 3b 0a 09 7d 0a 20 20 20 20 7d 0a 23 65  AIN;..}.    }.#e
2ad0: 6e 64 69 66 0a 0a 20 20 20 20 73 77 69 74 63 68  ndif..    switch
2ae0: 20 28 65 72 72 29 20 7b 0a 09 63 61 73 65 20 53   (err) {..case S
2af0: 53 4c 5f 45 52 52 4f 52 5f 4e 4f 4e 45 3a 0a 09  SL_ERROR_NONE:..
2b00: 20 20 20 20 64 70 72 69 6e 74 42 75 66 66 65 72      dprintBuffer
2b10: 28 62 75 66 2c 20 62 79 74 65 73 52 65 61 64 29  (buf, bytesRead)
2b20: 3b 0a 09 20 20 20 20 62 72 65 61 6b 3b 0a 0a 09  ;..    break;...
2b30: 63 61 73 65 20 53 53 4c 5f 45 52 52 4f 52 5f 53  case SSL_ERROR_S
2b40: 53 4c 3a 0a 09 20 20 20 20 2f 2a 20 41 20 6e 6f  SL:..    /* A no
2b50: 6e 2d 72 65 63 6f 76 65 72 61 62 6c 65 2c 20 66  n-recoverable, f
2b60: 61 74 61 6c 20 65 72 72 6f 72 20 69 6e 20 74 68  atal error in th
2b70: 65 20 53 53 4c 20 6c 69 62 72 61 72 79 20 6f 63  e SSL library oc
2b80: 63 75 72 72 65 64 2c 20 75 73 75 61 6c 6c 79 20  curred, usually 
2b90: 61 20 70 72 6f 74 6f 63 6f 6c 20 65 72 72 6f 72  a protocol error
2ba0: 20 2a 2f 0a 09 20 20 20 20 64 70 72 69 6e 74 66   */..    dprintf
2bb0: 28 22 53 53 4c 20 65 72 72 6f 72 2c 20 69 6e 64  ("SSL error, ind
2bc0: 69 63 61 74 69 6e 67 20 74 68 61 74 20 74 68 65  icating that the
2bd0: 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 68 61 73 20   connection has 
2be0: 62 65 65 6e 20 61 62 6f 72 74 65 64 22 29 3b 0a  been aborted");.
2bf0: 09 20 20 20 20 69 66 20 28 62 61 63 6b 69 6e 67  .    if (backing
2c00: 45 72 72 6f 72 20 21 3d 20 30 29 20 7b 0a 09 09  Error != 0) {...
2c10: 54 6c 73 5f 45 72 72 6f 72 28 73 74 61 74 65 50  Tls_Error(stateP
2c20: 74 72 2c 20 28 63 68 61 72 20 2a 29 20 45 52 52  tr, (char *) ERR
2c30: 5f 72 65 61 73 6f 6e 5f 65 72 72 6f 72 5f 73 74  _reason_error_st
2c40: 72 69 6e 67 28 62 61 63 6b 69 6e 67 45 72 72 6f  ring(backingErro
2c50: 72 29 29 3b 0a 09 20 20 20 20 7d 20 65 6c 73 65  r));..    } else
2c60: 20 69 66 20 28 53 53 4c 5f 67 65 74 5f 76 65 72   if (SSL_get_ver
2c70: 69 66 79 5f 72 65 73 75 6c 74 28 73 74 61 74 65  ify_result(state
2c80: 50 74 72 2d 3e 73 73 6c 29 20 21 3d 20 58 35 30  Ptr->ssl) != X50
2c90: 39 5f 56 5f 4f 4b 29 20 7b 0a 09 09 54 6c 73 5f  9_V_OK) {...Tls_
2ca0: 45 72 72 6f 72 28 73 74 61 74 65 50 74 72 2c 20  Error(statePtr, 
2cb0: 28 63 68 61 72 20 2a 29 20 58 35 30 39 5f 76 65  (char *) X509_ve
2cc0: 72 69 66 79 5f 63 65 72 74 5f 65 72 72 6f 72 5f  rify_cert_error_
2cd0: 73 74 72 69 6e 67 28 53 53 4c 5f 67 65 74 5f 76  string(SSL_get_v
2ce0: 65 72 69 66 79 5f 72 65 73 75 6c 74 28 73 74 61  erify_result(sta
2cf0: 74 65 50 74 72 2d 3e 73 73 6c 29 29 29 3b 0a 09  tePtr->ssl)));..
2d00: 20 20 20 20 7d 20 65 6c 73 65 20 7b 0a 09 09 54      } else {...T
2d10: 6c 73 5f 45 72 72 6f 72 28 73 74 61 74 65 50 74  ls_Error(statePt
2d20: 72 2c 20 22 55 6e 6b 6e 6f 77 6e 20 53 53 4c 20  r, "Unknown SSL 
2d30: 65 72 72 6f 72 22 29 3b 0a 09 20 20 20 20 7d 0a  error");..    }.
2d40: 09 20 20 20 20 2a 65 72 72 6f 72 43 6f 64 65 50  .    *errorCodeP
2d50: 74 72 20 3d 20 45 43 4f 4e 4e 41 42 4f 52 54 45  tr = ECONNABORTE
2d60: 44 3b 0a 09 20 20 20 20 62 79 74 65 73 52 65 61  D;..    bytesRea
2d70: 64 20 3d 20 2d 31 3b 0a 0a 23 69 66 20 4f 50 45  d = -1;..#if OPE
2d80: 4e 53 53 4c 5f 56 45 52 53 49 4f 4e 5f 4e 55 4d  NSSL_VERSION_NUM
2d90: 42 45 52 20 3e 3d 20 30 78 33 30 30 30 30 30 30  BER >= 0x3000000
2da0: 30 4c 0a 09 20 20 20 20 2f 2a 20 55 6e 65 78 70  0L..    /* Unexp
2db0: 65 63 74 65 64 20 45 4f 46 20 66 72 6f 6d 20 74  ected EOF from t
2dc0: 68 65 20 70 65 65 72 20 66 6f 72 20 4f 70 65 6e  he peer for Open
2dd0: 53 53 4c 20 33 2e 30 2b 20 2a 2f 0a 09 20 20 20  SSL 3.0+ */..   
2de0: 20 69 66 20 28 45 52 52 5f 47 45 54 5f 52 45 41   if (ERR_GET_REA
2df0: 53 4f 4e 28 62 61 63 6b 69 6e 67 45 72 72 6f 72  SON(backingError
2e00: 29 20 3d 3d 20 53 53 4c 5f 52 5f 55 4e 45 58 50  ) == SSL_R_UNEXP
2e10: 45 43 54 45 44 5f 45 4f 46 5f 57 48 49 4c 45 5f  ECTED_EOF_WHILE_
2e20: 52 45 41 44 49 4e 47 29 20 7b 0a 09 09 64 70 72  READING) {...dpr
2e30: 69 6e 74 66 28 22 28 55 6e 65 78 70 65 63 74 65  intf("(Unexpecte
2e40: 64 29 20 45 4f 46 20 72 65 61 63 68 65 64 22 29  d) EOF reached")
2e50: 0a 09 09 2a 65 72 72 6f 72 43 6f 64 65 50 74 72  ...*errorCodePtr
2e60: 20 3d 20 30 3b 0a 09 09 62 79 74 65 73 52 65 61   = 0;...bytesRea
2e70: 64 20 3d 20 30 3b 0a 09 09 54 6c 73 5f 45 72 72  d = 0;...Tls_Err
2e80: 6f 72 28 73 74 61 74 65 50 74 72 2c 20 22 45 4f  or(statePtr, "EO
2e90: 46 20 72 65 61 63 68 65 64 22 29 3b 0a 09 20 20  F reached");..  
2ea0: 20 20 7d 20 20 20 20 0a 23 65 6e 64 69 66 0a 09    }    .#endif..
2eb0: 20 20 20 20 62 72 65 61 6b 3b 0a 0a 09 63 61 73      break;...cas
2ec0: 65 20 53 53 4c 5f 45 52 52 4f 52 5f 53 59 53 43  e SSL_ERROR_SYSC
2ed0: 41 4c 4c 3a 0a 09 20 20 20 20 2f 2a 20 53 6f 6d  ALL:..    /* Som
2ee0: 65 20 6e 6f 6e 2d 72 65 63 6f 76 65 72 61 62 6c  e non-recoverabl
2ef0: 65 2c 20 66 61 74 61 6c 20 49 2f 4f 20 65 72 72  e, fatal I/O err
2f00: 6f 72 20 6f 63 63 75 72 72 65 64 20 2a 2f 0a 09  or occurred */..
2f10: 20 20 20 20 69 66 20 28 62 61 63 6b 69 6e 67 45      if (backingE
2f20: 72 72 6f 72 20 3d 3d 20 30 20 26 26 20 62 79 74  rror == 0 && byt
2f30: 65 73 52 65 61 64 20 3d 3d 20 30 29 20 7b 0a 09  esRead == 0) {..
2f40: 09 2f 2a 20 55 6e 65 78 70 65 63 74 65 64 20 45  ./* Unexpected E
2f50: 4f 46 20 66 72 6f 6d 20 74 68 65 20 70 65 65 72  OF from the peer
2f60: 20 66 6f 72 20 4f 70 65 6e 53 53 4c 20 31 2e 31   for OpenSSL 1.1
2f70: 20 2a 2f 0a 09 09 64 70 72 69 6e 74 66 28 22 28   */...dprintf("(
2f80: 55 6e 65 78 70 65 63 74 65 64 29 20 45 4f 46 20  Unexpected) EOF 
2f90: 72 65 61 63 68 65 64 22 29 0a 09 09 2a 65 72 72  reached")...*err
2fa0: 6f 72 43 6f 64 65 50 74 72 20 3d 20 30 3b 0a 09  orCodePtr = 0;..
2fb0: 09 62 79 74 65 73 52 65 61 64 20 3d 20 30 3b 0a  .bytesRead = 0;.
2fc0: 09 09 54 6c 73 5f 45 72 72 6f 72 28 73 74 61 74  ..Tls_Error(stat
2fd0: 65 50 74 72 2c 20 22 45 4f 46 20 72 65 61 63 68  ePtr, "EOF reach
2fe0: 65 64 22 29 3b 0a 0a 09 20 20 20 20 7d 20 65 6c  ed");...    } el
2ff0: 73 65 20 69 66 20 28 62 61 63 6b 69 6e 67 45 72  se if (backingEr
3000: 72 6f 72 20 3d 3d 20 30 20 26 26 20 62 79 74 65  ror == 0 && byte
3010: 73 52 65 61 64 20 3d 3d 20 2d 31 29 20 7b 0a 09  sRead == -1) {..
3020: 09 64 70 72 69 6e 74 66 28 22 49 2f 4f 20 65 72  .dprintf("I/O er
3030: 72 6f 72 20 6f 63 63 75 72 72 65 64 20 28 65 72  ror occurred (er
3040: 72 6e 6f 20 3d 20 25 6c 75 29 22 2c 20 28 75 6e  rno = %lu)", (un
3050: 73 69 67 6e 65 64 20 6c 6f 6e 67 29 20 54 63 6c  signed long) Tcl
3060: 5f 47 65 74 45 72 72 6e 6f 28 29 29 3b 0a 09 09  _GetErrno());...
3070: 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 20 3d 20  *errorCodePtr = 
3080: 54 63 6c 5f 47 65 74 45 72 72 6e 6f 28 29 3b 0a  Tcl_GetErrno();.
3090: 09 09 62 79 74 65 73 52 65 61 64 20 3d 20 2d 31  ..bytesRead = -1
30a0: 3b 0a 09 09 54 6c 73 5f 45 72 72 6f 72 28 73 74  ;...Tls_Error(st
30b0: 61 74 65 50 74 72 2c 20 28 63 68 61 72 20 2a 29  atePtr, (char *)
30c0: 20 54 63 6c 5f 45 72 72 6e 6f 4d 73 67 28 2a 65   Tcl_ErrnoMsg(*e
30d0: 72 72 6f 72 43 6f 64 65 50 74 72 29 29 3b 0a 0a  rrorCodePtr));..
30e0: 09 20 20 20 20 7d 20 65 6c 73 65 20 7b 0a 09 09  .    } else {...
30f0: 64 70 72 69 6e 74 66 28 22 49 2f 4f 20 65 72 72  dprintf("I/O err
3100: 6f 72 20 6f 63 63 75 72 72 65 64 20 28 62 61 63  or occurred (bac
3110: 6b 69 6e 67 45 72 72 6f 72 20 3d 20 25 6c 75 29  kingError = %lu)
3120: 22 2c 20 62 61 63 6b 69 6e 67 45 72 72 6f 72 29  ", backingError)
3130: 3b 0a 09 09 2a 65 72 72 6f 72 43 6f 64 65 50 74  ;...*errorCodePt
3140: 72 20 3d 20 54 63 6c 5f 47 65 74 45 72 72 6e 6f  r = Tcl_GetErrno
3150: 28 29 3b 0a 09 09 62 79 74 65 73 52 65 61 64 20  ();...bytesRead 
3160: 3d 20 2d 31 3b 0a 09 09 54 6c 73 5f 45 72 72 6f  = -1;...Tls_Erro
3170: 72 28 73 74 61 74 65 50 74 72 2c 20 28 63 68 61  r(statePtr, (cha
3180: 72 20 2a 29 20 45 52 52 5f 72 65 61 73 6f 6e 5f  r *) ERR_reason_
3190: 65 72 72 6f 72 5f 73 74 72 69 6e 67 28 62 61 63  error_string(bac
31a0: 6b 69 6e 67 45 72 72 6f 72 29 29 3b 0a 09 20 20  kingError));..  
31b0: 20 20 7d 0a 09 20 20 20 20 62 72 65 61 6b 3b 0a    }..    break;.
31c0: 0a 09 63 61 73 65 20 53 53 4c 5f 45 52 52 4f 52  ..case SSL_ERROR
31d0: 5f 5a 45 52 4f 5f 52 45 54 55 52 4e 3a 0a 09 20  _ZERO_RETURN:.. 
31e0: 20 20 20 64 70 72 69 6e 74 66 28 22 47 6f 74 20     dprintf("Got 
31f0: 53 53 4c 5f 45 52 52 4f 52 5f 5a 45 52 4f 5f 52  SSL_ERROR_ZERO_R
3200: 45 54 55 52 4e 2c 20 74 68 69 73 20 6d 65 61 6e  ETURN, this mean
3210: 73 20 61 6e 20 45 4f 46 20 68 61 73 20 62 65 65  s an EOF has bee
3220: 6e 20 72 65 61 63 68 65 64 22 29 3b 0a 09 20 20  n reached");..  
3230: 20 20 62 79 74 65 73 52 65 61 64 20 3d 20 30 3b    bytesRead = 0;
3240: 0a 09 20 20 20 20 2a 65 72 72 6f 72 43 6f 64 65  ..    *errorCode
3250: 50 74 72 20 3d 20 30 3b 0a 09 20 20 20 20 54 6c  Ptr = 0;..    Tl
3260: 73 5f 45 72 72 6f 72 28 73 74 61 74 65 50 74 72  s_Error(statePtr
3270: 2c 20 22 50 65 65 72 20 68 61 73 20 63 6c 6f 73  , "Peer has clos
3280: 65 64 20 74 68 65 20 63 6f 6e 6e 65 63 74 69 6f  ed the connectio
3290: 6e 20 66 6f 72 20 77 72 69 74 69 6e 67 20 62 79  n for writing by
32a0: 20 73 65 6e 64 69 6e 67 20 74 68 65 20 63 6c 6f   sending the clo
32b0: 73 65 5f 6e 6f 74 69 66 79 20 61 6c 65 72 74 22  se_notify alert"
32c0: 29 3b 0a 09 20 20 20 20 62 72 65 61 6b 3b 0a 0a  );..    break;..
32d0: 09 63 61 73 65 20 53 53 4c 5f 45 52 52 4f 52 5f  .case SSL_ERROR_
32e0: 57 41 4e 54 5f 52 45 41 44 3a 0a 09 20 20 20 20  WANT_READ:..    
32f0: 64 70 72 69 6e 74 66 28 22 47 6f 74 20 53 53 4c  dprintf("Got SSL
3300: 5f 45 52 52 4f 52 5f 57 41 4e 54 5f 52 45 41 44  _ERROR_WANT_READ
3310: 2c 20 6d 61 70 70 69 6e 67 20 74 68 69 73 20 74  , mapping this t
3320: 6f 20 45 41 47 41 49 4e 22 29 3b 0a 09 20 20 20  o EAGAIN");..   
3330: 20 62 79 74 65 73 52 65 61 64 20 3d 20 2d 31 3b   bytesRead = -1;
3340: 0a 09 20 20 20 20 2a 65 72 72 6f 72 43 6f 64 65  ..    *errorCode
3350: 50 74 72 20 3d 20 45 41 47 41 49 4e 3b 0a 09 20  Ptr = EAGAIN;.. 
3360: 20 20 20 54 6c 73 5f 45 72 72 6f 72 28 73 74 61     Tls_Error(sta
3370: 74 65 50 74 72 2c 20 22 53 53 4c 5f 45 52 52 4f  tePtr, "SSL_ERRO
3380: 52 5f 57 41 4e 54 5f 52 45 41 44 22 29 3b 0a 09  R_WANT_READ");..
3390: 20 20 20 20 62 72 65 61 6b 3b 0a 0a 09 64 65 66      break;...def
33a0: 61 75 6c 74 3a 0a 09 20 20 20 20 64 70 72 69 6e  ault:..    dprin
33b0: 74 66 28 22 55 6e 6b 6e 6f 77 6e 20 65 72 72 6f  tf("Unknown erro
33c0: 72 20 28 65 72 72 20 3d 20 25 69 29 2c 20 6d 61  r (err = %i), ma
33d0: 70 70 69 6e 67 20 74 6f 20 45 4f 46 22 2c 20 65  pping to EOF", e
33e0: 72 72 29 3b 0a 09 20 20 20 20 2a 65 72 72 6f 72  rr);..    *error
33f0: 43 6f 64 65 50 74 72 20 3d 20 30 3b 0a 09 20 20  CodePtr = 0;..  
3400: 20 20 62 79 74 65 73 52 65 61 64 20 3d 20 30 3b    bytesRead = 0;
3410: 0a 09 20 20 20 20 54 6c 73 5f 45 72 72 6f 72 28  ..    Tls_Error(
3420: 73 74 61 74 65 50 74 72 2c 20 22 55 6e 6b 6e 6f  statePtr, "Unkno
3430: 77 6e 20 65 72 72 6f 72 22 29 3b 0a 09 20 20 20  wn error");..   
3440: 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a 0a 20   break;.    }.. 
3450: 20 20 20 64 70 72 69 6e 74 66 28 22 49 6e 70 75     dprintf("Inpu
3460: 74 28 25 64 29 20 2d 3e 20 25 64 20 5b 25 64 5d  t(%d) -> %d [%d]
3470: 22 2c 20 62 75 66 53 69 7a 65 2c 20 62 79 74 65  ", bufSize, byte
3480: 73 52 65 61 64 2c 20 2a 65 72 72 6f 72 43 6f 64  sRead, *errorCod
3490: 65 50 74 72 29 3b 0a 20 20 20 20 72 65 74 75 72  ePtr);.    retur
34a0: 6e 28 62 79 74 65 73 52 65 61 64 29 3b 0a 7d 0a  n(bytesRead);.}.
34b0: 0a 2f 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ./*. *----------
34c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
34d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
34e0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
34f0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 0a 20 2a 20  ---------. *. * 
3500: 54 6c 73 4f 75 74 70 75 74 50 72 6f 63 20 2d 2d  TlsOutputProc --
3510: 0a 20 2a 0a 20 2a 20 20 20 20 54 68 69 73 20 70  . *. *    This p
3520: 72 6f 63 65 64 75 72 65 20 69 73 20 69 6e 76 6f  rocedure is invo
3530: 6b 65 64 20 62 79 20 74 68 65 20 67 65 6e 65 72  ked by the gener
3540: 69 63 20 49 4f 20 6c 65 76 65 6c 0a 20 2a 20 20  ic IO level. *  
3550: 20 20 20 20 20 74 6f 20 77 72 69 74 65 20 6f 75       to write ou
3560: 74 70 75 74 20 74 6f 20 61 20 53 53 4c 20 73 6f  tput to a SSL so
3570: 63 6b 65 74 20 62 61 73 65 64 20 63 68 61 6e 6e  cket based chann
3580: 65 6c 2e 0a 20 2a 0a 20 2a 20 52 65 73 75 6c 74  el.. *. * Result
3590: 73 3a 0a 20 2a 20 20 20 20 52 65 74 75 72 6e 73  s:. *    Returns
35a0: 20 74 68 65 20 6e 75 6d 62 65 72 20 6f 66 20 62   the number of b
35b0: 79 74 65 73 20 77 72 69 74 74 65 6e 20 6f 72 20  ytes written or 
35c0: 2d 31 20 6f 6e 20 65 72 72 6f 72 2e 20 53 65 74  -1 on error. Set
35d0: 73 20 65 72 72 6f 72 43 6f 64 65 50 74 72 0a 20  s errorCodePtr. 
35e0: 2a 20 20 20 20 74 6f 20 61 20 50 4f 53 49 58 20  *    to a POSIX 
35f0: 65 72 72 6f 72 20 63 6f 64 65 20 69 66 20 61 6e  error code if an
3600: 20 65 72 72 6f 72 20 6f 63 63 75 72 72 65 64 2c   error occurred,
3610: 20 6f 72 20 30 20 69 66 20 6e 6f 6e 65 2e 0a 20   or 0 if none.. 
3620: 2a 0a 20 2a 20 53 69 64 65 20 65 66 66 65 63 74  *. * Side effect
3630: 73 3a 0a 20 2a 20 20 20 20 57 72 69 74 65 73 20  s:. *    Writes 
3640: 6f 75 74 70 75 74 20 6f 6e 20 74 68 65 20 6f 75  output on the ou
3650: 74 70 75 74 20 64 65 76 69 63 65 20 6f 66 20 74  tput device of t
3660: 68 65 20 63 68 61 6e 6e 65 6c 2e 0a 20 2a 0a 20  he channel.. *. 
3670: 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  *---------------
3680: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3690: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
36a0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
36b0: 2d 2d 2d 2d 0a 20 2a 2f 0a 73 74 61 74 69 63 20  ----. */.static 
36c0: 69 6e 74 20 54 6c 73 4f 75 74 70 75 74 50 72 6f  int TlsOutputPro
36d0: 63 28 43 6c 69 65 6e 74 44 61 74 61 20 69 6e 73  c(ClientData ins
36e0: 74 61 6e 63 65 44 61 74 61 2c 20 63 6f 6e 73 74  tanceData, const
36f0: 20 63 68 61 72 20 2a 62 75 66 2c 20 69 6e 74 20   char *buf, int 
3700: 74 6f 57 72 69 74 65 2c 20 69 6e 74 20 2a 65 72  toWrite, int *er
3710: 72 6f 72 43 6f 64 65 50 74 72 29 20 7b 0a 20 20  rorCodePtr) {.  
3720: 20 20 75 6e 73 69 67 6e 65 64 20 6c 6f 6e 67 20    unsigned long 
3730: 62 61 63 6b 69 6e 67 45 72 72 6f 72 3b 0a 20 20  backingError;.  
3740: 20 20 53 74 61 74 65 20 2a 73 74 61 74 65 50 74    State *statePt
3750: 72 20 3d 20 28 53 74 61 74 65 20 2a 29 20 69 6e  r = (State *) in
3760: 73 74 61 6e 63 65 44 61 74 61 3b 0a 20 20 20 20  stanceData;.    
3770: 69 6e 74 20 77 72 69 74 74 65 6e 2c 20 65 72 72  int written, err
3780: 3b 0a 20 20 20 20 69 6e 74 20 74 6c 73 43 6f 6e  ;.    int tlsCon
3790: 6e 65 63 74 3b 0a 0a 20 20 20 20 2a 65 72 72 6f  nect;..    *erro
37a0: 72 43 6f 64 65 50 74 72 20 3d 20 30 3b 0a 0a 20  rCodePtr = 0;.. 
37b0: 20 20 20 64 70 72 69 6e 74 66 28 22 42 49 4f 5f     dprintf("BIO_
37c0: 77 72 69 74 65 28 25 70 2c 20 25 64 29 22 2c 20  write(%p, %d)", 
37d0: 28 76 6f 69 64 20 2a 29 20 73 74 61 74 65 50 74  (void *) statePt
37e0: 72 2c 20 74 6f 57 72 69 74 65 29 3b 0a 20 20 20  r, toWrite);.   
37f0: 20 64 70 72 69 6e 74 42 75 66 66 65 72 28 62 75   dprintBuffer(bu
3800: 66 2c 20 74 6f 57 72 69 74 65 29 3b 0a 0a 20 20  f, toWrite);..  
3810: 20 20 69 66 20 28 73 74 61 74 65 50 74 72 2d 3e    if (statePtr->
3820: 66 6c 61 67 73 20 26 20 54 4c 53 5f 54 43 4c 5f  flags & TLS_TCL_
3830: 43 41 4c 4c 42 41 43 4b 29 20 7b 0a 09 64 70 72  CALLBACK) {..dpr
3840: 69 6e 74 66 28 22 44 6f 6e 27 74 20 70 72 6f 63  intf("Don't proc
3850: 65 73 73 20 6f 75 74 70 75 74 20 77 68 69 6c 65  ess output while
3860: 20 63 61 6c 6c 62 61 63 6b 73 20 61 72 65 20 72   callbacks are r
3870: 75 6e 6e 69 6e 67 22 29 3b 0a 09 77 72 69 74 74  unning");..writt
3880: 65 6e 20 3d 20 2d 31 3b 0a 09 2a 65 72 72 6f 72  en = -1;..*error
3890: 43 6f 64 65 50 74 72 20 3d 20 45 41 47 41 49 4e  CodePtr = EAGAIN
38a0: 3b 0a 09 72 65 74 75 72 6e 28 2d 31 29 3b 0a 20  ;..return(-1);. 
38b0: 20 20 20 7d 0a 0a 20 20 20 20 64 70 72 69 6e 74     }..    dprint
38c0: 66 28 22 43 61 6c 6c 69 6e 67 20 54 6c 73 5f 57  f("Calling Tls_W
38d0: 61 69 74 46 6f 72 43 6f 6e 6e 65 63 74 22 29 3b  aitForConnect");
38e0: 0a 20 20 20 20 74 6c 73 43 6f 6e 6e 65 63 74 20  .    tlsConnect 
38f0: 3d 20 54 6c 73 5f 57 61 69 74 46 6f 72 43 6f 6e  = Tls_WaitForCon
3900: 6e 65 63 74 28 73 74 61 74 65 50 74 72 2c 20 65  nect(statePtr, e
3910: 72 72 6f 72 43 6f 64 65 50 74 72 2c 20 31 29 3b  rrorCodePtr, 1);
3920: 0a 20 20 20 20 69 66 20 28 74 6c 73 43 6f 6e 6e  .    if (tlsConn
3930: 65 63 74 20 3c 20 30 29 20 7b 0a 09 64 70 72 69  ect < 0) {..dpri
3940: 6e 74 66 28 22 47 6f 74 20 61 6e 20 65 72 72 6f  ntf("Got an erro
3950: 72 20 77 61 69 74 69 6e 67 20 74 6f 20 63 6f 6e  r waiting to con
3960: 6e 65 63 74 20 28 74 6c 73 43 6f 6e 6e 65 63 74  nect (tlsConnect
3970: 20 3d 20 25 69 2c 20 2a 65 72 72 6f 72 43 6f 64   = %i, *errorCod
3980: 65 50 74 72 20 3d 20 25 69 29 22 2c 20 74 6c 73  ePtr = %i)", tls
3990: 43 6f 6e 6e 65 63 74 2c 20 2a 65 72 72 6f 72 43  Connect, *errorC
39a0: 6f 64 65 50 74 72 29 3b 0a 09 54 6c 73 5f 45 72  odePtr);..Tls_Er
39b0: 72 6f 72 28 73 74 61 74 65 50 74 72 2c 20 73 74  ror(statePtr, st
39c0: 72 65 72 72 6f 72 28 2a 65 72 72 6f 72 43 6f 64  rerror(*errorCod
39d0: 65 50 74 72 29 29 3b 0a 0a 09 77 72 69 74 74 65  ePtr));...writte
39e0: 6e 20 3d 20 2d 31 3b 0a 09 69 66 20 28 2a 65 72  n = -1;..if (*er
39f0: 72 6f 72 43 6f 64 65 50 74 72 20 3d 3d 20 45 43  rorCodePtr == EC
3a00: 4f 4e 4e 52 45 53 45 54 29 20 7b 0a 09 20 20 20  ONNRESET) {..   
3a10: 20 64 70 72 69 6e 74 66 28 22 47 6f 74 20 63 6f   dprintf("Got co
3a20: 6e 6e 65 63 74 69 6f 6e 20 72 65 73 65 74 22 29  nnection reset")
3a30: 3b 0a 09 20 20 20 20 2f 2a 20 53 6f 66 74 20 45  ;..    /* Soft E
3a40: 4f 46 20 2a 2f 0a 09 20 20 20 20 2a 65 72 72 6f  OF */..    *erro
3a50: 72 43 6f 64 65 50 74 72 20 3d 20 30 3b 0a 09 20  rCodePtr = 0;.. 
3a60: 20 20 20 77 72 69 74 74 65 6e 20 3d 20 30 3b 0a     written = 0;.
3a70: 09 7d 0a 09 72 65 74 75 72 6e 28 77 72 69 74 74  .}..return(writt
3a80: 65 6e 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20  en);.    }..    
3a90: 69 66 20 28 74 6f 57 72 69 74 65 20 3d 3d 20 30  if (toWrite == 0
3aa0: 29 20 7b 0a 09 64 70 72 69 6e 74 66 28 22 7a 65  ) {..dprintf("ze
3ab0: 72 6f 2d 77 72 69 74 65 22 29 3b 0a 09 65 72 72  ro-write");..err
3ac0: 20 3d 20 42 49 4f 5f 66 6c 75 73 68 28 73 74 61   = BIO_flush(sta
3ad0: 74 65 50 74 72 2d 3e 62 69 6f 29 3b 0a 0a 09 69  tePtr->bio);...i
3ae0: 66 20 28 65 72 72 20 3c 3d 20 30 29 20 7b 0a 09  f (err <= 0) {..
3af0: 20 20 20 20 64 70 72 69 6e 74 66 28 22 46 6c 75      dprintf("Flu
3b00: 73 68 69 6e 67 20 66 61 69 6c 65 64 22 29 3b 0a  shing failed");.
3b10: 09 20 20 20 20 54 6c 73 5f 45 72 72 6f 72 28 73  .    Tls_Error(s
3b20: 74 61 74 65 50 74 72 2c 20 22 46 6c 75 73 68 20  tatePtr, "Flush 
3b30: 66 61 69 6c 65 64 22 29 3b 0a 0a 09 20 20 20 20  failed");...    
3b40: 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 20 3d 20  *errorCodePtr = 
3b50: 45 49 4f 3b 0a 09 20 20 20 20 77 72 69 74 74 65  EIO;..    writte
3b60: 6e 20 3d 20 30 3b 0a 09 20 20 20 20 72 65 74 75  n = 0;..    retu
3b70: 72 6e 28 2d 31 29 3b 0a 09 7d 0a 0a 09 77 72 69  rn(-1);..}...wri
3b80: 74 74 65 6e 20 3d 20 30 3b 0a 09 2a 65 72 72 6f  tten = 0;..*erro
3b90: 72 43 6f 64 65 50 74 72 20 3d 20 30 3b 0a 09 72  rCodePtr = 0;..r
3ba0: 65 74 75 72 6e 28 30 29 3b 0a 20 20 20 20 7d 0a  eturn(0);.    }.
3bb0: 0a 20 20 20 20 2f 2a 0a 20 20 20 20 20 2a 20 57  .    /*.     * W
3bc0: 65 20 6e 65 65 64 20 74 6f 20 63 6c 65 61 72 20  e need to clear 
3bd0: 74 68 65 20 53 53 4c 20 65 72 72 6f 72 20 73 74  the SSL error st
3be0: 61 63 6b 20 6e 6f 77 20 62 65 63 61 75 73 65 20  ack now because 
3bf0: 77 65 20 73 6f 6d 65 74 69 6d 65 73 20 72 65 61  we sometimes rea
3c00: 63 68 0a 20 20 20 20 20 2a 20 74 68 69 73 20 66  ch.     * this f
3c10: 75 6e 63 74 69 6f 6e 20 77 69 74 68 20 6c 65 66  unction with lef
3c20: 74 6f 76 65 72 20 65 72 72 6f 72 73 20 69 6e 20  tover errors in 
3c30: 74 68 65 20 73 74 61 63 6b 2e 20 20 49 66 20 42  the stack.  If B
3c40: 49 4f 5f 77 72 69 74 65 0a 20 20 20 20 20 2a 20  IO_write.     * 
3c50: 72 65 74 75 72 6e 73 20 2d 31 20 61 6e 64 20 69  returns -1 and i
3c60: 6e 74 65 6e 64 73 20 45 41 47 41 49 4e 2c 20 74  ntends EAGAIN, t
3c70: 68 65 72 65 20 69 73 20 61 20 6c 65 66 74 6f 76  here is a leftov
3c80: 65 72 20 65 72 72 6f 72 2c 20 69 74 20 77 69 6c  er error, it wil
3c90: 6c 20 62 65 0a 20 20 20 20 20 2a 20 6d 69 73 63  l be.     * misc
3ca0: 6f 6e 73 74 72 75 65 64 20 61 73 20 61 6e 20 65  onstrued as an e
3cb0: 72 72 6f 72 2c 20 6e 6f 74 20 45 41 47 41 49 4e  rror, not EAGAIN
3cc0: 2e 0a 20 20 20 20 20 2a 0a 20 20 20 20 20 2a 20  ..     *.     * 
3cd0: 41 6c 74 65 72 6e 61 74 69 76 65 6c 79 2c 20 77  Alternatively, w
3ce0: 65 20 6d 61 79 20 77 61 6e 74 20 74 6f 20 68 61  e may want to ha
3cf0: 6e 64 6c 65 20 74 68 65 20 3c 30 20 72 65 74 75  ndle the <0 retu
3d00: 72 6e 20 63 6f 64 65 73 20 66 72 6f 6d 0a 20 20  rn codes from.  
3d10: 20 20 20 2a 20 42 49 4f 5f 77 72 69 74 65 20 73     * BIO_write s
3d20: 70 65 63 69 61 6c 6c 79 20 28 61 73 20 61 64 76  pecially (as adv
3d30: 69 73 65 64 20 69 6e 20 74 68 65 20 52 53 41 20  ised in the RSA 
3d40: 64 6f 63 73 29 2e 20 20 54 4c 53 27 73 20 6c 6f  docs).  TLS's lo
3d50: 77 65 72 20 6c 65 76 65 6c 0a 20 20 20 20 20 2a  wer level.     *
3d60: 20 42 49 4f 20 66 75 6e 63 74 69 6f 6e 73 20 70   BIO functions p
3d70: 6c 61 79 20 77 69 74 68 20 74 68 65 20 72 65 74  lay with the ret
3d80: 72 79 20 66 6c 61 67 73 20 74 68 6f 75 67 68 2c  ry flags though,
3d90: 20 61 6e 64 20 74 68 69 73 20 73 65 65 6d 73 20   and this seems 
3da0: 74 6f 0a 20 20 20 20 20 2a 20 77 6f 72 6b 20 63  to.     * work c
3db0: 6f 72 72 65 63 74 6c 79 2e 20 20 53 69 6d 69 6c  orrectly.  Simil
3dc0: 61 72 20 66 69 78 20 69 6e 20 54 6c 73 49 6e 70  ar fix in TlsInp
3dd0: 75 74 50 72 6f 63 2e 20 2d 20 68 6f 62 62 73 0a  utProc. - hobbs.
3de0: 20 20 20 20 20 2a 2f 0a 20 20 20 20 45 52 52 5f       */.    ERR_
3df0: 63 6c 65 61 72 5f 65 72 72 6f 72 28 29 3b 0a 20  clear_error();. 
3e00: 20 20 20 77 72 69 74 74 65 6e 20 3d 20 42 49 4f     written = BIO
3e10: 5f 77 72 69 74 65 28 73 74 61 74 65 50 74 72 2d  _write(statePtr-
3e20: 3e 62 69 6f 2c 20 62 75 66 2c 20 74 6f 57 72 69  >bio, buf, toWri
3e30: 74 65 29 3b 0a 20 20 20 20 64 70 72 69 6e 74 66  te);.    dprintf
3e40: 28 22 42 49 4f 5f 77 72 69 74 65 28 25 70 2c 20  ("BIO_write(%p, 
3e50: 25 64 29 20 2d 3e 20 5b 25 64 5d 22 2c 20 28 76  %d) -> [%d]", (v
3e60: 6f 69 64 20 2a 29 20 73 74 61 74 65 50 74 72 2c  oid *) statePtr,
3e70: 20 74 6f 57 72 69 74 65 2c 20 77 72 69 74 74 65   toWrite, writte
3e80: 6e 29 3b 0a 0a 20 20 20 20 65 72 72 20 3d 20 53  n);..    err = S
3e90: 53 4c 5f 67 65 74 5f 65 72 72 6f 72 28 73 74 61  SL_get_error(sta
3ea0: 74 65 50 74 72 2d 3e 73 73 6c 2c 20 77 72 69 74  tePtr->ssl, writ
3eb0: 74 65 6e 29 3b 0a 20 20 20 20 62 61 63 6b 69 6e  ten);.    backin
3ec0: 67 45 72 72 6f 72 20 3d 20 45 52 52 5f 67 65 74  gError = ERR_get
3ed0: 5f 65 72 72 6f 72 28 29 3b 0a 0a 20 20 20 20 73  _error();..    s
3ee0: 77 69 74 63 68 20 28 65 72 72 29 20 7b 0a 09 63  witch (err) {..c
3ef0: 61 73 65 20 53 53 4c 5f 45 52 52 4f 52 5f 4e 4f  ase SSL_ERROR_NO
3f00: 4e 45 3a 0a 09 20 20 20 20 69 66 20 28 77 72 69  NE:..    if (wri
3f10: 74 74 65 6e 20 3c 20 30 29 20 7b 0a 09 09 77 72  tten < 0) {...wr
3f20: 69 74 74 65 6e 20 3d 20 30 3b 0a 09 20 20 20 20  itten = 0;..    
3f30: 7d 0a 09 20 20 20 20 62 72 65 61 6b 3b 0a 0a 09  }..    break;...
3f40: 63 61 73 65 20 53 53 4c 5f 45 52 52 4f 52 5f 57  case SSL_ERROR_W
3f50: 41 4e 54 5f 57 52 49 54 45 3a 0a 09 20 20 20 20  ANT_WRITE:..    
3f60: 64 70 72 69 6e 74 66 28 22 47 6f 74 20 53 53 4c  dprintf("Got SSL
3f70: 5f 45 52 52 4f 52 5f 57 41 4e 54 5f 57 52 49 54  _ERROR_WANT_WRIT
3f80: 45 2c 20 6d 61 70 70 69 6e 67 20 69 74 20 74 6f  E, mapping it to
3f90: 20 45 41 47 41 49 4e 22 29 3b 0a 09 20 20 20 20   EAGAIN");..    
3fa0: 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 20 3d 20  *errorCodePtr = 
3fb0: 45 41 47 41 49 4e 3b 0a 09 20 20 20 20 77 72 69  EAGAIN;..    wri
3fc0: 74 74 65 6e 20 3d 20 2d 31 3b 0a 09 20 20 20 20  tten = -1;..    
3fd0: 54 6c 73 5f 45 72 72 6f 72 28 73 74 61 74 65 50  Tls_Error(stateP
3fe0: 74 72 2c 20 22 53 53 4c 5f 45 52 52 4f 52 5f 57  tr, "SSL_ERROR_W
3ff0: 41 4e 54 5f 57 52 49 54 45 22 29 3b 0a 09 20 20  ANT_WRITE");..  
4000: 20 20 62 72 65 61 6b 3b 0a 0a 09 63 61 73 65 20    break;...case 
4010: 53 53 4c 5f 45 52 52 4f 52 5f 57 41 4e 54 5f 52  SSL_ERROR_WANT_R
4020: 45 41 44 3a 0a 09 20 20 20 20 64 70 72 69 6e 74  EAD:..    dprint
4030: 66 28 22 20 77 72 69 74 65 20 52 20 42 4c 4f 43  f(" write R BLOC
4040: 4b 22 29 3b 0a 09 20 20 20 20 54 6c 73 5f 45 72  K");..    Tls_Er
4050: 72 6f 72 28 73 74 61 74 65 50 74 72 2c 20 22 53  ror(statePtr, "S
4060: 53 4c 5f 45 52 52 4f 52 5f 57 41 4e 54 5f 52 45  SL_ERROR_WANT_RE
4070: 41 44 22 29 3b 0a 09 20 20 20 20 62 72 65 61 6b  AD");..    break
4080: 3b 0a 0a 09 63 61 73 65 20 53 53 4c 5f 45 52 52  ;...case SSL_ERR
4090: 4f 52 5f 57 41 4e 54 5f 58 35 30 39 5f 4c 4f 4f  OR_WANT_X509_LOO
40a0: 4b 55 50 3a 0a 09 20 20 20 20 64 70 72 69 6e 74  KUP:..    dprint
40b0: 66 28 22 20 77 72 69 74 65 20 58 20 42 4c 4f 43  f(" write X BLOC
40c0: 4b 22 29 3b 0a 09 20 20 20 20 54 6c 73 5f 45 72  K");..    Tls_Er
40d0: 72 6f 72 28 73 74 61 74 65 50 74 72 2c 20 22 53  ror(statePtr, "S
40e0: 53 4c 5f 45 52 52 4f 52 5f 57 41 4e 54 5f 58 35  SL_ERROR_WANT_X5
40f0: 30 39 5f 4c 4f 4f 4b 55 50 22 29 3b 0a 09 20 20  09_LOOKUP");..  
4100: 20 20 62 72 65 61 6b 3b 0a 0a 09 63 61 73 65 20    break;...case 
4110: 53 53 4c 5f 45 52 52 4f 52 5f 5a 45 52 4f 5f 52  SSL_ERROR_ZERO_R
4120: 45 54 55 52 4e 3a 0a 09 20 20 20 20 64 70 72 69  ETURN:..    dpri
4130: 6e 74 66 28 22 20 63 6c 6f 73 65 64 22 29 3b 0a  ntf(" closed");.
4140: 09 20 20 20 20 77 72 69 74 74 65 6e 20 3d 20 30  .    written = 0
4150: 3b 0a 09 20 20 20 20 2a 65 72 72 6f 72 43 6f 64  ;..    *errorCod
4160: 65 50 74 72 20 3d 20 30 3b 0a 09 20 20 20 20 54  ePtr = 0;..    T
4170: 6c 73 5f 45 72 72 6f 72 28 73 74 61 74 65 50 74  ls_Error(statePt
4180: 72 2c 20 22 50 65 65 72 20 68 61 73 20 63 6c 6f  r, "Peer has clo
4190: 73 65 64 20 74 68 65 20 63 6f 6e 6e 65 63 74 69  sed the connecti
41a0: 6f 6e 20 66 6f 72 20 77 72 69 74 69 6e 67 20 62  on for writing b
41b0: 79 20 73 65 6e 64 69 6e 67 20 74 68 65 20 63 6c  y sending the cl
41c0: 6f 73 65 5f 6e 6f 74 69 66 79 20 61 6c 65 72 74  ose_notify alert
41d0: 22 29 3b 0a 09 20 20 20 20 62 72 65 61 6b 3b 0a  ");..    break;.
41e0: 0a 09 63 61 73 65 20 53 53 4c 5f 45 52 52 4f 52  ..case SSL_ERROR
41f0: 5f 53 59 53 43 41 4c 4c 3a 0a 09 20 20 20 20 2f  _SYSCALL:..    /
4200: 2a 20 53 6f 6d 65 20 6e 6f 6e 2d 72 65 63 6f 76  * Some non-recov
4210: 65 72 61 62 6c 65 2c 20 66 61 74 61 6c 20 49 2f  erable, fatal I/
4220: 4f 20 65 72 72 6f 72 20 6f 63 63 75 72 72 65 64  O error occurred
4230: 20 2a 2f 0a 09 20 20 20 20 69 66 20 28 62 61 63   */..    if (bac
4240: 6b 69 6e 67 45 72 72 6f 72 20 3d 3d 20 30 20 26  kingError == 0 &
4250: 26 20 77 72 69 74 74 65 6e 20 3d 3d 20 30 29 20  & written == 0) 
4260: 7b 0a 09 09 64 70 72 69 6e 74 66 28 22 45 4f 46  {...dprintf("EOF
4270: 20 72 65 61 63 68 65 64 22 29 0a 09 09 2a 65 72   reached")...*er
4280: 72 6f 72 43 6f 64 65 50 74 72 20 3d 20 30 3b 0a  rorCodePtr = 0;.
4290: 09 09 77 72 69 74 74 65 6e 20 3d 20 30 3b 0a 09  ..written = 0;..
42a0: 09 54 6c 73 5f 45 72 72 6f 72 28 73 74 61 74 65  .Tls_Error(state
42b0: 50 74 72 2c 20 22 45 4f 46 20 72 65 61 63 68 65  Ptr, "EOF reache
42c0: 64 22 29 3b 0a 0a 09 20 20 20 20 7d 20 65 6c 73  d");...    } els
42d0: 65 20 69 66 20 28 62 61 63 6b 69 6e 67 45 72 72  e if (backingErr
42e0: 6f 72 20 3d 3d 20 30 20 26 26 20 77 72 69 74 74  or == 0 && writt
42f0: 65 6e 20 3d 3d 20 2d 31 29 20 7b 0a 09 09 64 70  en == -1) {...dp
4300: 72 69 6e 74 66 28 22 49 2f 4f 20 65 72 72 6f 72  rintf("I/O error
4310: 20 6f 63 63 75 72 72 65 64 20 28 65 72 72 6e 6f   occurred (errno
4320: 20 3d 20 25 6c 75 29 22 2c 20 28 75 6e 73 69 67   = %lu)", (unsig
4330: 6e 65 64 20 6c 6f 6e 67 29 20 54 63 6c 5f 47 65  ned long) Tcl_Ge
4340: 74 45 72 72 6e 6f 28 29 29 3b 0a 09 09 2a 65 72  tErrno());...*er
4350: 72 6f 72 43 6f 64 65 50 74 72 20 3d 20 54 63 6c  rorCodePtr = Tcl
4360: 5f 47 65 74 45 72 72 6e 6f 28 29 3b 0a 09 09 77  _GetErrno();...w
4370: 72 69 74 74 65 6e 20 3d 20 2d 31 3b 0a 09 09 54  ritten = -1;...T
4380: 6c 73 5f 45 72 72 6f 72 28 73 74 61 74 65 50 74  ls_Error(statePt
4390: 72 2c 20 28 63 68 61 72 20 2a 29 20 54 63 6c 5f  r, (char *) Tcl_
43a0: 45 72 72 6e 6f 4d 73 67 28 2a 65 72 72 6f 72 43  ErrnoMsg(*errorC
43b0: 6f 64 65 50 74 72 29 29 3b 0a 0a 09 20 20 20 20  odePtr));...    
43c0: 7d 20 65 6c 73 65 20 7b 0a 09 09 64 70 72 69 6e  } else {...dprin
43d0: 74 66 28 22 49 2f 4f 20 65 72 72 6f 72 20 6f 63  tf("I/O error oc
43e0: 63 75 72 72 65 64 20 28 62 61 63 6b 69 6e 67 45  curred (backingE
43f0: 72 72 6f 72 20 3d 20 25 6c 75 29 22 2c 20 62 61  rror = %lu)", ba
4400: 63 6b 69 6e 67 45 72 72 6f 72 29 3b 0a 09 09 2a  ckingError);...*
4410: 65 72 72 6f 72 43 6f 64 65 50 74 72 20 3d 20 54  errorCodePtr = T
4420: 63 6c 5f 47 65 74 45 72 72 6e 6f 28 29 3b 0a 09  cl_GetErrno();..
4430: 09 77 72 69 74 74 65 6e 20 3d 20 2d 31 3b 0a 09  .written = -1;..
4440: 09 54 6c 73 5f 45 72 72 6f 72 28 73 74 61 74 65  .Tls_Error(state
4450: 50 74 72 2c 20 28 63 68 61 72 20 2a 29 20 45 52  Ptr, (char *) ER
4460: 52 5f 72 65 61 73 6f 6e 5f 65 72 72 6f 72 5f 73  R_reason_error_s
4470: 74 72 69 6e 67 28 62 61 63 6b 69 6e 67 45 72 72  tring(backingErr
4480: 6f 72 29 29 3b 0a 09 20 20 20 20 7d 0a 09 20 20  or));..    }..  
4490: 20 20 62 72 65 61 6b 3b 0a 0a 09 63 61 73 65 20    break;...case 
44a0: 53 53 4c 5f 45 52 52 4f 52 5f 53 53 4c 3a 0a 09  SSL_ERROR_SSL:..
44b0: 20 20 20 20 2f 2a 20 41 20 6e 6f 6e 2d 72 65 63      /* A non-rec
44c0: 6f 76 65 72 61 62 6c 65 2c 20 66 61 74 61 6c 20  overable, fatal 
44d0: 65 72 72 6f 72 20 69 6e 20 74 68 65 20 53 53 4c  error in the SSL
44e0: 20 6c 69 62 72 61 72 79 20 6f 63 63 75 72 72 65   library occurre
44f0: 64 2c 20 75 73 75 61 6c 6c 79 20 61 20 70 72 6f  d, usually a pro
4500: 74 6f 63 6f 6c 20 65 72 72 6f 72 20 2a 2f 0a 09  tocol error */..
4510: 20 20 20 20 64 70 72 69 6e 74 66 28 22 53 53 4c      dprintf("SSL
4520: 20 65 72 72 6f 72 2c 20 69 6e 64 69 63 61 74 69   error, indicati
4530: 6e 67 20 74 68 61 74 20 74 68 65 20 63 6f 6e 6e  ng that the conn
4540: 65 63 74 69 6f 6e 20 68 61 73 20 62 65 65 6e 20  ection has been 
4550: 61 62 6f 72 74 65 64 22 29 3b 0a 09 20 20 20 20  aborted");..    
4560: 69 66 20 28 62 61 63 6b 69 6e 67 45 72 72 6f 72  if (backingError
4570: 20 21 3d 20 30 29 20 7b 0a 09 09 54 6c 73 5f 45   != 0) {...Tls_E
4580: 72 72 6f 72 28 73 74 61 74 65 50 74 72 2c 20 28  rror(statePtr, (
4590: 63 68 61 72 20 2a 29 20 45 52 52 5f 72 65 61 73  char *) ERR_reas
45a0: 6f 6e 5f 65 72 72 6f 72 5f 73 74 72 69 6e 67 28  on_error_string(
45b0: 62 61 63 6b 69 6e 67 45 72 72 6f 72 29 29 3b 0a  backingError));.
45c0: 09 20 20 20 20 7d 20 65 6c 73 65 20 69 66 20 28  .    } else if (
45d0: 53 53 4c 5f 67 65 74 5f 76 65 72 69 66 79 5f 72  SSL_get_verify_r
45e0: 65 73 75 6c 74 28 73 74 61 74 65 50 74 72 2d 3e  esult(statePtr->
45f0: 73 73 6c 29 20 21 3d 20 58 35 30 39 5f 56 5f 4f  ssl) != X509_V_O
4600: 4b 29 20 7b 0a 09 09 54 6c 73 5f 45 72 72 6f 72  K) {...Tls_Error
4610: 28 73 74 61 74 65 50 74 72 2c 20 28 63 68 61 72  (statePtr, (char
4620: 20 2a 29 20 58 35 30 39 5f 76 65 72 69 66 79 5f   *) X509_verify_
4630: 63 65 72 74 5f 65 72 72 6f 72 5f 73 74 72 69 6e  cert_error_strin
4640: 67 28 53 53 4c 5f 67 65 74 5f 76 65 72 69 66 79  g(SSL_get_verify
4650: 5f 72 65 73 75 6c 74 28 73 74 61 74 65 50 74 72  _result(statePtr
4660: 2d 3e 73 73 6c 29 29 29 3b 0a 09 20 20 20 20 7d  ->ssl)));..    }
4670: 20 65 6c 73 65 20 7b 0a 09 09 54 6c 73 5f 45 72   else {...Tls_Er
4680: 72 6f 72 28 73 74 61 74 65 50 74 72 2c 20 22 55  ror(statePtr, "U
4690: 6e 6b 6e 6f 77 6e 20 53 53 4c 20 65 72 72 6f 72  nknown SSL error
46a0: 22 29 3b 0a 09 20 20 20 20 7d 0a 09 20 20 20 20  ");..    }..    
46b0: 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 20 3d 20  *errorCodePtr = 
46c0: 45 43 4f 4e 4e 41 42 4f 52 54 45 44 3b 0a 09 20  ECONNABORTED;.. 
46d0: 20 20 20 77 72 69 74 74 65 6e 20 3d 20 2d 31 3b     written = -1;
46e0: 0a 09 20 20 20 20 62 72 65 61 6b 3b 0a 0a 09 64  ..    break;...d
46f0: 65 66 61 75 6c 74 3a 0a 09 20 20 20 20 64 70 72  efault:..    dpr
4700: 69 6e 74 66 28 22 75 6e 6b 6e 6f 77 6e 20 65 72  intf("unknown er
4710: 72 6f 72 3a 20 25 64 22 2c 20 65 72 72 29 3b 0a  ror: %d", err);.
4720: 09 20 20 20 20 54 6c 73 5f 45 72 72 6f 72 28 73  .    Tls_Error(s
4730: 74 61 74 65 50 74 72 2c 20 22 55 6e 6b 6e 6f 77  tatePtr, "Unknow
4740: 6e 20 65 72 72 6f 72 22 29 3b 0a 09 20 20 20 20  n error");..    
4750: 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a 0a 20 20  break;.    }..  
4760: 20 20 64 70 72 69 6e 74 66 28 22 4f 75 74 70 75    dprintf("Outpu
4770: 74 28 25 64 29 20 2d 3e 20 25 64 22 2c 20 74 6f  t(%d) -> %d", to
4780: 57 72 69 74 65 2c 20 77 72 69 74 74 65 6e 29 3b  Write, written);
4790: 0a 20 20 20 20 72 65 74 75 72 6e 28 77 72 69 74  .    return(writ
47a0: 74 65 6e 29 3b 0a 7d 0a 0a 2f 2a 0a 20 2a 2d 2d  ten);.}../*. *--
47b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
47c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
47d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
47e0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
47f0: 2d 0a 20 2a 0a 20 2a 20 54 6c 73 53 65 74 4f 70  -. *. * TlsSetOp
4800: 74 69 6f 6e 50 72 6f 63 20 2d 2d 0a 20 2a 0a 20  tionProc --. *. 
4810: 2a 20 20 20 20 53 65 74 73 20 61 6e 20 6f 70 74  *    Sets an opt
4820: 69 6f 6e 20 76 61 6c 75 65 20 66 6f 72 20 61 20  ion value for a 
4830: 53 53 4c 20 73 6f 63 6b 65 74 20 62 61 73 65 64  SSL socket based
4840: 20 63 68 61 6e 6e 65 6c 2c 20 6f 72 20 61 0a 20   channel, or a. 
4850: 2a 20 20 20 20 6c 69 73 74 20 6f 66 20 61 6c 6c  *    list of all
4860: 20 6f 70 74 69 6f 6e 73 20 61 6e 64 20 74 68 65   options and the
4870: 69 72 20 76 61 6c 75 65 73 2e 0a 20 2a 0a 20 2a  ir values.. *. *
4880: 20 52 65 73 75 6c 74 73 3a 0a 20 2a 20 20 20 20   Results:. *    
4890: 54 43 4c 5f 4f 4b 20 69 66 20 73 75 63 63 65 73  TCL_OK if succes
48a0: 73 66 75 6c 20 6f 72 20 54 43 4c 5f 45 52 52 4f  sful or TCL_ERRO
48b0: 52 20 69 66 20 66 61 69 6c 65 64 2e 0a 20 2a 0a  R if failed.. *.
48c0: 20 2a 20 53 69 64 65 20 65 66 66 65 63 74 73 3a   * Side effects:
48d0: 0a 20 2a 20 20 20 20 55 70 64 61 74 65 73 20 63  . *    Updates c
48e0: 68 61 6e 6e 65 6c 20 6f 70 74 69 6f 6e 20 74 6f  hannel option to
48f0: 20 6e 65 77 20 76 61 6c 75 65 2e 0a 20 2a 0a 20   new value.. *. 
4900: 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  *---------------
4910: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4920: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4930: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4940: 2d 2d 2d 2d 0a 20 2a 2f 0a 73 74 61 74 69 63 20  ----. */.static 
4950: 69 6e 74 0a 54 6c 73 53 65 74 4f 70 74 69 6f 6e  int.TlsSetOption
4960: 50 72 6f 63 28 43 6c 69 65 6e 74 44 61 74 61 20  Proc(ClientData 
4970: 69 6e 73 74 61 6e 63 65 44 61 74 61 2c 20 20 20  instanceData,   
4980: 20 2f 2a 20 53 6f 63 6b 65 74 20 73 74 61 74 65   /* Socket state
4990: 2e 20 2a 2f 0a 20 20 20 20 54 63 6c 5f 49 6e 74  . */.    Tcl_Int
49a0: 65 72 70 20 2a 69 6e 74 65 72 70 2c 09 09 2f 2a  erp *interp,../*
49b0: 20 46 6f 72 20 65 72 72 6f 72 73 20 2d 20 63 61   For errors - ca
49c0: 6e 20 62 65 20 4e 55 4c 4c 2e 20 2a 2f 0a 20 20  n be NULL. */.  
49d0: 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 6f 70    const char *op
49e0: 74 69 6f 6e 4e 61 6d 65 2c 09 2f 2a 20 4e 61 6d  tionName,./* Nam
49f0: 65 20 6f 66 20 74 68 65 20 6f 70 74 69 6f 6e 20  e of the option 
4a00: 74 6f 20 73 65 74 20 74 68 65 20 76 61 6c 75 65  to set the value
4a10: 20 66 6f 72 2c 20 6f 72 0a 09 09 09 09 20 2a 20   for, or..... * 
4a20: 4e 55 4c 4c 20 74 6f 20 67 65 74 20 61 6c 6c 20  NULL to get all 
4a30: 6f 70 74 69 6f 6e 73 20 61 6e 64 20 74 68 65 69  options and thei
4a40: 72 20 76 61 6c 75 65 73 2e 20 2a 2f 0a 20 20 20  r values. */.   
4a50: 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 6f 70 74   const char *opt
4a60: 69 6f 6e 56 61 6c 75 65 29 09 2f 2a 20 56 61 6c  ionValue)./* Val
4a70: 75 65 20 66 6f 72 20 6f 70 74 69 6f 6e 2e 20 2a  ue for option. *
4a80: 2f 0a 7b 0a 20 20 20 20 53 74 61 74 65 20 2a 73  /.{.    State *s
4a90: 74 61 74 65 50 74 72 20 3d 20 28 53 74 61 74 65  tatePtr = (State
4aa0: 20 2a 29 20 69 6e 73 74 61 6e 63 65 44 61 74 61   *) instanceData
4ab0: 3b 0a 0a 20 20 20 20 54 63 6c 5f 43 68 61 6e 6e  ;..    Tcl_Chann
4ac0: 65 6c 20 64 6f 77 6e 43 68 61 6e 20 3d 20 54 6c  el downChan = Tl
4ad0: 73 5f 47 65 74 50 61 72 65 6e 74 28 73 74 61 74  s_GetParent(stat
4ae0: 65 50 74 72 2c 20 54 4c 53 5f 54 43 4c 5f 46 41  ePtr, TLS_TCL_FA
4af0: 53 54 50 41 54 48 29 3b 0a 20 20 20 20 54 63 6c  STPATH);.    Tcl
4b00: 5f 44 72 69 76 65 72 53 65 74 4f 70 74 69 6f 6e  _DriverSetOption
4b10: 50 72 6f 63 20 2a 73 65 74 4f 70 74 69 6f 6e 50  Proc *setOptionP
4b20: 72 6f 63 3b 0a 0a 20 20 20 20 73 65 74 4f 70 74  roc;..    setOpt
4b30: 69 6f 6e 50 72 6f 63 20 3d 20 54 63 6c 5f 43 68  ionProc = Tcl_Ch
4b40: 61 6e 6e 65 6c 53 65 74 4f 70 74 69 6f 6e 50 72  annelSetOptionPr
4b50: 6f 63 28 54 63 6c 5f 47 65 74 43 68 61 6e 6e 65  oc(Tcl_GetChanne
4b60: 6c 54 79 70 65 28 64 6f 77 6e 43 68 61 6e 29 29  lType(downChan))
4b70: 3b 0a 20 20 20 20 69 66 20 28 73 65 74 4f 70 74  ;.    if (setOpt
4b80: 69 6f 6e 50 72 6f 63 20 21 3d 20 4e 55 4c 4c 29  ionProc != NULL)
4b90: 20 7b 0a 09 72 65 74 75 72 6e 20 28 2a 73 65 74   {..return (*set
4ba0: 4f 70 74 69 6f 6e 50 72 6f 63 29 28 54 63 6c 5f  OptionProc)(Tcl_
4bb0: 47 65 74 43 68 61 6e 6e 65 6c 49 6e 73 74 61 6e  GetChannelInstan
4bc0: 63 65 44 61 74 61 28 64 6f 77 6e 43 68 61 6e 29  ceData(downChan)
4bd0: 2c 20 69 6e 74 65 72 70 2c 20 6f 70 74 69 6f 6e  , interp, option
4be0: 4e 61 6d 65 2c 20 6f 70 74 69 6f 6e 56 61 6c 75  Name, optionValu
4bf0: 65 29 3b 0a 20 20 20 20 7d 20 65 6c 73 65 20 69  e);.    } else i
4c00: 66 20 28 6f 70 74 69 6f 6e 4e 61 6d 65 20 3d 3d  f (optionName ==
4c10: 20 28 63 68 61 72 2a 29 20 4e 55 4c 4c 29 20 7b   (char*) NULL) {
4c20: 0a 09 2f 2a 0a 09 20 2a 20 52 65 71 75 65 73 74  ../*.. * Request
4c30: 20 69 73 20 71 75 65 72 79 20 66 6f 72 20 61 6c   is query for al
4c40: 6c 20 6f 70 74 69 6f 6e 73 2c 20 74 68 69 73 20  l options, this 
4c50: 69 73 20 6f 6b 2e 0a 09 20 2a 2f 0a 09 72 65 74  is ok... */..ret
4c60: 75 72 6e 20 54 43 4c 5f 4f 4b 3b 0a 20 20 20 20  urn TCL_OK;.    
4c70: 7d 0a 20 20 20 20 2f 2a 0a 20 20 20 20 20 2a 20  }.    /*.     * 
4c80: 52 65 71 75 65 73 74 20 66 6f 72 20 61 20 73 70  Request for a sp
4c90: 65 63 69 66 69 63 20 6f 70 74 69 6f 6e 20 68 61  ecific option ha
4ca0: 73 20 74 6f 20 66 61 69 6c 2c 20 77 65 20 64 6f  s to fail, we do
4cb0: 6e 27 74 20 68 61 76 65 20 61 6e 79 2e 0a 20 20  n't have any..  
4cc0: 20 20 20 2a 2f 0a 20 20 20 20 72 65 74 75 72 6e     */.    return
4cd0: 20 54 63 6c 5f 42 61 64 43 68 61 6e 6e 65 6c 4f   Tcl_BadChannelO
4ce0: 70 74 69 6f 6e 28 69 6e 74 65 72 70 2c 20 6f 70  ption(interp, op
4cf0: 74 69 6f 6e 4e 61 6d 65 2c 20 22 22 29 3b 0a 7d  tionName, "");.}
4d00: 0a 0a 2f 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d  ../*. *---------
4d10: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4d20: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4d30: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4d40: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 0a 20 2a  ----------. *. *
4d50: 20 54 6c 73 47 65 74 4f 70 74 69 6f 6e 50 72 6f   TlsGetOptionPro
4d60: 63 20 2d 2d 0a 20 2a 0a 20 2a 20 20 20 20 47 65  c --. *. *    Ge
4d70: 74 73 20 61 6e 20 6f 70 74 69 6f 6e 20 76 61 6c  ts an option val
4d80: 75 65 20 66 6f 72 20 61 20 53 53 4c 20 73 6f 63  ue for a SSL soc
4d90: 6b 65 74 20 62 61 73 65 64 20 63 68 61 6e 6e 65  ket based channe
4da0: 6c 2c 20 6f 72 20 61 0a 20 2a 20 20 20 20 6c 69  l, or a. *    li
4db0: 73 74 20 6f 66 20 61 6c 6c 20 6f 70 74 69 6f 6e  st of all option
4dc0: 73 20 61 6e 64 20 74 68 65 69 72 20 76 61 6c 75  s and their valu
4dd0: 65 73 2e 0a 20 2a 0a 20 2a 20 52 65 73 75 6c 74  es.. *. * Result
4de0: 73 3a 0a 20 2a 20 20 20 20 41 20 73 74 61 6e 64  s:. *    A stand
4df0: 61 72 64 20 54 63 6c 20 72 65 73 75 6c 74 2e 20  ard Tcl result. 
4e00: 54 68 65 20 76 61 6c 75 65 20 6f 66 20 74 68 65  The value of the
4e10: 20 73 70 65 63 69 66 69 65 64 20 6f 70 74 69 6f   specified optio
4e20: 6e 20 6f 72 20 61 0a 20 2a 20 20 20 20 6c 69 73  n or a. *    lis
4e30: 74 20 6f 66 20 61 6c 6c 20 6f 70 74 69 6f 6e 73  t of all options
4e40: 20 61 6e 64 20 74 68 65 69 72 20 76 61 6c 75 65   and their value
4e50: 73 20 69 73 20 72 65 74 75 72 6e 65 64 20 69 6e  s is returned in
4e60: 20 74 68 65 0a 20 2a 20 20 20 20 73 75 70 70 6c   the. *    suppl
4e70: 69 65 64 20 44 53 74 72 69 6e 67 2e 0a 20 2a 0a  ied DString.. *.
4e80: 20 2a 20 53 69 64 65 20 65 66 66 65 63 74 73 3a   * Side effects:
4e90: 0a 20 2a 20 20 20 20 4e 6f 6e 65 2e 0a 20 2a 0a  . *    None.. *.
4ea0: 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d   *--------------
4eb0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4ec0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4ed0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4ee0: 2d 2d 2d 2d 2d 0a 20 2a 2f 0a 73 74 61 74 69 63  -----. */.static
4ef0: 20 69 6e 74 0a 54 6c 73 47 65 74 4f 70 74 69 6f   int.TlsGetOptio
4f00: 6e 50 72 6f 63 28 43 6c 69 65 6e 74 44 61 74 61  nProc(ClientData
4f10: 20 69 6e 73 74 61 6e 63 65 44 61 74 61 2c 20 20   instanceData,  
4f20: 20 20 2f 2a 20 53 6f 63 6b 65 74 20 73 74 61 74    /* Socket stat
4f30: 65 2e 20 2a 2f 0a 20 20 20 20 54 63 6c 5f 49 6e  e. */.    Tcl_In
4f40: 74 65 72 70 20 2a 69 6e 74 65 72 70 2c 09 09 2f  terp *interp,../
4f50: 2a 20 46 6f 72 20 65 72 72 6f 72 73 20 2d 20 63  * For errors - c
4f60: 61 6e 20 62 65 20 4e 55 4c 4c 2e 20 2a 2f 0a 20  an be NULL. */. 
4f70: 20 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 6f     const char *o
4f80: 70 74 69 6f 6e 4e 61 6d 65 2c 09 2f 2a 20 4e 61  ptionName,./* Na
4f90: 6d 65 20 6f 66 20 74 68 65 20 6f 70 74 69 6f 6e  me of the option
4fa0: 20 74 6f 20 72 65 74 72 69 65 76 65 20 74 68 65   to retrieve the
4fb0: 20 76 61 6c 75 65 20 66 6f 72 2c 20 6f 72 0a 09   value for, or..
4fc0: 09 09 09 20 2a 20 4e 55 4c 4c 20 74 6f 20 67 65  ... * NULL to ge
4fd0: 74 20 61 6c 6c 20 6f 70 74 69 6f 6e 73 20 61 6e  t all options an
4fe0: 64 20 74 68 65 69 72 20 76 61 6c 75 65 73 2e 20  d their values. 
4ff0: 2a 2f 0a 20 20 20 20 54 63 6c 5f 44 53 74 72 69  */.    Tcl_DStri
5000: 6e 67 20 2a 6f 70 74 69 6f 6e 56 61 6c 75 65 29  ng *optionValue)
5010: 09 2f 2a 20 57 68 65 72 65 20 74 6f 20 73 74 6f  ./* Where to sto
5020: 72 65 20 74 68 65 20 63 6f 6d 70 75 74 65 64 20  re the computed 
5030: 76 61 6c 75 65 20 69 6e 69 74 69 61 6c 69 7a 65  value initialize
5040: 64 20 62 79 20 63 61 6c 6c 65 72 2e 20 2a 2f 0a  d by caller. */.
5050: 7b 0a 20 20 20 20 53 74 61 74 65 20 2a 73 74 61  {.    State *sta
5060: 74 65 50 74 72 20 3d 20 28 53 74 61 74 65 20 2a  tePtr = (State *
5070: 29 20 69 6e 73 74 61 6e 63 65 44 61 74 61 3b 0a  ) instanceData;.
5080: 0a 20 20 20 20 54 63 6c 5f 43 68 61 6e 6e 65 6c  .    Tcl_Channel
5090: 20 64 6f 77 6e 43 68 61 6e 20 3d 20 54 6c 73 5f   downChan = Tls_
50a0: 47 65 74 50 61 72 65 6e 74 28 73 74 61 74 65 50  GetParent(stateP
50b0: 74 72 2c 20 54 4c 53 5f 54 43 4c 5f 46 41 53 54  tr, TLS_TCL_FAST
50c0: 50 41 54 48 29 3b 0a 20 20 20 20 54 63 6c 5f 44  PATH);.    Tcl_D
50d0: 72 69 76 65 72 47 65 74 4f 70 74 69 6f 6e 50 72  riverGetOptionPr
50e0: 6f 63 20 2a 67 65 74 4f 70 74 69 6f 6e 50 72 6f  oc *getOptionPro
50f0: 63 3b 0a 0a 20 20 20 20 67 65 74 4f 70 74 69 6f  c;..    getOptio
5100: 6e 50 72 6f 63 20 3d 20 54 63 6c 5f 43 68 61 6e  nProc = Tcl_Chan
5110: 6e 65 6c 47 65 74 4f 70 74 69 6f 6e 50 72 6f 63  nelGetOptionProc
5120: 28 54 63 6c 5f 47 65 74 43 68 61 6e 6e 65 6c 54  (Tcl_GetChannelT
5130: 79 70 65 28 64 6f 77 6e 43 68 61 6e 29 29 3b 0a  ype(downChan));.
5140: 20 20 20 20 69 66 20 28 67 65 74 4f 70 74 69 6f      if (getOptio
5150: 6e 50 72 6f 63 20 21 3d 20 4e 55 4c 4c 29 20 7b  nProc != NULL) {
5160: 0a 09 72 65 74 75 72 6e 20 28 2a 67 65 74 4f 70  ..return (*getOp
5170: 74 69 6f 6e 50 72 6f 63 29 28 54 63 6c 5f 47 65  tionProc)(Tcl_Ge
5180: 74 43 68 61 6e 6e 65 6c 49 6e 73 74 61 6e 63 65  tChannelInstance
5190: 44 61 74 61 28 64 6f 77 6e 43 68 61 6e 29 2c 20  Data(downChan), 
51a0: 69 6e 74 65 72 70 2c 20 6f 70 74 69 6f 6e 4e 61  interp, optionNa
51b0: 6d 65 2c 20 6f 70 74 69 6f 6e 56 61 6c 75 65 29  me, optionValue)
51c0: 3b 0a 20 20 20 20 7d 20 65 6c 73 65 20 69 66 20  ;.    } else if 
51d0: 28 6f 70 74 69 6f 6e 4e 61 6d 65 20 3d 3d 20 28  (optionName == (
51e0: 63 68 61 72 2a 29 20 4e 55 4c 4c 29 20 7b 0a 09  char*) NULL) {..
51f0: 2f 2a 0a 09 20 2a 20 52 65 71 75 65 73 74 20 69  /*.. * Request i
5200: 73 20 71 75 65 72 79 20 66 6f 72 20 61 6c 6c 20  s query for all 
5210: 6f 70 74 69 6f 6e 73 2c 20 74 68 69 73 20 69 73  options, this is
5220: 20 6f 6b 2e 0a 09 20 2a 2f 0a 09 72 65 74 75 72   ok... */..retur
5230: 6e 20 54 43 4c 5f 4f 4b 3b 0a 20 20 20 20 7d 0a  n TCL_OK;.    }.
5240: 20 20 20 20 2f 2a 0a 20 20 20 20 20 2a 20 52 65      /*.     * Re
5250: 71 75 65 73 74 20 66 6f 72 20 61 20 73 70 65 63  quest for a spec
5260: 69 66 69 63 20 6f 70 74 69 6f 6e 20 68 61 73 20  ific option has 
5270: 74 6f 20 66 61 69 6c 2c 20 77 65 20 64 6f 6e 27  to fail, we don'
5280: 74 20 68 61 76 65 20 61 6e 79 2e 0a 20 20 20 20  t have any..    
5290: 20 2a 2f 0a 20 20 20 20 72 65 74 75 72 6e 20 54   */.    return T
52a0: 63 6c 5f 42 61 64 43 68 61 6e 6e 65 6c 4f 70 74  cl_BadChannelOpt
52b0: 69 6f 6e 28 69 6e 74 65 72 70 2c 20 6f 70 74 69  ion(interp, opti
52c0: 6f 6e 4e 61 6d 65 2c 20 22 22 29 3b 0a 7d 0a 0a  onName, "");.}..
52d0: 2f 2a 0a 20 2a 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 2d 2d 2d 2d 2d 2d 2d  ----------------
5300: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5310: 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 0a 20 2a 20 54  --------. *. * T
5320: 6c 73 57 61 74 63 68 50 72 6f 63 20 2d 2d 0a 20  lsWatchProc --. 
5330: 2a 0a 20 2a 20 20 20 20 49 6e 69 74 69 61 6c 69  *. *    Initiali
5340: 7a 65 20 74 68 65 20 6e 6f 74 69 66 69 65 72 20  ze the notifier 
5350: 74 6f 20 77 61 74 63 68 20 54 63 6c 5f 46 69 6c  to watch Tcl_Fil
5360: 65 73 20 66 72 6f 6d 20 74 68 69 73 20 63 68 61  es from this cha
5370: 6e 6e 65 6c 2e 0a 20 2a 0a 20 2a 20 52 65 73 75  nnel.. *. * Resu
5380: 6c 74 73 3a 0a 20 2a 20 20 20 20 4e 6f 6e 65 2e  lts:. *    None.
5390: 0a 20 2a 0a 20 2a 20 53 69 64 65 20 65 66 66 65  . *. * Side effe
53a0: 63 74 73 3a 0a 20 2a 20 20 20 20 53 65 74 73 20  cts:. *    Sets 
53b0: 75 70 20 74 68 65 20 6e 6f 74 69 66 69 65 72 20  up the notifier 
53c0: 73 6f 20 74 68 61 74 20 61 20 66 75 74 75 72 65  so that a future
53d0: 20 65 76 65 6e 74 20 6f 6e 20 74 68 65 20 63 68   event on the ch
53e0: 61 6e 6e 65 6c 0a 20 2a 20 20 20 20 77 69 6c 6c  annel. *    will
53f0: 20 62 65 20 73 65 65 6e 20 62 79 20 54 63 6c 2e   be seen by Tcl.
5400: 0a 20 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  . *. *----------
5410: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5420: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5430: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5440: 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 2f 0a 73 74  ---------. */.st
5450: 61 74 69 63 20 76 6f 69 64 0a 54 6c 73 57 61 74  atic void.TlsWat
5460: 63 68 50 72 6f 63 28 43 6c 69 65 6e 74 44 61 74  chProc(ClientDat
5470: 61 20 69 6e 73 74 61 6e 63 65 44 61 74 61 2c 20  a instanceData, 
5480: 20 20 20 2f 2a 20 54 68 65 20 73 6f 63 6b 65 74     /* The socket
5490: 20 73 74 61 74 65 2e 20 2a 2f 0a 20 20 20 20 69   state. */.    i
54a0: 6e 74 20 6d 61 73 6b 29 09 09 09 2f 2a 20 45 76  nt mask).../* Ev
54b0: 65 6e 74 73 20 6f 66 20 69 6e 74 65 72 65 73 74  ents of interest
54c0: 3b 20 61 6e 20 4f 52 2d 65 64 20 63 6f 6d 62 69  ; an OR-ed combi
54d0: 6e 61 74 69 6f 6e 20 6f 66 0a 09 09 09 09 20 2a  nation of..... *
54e0: 20 54 43 4c 5f 52 45 41 44 41 42 4c 45 2c 20 54   TCL_READABLE, T
54f0: 43 4c 5f 57 52 49 54 41 42 4c 45 20 61 6e 64 20  CL_WRITABLE and 
5500: 54 43 4c 5f 45 58 43 45 50 54 49 4f 4e 2e 20 2a  TCL_EXCEPTION. *
5510: 2f 0a 7b 0a 20 20 20 20 54 63 6c 5f 43 68 61 6e  /.{.    Tcl_Chan
5520: 6e 65 6c 20 20 20 20 20 64 6f 77 6e 43 68 61 6e  nel     downChan
5530: 3b 0a 20 20 20 20 53 74 61 74 65 20 2a 73 74 61  ;.    State *sta
5540: 74 65 50 74 72 20 3d 20 28 53 74 61 74 65 20 2a  tePtr = (State *
5550: 29 20 69 6e 73 74 61 6e 63 65 44 61 74 61 3b 0a  ) instanceData;.
5560: 20 20 20 20 54 63 6c 5f 44 72 69 76 65 72 57 61      Tcl_DriverWa
5570: 74 63 68 50 72 6f 63 20 2a 77 61 74 63 68 50 72  tchProc *watchPr
5580: 6f 63 3b 0a 0a 20 20 20 20 64 70 72 69 6e 74 66  oc;..    dprintf
5590: 28 22 54 6c 73 57 61 74 63 68 50 72 6f 63 28 30  ("TlsWatchProc(0
55a0: 78 25 78 29 22 2c 20 6d 61 73 6b 29 3b 0a 0a 20  x%x)", mask);.. 
55b0: 20 20 20 2f 2a 20 50 72 65 74 65 6e 64 20 74 6f     /* Pretend to
55c0: 20 62 65 20 64 65 61 64 20 61 73 20 6c 6f 6e 67   be dead as long
55d0: 20 61 73 20 74 68 65 20 76 65 72 69 66 79 20 63   as the verify c
55e0: 61 6c 6c 62 61 63 6b 20 69 73 20 72 75 6e 6e 69  allback is runni
55f0: 6e 67 2e 0a 20 20 20 20 20 2a 20 4f 74 68 65 72  ng..     * Other
5600: 77 69 73 65 20 74 68 61 74 20 63 61 6c 6c 62 61  wise that callba
5610: 63 6b 20 63 6f 75 6c 64 20 62 65 20 69 6e 76 6f  ck could be invo
5620: 6b 65 64 20 72 65 63 75 72 73 69 76 65 6c 79 2e  ked recursively.
5630: 20 2a 2f 0a 20 20 20 20 69 66 20 28 73 74 61 74   */.    if (stat
5640: 65 50 74 72 2d 3e 66 6c 61 67 73 20 26 20 54 4c  ePtr->flags & TL
5650: 53 5f 54 43 4c 5f 43 41 4c 4c 42 41 43 4b 29 20  S_TCL_CALLBACK) 
5660: 7b 0a 09 64 70 72 69 6e 74 66 28 22 43 61 6c 6c  {..dprintf("Call
5670: 62 61 63 6b 20 69 73 20 6f 6e 2d 67 6f 69 6e 67  back is on-going
5680: 2c 20 64 6f 69 6e 67 20 6e 6f 74 68 69 6e 67 22  , doing nothing"
5690: 29 3b 0a 09 72 65 74 75 72 6e 3b 0a 20 20 20 20  );..return;.    
56a0: 7d 0a 0a 20 20 20 20 64 70 72 69 6e 74 46 6c 61  }..    dprintFla
56b0: 67 73 28 73 74 61 74 65 50 74 72 29 3b 0a 0a 20  gs(statePtr);.. 
56c0: 20 20 20 64 6f 77 6e 43 68 61 6e 20 3d 20 54 6c     downChan = Tl
56d0: 73 5f 47 65 74 50 61 72 65 6e 74 28 73 74 61 74  s_GetParent(stat
56e0: 65 50 74 72 2c 20 54 4c 53 5f 54 43 4c 5f 46 41  ePtr, TLS_TCL_FA
56f0: 53 54 50 41 54 48 29 3b 0a 0a 20 20 20 20 69 66  STPATH);..    if
5700: 20 28 73 74 61 74 65 50 74 72 2d 3e 66 6c 61 67   (statePtr->flag
5710: 73 20 26 20 54 4c 53 5f 54 43 4c 5f 48 41 4e 44  s & TLS_TCL_HAND
5720: 53 48 41 4b 45 5f 46 41 49 4c 45 44 29 20 7b 0a  SHAKE_FAILED) {.
5730: 09 64 70 72 69 6e 74 66 28 22 41 73 6b 65 64 20  .dprintf("Asked 
5740: 74 6f 20 77 61 74 63 68 20 61 20 73 6f 63 6b 65  to watch a socke
5750: 74 20 77 69 74 68 20 61 20 66 61 69 6c 65 64 20  t with a failed 
5760: 68 61 6e 64 73 68 61 6b 65 20 2d 2d 20 6e 6f 74  handshake -- not
5770: 68 69 6e 67 20 63 61 6e 20 68 61 70 70 65 6e 20  hing can happen 
5780: 68 65 72 65 22 29 3b 0a 09 64 70 72 69 6e 74 66  here");..dprintf
5790: 28 22 55 6e 72 65 67 69 73 74 65 72 69 6e 67 20  ("Unregistering 
57a0: 69 6e 74 65 72 65 73 74 20 69 6e 20 74 68 65 20  interest in the 
57b0: 6c 6f 77 65 72 20 63 68 61 6e 6e 65 6c 22 29 3b  lower channel");
57c0: 0a 0a 09 77 61 74 63 68 50 72 6f 63 20 3d 20 54  ...watchProc = T
57d0: 63 6c 5f 43 68 61 6e 6e 65 6c 57 61 74 63 68 50  cl_ChannelWatchP
57e0: 72 6f 63 28 54 63 6c 5f 47 65 74 43 68 61 6e 6e  roc(Tcl_GetChann
57f0: 65 6c 54 79 70 65 28 64 6f 77 6e 43 68 61 6e 29  elType(downChan)
5800: 29 3b 0a 09 77 61 74 63 68 50 72 6f 63 28 54 63  );..watchProc(Tc
5810: 6c 5f 47 65 74 43 68 61 6e 6e 65 6c 49 6e 73 74  l_GetChannelInst
5820: 61 6e 63 65 44 61 74 61 28 64 6f 77 6e 43 68 61  anceData(downCha
5830: 6e 29 2c 20 30 29 3b 0a 09 73 74 61 74 65 50 74  n), 0);..statePt
5840: 72 2d 3e 77 61 74 63 68 4d 61 73 6b 20 3d 20 30  r->watchMask = 0
5850: 3b 0a 09 72 65 74 75 72 6e 3b 0a 20 20 20 20 7d  ;..return;.    }
5860: 0a 0a 20 20 20 20 73 74 61 74 65 50 74 72 2d 3e  ..    statePtr->
5870: 77 61 74 63 68 4d 61 73 6b 20 3d 20 6d 61 73 6b  watchMask = mask
5880: 3b 0a 0a 20 20 20 20 2f 2a 20 4e 6f 20 63 68 61  ;..    /* No cha
5890: 6e 6e 65 6c 20 68 61 6e 64 6c 65 72 73 20 61 6e  nnel handlers an
58a0: 79 20 6d 6f 72 65 2e 20 57 65 20 77 69 6c 6c 20  y more. We will 
58b0: 62 65 20 6e 6f 74 69 66 69 65 64 20 61 75 74 6f  be notified auto
58c0: 6d 61 74 69 63 61 6c 6c 79 0a 20 20 20 20 20 2a  matically.     *
58d0: 20 61 62 6f 75 74 20 65 76 65 6e 74 73 20 6f 6e   about events on
58e0: 20 74 68 65 20 63 68 61 6e 6e 65 6c 20 62 65 6c   the channel bel
58f0: 6f 77 20 76 69 61 20 61 20 63 61 6c 6c 20 74 6f  ow via a call to
5900: 20 6f 75 72 0a 20 20 20 20 20 2a 20 27 54 72 61   our.     * 'Tra
5910: 6e 73 66 6f 72 6d 4e 6f 74 69 66 79 50 72 6f 63  nsformNotifyProc
5920: 27 2e 20 42 75 74 20 77 65 20 68 61 76 65 20 74  '. But we have t
5930: 6f 20 70 61 73 73 20 74 68 65 20 69 6e 74 65 72  o pass the inter
5940: 65 73 74 20 64 6f 77 6e 20 6e 6f 77 2e 0a 20 20  est down now..  
5950: 20 20 20 2a 20 57 65 20 61 72 65 20 61 6c 6c 6f     * We are allo
5960: 77 65 64 20 74 6f 20 61 64 64 20 61 64 64 69 74  wed to add addit
5970: 69 6f 6e 61 6c 20 27 69 6e 74 65 72 65 73 74 27  ional 'interest'
5980: 20 74 6f 20 74 68 65 20 6d 61 73 6b 20 69 66 20   to the mask if 
5990: 77 65 20 77 61 6e 74 0a 20 20 20 20 20 2a 20 74  we want.     * t
59a0: 6f 2e 20 42 75 74 20 74 68 69 73 20 74 72 61 6e  o. But this tran
59b0: 73 66 6f 72 6d 61 74 69 6f 6e 20 68 61 73 20 6e  sformation has n
59c0: 6f 20 73 75 63 68 20 69 6e 74 65 72 65 73 74 2e  o such interest.
59d0: 20 49 74 20 6a 75 73 74 20 70 61 73 73 65 73 0a   It just passes.
59e0: 20 20 20 20 20 2a 20 74 68 65 20 72 65 71 75 65       * the reque
59f0: 73 74 20 64 6f 77 6e 2c 20 75 6e 63 68 61 6e 67  st down, unchang
5a00: 65 64 2e 0a 20 20 20 20 20 2a 2f 0a 20 20 20 20  ed..     */.    
5a10: 64 70 72 69 6e 74 66 28 22 52 65 67 69 73 74 65  dprintf("Registe
5a20: 72 69 6e 67 20 6f 75 72 20 69 6e 74 65 72 65 73  ring our interes
5a30: 74 20 69 6e 20 74 68 65 20 6c 6f 77 65 72 20 63  t in the lower c
5a40: 68 61 6e 6e 65 6c 20 28 63 68 61 6e 3d 25 70 29  hannel (chan=%p)
5a50: 22 2c 20 28 76 6f 69 64 20 2a 29 20 64 6f 77 6e  ", (void *) down
5a60: 43 68 61 6e 29 3b 0a 20 20 20 20 77 61 74 63 68  Chan);.    watch
5a70: 50 72 6f 63 20 3d 20 54 63 6c 5f 43 68 61 6e 6e  Proc = Tcl_Chann
5a80: 65 6c 57 61 74 63 68 50 72 6f 63 28 54 63 6c 5f  elWatchProc(Tcl_
5a90: 47 65 74 43 68 61 6e 6e 65 6c 54 79 70 65 28 64  GetChannelType(d
5aa0: 6f 77 6e 43 68 61 6e 29 29 3b 0a 20 20 20 20 77  ownChan));.    w
5ab0: 61 74 63 68 50 72 6f 63 28 54 63 6c 5f 47 65 74  atchProc(Tcl_Get
5ac0: 43 68 61 6e 6e 65 6c 49 6e 73 74 61 6e 63 65 44  ChannelInstanceD
5ad0: 61 74 61 28 64 6f 77 6e 43 68 61 6e 29 2c 20 6d  ata(downChan), m
5ae0: 61 73 6b 29 3b 0a 0a 0a 20 20 20 20 2f 2a 0a 20  ask);...    /*. 
5af0: 20 20 20 20 2a 20 4d 61 6e 61 67 65 6d 65 6e 74      * Management
5b00: 20 6f 66 20 74 68 65 20 69 6e 74 65 72 6e 61 6c   of the internal
5b10: 20 74 69 6d 65 72 2e 0a 20 20 20 20 20 2a 2f 0a   timer..     */.
5b20: 20 20 20 20 69 66 20 28 73 74 61 74 65 50 74 72      if (statePtr
5b30: 2d 3e 74 69 6d 65 72 20 21 3d 20 28 54 63 6c 5f  ->timer != (Tcl_
5b40: 54 69 6d 65 72 54 6f 6b 65 6e 29 20 4e 55 4c 4c  TimerToken) NULL
5b50: 29 20 7b 0a 09 64 70 72 69 6e 74 66 28 22 41 20  ) {..dprintf("A 
5b60: 74 69 6d 65 72 20 77 61 73 20 66 6f 75 6e 64 2c  timer was found,
5b70: 20 64 65 6c 65 74 69 6e 67 20 69 74 22 29 3b 0a   deleting it");.
5b80: 09 54 63 6c 5f 44 65 6c 65 74 65 54 69 6d 65 72  .Tcl_DeleteTimer
5b90: 48 61 6e 64 6c 65 72 28 73 74 61 74 65 50 74 72  Handler(statePtr
5ba0: 2d 3e 74 69 6d 65 72 29 3b 0a 09 73 74 61 74 65  ->timer);..state
5bb0: 50 74 72 2d 3e 74 69 6d 65 72 20 3d 20 28 54 63  Ptr->timer = (Tc
5bc0: 6c 5f 54 69 6d 65 72 54 6f 6b 65 6e 29 20 4e 55  l_TimerToken) NU
5bd0: 4c 4c 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69  LL;.    }..    i
5be0: 66 20 28 28 6d 61 73 6b 20 26 20 54 43 4c 5f 52  f ((mask & TCL_R
5bf0: 45 41 44 41 42 4c 45 29 20 26 26 0a 09 28 28 54  EADABLE) &&..((T
5c00: 63 6c 5f 49 6e 70 75 74 42 75 66 66 65 72 65 64  cl_InputBuffered
5c10: 28 73 74 61 74 65 50 74 72 2d 3e 73 65 6c 66 29  (statePtr->self)
5c20: 20 3e 20 30 29 20 7c 7c 20 28 42 49 4f 5f 63 74   > 0) || (BIO_ct
5c30: 72 6c 5f 70 65 6e 64 69 6e 67 28 73 74 61 74 65  rl_pending(state
5c40: 50 74 72 2d 3e 62 69 6f 29 20 3e 20 30 29 29 29  Ptr->bio) > 0)))
5c50: 20 7b 0a 09 2f 2a 0a 09 20 2a 20 54 68 65 72 65   {../*.. * There
5c60: 20 69 73 20 69 6e 74 65 72 65 73 74 20 69 6e 20   is interest in 
5c70: 72 65 61 64 61 62 6c 65 20 65 76 65 6e 74 73 20  readable events 
5c80: 61 6e 64 20 77 65 20 61 63 74 75 61 6c 6c 79 20  and we actually 
5c90: 68 61 76 65 0a 09 20 2a 20 64 61 74 61 20 77 61  have.. * data wa
5ca0: 69 74 69 6e 67 2c 20 73 6f 20 67 65 6e 65 72 61  iting, so genera
5cb0: 74 65 20 61 20 74 69 6d 65 72 20 74 6f 20 66 6c  te a timer to fl
5cc0: 75 73 68 20 74 68 61 74 2e 0a 09 20 2a 2f 0a 09  ush that... */..
5cd0: 64 70 72 69 6e 74 66 28 22 43 72 65 61 74 69 6e  dprintf("Creatin
5ce0: 67 20 61 20 6e 65 77 20 74 69 6d 65 72 20 73 69  g a new timer si
5cf0: 6e 63 65 20 64 61 74 61 20 61 70 70 65 61 72 73  nce data appears
5d00: 20 74 6f 20 62 65 20 77 61 69 74 69 6e 67 22 29   to be waiting")
5d10: 3b 0a 09 73 74 61 74 65 50 74 72 2d 3e 74 69 6d  ;..statePtr->tim
5d20: 65 72 20 3d 20 54 63 6c 5f 43 72 65 61 74 65 54  er = Tcl_CreateT
5d30: 69 6d 65 72 48 61 6e 64 6c 65 72 28 54 4c 53 5f  imerHandler(TLS_
5d40: 54 43 4c 5f 44 45 4c 41 59 2c 20 54 6c 73 43 68  TCL_DELAY, TlsCh
5d50: 61 6e 6e 65 6c 48 61 6e 64 6c 65 72 54 69 6d 65  annelHandlerTime
5d60: 72 2c 20 28 43 6c 69 65 6e 74 44 61 74 61 29 20  r, (ClientData) 
5d70: 73 74 61 74 65 50 74 72 29 3b 0a 20 20 20 20 7d  statePtr);.    }
5d80: 0a 7d 0a 0a 2f 2a 0a 20 2a 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 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5dc0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 0a  ------------. *.
5dd0: 20 2a 20 54 6c 73 47 65 74 48 61 6e 64 6c 65 50   * TlsGetHandleP
5de0: 72 6f 63 20 2d 2d 0a 20 2a 0a 20 2a 20 20 20 20  roc --. *. *    
5df0: 43 61 6c 6c 65 64 20 66 72 6f 6d 20 54 63 6c 5f  Called from Tcl_
5e00: 47 65 74 43 68 61 6e 6e 65 6c 46 69 6c 65 20 74  GetChannelFile t
5e10: 6f 20 72 65 74 72 69 65 76 65 20 6f 2f 73 20 66  o retrieve o/s f
5e20: 69 6c 65 20 68 61 6e 64 6c 65 72 0a 20 2a 20 20  ile handler. *  
5e30: 20 20 66 72 6f 6d 20 74 68 65 20 53 53 4c 20 73    from the SSL s
5e40: 6f 63 6b 65 74 20 62 61 73 65 64 20 63 68 61 6e  ocket based chan
5e50: 6e 65 6c 2e 0a 20 2a 0a 20 2a 20 52 65 73 75 6c  nel.. *. * Resul
5e60: 74 73 3a 0a 20 2a 20 20 20 20 54 68 65 20 61 70  ts:. *    The ap
5e70: 70 72 6f 70 72 69 61 74 65 20 54 63 6c 5f 46 69  propriate Tcl_Fi
5e80: 6c 65 20 68 61 6e 64 6c 65 20 6f 72 20 4e 55 4c  le handle or NUL
5e90: 4c 20 69 66 20 6e 6f 6e 65 2e 0a 20 2a 0a 20 2a  L if none.. *. *
5ea0: 20 53 69 64 65 20 65 66 66 65 63 74 73 3a 0a 20   Side effects:. 
5eb0: 2a 20 20 20 20 4e 6f 6e 65 2e 0a 20 2a 0a 20 2a  *    None.. *. *
5ec0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5ed0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5ee0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5ef0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5f00: 2d 2d 2d 0a 20 2a 2f 0a 73 74 61 74 69 63 20 69  ---. */.static i
5f10: 6e 74 20 54 6c 73 47 65 74 48 61 6e 64 6c 65 50  nt TlsGetHandleP
5f20: 72 6f 63 28 43 6c 69 65 6e 74 44 61 74 61 20 69  roc(ClientData i
5f30: 6e 73 74 61 6e 63 65 44 61 74 61 2c 20 20 20 20  nstanceData,    
5f40: 2f 2a 20 53 6f 63 6b 65 74 20 73 74 61 74 65 2e  /* Socket state.
5f50: 20 2a 2f 0a 20 20 20 20 69 6e 74 20 64 69 72 65   */.    int dire
5f60: 63 74 69 6f 6e 2c 09 09 2f 2a 20 54 43 4c 5f 52  ction,../* TCL_R
5f70: 45 41 44 41 42 4c 45 20 6f 72 20 54 43 4c 5f 57  EADABLE or TCL_W
5f80: 52 49 54 41 42 4c 45 20 2a 2f 0a 20 20 20 20 43  RITABLE */.    C
5f90: 6c 69 65 6e 74 44 61 74 61 20 2a 68 61 6e 64 6c  lientData *handl
5fa0: 65 50 74 72 29 09 2f 2a 20 48 61 6e 64 6c 65 20  ePtr)./* Handle 
5fb0: 61 73 73 6f 63 69 61 74 65 64 20 77 69 74 68 20  associated with 
5fc0: 74 68 65 20 63 68 61 6e 6e 65 6c 20 2a 2f 0a 7b  the channel */.{
5fd0: 0a 20 20 20 20 53 74 61 74 65 20 2a 73 74 61 74  .    State *stat
5fe0: 65 50 74 72 20 3d 20 28 53 74 61 74 65 20 2a 29  ePtr = (State *)
5ff0: 20 69 6e 73 74 61 6e 63 65 44 61 74 61 3b 0a 0a   instanceData;..
6000: 20 20 20 20 72 65 74 75 72 6e 28 54 63 6c 5f 47      return(Tcl_G
6010: 65 74 43 68 61 6e 6e 65 6c 48 61 6e 64 6c 65 28  etChannelHandle(
6020: 54 6c 73 5f 47 65 74 50 61 72 65 6e 74 28 73 74  Tls_GetParent(st
6030: 61 74 65 50 74 72 2c 20 54 4c 53 5f 54 43 4c 5f  atePtr, TLS_TCL_
6040: 46 41 53 54 50 41 54 48 29 2c 20 64 69 72 65 63  FASTPATH), direc
6050: 74 69 6f 6e 2c 20 68 61 6e 64 6c 65 50 74 72 29  tion, handlePtr)
6060: 29 3b 0a 7d 0a 0a 2f 2a 0a 20 2a 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 2d 2d 2d  ----------------
6090: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
60a0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20  --------------. 
60b0: 2a 0a 20 2a 20 54 6c 73 4e 6f 74 69 66 79 50 72  *. * TlsNotifyPr
60c0: 6f 63 20 2d 2d 0a 20 2a 0a 20 2a 20 20 20 20 48  oc --. *. *    H
60d0: 61 6e 64 6c 65 72 20 63 61 6c 6c 65 64 20 62 79  andler called by
60e0: 20 54 63 6c 20 74 6f 20 69 6e 66 6f 72 6d 20 75   Tcl to inform u
60f0: 73 20 6f 66 20 61 63 74 69 76 69 74 79 0a 20 2a  s of activity. *
6100: 20 20 20 20 6f 6e 20 74 68 65 20 75 6e 64 65 72      on the under
6110: 6c 79 69 6e 67 20 63 68 61 6e 6e 65 6c 2e 0a 20  lying channel.. 
6120: 2a 0a 20 2a 20 52 65 73 75 6c 74 73 3a 0a 20 2a  *. * Results:. *
6130: 20 20 20 20 54 79 70 65 20 6f 66 20 65 76 65 6e      Type of even
6140: 74 20 6f 72 20 30 20 69 66 20 66 61 69 6c 65 64  t or 0 if failed
6150: 0a 20 2a 0a 20 2a 20 53 69 64 65 20 65 66 66 65  . *. * Side effe
6160: 63 74 73 3a 0a 20 2a 20 20 20 20 4d 61 79 20 70  cts:. *    May p
6170: 72 6f 63 65 73 73 20 74 68 65 20 69 6e 63 6f 6d  rocess the incom
6180: 69 6e 67 20 65 76 65 6e 74 20 62 79 20 69 74 73  ing event by its
6190: 65 6c 66 2e 0a 20 2a 0a 20 2a 2d 2d 2d 2d 2d 2d  elf.. *. *------
61a0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
61b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
61c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
61d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a  -------------. *
61e0: 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 54 6c 73  /.static int Tls
61f0: 4e 6f 74 69 66 79 50 72 6f 63 28 43 6c 69 65 6e  NotifyProc(Clien
6200: 74 44 61 74 61 20 69 6e 73 74 61 6e 63 65 44 61  tData instanceDa
6210: 74 61 2c 20 20 20 20 2f 2a 20 53 6f 63 6b 65 74  ta,    /* Socket
6220: 20 73 74 61 74 65 2e 20 2a 2f 0a 20 20 20 20 69   state. */.    i
6230: 6e 74 20 6d 61 73 6b 29 09 09 09 2f 2a 20 74 79  nt mask).../* ty
6240: 70 65 20 6f 66 20 65 76 65 6e 74 20 74 68 61 74  pe of event that
6250: 20 6f 63 63 75 72 72 65 64 3a 0a 09 09 09 09 20   occurred:..... 
6260: 2a 20 4f 52 2d 65 64 20 63 6f 6d 62 69 6e 61 74  * OR-ed combinat
6270: 69 6f 6e 20 6f 66 20 54 43 4c 5f 52 45 41 44 41  ion of TCL_READA
6280: 42 4c 45 20 6f 72 20 54 43 4c 5f 57 52 49 54 41  BLE or TCL_WRITA
6290: 42 4c 45 20 2a 2f 0a 7b 0a 20 20 20 20 53 74 61  BLE */.{.    Sta
62a0: 74 65 20 2a 73 74 61 74 65 50 74 72 20 3d 20 28  te *statePtr = (
62b0: 53 74 61 74 65 20 2a 29 20 69 6e 73 74 61 6e 63  State *) instanc
62c0: 65 44 61 74 61 3b 0a 20 20 20 20 69 6e 74 20 65  eData;.    int e
62d0: 72 72 6f 72 43 6f 64 65 3b 0a 0a 20 20 20 20 2f  rrorCode;..    /
62e0: 2a 0a 20 20 20 20 20 2a 20 41 6e 20 65 76 65 6e  *.     * An even
62f0: 74 20 6f 63 63 75 72 72 65 64 20 69 6e 20 74 68  t occurred in th
6300: 65 20 75 6e 64 65 72 6c 79 69 6e 67 20 63 68 61  e underlying cha
6310: 6e 6e 65 6c 2e 20 20 54 68 69 73 0a 20 20 20 20  nnel.  This.    
6320: 20 2a 20 74 72 61 6e 73 66 6f 72 6d 61 74 69 6f   * transformatio
6330: 6e 20 64 6f 65 73 6e 27 74 20 70 72 6f 63 65 73  n doesn't proces
6340: 73 20 73 75 63 68 20 65 76 65 6e 74 73 20 74 68  s such events th
6350: 75 73 20 72 65 74 75 72 6e 73 20 74 68 65 0a 20  us returns the. 
6360: 20 20 20 20 2a 20 69 6e 63 6f 6d 69 6e 67 20 6d      * incoming m
6370: 61 73 6b 20 75 6e 63 68 61 6e 67 65 64 2e 0a 20  ask unchanged.. 
6380: 20 20 20 20 2a 2f 0a 20 20 20 20 69 66 20 28 73      */.    if (s
6390: 74 61 74 65 50 74 72 2d 3e 74 69 6d 65 72 20 21  tatePtr->timer !
63a0: 3d 20 28 54 63 6c 5f 54 69 6d 65 72 54 6f 6b 65  = (Tcl_TimerToke
63b0: 6e 29 20 4e 55 4c 4c 29 20 7b 0a 09 2f 2a 0a 09  n) NULL) {../*..
63c0: 20 2a 20 44 65 6c 65 74 65 20 61 6e 20 65 78 69   * Delete an exi
63d0: 73 74 69 6e 67 20 74 69 6d 65 72 2e 20 49 74 20  sting timer. It 
63e0: 77 61 73 20 6e 6f 74 20 66 69 72 65 64 2c 20 79  was not fired, y
63f0: 65 74 20 77 65 20 61 72 65 0a 09 20 2a 20 68 65  et we are.. * he
6400: 72 65 2c 20 73 6f 20 74 68 65 20 63 68 61 6e 6e  re, so the chann
6410: 65 6c 20 62 65 6c 6f 77 20 67 65 6e 65 72 61 74  el below generat
6420: 65 64 20 73 75 63 68 20 61 6e 20 65 76 65 6e 74  ed such an event
6430: 20 61 6e 64 20 77 65 0a 09 20 2a 20 64 6f 6e 27   and we.. * don'
6440: 74 20 68 61 76 65 20 74 6f 2e 20 54 68 65 20 72  t have to. The r
6450: 65 6e 65 77 61 6c 20 6f 66 20 74 68 65 20 69 6e  enewal of the in
6460: 74 65 72 65 73 74 20 61 66 74 65 72 20 74 68 65  terest after the
6470: 0a 09 20 2a 20 65 78 65 63 75 74 69 6f 6e 20 6f  .. * execution o
6480: 66 20 63 68 61 6e 6e 65 6c 20 68 61 6e 64 6c 65  f channel handle
6490: 72 73 20 77 69 6c 6c 20 65 76 65 6e 74 75 61 6c  rs will eventual
64a0: 6c 79 20 63 61 75 73 65 20 75 73 20 74 6f 0a 09  ly cause us to..
64b0: 20 2a 20 72 65 63 72 65 61 74 65 20 74 68 65 20   * recreate the 
64c0: 74 69 6d 65 72 20 28 69 6e 20 57 61 74 63 68 50  timer (in WatchP
64d0: 72 6f 63 29 2e 0a 09 20 2a 2f 0a 09 54 63 6c 5f  roc)... */..Tcl_
64e0: 44 65 6c 65 74 65 54 69 6d 65 72 48 61 6e 64 6c  DeleteTimerHandl
64f0: 65 72 28 73 74 61 74 65 50 74 72 2d 3e 74 69 6d  er(statePtr->tim
6500: 65 72 29 3b 0a 09 73 74 61 74 65 50 74 72 2d 3e  er);..statePtr->
6510: 74 69 6d 65 72 20 3d 20 28 54 63 6c 5f 54 69 6d  timer = (Tcl_Tim
6520: 65 72 54 6f 6b 65 6e 29 20 4e 55 4c 4c 3b 0a 20  erToken) NULL;. 
6530: 20 20 20 7d 0a 0a 20 20 20 20 69 66 20 28 73 74     }..    if (st
6540: 61 74 65 50 74 72 2d 3e 66 6c 61 67 73 20 26 20  atePtr->flags & 
6550: 54 4c 53 5f 54 43 4c 5f 43 41 4c 4c 42 41 43 4b  TLS_TCL_CALLBACK
6560: 29 20 7b 0a 09 64 70 72 69 6e 74 66 28 22 52 65  ) {..dprintf("Re
6570: 74 75 72 6e 69 6e 67 20 30 20 64 75 65 20 74 6f  turning 0 due to
6580: 20 63 61 6c 6c 62 61 63 6b 22 29 3b 0a 09 72 65   callback");..re
6590: 74 75 72 6e 20 30 3b 0a 20 20 20 20 7d 0a 0a 20  turn 0;.    }.. 
65a0: 20 20 20 64 70 72 69 6e 74 66 28 22 43 61 6c 6c     dprintf("Call
65b0: 69 6e 67 20 54 6c 73 5f 57 61 69 74 46 6f 72 43  ing Tls_WaitForC
65c0: 6f 6e 6e 65 63 74 22 29 3b 0a 20 20 20 20 65 72  onnect");.    er
65d0: 72 6f 72 43 6f 64 65 20 3d 20 30 3b 0a 20 20 20  rorCode = 0;.   
65e0: 20 69 66 20 28 54 6c 73 5f 57 61 69 74 46 6f 72   if (Tls_WaitFor
65f0: 43 6f 6e 6e 65 63 74 28 73 74 61 74 65 50 74 72  Connect(statePtr
6600: 2c 20 26 65 72 72 6f 72 43 6f 64 65 2c 20 31 29  , &errorCode, 1)
6610: 20 3c 20 30 29 20 7b 0a 09 54 6c 73 5f 45 72 72   < 0) {..Tls_Err
6620: 6f 72 28 73 74 61 74 65 50 74 72 2c 20 73 74 72  or(statePtr, str
6630: 65 72 72 6f 72 28 65 72 72 6f 72 43 6f 64 65 29  error(errorCode)
6640: 29 3b 0a 09 69 66 20 28 65 72 72 6f 72 43 6f 64  );..if (errorCod
6650: 65 20 3d 3d 20 45 41 47 41 49 4e 29 20 7b 0a 09  e == EAGAIN) {..
6660: 20 20 20 20 64 70 72 69 6e 74 66 28 22 41 73 79      dprintf("Asy
6670: 6e 63 20 66 6c 61 67 20 63 6f 75 6c 64 20 62 65  nc flag could be
6680: 20 73 65 74 20 28 64 69 64 6e 27 74 20 63 68 65   set (didn't che
6690: 63 6b 29 20 61 6e 64 20 65 72 72 6f 72 43 6f 64  ck) and errorCod
66a0: 65 20 3d 3d 20 45 41 47 41 49 4e 3a 20 20 52 65  e == EAGAIN:  Re
66b0: 74 75 72 6e 69 6e 67 20 30 22 29 3b 0a 0a 09 20  turning 0");... 
66c0: 20 20 20 72 65 74 75 72 6e 20 30 3b 0a 09 7d 0a     return 0;..}.
66d0: 0a 09 64 70 72 69 6e 74 66 28 22 54 6c 73 5f 57  ..dprintf("Tls_W
66e0: 61 69 74 46 6f 72 43 6f 6e 6e 65 63 74 20 72 65  aitForConnect re
66f0: 74 75 72 6e 65 64 20 61 6e 20 65 72 72 6f 72 22  turned an error"
6700: 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 64 70  );.    }..    dp
6710: 72 69 6e 74 66 28 22 52 65 74 75 72 6e 69 6e 67  rintf("Returning
6720: 20 25 69 22 2c 20 6d 61 73 6b 29 3b 0a 0a 20 20   %i", mask);..  
6730: 20 20 72 65 74 75 72 6e 28 6d 61 73 6b 29 3b 0a    return(mask);.
6740: 7d 0a 0a 2f 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d  }../*. *--------
6750: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6760: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6770: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2a 0a  --------------*.
6780: 20 2a 0a 20 2a 20 20 20 20 54 6c 73 43 68 61 6e   *. *    TlsChan
6790: 6e 65 6c 48 61 6e 64 6c 65 72 54 69 6d 65 72 20  nelHandlerTimer 
67a0: 2d 2d 0a 20 2a 0a 20 2a 20 20 20 20 2d 2d 2d 2d  --. *. *    ----
67b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
67c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
67d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2a 0a 20 2a  ------------*. *
67e0: 20 20 20 20 43 61 6c 6c 65 64 20 62 79 20 74 68      Called by th
67f0: 65 20 6e 6f 74 69 66 69 65 72 20 28 2d 3e 20 74  e notifier (-> t
6800: 69 6d 65 72 29 20 74 6f 20 66 6c 75 73 68 20 6f  imer) to flush o
6810: 75 74 0a 20 2a 20 20 20 20 69 6e 66 6f 72 6d 61  ut. *    informa
6820: 74 69 6f 6e 20 77 61 69 74 69 6e 67 20 69 6e 20  tion waiting in 
6830: 63 68 61 6e 6e 65 6c 20 62 75 66 66 65 72 73 2e  channel buffers.
6840: 0a 20 2a 20 20 20 20 2d 2d 2d 2d 2d 2d 2d 2d 2d  . *    ---------
6850: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6860: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6870: 2d 2d 2d 2d 2d 2d 2d 2a 0a 20 2a 0a 20 2a 20 20  -------*. *. *  
6880: 20 20 53 69 64 65 20 65 66 66 65 63 74 73 3a 0a    Side effects:.
6890: 20 2a 20 20 20 20 20 20 20 20 41 73 20 6f 66 20   *        As of 
68a0: 27 54 6c 73 43 68 61 6e 6e 65 6c 48 61 6e 64 6c  'TlsChannelHandl
68b0: 65 72 27 2e 0a 20 2a 0a 20 2a 20 20 20 20 52 65  er'.. *. *    Re
68c0: 73 75 6c 74 3a 0a 20 2a 20 20 20 20 20 20 20 20  sult:. *        
68d0: 4e 6f 6e 65 2e 0a 20 2a 0a 20 2a 2d 2d 2d 2d 2d  None.. *. *-----
68e0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
68f0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6900: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6910: 2d 2a 0a 20 2a 2f 0a 73 74 61 74 69 63 20 76 6f  -*. */.static vo
6920: 69 64 20 54 6c 73 43 68 61 6e 6e 65 6c 48 61 6e  id TlsChannelHan
6930: 64 6c 65 72 54 69 6d 65 72 28 43 6c 69 65 6e 74  dlerTimer(Client
6940: 44 61 74 61 20 63 6c 69 65 6e 74 44 61 74 61 29  Data clientData)
6950: 20 7b 0a 20 20 20 20 53 74 61 74 65 20 2a 73 74   {.    State *st
6960: 61 74 65 50 74 72 20 3d 20 28 53 74 61 74 65 20  atePtr = (State 
6970: 2a 29 20 63 6c 69 65 6e 74 44 61 74 61 3b 0a 20  *) clientData;. 
6980: 20 20 20 69 6e 74 20 6d 61 73 6b 20 3d 20 30 3b     int mask = 0;
6990: 0a 0a 20 20 20 20 64 70 72 69 6e 74 66 28 22 43  ..    dprintf("C
69a0: 61 6c 6c 65 64 22 29 3b 0a 0a 20 20 20 20 73 74  alled");..    st
69b0: 61 74 65 50 74 72 2d 3e 74 69 6d 65 72 20 3d 20  atePtr->timer = 
69c0: 28 54 63 6c 5f 54 69 6d 65 72 54 6f 6b 65 6e 29  (Tcl_TimerToken)
69d0: 20 4e 55 4c 4c 3b 0a 0a 20 20 20 20 69 66 20 28   NULL;..    if (
69e0: 42 49 4f 5f 77 70 65 6e 64 69 6e 67 28 73 74 61  BIO_wpending(sta
69f0: 74 65 50 74 72 2d 3e 62 69 6f 29 29 20 7b 0a 09  tePtr->bio)) {..
6a00: 64 70 72 69 6e 74 66 28 22 5b 63 68 61 6e 3d 25  dprintf("[chan=%
6a10: 70 5d 20 42 49 4f 20 77 72 69 74 61 62 6c 65 22  p] BIO writable"
6a20: 2c 20 73 74 61 74 65 50 74 72 2d 3e 73 65 6c 66  , statePtr->self
6a30: 29 3b 0a 0a 09 6d 61 73 6b 20 7c 3d 20 54 43 4c  );...mask |= TCL
6a40: 5f 57 52 49 54 41 42 4c 45 3b 0a 20 20 20 20 7d  _WRITABLE;.    }
6a50: 0a 0a 20 20 20 20 69 66 20 28 42 49 4f 5f 70 65  ..    if (BIO_pe
6a60: 6e 64 69 6e 67 28 73 74 61 74 65 50 74 72 2d 3e  nding(statePtr->
6a70: 62 69 6f 29 29 20 7b 0a 09 64 70 72 69 6e 74 66  bio)) {..dprintf
6a80: 28 22 5b 63 68 61 6e 3d 25 70 5d 20 42 49 4f 20  ("[chan=%p] BIO 
6a90: 72 65 61 64 61 62 6c 65 22 2c 20 73 74 61 74 65  readable", state
6aa0: 50 74 72 2d 3e 73 65 6c 66 29 3b 0a 0a 09 6d 61  Ptr->self);...ma
6ab0: 73 6b 20 7c 3d 20 54 43 4c 5f 52 45 41 44 41 42  sk |= TCL_READAB
6ac0: 4c 45 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 64  LE;.    }..    d
6ad0: 70 72 69 6e 74 66 28 22 4e 6f 74 69 66 79 69 6e  printf("Notifyin
6ae0: 67 20 6f 75 72 73 65 6c 76 65 73 22 29 3b 0a 20  g ourselves");. 
6af0: 20 20 20 54 63 6c 5f 4e 6f 74 69 66 79 43 68 61     Tcl_NotifyCha
6b00: 6e 6e 65 6c 28 73 74 61 74 65 50 74 72 2d 3e 73  nnel(statePtr->s
6b10: 65 6c 66 2c 20 6d 61 73 6b 29 3b 0a 0a 20 20 20  elf, mask);..   
6b20: 20 64 70 72 69 6e 74 66 28 22 52 65 74 75 72 6e   dprintf("Return
6b30: 69 6e 67 22 29 3b 0a 0a 20 20 20 20 72 65 74 75  ing");..    retu
6b40: 72 6e 3b 0a 7d 0a 0a 54 63 6c 5f 43 68 61 6e 6e  rn;.}..Tcl_Chann
6b50: 65 6c 20 54 6c 73 5f 47 65 74 50 61 72 65 6e 74  el Tls_GetParent
6b60: 28 53 74 61 74 65 20 2a 73 74 61 74 65 50 74 72  (State *statePtr
6b70: 2c 20 69 6e 74 20 6d 61 73 6b 46 6c 61 67 73 29  , int maskFlags)
6b80: 20 7b 0a 20 20 20 20 64 70 72 69 6e 74 66 28 22   {.    dprintf("
6b90: 52 65 71 75 65 73 74 65 64 20 74 6f 20 67 65 74  Requested to get
6ba0: 20 70 61 72 65 6e 74 20 6f 66 20 63 68 61 6e 6e   parent of chann
6bb0: 65 6c 20 25 70 22 2c 20 73 74 61 74 65 50 74 72  el %p", statePtr
6bc0: 2d 3e 73 65 6c 66 29 3b 0a 0a 20 20 20 20 69 66  ->self);..    if
6bd0: 20 28 28 73 74 61 74 65 50 74 72 2d 3e 66 6c 61   ((statePtr->fla
6be0: 67 73 20 26 20 7e 6d 61 73 6b 46 6c 61 67 73 29  gs & ~maskFlags)
6bf0: 20 26 20 54 4c 53 5f 54 43 4c 5f 46 41 53 54 50   & TLS_TCL_FASTP
6c00: 41 54 48 29 20 7b 0a 09 64 70 72 69 6e 74 66 28  ATH) {..dprintf(
6c10: 22 41 73 6b 65 64 20 74 6f 20 67 65 74 20 74 68  "Asked to get th
6c20: 65 20 70 61 72 65 6e 74 20 63 68 61 6e 6e 65 6c  e parent channel
6c30: 20 77 68 69 6c 65 20 77 65 20 61 72 65 20 75 73   while we are us
6c40: 69 6e 67 20 46 61 73 74 50 61 74 68 20 2d 2d 20  ing FastPath -- 
6c50: 72 65 74 75 72 6e 69 6e 67 20 4e 55 4c 4c 22 29  returning NULL")
6c60: 3b 0a 09 72 65 74 75 72 6e 28 4e 55 4c 4c 29 3b  ;..return(NULL);
6c70: 0a 20 20 20 20 7d 0a 20 20 20 20 72 65 74 75 72  .    }.    retur
6c80: 6e 28 54 63 6c 5f 47 65 74 53 74 61 63 6b 65 64  n(Tcl_GetStacked
6c90: 43 68 61 6e 6e 65 6c 28 73 74 61 74 65 50 74 72  Channel(statePtr
6ca0: 2d 3e 73 65 6c 66 29 29 3b 0a 7d 0a 0a 2f 2a 0a  ->self));.}../*.
6cb0: 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d   *--------------
6cc0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6cd0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6ce0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6cf0: 2d 2d 2d 2d 2d 0a 20 2a 0a 20 2a 20 54 6c 73 5f  -----. *. * Tls_
6d00: 43 68 61 6e 6e 65 6c 54 79 70 65 20 2d 2d 0a 20  ChannelType --. 
6d10: 2a 0a 20 2a 20 20 20 20 52 65 74 75 72 6e 20 74  *. *    Return t
6d20: 68 65 20 63 6f 72 72 65 63 74 20 54 4c 53 20 63  he correct TLS c
6d30: 68 61 6e 6e 65 6c 20 64 72 69 76 65 72 20 69 6e  hannel driver in
6d40: 66 6f 0a 20 2a 0a 20 2a 20 52 65 73 75 6c 74 73  fo. *. * Results
6d50: 3a 0a 20 2a 20 20 20 20 54 68 65 20 63 6f 72 72  :. *    The corr
6d60: 65 63 74 20 63 68 61 6e 6e 65 6c 20 64 72 69 76  ect channel driv
6d70: 65 72 20 66 6f 72 20 74 68 65 20 63 75 72 72 65  er for the curre
6d80: 6e 74 20 76 65 72 73 69 6f 6e 20 6f 66 20 54 63  nt version of Tc
6d90: 6c 2e 0a 20 2a 0a 20 2a 20 53 69 64 65 20 65 66  l.. *. * Side ef
6da0: 66 65 63 74 73 3a 0a 20 2a 20 20 20 20 4e 6f 6e  fects:. *    Non
6db0: 65 2e 0a 20 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d  e.. *. *--------
6dc0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6dd0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6de0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6df0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 2f 0a  -----------. */.
6e00: 73 74 61 74 69 63 20 63 6f 6e 73 74 20 54 63 6c  static const Tcl
6e10: 5f 43 68 61 6e 6e 65 6c 54 79 70 65 20 74 6c 73  _ChannelType tls
6e20: 43 68 61 6e 6e 65 6c 54 79 70 65 20 3d 20 7b 0a  ChannelType = {.
6e30: 20 20 20 20 22 74 6c 73 22 2c 09 09 09 2f 2a 20      "tls",.../* 
6e40: 54 79 70 65 20 6e 61 6d 65 20 2a 2f 0a 20 20 20  Type name */.   
6e50: 20 54 43 4c 5f 43 48 41 4e 4e 45 4c 5f 56 45 52   TCL_CHANNEL_VER
6e60: 53 49 4f 4e 5f 35 2c 09 2f 2a 20 76 35 20 63 68  SION_5,./* v5 ch
6e70: 61 6e 6e 65 6c 20 2a 2f 0a 20 20 20 20 54 6c 73  annel */.    Tls
6e80: 43 6c 6f 73 65 50 72 6f 63 2c 09 09 2f 2a 20 43  CloseProc,../* C
6e90: 6c 6f 73 65 20 70 72 6f 63 20 2a 2f 0a 20 20 20  lose proc */.   
6ea0: 20 54 6c 73 49 6e 70 75 74 50 72 6f 63 2c 09 09   TlsInputProc,..
6eb0: 2f 2a 20 49 6e 70 75 74 20 70 72 6f 63 20 2a 2f  /* Input proc */
6ec0: 0a 20 20 20 20 54 6c 73 4f 75 74 70 75 74 50 72  .    TlsOutputPr
6ed0: 6f 63 2c 09 09 2f 2a 20 4f 75 74 70 75 74 20 70  oc,../* Output p
6ee0: 72 6f 63 20 2a 2f 0a 20 20 20 20 4e 55 4c 4c 2c  roc */.    NULL,
6ef0: 09 09 09 2f 2a 20 53 65 65 6b 20 70 72 6f 63 20  .../* Seek proc 
6f00: 2a 2f 0a 20 20 20 20 54 6c 73 53 65 74 4f 70 74  */.    TlsSetOpt
6f10: 69 6f 6e 50 72 6f 63 2c 09 09 2f 2a 20 53 65 74  ionProc,../* Set
6f20: 20 6f 70 74 69 6f 6e 20 70 72 6f 63 20 2a 2f 0a   option proc */.
6f30: 20 20 20 20 54 6c 73 47 65 74 4f 70 74 69 6f 6e      TlsGetOption
6f40: 50 72 6f 63 2c 09 09 2f 2a 20 47 65 74 20 6f 70  Proc,../* Get op
6f50: 74 69 6f 6e 20 70 72 6f 63 20 2a 2f 0a 20 20 20  tion proc */.   
6f60: 20 54 6c 73 57 61 74 63 68 50 72 6f 63 2c 09 09   TlsWatchProc,..
6f70: 2f 2a 20 49 6e 69 74 69 61 6c 69 7a 65 20 6e 6f  /* Initialize no
6f80: 74 69 66 69 65 72 20 2a 2f 0a 20 20 20 20 54 6c  tifier */.    Tl
6f90: 73 47 65 74 48 61 6e 64 6c 65 50 72 6f 63 2c 09  sGetHandleProc,.
6fa0: 09 2f 2a 20 47 65 74 20 4f 53 20 68 61 6e 64 6c  ./* Get OS handl
6fb0: 65 73 20 6f 75 74 20 6f 66 20 63 68 61 6e 6e 65  es out of channe
6fc0: 6c 20 2a 2f 0a 20 20 20 20 54 6c 73 43 6c 6f 73  l */.    TlsClos
6fd0: 65 32 50 72 6f 63 2c 09 09 2f 2a 20 63 6c 6f 73  e2Proc,../* clos
6fe0: 65 32 70 72 6f 63 20 2a 2f 0a 20 20 20 20 54 6c  e2proc */.    Tl
6ff0: 73 42 6c 6f 63 6b 4d 6f 64 65 50 72 6f 63 2c 09  sBlockModeProc,.
7000: 09 2f 2a 20 53 65 74 20 62 6c 6f 63 6b 69 6e 67  ./* Set blocking
7010: 2f 6e 6f 6e 62 6c 6f 63 6b 69 6e 67 20 6d 6f 64  /nonblocking mod
7020: 65 2a 2f 0a 20 20 20 20 4e 55 4c 4c 2c 09 09 09  e*/.    NULL,...
7030: 2f 2a 20 46 6c 75 73 68 20 70 72 6f 63 20 2a 2f  /* Flush proc */
7040: 0a 20 20 20 20 54 6c 73 4e 6f 74 69 66 79 50 72  .    TlsNotifyPr
7050: 6f 63 2c 09 09 2f 2a 20 48 61 6e 64 6c 69 6e 67  oc,../* Handling
7060: 20 6f 66 20 65 76 65 6e 74 73 20 62 75 62 62 6c   of events bubbl
7070: 69 6e 67 20 75 70 20 2a 2f 0a 20 20 20 20 4e 55  ing up */.    NU
7080: 4c 4c 2c 09 09 09 2f 2a 20 57 69 64 65 20 73 65  LL,.../* Wide se
7090: 65 6b 20 70 72 6f 63 20 2a 2f 0a 20 20 20 20 4e  ek proc */.    N
70a0: 55 4c 4c 2c 09 09 09 2f 2a 20 54 68 72 65 61 64  ULL,.../* Thread
70b0: 20 61 63 74 69 6f 6e 20 2a 2f 0a 20 20 20 20 4e   action */.    N
70c0: 55 4c 4c 09 09 09 2f 2a 20 54 72 75 6e 63 61 74  ULL.../* Truncat
70d0: 65 20 2a 2f 0a 7d 3b 0a 0a 63 6f 6e 73 74 20 54  e */.};..const T
70e0: 63 6c 5f 43 68 61 6e 6e 65 6c 54 79 70 65 20 2a  cl_ChannelType *
70f0: 54 6c 73 5f 43 68 61 6e 6e 65 6c 54 79 70 65 28  Tls_ChannelType(
7100: 76 6f 69 64 29 20 7b 0a 20 20 20 20 72 65 74 75  void) {.    retu
7110: 72 6e 20 26 74 6c 73 43 68 61 6e 6e 65 6c 54 79  rn &tlsChannelTy
7120: 70 65 3b 0a 7d 0a                                pe;.}.