Hex Artifact Content

Artifact 46ff3e28a8428495d988bac129beb3ffcc3d6e78a046b9cf1a67739b80c58a5a:


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 0a 2f 2a 0a   "tlsInt.h"../*.
02b0: 20 2a 20 46 6f 72 77 61 72 64 20 64 65 63 6c 61   * Forward decla
02c0: 72 61 74 69 6f 6e 73 0a 20 2a 2f 0a 73 74 61 74  rations. */.stat
02d0: 69 63 20 76 6f 69 64 20 54 6c 73 43 68 61 6e 6e  ic void TlsChann
02e0: 65 6c 48 61 6e 64 6c 65 72 54 69 6d 65 72 28 76  elHandlerTimer(v
02f0: 6f 69 64 20 2a 63 6c 69 65 6e 74 44 61 74 61 29  oid *clientData)
0300: 3b 0a 0a 2f 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d  ;../*. *--------
0310: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
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 0a 20 2a 0a 20  -----------. *. 
0350: 2a 20 54 6c 73 42 6c 6f 63 6b 4d 6f 64 65 50 72  * TlsBlockModePr
0360: 6f 63 20 2d 2d 0a 20 2a 0a 20 2a 20 20 20 20 54  oc --. *. *    T
0370: 68 69 73 20 70 72 6f 63 65 64 75 72 65 20 69 73  his procedure is
0380: 20 69 6e 76 6f 6b 65 64 20 62 79 20 74 68 65 20   invoked by the 
0390: 67 65 6e 65 72 69 63 20 49 4f 20 6c 65 76 65 6c  generic IO level
03a0: 0a 20 2a 20 20 20 20 20 20 20 74 6f 20 73 65 74  . *       to set
03b0: 20 62 6c 6f 63 6b 69 6e 67 20 61 6e 64 20 6e 6f   blocking and no
03c0: 6e 62 6c 6f 63 6b 69 6e 67 20 6d 6f 64 65 73 0a  nblocking modes.
03d0: 20 2a 0a 20 2a 20 52 65 73 75 6c 74 73 3a 0a 20   *. * Results:. 
03e0: 2a 20 20 20 20 30 20 69 66 20 73 75 63 63 65 73  *    0 if succes
03f0: 73 66 75 6c 20 6f 72 20 50 4f 53 49 58 20 65 72  sful or POSIX er
0400: 72 6f 72 20 63 6f 64 65 20 69 66 20 66 61 69 6c  ror code if fail
0410: 65 64 2e 0a 20 2a 0a 20 2a 20 53 69 64 65 20 65  ed.. *. * Side e
0420: 66 66 65 63 74 73 3a 0a 20 2a 20 20 20 20 53 65  ffects:. *    Se
0430: 74 73 20 74 68 65 20 64 65 76 69 63 65 20 69 6e  ts the device in
0440: 74 6f 20 62 6c 6f 63 6b 69 6e 67 20 6f 72 20 6e  to blocking or n
0450: 6f 6e 62 6c 6f 63 6b 69 6e 67 20 6d 6f 64 65 2e  onblocking mode.
0460: 0a 20 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  . *. *----------
0470: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
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 0a 20 2a 2f 0a 73 74  ---------. */.st
04b0: 61 74 69 63 20 69 6e 74 20 54 6c 73 42 6c 6f 63  atic int TlsBloc
04c0: 6b 4d 6f 64 65 50 72 6f 63 28 76 6f 69 64 20 2a  kModeProc(void *
04d0: 69 6e 73 74 61 6e 63 65 44 61 74 61 2c 20 69 6e  instanceData, in
04e0: 74 20 6d 6f 64 65 29 20 7b 0a 20 20 20 20 53 74  t mode) {.    St
04f0: 61 74 65 20 2a 73 74 61 74 65 50 74 72 20 3d 20  ate *statePtr = 
0500: 28 53 74 61 74 65 20 2a 29 20 69 6e 73 74 61 6e  (State *) instan
0510: 63 65 44 61 74 61 3b 0a 0a 20 20 20 20 69 66 20  ceData;..    if 
0520: 28 6d 6f 64 65 20 3d 3d 20 54 43 4c 5f 4d 4f 44  (mode == TCL_MOD
0530: 45 5f 4e 4f 4e 42 4c 4f 43 4b 49 4e 47 29 20 7b  E_NONBLOCKING) {
0540: 0a 09 73 74 61 74 65 50 74 72 2d 3e 66 6c 61 67  ..statePtr->flag
0550: 73 20 7c 3d 20 54 4c 53 5f 54 43 4c 5f 41 53 59  s |= TLS_TCL_ASY
0560: 4e 43 3b 0a 20 20 20 20 7d 20 65 6c 73 65 20 7b  NC;.    } else {
0570: 0a 09 73 74 61 74 65 50 74 72 2d 3e 66 6c 61 67  ..statePtr->flag
0580: 73 20 26 3d 20 7e 28 54 4c 53 5f 54 43 4c 5f 41  s &= ~(TLS_TCL_A
0590: 53 59 4e 43 29 3b 0a 20 20 20 20 7d 0a 20 20 20  SYNC);.    }.   
05a0: 20 72 65 74 75 72 6e 28 30 29 3b 0a 7d 0a 0a 2f   return(0);.}../
05b0: 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  *. *------------
05c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
05d0: 2d 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 0a 20 2a 0a 20 2a 20 54 6c  -------. *. * Tl
0600: 73 43 6c 6f 73 65 50 72 6f 63 20 2d 2d 0a 20 2a  sCloseProc --. *
0610: 0a 20 2a 20 20 20 20 54 68 69 73 20 70 72 6f 63  . *    This proc
0620: 65 64 75 72 65 20 69 73 20 69 6e 76 6f 6b 65 64  edure is invoked
0630: 20 62 79 20 74 68 65 20 67 65 6e 65 72 69 63 20   by the generic 
0640: 49 4f 20 6c 65 76 65 6c 20 74 6f 20 70 65 72 66  IO level to perf
0650: 6f 72 6d 0a 20 2a 20 20 20 20 63 68 61 6e 6e 65  orm. *    channe
0660: 6c 2d 74 79 70 65 2d 73 70 65 63 69 66 69 63 20  l-type-specific 
0670: 63 6c 65 61 6e 75 70 20 77 68 65 6e 20 61 20 53  cleanup when a S
0680: 53 4c 20 73 6f 63 6b 65 74 20 62 61 73 65 64 20  SL socket based 
0690: 63 68 61 6e 6e 65 6c 0a 20 2a 20 20 20 20 69 73  channel. *    is
06a0: 20 63 6c 6f 73 65 64 2e 0a 20 2a 0a 20 2a 20 20   closed.. *. *  
06b0: 20 20 4e 6f 74 65 3a 20 77 65 20 6c 65 61 76 65    Note: we leave
06c0: 20 74 68 65 20 75 6e 64 65 72 6c 79 69 6e 67 20   the underlying 
06d0: 73 6f 63 6b 65 74 20 61 6c 6f 6e 65 2c 20 69 73  socket alone, is
06e0: 20 74 68 69 73 20 72 69 67 68 74 3f 0a 20 2a 0a   this right?. *.
06f0: 20 2a 20 52 65 73 75 6c 74 73 3a 0a 20 2a 20 20   * Results:. *  
0700: 20 20 30 20 69 66 20 73 75 63 63 65 73 73 66 75    0 if successfu
0710: 6c 20 6f 72 20 50 4f 53 49 58 20 65 72 72 6f 72  l or POSIX error
0720: 20 63 6f 64 65 20 69 66 20 66 61 69 6c 65 64 2e   code if failed.
0730: 0a 20 2a 0a 20 2a 20 53 69 64 65 20 65 66 66 65  . *. * Side effe
0740: 63 74 73 3a 0a 20 2a 20 20 20 20 43 6c 6f 73 65  cts:. *    Close
0750: 73 20 74 68 65 20 73 6f 63 6b 65 74 20 6f 66 20  s the socket of 
0760: 74 68 65 20 63 68 61 6e 6e 65 6c 2e 0a 20 2a 0a  the channel.. *.
0770: 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d   *--------------
0780: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
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 0a 20 2a 2f 0a 73 74 61 74 69 63  -----. */.static
07c0: 20 69 6e 74 20 54 6c 73 43 6c 6f 73 65 50 72 6f   int TlsClosePro
07d0: 63 28 0a 20 20 20 20 76 6f 69 64 20 2a 69 6e 73  c(.    void *ins
07e0: 74 61 6e 63 65 44 61 74 61 2c 0a 20 20 20 20 54  tanceData,.    T
07f0: 43 4c 5f 55 4e 55 53 45 44 28 54 63 6c 5f 49 6e  CL_UNUSED(Tcl_In
0800: 74 65 72 70 20 2a 29 29 0a 7b 0a 20 20 20 20 53  terp *)).{.    S
0810: 74 61 74 65 20 2a 73 74 61 74 65 50 74 72 20 3d  tate *statePtr =
0820: 20 28 53 74 61 74 65 20 2a 29 20 69 6e 73 74 61   (State *) insta
0830: 6e 63 65 44 61 74 61 3b 0a 0a 20 20 20 20 64 70  nceData;..    dp
0840: 72 69 6e 74 66 28 22 54 6c 73 43 6c 6f 73 65 50  rintf("TlsCloseP
0850: 72 6f 63 28 25 70 29 22 2c 20 73 74 61 74 65 50  roc(%p)", stateP
0860: 74 72 29 3b 0a 0a 20 20 20 20 54 6c 73 5f 43 6c  tr);..    Tls_Cl
0870: 65 61 6e 28 73 74 61 74 65 50 74 72 29 3b 0a 20  ean(statePtr);. 
0880: 20 20 20 54 63 6c 5f 45 76 65 6e 74 75 61 6c 6c     Tcl_Eventuall
0890: 79 46 72 65 65 28 73 74 61 74 65 50 74 72 2c 20  yFree(statePtr, 
08a0: 54 6c 73 5f 46 72 65 65 29 3b 0a 20 20 20 20 72  Tls_Free);.    r
08b0: 65 74 75 72 6e 20 54 43 4c 5f 4f 4b 3b 0a 7d 0a  eturn TCL_OK;.}.
08c0: 0a 73 74 61 74 69 63 20 69 6e 74 20 54 6c 73 43  .static int TlsC
08d0: 6c 6f 73 65 32 50 72 6f 63 28 0a 20 20 20 20 76  lose2Proc(.    v
08e0: 6f 69 64 20 2a 69 6e 73 74 61 6e 63 65 44 61 74  oid *instanceDat
08f0: 61 2c 20 20 20 20 2f 2a 20 54 68 65 20 73 6f 63  a,    /* The soc
0900: 6b 65 74 20 73 74 61 74 65 2e 20 2a 2f 0a 20 20  ket state. */.  
0910: 20 20 54 63 6c 5f 49 6e 74 65 72 70 20 2a 69 6e    Tcl_Interp *in
0920: 74 65 72 70 2c 09 09 2f 2a 20 46 6f 72 20 65 72  terp,../* For er
0930: 72 6f 72 73 20 2d 20 63 61 6e 20 62 65 20 4e 55  rors - can be NU
0940: 4c 4c 2e 20 2a 2f 0a 20 20 20 20 69 6e 74 20 66  LL. */.    int f
0950: 6c 61 67 73 29 09 09 09 2f 2a 20 46 6c 61 67 73  lags).../* Flags
0960: 20 74 6f 20 63 6c 6f 73 65 20 72 65 61 64 20 61   to close read a
0970: 6e 64 2f 6f 72 20 77 72 69 74 65 20 73 69 64 65  nd/or write side
0980: 20 6f 66 20 63 68 61 6e 6e 65 6c 20 2a 2f 0a 7b   of channel */.{
0990: 0a 20 20 20 20 69 66 20 28 21 28 66 6c 61 67 73  .    if (!(flags
09a0: 26 28 54 43 4c 5f 43 4c 4f 53 45 5f 52 45 41 44  &(TCL_CLOSE_READ
09b0: 7c 54 43 4c 5f 43 4c 4f 53 45 5f 57 52 49 54 45  |TCL_CLOSE_WRITE
09c0: 29 29 29 20 7b 0a 09 72 65 74 75 72 6e 20 54 6c  ))) {..return Tl
09d0: 73 43 6c 6f 73 65 50 72 6f 63 28 69 6e 73 74 61  sCloseProc(insta
09e0: 6e 63 65 44 61 74 61 2c 20 69 6e 74 65 72 70 29  nceData, interp)
09f0: 3b 0a 20 20 20 20 7d 0a 20 20 20 20 72 65 74 75  ;.    }.    retu
0a00: 72 6e 20 45 49 4e 56 41 4c 3b 0a 7d 0a 0a 2f 2a  rn EINVAL;.}../*
0a10: 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  . *-------------
0a20: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0a30: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0a40: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2a 0a 20 2a 0a 20 2a  ---------*. *. *
0a50: 20 54 6c 73 5f 57 61 69 74 46 6f 72 43 6f 6e 6e   Tls_WaitForConn
0a60: 65 63 74 20 2d 2d 0a 20 2a 0a 20 2a 20 52 65 73  ect --. *. * Res
0a70: 75 6c 74 3a 0a 20 2a 20 20 20 20 30 20 69 66 20  ult:. *    0 if 
0a80: 73 75 63 63 65 73 73 66 75 6c 2c 20 2d 31 20 69  successful, -1 i
0a90: 66 20 66 61 69 6c 65 64 2e 0a 20 2a 0a 20 2a 20  f failed.. *. * 
0aa0: 53 69 64 65 20 65 66 66 65 63 74 73 3a 0a 20 2a  Side effects:. *
0ab0: 20 20 20 20 49 73 73 75 65 73 20 53 53 4c 5f 61      Issues SSL_a
0ac0: 63 63 65 70 74 20 6f 72 20 53 53 4c 5f 63 6f 6e  ccept or SSL_con
0ad0: 6e 65 63 74 0a 20 2a 0a 20 2a 2d 2d 2d 2d 2d 2d  nect. *. *------
0ae0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0af0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0b00: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0b10: 2a 0a 20 2a 2f 0a 69 6e 74 20 54 6c 73 5f 57 61  *. */.int Tls_Wa
0b20: 69 74 46 6f 72 43 6f 6e 6e 65 63 74 28 53 74 61  itForConnect(Sta
0b30: 74 65 20 2a 73 74 61 74 65 50 74 72 2c 20 69 6e  te *statePtr, in
0b40: 74 20 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 2c  t *errorCodePtr,
0b50: 20 69 6e 74 20 68 61 6e 64 73 68 61 6b 65 46 61   int handshakeFa
0b60: 69 6c 75 72 65 49 73 50 65 72 6d 61 6e 65 6e 74  ilureIsPermanent
0b70: 29 20 7b 0a 20 20 20 20 75 6e 73 69 67 6e 65 64  ) {.    unsigned
0b80: 20 6c 6f 6e 67 20 62 61 63 6b 69 6e 67 45 72 72   long backingErr
0b90: 6f 72 3b 0a 20 20 20 20 69 6e 74 20 65 72 72 2c  or;.    int err,
0ba0: 20 72 63 3b 0a 20 20 20 20 69 6e 74 20 62 69 6f   rc;.    int bio
0bb0: 53 68 6f 75 6c 64 52 65 74 72 79 3b 0a 0a 20 20  ShouldRetry;..  
0bc0: 20 20 64 70 72 69 6e 74 66 28 22 57 61 69 74 46    dprintf("WaitF
0bd0: 6f 72 43 6f 6e 6e 65 63 74 28 25 70 29 22 2c 20  orConnect(%p)", 
0be0: 73 74 61 74 65 50 74 72 29 3b 0a 20 20 20 20 64  statePtr);.    d
0bf0: 70 72 69 6e 74 46 6c 61 67 73 28 73 74 61 74 65  printFlags(state
0c00: 50 74 72 29 3b 0a 0a 20 20 20 20 69 66 20 28 21  Ptr);..    if (!
0c10: 28 73 74 61 74 65 50 74 72 2d 3e 66 6c 61 67 73  (statePtr->flags
0c20: 20 26 20 54 4c 53 5f 54 43 4c 5f 49 4e 49 54 29   & TLS_TCL_INIT)
0c30: 29 20 7b 0a 09 64 70 72 69 6e 74 66 28 22 54 6c  ) {..dprintf("Tl
0c40: 73 5f 57 61 69 74 46 6f 72 43 6f 6e 6e 65 63 74  s_WaitForConnect
0c50: 20 63 61 6c 6c 65 64 20 6f 6e 20 61 6c 72 65 61   called on alrea
0c60: 64 79 20 69 6e 69 74 69 61 6c 69 7a 65 64 20 63  dy initialized c
0c70: 68 61 6e 6e 65 6c 20 2d 2d 20 72 65 74 75 72 6e  hannel -- return
0c80: 69 6e 67 20 77 69 74 68 20 69 6d 6d 65 64 69 61  ing with immedia
0c90: 74 65 20 73 75 63 63 65 73 73 22 29 3b 0a 09 2a  te success");..*
0ca0: 65 72 72 6f 72 43 6f 64 65 50 74 72 20 3d 20 30  errorCodePtr = 0
0cb0: 3b 0a 09 72 65 74 75 72 6e 28 30 29 3b 0a 20 20  ;..return(0);.  
0cc0: 20 20 7d 0a 0a 20 20 20 20 69 66 20 28 73 74 61    }..    if (sta
0cd0: 74 65 50 74 72 2d 3e 66 6c 61 67 73 20 26 20 54  tePtr->flags & T
0ce0: 4c 53 5f 54 43 4c 5f 48 41 4e 44 53 48 41 4b 45  LS_TCL_HANDSHAKE
0cf0: 5f 46 41 49 4c 45 44 29 20 7b 0a 09 2f 2a 0a 09  _FAILED) {../*..
0d00: 20 2a 20 44 69 66 66 65 72 65 6e 74 20 74 79 70   * Different typ
0d10: 65 73 20 6f 66 20 6f 70 65 72 61 74 69 6f 6e 73  es of operations
0d20: 20 68 61 76 65 20 64 69 66 66 65 72 65 6e 74 20   have different 
0d30: 72 65 71 75 69 72 65 6d 65 6e 74 73 0a 09 20 2a  requirements.. *
0d40: 20 53 53 4c 20 62 65 69 6e 67 20 65 73 74 61 62   SSL being estab
0d50: 6c 69 73 68 65 64 0a 09 20 2a 2f 0a 09 69 66 20  lished.. */..if 
0d60: 28 68 61 6e 64 73 68 61 6b 65 46 61 69 6c 75 72  (handshakeFailur
0d70: 65 49 73 50 65 72 6d 61 6e 65 6e 74 29 20 7b 0a  eIsPermanent) {.
0d80: 09 20 20 20 20 64 70 72 69 6e 74 66 28 22 41 73  .    dprintf("As
0d90: 6b 65 64 20 74 6f 20 77 61 69 74 20 66 6f 72 20  ked to wait for 
0da0: 61 20 54 4c 53 20 68 61 6e 64 73 68 61 6b 65 20  a TLS handshake 
0db0: 74 68 61 74 20 68 61 73 20 61 6c 72 65 61 64 79  that has already
0dc0: 20 66 61 69 6c 65 64 2e 20 20 52 65 74 75 72 6e   failed.  Return
0dd0: 69 6e 67 20 66 61 74 61 6c 20 65 72 72 6f 72 22  ing fatal error"
0de0: 29 3b 0a 09 20 20 20 20 2a 65 72 72 6f 72 43 6f  );..    *errorCo
0df0: 64 65 50 74 72 20 3d 20 45 43 4f 4e 4e 41 42 4f  dePtr = ECONNABO
0e00: 52 54 45 44 3b 0a 09 7d 20 65 6c 73 65 20 7b 0a  RTED;..} else {.
0e10: 09 20 20 20 20 64 70 72 69 6e 74 66 28 22 41 73  .    dprintf("As
0e20: 6b 65 64 20 74 6f 20 77 61 69 74 20 66 6f 72 20  ked to wait for 
0e30: 61 20 54 4c 53 20 68 61 6e 64 73 68 61 6b 65 20  a TLS handshake 
0e40: 74 68 61 74 20 68 61 73 20 61 6c 72 65 61 64 79  that has already
0e50: 20 66 61 69 6c 65 64 2e 20 20 52 65 74 75 72 6e   failed.  Return
0e60: 69 6e 67 20 73 6f 66 74 20 65 72 72 6f 72 22 29  ing soft error")
0e70: 3b 0a 09 20 20 20 20 2a 65 72 72 6f 72 43 6f 64  ;..    *errorCod
0e80: 65 50 74 72 20 3d 20 45 43 4f 4e 4e 52 45 53 45  ePtr = ECONNRESE
0e90: 54 3b 0a 09 7d 0a 09 72 65 74 75 72 6e 28 2d 31  T;..}..return(-1
0ea0: 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 66 6f  );.    }..    fo
0eb0: 72 20 28 3b 3b 29 20 7b 0a 09 2f 2a 20 4e 6f 74  r (;;) {../* Not
0ec0: 20 69 6e 69 74 69 61 6c 69 7a 65 64 20 79 65 74   initialized yet
0ed0: 21 20 2a 2f 0a 09 69 66 20 28 73 74 61 74 65 50  ! */..if (stateP
0ee0: 74 72 2d 3e 66 6c 61 67 73 20 26 20 54 4c 53 5f  tr->flags & TLS_
0ef0: 54 43 4c 5f 53 45 52 56 45 52 29 20 7b 0a 09 20  TCL_SERVER) {.. 
0f00: 20 20 20 64 70 72 69 6e 74 66 28 22 43 61 6c 6c     dprintf("Call
0f10: 69 6e 67 20 53 53 4c 5f 61 63 63 65 70 74 28 29  ing SSL_accept()
0f20: 22 29 3b 0a 0a 09 09 65 72 72 20 3d 20 53 53 4c  ");....err = SSL
0f30: 5f 61 63 63 65 70 74 28 73 74 61 74 65 50 74 72  _accept(statePtr
0f40: 2d 3e 73 73 6c 29 3b 0a 09 7d 20 65 6c 73 65 20  ->ssl);..} else 
0f50: 7b 0a 09 20 20 20 20 64 70 72 69 6e 74 66 28 22  {..    dprintf("
0f60: 43 61 6c 6c 69 6e 67 20 53 53 4c 5f 63 6f 6e 6e  Calling SSL_conn
0f70: 65 63 74 28 29 22 29 3b 0a 09 20 20 20 20 65 72  ect()");..    er
0f80: 72 20 3d 20 53 53 4c 5f 63 6f 6e 6e 65 63 74 28  r = SSL_connect(
0f90: 73 74 61 74 65 50 74 72 2d 3e 73 73 6c 29 3b 0a  statePtr->ssl);.
0fa0: 09 7d 0a 0a 09 69 66 20 28 65 72 72 20 3e 20 30  .}...if (err > 0
0fb0: 29 20 7b 0a 09 20 20 20 20 64 70 72 69 6e 74 66  ) {..    dprintf
0fc0: 28 22 54 68 61 74 20 73 65 65 6d 73 20 74 6f 20  ("That seems to 
0fd0: 68 61 76 65 20 67 6f 6e 65 20 6f 6b 61 79 22 29  have gone okay")
0fe0: 3b 0a 0a 09 20 20 20 20 65 72 72 20 3d 20 42 49  ;...    err = BI
0ff0: 4f 5f 66 6c 75 73 68 28 73 74 61 74 65 50 74 72  O_flush(statePtr
1000: 2d 3e 62 69 6f 29 3b 0a 09 20 20 20 20 69 66 20  ->bio);..    if 
1010: 28 65 72 72 20 3c 3d 20 30 29 20 7b 0a 09 09 64  (err <= 0) {...d
1020: 70 72 69 6e 74 66 28 22 46 6c 75 73 68 69 6e 67  printf("Flushing
1030: 20 74 68 65 20 6c 6f 77 65 72 20 6c 61 79 65 72   the lower layer
1040: 73 20 66 61 69 6c 65 64 2c 20 74 68 69 73 20 77  s failed, this w
1050: 69 6c 6c 20 70 72 6f 62 61 62 6c 79 20 74 65 72  ill probably ter
1060: 6d 69 6e 61 74 65 20 74 68 69 73 20 73 65 73 73  minate this sess
1070: 69 6f 6e 22 29 3b 0a 09 20 20 20 20 7d 0a 09 7d  ion");..    }..}
1080: 0a 0a 09 72 63 20 3d 20 53 53 4c 5f 67 65 74 5f  ...rc = SSL_get_
1090: 65 72 72 6f 72 28 73 74 61 74 65 50 74 72 2d 3e  error(statePtr->
10a0: 73 73 6c 2c 20 65 72 72 29 3b 0a 0a 09 64 70 72  ssl, err);...dpr
10b0: 69 6e 74 66 28 22 47 6f 74 20 65 72 72 6f 72 3a  intf("Got error:
10c0: 20 25 69 20 28 72 63 20 3d 20 25 69 29 22 2c 20   %i (rc = %i)", 
10d0: 65 72 72 2c 20 72 63 29 3b 0a 0a 09 62 69 6f 53  err, rc);...bioS
10e0: 68 6f 75 6c 64 52 65 74 72 79 20 3d 20 30 3b 0a  houldRetry = 0;.
10f0: 09 69 66 20 28 65 72 72 20 3c 3d 20 30 29 20 7b  .if (err <= 0) {
1100: 0a 09 20 20 20 20 69 66 20 28 72 63 20 3d 3d 20  ..    if (rc == 
1110: 53 53 4c 5f 45 52 52 4f 52 5f 57 41 4e 54 5f 43  SSL_ERROR_WANT_C
1120: 4f 4e 4e 45 43 54 20 7c 7c 20 72 63 20 3d 3d 20  ONNECT || rc == 
1130: 53 53 4c 5f 45 52 52 4f 52 5f 57 41 4e 54 5f 41  SSL_ERROR_WANT_A
1140: 43 43 45 50 54 20 7c 7c 20 72 63 20 3d 3d 20 53  CCEPT || rc == S
1150: 53 4c 5f 45 52 52 4f 52 5f 57 41 4e 54 5f 52 45  SL_ERROR_WANT_RE
1160: 41 44 20 7c 7c 20 72 63 20 3d 3d 20 53 53 4c 5f  AD || rc == SSL_
1170: 45 52 52 4f 52 5f 57 41 4e 54 5f 57 52 49 54 45  ERROR_WANT_WRITE
1180: 29 20 7b 0a 09 09 62 69 6f 53 68 6f 75 6c 64 52  ) {...bioShouldR
1190: 65 74 72 79 20 3d 20 31 3b 0a 09 20 20 20 20 7d  etry = 1;..    }
11a0: 20 65 6c 73 65 20 69 66 20 28 42 49 4f 5f 73 68   else if (BIO_sh
11b0: 6f 75 6c 64 5f 72 65 74 72 79 28 73 74 61 74 65  ould_retry(state
11c0: 50 74 72 2d 3e 62 69 6f 29 29 20 7b 0a 09 09 62  Ptr->bio)) {...b
11d0: 69 6f 53 68 6f 75 6c 64 52 65 74 72 79 20 3d 20  ioShouldRetry = 
11e0: 31 3b 0a 09 20 20 20 20 7d 20 65 6c 73 65 20 69  1;..    } else i
11f0: 66 20 28 72 63 20 3d 3d 20 53 53 4c 5f 45 52 52  f (rc == SSL_ERR
1200: 4f 52 5f 53 59 53 43 41 4c 4c 20 26 26 20 54 63  OR_SYSCALL && Tc
1210: 6c 5f 47 65 74 45 72 72 6e 6f 28 29 20 3d 3d 20  l_GetErrno() == 
1220: 45 41 47 41 49 4e 29 20 7b 0a 09 09 62 69 6f 53  EAGAIN) {...bioS
1230: 68 6f 75 6c 64 52 65 74 72 79 20 3d 20 31 3b 0a  houldRetry = 1;.
1240: 09 20 20 20 20 7d 0a 09 7d 20 65 6c 73 65 20 7b  .    }..} else {
1250: 0a 09 20 20 20 20 69 66 20 28 21 53 53 4c 5f 69  ..    if (!SSL_i
1260: 73 5f 69 6e 69 74 5f 66 69 6e 69 73 68 65 64 28  s_init_finished(
1270: 73 74 61 74 65 50 74 72 2d 3e 73 73 6c 29 29 20  statePtr->ssl)) 
1280: 7b 0a 09 09 62 69 6f 53 68 6f 75 6c 64 52 65 74  {...bioShouldRet
1290: 72 79 20 3d 20 31 3b 0a 09 20 20 20 20 7d 0a 09  ry = 1;..    }..
12a0: 7d 0a 0a 09 69 66 20 28 62 69 6f 53 68 6f 75 6c  }...if (bioShoul
12b0: 64 52 65 74 72 79 29 20 7b 0a 09 20 20 20 20 64  dRetry) {..    d
12c0: 70 72 69 6e 74 66 28 22 54 68 65 20 49 2f 4f 20  printf("The I/O 
12d0: 64 69 64 20 6e 6f 74 20 63 6f 6d 70 6c 65 74 65  did not complete
12e0: 20 2d 2d 20 62 75 74 20 77 65 20 73 68 6f 75 6c   -- but we shoul
12f0: 64 20 74 72 79 20 69 74 20 61 67 61 69 6e 22 29  d try it again")
1300: 3b 0a 0a 09 20 20 20 20 69 66 20 28 73 74 61 74  ;...    if (stat
1310: 65 50 74 72 2d 3e 66 6c 61 67 73 20 26 20 54 4c  ePtr->flags & TL
1320: 53 5f 54 43 4c 5f 41 53 59 4e 43 29 20 7b 0a 09  S_TCL_ASYNC) {..
1330: 09 64 70 72 69 6e 74 66 28 22 52 65 74 75 72 6e  .dprintf("Return
1340: 69 6e 67 20 45 41 47 41 49 4e 20 73 6f 20 74 68  ing EAGAIN so th
1350: 61 74 20 69 74 20 63 61 6e 20 62 65 20 72 65 74  at it can be ret
1360: 72 69 65 64 20 6c 61 74 65 72 22 29 3b 0a 09 09  ried later");...
1370: 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 20 3d 20  *errorCodePtr = 
1380: 45 41 47 41 49 4e 3b 0a 09 09 72 65 74 75 72 6e  EAGAIN;...return
1390: 28 2d 31 29 3b 0a 09 20 20 20 20 7d 20 65 6c 73  (-1);..    } els
13a0: 65 20 7b 0a 09 09 64 70 72 69 6e 74 66 28 22 44  e {...dprintf("D
13b0: 6f 69 6e 67 20 73 6f 20 6e 6f 77 22 29 3b 0a 09  oing so now");..
13c0: 09 63 6f 6e 74 69 6e 75 65 3b 0a 09 20 20 20 20  .continue;..    
13d0: 7d 0a 09 7d 0a 0a 09 64 70 72 69 6e 74 66 28 22  }..}...dprintf("
13e0: 57 65 20 68 61 76 65 20 65 69 74 68 65 72 20 63  We have either c
13f0: 6f 6d 70 6c 65 74 65 6c 79 20 65 73 74 61 62 6c  ompletely establ
1400: 69 73 68 65 64 20 74 68 65 20 73 65 73 73 69 6f  ished the sessio
1410: 6e 20 6f 72 20 63 6f 6d 70 6c 65 74 65 6c 79 20  n or completely 
1420: 66 61 69 6c 65 64 20 69 74 20 2d 2d 20 74 68 65  failed it -- the
1430: 72 65 20 69 73 20 6e 6f 20 6d 6f 72 65 20 6e 65  re is no more ne
1440: 65 64 20 74 6f 20 65 76 65 72 20 72 65 74 72 79  ed to ever retry
1450: 20 69 74 20 74 68 6f 75 67 68 22 29 3b 0a 09 62   it though");..b
1460: 72 65 61 6b 3b 0a 20 20 20 20 7d 0a 0a 0a 20 20  reak;.    }...  
1470: 20 20 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 20    *errorCodePtr 
1480: 3d 20 45 49 4e 56 41 4c 3b 0a 0a 20 20 20 20 73  = EINVAL;..    s
1490: 77 69 74 63 68 20 28 72 63 29 20 7b 0a 09 63 61  witch (rc) {..ca
14a0: 73 65 20 53 53 4c 5f 45 52 52 4f 52 5f 4e 4f 4e  se SSL_ERROR_NON
14b0: 45 3a 0a 09 20 20 20 20 2f 2a 20 54 68 65 20 63  E:..    /* The c
14c0: 6f 6e 6e 65 63 74 69 6f 6e 20 69 73 20 75 70 2c  onnection is up,
14d0: 20 77 65 20 61 72 65 20 64 6f 6e 65 20 68 65 72   we are done her
14e0: 65 20 2a 2f 0a 09 20 20 20 20 64 70 72 69 6e 74  e */..    dprint
14f0: 66 28 22 54 68 65 20 63 6f 6e 6e 65 63 74 69 6f  f("The connectio
1500: 6e 20 69 73 20 75 70 22 29 3b 0a 09 20 20 20 20  n is up");..    
1510: 62 72 65 61 6b 3b 0a 09 63 61 73 65 20 53 53 4c  break;..case SSL
1520: 5f 45 52 52 4f 52 5f 5a 45 52 4f 5f 52 45 54 55  _ERROR_ZERO_RETU
1530: 52 4e 3a 0a 09 20 20 20 20 64 70 72 69 6e 74 66  RN:..    dprintf
1540: 28 22 53 53 4c 5f 45 52 52 4f 52 5f 5a 45 52 4f  ("SSL_ERROR_ZERO
1550: 5f 52 45 54 55 52 4e 3a 20 43 6f 6e 6e 65 63 74  _RETURN: Connect
1560: 20 72 65 74 75 72 6e 65 64 20 61 6e 20 69 6e 76   returned an inv
1570: 61 6c 69 64 20 76 61 6c 75 65 2e 2e 2e 22 29 0a  alid value...").
1580: 09 20 20 20 20 72 65 74 75 72 6e 28 2d 31 29 3b  .    return(-1);
1590: 0a 09 63 61 73 65 20 53 53 4c 5f 45 52 52 4f 52  ..case SSL_ERROR
15a0: 5f 53 59 53 43 41 4c 4c 3a 0a 09 20 20 20 20 62  _SYSCALL:..    b
15b0: 61 63 6b 69 6e 67 45 72 72 6f 72 20 3d 20 45 52  ackingError = ER
15c0: 52 5f 67 65 74 5f 65 72 72 6f 72 28 29 3b 0a 0a  R_get_error();..
15d0: 09 20 20 20 20 69 66 20 28 62 61 63 6b 69 6e 67  .    if (backing
15e0: 45 72 72 6f 72 20 3d 3d 20 30 20 26 26 20 65 72  Error == 0 && er
15f0: 72 20 3d 3d 20 30 29 20 7b 0a 09 09 64 70 72 69  r == 0) {...dpri
1600: 6e 74 66 28 22 45 4f 46 20 72 65 61 63 68 65 64  ntf("EOF reached
1610: 22 29 0a 09 09 2a 65 72 72 6f 72 43 6f 64 65 50  ")...*errorCodeP
1620: 74 72 20 3d 20 45 43 4f 4e 4e 52 45 53 45 54 3b  tr = ECONNRESET;
1630: 0a 09 20 20 20 20 7d 20 65 6c 73 65 20 69 66 20  ..    } else if 
1640: 28 62 61 63 6b 69 6e 67 45 72 72 6f 72 20 3d 3d  (backingError ==
1650: 20 30 20 26 26 20 65 72 72 20 3d 3d 20 2d 31 29   0 && err == -1)
1660: 20 7b 0a 09 09 64 70 72 69 6e 74 66 28 22 49 2f   {...dprintf("I/
1670: 4f 20 65 72 72 6f 72 20 6f 63 63 75 72 72 65 64  O error occurred
1680: 20 28 65 72 72 6e 6f 20 3d 20 25 6c 75 29 22 2c   (errno = %lu)",
1690: 20 28 75 6e 73 69 67 6e 65 64 20 6c 6f 6e 67 29   (unsigned long)
16a0: 20 54 63 6c 5f 47 65 74 45 72 72 6e 6f 28 29 29   Tcl_GetErrno())
16b0: 3b 0a 09 09 2a 65 72 72 6f 72 43 6f 64 65 50 74  ;...*errorCodePt
16c0: 72 20 3d 20 54 63 6c 5f 47 65 74 45 72 72 6e 6f  r = Tcl_GetErrno
16d0: 28 29 3b 0a 09 09 69 66 20 28 2a 65 72 72 6f 72  ();...if (*error
16e0: 43 6f 64 65 50 74 72 20 3d 3d 20 45 43 4f 4e 4e  CodePtr == ECONN
16f0: 52 45 53 45 54 29 20 7b 0a 09 09 20 20 20 20 2a  RESET) {...    *
1700: 65 72 72 6f 72 43 6f 64 65 50 74 72 20 3d 20 45  errorCodePtr = E
1710: 43 4f 4e 4e 41 42 4f 52 54 45 44 3b 0a 09 09 7d  CONNABORTED;...}
1720: 0a 09 20 20 20 20 7d 20 65 6c 73 65 20 7b 0a 09  ..    } else {..
1730: 09 64 70 72 69 6e 74 66 28 22 49 2f 4f 20 65 72  .dprintf("I/O er
1740: 72 6f 72 20 6f 63 63 75 72 72 65 64 20 28 62 61  ror occurred (ba
1750: 63 6b 69 6e 67 45 72 72 6f 72 20 3d 20 25 6c 75  ckingError = %lu
1760: 29 22 2c 20 62 61 63 6b 69 6e 67 45 72 72 6f 72  )", backingError
1770: 29 3b 0a 09 09 2a 65 72 72 6f 72 43 6f 64 65 50  );...*errorCodeP
1780: 74 72 20 3d 20 62 61 63 6b 69 6e 67 45 72 72 6f  tr = backingErro
1790: 72 3b 0a 09 09 69 66 20 28 2a 65 72 72 6f 72 43  r;...if (*errorC
17a0: 6f 64 65 50 74 72 20 3d 3d 20 45 43 4f 4e 4e 52  odePtr == ECONNR
17b0: 45 53 45 54 29 20 7b 0a 09 09 20 20 20 20 2a 65  ESET) {...    *e
17c0: 72 72 6f 72 43 6f 64 65 50 74 72 20 3d 20 45 43  rrorCodePtr = EC
17d0: 4f 4e 4e 41 42 4f 52 54 45 44 3b 0a 09 09 7d 0a  ONNABORTED;...}.
17e0: 09 09 7d 0a 0a 09 09 73 74 61 74 65 50 74 72 2d  ..}....statePtr-
17f0: 3e 66 6c 61 67 73 20 7c 3d 20 54 4c 53 5f 54 43  >flags |= TLS_TC
1800: 4c 5f 48 41 4e 44 53 48 41 4b 45 5f 46 41 49 4c  L_HANDSHAKE_FAIL
1810: 45 44 3b 0a 0a 09 09 72 65 74 75 72 6e 28 2d 31  ED;....return(-1
1820: 29 3b 0a 09 63 61 73 65 20 53 53 4c 5f 45 52 52  );..case SSL_ERR
1830: 4f 52 5f 53 53 4c 3a 0a 09 20 20 20 20 64 70 72  OR_SSL:..    dpr
1840: 69 6e 74 66 28 22 47 6f 74 20 70 65 72 6d 61 6e  intf("Got perman
1850: 65 6e 74 20 66 61 74 61 6c 20 53 53 4c 20 65 72  ent fatal SSL er
1860: 72 6f 72 2c 20 61 62 6f 72 74 69 6e 67 20 69 6d  ror, aborting im
1870: 6d 65 64 69 61 74 65 6c 79 22 29 3b 0a 09 09 54  mediately");...T
1880: 6c 73 5f 45 72 72 6f 72 28 73 74 61 74 65 50 74  ls_Error(statePt
1890: 72 2c 20 28 63 68 61 72 20 2a 29 45 52 52 5f 72  r, (char *)ERR_r
18a0: 65 61 73 6f 6e 5f 65 72 72 6f 72 5f 73 74 72 69  eason_error_stri
18b0: 6e 67 28 45 52 52 5f 67 65 74 5f 65 72 72 6f 72  ng(ERR_get_error
18c0: 28 29 29 29 3b 0a 09 20 20 20 20 73 74 61 74 65  ()));..    state
18d0: 50 74 72 2d 3e 66 6c 61 67 73 20 7c 3d 20 54 4c  Ptr->flags |= TL
18e0: 53 5f 54 43 4c 5f 48 41 4e 44 53 48 41 4b 45 5f  S_TCL_HANDSHAKE_
18f0: 46 41 49 4c 45 44 3b 0a 09 20 20 20 20 2a 65 72  FAILED;..    *er
1900: 72 6f 72 43 6f 64 65 50 74 72 20 3d 20 45 43 4f  rorCodePtr = ECO
1910: 4e 4e 41 42 4f 52 54 45 44 3b 0a 09 20 20 20 20  NNABORTED;..    
1920: 72 65 74 75 72 6e 28 2d 31 29 3b 0a 09 63 61 73  return(-1);..cas
1930: 65 20 53 53 4c 5f 45 52 52 4f 52 5f 57 41 4e 54  e SSL_ERROR_WANT
1940: 5f 43 4f 4e 4e 45 43 54 3a 0a 09 63 61 73 65 20  _CONNECT:..case 
1950: 53 53 4c 5f 45 52 52 4f 52 5f 57 41 4e 54 5f 41  SSL_ERROR_WANT_A
1960: 43 43 45 50 54 3a 0a 09 63 61 73 65 20 53 53 4c  CCEPT:..case SSL
1970: 5f 45 52 52 4f 52 5f 57 41 4e 54 5f 58 35 30 39  _ERROR_WANT_X509
1980: 5f 4c 4f 4f 4b 55 50 3a 0a 09 64 65 66 61 75 6c  _LOOKUP:..defaul
1990: 74 3a 0a 09 20 20 20 20 64 70 72 69 6e 74 66 28  t:..    dprintf(
19a0: 22 57 65 20 67 6f 74 20 61 20 63 6f 6e 66 75 73  "We got a confus
19b0: 69 6e 67 20 72 65 70 6c 79 3a 20 25 69 22 2c 20  ing reply: %i", 
19c0: 72 63 29 3b 0a 09 20 20 20 20 2a 65 72 72 6f 72  rc);..    *error
19d0: 43 6f 64 65 50 74 72 20 3d 20 54 63 6c 5f 47 65  CodePtr = Tcl_Ge
19e0: 74 45 72 72 6e 6f 28 29 3b 0a 09 20 20 20 20 64  tErrno();..    d
19f0: 70 72 69 6e 74 66 28 22 45 52 52 28 25 64 2c 20  printf("ERR(%d, 
1a00: 25 64 29 20 22 2c 20 72 63 2c 20 2a 65 72 72 6f  %d) ", rc, *erro
1a10: 72 43 6f 64 65 50 74 72 29 3b 0a 09 20 20 20 20  rCodePtr);..    
1a20: 72 65 74 75 72 6e 28 2d 31 29 3b 0a 20 20 20 20  return(-1);.    
1a30: 7d 0a 0a 23 69 66 20 30 0a 20 20 20 20 69 66 20  }..#if 0.    if 
1a40: 28 73 74 61 74 65 50 74 72 2d 3e 66 6c 61 67 73  (statePtr->flags
1a50: 20 26 20 54 4c 53 5f 54 43 4c 5f 53 45 52 56 45   & TLS_TCL_SERVE
1a60: 52 29 20 7b 0a 09 64 70 72 69 6e 74 66 28 22 54  R) {..dprintf("T
1a70: 68 69 73 20 69 73 20 61 6e 20 54 4c 53 20 73 65  his is an TLS se
1a80: 72 76 65 72 2c 20 63 68 65 63 6b 69 6e 67 20 74  rver, checking t
1a90: 68 65 20 63 65 72 74 69 66 69 63 61 74 65 20 66  he certificate f
1aa0: 6f 72 20 74 68 65 20 70 65 65 72 22 29 3b 0a 0a  or the peer");..
1ab0: 09 65 72 72 20 3d 20 53 53 4c 5f 67 65 74 5f 76  .err = SSL_get_v
1ac0: 65 72 69 66 79 5f 72 65 73 75 6c 74 28 73 74 61  erify_result(sta
1ad0: 74 65 50 74 72 2d 3e 73 73 6c 29 3b 0a 09 69 66  tePtr->ssl);..if
1ae0: 20 28 65 72 72 20 21 3d 20 58 35 30 39 5f 56 5f   (err != X509_V_
1af0: 4f 4b 29 20 7b 0a 09 09 64 70 72 69 6e 74 66 28  OK) {...dprintf(
1b00: 22 49 6e 76 61 6c 69 64 20 63 65 72 74 69 66 69  "Invalid certifi
1b10: 63 61 74 65 2c 20 72 65 74 75 72 6e 69 6e 67 20  cate, returning 
1b20: 69 6e 20 66 61 69 6c 75 72 65 22 29 3b 0a 0a 09  in failure");...
1b30: 09 54 6c 73 5f 45 72 72 6f 72 28 73 74 61 74 65  .Tls_Error(state
1b40: 50 74 72 2c 20 28 63 68 61 72 20 2a 29 58 35 30  Ptr, (char *)X50
1b50: 39 5f 76 65 72 69 66 79 5f 63 65 72 74 5f 65 72  9_verify_cert_er
1b60: 72 6f 72 5f 73 74 72 69 6e 67 28 65 72 72 29 29  ror_string(err))
1b70: 3b 0a 09 09 73 74 61 74 65 50 74 72 2d 3e 66 6c  ;...statePtr->fl
1b80: 61 67 73 20 7c 3d 20 54 4c 53 5f 54 43 4c 5f 48  ags |= TLS_TCL_H
1b90: 41 4e 44 53 48 41 4b 45 5f 46 41 49 4c 45 44 3b  ANDSHAKE_FAILED;
1ba0: 0a 09 09 2a 65 72 72 6f 72 43 6f 64 65 50 74 72  ...*errorCodePtr
1bb0: 20 3d 20 45 43 4f 4e 4e 41 42 4f 52 54 45 44 3b   = ECONNABORTED;
1bc0: 0a 09 09 72 65 74 75 72 6e 28 2d 31 29 3b 0a 09  ...return(-1);..
1bd0: 7d 0a 20 20 20 20 7d 0a 23 65 6e 64 69 66 0a 0a  }.    }.#endif..
1be0: 20 20 20 20 64 70 72 69 6e 74 66 28 22 52 65 6d      dprintf("Rem
1bf0: 6f 76 69 6e 67 20 74 68 65 20 5c 22 54 4c 53 5f  oving the \"TLS_
1c00: 54 43 4c 5f 49 4e 49 54 5c 22 20 66 6c 61 67 20  TCL_INIT\" flag 
1c10: 73 69 6e 63 65 20 77 65 20 68 61 76 65 20 63 6f  since we have co
1c20: 6d 70 6c 65 74 65 64 20 74 68 65 20 68 61 6e 64  mpleted the hand
1c30: 73 68 61 6b 65 22 29 3b 0a 20 20 20 20 73 74 61  shake");.    sta
1c40: 74 65 50 74 72 2d 3e 66 6c 61 67 73 20 26 3d 20  tePtr->flags &= 
1c50: 7e 54 4c 53 5f 54 43 4c 5f 49 4e 49 54 3b 0a 0a  ~TLS_TCL_INIT;..
1c60: 20 20 20 20 64 70 72 69 6e 74 66 28 22 52 65 74      dprintf("Ret
1c70: 75 72 6e 69 6e 67 20 69 6e 20 73 75 63 63 65 73  urning in succes
1c80: 73 22 29 3b 0a 20 20 20 20 2a 65 72 72 6f 72 43  s");.    *errorC
1c90: 6f 64 65 50 74 72 20 3d 20 30 3b 0a 20 20 20 20  odePtr = 0;.    
1ca0: 72 65 74 75 72 6e 20 30 3b 0a 7d 0a 0a 2f 2a 0a  return 0;.}../*.
1cb0: 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d   *--------------
1cc0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1cd0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1ce0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1cf0: 2d 2d 2d 2d 2d 0a 20 2a 0a 20 2a 20 54 6c 73 49  -----. *. * TlsI
1d00: 6e 70 75 74 50 72 6f 63 20 2d 2d 0a 20 2a 0a 20  nputProc --. *. 
1d10: 2a 20 20 20 20 54 68 69 73 20 70 72 6f 63 65 64  *    This proced
1d20: 75 72 65 20 69 73 20 69 6e 76 6f 6b 65 64 20 62  ure is invoked b
1d30: 79 20 74 68 65 20 67 65 6e 65 72 69 63 20 49 4f  y the generic IO
1d40: 20 6c 65 76 65 6c 0a 20 2a 20 20 20 20 20 20 20   level. *       
1d50: 74 6f 20 72 65 61 64 20 69 6e 70 75 74 20 66 72  to read input fr
1d60: 6f 6d 20 61 20 53 53 4c 20 73 6f 63 6b 65 74 20  om a SSL socket 
1d70: 62 61 73 65 64 20 63 68 61 6e 6e 65 6c 2e 0a 20  based channel.. 
1d80: 2a 0a 20 2a 20 52 65 73 75 6c 74 73 3a 0a 20 2a  *. * Results:. *
1d90: 20 20 20 20 52 65 74 75 72 6e 73 20 74 68 65 20      Returns the 
1da0: 6e 75 6d 62 65 72 20 6f 66 20 62 79 74 65 73 20  number of bytes 
1db0: 72 65 61 64 20 6f 72 20 2d 31 20 6f 6e 20 65 72  read or -1 on er
1dc0: 72 6f 72 2e 20 53 65 74 73 20 65 72 72 6f 72 43  ror. Sets errorC
1dd0: 6f 64 65 50 74 72 0a 20 2a 20 20 20 20 74 6f 20  odePtr. *    to 
1de0: 61 20 50 4f 53 49 58 20 65 72 72 6f 72 20 63 6f  a POSIX error co
1df0: 64 65 20 69 66 20 61 6e 20 65 72 72 6f 72 20 6f  de if an error o
1e00: 63 63 75 72 72 65 64 2c 20 6f 72 20 30 20 69 66  ccurred, or 0 if
1e10: 20 6e 6f 6e 65 2e 0a 20 2a 0a 20 2a 20 53 69 64   none.. *. * Sid
1e20: 65 20 65 66 66 65 63 74 73 3a 0a 20 2a 20 20 20  e effects:. *   
1e30: 20 52 65 61 64 73 20 69 6e 70 75 74 20 66 72 6f   Reads input fro
1e40: 6d 20 74 68 65 20 69 6e 70 75 74 20 64 65 76 69  m the input devi
1e50: 63 65 20 6f 66 20 74 68 65 20 63 68 61 6e 6e 65  ce of the channe
1e60: 6c 2e 0a 20 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d  l.. *. *--------
1e70: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1e80: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1e90: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1ea0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 2f 0a  -----------. */.
1eb0: 0a 73 74 61 74 69 63 20 69 6e 74 20 54 6c 73 49  .static int TlsI
1ec0: 6e 70 75 74 50 72 6f 63 28 0a 20 20 20 20 76 6f  nputProc(.    vo
1ed0: 69 64 20 2a 69 6e 73 74 61 6e 63 65 44 61 74 61  id *instanceData
1ee0: 2c 0a 20 20 20 20 63 68 61 72 20 2a 62 75 66 2c  ,.    char *buf,
1ef0: 0a 20 20 20 20 69 6e 74 20 62 75 66 53 69 7a 65  .    int bufSize
1f00: 2c 0a 20 20 20 20 69 6e 74 20 2a 65 72 72 6f 72  ,.    int *error
1f10: 43 6f 64 65 50 74 72 29 0a 7b 0a 20 20 20 20 75  CodePtr).{.    u
1f20: 6e 73 69 67 6e 65 64 20 6c 6f 6e 67 20 62 61 63  nsigned long bac
1f30: 6b 69 6e 67 45 72 72 6f 72 3b 0a 20 20 20 20 53  kingError;.    S
1f40: 74 61 74 65 20 2a 73 74 61 74 65 50 74 72 20 3d  tate *statePtr =
1f50: 20 28 53 74 61 74 65 20 2a 29 20 69 6e 73 74 61   (State *) insta
1f60: 6e 63 65 44 61 74 61 3b 0a 20 20 20 20 69 6e 74  nceData;.    int
1f70: 20 62 79 74 65 73 52 65 61 64 3b 0a 20 20 20 20   bytesRead;.    
1f80: 69 6e 74 20 74 6c 73 43 6f 6e 6e 65 63 74 3b 0a  int tlsConnect;.
1f90: 20 20 20 20 69 6e 74 20 65 72 72 3b 0a 0a 20 20      int err;..  
1fa0: 20 20 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 20    *errorCodePtr 
1fb0: 3d 20 30 3b 0a 0a 20 20 20 20 64 70 72 69 6e 74  = 0;..    dprint
1fc0: 66 28 22 42 49 4f 5f 72 65 61 64 28 25 64 29 22  f("BIO_read(%d)"
1fd0: 2c 20 62 75 66 53 69 7a 65 29 3b 0a 0a 20 20 20  , bufSize);..   
1fe0: 20 69 66 20 28 73 74 61 74 65 50 74 72 2d 3e 66   if (statePtr->f
1ff0: 6c 61 67 73 20 26 20 54 4c 53 5f 54 43 4c 5f 43  lags & TLS_TCL_C
2000: 41 4c 4c 42 41 43 4b 29 20 7b 0a 09 2f 2a 20 64  ALLBACK) {../* d
2010: 6f 6e 27 74 20 70 72 6f 63 65 73 73 20 61 6e 79  on't process any
2020: 20 62 79 74 65 73 20 77 68 69 6c 65 20 76 65 72   bytes while ver
2030: 69 66 79 20 63 61 6c 6c 62 61 63 6b 20 69 73 20  ify callback is 
2040: 72 75 6e 6e 69 6e 67 20 2a 2f 0a 09 64 70 72 69  running */..dpri
2050: 6e 74 66 28 22 43 61 6c 6c 62 61 63 6b 20 69 73  ntf("Callback is
2060: 20 72 75 6e 6e 69 6e 67 2c 20 72 65 61 64 69 6e   running, readin
2070: 67 20 30 20 62 79 74 65 73 22 29 3b 0a 09 72 65  g 0 bytes");..re
2080: 74 75 72 6e 28 30 29 3b 0a 20 20 20 20 7d 0a 0a  turn(0);.    }..
2090: 20 20 20 20 64 70 72 69 6e 74 66 28 22 43 61 6c      dprintf("Cal
20a0: 6c 69 6e 67 20 54 6c 73 5f 57 61 69 74 46 6f 72  ling Tls_WaitFor
20b0: 43 6f 6e 6e 65 63 74 22 29 3b 0a 20 20 20 20 74  Connect");.    t
20c0: 6c 73 43 6f 6e 6e 65 63 74 20 3d 20 54 6c 73 5f  lsConnect = Tls_
20d0: 57 61 69 74 46 6f 72 43 6f 6e 6e 65 63 74 28 73  WaitForConnect(s
20e0: 74 61 74 65 50 74 72 2c 20 65 72 72 6f 72 43 6f  tatePtr, errorCo
20f0: 64 65 50 74 72 2c 20 30 29 3b 0a 20 20 20 20 69  dePtr, 0);.    i
2100: 66 20 28 74 6c 73 43 6f 6e 6e 65 63 74 20 3c 20  f (tlsConnect < 
2110: 30 29 20 7b 0a 09 64 70 72 69 6e 74 66 28 22 47  0) {..dprintf("G
2120: 6f 74 20 61 6e 20 65 72 72 6f 72 20 77 61 69 74  ot an error wait
2130: 69 6e 67 20 74 6f 20 63 6f 6e 6e 65 63 74 20 28  ing to connect (
2140: 74 6c 73 43 6f 6e 6e 65 63 74 20 3d 20 25 69 2c  tlsConnect = %i,
2150: 20 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 20 3d   *errorCodePtr =
2160: 20 25 69 29 22 2c 20 74 6c 73 43 6f 6e 6e 65 63   %i)", tlsConnec
2170: 74 2c 20 2a 65 72 72 6f 72 43 6f 64 65 50 74 72  t, *errorCodePtr
2180: 29 3b 0a 0a 09 62 79 74 65 73 52 65 61 64 20 3d  );...bytesRead =
2190: 20 2d 31 3b 0a 09 69 66 20 28 2a 65 72 72 6f 72   -1;..if (*error
21a0: 43 6f 64 65 50 74 72 20 3d 3d 20 45 43 4f 4e 4e  CodePtr == ECONN
21b0: 52 45 53 45 54 29 20 7b 0a 09 20 20 20 20 64 70  RESET) {..    dp
21c0: 72 69 6e 74 66 28 22 47 6f 74 20 63 6f 6e 6e 65  rintf("Got conne
21d0: 63 74 69 6f 6e 20 72 65 73 65 74 22 29 3b 0a 09  ction reset");..
21e0: 20 20 20 20 2f 2a 20 53 6f 66 74 20 45 4f 46 20      /* Soft EOF 
21f0: 2a 2f 0a 09 20 20 20 20 2a 65 72 72 6f 72 43 6f  */..    *errorCo
2200: 64 65 50 74 72 20 3d 20 30 3b 0a 09 20 20 20 20  dePtr = 0;..    
2210: 62 79 74 65 73 52 65 61 64 20 3d 20 30 3b 0a 09  bytesRead = 0;..
2220: 7d 0a 09 72 65 74 75 72 6e 28 62 79 74 65 73 52  }..return(bytesR
2230: 65 61 64 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20  ead);.    }..   
2240: 20 2f 2a 0a 20 20 20 20 20 2a 20 57 65 20 6e 65   /*.     * We ne
2250: 65 64 20 74 6f 20 63 6c 65 61 72 20 74 68 65 20  ed to clear the 
2260: 53 53 4c 20 65 72 72 6f 72 20 73 74 61 63 6b 20  SSL error stack 
2270: 6e 6f 77 20 62 65 63 61 75 73 65 20 77 65 20 73  now because we s
2280: 6f 6d 65 74 69 6d 65 73 20 72 65 61 63 68 0a 20  ometimes reach. 
2290: 20 20 20 20 2a 20 74 68 69 73 20 66 75 6e 63 74      * this funct
22a0: 69 6f 6e 20 77 69 74 68 20 6c 65 66 74 6f 76 65  ion with leftove
22b0: 72 20 65 72 72 6f 72 73 20 69 6e 20 74 68 65 20  r errors in the 
22c0: 73 74 61 63 6b 2e 20 20 49 66 20 42 49 4f 5f 72  stack.  If BIO_r
22d0: 65 61 64 0a 20 20 20 20 20 2a 20 72 65 74 75 72  ead.     * retur
22e0: 6e 73 20 2d 31 20 61 6e 64 20 69 6e 74 65 6e 64  ns -1 and intend
22f0: 73 20 45 41 47 41 49 4e 2c 20 74 68 65 72 65 20  s EAGAIN, there 
2300: 69 73 20 61 20 6c 65 66 74 6f 76 65 72 20 65 72  is a leftover er
2310: 72 6f 72 2c 20 69 74 20 77 69 6c 6c 20 62 65 0a  ror, it will be.
2320: 20 20 20 20 20 2a 20 6d 69 73 63 6f 6e 73 74 72       * misconstr
2330: 75 65 64 20 61 73 20 61 6e 20 65 72 72 6f 72 2c  ued as an error,
2340: 20 6e 6f 74 20 45 41 47 41 49 4e 2e 0a 20 20 20   not EAGAIN..   
2350: 20 20 2a 0a 20 20 20 20 20 2a 20 41 6c 74 65 72    *.     * Alter
2360: 6e 61 74 69 76 65 6c 79 2c 20 77 65 20 6d 61 79  natively, we may
2370: 20 77 61 6e 74 20 74 6f 20 68 61 6e 64 6c 65 20   want to handle 
2380: 74 68 65 20 3c 30 20 72 65 74 75 72 6e 20 63 6f  the <0 return co
2390: 64 65 73 20 66 72 6f 6d 0a 20 20 20 20 20 2a 20  des from.     * 
23a0: 42 49 4f 5f 72 65 61 64 20 73 70 65 63 69 61 6c  BIO_read special
23b0: 6c 79 20 28 61 73 20 61 64 76 69 73 65 64 20 69  ly (as advised i
23c0: 6e 20 74 68 65 20 52 53 41 20 64 6f 63 73 29 2e  n the RSA docs).
23d0: 20 20 54 4c 53 27 73 20 6c 6f 77 65 72 20 6c 65    TLS's lower le
23e0: 76 65 6c 20 42 49 4f 0a 20 20 20 20 20 2a 20 66  vel BIO.     * f
23f0: 75 6e 63 74 69 6f 6e 73 20 70 6c 61 79 20 77 69  unctions play wi
2400: 74 68 20 74 68 65 20 72 65 74 72 79 20 66 6c 61  th the retry fla
2410: 67 73 20 74 68 6f 75 67 68 2c 20 61 6e 64 20 74  gs though, and t
2420: 68 69 73 20 73 65 65 6d 73 20 74 6f 20 77 6f 72  his seems to wor
2430: 6b 0a 20 20 20 20 20 2a 20 63 6f 72 72 65 63 74  k.     * correct
2440: 6c 79 2e 20 20 53 69 6d 69 6c 61 72 20 66 69 78  ly.  Similar fix
2450: 20 69 6e 20 54 6c 73 4f 75 74 70 75 74 50 72 6f   in TlsOutputPro
2460: 63 2e 20 2d 20 68 6f 62 62 73 0a 20 20 20 20 20  c. - hobbs.     
2470: 2a 2f 0a 20 20 20 20 45 52 52 5f 63 6c 65 61 72  */.    ERR_clear
2480: 5f 65 72 72 6f 72 28 29 3b 0a 20 20 20 20 62 79  _error();.    by
2490: 74 65 73 52 65 61 64 20 3d 20 42 49 4f 5f 72 65  tesRead = BIO_re
24a0: 61 64 28 73 74 61 74 65 50 74 72 2d 3e 62 69 6f  ad(statePtr->bio
24b0: 2c 20 62 75 66 2c 20 62 75 66 53 69 7a 65 29 3b  , buf, bufSize);
24c0: 0a 20 20 20 20 64 70 72 69 6e 74 66 28 22 42 49  .    dprintf("BI
24d0: 4f 5f 72 65 61 64 20 2d 3e 20 25 64 22 2c 20 62  O_read -> %d", b
24e0: 79 74 65 73 52 65 61 64 29 3b 0a 0a 20 20 20 20  ytesRead);..    
24f0: 65 72 72 20 3d 20 53 53 4c 5f 67 65 74 5f 65 72  err = SSL_get_er
2500: 72 6f 72 28 73 74 61 74 65 50 74 72 2d 3e 73 73  ror(statePtr->ss
2510: 6c 2c 20 62 79 74 65 73 52 65 61 64 29 3b 0a 0a  l, bytesRead);..
2520: 23 69 66 20 30 0a 20 20 20 20 69 66 20 28 62 79  #if 0.    if (by
2530: 74 65 73 52 65 61 64 20 3c 3d 20 30 29 20 7b 0a  tesRead <= 0) {.
2540: 09 69 66 20 28 42 49 4f 5f 73 68 6f 75 6c 64 5f  .if (BIO_should_
2550: 72 65 74 72 79 28 73 74 61 74 65 50 74 72 2d 3e  retry(statePtr->
2560: 62 69 6f 29 29 20 7b 0a 09 20 20 20 20 64 70 72  bio)) {..    dpr
2570: 69 6e 74 66 28 22 49 2f 4f 20 66 61 69 6c 65 64  intf("I/O failed
2580: 2c 20 77 69 6c 6c 20 72 65 74 72 79 20 62 61 73  , will retry bas
2590: 65 64 20 6f 6e 20 45 41 47 41 49 4e 22 29 3b 0a  ed on EAGAIN");.
25a0: 09 20 20 20 20 2a 65 72 72 6f 72 43 6f 64 65 50  .    *errorCodeP
25b0: 74 72 20 3d 20 45 41 47 41 49 4e 3b 0a 09 7d 0a  tr = EAGAIN;..}.
25c0: 20 20 20 20 7d 0a 23 65 6e 64 69 66 0a 0a 20 20      }.#endif..  
25d0: 20 20 73 77 69 74 63 68 20 28 65 72 72 29 20 7b    switch (err) {
25e0: 0a 09 63 61 73 65 20 53 53 4c 5f 45 52 52 4f 52  ..case SSL_ERROR
25f0: 5f 4e 4f 4e 45 3a 0a 09 20 20 20 20 64 70 72 69  _NONE:..    dpri
2600: 6e 74 42 75 66 66 65 72 28 62 75 66 2c 20 62 79  ntBuffer(buf, by
2610: 74 65 73 52 65 61 64 29 3b 0a 09 20 20 20 20 62  tesRead);..    b
2620: 72 65 61 6b 3b 0a 09 63 61 73 65 20 53 53 4c 5f  reak;..case SSL_
2630: 45 52 52 4f 52 5f 53 53 4c 3a 0a 09 20 20 20 20  ERROR_SSL:..    
2640: 64 70 72 69 6e 74 66 28 22 53 53 4c 20 6e 65 67  dprintf("SSL neg
2650: 6f 74 69 61 74 69 6f 6e 20 65 72 72 6f 72 2c 20  otiation error, 
2660: 69 6e 64 69 63 61 74 69 6e 67 20 74 68 61 74 20  indicating that 
2670: 74 68 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 68  the connection h
2680: 61 73 20 62 65 65 6e 20 61 62 6f 72 74 65 64 22  as been aborted"
2690: 29 3b 0a 0a 09 20 20 20 20 54 6c 73 5f 45 72 72  );...    Tls_Err
26a0: 6f 72 28 73 74 61 74 65 50 74 72 2c 20 54 43 4c  or(statePtr, TCL
26b0: 54 4c 53 5f 53 53 4c 5f 45 52 52 4f 52 28 73 74  TLS_SSL_ERROR(st
26c0: 61 74 65 50 74 72 2d 3e 73 73 6c 2c 20 62 79 74  atePtr->ssl, byt
26d0: 65 73 52 65 61 64 29 29 3b 0a 09 20 20 20 20 2a  esRead));..    *
26e0: 65 72 72 6f 72 43 6f 64 65 50 74 72 20 3d 20 45  errorCodePtr = E
26f0: 43 4f 4e 4e 41 42 4f 52 54 45 44 3b 0a 09 20 20  CONNABORTED;..  
2700: 20 20 62 79 74 65 73 52 65 61 64 20 3d 20 2d 31    bytesRead = -1
2710: 3b 0a 0a 09 20 20 20 20 62 72 65 61 6b 3b 0a 09  ;...    break;..
2720: 63 61 73 65 20 53 53 4c 5f 45 52 52 4f 52 5f 53  case SSL_ERROR_S
2730: 59 53 43 41 4c 4c 3a 0a 09 09 62 61 63 6b 69 6e  YSCALL:...backin
2740: 67 45 72 72 6f 72 20 3d 20 45 52 52 5f 67 65 74  gError = ERR_get
2750: 5f 65 72 72 6f 72 28 29 3b 0a 0a 09 09 69 66 20  _error();....if 
2760: 28 62 61 63 6b 69 6e 67 45 72 72 6f 72 20 3d 3d  (backingError ==
2770: 20 30 20 26 26 20 62 79 74 65 73 52 65 61 64 20   0 && bytesRead 
2780: 3d 3d 20 30 29 20 7b 0a 09 09 09 09 64 70 72 69  == 0) {.....dpri
2790: 6e 74 66 28 22 45 4f 46 20 72 65 61 63 68 65 64  ntf("EOF reached
27a0: 22 29 0a 09 09 09 09 2a 65 72 72 6f 72 43 6f 64  ").....*errorCod
27b0: 65 50 74 72 20 3d 20 30 3b 0a 09 09 09 09 62 79  ePtr = 0;.....by
27c0: 74 65 73 52 65 61 64 20 3d 20 30 3b 0a 09 09 7d  tesRead = 0;...}
27d0: 20 65 6c 73 65 20 69 66 20 28 62 61 63 6b 69 6e   else if (backin
27e0: 67 45 72 72 6f 72 20 3d 3d 20 30 20 26 26 20 62  gError == 0 && b
27f0: 79 74 65 73 52 65 61 64 20 3d 3d 20 2d 31 29 20  ytesRead == -1) 
2800: 7b 0a 09 09 09 09 64 70 72 69 6e 74 66 28 22 49  {.....dprintf("I
2810: 2f 4f 20 65 72 72 6f 72 20 6f 63 63 75 72 72 65  /O error occurre
2820: 64 20 28 65 72 72 6e 6f 20 3d 20 25 6c 75 29 22  d (errno = %lu)"
2830: 2c 20 28 75 6e 73 69 67 6e 65 64 20 6c 6f 6e 67  , (unsigned long
2840: 29 20 54 63 6c 5f 47 65 74 45 72 72 6e 6f 28 29  ) Tcl_GetErrno()
2850: 29 3b 0a 09 09 09 09 2a 65 72 72 6f 72 43 6f 64  );.....*errorCod
2860: 65 50 74 72 20 3d 20 54 63 6c 5f 47 65 74 45 72  ePtr = Tcl_GetEr
2870: 72 6e 6f 28 29 3b 0a 09 09 09 09 62 79 74 65 73  rno();.....bytes
2880: 52 65 61 64 20 3d 20 2d 31 3b 0a 09 09 7d 20 65  Read = -1;...} e
2890: 6c 73 65 20 7b 0a 09 09 09 09 64 70 72 69 6e 74  lse {.....dprint
28a0: 66 28 22 49 2f 4f 20 65 72 72 6f 72 20 6f 63 63  f("I/O error occ
28b0: 75 72 72 65 64 20 28 62 61 63 6b 69 6e 67 45 72  urred (backingEr
28c0: 72 6f 72 20 3d 20 25 6c 75 29 22 2c 20 62 61 63  ror = %lu)", bac
28d0: 6b 69 6e 67 45 72 72 6f 72 29 3b 0a 09 09 09 09  kingError);.....
28e0: 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 20 3d 20  *errorCodePtr = 
28f0: 62 61 63 6b 69 6e 67 45 72 72 6f 72 3b 0a 09 09  backingError;...
2900: 09 09 62 79 74 65 73 52 65 61 64 20 3d 20 2d 31  ..bytesRead = -1
2910: 3b 0a 09 09 7d 0a 0a 09 09 62 72 65 61 6b 3b 0a  ;...}....break;.
2920: 09 09 63 61 73 65 20 53 53 4c 5f 45 52 52 4f 52  ..case SSL_ERROR
2930: 5f 5a 45 52 4f 5f 52 45 54 55 52 4e 3a 0a 09 09  _ZERO_RETURN:...
2940: 09 64 70 72 69 6e 74 66 28 22 47 6f 74 20 53 53  .dprintf("Got SS
2950: 4c 5f 45 52 52 4f 52 5f 5a 45 52 4f 5f 52 45 54  L_ERROR_ZERO_RET
2960: 55 52 4e 2c 20 74 68 69 73 20 6d 65 61 6e 73 20  URN, this means 
2970: 61 6e 20 45 4f 46 20 68 61 73 20 62 65 65 6e 20  an EOF has been 
2980: 72 65 61 63 68 65 64 22 29 3b 0a 09 09 09 62 79  reached");....by
2990: 74 65 73 52 65 61 64 20 3d 20 30 3b 0a 09 09 09  tesRead = 0;....
29a0: 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 20 3d 20  *errorCodePtr = 
29b0: 30 3b 0a 09 09 09 62 72 65 61 6b 3b 0a 09 09 63  0;....break;...c
29c0: 61 73 65 20 53 53 4c 5f 45 52 52 4f 52 5f 57 41  ase SSL_ERROR_WA
29d0: 4e 54 5f 52 45 41 44 3a 0a 09 09 09 64 70 72 69  NT_READ:....dpri
29e0: 6e 74 66 28 22 47 6f 74 20 53 53 4c 5f 45 52 52  ntf("Got SSL_ERR
29f0: 4f 52 5f 57 41 4e 54 5f 52 45 41 44 2c 20 6d 61  OR_WANT_READ, ma
2a00: 70 70 69 6e 67 20 74 68 69 73 20 74 6f 20 45 41  pping this to EA
2a10: 47 41 49 4e 22 29 3b 0a 09 09 09 62 79 74 65 73  GAIN");....bytes
2a20: 52 65 61 64 20 3d 20 2d 31 3b 0a 09 09 09 2a 65  Read = -1;....*e
2a30: 72 72 6f 72 43 6f 64 65 50 74 72 20 3d 20 45 41  rrorCodePtr = EA
2a40: 47 41 49 4e 3b 0a 09 09 09 62 72 65 61 6b 3b 0a  GAIN;....break;.
2a50: 09 09 64 65 66 61 75 6c 74 3a 0a 09 09 09 64 70  ..default:....dp
2a60: 72 69 6e 74 66 28 22 55 6e 6b 6e 6f 77 6e 20 65  rintf("Unknown e
2a70: 72 72 6f 72 20 28 65 72 72 20 3d 20 25 69 29 2c  rror (err = %i),
2a80: 20 6d 61 70 70 69 6e 67 20 74 6f 20 45 4f 46 22   mapping to EOF"
2a90: 2c 20 65 72 72 29 3b 0a 09 09 2a 65 72 72 6f 72  , err);...*error
2aa0: 43 6f 64 65 50 74 72 20 3d 20 30 3b 0a 09 09 62  CodePtr = 0;...b
2ab0: 79 74 65 73 52 65 61 64 20 3d 20 30 3b 0a 09 09  ytesRead = 0;...
2ac0: 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a 0a 20 20  break;.    }..  
2ad0: 20 20 64 70 72 69 6e 74 66 28 22 49 6e 70 75 74    dprintf("Input
2ae0: 28 25 64 29 20 2d 3e 20 25 64 20 5b 25 64 5d 22  (%d) -> %d [%d]"
2af0: 2c 20 62 75 66 53 69 7a 65 2c 20 62 79 74 65 73  , bufSize, bytes
2b00: 52 65 61 64 2c 20 2a 65 72 72 6f 72 43 6f 64 65  Read, *errorCode
2b10: 50 74 72 29 3b 0a 20 20 20 20 72 65 74 75 72 6e  Ptr);.    return
2b20: 20 62 79 74 65 73 52 65 61 64 3b 0a 7d 0a 0a 2f   bytesRead;.}../
2b30: 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  *. *------------
2b40: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2b50: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2b60: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2b70: 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 0a 20 2a 20 54 6c  -------. *. * Tl
2b80: 73 4f 75 74 70 75 74 50 72 6f 63 20 2d 2d 0a 20  sOutputProc --. 
2b90: 2a 0a 20 2a 20 20 20 20 54 68 69 73 20 70 72 6f  *. *    This pro
2ba0: 63 65 64 75 72 65 20 69 73 20 69 6e 76 6f 6b 65  cedure is invoke
2bb0: 64 20 62 79 20 74 68 65 20 67 65 6e 65 72 69 63  d by the generic
2bc0: 20 49 4f 20 6c 65 76 65 6c 0a 20 2a 20 20 20 20   IO level. *    
2bd0: 20 20 20 74 6f 20 77 72 69 74 65 20 6f 75 74 70     to write outp
2be0: 75 74 20 74 6f 20 61 20 53 53 4c 20 73 6f 63 6b  ut to a SSL sock
2bf0: 65 74 20 62 61 73 65 64 20 63 68 61 6e 6e 65 6c  et based channel
2c00: 2e 0a 20 2a 0a 20 2a 20 52 65 73 75 6c 74 73 3a  .. *. * Results:
2c10: 0a 20 2a 20 20 20 20 52 65 74 75 72 6e 73 20 74  . *    Returns t
2c20: 68 65 20 6e 75 6d 62 65 72 20 6f 66 20 62 79 74  he number of byt
2c30: 65 73 20 77 72 69 74 74 65 6e 20 6f 72 20 2d 31  es written or -1
2c40: 20 6f 6e 20 65 72 72 6f 72 2e 20 53 65 74 73 20   on error. Sets 
2c50: 65 72 72 6f 72 43 6f 64 65 50 74 72 0a 20 2a 20  errorCodePtr. * 
2c60: 20 20 20 74 6f 20 61 20 50 4f 53 49 58 20 65 72     to a POSIX er
2c70: 72 6f 72 20 63 6f 64 65 20 69 66 20 61 6e 20 65  ror code if an e
2c80: 72 72 6f 72 20 6f 63 63 75 72 72 65 64 2c 20 6f  rror occurred, o
2c90: 72 20 30 20 69 66 20 6e 6f 6e 65 2e 0a 20 2a 0a  r 0 if none.. *.
2ca0: 20 2a 20 53 69 64 65 20 65 66 66 65 63 74 73 3a   * Side effects:
2cb0: 0a 20 2a 20 20 20 20 57 72 69 74 65 73 20 6f 75  . *    Writes ou
2cc0: 74 70 75 74 20 6f 6e 20 74 68 65 20 6f 75 74 70  tput on the outp
2cd0: 75 74 20 64 65 76 69 63 65 20 6f 66 20 74 68 65  ut device of the
2ce0: 20 63 68 61 6e 6e 65 6c 2e 0a 20 2a 0a 20 2a 2d   channel.. *. *-
2cf0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2d00: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2d10: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2d20: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2d30: 2d 2d 0a 20 2a 2f 0a 0a 73 74 61 74 69 63 20 69  --. */..static i
2d40: 6e 74 20 54 6c 73 4f 75 74 70 75 74 50 72 6f 63  nt TlsOutputProc
2d50: 28 0a 20 20 20 20 76 6f 69 64 20 2a 69 6e 73 74  (.    void *inst
2d60: 61 6e 63 65 44 61 74 61 2c 0a 20 20 20 20 63 6f  anceData,.    co
2d70: 6e 73 74 20 63 68 61 72 20 2a 62 75 66 2c 0a 20  nst char *buf,. 
2d80: 20 20 20 69 6e 74 20 74 6f 57 72 69 74 65 2c 0a     int toWrite,.
2d90: 20 20 20 20 69 6e 74 20 2a 65 72 72 6f 72 43 6f      int *errorCo
2da0: 64 65 50 74 72 29 0a 7b 0a 20 20 20 20 75 6e 73  dePtr).{.    uns
2db0: 69 67 6e 65 64 20 6c 6f 6e 67 20 62 61 63 6b 69  igned long backi
2dc0: 6e 67 45 72 72 6f 72 3b 0a 20 20 20 20 53 74 61  ngError;.    Sta
2dd0: 74 65 20 2a 73 74 61 74 65 50 74 72 20 3d 20 28  te *statePtr = (
2de0: 53 74 61 74 65 20 2a 29 20 69 6e 73 74 61 6e 63  State *) instanc
2df0: 65 44 61 74 61 3b 0a 20 20 20 20 69 6e 74 20 77  eData;.    int w
2e00: 72 69 74 74 65 6e 2c 20 65 72 72 3b 0a 20 20 20  ritten, err;.   
2e10: 20 69 6e 74 20 74 6c 73 43 6f 6e 6e 65 63 74 3b   int tlsConnect;
2e20: 0a 0a 20 20 20 20 2a 65 72 72 6f 72 43 6f 64 65  ..    *errorCode
2e30: 50 74 72 20 3d 20 30 3b 0a 0a 20 20 20 20 64 70  Ptr = 0;..    dp
2e40: 72 69 6e 74 66 28 22 42 49 4f 5f 77 72 69 74 65  rintf("BIO_write
2e50: 28 25 70 2c 20 25 64 29 22 2c 20 28 76 6f 69 64  (%p, %d)", (void
2e60: 20 2a 29 20 73 74 61 74 65 50 74 72 2c 20 74 6f   *) statePtr, to
2e70: 57 72 69 74 65 29 3b 0a 20 20 20 20 64 70 72 69  Write);.    dpri
2e80: 6e 74 42 75 66 66 65 72 28 62 75 66 2c 20 74 6f  ntBuffer(buf, to
2e90: 57 72 69 74 65 29 3b 0a 0a 20 20 20 20 69 66 20  Write);..    if 
2ea0: 28 73 74 61 74 65 50 74 72 2d 3e 66 6c 61 67 73  (statePtr->flags
2eb0: 20 26 20 54 4c 53 5f 54 43 4c 5f 43 41 4c 4c 42   & TLS_TCL_CALLB
2ec0: 41 43 4b 29 20 7b 0a 09 64 70 72 69 6e 74 66 28  ACK) {..dprintf(
2ed0: 22 44 6f 6e 27 74 20 70 72 6f 63 65 73 73 20 6f  "Don't process o
2ee0: 75 74 70 75 74 20 77 68 69 6c 65 20 63 61 6c 6c  utput while call
2ef0: 62 61 63 6b 73 20 61 72 65 20 72 75 6e 6e 69 6e  backs are runnin
2f00: 67 22 29 3b 0a 09 77 72 69 74 74 65 6e 20 3d 20  g");..written = 
2f10: 2d 31 3b 0a 09 2a 65 72 72 6f 72 43 6f 64 65 50  -1;..*errorCodeP
2f20: 74 72 20 3d 20 45 41 47 41 49 4e 3b 0a 09 72 65  tr = EAGAIN;..re
2f30: 74 75 72 6e 28 2d 31 29 3b 0a 20 20 20 20 7d 0a  turn(-1);.    }.
2f40: 0a 20 20 20 20 64 70 72 69 6e 74 66 28 22 43 61  .    dprintf("Ca
2f50: 6c 6c 69 6e 67 20 54 6c 73 5f 57 61 69 74 46 6f  lling Tls_WaitFo
2f60: 72 43 6f 6e 6e 65 63 74 22 29 3b 0a 20 20 20 20  rConnect");.    
2f70: 74 6c 73 43 6f 6e 6e 65 63 74 20 3d 20 54 6c 73  tlsConnect = Tls
2f80: 5f 57 61 69 74 46 6f 72 43 6f 6e 6e 65 63 74 28  _WaitForConnect(
2f90: 73 74 61 74 65 50 74 72 2c 20 65 72 72 6f 72 43  statePtr, errorC
2fa0: 6f 64 65 50 74 72 2c 20 31 29 3b 0a 20 20 20 20  odePtr, 1);.    
2fb0: 69 66 20 28 74 6c 73 43 6f 6e 6e 65 63 74 20 3c  if (tlsConnect <
2fc0: 20 30 29 20 7b 0a 09 64 70 72 69 6e 74 66 28 22   0) {..dprintf("
2fd0: 47 6f 74 20 61 6e 20 65 72 72 6f 72 20 77 61 69  Got an error wai
2fe0: 74 69 6e 67 20 74 6f 20 63 6f 6e 6e 65 63 74 20  ting to connect 
2ff0: 28 74 6c 73 43 6f 6e 6e 65 63 74 20 3d 20 25 69  (tlsConnect = %i
3000: 2c 20 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 20  , *errorCodePtr 
3010: 3d 20 25 69 29 22 2c 20 74 6c 73 43 6f 6e 6e 65  = %i)", tlsConne
3020: 63 74 2c 20 2a 65 72 72 6f 72 43 6f 64 65 50 74  ct, *errorCodePt
3030: 72 29 3b 0a 0a 09 77 72 69 74 74 65 6e 20 3d 20  r);...written = 
3040: 2d 31 3b 0a 09 69 66 20 28 2a 65 72 72 6f 72 43  -1;..if (*errorC
3050: 6f 64 65 50 74 72 20 3d 3d 20 45 43 4f 4e 4e 52  odePtr == ECONNR
3060: 45 53 45 54 29 20 7b 0a 09 20 20 20 20 64 70 72  ESET) {..    dpr
3070: 69 6e 74 66 28 22 47 6f 74 20 63 6f 6e 6e 65 63  intf("Got connec
3080: 74 69 6f 6e 20 72 65 73 65 74 22 29 3b 0a 09 20  tion reset");.. 
3090: 20 20 20 2f 2a 20 53 6f 66 74 20 45 4f 46 20 2a     /* Soft EOF *
30a0: 2f 0a 09 20 20 20 20 2a 65 72 72 6f 72 43 6f 64  /..    *errorCod
30b0: 65 50 74 72 20 3d 20 30 3b 0a 09 20 20 20 20 77  ePtr = 0;..    w
30c0: 72 69 74 74 65 6e 20 3d 20 30 3b 0a 09 7d 0a 09  ritten = 0;..}..
30d0: 72 65 74 75 72 6e 28 77 72 69 74 74 65 6e 29 3b  return(written);
30e0: 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 66 20 28  .    }..    if (
30f0: 74 6f 57 72 69 74 65 20 3d 3d 20 30 29 20 7b 0a  toWrite == 0) {.
3100: 09 64 70 72 69 6e 74 66 28 22 7a 65 72 6f 2d 77  .dprintf("zero-w
3110: 72 69 74 65 22 29 3b 0a 09 65 72 72 20 3d 20 42  rite");..err = B
3120: 49 4f 5f 66 6c 75 73 68 28 73 74 61 74 65 50 74  IO_flush(statePt
3130: 72 2d 3e 62 69 6f 29 3b 0a 0a 09 69 66 20 28 65  r->bio);...if (e
3140: 72 72 20 3c 3d 20 30 29 20 7b 0a 09 20 20 20 20  rr <= 0) {..    
3150: 64 70 72 69 6e 74 66 28 22 46 6c 75 73 68 69 6e  dprintf("Flushin
3160: 67 20 66 61 69 6c 65 64 22 29 3b 0a 0a 09 20 20  g failed");...  
3170: 20 20 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 20    *errorCodePtr 
3180: 3d 20 45 49 4f 3b 0a 09 20 20 20 20 77 72 69 74  = EIO;..    writ
3190: 74 65 6e 20 3d 20 30 3b 0a 09 20 20 20 20 72 65  ten = 0;..    re
31a0: 74 75 72 6e 28 2d 31 29 3b 0a 09 7d 0a 0a 09 77  turn(-1);..}...w
31b0: 72 69 74 74 65 6e 20 3d 20 30 3b 0a 09 2a 65 72  ritten = 0;..*er
31c0: 72 6f 72 43 6f 64 65 50 74 72 20 3d 20 30 3b 0a  rorCodePtr = 0;.
31d0: 09 72 65 74 75 72 6e 28 30 29 3b 0a 20 20 20 20  .return(0);.    
31e0: 7d 0a 0a 20 20 20 20 2f 2a 0a 20 20 20 20 20 2a  }..    /*.     *
31f0: 20 57 65 20 6e 65 65 64 20 74 6f 20 63 6c 65 61   We need to clea
3200: 72 20 74 68 65 20 53 53 4c 20 65 72 72 6f 72 20  r the SSL error 
3210: 73 74 61 63 6b 20 6e 6f 77 20 62 65 63 61 75 73  stack now becaus
3220: 65 20 77 65 20 73 6f 6d 65 74 69 6d 65 73 20 72  e we sometimes r
3230: 65 61 63 68 0a 20 20 20 20 20 2a 20 74 68 69 73  each.     * this
3240: 20 66 75 6e 63 74 69 6f 6e 20 77 69 74 68 20 6c   function with l
3250: 65 66 74 6f 76 65 72 20 65 72 72 6f 72 73 20 69  eftover errors i
3260: 6e 20 74 68 65 20 73 74 61 63 6b 2e 20 20 49 66  n the stack.  If
3270: 20 42 49 4f 5f 77 72 69 74 65 0a 20 20 20 20 20   BIO_write.     
3280: 2a 20 72 65 74 75 72 6e 73 20 2d 31 20 61 6e 64  * returns -1 and
3290: 20 69 6e 74 65 6e 64 73 20 45 41 47 41 49 4e 2c   intends EAGAIN,
32a0: 20 74 68 65 72 65 20 69 73 20 61 20 6c 65 66 74   there is a left
32b0: 6f 76 65 72 20 65 72 72 6f 72 2c 20 69 74 20 77  over error, it w
32c0: 69 6c 6c 20 62 65 0a 20 20 20 20 20 2a 20 6d 69  ill be.     * mi
32d0: 73 63 6f 6e 73 74 72 75 65 64 20 61 73 20 61 6e  sconstrued as an
32e0: 20 65 72 72 6f 72 2c 20 6e 6f 74 20 45 41 47 41   error, not EAGA
32f0: 49 4e 2e 0a 20 20 20 20 20 2a 0a 20 20 20 20 20  IN..     *.     
3300: 2a 20 41 6c 74 65 72 6e 61 74 69 76 65 6c 79 2c  * Alternatively,
3310: 20 77 65 20 6d 61 79 20 77 61 6e 74 20 74 6f 20   we may want to 
3320: 68 61 6e 64 6c 65 20 74 68 65 20 3c 30 20 72 65  handle the <0 re
3330: 74 75 72 6e 20 63 6f 64 65 73 20 66 72 6f 6d 0a  turn codes from.
3340: 20 20 20 20 20 2a 20 42 49 4f 5f 77 72 69 74 65       * BIO_write
3350: 20 73 70 65 63 69 61 6c 6c 79 20 28 61 73 20 61   specially (as a
3360: 64 76 69 73 65 64 20 69 6e 20 74 68 65 20 52 53  dvised in the RS
3370: 41 20 64 6f 63 73 29 2e 20 20 54 4c 53 27 73 20  A docs).  TLS's 
3380: 6c 6f 77 65 72 20 6c 65 76 65 6c 0a 20 20 20 20  lower level.    
3390: 20 2a 20 42 49 4f 20 66 75 6e 63 74 69 6f 6e 73   * BIO functions
33a0: 20 70 6c 61 79 20 77 69 74 68 20 74 68 65 20 72   play with the r
33b0: 65 74 72 79 20 66 6c 61 67 73 20 74 68 6f 75 67  etry flags thoug
33c0: 68 2c 20 61 6e 64 20 74 68 69 73 20 73 65 65 6d  h, and this seem
33d0: 73 20 74 6f 0a 20 20 20 20 20 2a 20 77 6f 72 6b  s to.     * work
33e0: 20 63 6f 72 72 65 63 74 6c 79 2e 20 20 53 69 6d   correctly.  Sim
33f0: 69 6c 61 72 20 66 69 78 20 69 6e 20 54 6c 73 49  ilar fix in TlsI
3400: 6e 70 75 74 50 72 6f 63 2e 20 2d 20 68 6f 62 62  nputProc. - hobb
3410: 73 0a 20 20 20 20 20 2a 2f 0a 20 20 20 20 45 52  s.     */.    ER
3420: 52 5f 63 6c 65 61 72 5f 65 72 72 6f 72 28 29 3b  R_clear_error();
3430: 0a 20 20 20 20 77 72 69 74 74 65 6e 20 3d 20 42  .    written = B
3440: 49 4f 5f 77 72 69 74 65 28 73 74 61 74 65 50 74  IO_write(statePt
3450: 72 2d 3e 62 69 6f 2c 20 62 75 66 2c 20 74 6f 57  r->bio, buf, toW
3460: 72 69 74 65 29 3b 0a 20 20 20 20 64 70 72 69 6e  rite);.    dprin
3470: 74 66 28 22 42 49 4f 5f 77 72 69 74 65 28 25 70  tf("BIO_write(%p
3480: 2c 20 25 64 29 20 2d 3e 20 5b 25 64 5d 22 2c 20  , %d) -> [%d]", 
3490: 28 76 6f 69 64 20 2a 29 20 73 74 61 74 65 50 74  (void *) statePt
34a0: 72 2c 20 74 6f 57 72 69 74 65 2c 20 77 72 69 74  r, toWrite, writ
34b0: 74 65 6e 29 3b 0a 0a 20 20 20 20 65 72 72 20 3d  ten);..    err =
34c0: 20 53 53 4c 5f 67 65 74 5f 65 72 72 6f 72 28 73   SSL_get_error(s
34d0: 74 61 74 65 50 74 72 2d 3e 73 73 6c 2c 20 77 72  tatePtr->ssl, wr
34e0: 69 74 74 65 6e 29 3b 0a 20 20 20 20 73 77 69 74  itten);.    swit
34f0: 63 68 20 28 65 72 72 29 20 7b 0a 09 63 61 73 65  ch (err) {..case
3500: 20 53 53 4c 5f 45 52 52 4f 52 5f 4e 4f 4e 45 3a   SSL_ERROR_NONE:
3510: 0a 09 20 20 20 20 69 66 20 28 77 72 69 74 74 65  ..    if (writte
3520: 6e 20 3c 20 30 29 20 7b 0a 09 09 77 72 69 74 74  n < 0) {...writt
3530: 65 6e 20 3d 20 30 3b 0a 09 20 20 20 20 7d 0a 09  en = 0;..    }..
3540: 20 20 20 20 62 72 65 61 6b 3b 0a 09 63 61 73 65      break;..case
3550: 20 53 53 4c 5f 45 52 52 4f 52 5f 57 41 4e 54 5f   SSL_ERROR_WANT_
3560: 57 52 49 54 45 3a 0a 09 20 20 20 20 64 70 72 69  WRITE:..    dpri
3570: 6e 74 66 28 22 47 6f 74 20 53 53 4c 5f 45 52 52  ntf("Got SSL_ERR
3580: 4f 52 5f 57 41 4e 54 5f 57 52 49 54 45 2c 20 6d  OR_WANT_WRITE, m
3590: 61 70 70 69 6e 67 20 69 74 20 74 6f 20 45 41 47  apping it to EAG
35a0: 41 49 4e 22 29 3b 0a 09 20 20 20 20 2a 65 72 72  AIN");..    *err
35b0: 6f 72 43 6f 64 65 50 74 72 20 3d 20 45 41 47 41  orCodePtr = EAGA
35c0: 49 4e 3b 0a 09 20 20 20 20 77 72 69 74 74 65 6e  IN;..    written
35d0: 20 3d 20 2d 31 3b 0a 09 20 20 20 20 62 72 65 61   = -1;..    brea
35e0: 6b 3b 0a 09 63 61 73 65 20 53 53 4c 5f 45 52 52  k;..case SSL_ERR
35f0: 4f 52 5f 57 41 4e 54 5f 52 45 41 44 3a 0a 09 20  OR_WANT_READ:.. 
3600: 20 20 20 64 70 72 69 6e 74 66 28 22 20 77 72 69     dprintf(" wri
3610: 74 65 20 52 20 42 4c 4f 43 4b 22 29 3b 0a 09 20  te R BLOCK");.. 
3620: 20 20 20 62 72 65 61 6b 3b 0a 09 63 61 73 65 20     break;..case 
3630: 53 53 4c 5f 45 52 52 4f 52 5f 57 41 4e 54 5f 58  SSL_ERROR_WANT_X
3640: 35 30 39 5f 4c 4f 4f 4b 55 50 3a 0a 09 20 20 20  509_LOOKUP:..   
3650: 20 64 70 72 69 6e 74 66 28 22 20 77 72 69 74 65   dprintf(" write
3660: 20 58 20 42 4c 4f 43 4b 22 29 3b 0a 09 20 20 20   X BLOCK");..   
3670: 20 62 72 65 61 6b 3b 0a 09 63 61 73 65 20 53 53   break;..case SS
3680: 4c 5f 45 52 52 4f 52 5f 5a 45 52 4f 5f 52 45 54  L_ERROR_ZERO_RET
3690: 55 52 4e 3a 0a 09 20 20 20 20 64 70 72 69 6e 74  URN:..    dprint
36a0: 66 28 22 20 63 6c 6f 73 65 64 22 29 3b 0a 09 20  f(" closed");.. 
36b0: 20 20 20 77 72 69 74 74 65 6e 20 3d 20 30 3b 0a     written = 0;.
36c0: 09 20 20 20 20 2a 65 72 72 6f 72 43 6f 64 65 50  .    *errorCodeP
36d0: 74 72 20 3d 20 30 3b 0a 09 20 20 20 20 62 72 65  tr = 0;..    bre
36e0: 61 6b 3b 0a 09 63 61 73 65 20 53 53 4c 5f 45 52  ak;..case SSL_ER
36f0: 52 4f 52 5f 53 59 53 43 41 4c 4c 3a 0a 09 20 20  ROR_SYSCALL:..  
3700: 20 20 62 61 63 6b 69 6e 67 45 72 72 6f 72 20 3d    backingError =
3710: 20 45 52 52 5f 67 65 74 5f 65 72 72 6f 72 28 29   ERR_get_error()
3720: 3b 0a 0a 09 20 20 20 20 69 66 20 28 62 61 63 6b  ;...    if (back
3730: 69 6e 67 45 72 72 6f 72 20 3d 3d 20 30 20 26 26  ingError == 0 &&
3740: 20 77 72 69 74 74 65 6e 20 3d 3d 20 30 29 20 7b   written == 0) {
3750: 0a 09 09 64 70 72 69 6e 74 66 28 22 45 4f 46 20  ...dprintf("EOF 
3760: 72 65 61 63 68 65 64 22 29 0a 09 09 2a 65 72 72  reached")...*err
3770: 6f 72 43 6f 64 65 50 74 72 20 3d 20 30 3b 0a 09  orCodePtr = 0;..
3780: 09 77 72 69 74 74 65 6e 20 3d 20 30 3b 0a 09 20  .written = 0;.. 
3790: 20 20 20 7d 20 65 6c 73 65 20 69 66 20 28 62 61     } else if (ba
37a0: 63 6b 69 6e 67 45 72 72 6f 72 20 3d 3d 20 30 20  ckingError == 0 
37b0: 26 26 20 77 72 69 74 74 65 6e 20 3d 3d 20 2d 31  && written == -1
37c0: 29 20 7b 0a 09 09 64 70 72 69 6e 74 66 28 22 49  ) {...dprintf("I
37d0: 2f 4f 20 65 72 72 6f 72 20 6f 63 63 75 72 72 65  /O error occurre
37e0: 64 20 28 65 72 72 6e 6f 20 3d 20 25 6c 75 29 22  d (errno = %lu)"
37f0: 2c 20 28 75 6e 73 69 67 6e 65 64 20 6c 6f 6e 67  , (unsigned long
3800: 29 20 54 63 6c 5f 47 65 74 45 72 72 6e 6f 28 29  ) Tcl_GetErrno()
3810: 29 3b 0a 09 09 2a 65 72 72 6f 72 43 6f 64 65 50  );...*errorCodeP
3820: 74 72 20 3d 20 54 63 6c 5f 47 65 74 45 72 72 6e  tr = Tcl_GetErrn
3830: 6f 28 29 3b 0a 09 09 77 72 69 74 74 65 6e 20 3d  o();...written =
3840: 20 2d 31 3b 0a 09 20 20 20 20 7d 20 65 6c 73 65   -1;..    } else
3850: 20 7b 0a 09 09 64 70 72 69 6e 74 66 28 22 49 2f   {...dprintf("I/
3860: 4f 20 65 72 72 6f 72 20 6f 63 63 75 72 72 65 64  O error occurred
3870: 20 28 62 61 63 6b 69 6e 67 45 72 72 6f 72 20 3d   (backingError =
3880: 20 25 6c 75 29 22 2c 20 62 61 63 6b 69 6e 67 45   %lu)", backingE
3890: 72 72 6f 72 29 3b 0a 09 09 2a 65 72 72 6f 72 43  rror);...*errorC
38a0: 6f 64 65 50 74 72 20 3d 20 62 61 63 6b 69 6e 67  odePtr = backing
38b0: 45 72 72 6f 72 3b 0a 09 09 77 72 69 74 74 65 6e  Error;...written
38c0: 20 3d 20 2d 31 3b 0a 09 20 20 20 20 7d 0a 09 20   = -1;..    }.. 
38d0: 20 20 20 62 72 65 61 6b 3b 0a 09 63 61 73 65 20     break;..case 
38e0: 53 53 4c 5f 45 52 52 4f 52 5f 53 53 4c 3a 0a 09  SSL_ERROR_SSL:..
38f0: 20 20 20 20 54 6c 73 5f 45 72 72 6f 72 28 73 74      Tls_Error(st
3900: 61 74 65 50 74 72 2c 20 54 43 4c 54 4c 53 5f 53  atePtr, TCLTLS_S
3910: 53 4c 5f 45 52 52 4f 52 28 73 74 61 74 65 50 74  SL_ERROR(statePt
3920: 72 2d 3e 73 73 6c 2c 20 77 72 69 74 74 65 6e 29  r->ssl, written)
3930: 29 3b 0a 09 20 20 20 20 2a 65 72 72 6f 72 43 6f  );..    *errorCo
3940: 64 65 50 74 72 20 3d 20 45 43 4f 4e 4e 41 42 4f  dePtr = ECONNABO
3950: 52 54 45 44 3b 0a 09 20 20 20 20 77 72 69 74 74  RTED;..    writt
3960: 65 6e 20 3d 20 2d 31 3b 0a 09 20 20 20 20 62 72  en = -1;..    br
3970: 65 61 6b 3b 0a 09 64 65 66 61 75 6c 74 3a 0a 09  eak;..default:..
3980: 20 20 20 20 64 70 72 69 6e 74 66 28 22 20 75 6e      dprintf(" un
3990: 6b 6e 6f 77 6e 20 65 72 72 3a 20 25 64 22 2c 20  known err: %d", 
39a0: 65 72 72 29 3b 0a 09 20 20 20 20 62 72 65 61 6b  err);..    break
39b0: 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 64 70 72  ;.    }..    dpr
39c0: 69 6e 74 66 28 22 4f 75 74 70 75 74 28 25 64 29  intf("Output(%d)
39d0: 20 2d 3e 20 25 64 22 2c 20 74 6f 57 72 69 74 65   -> %d", toWrite
39e0: 2c 20 77 72 69 74 74 65 6e 29 3b 0a 20 20 20 20  , written);.    
39f0: 72 65 74 75 72 6e 28 77 72 69 74 74 65 6e 29 3b  return(written);
3a00: 0a 7d 0a 0a 2f 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d  .}../*. *-------
3a10: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3a20: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3a30: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3a40: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 0a  ------------. *.
3a50: 20 2a 20 54 6c 73 47 65 74 4f 70 74 69 6f 6e 50   * TlsGetOptionP
3a60: 72 6f 63 20 2d 2d 0a 20 2a 0a 20 2a 20 20 20 20  roc --. *. *    
3a70: 47 65 74 73 20 61 6e 20 6f 70 74 69 6f 6e 20 76  Gets an option v
3a80: 61 6c 75 65 20 66 6f 72 20 61 20 53 53 4c 20 73  alue for a SSL s
3a90: 6f 63 6b 65 74 20 62 61 73 65 64 20 63 68 61 6e  ocket based chan
3aa0: 6e 65 6c 2c 20 6f 72 20 61 0a 20 2a 20 20 20 20  nel, or a. *    
3ab0: 6c 69 73 74 20 6f 66 20 61 6c 6c 20 6f 70 74 69  list of all opti
3ac0: 6f 6e 73 20 61 6e 64 20 74 68 65 69 72 20 76 61  ons and their va
3ad0: 6c 75 65 73 2e 0a 20 2a 0a 20 2a 20 52 65 73 75  lues.. *. * Resu
3ae0: 6c 74 73 3a 0a 20 2a 20 20 20 20 41 20 73 74 61  lts:. *    A sta
3af0: 6e 64 61 72 64 20 54 63 6c 20 72 65 73 75 6c 74  ndard Tcl result
3b00: 2e 20 54 68 65 20 76 61 6c 75 65 20 6f 66 20 74  . The value of t
3b10: 68 65 20 73 70 65 63 69 66 69 65 64 20 6f 70 74  he specified opt
3b20: 69 6f 6e 20 6f 72 20 61 0a 20 2a 20 20 20 20 6c  ion or a. *    l
3b30: 69 73 74 20 6f 66 20 61 6c 6c 20 6f 70 74 69 6f  ist of all optio
3b40: 6e 73 20 61 6e 64 20 74 68 65 69 72 20 76 61 6c  ns and their val
3b50: 75 65 73 20 69 73 20 72 65 74 75 72 6e 65 64 20  ues is returned 
3b60: 69 6e 20 74 68 65 0a 20 2a 20 20 20 20 73 75 70  in the. *    sup
3b70: 70 6c 69 65 64 20 44 53 74 72 69 6e 67 2e 0a 20  plied DString.. 
3b80: 2a 0a 20 2a 20 53 69 64 65 20 65 66 66 65 63 74  *. * Side effect
3b90: 73 3a 0a 20 2a 20 20 20 20 4e 6f 6e 65 2e 0a 20  s:. *    None.. 
3ba0: 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  *. *------------
3bb0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3bc0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3bd0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3be0: 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 2f 0a 73 74 61 74  -------. */.stat
3bf0: 69 63 20 69 6e 74 0a 54 6c 73 47 65 74 4f 70 74  ic int.TlsGetOpt
3c00: 69 6f 6e 50 72 6f 63 28 0a 20 20 20 20 76 6f 69  ionProc(.    voi
3c10: 64 20 2a 69 6e 73 74 61 6e 63 65 44 61 74 61 2c  d *instanceData,
3c20: 09 2f 2a 20 53 6f 63 6b 65 74 20 73 74 61 74 65  ./* Socket state
3c30: 2e 20 2a 2f 0a 20 20 20 20 54 63 6c 5f 49 6e 74  . */.    Tcl_Int
3c40: 65 72 70 20 2a 69 6e 74 65 72 70 2c 09 09 2f 2a  erp *interp,../*
3c50: 20 46 6f 72 20 65 72 72 6f 72 73 20 2d 20 63 61   For errors - ca
3c60: 6e 20 62 65 20 4e 55 4c 4c 2e 20 2a 2f 0a 20 20  n be NULL. */.  
3c70: 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 6f 70    const char *op
3c80: 74 69 6f 6e 4e 61 6d 65 2c 09 2f 2a 20 4e 61 6d  tionName,./* Nam
3c90: 65 20 6f 66 20 74 68 65 20 6f 70 74 69 6f 6e 20  e of the option 
3ca0: 74 6f 20 72 65 74 72 69 65 76 65 20 74 68 65 20  to retrieve the 
3cb0: 76 61 6c 75 65 20 66 6f 72 2c 20 6f 72 0a 09 09  value for, or...
3cc0: 09 09 20 2a 20 4e 55 4c 4c 20 74 6f 20 67 65 74  .. * NULL to get
3cd0: 20 61 6c 6c 20 6f 70 74 69 6f 6e 73 20 61 6e 64   all options and
3ce0: 20 74 68 65 69 72 20 76 61 6c 75 65 73 2e 20 2a   their values. *
3cf0: 2f 0a 20 20 20 20 54 63 6c 5f 44 53 74 72 69 6e  /.    Tcl_DStrin
3d00: 67 20 2a 64 73 50 74 72 29 09 2f 2a 20 57 68 65  g *dsPtr)./* Whe
3d10: 72 65 20 74 6f 20 73 74 6f 72 65 20 74 68 65 20  re to store the 
3d20: 63 6f 6d 70 75 74 65 64 20 76 61 6c 75 65 20 69  computed value i
3d30: 6e 69 74 69 61 6c 69 7a 65 64 20 62 79 20 63 61  nitialized by ca
3d40: 6c 6c 65 72 2e 20 2a 2f 0a 7b 0a 20 20 20 20 53  ller. */.{.    S
3d50: 74 61 74 65 20 2a 73 74 61 74 65 50 74 72 20 3d  tate *statePtr =
3d60: 20 28 53 74 61 74 65 20 2a 29 20 69 6e 73 74 61   (State *) insta
3d70: 6e 63 65 44 61 74 61 3b 0a 0a 20 20 20 20 54 63  nceData;..    Tc
3d80: 6c 5f 43 68 61 6e 6e 65 6c 20 64 6f 77 6e 43 68  l_Channel downCh
3d90: 61 6e 20 3d 20 54 6c 73 5f 47 65 74 50 61 72 65  an = Tls_GetPare
3da0: 6e 74 28 73 74 61 74 65 50 74 72 2c 20 54 4c 53  nt(statePtr, TLS
3db0: 5f 54 43 4c 5f 46 41 53 54 50 41 54 48 29 3b 0a  _TCL_FASTPATH);.
3dc0: 20 20 20 20 54 63 6c 5f 44 72 69 76 65 72 47 65      Tcl_DriverGe
3dd0: 74 4f 70 74 69 6f 6e 50 72 6f 63 20 2a 67 65 74  tOptionProc *get
3de0: 4f 70 74 69 6f 6e 50 72 6f 63 3b 0a 0a 20 20 20  OptionProc;..   
3df0: 20 67 65 74 4f 70 74 69 6f 6e 50 72 6f 63 20 3d   getOptionProc =
3e00: 20 54 63 6c 5f 43 68 61 6e 6e 65 6c 47 65 74 4f   Tcl_ChannelGetO
3e10: 70 74 69 6f 6e 50 72 6f 63 28 54 63 6c 5f 47 65  ptionProc(Tcl_Ge
3e20: 74 43 68 61 6e 6e 65 6c 54 79 70 65 28 64 6f 77  tChannelType(dow
3e30: 6e 43 68 61 6e 29 29 3b 0a 20 20 20 20 69 66 20  nChan));.    if 
3e40: 28 67 65 74 4f 70 74 69 6f 6e 50 72 6f 63 20 21  (getOptionProc !
3e50: 3d 20 4e 55 4c 4c 29 20 7b 0a 09 72 65 74 75 72  = NULL) {..retur
3e60: 6e 20 28 2a 67 65 74 4f 70 74 69 6f 6e 50 72 6f  n (*getOptionPro
3e70: 63 29 28 54 63 6c 5f 47 65 74 43 68 61 6e 6e 65  c)(Tcl_GetChanne
3e80: 6c 49 6e 73 74 61 6e 63 65 44 61 74 61 28 64 6f  lInstanceData(do
3e90: 77 6e 43 68 61 6e 29 2c 20 69 6e 74 65 72 70 2c  wnChan), interp,
3ea0: 20 6f 70 74 69 6f 6e 4e 61 6d 65 2c 20 64 73 50   optionName, dsP
3eb0: 74 72 29 3b 0a 20 20 20 20 7d 20 65 6c 73 65 20  tr);.    } else 
3ec0: 69 66 20 28 6f 70 74 69 6f 6e 4e 61 6d 65 20 3d  if (optionName =
3ed0: 3d 20 28 63 68 61 72 2a 29 20 4e 55 4c 4c 29 20  = (char*) NULL) 
3ee0: 7b 0a 09 2f 2a 0a 09 20 2a 20 52 65 71 75 65 73  {../*.. * Reques
3ef0: 74 20 69 73 20 71 75 65 72 79 20 66 6f 72 20 61  t is query for a
3f00: 6c 6c 20 6f 70 74 69 6f 6e 73 2c 20 74 68 69 73  ll options, this
3f10: 20 69 73 20 6f 6b 2e 0a 09 20 2a 2f 0a 09 72 65   is ok... */..re
3f20: 74 75 72 6e 20 54 43 4c 5f 4f 4b 3b 0a 20 20 20  turn TCL_OK;.   
3f30: 20 7d 0a 20 20 20 20 2f 2a 0a 20 20 20 20 20 2a   }.    /*.     *
3f40: 20 52 65 71 75 65 73 74 20 66 6f 72 20 61 20 73   Request for a s
3f50: 70 65 63 69 66 69 63 20 6f 70 74 69 6f 6e 20 68  pecific option h
3f60: 61 73 20 74 6f 20 66 61 69 6c 2c 20 77 65 20 64  as to fail, we d
3f70: 6f 6e 27 74 20 68 61 76 65 20 61 6e 79 2e 0a 20  on't have any.. 
3f80: 20 20 20 20 2a 2f 0a 20 20 20 20 72 65 74 75 72      */.    retur
3f90: 6e 20 54 43 4c 5f 45 52 52 4f 52 3b 0a 7d 0a 0a  n TCL_ERROR;.}..
3fa0: 2f 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  /*. *-----------
3fb0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3fc0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3fd0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3fe0: 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 0a 20 2a 20 54  --------. *. * T
3ff0: 6c 73 57 61 74 63 68 50 72 6f 63 20 2d 2d 0a 20  lsWatchProc --. 
4000: 2a 0a 20 2a 20 20 20 20 49 6e 69 74 69 61 6c 69  *. *    Initiali
4010: 7a 65 20 74 68 65 20 6e 6f 74 69 66 69 65 72 20  ze the notifier 
4020: 74 6f 20 77 61 74 63 68 20 54 63 6c 5f 46 69 6c  to watch Tcl_Fil
4030: 65 73 20 66 72 6f 6d 20 74 68 69 73 20 63 68 61  es from this cha
4040: 6e 6e 65 6c 2e 0a 20 2a 0a 20 2a 20 52 65 73 75  nnel.. *. * Resu
4050: 6c 74 73 3a 0a 20 2a 20 20 20 20 4e 6f 6e 65 2e  lts:. *    None.
4060: 0a 20 2a 0a 20 2a 20 53 69 64 65 20 65 66 66 65  . *. * Side effe
4070: 63 74 73 3a 0a 20 2a 20 20 20 20 53 65 74 73 20  cts:. *    Sets 
4080: 75 70 20 74 68 65 20 6e 6f 74 69 66 69 65 72 20  up the notifier 
4090: 73 6f 20 74 68 61 74 20 61 20 66 75 74 75 72 65  so that a future
40a0: 20 65 76 65 6e 74 20 6f 6e 20 74 68 65 20 63 68   event on the ch
40b0: 61 6e 6e 65 6c 0a 20 2a 20 20 20 20 77 69 6c 6c  annel. *    will
40c0: 20 62 65 20 73 65 65 6e 20 62 79 20 54 63 6c 2e   be seen by Tcl.
40d0: 0a 20 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  . *. *----------
40e0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
40f0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4100: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4110: 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 2f 0a 0a 73  ---------. */..s
4120: 74 61 74 69 63 20 76 6f 69 64 0a 54 6c 73 57 61  tatic void.TlsWa
4130: 74 63 68 50 72 6f 63 28 0a 20 20 20 20 76 6f 69  tchProc(.    voi
4140: 64 20 2a 69 6e 73 74 61 6e 63 65 44 61 74 61 2c  d *instanceData,
4150: 20 20 20 20 2f 2a 20 54 68 65 20 73 6f 63 6b 65      /* The socke
4160: 74 20 73 74 61 74 65 2e 20 2a 2f 0a 20 20 20 20  t state. */.    
4170: 69 6e 74 20 6d 61 73 6b 29 09 09 09 2f 2a 20 45  int mask).../* E
4180: 76 65 6e 74 73 20 6f 66 20 69 6e 74 65 72 65 73  vents of interes
4190: 74 3b 20 61 6e 20 4f 52 2d 65 64 20 63 6f 6d 62  t; an OR-ed comb
41a0: 69 6e 61 74 69 6f 6e 20 6f 66 0a 09 09 09 09 20  ination of..... 
41b0: 2a 20 54 43 4c 5f 52 45 41 44 41 42 4c 45 2c 20  * TCL_READABLE, 
41c0: 54 43 4c 5f 57 52 49 54 41 42 4c 45 20 61 6e 64  TCL_WRITABLE and
41d0: 20 54 43 4c 5f 45 58 43 45 50 54 49 4f 4e 2e 20   TCL_EXCEPTION. 
41e0: 2a 2f 0a 7b 0a 20 20 20 20 54 63 6c 5f 43 68 61  */.{.    Tcl_Cha
41f0: 6e 6e 65 6c 20 20 20 20 20 64 6f 77 6e 43 68 61  nnel     downCha
4200: 6e 3b 0a 20 20 20 20 53 74 61 74 65 20 2a 73 74  n;.    State *st
4210: 61 74 65 50 74 72 20 3d 20 28 53 74 61 74 65 20  atePtr = (State 
4220: 2a 29 20 69 6e 73 74 61 6e 63 65 44 61 74 61 3b  *) instanceData;
4230: 0a 0a 20 20 20 20 64 70 72 69 6e 74 66 28 22 54  ..    dprintf("T
4240: 6c 73 57 61 74 63 68 50 72 6f 63 28 30 78 25 78  lsWatchProc(0x%x
4250: 29 22 2c 20 6d 61 73 6b 29 3b 0a 0a 20 20 20 20  )", mask);..    
4260: 2f 2a 20 50 72 65 74 65 6e 64 20 74 6f 20 62 65  /* Pretend to be
4270: 20 64 65 61 64 20 61 73 20 6c 6f 6e 67 20 61 73   dead as long as
4280: 20 74 68 65 20 76 65 72 69 66 79 20 63 61 6c 6c   the verify call
4290: 62 61 63 6b 20 69 73 20 72 75 6e 6e 69 6e 67 2e  back is running.
42a0: 0a 20 20 20 20 20 2a 20 4f 74 68 65 72 77 69 73  .     * Otherwis
42b0: 65 20 74 68 61 74 20 63 61 6c 6c 62 61 63 6b 20  e that callback 
42c0: 63 6f 75 6c 64 20 62 65 20 69 6e 76 6f 6b 65 64  could be invoked
42d0: 20 72 65 63 75 72 73 69 76 65 6c 79 2e 20 2a 2f   recursively. */
42e0: 0a 20 20 20 20 69 66 20 28 73 74 61 74 65 50 74  .    if (statePt
42f0: 72 2d 3e 66 6c 61 67 73 20 26 20 54 4c 53 5f 54  r->flags & TLS_T
4300: 43 4c 5f 43 41 4c 4c 42 41 43 4b 29 20 7b 0a 09  CL_CALLBACK) {..
4310: 64 70 72 69 6e 74 66 28 22 43 61 6c 6c 62 61 63  dprintf("Callbac
4320: 6b 20 69 73 20 6f 6e 2d 67 6f 69 6e 67 2c 20 64  k is on-going, d
4330: 6f 69 6e 67 20 6e 6f 74 68 69 6e 67 22 29 3b 0a  oing nothing");.
4340: 09 72 65 74 75 72 6e 3b 0a 20 20 20 20 7d 0a 0a  .return;.    }..
4350: 20 20 20 20 64 70 72 69 6e 74 46 6c 61 67 73 28      dprintFlags(
4360: 73 74 61 74 65 50 74 72 29 3b 0a 0a 20 20 20 20  statePtr);..    
4370: 64 6f 77 6e 43 68 61 6e 20 3d 20 54 6c 73 5f 47  downChan = Tls_G
4380: 65 74 50 61 72 65 6e 74 28 73 74 61 74 65 50 74  etParent(statePt
4390: 72 2c 20 54 4c 53 5f 54 43 4c 5f 46 41 53 54 50  r, TLS_TCL_FASTP
43a0: 41 54 48 29 3b 0a 0a 20 20 20 20 69 66 20 28 73  ATH);..    if (s
43b0: 74 61 74 65 50 74 72 2d 3e 66 6c 61 67 73 20 26  tatePtr->flags &
43c0: 20 54 4c 53 5f 54 43 4c 5f 48 41 4e 44 53 48 41   TLS_TCL_HANDSHA
43d0: 4b 45 5f 46 41 49 4c 45 44 29 20 7b 0a 09 64 70  KE_FAILED) {..dp
43e0: 72 69 6e 74 66 28 22 41 73 6b 65 64 20 74 6f 20  rintf("Asked to 
43f0: 77 61 74 63 68 20 61 20 73 6f 63 6b 65 74 20 77  watch a socket w
4400: 69 74 68 20 61 20 66 61 69 6c 65 64 20 68 61 6e  ith a failed han
4410: 64 73 68 61 6b 65 20 2d 2d 20 6e 6f 74 68 69 6e  dshake -- nothin
4420: 67 20 63 61 6e 20 68 61 70 70 65 6e 20 68 65 72  g can happen her
4430: 65 22 29 3b 0a 09 64 70 72 69 6e 74 66 28 22 55  e");..dprintf("U
4440: 6e 72 65 67 69 73 74 65 72 69 6e 67 20 69 6e 74  nregistering int
4450: 65 72 65 73 74 20 69 6e 20 74 68 65 20 6c 6f 77  erest in the low
4460: 65 72 20 63 68 61 6e 6e 65 6c 22 29 3b 0a 0a 09  er channel");...
4470: 28 54 63 6c 5f 47 65 74 43 68 61 6e 6e 65 6c 54  (Tcl_GetChannelT
4480: 79 70 65 28 64 6f 77 6e 43 68 61 6e 29 29 2d 3e  ype(downChan))->
4490: 77 61 74 63 68 50 72 6f 63 28 54 63 6c 5f 47 65  watchProc(Tcl_Ge
44a0: 74 43 68 61 6e 6e 65 6c 49 6e 73 74 61 6e 63 65  tChannelInstance
44b0: 44 61 74 61 28 64 6f 77 6e 43 68 61 6e 29 2c 20  Data(downChan), 
44c0: 30 29 3b 0a 09 73 74 61 74 65 50 74 72 2d 3e 77  0);..statePtr->w
44d0: 61 74 63 68 4d 61 73 6b 20 3d 20 30 3b 0a 09 72  atchMask = 0;..r
44e0: 65 74 75 72 6e 3b 0a 20 20 20 20 7d 0a 0a 20 20  eturn;.    }..  
44f0: 20 20 73 74 61 74 65 50 74 72 2d 3e 77 61 74 63    statePtr->watc
4500: 68 4d 61 73 6b 20 3d 20 6d 61 73 6b 3b 0a 0a 20  hMask = mask;.. 
4510: 20 20 20 2f 2a 20 4e 6f 20 63 68 61 6e 6e 65 6c     /* No channel
4520: 20 68 61 6e 64 6c 65 72 73 20 61 6e 79 20 6d 6f   handlers any mo
4530: 72 65 2e 20 57 65 20 77 69 6c 6c 20 62 65 20 6e  re. We will be n
4540: 6f 74 69 66 69 65 64 20 61 75 74 6f 6d 61 74 69  otified automati
4550: 63 61 6c 6c 79 0a 20 20 20 20 20 2a 20 61 62 6f  cally.     * abo
4560: 75 74 20 65 76 65 6e 74 73 20 6f 6e 20 74 68 65  ut events on the
4570: 20 63 68 61 6e 6e 65 6c 20 62 65 6c 6f 77 20 76   channel below v
4580: 69 61 20 61 20 63 61 6c 6c 20 74 6f 20 6f 75 72  ia a call to our
4590: 0a 20 20 20 20 20 2a 20 27 54 72 61 6e 73 66 6f  .     * 'Transfo
45a0: 72 6d 4e 6f 74 69 66 79 50 72 6f 63 27 2e 20 42  rmNotifyProc'. B
45b0: 75 74 20 77 65 20 68 61 76 65 20 74 6f 20 70 61  ut we have to pa
45c0: 73 73 20 74 68 65 20 69 6e 74 65 72 65 73 74 20  ss the interest 
45d0: 64 6f 77 6e 20 6e 6f 77 2e 0a 20 20 20 20 20 2a  down now..     *
45e0: 20 57 65 20 61 72 65 20 61 6c 6c 6f 77 65 64 20   We are allowed 
45f0: 74 6f 20 61 64 64 20 61 64 64 69 74 69 6f 6e 61  to add additiona
4600: 6c 20 27 69 6e 74 65 72 65 73 74 27 20 74 6f 20  l 'interest' to 
4610: 74 68 65 20 6d 61 73 6b 20 69 66 20 77 65 20 77  the mask if we w
4620: 61 6e 74 0a 20 20 20 20 20 2a 20 74 6f 2e 20 42  ant.     * to. B
4630: 75 74 20 74 68 69 73 20 74 72 61 6e 73 66 6f 72  ut this transfor
4640: 6d 61 74 69 6f 6e 20 68 61 73 20 6e 6f 20 73 75  mation has no su
4650: 63 68 20 69 6e 74 65 72 65 73 74 2e 20 49 74 20  ch interest. It 
4660: 6a 75 73 74 20 70 61 73 73 65 73 0a 20 20 20 20  just passes.    
4670: 20 2a 20 74 68 65 20 72 65 71 75 65 73 74 20 64   * the request d
4680: 6f 77 6e 2c 20 75 6e 63 68 61 6e 67 65 64 2e 0a  own, unchanged..
4690: 20 20 20 20 20 2a 2f 0a 20 20 20 20 64 70 72 69       */.    dpri
46a0: 6e 74 66 28 22 52 65 67 69 73 74 65 72 69 6e 67  ntf("Registering
46b0: 20 6f 75 72 20 69 6e 74 65 72 65 73 74 20 69 6e   our interest in
46c0: 20 74 68 65 20 6c 6f 77 65 72 20 63 68 61 6e 6e   the lower chann
46d0: 65 6c 20 28 63 68 61 6e 3d 25 70 29 22 2c 20 28  el (chan=%p)", (
46e0: 76 6f 69 64 20 2a 29 20 64 6f 77 6e 43 68 61 6e  void *) downChan
46f0: 29 3b 0a 20 20 20 20 28 54 63 6c 5f 47 65 74 43  );.    (Tcl_GetC
4700: 68 61 6e 6e 65 6c 54 79 70 65 28 64 6f 77 6e 43  hannelType(downC
4710: 68 61 6e 29 29 0a 09 20 20 20 20 2d 3e 77 61 74  han))..    ->wat
4720: 63 68 50 72 6f 63 28 54 63 6c 5f 47 65 74 43 68  chProc(Tcl_GetCh
4730: 61 6e 6e 65 6c 49 6e 73 74 61 6e 63 65 44 61 74  annelInstanceDat
4740: 61 28 64 6f 77 6e 43 68 61 6e 29 2c 20 6d 61 73  a(downChan), mas
4750: 6b 29 3b 0a 0a 20 20 20 20 2f 2a 0a 20 20 20 20  k);..    /*.    
4760: 20 2a 20 4d 61 6e 61 67 65 6d 65 6e 74 20 6f 66   * Management of
4770: 20 74 68 65 20 69 6e 74 65 72 6e 61 6c 20 74 69   the internal ti
4780: 6d 65 72 2e 0a 20 20 20 20 20 2a 2f 0a 20 20 20  mer..     */.   
4790: 20 69 66 20 28 73 74 61 74 65 50 74 72 2d 3e 74   if (statePtr->t
47a0: 69 6d 65 72 20 21 3d 20 28 54 63 6c 5f 54 69 6d  imer != (Tcl_Tim
47b0: 65 72 54 6f 6b 65 6e 29 20 4e 55 4c 4c 29 20 7b  erToken) NULL) {
47c0: 0a 09 64 70 72 69 6e 74 66 28 22 41 20 74 69 6d  ..dprintf("A tim
47d0: 65 72 20 77 61 73 20 66 6f 75 6e 64 2c 20 64 65  er was found, de
47e0: 6c 65 74 69 6e 67 20 69 74 22 29 3b 0a 09 54 63  leting it");..Tc
47f0: 6c 5f 44 65 6c 65 74 65 54 69 6d 65 72 48 61 6e  l_DeleteTimerHan
4800: 64 6c 65 72 28 73 74 61 74 65 50 74 72 2d 3e 74  dler(statePtr->t
4810: 69 6d 65 72 29 3b 0a 09 73 74 61 74 65 50 74 72  imer);..statePtr
4820: 2d 3e 74 69 6d 65 72 20 3d 20 28 54 63 6c 5f 54  ->timer = (Tcl_T
4830: 69 6d 65 72 54 6f 6b 65 6e 29 20 4e 55 4c 4c 3b  imerToken) NULL;
4840: 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 66 20 28  .    }..    if (
4850: 28 6d 61 73 6b 20 26 20 54 43 4c 5f 52 45 41 44  (mask & TCL_READ
4860: 41 42 4c 45 29 20 26 26 0a 09 28 28 54 63 6c 5f  ABLE) &&..((Tcl_
4870: 49 6e 70 75 74 42 75 66 66 65 72 65 64 28 73 74  InputBuffered(st
4880: 61 74 65 50 74 72 2d 3e 73 65 6c 66 29 20 3e 20  atePtr->self) > 
4890: 30 29 20 7c 7c 20 28 42 49 4f 5f 63 74 72 6c 5f  0) || (BIO_ctrl_
48a0: 70 65 6e 64 69 6e 67 28 73 74 61 74 65 50 74 72  pending(statePtr
48b0: 2d 3e 62 69 6f 29 20 3e 20 30 29 29 29 20 7b 0a  ->bio) > 0))) {.
48c0: 09 2f 2a 0a 09 20 2a 20 54 68 65 72 65 20 69 73  ./*.. * There is
48d0: 20 69 6e 74 65 72 65 73 74 20 69 6e 20 72 65 61   interest in rea
48e0: 64 61 62 6c 65 20 65 76 65 6e 74 73 20 61 6e 64  dable events and
48f0: 20 77 65 20 61 63 74 75 61 6c 6c 79 20 68 61 76   we actually hav
4900: 65 0a 09 20 2a 20 64 61 74 61 20 77 61 69 74 69  e.. * data waiti
4910: 6e 67 2c 20 73 6f 20 67 65 6e 65 72 61 74 65 20  ng, so generate 
4920: 61 20 74 69 6d 65 72 20 74 6f 20 66 6c 75 73 68  a timer to flush
4930: 20 74 68 61 74 2e 0a 09 20 2a 2f 0a 09 64 70 72   that... */..dpr
4940: 69 6e 74 66 28 22 43 72 65 61 74 69 6e 67 20 61  intf("Creating a
4950: 20 6e 65 77 20 74 69 6d 65 72 20 73 69 6e 63 65   new timer since
4960: 20 64 61 74 61 20 61 70 70 65 61 72 73 20 74 6f   data appears to
4970: 20 62 65 20 77 61 69 74 69 6e 67 22 29 3b 0a 09   be waiting");..
4980: 73 74 61 74 65 50 74 72 2d 3e 74 69 6d 65 72 20  statePtr->timer 
4990: 3d 20 54 63 6c 5f 43 72 65 61 74 65 54 69 6d 65  = Tcl_CreateTime
49a0: 72 48 61 6e 64 6c 65 72 28 54 4c 53 5f 54 43 4c  rHandler(TLS_TCL
49b0: 5f 44 45 4c 41 59 2c 20 54 6c 73 43 68 61 6e 6e  _DELAY, TlsChann
49c0: 65 6c 48 61 6e 64 6c 65 72 54 69 6d 65 72 2c 20  elHandlerTimer, 
49d0: 73 74 61 74 65 50 74 72 29 3b 0a 20 20 20 20 7d  statePtr);.    }
49e0: 0a 7d 0a 0a 2f 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d  .}../*. *-------
49f0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4a00: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4a10: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4a20: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 0a  ------------. *.
4a30: 20 2a 20 54 6c 73 47 65 74 48 61 6e 64 6c 65 50   * TlsGetHandleP
4a40: 72 6f 63 20 2d 2d 0a 20 2a 0a 20 2a 20 20 20 20  roc --. *. *    
4a50: 43 61 6c 6c 65 64 20 66 72 6f 6d 20 54 63 6c 5f  Called from Tcl_
4a60: 47 65 74 43 68 61 6e 6e 65 6c 46 69 6c 65 20 74  GetChannelFile t
4a70: 6f 20 72 65 74 72 69 65 76 65 20 6f 2f 73 20 66  o retrieve o/s f
4a80: 69 6c 65 20 68 61 6e 64 6c 65 72 0a 20 2a 20 20  ile handler. *  
4a90: 20 20 66 72 6f 6d 20 74 68 65 20 53 53 4c 20 73    from the SSL s
4aa0: 6f 63 6b 65 74 20 62 61 73 65 64 20 63 68 61 6e  ocket based chan
4ab0: 6e 65 6c 2e 0a 20 2a 0a 20 2a 20 52 65 73 75 6c  nel.. *. * Resul
4ac0: 74 73 3a 0a 20 2a 20 20 20 20 54 68 65 20 61 70  ts:. *    The ap
4ad0: 70 72 6f 70 72 69 61 74 65 20 54 63 6c 5f 46 69  propriate Tcl_Fi
4ae0: 6c 65 20 68 61 6e 64 6c 65 20 6f 72 20 4e 55 4c  le handle or NUL
4af0: 4c 20 69 66 20 6e 6f 6e 65 2e 0a 20 2a 0a 20 2a  L if none.. *. *
4b00: 20 53 69 64 65 20 65 66 66 65 63 74 73 3a 0a 20   Side effects:. 
4b10: 2a 20 20 20 20 4e 6f 6e 65 2e 0a 20 2a 0a 20 2a  *    None.. *. *
4b20: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4b30: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4b40: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4b50: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4b60: 2d 2d 2d 0a 20 2a 2f 0a 73 74 61 74 69 63 20 69  ---. */.static i
4b70: 6e 74 20 54 6c 73 47 65 74 48 61 6e 64 6c 65 50  nt TlsGetHandleP
4b80: 72 6f 63 28 0a 20 20 20 20 76 6f 69 64 20 2a 69  roc(.    void *i
4b90: 6e 73 74 61 6e 63 65 44 61 74 61 2c 20 20 20 20  nstanceData,    
4ba0: 2f 2a 20 53 6f 63 6b 65 74 20 73 74 61 74 65 2e  /* Socket state.
4bb0: 20 2a 2f 0a 20 20 20 20 69 6e 74 20 64 69 72 65   */.    int dire
4bc0: 63 74 69 6f 6e 2c 09 09 2f 2a 20 54 43 4c 5f 52  ction,../* TCL_R
4bd0: 45 41 44 41 42 4c 45 20 6f 72 20 54 43 4c 5f 57  EADABLE or TCL_W
4be0: 52 49 54 41 42 4c 45 20 2a 2f 0a 20 20 20 20 76  RITABLE */.    v
4bf0: 6f 69 64 20 2a 2a 68 61 6e 64 6c 65 50 74 72 29  oid **handlePtr)
4c00: 09 2f 2a 20 48 61 6e 64 6c 65 20 61 73 73 6f 63  ./* Handle assoc
4c10: 69 61 74 65 64 20 77 69 74 68 20 74 68 65 20 63  iated with the c
4c20: 68 61 6e 6e 65 6c 20 2a 2f 0a 7b 0a 20 20 20 20  hannel */.{.    
4c30: 53 74 61 74 65 20 2a 73 74 61 74 65 50 74 72 20  State *statePtr 
4c40: 3d 20 28 53 74 61 74 65 20 2a 29 69 6e 73 74 61  = (State *)insta
4c50: 6e 63 65 44 61 74 61 3b 0a 0a 20 20 20 20 72 65  nceData;..    re
4c60: 74 75 72 6e 28 54 63 6c 5f 47 65 74 43 68 61 6e  turn(Tcl_GetChan
4c70: 6e 65 6c 48 61 6e 64 6c 65 28 54 6c 73 5f 47 65  nelHandle(Tls_Ge
4c80: 74 50 61 72 65 6e 74 28 73 74 61 74 65 50 74 72  tParent(statePtr
4c90: 2c 20 54 4c 53 5f 54 43 4c 5f 46 41 53 54 50 41  , TLS_TCL_FASTPA
4ca0: 54 48 29 2c 20 64 69 72 65 63 74 69 6f 6e 2c 20  TH), direction, 
4cb0: 68 61 6e 64 6c 65 50 74 72 29 29 3b 0a 7d 0a 0a  handlePtr));.}..
4cc0: 2f 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  /*. *-----------
4cd0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4ce0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4cf0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4d00: 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 0a 20 2a 20 54  --------. *. * T
4d10: 6c 73 4e 6f 74 69 66 79 50 72 6f 63 20 2d 2d 0a  lsNotifyProc --.
4d20: 20 2a 0a 20 2a 20 20 20 20 48 61 6e 64 6c 65 72   *. *    Handler
4d30: 20 63 61 6c 6c 65 64 20 62 79 20 54 63 6c 20 74   called by Tcl t
4d40: 6f 20 69 6e 66 6f 72 6d 20 75 73 20 6f 66 20 61  o inform us of a
4d50: 63 74 69 76 69 74 79 0a 20 2a 20 20 20 20 6f 6e  ctivity. *    on
4d60: 20 74 68 65 20 75 6e 64 65 72 6c 79 69 6e 67 20   the underlying 
4d70: 63 68 61 6e 6e 65 6c 2e 0a 20 2a 0a 20 2a 20 52  channel.. *. * R
4d80: 65 73 75 6c 74 73 3a 0a 20 2a 20 20 20 20 54 79  esults:. *    Ty
4d90: 70 65 20 6f 66 20 65 76 65 6e 74 20 6f 72 20 30  pe of event or 0
4da0: 20 69 66 20 66 61 69 6c 65 64 0a 20 2a 0a 20 2a   if failed. *. *
4db0: 20 53 69 64 65 20 65 66 66 65 63 74 73 3a 0a 20   Side effects:. 
4dc0: 2a 20 20 20 20 4d 61 79 20 70 72 6f 63 65 73 73  *    May process
4dd0: 20 74 68 65 20 69 6e 63 6f 6d 69 6e 67 20 65 76   the incoming ev
4de0: 65 6e 74 20 62 79 20 69 74 73 65 6c 66 2e 0a 20  ent by itself.. 
4df0: 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  *. *------------
4e00: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4e10: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4e20: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4e30: 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 2f 0a 0a 73 74 61  -------. */..sta
4e40: 74 69 63 20 69 6e 74 20 54 6c 73 4e 6f 74 69 66  tic int TlsNotif
4e50: 79 50 72 6f 63 28 0a 20 20 20 20 76 6f 69 64 20  yProc(.    void 
4e60: 2a 69 6e 73 74 61 6e 63 65 44 61 74 61 2c 20 20  *instanceData,  
4e70: 20 20 2f 2a 20 53 6f 63 6b 65 74 20 73 74 61 74    /* Socket stat
4e80: 65 2e 20 2a 2f 0a 20 20 20 20 69 6e 74 20 6d 61  e. */.    int ma
4e90: 73 6b 29 09 09 09 2f 2a 20 74 79 70 65 20 6f 66  sk).../* type of
4ea0: 20 65 76 65 6e 74 20 74 68 61 74 20 6f 63 63 75   event that occu
4eb0: 72 72 65 64 3a 0a 09 09 09 09 20 2a 20 4f 52 2d  rred:..... * OR-
4ec0: 65 64 20 63 6f 6d 62 69 6e 61 74 69 6f 6e 20 6f  ed combination o
4ed0: 66 20 54 43 4c 5f 52 45 41 44 41 42 4c 45 20 6f  f TCL_READABLE o
4ee0: 72 20 54 43 4c 5f 57 52 49 54 41 42 4c 45 20 2a  r TCL_WRITABLE *
4ef0: 2f 0a 7b 0a 20 20 20 20 53 74 61 74 65 20 2a 73  /.{.    State *s
4f00: 74 61 74 65 50 74 72 20 3d 20 28 53 74 61 74 65  tatePtr = (State
4f10: 20 2a 29 69 6e 73 74 61 6e 63 65 44 61 74 61 3b   *)instanceData;
4f20: 0a 20 20 20 20 69 6e 74 20 65 72 72 6f 72 43 6f  .    int errorCo
4f30: 64 65 3b 0a 0a 20 20 20 20 2f 2a 0a 20 20 20 20  de;..    /*.    
4f40: 20 2a 20 41 6e 20 65 76 65 6e 74 20 6f 63 63 75   * An event occu
4f50: 72 72 65 64 20 69 6e 20 74 68 65 20 75 6e 64 65  rred in the unde
4f60: 72 6c 79 69 6e 67 20 63 68 61 6e 6e 65 6c 2e 20  rlying channel. 
4f70: 20 54 68 69 73 0a 20 20 20 20 20 2a 20 74 72 61   This.     * tra
4f80: 6e 73 66 6f 72 6d 61 74 69 6f 6e 20 64 6f 65 73  nsformation does
4f90: 6e 27 74 20 70 72 6f 63 65 73 73 20 73 75 63 68  n't process such
4fa0: 20 65 76 65 6e 74 73 20 74 68 75 73 20 72 65 74   events thus ret
4fb0: 75 72 6e 73 20 74 68 65 0a 20 20 20 20 20 2a 20  urns the.     * 
4fc0: 69 6e 63 6f 6d 69 6e 67 20 6d 61 73 6b 20 75 6e  incoming mask un
4fd0: 63 68 61 6e 67 65 64 2e 0a 20 20 20 20 20 2a 2f  changed..     */
4fe0: 0a 20 20 20 20 69 66 20 28 73 74 61 74 65 50 74  .    if (statePt
4ff0: 72 2d 3e 74 69 6d 65 72 20 21 3d 20 28 54 63 6c  r->timer != (Tcl
5000: 5f 54 69 6d 65 72 54 6f 6b 65 6e 29 20 4e 55 4c  _TimerToken) NUL
5010: 4c 29 20 7b 0a 09 2f 2a 0a 09 20 2a 20 44 65 6c  L) {../*.. * Del
5020: 65 74 65 20 61 6e 20 65 78 69 73 74 69 6e 67 20  ete an existing 
5030: 74 69 6d 65 72 2e 20 49 74 20 77 61 73 20 6e 6f  timer. It was no
5040: 74 20 66 69 72 65 64 2c 20 79 65 74 20 77 65 20  t fired, yet we 
5050: 61 72 65 0a 09 20 2a 20 68 65 72 65 2c 20 73 6f  are.. * here, so
5060: 20 74 68 65 20 63 68 61 6e 6e 65 6c 20 62 65 6c   the channel bel
5070: 6f 77 20 67 65 6e 65 72 61 74 65 64 20 73 75 63  ow generated suc
5080: 68 20 61 6e 20 65 76 65 6e 74 20 61 6e 64 20 77  h an event and w
5090: 65 0a 09 20 2a 20 64 6f 6e 27 74 20 68 61 76 65  e.. * don't have
50a0: 20 74 6f 2e 20 54 68 65 20 72 65 6e 65 77 61 6c   to. The renewal
50b0: 20 6f 66 20 74 68 65 20 69 6e 74 65 72 65 73 74   of the interest
50c0: 20 61 66 74 65 72 20 74 68 65 0a 09 20 2a 20 65   after the.. * e
50d0: 78 65 63 75 74 69 6f 6e 20 6f 66 20 63 68 61 6e  xecution of chan
50e0: 6e 65 6c 20 68 61 6e 64 6c 65 72 73 20 77 69 6c  nel handlers wil
50f0: 6c 20 65 76 65 6e 74 75 61 6c 6c 79 20 63 61 75  l eventually cau
5100: 73 65 20 75 73 20 74 6f 0a 09 20 2a 20 72 65 63  se us to.. * rec
5110: 72 65 61 74 65 20 74 68 65 20 74 69 6d 65 72 20  reate the timer 
5120: 28 69 6e 20 57 61 74 63 68 50 72 6f 63 29 2e 0a  (in WatchProc)..
5130: 09 20 2a 2f 0a 09 54 63 6c 5f 44 65 6c 65 74 65  . */..Tcl_Delete
5140: 54 69 6d 65 72 48 61 6e 64 6c 65 72 28 73 74 61  TimerHandler(sta
5150: 74 65 50 74 72 2d 3e 74 69 6d 65 72 29 3b 0a 09  tePtr->timer);..
5160: 73 74 61 74 65 50 74 72 2d 3e 74 69 6d 65 72 20  statePtr->timer 
5170: 3d 20 28 54 63 6c 5f 54 69 6d 65 72 54 6f 6b 65  = (Tcl_TimerToke
5180: 6e 29 20 4e 55 4c 4c 3b 0a 20 20 20 20 7d 0a 0a  n) NULL;.    }..
5190: 20 20 20 20 69 66 20 28 73 74 61 74 65 50 74 72      if (statePtr
51a0: 2d 3e 66 6c 61 67 73 20 26 20 54 4c 53 5f 54 43  ->flags & TLS_TC
51b0: 4c 5f 43 41 4c 4c 42 41 43 4b 29 20 7b 0a 09 64  L_CALLBACK) {..d
51c0: 70 72 69 6e 74 66 28 22 52 65 74 75 72 6e 69 6e  printf("Returnin
51d0: 67 20 30 20 64 75 65 20 74 6f 20 63 61 6c 6c 62  g 0 due to callb
51e0: 61 63 6b 22 29 3b 0a 09 72 65 74 75 72 6e 20 30  ack");..return 0
51f0: 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 64 70 72  ;.    }..    dpr
5200: 69 6e 74 66 28 22 43 61 6c 6c 69 6e 67 20 54 6c  intf("Calling Tl
5210: 73 5f 57 61 69 74 46 6f 72 43 6f 6e 6e 65 63 74  s_WaitForConnect
5220: 22 29 3b 0a 20 20 20 20 65 72 72 6f 72 43 6f 64  ");.    errorCod
5230: 65 20 3d 20 30 3b 0a 20 20 20 20 69 66 20 28 54  e = 0;.    if (T
5240: 6c 73 5f 57 61 69 74 46 6f 72 43 6f 6e 6e 65 63  ls_WaitForConnec
5250: 74 28 73 74 61 74 65 50 74 72 2c 20 26 65 72 72  t(statePtr, &err
5260: 6f 72 43 6f 64 65 2c 20 31 29 20 3c 20 30 29 20  orCode, 1) < 0) 
5270: 7b 0a 09 69 66 20 28 65 72 72 6f 72 43 6f 64 65  {..if (errorCode
5280: 20 3d 3d 20 45 41 47 41 49 4e 29 20 7b 0a 09 20   == EAGAIN) {.. 
5290: 20 20 20 64 70 72 69 6e 74 66 28 22 41 73 79 6e     dprintf("Asyn
52a0: 63 20 66 6c 61 67 20 63 6f 75 6c 64 20 62 65 20  c flag could be 
52b0: 73 65 74 20 28 64 69 64 6e 27 74 20 63 68 65 63  set (didn't chec
52c0: 6b 29 20 61 6e 64 20 65 72 72 6f 72 43 6f 64 65  k) and errorCode
52d0: 20 3d 3d 20 45 41 47 41 49 4e 3a 20 20 52 65 74   == EAGAIN:  Ret
52e0: 75 72 6e 69 6e 67 20 30 22 29 3b 0a 0a 09 20 20  urning 0");...  
52f0: 20 20 72 65 74 75 72 6e 20 30 3b 0a 09 7d 0a 0a    return 0;..}..
5300: 09 64 70 72 69 6e 74 66 28 22 54 6c 73 5f 57 61  .dprintf("Tls_Wa
5310: 69 74 46 6f 72 43 6f 6e 6e 65 63 74 20 72 65 74  itForConnect ret
5320: 75 72 6e 65 64 20 61 6e 20 65 72 72 6f 72 22 29  urned an error")
5330: 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 64 70 72  ;.    }..    dpr
5340: 69 6e 74 66 28 22 52 65 74 75 72 6e 69 6e 67 20  intf("Returning 
5350: 25 69 22 2c 20 6d 61 73 6b 29 3b 0a 0a 20 20 20  %i", mask);..   
5360: 20 72 65 74 75 72 6e 28 6d 61 73 6b 29 3b 0a 7d   return(mask);.}
5370: 0a 0a 23 69 66 20 30 0a 2f 2a 0a 20 2a 2d 2d 2d  ..#if 0./*. *---
5380: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5390: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
53a0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
53b0: 2d 2d 2d 2a 0a 20 2a 0a 20 2a 20 20 20 20 20 20  ---*. *. *      
53c0: 54 6c 73 43 68 61 6e 6e 65 6c 48 61 6e 64 6c 65  TlsChannelHandle
53d0: 72 20 2d 2d 0a 20 2a 0a 20 2a 20 20 20 20 20 20  r --. *. *      
53e0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
53f0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5400: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5410: 2a 0a 20 2a 20 20 20 20 20 20 48 61 6e 64 6c 65  *. *      Handle
5420: 72 20 63 61 6c 6c 65 64 20 62 79 20 54 63 6c 20  r called by Tcl 
5430: 61 73 20 61 20 72 65 73 75 6c 74 20 6f 66 0a 20  as a result of. 
5440: 2a 20 20 20 20 20 20 54 63 6c 5f 43 72 65 61 74  *      Tcl_Creat
5450: 65 43 68 61 6e 6e 65 6c 48 61 6e 64 6c 65 72 20  eChannelHandler 
5460: 2d 20 74 6f 20 69 6e 66 6f 72 6d 20 75 73 20 6f  - to inform us o
5470: 66 20 61 63 74 69 76 69 74 79 0a 20 2a 20 20 20  f activity. *   
5480: 20 20 20 6f 6e 20 74 68 65 20 75 6e 64 65 72 6c     on the underl
5490: 79 69 6e 67 20 63 68 61 6e 6e 65 6c 2e 0a 20 2a  ying channel.. *
54a0: 20 20 20 20 20 20 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d        ----------
54b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
54c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
54d0: 2d 2d 2d 2d 2d 2d 2a 0a 20 2a 0a 20 2a 20 20 20  ------*. *. *   
54e0: 20 20 20 53 69 64 65 65 66 66 65 63 74 73 3a 0a     Sideeffects:.
54f0: 20 2a 20 20 20 20 20 20 20 20 20 20 20 20 20 20   *              
5500: 4d 61 79 20 67 65 6e 65 72 61 74 65 20 73 75 62  May generate sub
5510: 73 65 71 75 65 6e 74 20 63 61 6c 6c 73 20 74 6f  sequent calls to
5520: 0a 20 2a 20 20 20 20 20 20 20 20 20 20 20 20 20  . *             
5530: 20 54 63 6c 5f 4e 6f 74 69 66 79 43 68 61 6e 6e   Tcl_NotifyChann
5540: 65 6c 2e 0a 20 2a 0a 20 2a 20 20 20 20 20 20 52  el.. *. *      R
5550: 65 73 75 6c 74 3a 0a 20 2a 20 20 20 20 20 20 20  esult:. *       
5560: 20 20 20 20 20 20 20 4e 6f 6e 65 2e 0a 20 2a 0a         None.. *.
5570: 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d   *--------------
5580: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5590: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
55a0: 2d 2d 2d 2d 2d 2d 2d 2d 2a 0a 20 2a 2f 0a 0a 73  --------*. */..s
55b0: 74 61 74 69 63 20 76 6f 69 64 0a 54 6c 73 43 68  tatic void.TlsCh
55c0: 61 6e 6e 65 6c 48 61 6e 64 6c 65 72 20 28 63 6c  annelHandler (cl
55d0: 69 65 6e 74 44 61 74 61 2c 20 6d 61 73 6b 29 0a  ientData, mask).
55e0: 20 20 20 20 76 6f 69 64 20 2a 20 20 20 20 63 6c      void *    cl
55f0: 69 65 6e 74 44 61 74 61 3b 0a 20 20 20 20 69 6e  ientData;.    in
5600: 74 20 20 20 20 20 20 20 20 20 20 20 20 6d 61 73  t            mas
5610: 6b 3b 0a 7b 0a 20 20 20 20 53 74 61 74 65 20 2a  k;.{.    State *
5620: 73 74 61 74 65 50 74 72 20 3d 20 28 53 74 61 74  statePtr = (Stat
5630: 65 20 2a 29 20 63 6c 69 65 6e 74 44 61 74 61 3b  e *) clientData;
5640: 0a 0a 20 20 20 20 64 70 72 69 6e 74 66 28 22 48  ..    dprintf("H
5650: 41 4e 44 4c 45 52 28 30 78 25 78 29 22 2c 20 6d  ANDLER(0x%x)", m
5660: 61 73 6b 29 3b 0a 20 20 20 20 54 63 6c 5f 50 72  ask);.    Tcl_Pr
5670: 65 73 65 72 76 65 28 73 74 61 74 65 50 74 72 29  eserve(statePtr)
5680: 3b 0a 0a 20 20 20 20 69 66 20 28 6d 61 73 6b 20  ;..    if (mask 
5690: 26 20 54 43 4c 5f 52 45 41 44 41 42 4c 45 29 20  & TCL_READABLE) 
56a0: 7b 0a 09 42 49 4f 5f 73 65 74 5f 66 6c 61 67 73  {..BIO_set_flags
56b0: 28 73 74 61 74 65 50 74 72 2d 3e 70 5f 62 69 6f  (statePtr->p_bio
56c0: 2c 20 42 49 4f 5f 46 4c 41 47 53 5f 52 45 41 44  , BIO_FLAGS_READ
56d0: 29 3b 0a 20 20 20 20 7d 20 65 6c 73 65 20 7b 0a  );.    } else {.
56e0: 09 42 49 4f 5f 63 6c 65 61 72 5f 66 6c 61 67 73  .BIO_clear_flags
56f0: 28 73 74 61 74 65 50 74 72 2d 3e 70 5f 62 69 6f  (statePtr->p_bio
5700: 2c 20 42 49 4f 5f 46 4c 41 47 53 5f 52 45 41 44  , BIO_FLAGS_READ
5710: 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 66  );.    }..    if
5720: 20 28 6d 61 73 6b 20 26 20 54 43 4c 5f 57 52 49   (mask & TCL_WRI
5730: 54 41 42 4c 45 29 20 7b 0a 09 42 49 4f 5f 73 65  TABLE) {..BIO_se
5740: 74 5f 66 6c 61 67 73 28 73 74 61 74 65 50 74 72  t_flags(statePtr
5750: 2d 3e 70 5f 62 69 6f 2c 20 42 49 4f 5f 46 4c 41  ->p_bio, BIO_FLA
5760: 47 53 5f 57 52 49 54 45 29 3b 0a 20 20 20 20 7d  GS_WRITE);.    }
5770: 20 65 6c 73 65 20 7b 0a 09 42 49 4f 5f 63 6c 65   else {..BIO_cle
5780: 61 72 5f 66 6c 61 67 73 28 73 74 61 74 65 50 74  ar_flags(statePt
5790: 72 2d 3e 70 5f 62 69 6f 2c 20 42 49 4f 5f 46 4c  r->p_bio, BIO_FL
57a0: 41 47 53 5f 57 52 49 54 45 29 3b 0a 20 20 20 20  AGS_WRITE);.    
57b0: 7d 0a 0a 20 20 20 20 6d 61 73 6b 20 3d 20 30 3b  }..    mask = 0;
57c0: 0a 20 20 20 20 69 66 20 28 42 49 4f 5f 77 70 65  .    if (BIO_wpe
57d0: 6e 64 69 6e 67 28 73 74 61 74 65 50 74 72 2d 3e  nding(statePtr->
57e0: 62 69 6f 29 29 20 7b 0a 09 6d 61 73 6b 20 7c 3d  bio)) {..mask |=
57f0: 20 54 43 4c 5f 57 52 49 54 41 42 4c 45 3b 0a 20   TCL_WRITABLE;. 
5800: 20 20 20 7d 0a 20 20 20 20 69 66 20 28 42 49 4f     }.    if (BIO
5810: 5f 70 65 6e 64 69 6e 67 28 73 74 61 74 65 50 74  _pending(statePt
5820: 72 2d 3e 62 69 6f 29 29 20 7b 0a 09 6d 61 73 6b  r->bio)) {..mask
5830: 20 7c 3d 20 54 43 4c 5f 52 45 41 44 41 42 4c 45   |= TCL_READABLE
5840: 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2a 0a  ;.    }..    /*.
5850: 20 20 20 20 20 2a 20 54 68 65 20 66 6f 6c 6c 6f       * The follo
5860: 77 69 6e 67 20 4e 6f 74 69 66 79 43 68 61 6e 6e  wing NotifyChann
5870: 65 6c 20 63 61 6c 6c 73 20 73 65 65 6d 73 20 74  el calls seems t
5880: 6f 20 62 65 20 69 6d 70 6f 72 74 61 6e 74 2c 20  o be important, 
5890: 62 75 74 0a 20 20 20 20 20 2a 20 77 65 20 64 6f  but.     * we do
58a0: 6e 27 74 20 6b 6e 6f 77 20 77 68 79 2e 20 20 49  n't know why.  I
58b0: 74 20 6c 6f 6f 6b 73 20 6c 69 6b 65 20 69 66 20  t looks like if 
58c0: 74 68 65 20 6d 61 73 6b 20 69 73 20 65 76 65 72  the mask is ever
58d0: 20 6e 6f 6e 2d 7a 65 72 6f 0a 20 20 20 20 20 2a   non-zero.     *
58e0: 20 74 68 61 74 20 69 74 20 77 69 6c 6c 20 65 6e   that it will en
58f0: 74 65 72 20 61 6e 20 69 6e 66 69 6e 69 74 65 20  ter an infinite 
5900: 6c 6f 6f 70 2e 0a 20 20 20 20 20 2a 0a 20 20 20  loop..     *.   
5910: 20 20 2a 20 4e 6f 74 69 66 79 20 74 68 65 20 75    * Notify the u
5920: 70 70 65 72 20 63 68 61 6e 6e 65 6c 20 6f 66 20  pper channel of 
5930: 74 68 65 20 63 75 72 72 65 6e 74 20 42 49 4f 20  the current BIO 
5940: 73 74 61 74 65 20 73 6f 20 74 68 65 20 65 76 65  state so the eve
5950: 6e 74 0a 20 20 20 20 20 2a 20 63 6f 6e 74 69 6e  nt.     * contin
5960: 75 65 73 20 74 6f 20 70 72 6f 70 61 67 61 74 65  ues to propagate
5970: 20 75 70 20 74 68 65 20 63 68 61 69 6e 2e 0a 20   up the chain.. 
5980: 20 20 20 20 2a 0a 20 20 20 20 20 2a 20 73 74 61      *.     * sta
5990: 6e 74 6f 6e 3a 20 49 74 20 6c 6f 6f 6b 73 20 6c  nton: It looks l
59a0: 69 6b 65 20 74 68 69 73 20 63 6f 75 6c 64 20 72  ike this could r
59b0: 65 73 75 6c 74 20 69 6e 20 61 6e 20 69 6e 66 69  esult in an infi
59c0: 6e 69 74 65 20 6c 6f 6f 70 20 69 66 0a 20 20 20  nite loop if.   
59d0: 20 20 2a 20 74 68 65 20 75 70 70 65 72 20 63 68    * the upper ch
59e0: 61 6e 6e 65 6c 20 64 6f 65 73 6e 27 74 20 63 61  annel doesn't ca
59f0: 75 73 65 20 43 68 61 6e 6e 65 6c 48 61 6e 64 6c  use ChannelHandl
5a00: 65 72 20 74 6f 20 62 65 20 72 65 6d 6f 76 65 64  er to be removed
5a10: 0a 20 20 20 20 20 2a 20 62 65 66 6f 72 65 20 54  .     * before T
5a20: 63 6c 5f 4e 6f 74 69 66 79 43 68 61 6e 6e 65 6c  cl_NotifyChannel
5a30: 20 63 61 6c 6c 73 20 63 68 61 6e 6e 65 6c 20 68   calls channel h
5a40: 61 6e 64 6c 65 72 73 20 6f 6e 20 74 68 65 20 6c  andlers on the l
5a50: 6f 77 65 72 20 63 68 61 6e 6e 65 6c 2e 0a 20 20  ower channel..  
5a60: 20 20 20 2a 2f 0a 0a 20 20 20 20 54 63 6c 5f 4e     */..    Tcl_N
5a70: 6f 74 69 66 79 43 68 61 6e 6e 65 6c 28 73 74 61  otifyChannel(sta
5a80: 74 65 50 74 72 2d 3e 73 65 6c 66 2c 20 6d 61 73  tePtr->self, mas
5a90: 6b 29 3b 0a 0a 20 20 20 20 69 66 20 28 73 74 61  k);..    if (sta
5aa0: 74 65 50 74 72 2d 3e 74 69 6d 65 72 20 21 3d 20  tePtr->timer != 
5ab0: 28 54 63 6c 5f 54 69 6d 65 72 54 6f 6b 65 6e 29  (Tcl_TimerToken)
5ac0: 4e 55 4c 4c 29 20 7b 0a 09 54 63 6c 5f 44 65 6c  NULL) {..Tcl_Del
5ad0: 65 74 65 54 69 6d 65 72 48 61 6e 64 6c 65 72 28  eteTimerHandler(
5ae0: 73 74 61 74 65 50 74 72 2d 3e 74 69 6d 65 72 29  statePtr->timer)
5af0: 3b 0a 09 73 74 61 74 65 50 74 72 2d 3e 74 69 6d  ;..statePtr->tim
5b00: 65 72 20 3d 20 28 54 63 6c 5f 54 69 6d 65 72 54  er = (Tcl_TimerT
5b10: 6f 6b 65 6e 29 4e 55 4c 4c 3b 0a 20 20 20 20 7d  oken)NULL;.    }
5b20: 0a 20 20 20 20 69 66 20 28 28 6d 61 73 6b 20 26  .    if ((mask &
5b30: 20 54 43 4c 5f 52 45 41 44 41 42 4c 45 29 20 26   TCL_READABLE) &
5b40: 26 20 54 63 6c 5f 49 6e 70 75 74 42 75 66 66 65  & Tcl_InputBuffe
5b50: 72 65 64 28 73 74 61 74 65 50 74 72 2d 3e 73 65  red(statePtr->se
5b60: 6c 66 29 20 3e 20 30 29 20 7b 0a 09 2f 2a 0a 09  lf) > 0) {../*..
5b70: 20 2a 20 44 61 74 61 20 69 73 20 77 61 69 74 69   * Data is waiti
5b80: 6e 67 2c 20 66 6c 75 73 68 20 69 74 20 6f 75 74  ng, flush it out
5b90: 20 69 6e 20 73 68 6f 72 74 20 74 69 6d 65 0a 09   in short time..
5ba0: 20 2a 2f 0a 09 73 74 61 74 65 50 74 72 2d 3e 74   */..statePtr->t
5bb0: 69 6d 65 72 20 3d 20 54 63 6c 5f 43 72 65 61 74  imer = Tcl_Creat
5bc0: 65 54 69 6d 65 72 48 61 6e 64 6c 65 72 28 54 4c  eTimerHandler(TL
5bd0: 53 5f 54 43 4c 5f 44 45 4c 41 59 2c 0a 09 09 54  S_TCL_DELAY,...T
5be0: 6c 73 43 68 61 6e 6e 65 6c 48 61 6e 64 6c 65 72  lsChannelHandler
5bf0: 54 69 6d 65 72 2c 20 73 74 61 74 65 50 74 72 29  Timer, statePtr)
5c00: 3b 0a 20 20 20 20 7d 0a 20 20 20 20 54 63 6c 5f  ;.    }.    Tcl_
5c10: 52 65 6c 65 61 73 65 28 73 74 61 74 65 50 74 72  Release(statePtr
5c20: 29 3b 0a 7d 0a 23 65 6e 64 69 66 0a 0a 2f 2a 0a  );.}.#endif../*.
5c30: 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d   *--------------
5c40: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5c50: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5c60: 2d 2d 2d 2d 2d 2d 2d 2d 2a 0a 20 2a 0a 20 2a 09  --------*. *. *.
5c70: 54 6c 73 43 68 61 6e 6e 65 6c 48 61 6e 64 6c 65  TlsChannelHandle
5c80: 72 54 69 6d 65 72 20 2d 2d 0a 20 2a 0a 20 2a 09  rTimer --. *. *.
5c90: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5ca0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5cb0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5cc0: 2a 0a 20 2a 09 43 61 6c 6c 65 64 20 62 79 20 74  *. *.Called by t
5cd0: 68 65 20 6e 6f 74 69 66 69 65 72 20 28 2d 3e 20  he notifier (-> 
5ce0: 74 69 6d 65 72 29 20 74 6f 20 66 6c 75 73 68 20  timer) to flush 
5cf0: 6f 75 74 0a 20 2a 09 69 6e 66 6f 72 6d 61 74 69  out. *.informati
5d00: 6f 6e 20 77 61 69 74 69 6e 67 20 69 6e 20 63 68  on waiting in ch
5d10: 61 6e 6e 65 6c 20 62 75 66 66 65 72 73 2e 0a 20  annel buffers.. 
5d20: 2a 09 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  *.--------------
5d30: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5d40: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5d50: 2d 2d 2a 0a 20 2a 0a 20 2a 09 53 69 64 65 65 66  --*. *. *.Sideef
5d60: 66 65 63 74 73 3a 0a 20 2a 09 09 41 73 20 6f 66  fects:. *..As of
5d70: 20 27 54 6c 73 43 68 61 6e 6e 65 6c 48 61 6e 64   'TlsChannelHand
5d80: 6c 65 72 27 2e 0a 20 2a 0a 20 2a 09 52 65 73 75  ler'.. *. *.Resu
5d90: 6c 74 3a 0a 20 2a 09 09 4e 6f 6e 65 2e 0a 20 2a  lt:. *..None.. *
5da0: 0a 20 2a 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 2d 2d 2d 2d  ----------------
5dd0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2a 0a 20 2a 2f 0a 0a  ---------*. */..
5de0: 0a 2f 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ./*. *----------
5df0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5e00: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5e10: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5e20: 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 0a 20 2a 20  ---------. *. * 
5e30: 54 6c 73 5f 43 68 61 6e 6e 65 6c 54 79 70 65 20  Tls_ChannelType 
5e40: 2d 2d 0a 20 2a 0a 20 2a 20 20 20 20 52 65 74 75  --. *. *    Retu
5e50: 72 6e 20 74 68 65 20 63 6f 72 72 65 63 74 20 54  rn the correct T
5e60: 4c 53 20 63 68 61 6e 6e 65 6c 20 64 72 69 76 65  LS channel drive
5e70: 72 20 69 6e 66 6f 0a 20 2a 0a 20 2a 20 52 65 73  r info. *. * Res
5e80: 75 6c 74 73 3a 0a 20 2a 20 20 20 20 54 68 65 20  ults:. *    The 
5e90: 63 6f 72 72 65 63 74 20 63 68 61 6e 6e 65 6c 20  correct channel 
5ea0: 64 72 69 76 65 72 20 66 6f 72 20 74 68 65 20 63  driver for the c
5eb0: 75 72 72 65 6e 74 20 76 65 72 73 69 6f 6e 20 6f  urrent version o
5ec0: 66 20 54 63 6c 2e 0a 20 2a 0a 20 2a 20 53 69 64  f Tcl.. *. * Sid
5ed0: 65 20 65 66 66 65 63 74 73 3a 0a 20 2a 20 20 20  e effects:. *   
5ee0: 20 4e 6f 6e 65 2e 0a 20 2a 0a 20 2a 2d 2d 2d 2d   None.. *. *----
5ef0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5f00: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5f10: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5f20: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a  ---------------.
5f30: 20 2a 2f 0a 73 74 61 74 69 63 20 63 6f 6e 73 74   */.static const
5f40: 20 54 63 6c 5f 43 68 61 6e 6e 65 6c 54 79 70 65   Tcl_ChannelType
5f50: 20 74 6c 73 43 68 61 6e 6e 65 6c 54 79 70 65 20   tlsChannelType 
5f60: 3d 20 7b 0a 20 20 20 20 22 74 6c 73 22 2c 09 09  = {.    "tls",..
5f70: 09 2f 2a 20 54 79 70 65 20 6e 61 6d 65 20 2a 2f  ./* Type name */
5f80: 0a 20 20 20 20 54 43 4c 5f 43 48 41 4e 4e 45 4c  .    TCL_CHANNEL
5f90: 5f 56 45 52 53 49 4f 4e 5f 35 2c 09 2f 2a 20 76  _VERSION_5,./* v
5fa0: 35 20 63 68 61 6e 6e 65 6c 20 2a 2f 0a 20 20 20  5 channel */.   
5fb0: 20 54 6c 73 43 6c 6f 73 65 50 72 6f 63 2c 09 09   TlsCloseProc,..
5fc0: 2f 2a 20 43 6c 6f 73 65 20 70 72 6f 63 20 2a 2f  /* Close proc */
5fd0: 0a 20 20 20 20 54 6c 73 49 6e 70 75 74 50 72 6f  .    TlsInputPro
5fe0: 63 2c 09 09 2f 2a 20 49 6e 70 75 74 20 70 72 6f  c,../* Input pro
5ff0: 63 20 2a 2f 0a 20 20 20 20 54 6c 73 4f 75 74 70  c */.    TlsOutp
6000: 75 74 50 72 6f 63 2c 09 09 2f 2a 20 4f 75 74 70  utProc,../* Outp
6010: 75 74 20 70 72 6f 63 20 2a 2f 0a 20 20 20 20 30  ut proc */.    0
6020: 2c 09 09 09 2f 2a 20 53 65 65 6b 20 70 72 6f 63  ,.../* Seek proc
6030: 20 2a 2f 0a 20 20 20 20 30 2c 09 09 2f 2a 20 53   */.    0,../* S
6040: 65 74 20 6f 70 74 69 6f 6e 20 70 72 6f 63 20 2a  et option proc *
6050: 2f 0a 20 20 20 20 54 6c 73 47 65 74 4f 70 74 69  /.    TlsGetOpti
6060: 6f 6e 50 72 6f 63 2c 09 09 2f 2a 20 47 65 74 20  onProc,../* Get 
6070: 6f 70 74 69 6f 6e 20 70 72 6f 63 20 2a 2f 0a 20  option proc */. 
6080: 20 20 20 54 6c 73 57 61 74 63 68 50 72 6f 63 2c     TlsWatchProc,
6090: 09 09 2f 2a 20 49 6e 69 74 69 61 6c 69 7a 65 20  ../* Initialize 
60a0: 6e 6f 74 69 66 69 65 72 20 2a 2f 0a 20 20 20 20  notifier */.    
60b0: 54 6c 73 47 65 74 48 61 6e 64 6c 65 50 72 6f 63  TlsGetHandleProc
60c0: 2c 09 09 2f 2a 20 47 65 74 20 4f 53 20 68 61 6e  ,../* Get OS han
60d0: 64 6c 65 73 20 6f 75 74 20 6f 66 20 63 68 61 6e  dles out of chan
60e0: 6e 65 6c 20 2a 2f 0a 20 20 20 20 54 6c 73 43 6c  nel */.    TlsCl
60f0: 6f 73 65 32 50 72 6f 63 2c 09 09 2f 2a 20 63 6c  ose2Proc,../* cl
6100: 6f 73 65 32 70 72 6f 63 20 2a 2f 0a 20 20 20 20  ose2proc */.    
6110: 54 6c 73 42 6c 6f 63 6b 4d 6f 64 65 50 72 6f 63  TlsBlockModeProc
6120: 2c 09 09 2f 2a 20 53 65 74 20 62 6c 6f 63 6b 69  ,../* Set blocki
6130: 6e 67 2f 6e 6f 6e 62 6c 6f 63 6b 69 6e 67 20 6d  ng/nonblocking m
6140: 6f 64 65 2a 2f 0a 20 20 20 20 30 2c 09 09 09 2f  ode*/.    0,.../
6150: 2a 20 46 6c 75 73 68 20 70 72 6f 63 20 2a 2f 0a  * Flush proc */.
6160: 20 20 20 20 54 6c 73 4e 6f 74 69 66 79 50 72 6f      TlsNotifyPro
6170: 63 2c 09 09 2f 2a 20 48 61 6e 64 6c 69 6e 67 20  c,../* Handling 
6180: 6f 66 20 65 76 65 6e 74 73 20 62 75 62 62 6c 69  of events bubbli
6190: 6e 67 20 75 70 20 2a 2f 0a 20 20 20 20 30 2c 09  ng up */.    0,.
61a0: 09 09 2f 2a 20 57 69 64 65 20 73 65 65 6b 20 70  ../* Wide seek p
61b0: 72 6f 63 20 2a 2f 0a 20 20 20 20 4e 55 4c 4c 2c  roc */.    NULL,
61c0: 09 09 09 2f 2a 20 54 68 72 65 61 64 20 61 63 74  .../* Thread act
61d0: 69 6f 6e 20 2a 2f 0a 20 20 20 20 4e 55 4c 4c 09  ion */.    NULL.
61e0: 09 09 2f 2a 20 54 72 75 6e 63 61 74 65 20 2a 2f  ../* Truncate */
61f0: 0a 7d 3b 0a 0a 63 6f 6e 73 74 20 54 63 6c 5f 43  .};..const Tcl_C
6200: 68 61 6e 6e 65 6c 54 79 70 65 20 2a 54 6c 73 5f  hannelType *Tls_
6210: 43 68 61 6e 6e 65 6c 54 79 70 65 28 76 6f 69 64  ChannelType(void
6220: 29 20 7b 0a 20 20 20 20 72 65 74 75 72 6e 20 26  ) {.    return &
6230: 74 6c 73 43 68 61 6e 6e 65 6c 54 79 70 65 3b 0a  tlsChannelType;.
6240: 7d 0a 0a 0a 73 74 61 74 69 63 20 76 6f 69 64 20  }...static void 
6250: 54 6c 73 43 68 61 6e 6e 65 6c 48 61 6e 64 6c 65  TlsChannelHandle
6260: 72 54 69 6d 65 72 28 76 6f 69 64 20 2a 63 6c 69  rTimer(void *cli
6270: 65 6e 74 44 61 74 61 29 20 7b 0a 09 53 74 61 74  entData) {..Stat
6280: 65 20 2a 73 74 61 74 65 50 74 72 20 3d 20 28 53  e *statePtr = (S
6290: 74 61 74 65 20 2a 29 20 63 6c 69 65 6e 74 44 61  tate *) clientDa
62a0: 74 61 3b 0a 09 69 6e 74 20 6d 61 73 6b 20 3d 20  ta;..int mask = 
62b0: 30 3b 0a 0a 09 64 70 72 69 6e 74 66 28 22 43 61  0;...dprintf("Ca
62c0: 6c 6c 65 64 22 29 3b 0a 0a 09 73 74 61 74 65 50  lled");...stateP
62d0: 74 72 2d 3e 74 69 6d 65 72 20 3d 20 28 54 63 6c  tr->timer = (Tcl
62e0: 5f 54 69 6d 65 72 54 6f 6b 65 6e 29 20 4e 55 4c  _TimerToken) NUL
62f0: 4c 3b 0a 0a 09 69 66 20 28 42 49 4f 5f 77 70 65  L;...if (BIO_wpe
6300: 6e 64 69 6e 67 28 73 74 61 74 65 50 74 72 2d 3e  nding(statePtr->
6310: 62 69 6f 29 29 20 7b 0a 09 09 64 70 72 69 6e 74  bio)) {...dprint
6320: 66 28 22 5b 63 68 61 6e 3d 25 70 5d 20 42 49 4f  f("[chan=%p] BIO
6330: 20 77 72 69 74 61 62 6c 65 22 2c 20 73 74 61 74   writable", stat
6340: 65 50 74 72 2d 3e 73 65 6c 66 29 3b 0a 0a 09 09  ePtr->self);....
6350: 6d 61 73 6b 20 7c 3d 20 54 43 4c 5f 57 52 49 54  mask |= TCL_WRIT
6360: 41 42 4c 45 3b 0a 09 7d 0a 0a 09 69 66 20 28 42  ABLE;..}...if (B
6370: 49 4f 5f 70 65 6e 64 69 6e 67 28 73 74 61 74 65  IO_pending(state
6380: 50 74 72 2d 3e 62 69 6f 29 29 20 7b 0a 09 09 64  Ptr->bio)) {...d
6390: 70 72 69 6e 74 66 28 22 5b 63 68 61 6e 3d 25 70  printf("[chan=%p
63a0: 5d 20 42 49 4f 20 72 65 61 64 61 62 6c 65 22 2c  ] BIO readable",
63b0: 20 73 74 61 74 65 50 74 72 2d 3e 73 65 6c 66 29   statePtr->self)
63c0: 3b 0a 0a 09 09 6d 61 73 6b 20 7c 3d 20 54 43 4c  ;....mask |= TCL
63d0: 5f 52 45 41 44 41 42 4c 45 3b 0a 09 7d 0a 0a 09  _READABLE;..}...
63e0: 64 70 72 69 6e 74 66 28 22 4e 6f 74 69 66 79 69  dprintf("Notifyi
63f0: 6e 67 20 6f 75 72 73 65 6c 76 65 73 22 29 3b 0a  ng ourselves");.
6400: 09 54 63 6c 5f 4e 6f 74 69 66 79 43 68 61 6e 6e  .Tcl_NotifyChann
6410: 65 6c 28 73 74 61 74 65 50 74 72 2d 3e 73 65 6c  el(statePtr->sel
6420: 66 2c 20 6d 61 73 6b 29 3b 0a 0a 09 64 70 72 69  f, mask);...dpri
6430: 6e 74 66 28 22 52 65 74 75 72 6e 69 6e 67 22 29  ntf("Returning")
6440: 3b 0a 0a 09 72 65 74 75 72 6e 3b 0a 7d 0a 0a 54  ;...return;.}..T
6450: 63 6c 5f 43 68 61 6e 6e 65 6c 20 54 6c 73 5f 47  cl_Channel Tls_G
6460: 65 74 50 61 72 65 6e 74 28 53 74 61 74 65 20 2a  etParent(State *
6470: 73 74 61 74 65 50 74 72 2c 20 69 6e 74 20 6d 61  statePtr, int ma
6480: 73 6b 46 6c 61 67 73 29 20 7b 0a 09 64 70 72 69  skFlags) {..dpri
6490: 6e 74 66 28 22 52 65 71 75 65 73 74 65 64 20 74  ntf("Requested t
64a0: 6f 20 67 65 74 20 70 61 72 65 6e 74 20 6f 66 20  o get parent of 
64b0: 63 68 61 6e 6e 65 6c 20 25 70 22 2c 20 73 74 61  channel %p", sta
64c0: 74 65 50 74 72 2d 3e 73 65 6c 66 29 3b 0a 0a 09  tePtr->self);...
64d0: 69 66 20 28 28 73 74 61 74 65 50 74 72 2d 3e 66  if ((statePtr->f
64e0: 6c 61 67 73 20 26 20 7e 6d 61 73 6b 46 6c 61 67  lags & ~maskFlag
64f0: 73 29 20 26 20 54 4c 53 5f 54 43 4c 5f 46 41 53  s) & TLS_TCL_FAS
6500: 54 50 41 54 48 29 20 7b 0a 09 09 64 70 72 69 6e  TPATH) {...dprin
6510: 74 66 28 22 41 73 6b 65 64 20 74 6f 20 67 65 74  tf("Asked to get
6520: 20 74 68 65 20 70 61 72 65 6e 74 20 63 68 61 6e   the parent chan
6530: 6e 65 6c 20 77 68 69 6c 65 20 77 65 20 61 72 65  nel while we are
6540: 20 75 73 69 6e 67 20 46 61 73 74 50 61 74 68 20   using FastPath 
6550: 2d 2d 20 72 65 74 75 72 6e 69 6e 67 20 4e 55 4c  -- returning NUL
6560: 4c 22 29 3b 0a 09 09 72 65 74 75 72 6e 28 4e 55  L");...return(NU
6570: 4c 4c 29 3b 0a 09 7d 0a 0a 09 72 65 74 75 72 6e  LL);..}...return
6580: 28 54 63 6c 5f 47 65 74 53 74 61 63 6b 65 64 43  (Tcl_GetStackedC
6590: 68 61 6e 6e 65 6c 28 73 74 61 74 65 50 74 72 2d  hannel(statePtr-
65a0: 3e 73 65 6c 66 29 29 3b 0a 7d 0a                 >self));.}.