Hex Artifact Content

Artifact 8b14832fee29c3de46b085f8e44a6345fca5e20b94b911ffe43676632354d677:


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 69 6e 73 74 61 6e 63  (State *)instanc
0510: 65 44 61 74 61 3b 0a 0a 20 20 20 20 69 66 20 28  eData;..    if (
0520: 6d 6f 64 65 20 3d 3d 20 54 43 4c 5f 4d 4f 44 45  mode == TCL_MODE
0530: 5f 4e 4f 4e 42 4c 4f 43 4b 49 4e 47 29 20 7b 0a  _NONBLOCKING) {.
0540: 09 73 74 61 74 65 50 74 72 2d 3e 66 6c 61 67 73  .statePtr->flags
0550: 20 7c 3d 20 54 4c 53 5f 54 43 4c 5f 41 53 59 4e   |= TLS_TCL_ASYN
0560: 43 3b 0a 20 20 20 20 7d 20 65 6c 73 65 20 7b 0a  C;.    } else {.
0570: 09 73 74 61 74 65 50 74 72 2d 3e 66 6c 61 67 73  .statePtr->flags
0580: 20 26 3d 20 7e 28 54 4c 53 5f 54 43 4c 5f 41 53   &= ~(TLS_TCL_AS
0590: 59 4e 43 29 3b 0a 20 20 20 20 7d 0a 20 20 20 20  YNC);.    }.    
05a0: 72 65 74 75 72 6e 20 30 3b 0a 7d 0a 0a 2f 2a 0a  return 0;.}../*.
05b0: 20 2a 2d 2d 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 0a 20 2a 0a 20 2a 20 54 6c 73 43  -----. *. * TlsC
0600: 6c 6f 73 65 32 50 72 6f 63 20 2d 2d 0a 20 2a 0a  lose2Proc --. *.
0610: 20 2a 20 20 20 20 54 68 69 73 20 70 72 6f 63 65   *    This proce
0620: 64 75 72 65 20 69 73 20 69 6e 76 6f 6b 65 64 20  dure is invoked 
0630: 62 79 20 74 68 65 20 67 65 6e 65 72 69 63 20 49  by the generic I
0640: 4f 20 6c 65 76 65 6c 20 74 6f 20 70 65 72 66 6f  O level to perfo
0650: 72 6d 0a 20 2a 20 20 20 20 63 68 61 6e 6e 65 6c  rm. *    channel
0660: 2d 74 79 70 65 2d 73 70 65 63 69 66 69 63 20 63  -type-specific c
0670: 6c 65 61 6e 75 70 20 77 68 65 6e 20 61 20 53 53  leanup when a SS
0680: 4c 20 73 6f 63 6b 65 74 20 62 61 73 65 64 20 63  L socket based c
0690: 68 61 6e 6e 65 6c 0a 20 2a 20 20 20 20 69 73 20  hannel. *    is 
06a0: 63 6c 6f 73 65 64 2e 0a 20 2a 0a 20 2a 20 20 20  closed.. *. *   
06b0: 20 4e 6f 74 65 3a 20 77 65 20 6c 65 61 76 65 20   Note: we leave 
06c0: 74 68 65 20 75 6e 64 65 72 6c 79 69 6e 67 20 73  the underlying s
06d0: 6f 63 6b 65 74 20 61 6c 6f 6e 65 2c 20 69 73 20  ocket alone, is 
06e0: 74 68 69 73 20 72 69 67 68 74 3f 0a 20 2a 0a 20  this right?. *. 
06f0: 2a 20 52 65 73 75 6c 74 73 3a 0a 20 2a 20 20 20  * Results:. *   
0700: 20 30 20 69 66 20 73 75 63 63 65 73 73 66 75 6c   0 if successful
0710: 20 6f 72 20 50 4f 53 49 58 20 65 72 72 6f 72 20   or POSIX error 
0720: 63 6f 64 65 20 69 66 20 66 61 69 6c 65 64 2e 0a  code if failed..
0730: 20 2a 0a 20 2a 20 53 69 64 65 20 65 66 66 65 63   *. * Side effec
0740: 74 73 3a 0a 20 2a 20 20 20 20 43 6c 6f 73 65 73  ts:. *    Closes
0750: 20 74 68 65 20 73 6f 63 6b 65 74 20 6f 66 20 74   the socket of t
0760: 68 65 20 63 68 61 6e 6e 65 6c 2e 0a 20 2a 0a 20  he channel.. *. 
0770: 2a 2d 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 0a 20 2a 2f 0a 23 69 66 20 54 43 4c  ----. */.#if TCL
07c0: 5f 4d 41 4a 4f 52 5f 56 45 52 53 49 4f 4e 20 3e  _MAJOR_VERSION >
07d0: 20 38 0a 23 20 20 20 64 65 66 69 6e 65 20 54 6c   8.#   define Tl
07e0: 73 43 6c 6f 73 65 50 72 6f 63 20 4e 55 4c 4c 20  sCloseProc NULL 
07f0: 2f 2a 20 4e 6f 20 6c 6f 6e 67 65 72 20 6e 65 63  /* No longer nec
0800: 63 65 73 73 61 72 79 20 69 6e 20 54 63 6c 20 39  cessary in Tcl 9
0810: 20 2a 2f 0a 23 65 6c 73 65 0a 73 74 61 74 69 63   */.#else.static
0820: 20 69 6e 74 20 54 6c 73 43 6c 6f 73 65 50 72 6f   int TlsClosePro
0830: 63 28 0a 20 20 20 20 76 6f 69 64 20 2a 69 6e 73  c(.    void *ins
0840: 74 61 6e 63 65 44 61 74 61 2c 0a 20 20 20 20 54  tanceData,.    T
0850: 43 4c 5f 55 4e 55 53 45 44 28 54 63 6c 5f 49 6e  CL_UNUSED(Tcl_In
0860: 74 65 72 70 20 2a 29 29 0a 7b 0a 20 20 20 20 53  terp *)).{.    S
0870: 74 61 74 65 20 2a 73 74 61 74 65 50 74 72 20 3d  tate *statePtr =
0880: 20 28 53 74 61 74 65 20 2a 29 69 6e 73 74 61 6e   (State *)instan
0890: 63 65 44 61 74 61 3b 0a 0a 20 20 20 20 64 70 72  ceData;..    dpr
08a0: 69 6e 74 66 28 22 54 6c 73 43 6c 6f 73 65 50 72  intf("TlsClosePr
08b0: 6f 63 28 25 70 29 22 2c 20 73 74 61 74 65 50 74  oc(%p)", statePt
08c0: 72 29 3b 0a 0a 20 20 20 20 54 6c 73 5f 43 6c 65  r);..    Tls_Cle
08d0: 61 6e 28 73 74 61 74 65 50 74 72 29 3b 0a 20 20  an(statePtr);.  
08e0: 20 20 54 63 6c 5f 45 76 65 6e 74 75 61 6c 6c 79    Tcl_Eventually
08f0: 46 72 65 65 28 73 74 61 74 65 50 74 72 2c 20 54  Free(statePtr, T
0900: 6c 73 5f 46 72 65 65 29 3b 0a 20 20 20 20 72 65  ls_Free);.    re
0910: 74 75 72 6e 20 54 43 4c 5f 4f 4b 3b 0a 7d 0a 23  turn TCL_OK;.}.#
0920: 65 6e 64 69 66 0a 0a 73 74 61 74 69 63 20 69 6e  endif..static in
0930: 74 20 54 6c 73 43 6c 6f 73 65 32 50 72 6f 63 28  t TlsClose2Proc(
0940: 0a 20 20 20 20 76 6f 69 64 20 2a 69 6e 73 74 61  .    void *insta
0950: 6e 63 65 44 61 74 61 2c 20 20 20 20 2f 2a 20 54  nceData,    /* T
0960: 68 65 20 73 6f 63 6b 65 74 20 73 74 61 74 65 2e  he socket state.
0970: 20 2a 2f 0a 20 20 20 20 54 63 6c 5f 49 6e 74 65   */.    Tcl_Inte
0980: 72 70 20 2a 69 6e 74 65 72 70 2c 09 09 2f 2a 20  rp *interp,../* 
0990: 46 6f 72 20 65 72 72 6f 72 73 20 2d 20 63 61 6e  For errors - can
09a0: 20 62 65 20 4e 55 4c 4c 2e 20 2a 2f 0a 20 20 20   be NULL. */.   
09b0: 20 69 6e 74 20 66 6c 61 67 73 29 09 09 09 2f 2a   int flags).../*
09c0: 20 46 6c 61 67 73 20 74 6f 20 63 6c 6f 73 65 20   Flags to close 
09d0: 72 65 61 64 20 61 6e 64 2f 6f 72 20 77 72 69 74  read and/or writ
09e0: 65 20 73 69 64 65 20 6f 66 20 63 68 61 6e 6e 65  e side of channe
09f0: 6c 20 2a 2f 0a 7b 0a 20 20 20 20 53 74 61 74 65  l */.{.    State
0a00: 20 2a 73 74 61 74 65 50 74 72 20 3d 20 28 53 74   *statePtr = (St
0a10: 61 74 65 20 2a 29 69 6e 73 74 61 6e 63 65 44 61  ate *)instanceDa
0a20: 74 61 3b 0a 0a 20 20 20 20 64 70 72 69 6e 74 66  ta;..    dprintf
0a30: 28 22 54 6c 73 43 6c 6f 73 65 32 50 72 6f 63 28  ("TlsClose2Proc(
0a40: 25 70 29 22 2c 20 73 74 61 74 65 50 74 72 29 3b  %p)", statePtr);
0a50: 0a 0a 20 20 20 20 69 66 20 28 28 66 6c 61 67 73  ..    if ((flags
0a60: 26 28 54 43 4c 5f 43 4c 4f 53 45 5f 52 45 41 44  &(TCL_CLOSE_READ
0a70: 7c 54 43 4c 5f 43 4c 4f 53 45 5f 57 52 49 54 45  |TCL_CLOSE_WRITE
0a80: 29 29 29 20 7b 0a 09 72 65 74 75 72 6e 20 45 49  ))) {..return EI
0a90: 4e 56 41 4c 3b 0a 20 20 20 20 7d 0a 20 20 20 20  NVAL;.    }.    
0aa0: 54 6c 73 5f 43 6c 65 61 6e 28 73 74 61 74 65 50  Tls_Clean(stateP
0ab0: 74 72 29 3b 0a 20 20 20 20 54 63 6c 5f 45 76 65  tr);.    Tcl_Eve
0ac0: 6e 74 75 61 6c 6c 79 46 72 65 65 28 73 74 61 74  ntuallyFree(stat
0ad0: 65 50 74 72 2c 20 54 6c 73 5f 46 72 65 65 29 3b  ePtr, Tls_Free);
0ae0: 0a 20 20 20 20 72 65 74 75 72 6e 20 54 43 4c 5f  .    return TCL_
0af0: 4f 4b 3b 0a 7d 0a 0a 2f 2a 0a 20 2a 2d 2d 2d 2d  OK;.}../*. *----
0b00: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0b10: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0b20: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0b30: 2d 2d 2a 0a 20 2a 0a 20 2a 20 54 6c 73 5f 57 61  --*. *. * Tls_Wa
0b40: 69 74 46 6f 72 43 6f 6e 6e 65 63 74 20 2d 2d 0a  itForConnect --.
0b50: 20 2a 0a 20 2a 20 52 65 73 75 6c 74 3a 0a 20 2a   *. * Result:. *
0b60: 20 20 20 20 30 20 69 66 20 73 75 63 63 65 73 73      0 if success
0b70: 66 75 6c 2c 20 2d 31 20 69 66 20 66 61 69 6c 65  ful, -1 if faile
0b80: 64 2e 0a 20 2a 0a 20 2a 20 53 69 64 65 20 65 66  d.. *. * Side ef
0b90: 66 65 63 74 73 3a 0a 20 2a 20 20 20 20 49 73 73  fects:. *    Iss
0ba0: 75 65 73 20 53 53 4c 5f 61 63 63 65 70 74 20 6f  ues SSL_accept o
0bb0: 72 20 53 53 4c 5f 63 6f 6e 6e 65 63 74 0a 20 2a  r SSL_connect. *
0bc0: 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  . *-------------
0bd0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0be0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0bf0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2a 0a 20 2a 2f 0a 69  ---------*. */.i
0c00: 6e 74 20 54 6c 73 5f 57 61 69 74 46 6f 72 43 6f  nt Tls_WaitForCo
0c10: 6e 6e 65 63 74 28 53 74 61 74 65 20 2a 73 74 61  nnect(State *sta
0c20: 74 65 50 74 72 2c 20 69 6e 74 20 2a 65 72 72 6f  tePtr, int *erro
0c30: 72 43 6f 64 65 50 74 72 2c 20 69 6e 74 20 68 61  rCodePtr, int ha
0c40: 6e 64 73 68 61 6b 65 46 61 69 6c 75 72 65 49 73  ndshakeFailureIs
0c50: 50 65 72 6d 61 6e 65 6e 74 29 20 7b 0a 20 20 20  Permanent) {.   
0c60: 20 75 6e 73 69 67 6e 65 64 20 6c 6f 6e 67 20 62   unsigned long b
0c70: 61 63 6b 69 6e 67 45 72 72 6f 72 3b 0a 20 20 20  ackingError;.   
0c80: 20 69 6e 74 20 65 72 72 2c 20 72 63 3b 0a 20 20   int err, rc;.  
0c90: 20 20 69 6e 74 20 62 69 6f 53 68 6f 75 6c 64 52    int bioShouldR
0ca0: 65 74 72 79 3b 0a 20 20 20 20 2a 65 72 72 6f 72  etry;.    *error
0cb0: 43 6f 64 65 50 74 72 20 3d 20 30 3b 0a 0a 20 20  CodePtr = 0;..  
0cc0: 20 20 64 70 72 69 6e 74 66 28 22 57 61 69 74 46    dprintf("WaitF
0cd0: 6f 72 43 6f 6e 6e 65 63 74 28 25 70 29 22 2c 20  orConnect(%p)", 
0ce0: 73 74 61 74 65 50 74 72 29 3b 0a 20 20 20 20 64  statePtr);.    d
0cf0: 70 72 69 6e 74 46 6c 61 67 73 28 73 74 61 74 65  printFlags(state
0d00: 50 74 72 29 3b 0a 0a 20 20 20 20 69 66 20 28 21  Ptr);..    if (!
0d10: 28 73 74 61 74 65 50 74 72 2d 3e 66 6c 61 67 73  (statePtr->flags
0d20: 20 26 20 54 4c 53 5f 54 43 4c 5f 49 4e 49 54 29   & TLS_TCL_INIT)
0d30: 29 20 7b 0a 09 64 70 72 69 6e 74 66 28 22 54 6c  ) {..dprintf("Tl
0d40: 73 5f 57 61 69 74 46 6f 72 43 6f 6e 6e 65 63 74  s_WaitForConnect
0d50: 20 63 61 6c 6c 65 64 20 6f 6e 20 61 6c 72 65 61   called on alrea
0d60: 64 79 20 69 6e 69 74 69 61 6c 69 7a 65 64 20 63  dy initialized c
0d70: 68 61 6e 6e 65 6c 20 2d 2d 20 72 65 74 75 72 6e  hannel -- return
0d80: 69 6e 67 20 77 69 74 68 20 69 6d 6d 65 64 69 61  ing with immedia
0d90: 74 65 20 73 75 63 63 65 73 73 22 29 3b 0a 09 72  te success");..r
0da0: 65 74 75 72 6e 20 30 3b 0a 20 20 20 20 7d 0a 0a  eturn 0;.    }..
0db0: 20 20 20 20 69 66 20 28 73 74 61 74 65 50 74 72      if (statePtr
0dc0: 2d 3e 66 6c 61 67 73 20 26 20 54 4c 53 5f 54 43  ->flags & TLS_TC
0dd0: 4c 5f 48 41 4e 44 53 48 41 4b 45 5f 46 41 49 4c  L_HANDSHAKE_FAIL
0de0: 45 44 29 20 7b 0a 09 2f 2a 0a 09 20 2a 20 44 69  ED) {../*.. * Di
0df0: 66 66 65 72 65 6e 74 20 74 79 70 65 73 20 6f 66  fferent types of
0e00: 20 6f 70 65 72 61 74 69 6f 6e 73 20 68 61 76 65   operations have
0e10: 20 64 69 66 66 65 72 65 6e 74 20 72 65 71 75 69   different requi
0e20: 72 65 6d 65 6e 74 73 0a 09 20 2a 20 53 53 4c 20  rements.. * SSL 
0e30: 62 65 69 6e 67 20 65 73 74 61 62 6c 69 73 68 65  being establishe
0e40: 64 0a 09 20 2a 2f 0a 09 69 66 20 28 68 61 6e 64  d.. */..if (hand
0e50: 73 68 61 6b 65 46 61 69 6c 75 72 65 49 73 50 65  shakeFailureIsPe
0e60: 72 6d 61 6e 65 6e 74 29 20 7b 0a 09 20 20 20 20  rmanent) {..    
0e70: 64 70 72 69 6e 74 66 28 22 41 73 6b 65 64 20 74  dprintf("Asked t
0e80: 6f 20 77 61 69 74 20 66 6f 72 20 61 20 54 4c 53  o wait for a TLS
0e90: 20 68 61 6e 64 73 68 61 6b 65 20 74 68 61 74 20   handshake that 
0ea0: 68 61 73 20 61 6c 72 65 61 64 79 20 66 61 69 6c  has already fail
0eb0: 65 64 2e 20 20 52 65 74 75 72 6e 69 6e 67 20 66  ed.  Returning f
0ec0: 61 74 61 6c 20 65 72 72 6f 72 22 29 3b 0a 09 20  atal error");.. 
0ed0: 20 20 20 2a 65 72 72 6f 72 43 6f 64 65 50 74 72     *errorCodePtr
0ee0: 20 3d 20 45 43 4f 4e 4e 41 42 4f 52 54 45 44 3b   = ECONNABORTED;
0ef0: 0a 09 7d 20 65 6c 73 65 20 7b 0a 09 20 20 20 20  ..} else {..    
0f00: 64 70 72 69 6e 74 66 28 22 41 73 6b 65 64 20 74  dprintf("Asked t
0f10: 6f 20 77 61 69 74 20 66 6f 72 20 61 20 54 4c 53  o wait for a TLS
0f20: 20 68 61 6e 64 73 68 61 6b 65 20 74 68 61 74 20   handshake that 
0f30: 68 61 73 20 61 6c 72 65 61 64 79 20 66 61 69 6c  has already fail
0f40: 65 64 2e 20 20 52 65 74 75 72 6e 69 6e 67 20 73  ed.  Returning s
0f50: 6f 66 74 20 65 72 72 6f 72 22 29 3b 0a 09 20 20  oft error");..  
0f60: 20 20 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 20    *errorCodePtr 
0f70: 3d 20 45 43 4f 4e 4e 52 45 53 45 54 3b 0a 09 7d  = ECONNRESET;..}
0f80: 0a 09 54 6c 73 5f 45 72 72 6f 72 28 73 74 61 74  ..Tls_Error(stat
0f90: 65 50 74 72 2c 20 22 57 61 69 74 20 66 6f 72 20  ePtr, "Wait for 
0fa0: 66 61 69 6c 65 64 20 68 61 6e 64 73 68 61 6b 65  failed handshake
0fb0: 22 29 3b 0a 09 72 65 74 75 72 6e 20 2d 31 3b 0a  ");..return -1;.
0fc0: 20 20 20 20 7d 0a 0a 20 20 20 20 66 6f 72 20 28      }..    for (
0fd0: 3b 3b 29 20 7b 0a 09 45 52 52 5f 63 6c 65 61 72  ;;) {..ERR_clear
0fe0: 5f 65 72 72 6f 72 28 29 3b 0a 0a 09 2f 2a 20 4e  _error();.../* N
0ff0: 6f 74 20 69 6e 69 74 69 61 6c 69 7a 65 64 20 79  ot initialized y
1000: 65 74 21 20 41 6c 73 6f 20 63 61 6c 6c 73 20 53  et! Also calls S
1010: 53 4c 5f 64 6f 5f 68 61 6e 64 73 68 61 6b 65 2e  SL_do_handshake.
1020: 20 2a 2f 0a 09 69 66 20 28 73 74 61 74 65 50 74   */..if (statePt
1030: 72 2d 3e 66 6c 61 67 73 20 26 20 54 4c 53 5f 54  r->flags & TLS_T
1040: 43 4c 5f 53 45 52 56 45 52 29 20 7b 0a 09 20 20  CL_SERVER) {..  
1050: 20 20 64 70 72 69 6e 74 66 28 22 43 61 6c 6c 69    dprintf("Calli
1060: 6e 67 20 53 53 4c 5f 61 63 63 65 70 74 28 29 22  ng SSL_accept()"
1070: 29 3b 0a 09 20 20 20 20 65 72 72 20 3d 20 53 53  );..    err = SS
1080: 4c 5f 61 63 63 65 70 74 28 73 74 61 74 65 50 74  L_accept(statePt
1090: 72 2d 3e 73 73 6c 29 3b 0a 0a 09 7d 20 65 6c 73  r->ssl);...} els
10a0: 65 20 7b 0a 09 20 20 20 20 64 70 72 69 6e 74 66  e {..    dprintf
10b0: 28 22 43 61 6c 6c 69 6e 67 20 53 53 4c 5f 63 6f  ("Calling SSL_co
10c0: 6e 6e 65 63 74 28 29 22 29 3b 0a 09 20 20 20 20  nnect()");..    
10d0: 65 72 72 20 3d 20 53 53 4c 5f 63 6f 6e 6e 65 63  err = SSL_connec
10e0: 74 28 73 74 61 74 65 50 74 72 2d 3e 73 73 6c 29  t(statePtr->ssl)
10f0: 3b 0a 09 7d 0a 0a 09 69 66 20 28 65 72 72 20 3e  ;..}...if (err >
1100: 20 30 29 20 7b 0a 09 20 20 20 20 64 70 72 69 6e   0) {..    dprin
1110: 74 66 28 22 41 63 63 65 70 74 20 6f 72 20 63 6f  tf("Accept or co
1120: 6e 6e 65 63 74 20 77 61 73 20 73 75 63 63 65 73  nnect was succes
1130: 73 66 75 6c 22 29 3b 0a 0a 09 20 20 20 20 65 72  sful");...    er
1140: 72 20 3d 20 42 49 4f 5f 66 6c 75 73 68 28 73 74  r = BIO_flush(st
1150: 61 74 65 50 74 72 2d 3e 62 69 6f 29 3b 0a 09 20  atePtr->bio);.. 
1160: 20 20 20 69 66 20 28 65 72 72 20 3c 3d 20 30 29     if (err <= 0)
1170: 20 7b 0a 09 09 64 70 72 69 6e 74 66 28 22 46 6c   {...dprintf("Fl
1180: 75 73 68 69 6e 67 20 74 68 65 20 6c 6f 77 65 72  ushing the lower
1190: 20 6c 61 79 65 72 73 20 66 61 69 6c 65 64 2c 20   layers failed, 
11a0: 74 68 69 73 20 77 69 6c 6c 20 70 72 6f 62 61 62  this will probab
11b0: 6c 79 20 74 65 72 6d 69 6e 61 74 65 20 74 68 69  ly terminate thi
11c0: 73 20 73 65 73 73 69 6f 6e 22 29 3b 0a 09 20 20  s session");..  
11d0: 20 20 7d 0a 09 7d 20 65 6c 73 65 20 7b 0a 09 20    }..} else {.. 
11e0: 20 20 20 64 70 72 69 6e 74 66 28 22 41 63 63 65     dprintf("Acce
11f0: 70 74 20 6f 72 20 63 6f 6e 6e 65 63 74 20 66 61  pt or connect fa
1200: 69 6c 65 64 22 29 3b 0a 09 7d 0a 0a 09 72 63 20  iled");..}...rc 
1210: 3d 20 53 53 4c 5f 67 65 74 5f 65 72 72 6f 72 28  = SSL_get_error(
1220: 73 74 61 74 65 50 74 72 2d 3e 73 73 6c 2c 20 65  statePtr->ssl, e
1230: 72 72 29 3b 0a 09 62 61 63 6b 69 6e 67 45 72 72  rr);..backingErr
1240: 6f 72 20 3d 20 45 52 52 5f 67 65 74 5f 65 72 72  or = ERR_get_err
1250: 6f 72 28 29 3b 0a 09 69 66 20 28 72 63 20 21 3d  or();..if (rc !=
1260: 20 53 53 4c 5f 45 52 52 4f 52 5f 4e 4f 4e 45 29   SSL_ERROR_NONE)
1270: 20 7b 0a 09 20 20 20 20 64 70 72 69 6e 74 66 28   {..    dprintf(
1280: 22 47 6f 74 20 65 72 72 6f 72 3a 20 25 69 20 28  "Got error: %i (
1290: 72 63 20 3d 20 25 69 29 22 2c 20 65 72 72 2c 20  rc = %i)", err, 
12a0: 72 63 29 3b 0a 09 20 20 20 20 64 70 72 69 6e 74  rc);..    dprint
12b0: 66 28 22 47 6f 74 20 65 72 72 6f 72 3a 20 25 73  f("Got error: %s
12c0: 22 2c 20 45 52 52 5f 72 65 61 73 6f 6e 5f 65 72  ", ERR_reason_er
12d0: 72 6f 72 5f 73 74 72 69 6e 67 28 62 61 63 6b 69  ror_string(backi
12e0: 6e 67 45 72 72 6f 72 29 29 3b 0a 09 7d 0a 0a 09  ngError));..}...
12f0: 62 69 6f 53 68 6f 75 6c 64 52 65 74 72 79 20 3d  bioShouldRetry =
1300: 20 30 3b 0a 09 69 66 20 28 65 72 72 20 3c 3d 20   0;..if (err <= 
1310: 30 29 20 7b 0a 09 20 20 20 20 69 66 20 28 72 63  0) {..    if (rc
1320: 20 3d 3d 20 53 53 4c 5f 45 52 52 4f 52 5f 57 41   == SSL_ERROR_WA
1330: 4e 54 5f 43 4f 4e 4e 45 43 54 20 7c 7c 20 72 63  NT_CONNECT || rc
1340: 20 3d 3d 20 53 53 4c 5f 45 52 52 4f 52 5f 57 41   == SSL_ERROR_WA
1350: 4e 54 5f 41 43 43 45 50 54 20 7c 7c 20 72 63 20  NT_ACCEPT || rc 
1360: 3d 3d 20 53 53 4c 5f 45 52 52 4f 52 5f 57 41 4e  == SSL_ERROR_WAN
1370: 54 5f 52 45 41 44 20 7c 7c 20 72 63 20 3d 3d 20  T_READ || rc == 
1380: 53 53 4c 5f 45 52 52 4f 52 5f 57 41 4e 54 5f 57  SSL_ERROR_WANT_W
1390: 52 49 54 45 29 20 7b 0a 09 09 62 69 6f 53 68 6f  RITE) {...bioSho
13a0: 75 6c 64 52 65 74 72 79 20 3d 20 31 3b 0a 09 20  uldRetry = 1;.. 
13b0: 20 20 20 7d 20 65 6c 73 65 20 69 66 20 28 42 49     } else if (BI
13c0: 4f 5f 73 68 6f 75 6c 64 5f 72 65 74 72 79 28 73  O_should_retry(s
13d0: 74 61 74 65 50 74 72 2d 3e 62 69 6f 29 29 20 7b  tatePtr->bio)) {
13e0: 0a 09 09 62 69 6f 53 68 6f 75 6c 64 52 65 74 72  ...bioShouldRetr
13f0: 79 20 3d 20 31 3b 0a 09 20 20 20 20 7d 20 65 6c  y = 1;..    } el
1400: 73 65 20 69 66 20 28 72 63 20 3d 3d 20 53 53 4c  se if (rc == SSL
1410: 5f 45 52 52 4f 52 5f 53 59 53 43 41 4c 4c 20 26  _ERROR_SYSCALL &
1420: 26 20 54 63 6c 5f 47 65 74 45 72 72 6e 6f 28 29  & Tcl_GetErrno()
1430: 20 3d 3d 20 45 41 47 41 49 4e 29 20 7b 0a 09 09   == EAGAIN) {...
1440: 62 69 6f 53 68 6f 75 6c 64 52 65 74 72 79 20 3d  bioShouldRetry =
1450: 20 31 3b 0a 09 20 20 20 20 7d 0a 09 7d 20 65 6c   1;..    }..} el
1460: 73 65 20 7b 0a 09 20 20 20 20 69 66 20 28 21 53  se {..    if (!S
1470: 53 4c 5f 69 73 5f 69 6e 69 74 5f 66 69 6e 69 73  SL_is_init_finis
1480: 68 65 64 28 73 74 61 74 65 50 74 72 2d 3e 73 73  hed(statePtr->ss
1490: 6c 29 29 20 7b 0a 09 09 62 69 6f 53 68 6f 75 6c  l)) {...bioShoul
14a0: 64 52 65 74 72 79 20 3d 20 31 3b 0a 09 20 20 20  dRetry = 1;..   
14b0: 20 7d 0a 09 7d 0a 0a 09 69 66 20 28 62 69 6f 53   }..}...if (bioS
14c0: 68 6f 75 6c 64 52 65 74 72 79 29 20 7b 0a 09 20  houldRetry) {.. 
14d0: 20 20 20 64 70 72 69 6e 74 66 28 22 54 68 65 20     dprintf("The 
14e0: 49 2f 4f 20 64 69 64 20 6e 6f 74 20 63 6f 6d 70  I/O did not comp
14f0: 6c 65 74 65 20 2d 2d 20 62 75 74 20 77 65 20 73  lete -- but we s
1500: 68 6f 75 6c 64 20 74 72 79 20 69 74 20 61 67 61  hould try it aga
1510: 69 6e 22 29 3b 0a 0a 09 20 20 20 20 69 66 20 28  in");...    if (
1520: 73 74 61 74 65 50 74 72 2d 3e 66 6c 61 67 73 20  statePtr->flags 
1530: 26 20 54 4c 53 5f 54 43 4c 5f 41 53 59 4e 43 29  & TLS_TCL_ASYNC)
1540: 20 7b 0a 09 09 64 70 72 69 6e 74 66 28 22 52 65   {...dprintf("Re
1550: 74 75 72 6e 69 6e 67 20 45 41 47 41 49 4e 20 73  turning EAGAIN s
1560: 6f 20 74 68 61 74 20 69 74 20 63 61 6e 20 62 65  o that it can be
1570: 20 72 65 74 72 69 65 64 20 6c 61 74 65 72 22 29   retried later")
1580: 3b 0a 09 09 2a 65 72 72 6f 72 43 6f 64 65 50 74  ;...*errorCodePt
1590: 72 20 3d 20 45 41 47 41 49 4e 3b 0a 09 09 54 6c  r = EAGAIN;...Tl
15a0: 73 5f 45 72 72 6f 72 28 73 74 61 74 65 50 74 72  s_Error(statePtr
15b0: 2c 20 22 48 61 6e 64 73 68 61 6b 65 20 6e 6f 74  , "Handshake not
15c0: 20 63 6f 6d 70 6c 65 74 65 2c 20 77 69 6c 6c 20   complete, will 
15d0: 72 65 74 72 79 20 6c 61 74 65 72 22 29 3b 0a 09  retry later");..
15e0: 09 72 65 74 75 72 6e 20 2d 31 3b 0a 09 20 20 20  .return -1;..   
15f0: 20 7d 20 65 6c 73 65 20 7b 0a 09 09 64 70 72 69   } else {...dpri
1600: 6e 74 66 28 22 44 6f 69 6e 67 20 73 6f 20 6e 6f  ntf("Doing so no
1610: 77 22 29 3b 0a 09 09 63 6f 6e 74 69 6e 75 65 3b  w");...continue;
1620: 0a 09 20 20 20 20 7d 0a 09 7d 0a 0a 09 64 70 72  ..    }..}...dpr
1630: 69 6e 74 66 28 22 57 65 20 68 61 76 65 20 65 69  intf("We have ei
1640: 74 68 65 72 20 63 6f 6d 70 6c 65 74 65 6c 79 20  ther completely 
1650: 65 73 74 61 62 6c 69 73 68 65 64 20 74 68 65 20  established the 
1660: 73 65 73 73 69 6f 6e 20 6f 72 20 63 6f 6d 70 6c  session or compl
1670: 65 74 65 6c 79 20 66 61 69 6c 65 64 20 69 74 20  etely failed it 
1680: 2d 2d 20 74 68 65 72 65 20 69 73 20 6e 6f 20 6d  -- there is no m
1690: 6f 72 65 20 6e 65 65 64 20 74 6f 20 65 76 65 72  ore need to ever
16a0: 20 72 65 74 72 79 20 69 74 20 74 68 6f 75 67 68   retry it though
16b0: 22 29 3b 0a 09 62 72 65 61 6b 3b 0a 20 20 20 20  ");..break;.    
16c0: 7d 0a 0a 20 20 20 20 73 77 69 74 63 68 20 28 72  }..    switch (r
16d0: 63 29 20 7b 0a 09 63 61 73 65 20 53 53 4c 5f 45  c) {..case SSL_E
16e0: 52 52 4f 52 5f 4e 4f 4e 45 3a 0a 09 20 20 20 20  RROR_NONE:..    
16f0: 2f 2a 20 54 68 65 20 54 4c 53 2f 53 53 4c 20 49  /* The TLS/SSL I
1700: 2f 4f 20 6f 70 65 72 61 74 69 6f 6e 20 63 6f 6d  /O operation com
1710: 70 6c 65 74 65 64 20 2a 2f 0a 09 20 20 20 20 64  pleted */..    d
1720: 70 72 69 6e 74 66 28 22 54 68 65 20 63 6f 6e 6e  printf("The conn
1730: 65 63 74 69 6f 6e 20 69 73 20 67 6f 6f 64 22 29  ection is good")
1740: 3b 0a 09 20 20 20 20 2a 65 72 72 6f 72 43 6f 64  ;..    *errorCod
1750: 65 50 74 72 20 3d 20 30 3b 0a 09 20 20 20 20 62  ePtr = 0;..    b
1760: 72 65 61 6b 3b 0a 0a 09 63 61 73 65 20 53 53 4c  reak;...case SSL
1770: 5f 45 52 52 4f 52 5f 5a 45 52 4f 5f 52 45 54 55  _ERROR_ZERO_RETU
1780: 52 4e 3a 0a 09 20 20 20 20 2f 2a 20 54 68 65 20  RN:..    /* The 
1790: 54 4c 53 2f 53 53 4c 20 70 65 65 72 20 68 61 73  TLS/SSL peer has
17a0: 20 63 6c 6f 73 65 64 20 74 68 65 20 63 6f 6e 6e   closed the conn
17b0: 65 63 74 69 6f 6e 20 66 6f 72 20 77 72 69 74 69  ection for writi
17c0: 6e 67 20 62 79 20 73 65 6e 64 69 6e 67 20 74 68  ng by sending th
17d0: 65 20 63 6c 6f 73 65 5f 6e 6f 74 69 66 79 20 61  e close_notify a
17e0: 6c 65 72 74 20 2a 2f 0a 09 20 20 20 20 64 70 72  lert */..    dpr
17f0: 69 6e 74 66 28 22 53 53 4c 5f 45 52 52 4f 52 5f  intf("SSL_ERROR_
1800: 5a 45 52 4f 5f 52 45 54 55 52 4e 3a 20 43 6f 6e  ZERO_RETURN: Con
1810: 6e 65 63 74 20 72 65 74 75 72 6e 65 64 20 61 6e  nect returned an
1820: 20 69 6e 76 61 6c 69 64 20 76 61 6c 75 65 2e 2e   invalid value..
1830: 2e 22 29 3b 0a 09 20 20 20 20 2a 65 72 72 6f 72  .");..    *error
1840: 43 6f 64 65 50 74 72 20 3d 20 45 49 4e 56 41 4c  CodePtr = EINVAL
1850: 3b 0a 09 20 20 20 20 54 6c 73 5f 45 72 72 6f 72  ;..    Tls_Error
1860: 28 73 74 61 74 65 50 74 72 2c 20 22 50 65 65 72  (statePtr, "Peer
1870: 20 68 61 73 20 63 6c 6f 73 65 64 20 74 68 65 20   has closed the 
1880: 63 6f 6e 6e 65 63 74 69 6f 6e 20 66 6f 72 20 77  connection for w
1890: 72 69 74 69 6e 67 20 62 79 20 73 65 6e 64 69 6e  riting by sendin
18a0: 67 20 74 68 65 20 63 6c 6f 73 65 5f 6e 6f 74 69  g the close_noti
18b0: 66 79 20 61 6c 65 72 74 22 29 3b 0a 09 20 20 20  fy alert");..   
18c0: 20 72 65 74 75 72 6e 20 2d 31 3b 0a 0a 09 63 61   return -1;...ca
18d0: 73 65 20 53 53 4c 5f 45 52 52 4f 52 5f 53 59 53  se SSL_ERROR_SYS
18e0: 43 41 4c 4c 3a 0a 09 20 20 20 20 2f 2a 20 53 6f  CALL:..    /* So
18f0: 6d 65 20 6e 6f 6e 2d 72 65 63 6f 76 65 72 61 62  me non-recoverab
1900: 6c 65 2c 20 66 61 74 61 6c 20 49 2f 4f 20 65 72  le, fatal I/O er
1910: 72 6f 72 20 6f 63 63 75 72 72 65 64 20 2a 2f 0a  ror occurred */.
1920: 09 20 20 20 20 64 70 72 69 6e 74 66 28 22 53 53  .    dprintf("SS
1930: 4c 5f 45 52 52 4f 52 5f 53 59 53 43 41 4c 4c 22  L_ERROR_SYSCALL"
1940: 29 3b 0a 0a 09 20 20 20 20 69 66 20 28 62 61 63  );...    if (bac
1950: 6b 69 6e 67 45 72 72 6f 72 20 3d 3d 20 30 20 26  kingError == 0 &
1960: 26 20 65 72 72 20 3d 3d 20 30 29 20 7b 0a 09 09  & err == 0) {...
1970: 64 70 72 69 6e 74 66 28 22 45 4f 46 20 72 65 61  dprintf("EOF rea
1980: 63 68 65 64 22 29 0a 09 09 2a 65 72 72 6f 72 43  ched")...*errorC
1990: 6f 64 65 50 74 72 20 3d 20 45 43 4f 4e 4e 52 45  odePtr = ECONNRE
19a0: 53 45 54 3b 0a 09 09 54 6c 73 5f 45 72 72 6f 72  SET;...Tls_Error
19b0: 28 73 74 61 74 65 50 74 72 2c 20 22 28 75 6e 65  (statePtr, "(une
19c0: 78 70 65 63 74 65 64 29 20 45 4f 46 20 72 65 61  xpected) EOF rea
19d0: 63 68 65 64 22 29 3b 0a 0a 09 20 20 20 20 7d 20  ched");...    } 
19e0: 65 6c 73 65 20 69 66 20 28 62 61 63 6b 69 6e 67  else if (backing
19f0: 45 72 72 6f 72 20 3d 3d 20 30 20 26 26 20 65 72  Error == 0 && er
1a00: 72 20 3d 3d 20 2d 31 29 20 7b 0a 09 09 64 70 72  r == -1) {...dpr
1a10: 69 6e 74 66 28 22 49 2f 4f 20 65 72 72 6f 72 20  intf("I/O error 
1a20: 6f 63 63 75 72 72 65 64 20 28 65 72 72 6e 6f 20  occurred (errno 
1a30: 3d 20 25 6c 75 29 22 2c 20 28 75 6e 73 69 67 6e  = %lu)", (unsign
1a40: 65 64 20 6c 6f 6e 67 29 20 54 63 6c 5f 47 65 74  ed long) Tcl_Get
1a50: 45 72 72 6e 6f 28 29 29 3b 0a 09 09 2a 65 72 72  Errno());...*err
1a60: 6f 72 43 6f 64 65 50 74 72 20 3d 20 54 63 6c 5f  orCodePtr = Tcl_
1a70: 47 65 74 45 72 72 6e 6f 28 29 3b 0a 09 09 69 66  GetErrno();...if
1a80: 20 28 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 20   (*errorCodePtr 
1a90: 3d 3d 20 45 43 4f 4e 4e 52 45 53 45 54 29 20 7b  == ECONNRESET) {
1aa0: 0a 09 09 20 20 20 20 2a 65 72 72 6f 72 43 6f 64  ...    *errorCod
1ab0: 65 50 74 72 20 3d 20 45 43 4f 4e 4e 41 42 4f 52  ePtr = ECONNABOR
1ac0: 54 45 44 3b 0a 09 09 7d 0a 09 09 54 6c 73 5f 45  TED;...}...Tls_E
1ad0: 72 72 6f 72 28 73 74 61 74 65 50 74 72 2c 20 54  rror(statePtr, T
1ae0: 63 6c 5f 45 72 72 6e 6f 4d 73 67 28 2a 65 72 72  cl_ErrnoMsg(*err
1af0: 6f 72 43 6f 64 65 50 74 72 29 29 3b 0a 0a 09 20  orCodePtr));... 
1b00: 20 20 20 7d 20 65 6c 73 65 20 7b 0a 09 09 64 70     } else {...dp
1b10: 72 69 6e 74 66 28 22 49 2f 4f 20 65 72 72 6f 72  rintf("I/O error
1b20: 20 6f 63 63 75 72 72 65 64 20 28 62 61 63 6b 69   occurred (backi
1b30: 6e 67 45 72 72 6f 72 20 3d 20 25 6c 75 29 22 2c  ngError = %lu)",
1b40: 20 62 61 63 6b 69 6e 67 45 72 72 6f 72 29 3b 0a   backingError);.
1b50: 09 09 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 20  ..*errorCodePtr 
1b60: 3d 20 54 63 6c 5f 47 65 74 45 72 72 6e 6f 28 29  = Tcl_GetErrno()
1b70: 3b 0a 09 09 69 66 20 28 2a 65 72 72 6f 72 43 6f  ;...if (*errorCo
1b80: 64 65 50 74 72 20 3d 3d 20 45 43 4f 4e 4e 52 45  dePtr == ECONNRE
1b90: 53 45 54 29 20 7b 0a 09 09 20 20 20 20 2a 65 72  SET) {...    *er
1ba0: 72 6f 72 43 6f 64 65 50 74 72 20 3d 20 45 43 4f  rorCodePtr = ECO
1bb0: 4e 4e 41 42 4f 52 54 45 44 3b 0a 09 09 7d 0a 09  NNABORTED;...}..
1bc0: 09 54 6c 73 5f 45 72 72 6f 72 28 73 74 61 74 65  .Tls_Error(state
1bd0: 50 74 72 2c 20 45 52 52 5f 72 65 61 73 6f 6e 5f  Ptr, ERR_reason_
1be0: 65 72 72 6f 72 5f 73 74 72 69 6e 67 28 62 61 63  error_string(bac
1bf0: 6b 69 6e 67 45 72 72 6f 72 29 29 3b 0a 09 20 20  kingError));..  
1c00: 20 20 7d 0a 0a 09 20 20 20 20 73 74 61 74 65 50    }...    stateP
1c10: 74 72 2d 3e 66 6c 61 67 73 20 7c 3d 20 54 4c 53  tr->flags |= TLS
1c20: 5f 54 43 4c 5f 48 41 4e 44 53 48 41 4b 45 5f 46  _TCL_HANDSHAKE_F
1c30: 41 49 4c 45 44 3b 0a 09 20 20 20 20 72 65 74 75  AILED;..    retu
1c40: 72 6e 20 2d 31 3b 0a 0a 09 63 61 73 65 20 53 53  rn -1;...case SS
1c50: 4c 5f 45 52 52 4f 52 5f 53 53 4c 3a 0a 09 20 20  L_ERROR_SSL:..  
1c60: 20 20 2f 2a 20 41 20 6e 6f 6e 2d 72 65 63 6f 76    /* A non-recov
1c70: 65 72 61 62 6c 65 2c 20 66 61 74 61 6c 20 65 72  erable, fatal er
1c80: 72 6f 72 20 69 6e 20 74 68 65 20 53 53 4c 20 6c  ror in the SSL l
1c90: 69 62 72 61 72 79 20 6f 63 63 75 72 72 65 64 2c  ibrary occurred,
1ca0: 20 75 73 75 61 6c 6c 79 20 61 20 70 72 6f 74 6f   usually a proto
1cb0: 63 6f 6c 20 65 72 72 6f 72 20 2a 2f 0a 09 20 20  col error */..  
1cc0: 20 20 64 70 72 69 6e 74 66 28 22 53 53 4c 5f 45    dprintf("SSL_E
1cd0: 52 52 4f 52 5f 53 53 4c 3a 20 47 6f 74 20 70 65  RROR_SSL: Got pe
1ce0: 72 6d 61 6e 65 6e 74 20 66 61 74 61 6c 20 53 53  rmanent fatal SS
1cf0: 4c 20 65 72 72 6f 72 2c 20 61 62 6f 72 74 69 6e  L error, abortin
1d00: 67 20 69 6d 6d 65 64 69 61 74 65 6c 79 22 29 3b  g immediately");
1d10: 0a 09 20 20 20 20 69 66 20 28 53 53 4c 5f 67 65  ..    if (SSL_ge
1d20: 74 5f 76 65 72 69 66 79 5f 72 65 73 75 6c 74 28  t_verify_result(
1d30: 73 74 61 74 65 50 74 72 2d 3e 73 73 6c 29 20 21  statePtr->ssl) !
1d40: 3d 20 58 35 30 39 5f 56 5f 4f 4b 29 20 7b 0a 09  = X509_V_OK) {..
1d50: 09 54 6c 73 5f 45 72 72 6f 72 28 73 74 61 74 65  .Tls_Error(state
1d60: 50 74 72 2c 20 58 35 30 39 5f 76 65 72 69 66 79  Ptr, X509_verify
1d70: 5f 63 65 72 74 5f 65 72 72 6f 72 5f 73 74 72 69  _cert_error_stri
1d80: 6e 67 28 53 53 4c 5f 67 65 74 5f 76 65 72 69 66  ng(SSL_get_verif
1d90: 79 5f 72 65 73 75 6c 74 28 73 74 61 74 65 50 74  y_result(statePt
1da0: 72 2d 3e 73 73 6c 29 29 29 3b 0a 09 20 20 20 20  r->ssl)));..    
1db0: 7d 0a 09 20 20 20 20 69 66 20 28 62 61 63 6b 69  }..    if (backi
1dc0: 6e 67 45 72 72 6f 72 20 21 3d 20 30 29 20 7b 0a  ngError != 0) {.
1dd0: 09 09 54 6c 73 5f 45 72 72 6f 72 28 73 74 61 74  ..Tls_Error(stat
1de0: 65 50 74 72 2c 20 45 52 52 5f 72 65 61 73 6f 6e  ePtr, ERR_reason
1df0: 5f 65 72 72 6f 72 5f 73 74 72 69 6e 67 28 62 61  _error_string(ba
1e00: 63 6b 69 6e 67 45 72 72 6f 72 29 29 3b 0a 09 20  ckingError));.. 
1e10: 20 20 20 7d 0a 09 20 20 20 20 73 74 61 74 65 50     }..    stateP
1e20: 74 72 2d 3e 66 6c 61 67 73 20 7c 3d 20 54 4c 53  tr->flags |= TLS
1e30: 5f 54 43 4c 5f 48 41 4e 44 53 48 41 4b 45 5f 46  _TCL_HANDSHAKE_F
1e40: 41 49 4c 45 44 3b 0a 09 20 20 20 20 2a 65 72 72  AILED;..    *err
1e50: 6f 72 43 6f 64 65 50 74 72 20 3d 20 45 43 4f 4e  orCodePtr = ECON
1e60: 4e 41 42 4f 52 54 45 44 3b 0a 09 20 20 20 20 72  NABORTED;..    r
1e70: 65 74 75 72 6e 20 2d 31 3b 0a 09 64 65 66 61 75  eturn -1;..defau
1e80: 6c 74 3a 0a 09 20 20 20 20 2f 2a 20 54 68 65 20  lt:..    /* The 
1e90: 6f 70 65 72 61 74 69 6f 6e 20 64 69 64 20 6e 6f  operation did no
1ea0: 74 20 63 6f 6d 70 6c 65 74 65 20 61 6e 64 20 73  t complete and s
1eb0: 68 6f 75 6c 64 20 62 65 20 72 65 74 72 69 65 64  hould be retried
1ec0: 20 6c 61 74 65 72 2e 20 2a 2f 0a 09 20 20 20 20   later. */..    
1ed0: 64 70 72 69 6e 74 66 28 22 4f 70 65 72 61 74 69  dprintf("Operati
1ee0: 6f 6e 20 64 69 64 20 6e 6f 74 20 63 6f 6d 70 6c  on did not compl
1ef0: 65 74 65 2c 20 63 61 6c 6c 20 66 75 6e 63 74 69  ete, call functi
1f00: 6f 6e 20 61 67 61 69 6e 20 6c 61 74 65 72 3a 20  on again later: 
1f10: 25 69 22 2c 20 72 63 29 3b 0a 09 20 20 20 20 2a  %i", rc);..    *
1f20: 65 72 72 6f 72 43 6f 64 65 50 74 72 20 3d 20 45  errorCodePtr = E
1f30: 41 47 41 49 4e 3b 0a 09 20 20 20 20 64 70 72 69  AGAIN;..    dpri
1f40: 6e 74 66 28 22 45 52 52 28 25 64 2c 20 25 64 29  ntf("ERR(%d, %d)
1f50: 20 22 2c 20 72 63 2c 20 2a 65 72 72 6f 72 43 6f   ", rc, *errorCo
1f60: 64 65 50 74 72 29 3b 0a 09 20 20 20 20 54 6c 73  dePtr);..    Tls
1f70: 5f 45 72 72 6f 72 28 73 74 61 74 65 50 74 72 2c  _Error(statePtr,
1f80: 20 22 4f 70 65 72 61 74 69 6f 6e 20 64 69 64 20   "Operation did 
1f90: 6e 6f 74 20 63 6f 6d 70 6c 65 74 65 2c 20 63 61  not complete, ca
1fa0: 6c 6c 20 66 75 6e 63 74 69 6f 6e 20 61 67 61 69  ll function agai
1fb0: 6e 20 6c 61 74 65 72 22 29 3b 0a 09 20 20 20 20  n later");..    
1fc0: 72 65 74 75 72 6e 20 2d 31 3b 0a 20 20 20 20 7d  return -1;.    }
1fd0: 0a 0a 20 20 20 20 64 70 72 69 6e 74 66 28 22 52  ..    dprintf("R
1fe0: 65 6d 6f 76 69 6e 67 20 74 68 65 20 5c 22 54 4c  emoving the \"TL
1ff0: 53 5f 54 43 4c 5f 49 4e 49 54 5c 22 20 66 6c 61  S_TCL_INIT\" fla
2000: 67 20 73 69 6e 63 65 20 77 65 20 68 61 76 65 20  g since we have 
2010: 63 6f 6d 70 6c 65 74 65 64 20 74 68 65 20 68 61  completed the ha
2020: 6e 64 73 68 61 6b 65 22 29 3b 0a 20 20 20 20 73  ndshake");.    s
2030: 74 61 74 65 50 74 72 2d 3e 66 6c 61 67 73 20 26  tatePtr->flags &
2040: 3d 20 7e 54 4c 53 5f 54 43 4c 5f 49 4e 49 54 3b  = ~TLS_TCL_INIT;
2050: 0a 0a 20 20 20 20 64 70 72 69 6e 74 66 28 22 52  ..    dprintf("R
2060: 65 74 75 72 6e 69 6e 67 20 69 6e 20 73 75 63 63  eturning in succ
2070: 65 73 73 22 29 3b 0a 20 20 20 20 2a 65 72 72 6f  ess");.    *erro
2080: 72 43 6f 64 65 50 74 72 20 3d 20 30 3b 0a 20 20  rCodePtr = 0;.  
2090: 20 20 72 65 74 75 72 6e 20 30 3b 0a 7d 0a 0a 2f    return 0;.}../
20a0: 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  *. *------------
20b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
20c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
20d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
20e0: 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 0a 20 2a 20 54 6c  -------. *. * Tl
20f0: 73 49 6e 70 75 74 50 72 6f 63 20 2d 2d 0a 20 2a  sInputProc --. *
2100: 0a 20 2a 20 20 20 20 54 68 69 73 20 70 72 6f 63  . *    This proc
2110: 65 64 75 72 65 20 69 73 20 69 6e 76 6f 6b 65 64  edure is invoked
2120: 20 62 79 20 74 68 65 20 67 65 6e 65 72 69 63 20   by the generic 
2130: 49 4f 20 6c 65 76 65 6c 0a 20 2a 20 20 20 20 20  IO level. *     
2140: 20 20 74 6f 20 72 65 61 64 20 69 6e 70 75 74 20    to read input 
2150: 66 72 6f 6d 20 61 20 53 53 4c 20 73 6f 63 6b 65  from a SSL socke
2160: 74 20 62 61 73 65 64 20 63 68 61 6e 6e 65 6c 2e  t based channel.
2170: 0a 20 2a 0a 20 2a 20 52 65 73 75 6c 74 73 3a 0a  . *. * Results:.
2180: 20 2a 20 20 20 20 52 65 74 75 72 6e 73 20 74 68   *    Returns th
2190: 65 20 6e 75 6d 62 65 72 20 6f 66 20 62 79 74 65  e number of byte
21a0: 73 20 72 65 61 64 20 6f 72 20 2d 31 20 6f 6e 20  s read or -1 on 
21b0: 65 72 72 6f 72 2e 20 53 65 74 73 20 65 72 72 6f  error. Sets erro
21c0: 72 43 6f 64 65 50 74 72 0a 20 2a 20 20 20 20 74  rCodePtr. *    t
21d0: 6f 20 61 20 50 4f 53 49 58 20 65 72 72 6f 72 20  o a POSIX error 
21e0: 63 6f 64 65 20 69 66 20 61 6e 20 65 72 72 6f 72  code if an error
21f0: 20 6f 63 63 75 72 72 65 64 2c 20 6f 72 20 30 20   occurred, or 0 
2200: 69 66 20 6e 6f 6e 65 2e 0a 20 2a 0a 20 2a 20 53  if none.. *. * S
2210: 69 64 65 20 65 66 66 65 63 74 73 3a 0a 20 2a 20  ide effects:. * 
2220: 20 20 20 52 65 61 64 73 20 69 6e 70 75 74 20 66     Reads input f
2230: 72 6f 6d 20 74 68 65 20 69 6e 70 75 74 20 64 65  rom the input de
2240: 76 69 63 65 20 6f 66 20 74 68 65 20 63 68 61 6e  vice of the chan
2250: 6e 65 6c 2e 0a 20 2a 0a 20 2a 2d 2d 2d 2d 2d 2d  nel.. *. *------
2260: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2270: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2280: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2290: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a  -------------. *
22a0: 2f 0a 0a 73 74 61 74 69 63 20 69 6e 74 20 54 6c  /..static int Tl
22b0: 73 49 6e 70 75 74 50 72 6f 63 28 0a 20 20 20 20  sInputProc(.    
22c0: 76 6f 69 64 20 2a 69 6e 73 74 61 6e 63 65 44 61  void *instanceDa
22d0: 74 61 2c 0a 20 20 20 20 63 68 61 72 20 2a 62 75  ta,.    char *bu
22e0: 66 2c 0a 20 20 20 20 69 6e 74 20 62 75 66 53 69  f,.    int bufSi
22f0: 7a 65 2c 0a 20 20 20 20 69 6e 74 20 2a 65 72 72  ze,.    int *err
2300: 6f 72 43 6f 64 65 50 74 72 29 0a 7b 0a 20 20 20  orCodePtr).{.   
2310: 20 75 6e 73 69 67 6e 65 64 20 6c 6f 6e 67 20 62   unsigned long b
2320: 61 63 6b 69 6e 67 45 72 72 6f 72 3b 0a 20 20 20  ackingError;.   
2330: 20 53 74 61 74 65 20 2a 73 74 61 74 65 50 74 72   State *statePtr
2340: 20 3d 20 28 53 74 61 74 65 20 2a 29 69 6e 73 74   = (State *)inst
2350: 61 6e 63 65 44 61 74 61 3b 0a 20 20 20 20 69 6e  anceData;.    in
2360: 74 20 62 79 74 65 73 52 65 61 64 3b 0a 20 20 20  t bytesRead;.   
2370: 20 69 6e 74 20 74 6c 73 43 6f 6e 6e 65 63 74 3b   int tlsConnect;
2380: 0a 20 20 20 20 69 6e 74 20 65 72 72 3b 0a 0a 20  .    int err;.. 
2390: 20 20 20 2a 65 72 72 6f 72 43 6f 64 65 50 74 72     *errorCodePtr
23a0: 20 3d 20 30 3b 0a 0a 20 20 20 20 64 70 72 69 6e   = 0;..    dprin
23b0: 74 66 28 22 42 49 4f 5f 72 65 61 64 28 25 64 29  tf("BIO_read(%d)
23c0: 22 2c 20 62 75 66 53 69 7a 65 29 3b 0a 0a 20 20  ", bufSize);..  
23d0: 20 20 69 66 20 28 73 74 61 74 65 50 74 72 2d 3e    if (statePtr->
23e0: 66 6c 61 67 73 20 26 20 54 4c 53 5f 54 43 4c 5f  flags & TLS_TCL_
23f0: 43 41 4c 4c 42 41 43 4b 29 20 7b 0a 09 2f 2a 20  CALLBACK) {../* 
2400: 64 6f 6e 27 74 20 70 72 6f 63 65 73 73 20 61 6e  don't process an
2410: 79 20 62 79 74 65 73 20 77 68 69 6c 65 20 76 65  y bytes while ve
2420: 72 69 66 79 20 63 61 6c 6c 62 61 63 6b 20 69 73  rify callback is
2430: 20 72 75 6e 6e 69 6e 67 20 2a 2f 0a 09 64 70 72   running */..dpr
2440: 69 6e 74 66 28 22 43 61 6c 6c 62 61 63 6b 20 69  intf("Callback i
2450: 73 20 72 75 6e 6e 69 6e 67 2c 20 72 65 61 64 69  s running, readi
2460: 6e 67 20 30 20 62 79 74 65 73 22 29 3b 0a 09 72  ng 0 bytes");..r
2470: 65 74 75 72 6e 20 30 3b 0a 20 20 20 20 7d 0a 0a  eturn 0;.    }..
2480: 20 20 20 20 64 70 72 69 6e 74 66 28 22 43 61 6c      dprintf("Cal
2490: 6c 69 6e 67 20 54 6c 73 5f 57 61 69 74 46 6f 72  ling Tls_WaitFor
24a0: 43 6f 6e 6e 65 63 74 22 29 3b 0a 20 20 20 20 74  Connect");.    t
24b0: 6c 73 43 6f 6e 6e 65 63 74 20 3d 20 54 6c 73 5f  lsConnect = Tls_
24c0: 57 61 69 74 46 6f 72 43 6f 6e 6e 65 63 74 28 73  WaitForConnect(s
24d0: 74 61 74 65 50 74 72 2c 20 65 72 72 6f 72 43 6f  tatePtr, errorCo
24e0: 64 65 50 74 72 2c 20 30 29 3b 0a 20 20 20 20 69  dePtr, 0);.    i
24f0: 66 20 28 74 6c 73 43 6f 6e 6e 65 63 74 20 3c 20  f (tlsConnect < 
2500: 30 29 20 7b 0a 09 64 70 72 69 6e 74 66 28 22 47  0) {..dprintf("G
2510: 6f 74 20 61 6e 20 65 72 72 6f 72 20 77 61 69 74  ot an error wait
2520: 69 6e 67 20 74 6f 20 63 6f 6e 6e 65 63 74 20 28  ing to connect (
2530: 74 6c 73 43 6f 6e 6e 65 63 74 20 3d 20 25 69 2c  tlsConnect = %i,
2540: 20 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 20 3d   *errorCodePtr =
2550: 20 25 69 29 22 2c 20 74 6c 73 43 6f 6e 6e 65 63   %i)", tlsConnec
2560: 74 2c 20 2a 65 72 72 6f 72 43 6f 64 65 50 74 72  t, *errorCodePtr
2570: 29 3b 0a 09 54 6c 73 5f 45 72 72 6f 72 28 73 74  );..Tls_Error(st
2580: 61 74 65 50 74 72 2c 20 73 74 72 65 72 72 6f 72  atePtr, strerror
2590: 28 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 29 29  (*errorCodePtr))
25a0: 3b 0a 0a 09 62 79 74 65 73 52 65 61 64 20 3d 20  ;...bytesRead = 
25b0: 2d 31 3b 0a 09 69 66 20 28 2a 65 72 72 6f 72 43  -1;..if (*errorC
25c0: 6f 64 65 50 74 72 20 3d 3d 20 45 43 4f 4e 4e 52  odePtr == ECONNR
25d0: 45 53 45 54 29 20 7b 0a 09 20 20 20 20 64 70 72  ESET) {..    dpr
25e0: 69 6e 74 66 28 22 47 6f 74 20 63 6f 6e 6e 65 63  intf("Got connec
25f0: 74 69 6f 6e 20 72 65 73 65 74 22 29 3b 0a 09 20  tion reset");.. 
2600: 20 20 20 2f 2a 20 53 6f 66 74 20 45 4f 46 20 2a     /* Soft EOF *
2610: 2f 0a 09 20 20 20 20 2a 65 72 72 6f 72 43 6f 64  /..    *errorCod
2620: 65 50 74 72 20 3d 20 30 3b 0a 09 20 20 20 20 62  ePtr = 0;..    b
2630: 79 74 65 73 52 65 61 64 20 3d 20 30 3b 0a 09 7d  ytesRead = 0;..}
2640: 0a 09 72 65 74 75 72 6e 20 62 79 74 65 73 52 65  ..return bytesRe
2650: 61 64 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f  ad;.    }..    /
2660: 2a 0a 20 20 20 20 20 2a 20 57 65 20 6e 65 65 64  *.     * We need
2670: 20 74 6f 20 63 6c 65 61 72 20 74 68 65 20 53 53   to clear the SS
2680: 4c 20 65 72 72 6f 72 20 73 74 61 63 6b 20 6e 6f  L error stack no
2690: 77 20 62 65 63 61 75 73 65 20 77 65 20 73 6f 6d  w because we som
26a0: 65 74 69 6d 65 73 20 72 65 61 63 68 0a 20 20 20  etimes reach.   
26b0: 20 20 2a 20 74 68 69 73 20 66 75 6e 63 74 69 6f    * this functio
26c0: 6e 20 77 69 74 68 20 6c 65 66 74 6f 76 65 72 20  n with leftover 
26d0: 65 72 72 6f 72 73 20 69 6e 20 74 68 65 20 73 74  errors in the st
26e0: 61 63 6b 2e 20 20 49 66 20 42 49 4f 5f 72 65 61  ack.  If BIO_rea
26f0: 64 0a 20 20 20 20 20 2a 20 72 65 74 75 72 6e 73  d.     * returns
2700: 20 2d 31 20 61 6e 64 20 69 6e 74 65 6e 64 73 20   -1 and intends 
2710: 45 41 47 41 49 4e 2c 20 74 68 65 72 65 20 69 73  EAGAIN, there is
2720: 20 61 20 6c 65 66 74 6f 76 65 72 20 65 72 72 6f   a leftover erro
2730: 72 2c 20 69 74 20 77 69 6c 6c 20 62 65 0a 20 20  r, it will be.  
2740: 20 20 20 2a 20 6d 69 73 63 6f 6e 73 74 72 75 65     * misconstrue
2750: 64 20 61 73 20 61 6e 20 65 72 72 6f 72 2c 20 6e  d as an error, n
2760: 6f 74 20 45 41 47 41 49 4e 2e 0a 20 20 20 20 20  ot EAGAIN..     
2770: 2a 0a 20 20 20 20 20 2a 20 41 6c 74 65 72 6e 61  *.     * Alterna
2780: 74 69 76 65 6c 79 2c 20 77 65 20 6d 61 79 20 77  tively, we may w
2790: 61 6e 74 20 74 6f 20 68 61 6e 64 6c 65 20 74 68  ant to handle th
27a0: 65 20 3c 30 20 72 65 74 75 72 6e 20 63 6f 64 65  e <0 return code
27b0: 73 20 66 72 6f 6d 0a 20 20 20 20 20 2a 20 42 49  s from.     * BI
27c0: 4f 5f 72 65 61 64 20 73 70 65 63 69 61 6c 6c 79  O_read specially
27d0: 20 28 61 73 20 61 64 76 69 73 65 64 20 69 6e 20   (as advised in 
27e0: 74 68 65 20 52 53 41 20 64 6f 63 73 29 2e 20 20  the RSA docs).  
27f0: 54 4c 53 27 73 20 6c 6f 77 65 72 20 6c 65 76 65  TLS's lower leve
2800: 6c 20 42 49 4f 0a 20 20 20 20 20 2a 20 66 75 6e  l BIO.     * fun
2810: 63 74 69 6f 6e 73 20 70 6c 61 79 20 77 69 74 68  ctions play with
2820: 20 74 68 65 20 72 65 74 72 79 20 66 6c 61 67 73   the retry flags
2830: 20 74 68 6f 75 67 68 2c 20 61 6e 64 20 74 68 69   though, and thi
2840: 73 20 73 65 65 6d 73 20 74 6f 20 77 6f 72 6b 0a  s seems to work.
2850: 20 20 20 20 20 2a 20 63 6f 72 72 65 63 74 6c 79       * correctly
2860: 2e 20 20 53 69 6d 69 6c 61 72 20 66 69 78 20 69  .  Similar fix i
2870: 6e 20 54 6c 73 4f 75 74 70 75 74 50 72 6f 63 2e  n TlsOutputProc.
2880: 20 2d 20 68 6f 62 62 73 0a 20 20 20 20 20 2a 2f   - hobbs.     */
2890: 0a 20 20 20 20 45 52 52 5f 63 6c 65 61 72 5f 65  .    ERR_clear_e
28a0: 72 72 6f 72 28 29 3b 0a 20 20 20 20 62 79 74 65  rror();.    byte
28b0: 73 52 65 61 64 20 3d 20 42 49 4f 5f 72 65 61 64  sRead = BIO_read
28c0: 28 73 74 61 74 65 50 74 72 2d 3e 62 69 6f 2c 20  (statePtr->bio, 
28d0: 62 75 66 2c 20 62 75 66 53 69 7a 65 29 3b 0a 20  buf, bufSize);. 
28e0: 20 20 20 64 70 72 69 6e 74 66 28 22 42 49 4f 5f     dprintf("BIO_
28f0: 72 65 61 64 20 2d 3e 20 25 64 22 2c 20 62 79 74  read -> %d", byt
2900: 65 73 52 65 61 64 29 3b 0a 0a 20 20 20 20 65 72  esRead);..    er
2910: 72 20 3d 20 53 53 4c 5f 67 65 74 5f 65 72 72 6f  r = SSL_get_erro
2920: 72 28 73 74 61 74 65 50 74 72 2d 3e 73 73 6c 2c  r(statePtr->ssl,
2930: 20 62 79 74 65 73 52 65 61 64 29 3b 0a 20 20 20   bytesRead);.   
2940: 20 62 61 63 6b 69 6e 67 45 72 72 6f 72 20 3d 20   backingError = 
2950: 45 52 52 5f 67 65 74 5f 65 72 72 6f 72 28 29 3b  ERR_get_error();
2960: 0a 0a 23 69 66 20 30 0a 20 20 20 20 69 66 20 28  ..#if 0.    if (
2970: 62 79 74 65 73 52 65 61 64 20 3c 3d 20 30 29 20  bytesRead <= 0) 
2980: 7b 0a 09 69 66 20 28 42 49 4f 5f 73 68 6f 75 6c  {..if (BIO_shoul
2990: 64 5f 72 65 74 72 79 28 73 74 61 74 65 50 74 72  d_retry(statePtr
29a0: 2d 3e 62 69 6f 29 29 20 7b 0a 09 20 20 20 20 64  ->bio)) {..    d
29b0: 70 72 69 6e 74 66 28 22 49 2f 4f 20 66 61 69 6c  printf("I/O fail
29c0: 65 64 2c 20 77 69 6c 6c 20 72 65 74 72 79 20 62  ed, will retry b
29d0: 61 73 65 64 20 6f 6e 20 45 41 47 41 49 4e 22 29  ased on EAGAIN")
29e0: 3b 0a 09 20 20 20 20 2a 65 72 72 6f 72 43 6f 64  ;..    *errorCod
29f0: 65 50 74 72 20 3d 20 45 41 47 41 49 4e 3b 0a 09  ePtr = EAGAIN;..
2a00: 7d 0a 20 20 20 20 7d 0a 23 65 6e 64 69 66 0a 0a  }.    }.#endif..
2a10: 20 20 20 20 73 77 69 74 63 68 20 28 65 72 72 29      switch (err)
2a20: 20 7b 0a 09 63 61 73 65 20 53 53 4c 5f 45 52 52   {..case SSL_ERR
2a30: 4f 52 5f 4e 4f 4e 45 3a 0a 09 20 20 20 20 64 70  OR_NONE:..    dp
2a40: 72 69 6e 74 42 75 66 66 65 72 28 62 75 66 2c 20  rintBuffer(buf, 
2a50: 62 79 74 65 73 52 65 61 64 29 3b 0a 09 20 20 20  bytesRead);..   
2a60: 20 62 72 65 61 6b 3b 0a 0a 09 63 61 73 65 20 53   break;...case S
2a70: 53 4c 5f 45 52 52 4f 52 5f 53 53 4c 3a 0a 09 20  SL_ERROR_SSL:.. 
2a80: 20 20 20 2f 2a 20 41 20 6e 6f 6e 2d 72 65 63 6f     /* A non-reco
2a90: 76 65 72 61 62 6c 65 2c 20 66 61 74 61 6c 20 65  verable, fatal e
2aa0: 72 72 6f 72 20 69 6e 20 74 68 65 20 53 53 4c 20  rror in the SSL 
2ab0: 6c 69 62 72 61 72 79 20 6f 63 63 75 72 72 65 64  library occurred
2ac0: 2c 20 75 73 75 61 6c 6c 79 20 61 20 70 72 6f 74  , usually a prot
2ad0: 6f 63 6f 6c 20 65 72 72 6f 72 20 2a 2f 0a 09 20  ocol error */.. 
2ae0: 20 20 20 64 70 72 69 6e 74 66 28 22 53 53 4c 20     dprintf("SSL 
2af0: 65 72 72 6f 72 2c 20 69 6e 64 69 63 61 74 69 6e  error, indicatin
2b00: 67 20 74 68 61 74 20 74 68 65 20 63 6f 6e 6e 65  g that the conne
2b10: 63 74 69 6f 6e 20 68 61 73 20 62 65 65 6e 20 61  ction has been a
2b20: 62 6f 72 74 65 64 22 29 3b 0a 09 20 20 20 20 69  borted");..    i
2b30: 66 20 28 62 61 63 6b 69 6e 67 45 72 72 6f 72 20  f (backingError 
2b40: 21 3d 20 30 29 20 7b 0a 09 09 54 6c 73 5f 45 72  != 0) {...Tls_Er
2b50: 72 6f 72 28 73 74 61 74 65 50 74 72 2c 20 45 52  ror(statePtr, ER
2b60: 52 5f 72 65 61 73 6f 6e 5f 65 72 72 6f 72 5f 73  R_reason_error_s
2b70: 74 72 69 6e 67 28 62 61 63 6b 69 6e 67 45 72 72  tring(backingErr
2b80: 6f 72 29 29 3b 0a 09 20 20 20 20 7d 20 65 6c 73  or));..    } els
2b90: 65 20 69 66 20 28 53 53 4c 5f 67 65 74 5f 76 65  e if (SSL_get_ve
2ba0: 72 69 66 79 5f 72 65 73 75 6c 74 28 73 74 61 74  rify_result(stat
2bb0: 65 50 74 72 2d 3e 73 73 6c 29 20 21 3d 20 58 35  ePtr->ssl) != X5
2bc0: 30 39 5f 56 5f 4f 4b 29 20 7b 0a 09 09 54 6c 73  09_V_OK) {...Tls
2bd0: 5f 45 72 72 6f 72 28 73 74 61 74 65 50 74 72 2c  _Error(statePtr,
2be0: 20 58 35 30 39 5f 76 65 72 69 66 79 5f 63 65 72   X509_verify_cer
2bf0: 74 5f 65 72 72 6f 72 5f 73 74 72 69 6e 67 28 53  t_error_string(S
2c00: 53 4c 5f 67 65 74 5f 76 65 72 69 66 79 5f 72 65  SL_get_verify_re
2c10: 73 75 6c 74 28 73 74 61 74 65 50 74 72 2d 3e 73  sult(statePtr->s
2c20: 73 6c 29 29 29 3b 0a 09 20 20 20 20 7d 20 65 6c  sl)));..    } el
2c30: 73 65 20 7b 0a 09 09 54 6c 73 5f 45 72 72 6f 72  se {...Tls_Error
2c40: 28 73 74 61 74 65 50 74 72 2c 20 22 55 6e 6b 6e  (statePtr, "Unkn
2c50: 6f 77 6e 20 53 53 4c 20 65 72 72 6f 72 22 29 3b  own SSL error");
2c60: 0a 09 20 20 20 20 7d 0a 09 20 20 20 20 2a 65 72  ..    }..    *er
2c70: 72 6f 72 43 6f 64 65 50 74 72 20 3d 20 45 43 4f  rorCodePtr = ECO
2c80: 4e 4e 41 42 4f 52 54 45 44 3b 0a 09 20 20 20 20  NNABORTED;..    
2c90: 62 79 74 65 73 52 65 61 64 20 3d 20 2d 31 3b 0a  bytesRead = -1;.
2ca0: 0a 23 69 66 20 4f 50 45 4e 53 53 4c 5f 56 45 52  .#if OPENSSL_VER
2cb0: 53 49 4f 4e 5f 4e 55 4d 42 45 52 20 3e 3d 20 30  SION_NUMBER >= 0
2cc0: 78 33 30 30 30 30 30 30 30 4c 0a 09 20 20 20 20  x30000000L..    
2cd0: 2f 2a 20 55 6e 65 78 70 65 63 74 65 64 20 45 4f  /* Unexpected EO
2ce0: 46 20 66 72 6f 6d 20 74 68 65 20 70 65 65 72 20  F from the peer 
2cf0: 66 6f 72 20 4f 70 65 6e 53 53 4c 20 33 2e 30 2b  for OpenSSL 3.0+
2d00: 20 2a 2f 0a 09 20 20 20 20 69 66 20 28 45 52 52   */..    if (ERR
2d10: 5f 47 45 54 5f 52 45 41 53 4f 4e 28 62 61 63 6b  _GET_REASON(back
2d20: 69 6e 67 45 72 72 6f 72 29 20 3d 3d 20 53 53 4c  ingError) == SSL
2d30: 5f 52 5f 55 4e 45 58 50 45 43 54 45 44 5f 45 4f  _R_UNEXPECTED_EO
2d40: 46 5f 57 48 49 4c 45 5f 52 45 41 44 49 4e 47 29  F_WHILE_READING)
2d50: 20 7b 0a 09 09 64 70 72 69 6e 74 66 28 22 28 55   {...dprintf("(U
2d60: 6e 65 78 70 65 63 74 65 64 29 20 45 4f 46 20 72  nexpected) EOF r
2d70: 65 61 63 68 65 64 22 29 0a 09 09 2a 65 72 72 6f  eached")...*erro
2d80: 72 43 6f 64 65 50 74 72 20 3d 20 30 3b 0a 09 09  rCodePtr = 0;...
2d90: 62 79 74 65 73 52 65 61 64 20 3d 20 30 3b 0a 09  bytesRead = 0;..
2da0: 09 54 6c 73 5f 45 72 72 6f 72 28 73 74 61 74 65  .Tls_Error(state
2db0: 50 74 72 2c 20 22 45 4f 46 20 72 65 61 63 68 65  Ptr, "EOF reache
2dc0: 64 22 29 3b 0a 09 20 20 20 20 7d 0a 23 65 6e 64  d");..    }.#end
2dd0: 69 66 0a 09 20 20 20 20 62 72 65 61 6b 3b 0a 0a  if..    break;..
2de0: 09 63 61 73 65 20 53 53 4c 5f 45 52 52 4f 52 5f  .case SSL_ERROR_
2df0: 53 59 53 43 41 4c 4c 3a 0a 09 20 20 20 20 2f 2a  SYSCALL:..    /*
2e00: 20 53 6f 6d 65 20 6e 6f 6e 2d 72 65 63 6f 76 65   Some non-recove
2e10: 72 61 62 6c 65 2c 20 66 61 74 61 6c 20 49 2f 4f  rable, fatal I/O
2e20: 20 65 72 72 6f 72 20 6f 63 63 75 72 72 65 64 20   error occurred 
2e30: 2a 2f 0a 0a 09 20 20 20 20 69 66 20 28 62 61 63  */...    if (bac
2e40: 6b 69 6e 67 45 72 72 6f 72 20 3d 3d 20 30 20 26  kingError == 0 &
2e50: 26 20 62 79 74 65 73 52 65 61 64 20 3d 3d 20 30  & bytesRead == 0
2e60: 29 20 7b 0a 09 09 2f 2a 20 55 6e 65 78 70 65 63  ) {.../* Unexpec
2e70: 74 65 64 20 45 4f 46 20 66 72 6f 6d 20 74 68 65  ted EOF from the
2e80: 20 70 65 65 72 20 66 6f 72 20 4f 70 65 6e 53 53   peer for OpenSS
2e90: 4c 20 31 2e 31 20 2a 2f 0a 09 09 64 70 72 69 6e  L 1.1 */...dprin
2ea0: 74 66 28 22 28 55 6e 65 78 70 65 63 74 65 64 29  tf("(Unexpected)
2eb0: 20 45 4f 46 20 72 65 61 63 68 65 64 22 29 0a 09   EOF reached")..
2ec0: 09 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 20 3d  .*errorCodePtr =
2ed0: 20 30 3b 0a 09 09 62 79 74 65 73 52 65 61 64 20   0;...bytesRead 
2ee0: 3d 20 30 3b 0a 09 09 54 6c 73 5f 45 72 72 6f 72  = 0;...Tls_Error
2ef0: 28 73 74 61 74 65 50 74 72 2c 20 22 45 4f 46 20  (statePtr, "EOF 
2f00: 72 65 61 63 68 65 64 22 29 3b 0a 0a 09 20 20 20  reached");...   
2f10: 20 7d 20 65 6c 73 65 20 69 66 20 28 62 61 63 6b   } else if (back
2f20: 69 6e 67 45 72 72 6f 72 20 3d 3d 20 30 20 26 26  ingError == 0 &&
2f30: 20 62 79 74 65 73 52 65 61 64 20 3d 3d 20 2d 31   bytesRead == -1
2f40: 29 20 7b 0a 09 09 64 70 72 69 6e 74 66 28 22 49  ) {...dprintf("I
2f50: 2f 4f 20 65 72 72 6f 72 20 6f 63 63 75 72 72 65  /O error occurre
2f60: 64 20 28 65 72 72 6e 6f 20 3d 20 25 6c 75 29 22  d (errno = %lu)"
2f70: 2c 20 28 75 6e 73 69 67 6e 65 64 20 6c 6f 6e 67  , (unsigned long
2f80: 29 20 54 63 6c 5f 47 65 74 45 72 72 6e 6f 28 29  ) Tcl_GetErrno()
2f90: 29 3b 0a 09 09 2a 65 72 72 6f 72 43 6f 64 65 50  );...*errorCodeP
2fa0: 74 72 20 3d 20 54 63 6c 5f 47 65 74 45 72 72 6e  tr = Tcl_GetErrn
2fb0: 6f 28 29 3b 0a 09 09 62 79 74 65 73 52 65 61 64  o();...bytesRead
2fc0: 20 3d 20 2d 31 3b 0a 09 09 54 6c 73 5f 45 72 72   = -1;...Tls_Err
2fd0: 6f 72 28 73 74 61 74 65 50 74 72 2c 20 54 63 6c  or(statePtr, Tcl
2fe0: 5f 45 72 72 6e 6f 4d 73 67 28 2a 65 72 72 6f 72  _ErrnoMsg(*error
2ff0: 43 6f 64 65 50 74 72 29 29 3b 0a 0a 09 20 20 20  CodePtr));...   
3000: 20 7d 20 65 6c 73 65 20 7b 0a 09 09 64 70 72 69   } else {...dpri
3010: 6e 74 66 28 22 49 2f 4f 20 65 72 72 6f 72 20 6f  ntf("I/O error o
3020: 63 63 75 72 72 65 64 20 28 62 61 63 6b 69 6e 67  ccurred (backing
3030: 45 72 72 6f 72 20 3d 20 25 6c 75 29 22 2c 20 62  Error = %lu)", b
3040: 61 63 6b 69 6e 67 45 72 72 6f 72 29 3b 0a 09 09  ackingError);...
3050: 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 20 3d 20  *errorCodePtr = 
3060: 54 63 6c 5f 47 65 74 45 72 72 6e 6f 28 29 3b 0a  Tcl_GetErrno();.
3070: 09 09 62 79 74 65 73 52 65 61 64 20 3d 20 2d 31  ..bytesRead = -1
3080: 3b 0a 09 09 54 6c 73 5f 45 72 72 6f 72 28 73 74  ;...Tls_Error(st
3090: 61 74 65 50 74 72 2c 20 45 52 52 5f 72 65 61 73  atePtr, ERR_reas
30a0: 6f 6e 5f 65 72 72 6f 72 5f 73 74 72 69 6e 67 28  on_error_string(
30b0: 62 61 63 6b 69 6e 67 45 72 72 6f 72 29 29 3b 0a  backingError));.
30c0: 09 20 20 20 20 7d 0a 09 20 20 20 20 62 72 65 61  .    }..    brea
30d0: 6b 3b 0a 0a 09 63 61 73 65 20 53 53 4c 5f 45 52  k;...case SSL_ER
30e0: 52 4f 52 5f 5a 45 52 4f 5f 52 45 54 55 52 4e 3a  ROR_ZERO_RETURN:
30f0: 0a 09 20 20 20 20 64 70 72 69 6e 74 66 28 22 47  ..    dprintf("G
3100: 6f 74 20 53 53 4c 5f 45 52 52 4f 52 5f 5a 45 52  ot SSL_ERROR_ZER
3110: 4f 5f 52 45 54 55 52 4e 2c 20 74 68 69 73 20 6d  O_RETURN, this m
3120: 65 61 6e 73 20 61 6e 20 45 4f 46 20 68 61 73 20  eans an EOF has 
3130: 62 65 65 6e 20 72 65 61 63 68 65 64 22 29 3b 0a  been reached");.
3140: 09 20 20 20 20 62 79 74 65 73 52 65 61 64 20 3d  .    bytesRead =
3150: 20 30 3b 0a 09 20 20 20 20 2a 65 72 72 6f 72 43   0;..    *errorC
3160: 6f 64 65 50 74 72 20 3d 20 30 3b 0a 09 20 20 20  odePtr = 0;..   
3170: 20 54 6c 73 5f 45 72 72 6f 72 28 73 74 61 74 65   Tls_Error(state
3180: 50 74 72 2c 20 22 50 65 65 72 20 68 61 73 20 63  Ptr, "Peer has c
3190: 6c 6f 73 65 64 20 74 68 65 20 63 6f 6e 6e 65 63  losed the connec
31a0: 74 69 6f 6e 20 66 6f 72 20 77 72 69 74 69 6e 67  tion for writing
31b0: 20 62 79 20 73 65 6e 64 69 6e 67 20 74 68 65 20   by sending the 
31c0: 63 6c 6f 73 65 5f 6e 6f 74 69 66 79 20 61 6c 65  close_notify ale
31d0: 72 74 22 29 3b 0a 09 20 20 20 20 62 72 65 61 6b  rt");..    break
31e0: 3b 0a 0a 09 63 61 73 65 20 53 53 4c 5f 45 52 52  ;...case SSL_ERR
31f0: 4f 52 5f 57 41 4e 54 5f 52 45 41 44 3a 0a 09 20  OR_WANT_READ:.. 
3200: 20 20 20 64 70 72 69 6e 74 66 28 22 47 6f 74 20     dprintf("Got 
3210: 53 53 4c 5f 45 52 52 4f 52 5f 57 41 4e 54 5f 52  SSL_ERROR_WANT_R
3220: 45 41 44 2c 20 6d 61 70 70 69 6e 67 20 74 68 69  EAD, mapping thi
3230: 73 20 74 6f 20 45 41 47 41 49 4e 22 29 3b 0a 09  s to EAGAIN");..
3240: 20 20 20 20 62 79 74 65 73 52 65 61 64 20 3d 20      bytesRead = 
3250: 2d 31 3b 0a 09 20 20 20 20 2a 65 72 72 6f 72 43  -1;..    *errorC
3260: 6f 64 65 50 74 72 20 3d 20 45 41 47 41 49 4e 3b  odePtr = EAGAIN;
3270: 0a 09 20 20 20 20 54 6c 73 5f 45 72 72 6f 72 28  ..    Tls_Error(
3280: 73 74 61 74 65 50 74 72 2c 20 22 53 53 4c 5f 45  statePtr, "SSL_E
3290: 52 52 4f 52 5f 57 41 4e 54 5f 52 45 41 44 22 29  RROR_WANT_READ")
32a0: 3b 0a 09 20 20 20 20 62 72 65 61 6b 3b 0a 0a 09  ;..    break;...
32b0: 64 65 66 61 75 6c 74 3a 0a 09 20 20 20 20 64 70  default:..    dp
32c0: 72 69 6e 74 66 28 22 55 6e 6b 6e 6f 77 6e 20 65  rintf("Unknown e
32d0: 72 72 6f 72 20 28 65 72 72 20 3d 20 25 69 29 2c  rror (err = %i),
32e0: 20 6d 61 70 70 69 6e 67 20 74 6f 20 45 4f 46 22   mapping to EOF"
32f0: 2c 20 65 72 72 29 3b 0a 09 20 20 20 20 2a 65 72  , err);..    *er
3300: 72 6f 72 43 6f 64 65 50 74 72 20 3d 20 30 3b 0a  rorCodePtr = 0;.
3310: 09 20 20 20 20 62 79 74 65 73 52 65 61 64 20 3d  .    bytesRead =
3320: 20 30 3b 0a 09 20 20 20 20 54 6c 73 5f 45 72 72   0;..    Tls_Err
3330: 6f 72 28 73 74 61 74 65 50 74 72 2c 20 22 55 6e  or(statePtr, "Un
3340: 6b 6e 6f 77 6e 20 65 72 72 6f 72 22 29 3b 0a 09  known error");..
3350: 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d      break;.    }
3360: 0a 0a 20 20 20 20 64 70 72 69 6e 74 66 28 22 49  ..    dprintf("I
3370: 6e 70 75 74 28 25 64 29 20 2d 3e 20 25 64 20 5b  nput(%d) -> %d [
3380: 25 64 5d 22 2c 20 62 75 66 53 69 7a 65 2c 20 62  %d]", bufSize, b
3390: 79 74 65 73 52 65 61 64 2c 20 2a 65 72 72 6f 72  ytesRead, *error
33a0: 43 6f 64 65 50 74 72 29 3b 0a 20 20 20 20 72 65  CodePtr);.    re
33b0: 74 75 72 6e 20 62 79 74 65 73 52 65 61 64 3b 0a  turn bytesRead;.
33c0: 7d 0a 0a 2f 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d  }../*. *--------
33d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
33e0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
33f0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3400: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 0a 20  -----------. *. 
3410: 2a 20 54 6c 73 4f 75 74 70 75 74 50 72 6f 63 20  * TlsOutputProc 
3420: 2d 2d 0a 20 2a 0a 20 2a 20 20 20 20 54 68 69 73  --. *. *    This
3430: 20 70 72 6f 63 65 64 75 72 65 20 69 73 20 69 6e   procedure is in
3440: 76 6f 6b 65 64 20 62 79 20 74 68 65 20 67 65 6e  voked by the gen
3450: 65 72 69 63 20 49 4f 20 6c 65 76 65 6c 0a 20 2a  eric IO level. *
3460: 20 20 20 20 20 20 20 74 6f 20 77 72 69 74 65 20         to write 
3470: 6f 75 74 70 75 74 20 74 6f 20 61 20 53 53 4c 20  output to a SSL 
3480: 73 6f 63 6b 65 74 20 62 61 73 65 64 20 63 68 61  socket based cha
3490: 6e 6e 65 6c 2e 0a 20 2a 0a 20 2a 20 52 65 73 75  nnel.. *. * Resu
34a0: 6c 74 73 3a 0a 20 2a 20 20 20 20 52 65 74 75 72  lts:. *    Retur
34b0: 6e 73 20 74 68 65 20 6e 75 6d 62 65 72 20 6f 66  ns the number of
34c0: 20 62 79 74 65 73 20 77 72 69 74 74 65 6e 20 6f   bytes written o
34d0: 72 20 2d 31 20 6f 6e 20 65 72 72 6f 72 2e 20 53  r -1 on error. S
34e0: 65 74 73 20 65 72 72 6f 72 43 6f 64 65 50 74 72  ets errorCodePtr
34f0: 0a 20 2a 20 20 20 20 74 6f 20 61 20 50 4f 53 49  . *    to a POSI
3500: 58 20 65 72 72 6f 72 20 63 6f 64 65 20 69 66 20  X error code if 
3510: 61 6e 20 65 72 72 6f 72 20 6f 63 63 75 72 72 65  an error occurre
3520: 64 2c 20 6f 72 20 30 20 69 66 20 6e 6f 6e 65 2e  d, or 0 if none.
3530: 0a 20 2a 0a 20 2a 20 53 69 64 65 20 65 66 66 65  . *. * Side effe
3540: 63 74 73 3a 0a 20 2a 20 20 20 20 57 72 69 74 65  cts:. *    Write
3550: 73 20 6f 75 74 70 75 74 20 6f 6e 20 74 68 65 20  s output on the 
3560: 6f 75 74 70 75 74 20 64 65 76 69 63 65 20 6f 66  output device of
3570: 20 74 68 65 20 63 68 61 6e 6e 65 6c 2e 0a 20 2a   the channel.. *
3580: 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  . *-------------
3590: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
35a0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
35b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
35c0: 2d 2d 2d 2d 2d 2d 0a 20 2a 2f 0a 0a 73 74 61 74  ------. */..stat
35d0: 69 63 20 69 6e 74 20 54 6c 73 4f 75 74 70 75 74  ic int TlsOutput
35e0: 50 72 6f 63 28 0a 20 20 20 20 76 6f 69 64 20 2a  Proc(.    void *
35f0: 69 6e 73 74 61 6e 63 65 44 61 74 61 2c 0a 20 20  instanceData,.  
3600: 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 62 75    const char *bu
3610: 66 2c 0a 20 20 20 20 69 6e 74 20 74 6f 57 72 69  f,.    int toWri
3620: 74 65 2c 0a 20 20 20 20 69 6e 74 20 2a 65 72 72  te,.    int *err
3630: 6f 72 43 6f 64 65 50 74 72 29 0a 7b 0a 20 20 20  orCodePtr).{.   
3640: 20 75 6e 73 69 67 6e 65 64 20 6c 6f 6e 67 20 62   unsigned long b
3650: 61 63 6b 69 6e 67 45 72 72 6f 72 3b 0a 20 20 20  ackingError;.   
3660: 20 53 74 61 74 65 20 2a 73 74 61 74 65 50 74 72   State *statePtr
3670: 20 3d 20 28 53 74 61 74 65 20 2a 29 69 6e 73 74   = (State *)inst
3680: 61 6e 63 65 44 61 74 61 3b 0a 20 20 20 20 69 6e  anceData;.    in
3690: 74 20 77 72 69 74 74 65 6e 2c 20 65 72 72 3b 0a  t written, err;.
36a0: 20 20 20 20 69 6e 74 20 74 6c 73 43 6f 6e 6e 65      int tlsConne
36b0: 63 74 3b 0a 0a 20 20 20 20 2a 65 72 72 6f 72 43  ct;..    *errorC
36c0: 6f 64 65 50 74 72 20 3d 20 30 3b 0a 0a 20 20 20  odePtr = 0;..   
36d0: 20 64 70 72 69 6e 74 66 28 22 42 49 4f 5f 77 72   dprintf("BIO_wr
36e0: 69 74 65 28 25 70 2c 20 25 64 29 22 2c 20 28 76  ite(%p, %d)", (v
36f0: 6f 69 64 20 2a 29 20 73 74 61 74 65 50 74 72 2c  oid *) statePtr,
3700: 20 74 6f 57 72 69 74 65 29 3b 0a 20 20 20 20 64   toWrite);.    d
3710: 70 72 69 6e 74 42 75 66 66 65 72 28 62 75 66 2c  printBuffer(buf,
3720: 20 74 6f 57 72 69 74 65 29 3b 0a 0a 20 20 20 20   toWrite);..    
3730: 69 66 20 28 73 74 61 74 65 50 74 72 2d 3e 66 6c  if (statePtr->fl
3740: 61 67 73 20 26 20 54 4c 53 5f 54 43 4c 5f 43 41  ags & TLS_TCL_CA
3750: 4c 4c 42 41 43 4b 29 20 7b 0a 09 64 70 72 69 6e  LLBACK) {..dprin
3760: 74 66 28 22 44 6f 6e 27 74 20 70 72 6f 63 65 73  tf("Don't proces
3770: 73 20 6f 75 74 70 75 74 20 77 68 69 6c 65 20 63  s output while c
3780: 61 6c 6c 62 61 63 6b 73 20 61 72 65 20 72 75 6e  allbacks are run
3790: 6e 69 6e 67 22 29 3b 0a 09 77 72 69 74 74 65 6e  ning");..written
37a0: 20 3d 20 2d 31 3b 0a 09 2a 65 72 72 6f 72 43 6f   = -1;..*errorCo
37b0: 64 65 50 74 72 20 3d 20 45 41 47 41 49 4e 3b 0a  dePtr = EAGAIN;.
37c0: 09 72 65 74 75 72 6e 20 2d 31 3b 0a 20 20 20 20  .return -1;.    
37d0: 7d 0a 0a 20 20 20 20 64 70 72 69 6e 74 66 28 22  }..    dprintf("
37e0: 43 61 6c 6c 69 6e 67 20 54 6c 73 5f 57 61 69 74  Calling Tls_Wait
37f0: 46 6f 72 43 6f 6e 6e 65 63 74 22 29 3b 0a 20 20  ForConnect");.  
3800: 20 20 74 6c 73 43 6f 6e 6e 65 63 74 20 3d 20 54    tlsConnect = T
3810: 6c 73 5f 57 61 69 74 46 6f 72 43 6f 6e 6e 65 63  ls_WaitForConnec
3820: 74 28 73 74 61 74 65 50 74 72 2c 20 65 72 72 6f  t(statePtr, erro
3830: 72 43 6f 64 65 50 74 72 2c 20 31 29 3b 0a 20 20  rCodePtr, 1);.  
3840: 20 20 69 66 20 28 74 6c 73 43 6f 6e 6e 65 63 74    if (tlsConnect
3850: 20 3c 20 30 29 20 7b 0a 09 64 70 72 69 6e 74 66   < 0) {..dprintf
3860: 28 22 47 6f 74 20 61 6e 20 65 72 72 6f 72 20 77  ("Got an error w
3870: 61 69 74 69 6e 67 20 74 6f 20 63 6f 6e 6e 65 63  aiting to connec
3880: 74 20 28 74 6c 73 43 6f 6e 6e 65 63 74 20 3d 20  t (tlsConnect = 
3890: 25 69 2c 20 2a 65 72 72 6f 72 43 6f 64 65 50 74  %i, *errorCodePt
38a0: 72 20 3d 20 25 69 29 22 2c 20 74 6c 73 43 6f 6e  r = %i)", tlsCon
38b0: 6e 65 63 74 2c 20 2a 65 72 72 6f 72 43 6f 64 65  nect, *errorCode
38c0: 50 74 72 29 3b 0a 09 54 6c 73 5f 45 72 72 6f 72  Ptr);..Tls_Error
38d0: 28 73 74 61 74 65 50 74 72 2c 20 73 74 72 65 72  (statePtr, strer
38e0: 72 6f 72 28 2a 65 72 72 6f 72 43 6f 64 65 50 74  ror(*errorCodePt
38f0: 72 29 29 3b 0a 0a 09 77 72 69 74 74 65 6e 20 3d  r));...written =
3900: 20 2d 31 3b 0a 09 69 66 20 28 2a 65 72 72 6f 72   -1;..if (*error
3910: 43 6f 64 65 50 74 72 20 3d 3d 20 45 43 4f 4e 4e  CodePtr == ECONN
3920: 52 45 53 45 54 29 20 7b 0a 09 20 20 20 20 64 70  RESET) {..    dp
3930: 72 69 6e 74 66 28 22 47 6f 74 20 63 6f 6e 6e 65  rintf("Got conne
3940: 63 74 69 6f 6e 20 72 65 73 65 74 22 29 3b 0a 09  ction reset");..
3950: 20 20 20 20 2f 2a 20 53 6f 66 74 20 45 4f 46 20      /* Soft EOF 
3960: 2a 2f 0a 09 20 20 20 20 2a 65 72 72 6f 72 43 6f  */..    *errorCo
3970: 64 65 50 74 72 20 3d 20 30 3b 0a 09 20 20 20 20  dePtr = 0;..    
3980: 77 72 69 74 74 65 6e 20 3d 20 30 3b 0a 09 7d 0a  written = 0;..}.
3990: 09 72 65 74 75 72 6e 20 77 72 69 74 74 65 6e 3b  .return written;
39a0: 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 66 20 28  .    }..    if (
39b0: 74 6f 57 72 69 74 65 20 3d 3d 20 30 29 20 7b 0a  toWrite == 0) {.
39c0: 09 64 70 72 69 6e 74 66 28 22 7a 65 72 6f 2d 77  .dprintf("zero-w
39d0: 72 69 74 65 22 29 3b 0a 09 65 72 72 20 3d 20 42  rite");..err = B
39e0: 49 4f 5f 66 6c 75 73 68 28 73 74 61 74 65 50 74  IO_flush(statePt
39f0: 72 2d 3e 62 69 6f 29 3b 0a 0a 09 69 66 20 28 65  r->bio);...if (e
3a00: 72 72 20 3c 3d 20 30 29 20 7b 0a 09 20 20 20 20  rr <= 0) {..    
3a10: 64 70 72 69 6e 74 66 28 22 46 6c 75 73 68 69 6e  dprintf("Flushin
3a20: 67 20 66 61 69 6c 65 64 22 29 3b 0a 09 20 20 20  g failed");..   
3a30: 20 54 6c 73 5f 45 72 72 6f 72 28 73 74 61 74 65   Tls_Error(state
3a40: 50 74 72 2c 20 22 46 6c 75 73 68 20 66 61 69 6c  Ptr, "Flush fail
3a50: 65 64 22 29 3b 0a 0a 09 20 20 20 20 2a 65 72 72  ed");...    *err
3a60: 6f 72 43 6f 64 65 50 74 72 20 3d 20 45 49 4f 3b  orCodePtr = EIO;
3a70: 0a 09 20 20 20 20 77 72 69 74 74 65 6e 20 3d 20  ..    written = 
3a80: 30 3b 0a 09 20 20 20 20 72 65 74 75 72 6e 20 2d  0;..    return -
3a90: 31 3b 0a 09 7d 0a 0a 09 77 72 69 74 74 65 6e 20  1;..}...written 
3aa0: 3d 20 30 3b 0a 09 2a 65 72 72 6f 72 43 6f 64 65  = 0;..*errorCode
3ab0: 50 74 72 20 3d 20 30 3b 0a 09 72 65 74 75 72 6e  Ptr = 0;..return
3ac0: 20 30 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f   0;.    }..    /
3ad0: 2a 0a 20 20 20 20 20 2a 20 57 65 20 6e 65 65 64  *.     * We need
3ae0: 20 74 6f 20 63 6c 65 61 72 20 74 68 65 20 53 53   to clear the SS
3af0: 4c 20 65 72 72 6f 72 20 73 74 61 63 6b 20 6e 6f  L error stack no
3b00: 77 20 62 65 63 61 75 73 65 20 77 65 20 73 6f 6d  w because we som
3b10: 65 74 69 6d 65 73 20 72 65 61 63 68 0a 20 20 20  etimes reach.   
3b20: 20 20 2a 20 74 68 69 73 20 66 75 6e 63 74 69 6f    * this functio
3b30: 6e 20 77 69 74 68 20 6c 65 66 74 6f 76 65 72 20  n with leftover 
3b40: 65 72 72 6f 72 73 20 69 6e 20 74 68 65 20 73 74  errors in the st
3b50: 61 63 6b 2e 20 20 49 66 20 42 49 4f 5f 77 72 69  ack.  If BIO_wri
3b60: 74 65 0a 20 20 20 20 20 2a 20 72 65 74 75 72 6e  te.     * return
3b70: 73 20 2d 31 20 61 6e 64 20 69 6e 74 65 6e 64 73  s -1 and intends
3b80: 20 45 41 47 41 49 4e 2c 20 74 68 65 72 65 20 69   EAGAIN, there i
3b90: 73 20 61 20 6c 65 66 74 6f 76 65 72 20 65 72 72  s a leftover err
3ba0: 6f 72 2c 20 69 74 20 77 69 6c 6c 20 62 65 0a 20  or, it will be. 
3bb0: 20 20 20 20 2a 20 6d 69 73 63 6f 6e 73 74 72 75      * misconstru
3bc0: 65 64 20 61 73 20 61 6e 20 65 72 72 6f 72 2c 20  ed as an error, 
3bd0: 6e 6f 74 20 45 41 47 41 49 4e 2e 0a 20 20 20 20  not EAGAIN..    
3be0: 20 2a 0a 20 20 20 20 20 2a 20 41 6c 74 65 72 6e   *.     * Altern
3bf0: 61 74 69 76 65 6c 79 2c 20 77 65 20 6d 61 79 20  atively, we may 
3c00: 77 61 6e 74 20 74 6f 20 68 61 6e 64 6c 65 20 74  want to handle t
3c10: 68 65 20 3c 30 20 72 65 74 75 72 6e 20 63 6f 64  he <0 return cod
3c20: 65 73 20 66 72 6f 6d 0a 20 20 20 20 20 2a 20 42  es from.     * B
3c30: 49 4f 5f 77 72 69 74 65 20 73 70 65 63 69 61 6c  IO_write special
3c40: 6c 79 20 28 61 73 20 61 64 76 69 73 65 64 20 69  ly (as advised i
3c50: 6e 20 74 68 65 20 52 53 41 20 64 6f 63 73 29 2e  n the RSA docs).
3c60: 20 20 54 4c 53 27 73 20 6c 6f 77 65 72 20 6c 65    TLS's lower le
3c70: 76 65 6c 0a 20 20 20 20 20 2a 20 42 49 4f 20 66  vel.     * BIO f
3c80: 75 6e 63 74 69 6f 6e 73 20 70 6c 61 79 20 77 69  unctions play wi
3c90: 74 68 20 74 68 65 20 72 65 74 72 79 20 66 6c 61  th the retry fla
3ca0: 67 73 20 74 68 6f 75 67 68 2c 20 61 6e 64 20 74  gs though, and t
3cb0: 68 69 73 20 73 65 65 6d 73 20 74 6f 0a 20 20 20  his seems to.   
3cc0: 20 20 2a 20 77 6f 72 6b 20 63 6f 72 72 65 63 74    * work correct
3cd0: 6c 79 2e 20 20 53 69 6d 69 6c 61 72 20 66 69 78  ly.  Similar fix
3ce0: 20 69 6e 20 54 6c 73 49 6e 70 75 74 50 72 6f 63   in TlsInputProc
3cf0: 2e 20 2d 20 68 6f 62 62 73 0a 20 20 20 20 20 2a  . - hobbs.     *
3d00: 2f 0a 20 20 20 20 45 52 52 5f 63 6c 65 61 72 5f  /.    ERR_clear_
3d10: 65 72 72 6f 72 28 29 3b 0a 20 20 20 20 77 72 69  error();.    wri
3d20: 74 74 65 6e 20 3d 20 42 49 4f 5f 77 72 69 74 65  tten = BIO_write
3d30: 28 73 74 61 74 65 50 74 72 2d 3e 62 69 6f 2c 20  (statePtr->bio, 
3d40: 62 75 66 2c 20 74 6f 57 72 69 74 65 29 3b 0a 20  buf, toWrite);. 
3d50: 20 20 20 64 70 72 69 6e 74 66 28 22 42 49 4f 5f     dprintf("BIO_
3d60: 77 72 69 74 65 28 25 70 2c 20 25 64 29 20 2d 3e  write(%p, %d) ->
3d70: 20 5b 25 64 5d 22 2c 20 28 76 6f 69 64 20 2a 29   [%d]", (void *)
3d80: 20 73 74 61 74 65 50 74 72 2c 20 74 6f 57 72 69   statePtr, toWri
3d90: 74 65 2c 20 77 72 69 74 74 65 6e 29 3b 0a 0a 20  te, written);.. 
3da0: 20 20 20 65 72 72 20 3d 20 53 53 4c 5f 67 65 74     err = SSL_get
3db0: 5f 65 72 72 6f 72 28 73 74 61 74 65 50 74 72 2d  _error(statePtr-
3dc0: 3e 73 73 6c 2c 20 77 72 69 74 74 65 6e 29 3b 0a  >ssl, written);.
3dd0: 20 20 20 20 62 61 63 6b 69 6e 67 45 72 72 6f 72      backingError
3de0: 20 3d 20 45 52 52 5f 67 65 74 5f 65 72 72 6f 72   = ERR_get_error
3df0: 28 29 3b 0a 0a 20 20 20 20 73 77 69 74 63 68 20  ();..    switch 
3e00: 28 65 72 72 29 20 7b 0a 09 63 61 73 65 20 53 53  (err) {..case SS
3e10: 4c 5f 45 52 52 4f 52 5f 4e 4f 4e 45 3a 0a 09 20  L_ERROR_NONE:.. 
3e20: 20 20 20 69 66 20 28 77 72 69 74 74 65 6e 20 3c     if (written <
3e30: 20 30 29 20 7b 0a 09 09 77 72 69 74 74 65 6e 20   0) {...written 
3e40: 3d 20 30 3b 0a 09 20 20 20 20 7d 0a 09 20 20 20  = 0;..    }..   
3e50: 20 62 72 65 61 6b 3b 0a 0a 09 63 61 73 65 20 53   break;...case S
3e60: 53 4c 5f 45 52 52 4f 52 5f 57 41 4e 54 5f 57 52  SL_ERROR_WANT_WR
3e70: 49 54 45 3a 0a 09 20 20 20 20 64 70 72 69 6e 74  ITE:..    dprint
3e80: 66 28 22 47 6f 74 20 53 53 4c 5f 45 52 52 4f 52  f("Got SSL_ERROR
3e90: 5f 57 41 4e 54 5f 57 52 49 54 45 2c 20 6d 61 70  _WANT_WRITE, map
3ea0: 70 69 6e 67 20 69 74 20 74 6f 20 45 41 47 41 49  ping it to EAGAI
3eb0: 4e 22 29 3b 0a 09 20 20 20 20 2a 65 72 72 6f 72  N");..    *error
3ec0: 43 6f 64 65 50 74 72 20 3d 20 45 41 47 41 49 4e  CodePtr = EAGAIN
3ed0: 3b 0a 09 20 20 20 20 77 72 69 74 74 65 6e 20 3d  ;..    written =
3ee0: 20 2d 31 3b 0a 09 20 20 20 20 54 6c 73 5f 45 72   -1;..    Tls_Er
3ef0: 72 6f 72 28 73 74 61 74 65 50 74 72 2c 20 22 53  ror(statePtr, "S
3f00: 53 4c 5f 45 52 52 4f 52 5f 57 41 4e 54 5f 57 52  SL_ERROR_WANT_WR
3f10: 49 54 45 22 29 3b 0a 09 20 20 20 20 62 72 65 61  ITE");..    brea
3f20: 6b 3b 0a 0a 09 63 61 73 65 20 53 53 4c 5f 45 52  k;...case SSL_ER
3f30: 52 4f 52 5f 57 41 4e 54 5f 52 45 41 44 3a 0a 09  ROR_WANT_READ:..
3f40: 20 20 20 20 64 70 72 69 6e 74 66 28 22 20 77 72      dprintf(" wr
3f50: 69 74 65 20 52 20 42 4c 4f 43 4b 22 29 3b 0a 09  ite R BLOCK");..
3f60: 20 20 20 20 54 6c 73 5f 45 72 72 6f 72 28 73 74      Tls_Error(st
3f70: 61 74 65 50 74 72 2c 20 22 53 53 4c 5f 45 52 52  atePtr, "SSL_ERR
3f80: 4f 52 5f 57 41 4e 54 5f 52 45 41 44 22 29 3b 0a  OR_WANT_READ");.
3f90: 09 20 20 20 20 62 72 65 61 6b 3b 0a 0a 09 63 61  .    break;...ca
3fa0: 73 65 20 53 53 4c 5f 45 52 52 4f 52 5f 57 41 4e  se SSL_ERROR_WAN
3fb0: 54 5f 58 35 30 39 5f 4c 4f 4f 4b 55 50 3a 0a 09  T_X509_LOOKUP:..
3fc0: 20 20 20 20 64 70 72 69 6e 74 66 28 22 20 77 72      dprintf(" wr
3fd0: 69 74 65 20 58 20 42 4c 4f 43 4b 22 29 3b 0a 09  ite X BLOCK");..
3fe0: 20 20 20 20 54 6c 73 5f 45 72 72 6f 72 28 73 74      Tls_Error(st
3ff0: 61 74 65 50 74 72 2c 20 22 53 53 4c 5f 45 52 52  atePtr, "SSL_ERR
4000: 4f 52 5f 57 41 4e 54 5f 58 35 30 39 5f 4c 4f 4f  OR_WANT_X509_LOO
4010: 4b 55 50 22 29 3b 0a 09 20 20 20 20 62 72 65 61  KUP");..    brea
4020: 6b 3b 0a 0a 09 63 61 73 65 20 53 53 4c 5f 45 52  k;...case SSL_ER
4030: 52 4f 52 5f 5a 45 52 4f 5f 52 45 54 55 52 4e 3a  ROR_ZERO_RETURN:
4040: 0a 09 20 20 20 20 64 70 72 69 6e 74 66 28 22 20  ..    dprintf(" 
4050: 63 6c 6f 73 65 64 22 29 3b 0a 09 20 20 20 20 77  closed");..    w
4060: 72 69 74 74 65 6e 20 3d 20 30 3b 0a 09 20 20 20  ritten = 0;..   
4070: 20 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 20 3d   *errorCodePtr =
4080: 20 30 3b 0a 09 20 20 20 20 54 6c 73 5f 45 72 72   0;..    Tls_Err
4090: 6f 72 28 73 74 61 74 65 50 74 72 2c 20 22 50 65  or(statePtr, "Pe
40a0: 65 72 20 68 61 73 20 63 6c 6f 73 65 64 20 74 68  er has closed th
40b0: 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 66 6f 72  e connection for
40c0: 20 77 72 69 74 69 6e 67 20 62 79 20 73 65 6e 64   writing by send
40d0: 69 6e 67 20 74 68 65 20 63 6c 6f 73 65 5f 6e 6f  ing the close_no
40e0: 74 69 66 79 20 61 6c 65 72 74 22 29 3b 0a 09 20  tify alert");.. 
40f0: 20 20 20 62 72 65 61 6b 3b 0a 0a 09 63 61 73 65     break;...case
4100: 20 53 53 4c 5f 45 52 52 4f 52 5f 53 59 53 43 41   SSL_ERROR_SYSCA
4110: 4c 4c 3a 0a 09 20 20 20 20 2f 2a 20 53 6f 6d 65  LL:..    /* Some
4120: 20 6e 6f 6e 2d 72 65 63 6f 76 65 72 61 62 6c 65   non-recoverable
4130: 2c 20 66 61 74 61 6c 20 49 2f 4f 20 65 72 72 6f  , fatal I/O erro
4140: 72 20 6f 63 63 75 72 72 65 64 20 2a 2f 0a 0a 09  r occurred */...
4150: 20 20 20 20 69 66 20 28 62 61 63 6b 69 6e 67 45      if (backingE
4160: 72 72 6f 72 20 3d 3d 20 30 20 26 26 20 77 72 69  rror == 0 && wri
4170: 74 74 65 6e 20 3d 3d 20 30 29 20 7b 0a 09 09 64  tten == 0) {...d
4180: 70 72 69 6e 74 66 28 22 45 4f 46 20 72 65 61 63  printf("EOF reac
4190: 68 65 64 22 29 0a 09 09 2a 65 72 72 6f 72 43 6f  hed")...*errorCo
41a0: 64 65 50 74 72 20 3d 20 30 3b 0a 09 09 77 72 69  dePtr = 0;...wri
41b0: 74 74 65 6e 20 3d 20 30 3b 0a 09 09 54 6c 73 5f  tten = 0;...Tls_
41c0: 45 72 72 6f 72 28 73 74 61 74 65 50 74 72 2c 20  Error(statePtr, 
41d0: 22 45 4f 46 20 72 65 61 63 68 65 64 22 29 3b 0a  "EOF reached");.
41e0: 0a 09 20 20 20 20 7d 20 65 6c 73 65 20 69 66 20  ..    } else if 
41f0: 28 62 61 63 6b 69 6e 67 45 72 72 6f 72 20 3d 3d  (backingError ==
4200: 20 30 20 26 26 20 77 72 69 74 74 65 6e 20 3d 3d   0 && written ==
4210: 20 2d 31 29 20 7b 0a 09 09 64 70 72 69 6e 74 66   -1) {...dprintf
4220: 28 22 49 2f 4f 20 65 72 72 6f 72 20 6f 63 63 75  ("I/O error occu
4230: 72 72 65 64 20 28 65 72 72 6e 6f 20 3d 20 25 6c  rred (errno = %l
4240: 75 29 22 2c 20 28 75 6e 73 69 67 6e 65 64 20 6c  u)", (unsigned l
4250: 6f 6e 67 29 20 54 63 6c 5f 47 65 74 45 72 72 6e  ong) Tcl_GetErrn
4260: 6f 28 29 29 3b 0a 09 09 2a 65 72 72 6f 72 43 6f  o());...*errorCo
4270: 64 65 50 74 72 20 3d 20 54 63 6c 5f 47 65 74 45  dePtr = Tcl_GetE
4280: 72 72 6e 6f 28 29 3b 0a 09 09 77 72 69 74 74 65  rrno();...writte
4290: 6e 20 3d 20 2d 31 3b 0a 09 09 54 6c 73 5f 45 72  n = -1;...Tls_Er
42a0: 72 6f 72 28 73 74 61 74 65 50 74 72 2c 20 54 63  ror(statePtr, Tc
42b0: 6c 5f 45 72 72 6e 6f 4d 73 67 28 2a 65 72 72 6f  l_ErrnoMsg(*erro
42c0: 72 43 6f 64 65 50 74 72 29 29 3b 0a 0a 09 20 20  rCodePtr));...  
42d0: 20 20 7d 20 65 6c 73 65 20 7b 0a 09 09 64 70 72    } else {...dpr
42e0: 69 6e 74 66 28 22 49 2f 4f 20 65 72 72 6f 72 20  intf("I/O error 
42f0: 6f 63 63 75 72 72 65 64 20 28 62 61 63 6b 69 6e  occurred (backin
4300: 67 45 72 72 6f 72 20 3d 20 25 6c 75 29 22 2c 20  gError = %lu)", 
4310: 62 61 63 6b 69 6e 67 45 72 72 6f 72 29 3b 0a 09  backingError);..
4320: 09 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 20 3d  .*errorCodePtr =
4330: 20 54 63 6c 5f 47 65 74 45 72 72 6e 6f 28 29 3b   Tcl_GetErrno();
4340: 0a 09 09 77 72 69 74 74 65 6e 20 3d 20 2d 31 3b  ...written = -1;
4350: 0a 09 09 54 6c 73 5f 45 72 72 6f 72 28 73 74 61  ...Tls_Error(sta
4360: 74 65 50 74 72 2c 20 45 52 52 5f 72 65 61 73 6f  tePtr, ERR_reaso
4370: 6e 5f 65 72 72 6f 72 5f 73 74 72 69 6e 67 28 62  n_error_string(b
4380: 61 63 6b 69 6e 67 45 72 72 6f 72 29 29 3b 0a 09  ackingError));..
4390: 20 20 20 20 7d 0a 09 20 20 20 20 62 72 65 61 6b      }..    break
43a0: 3b 0a 0a 09 63 61 73 65 20 53 53 4c 5f 45 52 52  ;...case SSL_ERR
43b0: 4f 52 5f 53 53 4c 3a 0a 09 20 20 20 20 2f 2a 20  OR_SSL:..    /* 
43c0: 41 20 6e 6f 6e 2d 72 65 63 6f 76 65 72 61 62 6c  A non-recoverabl
43d0: 65 2c 20 66 61 74 61 6c 20 65 72 72 6f 72 20 69  e, fatal error i
43e0: 6e 20 74 68 65 20 53 53 4c 20 6c 69 62 72 61 72  n the SSL librar
43f0: 79 20 6f 63 63 75 72 72 65 64 2c 20 75 73 75 61  y occurred, usua
4400: 6c 6c 79 20 61 20 70 72 6f 74 6f 63 6f 6c 20 65  lly a protocol e
4410: 72 72 6f 72 20 2a 2f 0a 09 20 20 20 20 64 70 72  rror */..    dpr
4420: 69 6e 74 66 28 22 53 53 4c 20 65 72 72 6f 72 2c  intf("SSL error,
4430: 20 69 6e 64 69 63 61 74 69 6e 67 20 74 68 61 74   indicating that
4440: 20 74 68 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 20   the connection 
4450: 68 61 73 20 62 65 65 6e 20 61 62 6f 72 74 65 64  has been aborted
4460: 22 29 3b 0a 09 20 20 20 20 69 66 20 28 62 61 63  ");..    if (bac
4470: 6b 69 6e 67 45 72 72 6f 72 20 21 3d 20 30 29 20  kingError != 0) 
4480: 7b 0a 09 09 54 6c 73 5f 45 72 72 6f 72 28 73 74  {...Tls_Error(st
4490: 61 74 65 50 74 72 2c 20 45 52 52 5f 72 65 61 73  atePtr, ERR_reas
44a0: 6f 6e 5f 65 72 72 6f 72 5f 73 74 72 69 6e 67 28  on_error_string(
44b0: 62 61 63 6b 69 6e 67 45 72 72 6f 72 29 29 3b 0a  backingError));.
44c0: 09 20 20 20 20 7d 20 65 6c 73 65 20 69 66 20 28  .    } else if (
44d0: 53 53 4c 5f 67 65 74 5f 76 65 72 69 66 79 5f 72  SSL_get_verify_r
44e0: 65 73 75 6c 74 28 73 74 61 74 65 50 74 72 2d 3e  esult(statePtr->
44f0: 73 73 6c 29 20 21 3d 20 58 35 30 39 5f 56 5f 4f  ssl) != X509_V_O
4500: 4b 29 20 7b 0a 09 09 54 6c 73 5f 45 72 72 6f 72  K) {...Tls_Error
4510: 28 73 74 61 74 65 50 74 72 2c 20 58 35 30 39 5f  (statePtr, X509_
4520: 76 65 72 69 66 79 5f 63 65 72 74 5f 65 72 72 6f  verify_cert_erro
4530: 72 5f 73 74 72 69 6e 67 28 53 53 4c 5f 67 65 74  r_string(SSL_get
4540: 5f 76 65 72 69 66 79 5f 72 65 73 75 6c 74 28 73  _verify_result(s
4550: 74 61 74 65 50 74 72 2d 3e 73 73 6c 29 29 29 3b  tatePtr->ssl)));
4560: 0a 09 20 20 20 20 7d 20 65 6c 73 65 20 7b 0a 09  ..    } else {..
4570: 09 54 6c 73 5f 45 72 72 6f 72 28 73 74 61 74 65  .Tls_Error(state
4580: 50 74 72 2c 20 22 55 6e 6b 6e 6f 77 6e 20 53 53  Ptr, "Unknown SS
4590: 4c 20 65 72 72 6f 72 22 29 3b 0a 09 20 20 20 20  L error");..    
45a0: 7d 0a 09 20 20 20 20 2a 65 72 72 6f 72 43 6f 64  }..    *errorCod
45b0: 65 50 74 72 20 3d 20 45 43 4f 4e 4e 41 42 4f 52  ePtr = ECONNABOR
45c0: 54 45 44 3b 0a 09 20 20 20 20 77 72 69 74 74 65  TED;..    writte
45d0: 6e 20 3d 20 2d 31 3b 0a 09 20 20 20 20 62 72 65  n = -1;..    bre
45e0: 61 6b 3b 0a 0a 09 64 65 66 61 75 6c 74 3a 0a 09  ak;...default:..
45f0: 20 20 20 20 64 70 72 69 6e 74 66 28 22 75 6e 6b      dprintf("unk
4600: 6e 6f 77 6e 20 65 72 72 6f 72 3a 20 25 64 22 2c  nown error: %d",
4610: 20 65 72 72 29 3b 0a 09 20 20 20 20 54 6c 73 5f   err);..    Tls_
4620: 45 72 72 6f 72 28 73 74 61 74 65 50 74 72 2c 20  Error(statePtr, 
4630: 22 55 6e 6b 6e 6f 77 6e 20 65 72 72 6f 72 22 29  "Unknown error")
4640: 3b 0a 09 20 20 20 20 62 72 65 61 6b 3b 0a 20 20  ;..    break;.  
4650: 20 20 7d 0a 0a 20 20 20 20 64 70 72 69 6e 74 66    }..    dprintf
4660: 28 22 4f 75 74 70 75 74 28 25 64 29 20 2d 3e 20  ("Output(%d) -> 
4670: 25 64 22 2c 20 74 6f 57 72 69 74 65 2c 20 77 72  %d", toWrite, wr
4680: 69 74 74 65 6e 29 3b 0a 20 20 20 20 72 65 74 75  itten);.    retu
4690: 72 6e 20 77 72 69 74 74 65 6e 3b 0a 7d 0a 0a 2f  rn written;.}../
46a0: 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  *. *------------
46b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
46c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
46d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
46e0: 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 0a 20 2a 20 54 6c  -------. *. * Tl
46f0: 73 53 65 74 4f 70 74 69 6f 6e 50 72 6f 63 20 2d  sSetOptionProc -
4700: 2d 0a 20 2a 0a 20 2a 20 20 20 20 53 65 74 73 20  -. *. *    Sets 
4710: 61 6e 20 6f 70 74 69 6f 6e 20 76 61 6c 75 65 20  an option value 
4720: 66 6f 72 20 61 20 53 53 4c 20 73 6f 63 6b 65 74  for a SSL socket
4730: 20 62 61 73 65 64 20 63 68 61 6e 6e 65 6c 2c 20   based channel, 
4740: 6f 72 20 61 0a 20 2a 20 20 20 20 6c 69 73 74 20  or a. *    list 
4750: 6f 66 20 61 6c 6c 20 6f 70 74 69 6f 6e 73 20 61  of all options a
4760: 6e 64 20 74 68 65 69 72 20 76 61 6c 75 65 73 2e  nd their values.
4770: 0a 20 2a 0a 20 2a 20 52 65 73 75 6c 74 73 3a 0a  . *. * Results:.
4780: 20 2a 20 20 20 20 54 43 4c 5f 4f 4b 20 69 66 20   *    TCL_OK if 
4790: 73 75 63 63 65 73 73 66 75 6c 20 6f 72 20 54 43  successful or TC
47a0: 4c 5f 45 52 52 4f 52 20 69 66 20 66 61 69 6c 65  L_ERROR if faile
47b0: 64 2e 0a 20 2a 0a 20 2a 20 53 69 64 65 20 65 66  d.. *. * Side ef
47c0: 66 65 63 74 73 3a 0a 20 2a 20 20 20 20 55 70 64  fects:. *    Upd
47d0: 61 74 65 73 20 63 68 61 6e 6e 65 6c 20 6f 70 74  ates channel opt
47e0: 69 6f 6e 20 74 6f 20 6e 65 77 20 76 61 6c 75 65  ion to new value
47f0: 2e 0a 20 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d  .. *. *---------
4800: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4810: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4820: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4830: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 2f 0a 73  ----------. */.s
4840: 74 61 74 69 63 20 69 6e 74 0a 54 6c 73 53 65 74  tatic int.TlsSet
4850: 4f 70 74 69 6f 6e 50 72 6f 63 28 76 6f 69 64 20  OptionProc(void 
4860: 2a 69 6e 73 74 61 6e 63 65 44 61 74 61 2c 20 20  *instanceData,  
4870: 20 20 2f 2a 20 53 6f 63 6b 65 74 20 73 74 61 74    /* Socket stat
4880: 65 2e 20 2a 2f 0a 20 20 20 20 54 63 6c 5f 49 6e  e. */.    Tcl_In
4890: 74 65 72 70 20 2a 69 6e 74 65 72 70 2c 09 09 2f  terp *interp,../
48a0: 2a 20 46 6f 72 20 65 72 72 6f 72 73 20 2d 20 63  * For errors - c
48b0: 61 6e 20 62 65 20 4e 55 4c 4c 2e 20 2a 2f 0a 20  an be NULL. */. 
48c0: 20 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 6f     const char *o
48d0: 70 74 69 6f 6e 4e 61 6d 65 2c 09 2f 2a 20 4e 61  ptionName,./* Na
48e0: 6d 65 20 6f 66 20 74 68 65 20 6f 70 74 69 6f 6e  me of the option
48f0: 20 74 6f 20 73 65 74 20 74 68 65 20 76 61 6c 75   to set the valu
4900: 65 20 66 6f 72 2c 20 6f 72 0a 09 09 09 09 20 2a  e for, or..... *
4910: 20 4e 55 4c 4c 20 74 6f 20 67 65 74 20 61 6c 6c   NULL to get all
4920: 20 6f 70 74 69 6f 6e 73 20 61 6e 64 20 74 68 65   options and the
4930: 69 72 20 76 61 6c 75 65 73 2e 20 2a 2f 0a 20 20  ir values. */.  
4940: 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 6f 70    const char *op
4950: 74 69 6f 6e 56 61 6c 75 65 29 09 2f 2a 20 56 61  tionValue)./* Va
4960: 6c 75 65 20 66 6f 72 20 6f 70 74 69 6f 6e 2e 20  lue for option. 
4970: 2a 2f 0a 7b 0a 20 20 20 20 53 74 61 74 65 20 2a  */.{.    State *
4980: 73 74 61 74 65 50 74 72 20 3d 20 28 53 74 61 74  statePtr = (Stat
4990: 65 20 2a 29 69 6e 73 74 61 6e 63 65 44 61 74 61  e *)instanceData
49a0: 3b 0a 0a 20 20 20 20 54 63 6c 5f 43 68 61 6e 6e  ;..    Tcl_Chann
49b0: 65 6c 20 64 6f 77 6e 43 68 61 6e 20 3d 20 54 6c  el downChan = Tl
49c0: 73 5f 47 65 74 50 61 72 65 6e 74 28 73 74 61 74  s_GetParent(stat
49d0: 65 50 74 72 2c 20 54 4c 53 5f 54 43 4c 5f 46 41  ePtr, TLS_TCL_FA
49e0: 53 54 50 41 54 48 29 3b 0a 20 20 20 20 54 63 6c  STPATH);.    Tcl
49f0: 5f 44 72 69 76 65 72 53 65 74 4f 70 74 69 6f 6e  _DriverSetOption
4a00: 50 72 6f 63 20 2a 73 65 74 4f 70 74 69 6f 6e 50  Proc *setOptionP
4a10: 72 6f 63 3b 0a 0a 20 20 20 20 73 65 74 4f 70 74  roc;..    setOpt
4a20: 69 6f 6e 50 72 6f 63 20 3d 20 54 63 6c 5f 43 68  ionProc = Tcl_Ch
4a30: 61 6e 6e 65 6c 53 65 74 4f 70 74 69 6f 6e 50 72  annelSetOptionPr
4a40: 6f 63 28 54 63 6c 5f 47 65 74 43 68 61 6e 6e 65  oc(Tcl_GetChanne
4a50: 6c 54 79 70 65 28 64 6f 77 6e 43 68 61 6e 29 29  lType(downChan))
4a60: 3b 0a 20 20 20 20 69 66 20 28 73 65 74 4f 70 74  ;.    if (setOpt
4a70: 69 6f 6e 50 72 6f 63 20 21 3d 20 4e 55 4c 4c 29  ionProc != NULL)
4a80: 20 7b 0a 09 72 65 74 75 72 6e 20 28 2a 73 65 74   {..return (*set
4a90: 4f 70 74 69 6f 6e 50 72 6f 63 29 28 54 63 6c 5f  OptionProc)(Tcl_
4aa0: 47 65 74 43 68 61 6e 6e 65 6c 49 6e 73 74 61 6e  GetChannelInstan
4ab0: 63 65 44 61 74 61 28 64 6f 77 6e 43 68 61 6e 29  ceData(downChan)
4ac0: 2c 20 69 6e 74 65 72 70 2c 20 6f 70 74 69 6f 6e  , interp, option
4ad0: 4e 61 6d 65 2c 20 6f 70 74 69 6f 6e 56 61 6c 75  Name, optionValu
4ae0: 65 29 3b 0a 20 20 20 20 7d 20 65 6c 73 65 20 69  e);.    } else i
4af0: 66 20 28 6f 70 74 69 6f 6e 4e 61 6d 65 20 3d 3d  f (optionName ==
4b00: 20 28 63 68 61 72 2a 29 20 4e 55 4c 4c 29 20 7b   (char*) NULL) {
4b10: 0a 09 2f 2a 0a 09 20 2a 20 52 65 71 75 65 73 74  ../*.. * Request
4b20: 20 69 73 20 71 75 65 72 79 20 66 6f 72 20 61 6c   is query for al
4b30: 6c 20 6f 70 74 69 6f 6e 73 2c 20 74 68 69 73 20  l options, this 
4b40: 69 73 20 6f 6b 2e 0a 09 20 2a 2f 0a 09 72 65 74  is ok... */..ret
4b50: 75 72 6e 20 54 43 4c 5f 4f 4b 3b 0a 20 20 20 20  urn TCL_OK;.    
4b60: 7d 0a 20 20 20 20 2f 2a 0a 20 20 20 20 20 2a 20  }.    /*.     * 
4b70: 52 65 71 75 65 73 74 20 66 6f 72 20 61 20 73 70  Request for a sp
4b80: 65 63 69 66 69 63 20 6f 70 74 69 6f 6e 20 68 61  ecific option ha
4b90: 73 20 74 6f 20 66 61 69 6c 2c 20 77 65 20 64 6f  s to fail, we do
4ba0: 6e 27 74 20 68 61 76 65 20 61 6e 79 2e 0a 20 20  n't have any..  
4bb0: 20 20 20 2a 2f 0a 20 20 20 20 72 65 74 75 72 6e     */.    return
4bc0: 20 54 63 6c 5f 42 61 64 43 68 61 6e 6e 65 6c 4f   Tcl_BadChannelO
4bd0: 70 74 69 6f 6e 28 69 6e 74 65 72 70 2c 20 6f 70  ption(interp, op
4be0: 74 69 6f 6e 4e 61 6d 65 2c 20 22 22 29 3b 0a 7d  tionName, "");.}
4bf0: 0a 0a 2f 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d  ../*. *---------
4c00: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4c10: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4c20: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4c30: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 0a 20 2a  ----------. *. *
4c40: 20 54 6c 73 47 65 74 4f 70 74 69 6f 6e 50 72 6f   TlsGetOptionPro
4c50: 63 20 2d 2d 0a 20 2a 0a 20 2a 20 20 20 20 47 65  c --. *. *    Ge
4c60: 74 73 20 61 6e 20 6f 70 74 69 6f 6e 20 76 61 6c  ts an option val
4c70: 75 65 20 66 6f 72 20 61 20 53 53 4c 20 73 6f 63  ue for a SSL soc
4c80: 6b 65 74 20 62 61 73 65 64 20 63 68 61 6e 6e 65  ket based channe
4c90: 6c 2c 20 6f 72 20 61 0a 20 2a 20 20 20 20 6c 69  l, or a. *    li
4ca0: 73 74 20 6f 66 20 61 6c 6c 20 6f 70 74 69 6f 6e  st of all option
4cb0: 73 20 61 6e 64 20 74 68 65 69 72 20 76 61 6c 75  s and their valu
4cc0: 65 73 2e 0a 20 2a 0a 20 2a 20 52 65 73 75 6c 74  es.. *. * Result
4cd0: 73 3a 0a 20 2a 20 20 20 20 41 20 73 74 61 6e 64  s:. *    A stand
4ce0: 61 72 64 20 54 63 6c 20 72 65 73 75 6c 74 2e 20  ard Tcl result. 
4cf0: 54 68 65 20 76 61 6c 75 65 20 6f 66 20 74 68 65  The value of the
4d00: 20 73 70 65 63 69 66 69 65 64 20 6f 70 74 69 6f   specified optio
4d10: 6e 20 6f 72 20 61 0a 20 2a 20 20 20 20 6c 69 73  n or a. *    lis
4d20: 74 20 6f 66 20 61 6c 6c 20 6f 70 74 69 6f 6e 73  t of all options
4d30: 20 61 6e 64 20 74 68 65 69 72 20 76 61 6c 75 65   and their value
4d40: 73 20 69 73 20 72 65 74 75 72 6e 65 64 20 69 6e  s is returned in
4d50: 20 74 68 65 0a 20 2a 20 20 20 20 73 75 70 70 6c   the. *    suppl
4d60: 69 65 64 20 44 53 74 72 69 6e 67 2e 0a 20 2a 0a  ied DString.. *.
4d70: 20 2a 20 53 69 64 65 20 65 66 66 65 63 74 73 3a   * Side effects:
4d80: 0a 20 2a 20 20 20 20 4e 6f 6e 65 2e 0a 20 2a 0a  . *    None.. *.
4d90: 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d   *--------------
4da0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4db0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4dc0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4dd0: 2d 2d 2d 2d 2d 0a 20 2a 2f 0a 73 74 61 74 69 63  -----. */.static
4de0: 20 69 6e 74 0a 54 6c 73 47 65 74 4f 70 74 69 6f   int.TlsGetOptio
4df0: 6e 50 72 6f 63 28 0a 20 20 20 20 76 6f 69 64 20  nProc(.    void 
4e00: 2a 69 6e 73 74 61 6e 63 65 44 61 74 61 2c 09 2f  *instanceData,./
4e10: 2a 20 53 6f 63 6b 65 74 20 73 74 61 74 65 2e 20  * Socket state. 
4e20: 2a 2f 0a 20 20 20 20 54 63 6c 5f 49 6e 74 65 72  */.    Tcl_Inter
4e30: 70 20 2a 69 6e 74 65 72 70 2c 09 09 2f 2a 20 46  p *interp,../* F
4e40: 6f 72 20 65 72 72 6f 72 73 20 2d 20 63 61 6e 20  or errors - can 
4e50: 62 65 20 4e 55 4c 4c 2e 20 2a 2f 0a 20 20 20 20  be NULL. */.    
4e60: 63 6f 6e 73 74 20 63 68 61 72 20 2a 6f 70 74 69  const char *opti
4e70: 6f 6e 4e 61 6d 65 2c 09 2f 2a 20 4e 61 6d 65 20  onName,./* Name 
4e80: 6f 66 20 74 68 65 20 6f 70 74 69 6f 6e 20 74 6f  of the option to
4e90: 20 72 65 74 72 69 65 76 65 20 74 68 65 20 76 61   retrieve the va
4ea0: 6c 75 65 20 66 6f 72 2c 20 6f 72 0a 09 09 09 09  lue for, or.....
4eb0: 20 2a 20 4e 55 4c 4c 20 74 6f 20 67 65 74 20 61   * NULL to get a
4ec0: 6c 6c 20 6f 70 74 69 6f 6e 73 20 61 6e 64 20 74  ll options and t
4ed0: 68 65 69 72 20 76 61 6c 75 65 73 2e 20 2a 2f 0a  heir values. */.
4ee0: 20 20 20 20 54 63 6c 5f 44 53 74 72 69 6e 67 20      Tcl_DString 
4ef0: 2a 6f 70 74 69 6f 6e 56 61 6c 75 65 29 09 2f 2a  *optionValue)./*
4f00: 20 57 68 65 72 65 20 74 6f 20 73 74 6f 72 65 20   Where to store 
4f10: 74 68 65 20 63 6f 6d 70 75 74 65 64 20 76 61 6c  the computed val
4f20: 75 65 20 69 6e 69 74 69 61 6c 69 7a 65 64 20 62  ue initialized b
4f30: 79 20 63 61 6c 6c 65 72 2e 20 2a 2f 0a 7b 0a 20  y caller. */.{. 
4f40: 20 20 20 53 74 61 74 65 20 2a 73 74 61 74 65 50     State *stateP
4f50: 74 72 20 3d 20 28 53 74 61 74 65 20 2a 29 69 6e  tr = (State *)in
4f60: 73 74 61 6e 63 65 44 61 74 61 3b 0a 0a 20 20 20  stanceData;..   
4f70: 20 54 63 6c 5f 43 68 61 6e 6e 65 6c 20 64 6f 77   Tcl_Channel dow
4f80: 6e 43 68 61 6e 20 3d 20 54 6c 73 5f 47 65 74 50  nChan = Tls_GetP
4f90: 61 72 65 6e 74 28 73 74 61 74 65 50 74 72 2c 20  arent(statePtr, 
4fa0: 54 4c 53 5f 54 43 4c 5f 46 41 53 54 50 41 54 48  TLS_TCL_FASTPATH
4fb0: 29 3b 0a 20 20 20 20 54 63 6c 5f 44 72 69 76 65  );.    Tcl_Drive
4fc0: 72 47 65 74 4f 70 74 69 6f 6e 50 72 6f 63 20 2a  rGetOptionProc *
4fd0: 67 65 74 4f 70 74 69 6f 6e 50 72 6f 63 3b 0a 0a  getOptionProc;..
4fe0: 20 20 20 20 67 65 74 4f 70 74 69 6f 6e 50 72 6f      getOptionPro
4ff0: 63 20 3d 20 54 63 6c 5f 43 68 61 6e 6e 65 6c 47  c = Tcl_ChannelG
5000: 65 74 4f 70 74 69 6f 6e 50 72 6f 63 28 54 63 6c  etOptionProc(Tcl
5010: 5f 47 65 74 43 68 61 6e 6e 65 6c 54 79 70 65 28  _GetChannelType(
5020: 64 6f 77 6e 43 68 61 6e 29 29 3b 0a 20 20 20 20  downChan));.    
5030: 69 66 20 28 67 65 74 4f 70 74 69 6f 6e 50 72 6f  if (getOptionPro
5040: 63 20 21 3d 20 4e 55 4c 4c 29 20 7b 0a 09 72 65  c != NULL) {..re
5050: 74 75 72 6e 20 28 2a 67 65 74 4f 70 74 69 6f 6e  turn (*getOption
5060: 50 72 6f 63 29 28 54 63 6c 5f 47 65 74 43 68 61  Proc)(Tcl_GetCha
5070: 6e 6e 65 6c 49 6e 73 74 61 6e 63 65 44 61 74 61  nnelInstanceData
5080: 28 64 6f 77 6e 43 68 61 6e 29 2c 20 69 6e 74 65  (downChan), inte
5090: 72 70 2c 20 6f 70 74 69 6f 6e 4e 61 6d 65 2c 20  rp, optionName, 
50a0: 6f 70 74 69 6f 6e 56 61 6c 75 65 29 3b 0a 20 20  optionValue);.  
50b0: 20 20 7d 20 65 6c 73 65 20 69 66 20 28 6f 70 74    } else if (opt
50c0: 69 6f 6e 4e 61 6d 65 20 3d 3d 20 28 63 68 61 72  ionName == (char
50d0: 2a 29 20 4e 55 4c 4c 29 20 7b 0a 09 2f 2a 0a 09  *) NULL) {../*..
50e0: 20 2a 20 52 65 71 75 65 73 74 20 69 73 20 71 75   * Request is qu
50f0: 65 72 79 20 66 6f 72 20 61 6c 6c 20 6f 70 74 69  ery for all opti
5100: 6f 6e 73 2c 20 74 68 69 73 20 69 73 20 6f 6b 2e  ons, this is ok.
5110: 0a 09 20 2a 2f 0a 09 72 65 74 75 72 6e 20 54 43  .. */..return TC
5120: 4c 5f 4f 4b 3b 0a 20 20 20 20 7d 0a 20 20 20 20  L_OK;.    }.    
5130: 2f 2a 0a 20 20 20 20 20 2a 20 52 65 71 75 65 73  /*.     * Reques
5140: 74 20 66 6f 72 20 61 20 73 70 65 63 69 66 69 63  t for a specific
5150: 20 6f 70 74 69 6f 6e 20 68 61 73 20 74 6f 20 66   option has to f
5160: 61 69 6c 2c 20 77 65 20 64 6f 6e 27 74 20 68 61  ail, we don't ha
5170: 76 65 20 61 6e 79 2e 0a 20 20 20 20 20 2a 2f 0a  ve any..     */.
5180: 20 20 20 20 72 65 74 75 72 6e 20 54 63 6c 5f 42      return Tcl_B
5190: 61 64 43 68 61 6e 6e 65 6c 4f 70 74 69 6f 6e 28  adChannelOption(
51a0: 69 6e 74 65 72 70 2c 20 6f 70 74 69 6f 6e 4e 61  interp, optionNa
51b0: 6d 65 2c 20 22 22 29 3b 0a 7d 0a 0a 2f 2a 0a 20  me, "");.}../*. 
51c0: 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  *---------------
51d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
51e0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
51f0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5200: 2d 2d 2d 2d 0a 20 2a 0a 20 2a 20 54 6c 73 57 61  ----. *. * TlsWa
5210: 74 63 68 50 72 6f 63 20 2d 2d 0a 20 2a 0a 20 2a  tchProc --. *. *
5220: 20 20 20 20 49 6e 69 74 69 61 6c 69 7a 65 20 74      Initialize t
5230: 68 65 20 6e 6f 74 69 66 69 65 72 20 74 6f 20 77  he notifier to w
5240: 61 74 63 68 20 54 63 6c 5f 46 69 6c 65 73 20 66  atch Tcl_Files f
5250: 72 6f 6d 20 74 68 69 73 20 63 68 61 6e 6e 65 6c  rom this channel
5260: 2e 0a 20 2a 0a 20 2a 20 52 65 73 75 6c 74 73 3a  .. *. * Results:
5270: 0a 20 2a 20 20 20 20 4e 6f 6e 65 2e 0a 20 2a 0a  . *    None.. *.
5280: 20 2a 20 53 69 64 65 20 65 66 66 65 63 74 73 3a   * Side effects:
5290: 0a 20 2a 20 20 20 20 53 65 74 73 20 75 70 20 74  . *    Sets up t
52a0: 68 65 20 6e 6f 74 69 66 69 65 72 20 73 6f 20 74  he notifier so t
52b0: 68 61 74 20 61 20 66 75 74 75 72 65 20 65 76 65  hat a future eve
52c0: 6e 74 20 6f 6e 20 74 68 65 20 63 68 61 6e 6e 65  nt on the channe
52d0: 6c 0a 20 2a 20 20 20 20 77 69 6c 6c 20 62 65 20  l. *    will be 
52e0: 73 65 65 6e 20 62 79 20 54 63 6c 2e 0a 20 2a 0a  seen by Tcl.. *.
52f0: 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d   *--------------
5300: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5310: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5320: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5330: 2d 2d 2d 2d 2d 0a 20 2a 2f 0a 0a 73 74 61 74 69  -----. */..stati
5340: 63 20 76 6f 69 64 0a 54 6c 73 57 61 74 63 68 50  c void.TlsWatchP
5350: 72 6f 63 28 0a 20 20 20 20 76 6f 69 64 20 2a 69  roc(.    void *i
5360: 6e 73 74 61 6e 63 65 44 61 74 61 2c 20 20 20 20  nstanceData,    
5370: 2f 2a 20 54 68 65 20 73 6f 63 6b 65 74 20 73 74  /* The socket st
5380: 61 74 65 2e 20 2a 2f 0a 20 20 20 20 69 6e 74 20  ate. */.    int 
5390: 6d 61 73 6b 29 09 09 09 2f 2a 20 45 76 65 6e 74  mask).../* Event
53a0: 73 20 6f 66 20 69 6e 74 65 72 65 73 74 3b 20 61  s of interest; a
53b0: 6e 20 4f 52 2d 65 64 20 63 6f 6d 62 69 6e 61 74  n OR-ed combinat
53c0: 69 6f 6e 20 6f 66 0a 09 09 09 09 20 2a 20 54 43  ion of..... * TC
53d0: 4c 5f 52 45 41 44 41 42 4c 45 2c 20 54 43 4c 5f  L_READABLE, TCL_
53e0: 57 52 49 54 41 42 4c 45 20 61 6e 64 20 54 43 4c  WRITABLE and TCL
53f0: 5f 45 58 43 45 50 54 49 4f 4e 2e 20 2a 2f 0a 7b  _EXCEPTION. */.{
5400: 0a 20 20 20 20 54 63 6c 5f 43 68 61 6e 6e 65 6c  .    Tcl_Channel
5410: 20 20 20 20 20 64 6f 77 6e 43 68 61 6e 3b 0a 20       downChan;. 
5420: 20 20 20 53 74 61 74 65 20 2a 73 74 61 74 65 50     State *stateP
5430: 74 72 20 3d 20 28 53 74 61 74 65 20 2a 29 69 6e  tr = (State *)in
5440: 73 74 61 6e 63 65 44 61 74 61 3b 0a 0a 20 20 20  stanceData;..   
5450: 20 64 70 72 69 6e 74 66 28 22 54 6c 73 57 61 74   dprintf("TlsWat
5460: 63 68 50 72 6f 63 28 30 78 25 78 29 22 2c 20 6d  chProc(0x%x)", m
5470: 61 73 6b 29 3b 0a 0a 20 20 20 20 2f 2a 20 50 72  ask);..    /* Pr
5480: 65 74 65 6e 64 20 74 6f 20 62 65 20 64 65 61 64  etend to be dead
5490: 20 61 73 20 6c 6f 6e 67 20 61 73 20 74 68 65 20   as long as the 
54a0: 76 65 72 69 66 79 20 63 61 6c 6c 62 61 63 6b 20  verify callback 
54b0: 69 73 20 72 75 6e 6e 69 6e 67 2e 0a 20 20 20 20  is running..    
54c0: 20 2a 20 4f 74 68 65 72 77 69 73 65 20 74 68 61   * Otherwise tha
54d0: 74 20 63 61 6c 6c 62 61 63 6b 20 63 6f 75 6c 64  t callback could
54e0: 20 62 65 20 69 6e 76 6f 6b 65 64 20 72 65 63 75   be invoked recu
54f0: 72 73 69 76 65 6c 79 2e 20 2a 2f 0a 20 20 20 20  rsively. */.    
5500: 69 66 20 28 73 74 61 74 65 50 74 72 2d 3e 66 6c  if (statePtr->fl
5510: 61 67 73 20 26 20 54 4c 53 5f 54 43 4c 5f 43 41  ags & TLS_TCL_CA
5520: 4c 4c 42 41 43 4b 29 20 7b 0a 09 64 70 72 69 6e  LLBACK) {..dprin
5530: 74 66 28 22 43 61 6c 6c 62 61 63 6b 20 69 73 20  tf("Callback is 
5540: 6f 6e 2d 67 6f 69 6e 67 2c 20 64 6f 69 6e 67 20  on-going, doing 
5550: 6e 6f 74 68 69 6e 67 22 29 3b 0a 09 72 65 74 75  nothing");..retu
5560: 72 6e 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 64  rn;.    }..    d
5570: 70 72 69 6e 74 46 6c 61 67 73 28 73 74 61 74 65  printFlags(state
5580: 50 74 72 29 3b 0a 0a 20 20 20 20 64 6f 77 6e 43  Ptr);..    downC
5590: 68 61 6e 20 3d 20 54 6c 73 5f 47 65 74 50 61 72  han = Tls_GetPar
55a0: 65 6e 74 28 73 74 61 74 65 50 74 72 2c 20 54 4c  ent(statePtr, TL
55b0: 53 5f 54 43 4c 5f 46 41 53 54 50 41 54 48 29 3b  S_TCL_FASTPATH);
55c0: 0a 0a 20 20 20 20 69 66 20 28 73 74 61 74 65 50  ..    if (stateP
55d0: 74 72 2d 3e 66 6c 61 67 73 20 26 20 54 4c 53 5f  tr->flags & TLS_
55e0: 54 43 4c 5f 48 41 4e 44 53 48 41 4b 45 5f 46 41  TCL_HANDSHAKE_FA
55f0: 49 4c 45 44 29 20 7b 0a 09 64 70 72 69 6e 74 66  ILED) {..dprintf
5600: 28 22 41 73 6b 65 64 20 74 6f 20 77 61 74 63 68  ("Asked to watch
5610: 20 61 20 73 6f 63 6b 65 74 20 77 69 74 68 20 61   a socket with a
5620: 20 66 61 69 6c 65 64 20 68 61 6e 64 73 68 61 6b   failed handshak
5630: 65 20 2d 2d 20 6e 6f 74 68 69 6e 67 20 63 61 6e  e -- nothing can
5640: 20 68 61 70 70 65 6e 20 68 65 72 65 22 29 3b 0a   happen here");.
5650: 09 64 70 72 69 6e 74 66 28 22 55 6e 72 65 67 69  .dprintf("Unregi
5660: 73 74 65 72 69 6e 67 20 69 6e 74 65 72 65 73 74  stering interest
5670: 20 69 6e 20 74 68 65 20 6c 6f 77 65 72 20 63 68   in the lower ch
5680: 61 6e 6e 65 6c 22 29 3b 0a 0a 09 54 63 6c 5f 47  annel");...Tcl_G
5690: 65 74 43 68 61 6e 6e 65 6c 54 79 70 65 28 64 6f  etChannelType(do
56a0: 77 6e 43 68 61 6e 29 2d 3e 77 61 74 63 68 50 72  wnChan)->watchPr
56b0: 6f 63 28 54 63 6c 5f 47 65 74 43 68 61 6e 6e 65  oc(Tcl_GetChanne
56c0: 6c 49 6e 73 74 61 6e 63 65 44 61 74 61 28 64 6f  lInstanceData(do
56d0: 77 6e 43 68 61 6e 29 2c 20 30 29 3b 0a 09 73 74  wnChan), 0);..st
56e0: 61 74 65 50 74 72 2d 3e 77 61 74 63 68 4d 61 73  atePtr->watchMas
56f0: 6b 20 3d 20 30 3b 0a 09 72 65 74 75 72 6e 3b 0a  k = 0;..return;.
5700: 20 20 20 20 7d 0a 0a 20 20 20 20 73 74 61 74 65      }..    state
5710: 50 74 72 2d 3e 77 61 74 63 68 4d 61 73 6b 20 3d  Ptr->watchMask =
5720: 20 6d 61 73 6b 3b 0a 0a 20 20 20 20 2f 2a 20 4e   mask;..    /* N
5730: 6f 20 63 68 61 6e 6e 65 6c 20 68 61 6e 64 6c 65  o channel handle
5740: 72 73 20 61 6e 79 20 6d 6f 72 65 2e 20 57 65 20  rs any more. We 
5750: 77 69 6c 6c 20 62 65 20 6e 6f 74 69 66 69 65 64  will be notified
5760: 20 61 75 74 6f 6d 61 74 69 63 61 6c 6c 79 0a 20   automatically. 
5770: 20 20 20 20 2a 20 61 62 6f 75 74 20 65 76 65 6e      * about even
5780: 74 73 20 6f 6e 20 74 68 65 20 63 68 61 6e 6e 65  ts on the channe
5790: 6c 20 62 65 6c 6f 77 20 76 69 61 20 61 20 63 61  l below via a ca
57a0: 6c 6c 20 74 6f 20 6f 75 72 0a 20 20 20 20 20 2a  ll to our.     *
57b0: 20 27 54 72 61 6e 73 66 6f 72 6d 4e 6f 74 69 66   'TransformNotif
57c0: 79 50 72 6f 63 27 2e 20 42 75 74 20 77 65 20 68  yProc'. But we h
57d0: 61 76 65 20 74 6f 20 70 61 73 73 20 74 68 65 20  ave to pass the 
57e0: 69 6e 74 65 72 65 73 74 20 64 6f 77 6e 20 6e 6f  interest down no
57f0: 77 2e 0a 20 20 20 20 20 2a 20 57 65 20 61 72 65  w..     * We are
5800: 20 61 6c 6c 6f 77 65 64 20 74 6f 20 61 64 64 20   allowed to add 
5810: 61 64 64 69 74 69 6f 6e 61 6c 20 27 69 6e 74 65  additional 'inte
5820: 72 65 73 74 27 20 74 6f 20 74 68 65 20 6d 61 73  rest' to the mas
5830: 6b 20 69 66 20 77 65 20 77 61 6e 74 0a 20 20 20  k if we want.   
5840: 20 20 2a 20 74 6f 2e 20 42 75 74 20 74 68 69 73    * to. But this
5850: 20 74 72 61 6e 73 66 6f 72 6d 61 74 69 6f 6e 20   transformation 
5860: 68 61 73 20 6e 6f 20 73 75 63 68 20 69 6e 74 65  has no such inte
5870: 72 65 73 74 2e 20 49 74 20 6a 75 73 74 20 70 61  rest. It just pa
5880: 73 73 65 73 0a 20 20 20 20 20 2a 20 74 68 65 20  sses.     * the 
5890: 72 65 71 75 65 73 74 20 64 6f 77 6e 2c 20 75 6e  request down, un
58a0: 63 68 61 6e 67 65 64 2e 0a 20 20 20 20 20 2a 2f  changed..     */
58b0: 0a 20 20 20 20 64 70 72 69 6e 74 66 28 22 52 65  .    dprintf("Re
58c0: 67 69 73 74 65 72 69 6e 67 20 6f 75 72 20 69 6e  gistering our in
58d0: 74 65 72 65 73 74 20 69 6e 20 74 68 65 20 6c 6f  terest in the lo
58e0: 77 65 72 20 63 68 61 6e 6e 65 6c 20 28 63 68 61  wer channel (cha
58f0: 6e 3d 25 70 29 22 2c 20 28 76 6f 69 64 20 2a 29  n=%p)", (void *)
5900: 20 64 6f 77 6e 43 68 61 6e 29 3b 0a 20 20 20 20   downChan);.    
5910: 54 63 6c 5f 47 65 74 43 68 61 6e 6e 65 6c 54 79  Tcl_GetChannelTy
5920: 70 65 28 64 6f 77 6e 43 68 61 6e 29 2d 3e 77 61  pe(downChan)->wa
5930: 74 63 68 50 72 6f 63 28 54 63 6c 5f 47 65 74 43  tchProc(Tcl_GetC
5940: 68 61 6e 6e 65 6c 49 6e 73 74 61 6e 63 65 44 61  hannelInstanceDa
5950: 74 61 28 64 6f 77 6e 43 68 61 6e 29 2c 20 6d 61  ta(downChan), ma
5960: 73 6b 29 3b 0a 0a 20 20 20 20 2f 2a 0a 20 20 20  sk);..    /*.   
5970: 20 20 2a 20 4d 61 6e 61 67 65 6d 65 6e 74 20 6f    * Management o
5980: 66 20 74 68 65 20 69 6e 74 65 72 6e 61 6c 20 74  f the internal t
5990: 69 6d 65 72 2e 0a 20 20 20 20 20 2a 2f 0a 20 20  imer..     */.  
59a0: 20 20 69 66 20 28 73 74 61 74 65 50 74 72 2d 3e    if (statePtr->
59b0: 74 69 6d 65 72 20 21 3d 20 28 54 63 6c 5f 54 69  timer != (Tcl_Ti
59c0: 6d 65 72 54 6f 6b 65 6e 29 20 4e 55 4c 4c 29 20  merToken) NULL) 
59d0: 7b 0a 09 64 70 72 69 6e 74 66 28 22 41 20 74 69  {..dprintf("A ti
59e0: 6d 65 72 20 77 61 73 20 66 6f 75 6e 64 2c 20 64  mer was found, d
59f0: 65 6c 65 74 69 6e 67 20 69 74 22 29 3b 0a 09 54  eleting it");..T
5a00: 63 6c 5f 44 65 6c 65 74 65 54 69 6d 65 72 48 61  cl_DeleteTimerHa
5a10: 6e 64 6c 65 72 28 73 74 61 74 65 50 74 72 2d 3e  ndler(statePtr->
5a20: 74 69 6d 65 72 29 3b 0a 09 73 74 61 74 65 50 74  timer);..statePt
5a30: 72 2d 3e 74 69 6d 65 72 20 3d 20 28 54 63 6c 5f  r->timer = (Tcl_
5a40: 54 69 6d 65 72 54 6f 6b 65 6e 29 20 4e 55 4c 4c  TimerToken) NULL
5a50: 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 66 20  ;.    }..    if 
5a60: 28 28 6d 61 73 6b 20 26 20 54 43 4c 5f 52 45 41  ((mask & TCL_REA
5a70: 44 41 42 4c 45 29 20 26 26 0a 09 28 28 54 63 6c  DABLE) &&..((Tcl
5a80: 5f 49 6e 70 75 74 42 75 66 66 65 72 65 64 28 73  _InputBuffered(s
5a90: 74 61 74 65 50 74 72 2d 3e 73 65 6c 66 29 20 3e  tatePtr->self) >
5aa0: 20 30 29 20 7c 7c 20 28 42 49 4f 5f 63 74 72 6c   0) || (BIO_ctrl
5ab0: 5f 70 65 6e 64 69 6e 67 28 73 74 61 74 65 50 74  _pending(statePt
5ac0: 72 2d 3e 62 69 6f 29 20 3e 20 30 29 29 29 20 7b  r->bio) > 0))) {
5ad0: 0a 09 2f 2a 0a 09 20 2a 20 54 68 65 72 65 20 69  ../*.. * There i
5ae0: 73 20 69 6e 74 65 72 65 73 74 20 69 6e 20 72 65  s interest in re
5af0: 61 64 61 62 6c 65 20 65 76 65 6e 74 73 20 61 6e  adable events an
5b00: 64 20 77 65 20 61 63 74 75 61 6c 6c 79 20 68 61  d we actually ha
5b10: 76 65 0a 09 20 2a 20 64 61 74 61 20 77 61 69 74  ve.. * data wait
5b20: 69 6e 67 2c 20 73 6f 20 67 65 6e 65 72 61 74 65  ing, so generate
5b30: 20 61 20 74 69 6d 65 72 20 74 6f 20 66 6c 75 73   a timer to flus
5b40: 68 20 74 68 61 74 2e 0a 09 20 2a 2f 0a 09 64 70  h that... */..dp
5b50: 72 69 6e 74 66 28 22 43 72 65 61 74 69 6e 67 20  rintf("Creating 
5b60: 61 20 6e 65 77 20 74 69 6d 65 72 20 73 69 6e 63  a new timer sinc
5b70: 65 20 64 61 74 61 20 61 70 70 65 61 72 73 20 74  e data appears t
5b80: 6f 20 62 65 20 77 61 69 74 69 6e 67 22 29 3b 0a  o be waiting");.
5b90: 09 73 74 61 74 65 50 74 72 2d 3e 74 69 6d 65 72  .statePtr->timer
5ba0: 20 3d 20 54 63 6c 5f 43 72 65 61 74 65 54 69 6d   = Tcl_CreateTim
5bb0: 65 72 48 61 6e 64 6c 65 72 28 54 4c 53 5f 54 43  erHandler(TLS_TC
5bc0: 4c 5f 44 45 4c 41 59 2c 20 54 6c 73 43 68 61 6e  L_DELAY, TlsChan
5bd0: 6e 65 6c 48 61 6e 64 6c 65 72 54 69 6d 65 72 2c  nelHandlerTimer,
5be0: 20 73 74 61 74 65 50 74 72 29 3b 0a 20 20 20 20   statePtr);.    
5bf0: 7d 0a 7d 0a 0a 2f 2a 0a 20 2a 2d 2d 2d 2d 2d 2d  }.}../*. *------
5c00: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5c10: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5c20: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5c30: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a  -------------. *
5c40: 0a 20 2a 20 54 6c 73 47 65 74 48 61 6e 64 6c 65  . * TlsGetHandle
5c50: 50 72 6f 63 20 2d 2d 0a 20 2a 0a 20 2a 20 20 20  Proc --. *. *   
5c60: 20 43 61 6c 6c 65 64 20 66 72 6f 6d 20 54 63 6c   Called from Tcl
5c70: 5f 47 65 74 43 68 61 6e 6e 65 6c 46 69 6c 65 20  _GetChannelFile 
5c80: 74 6f 20 72 65 74 72 69 65 76 65 20 6f 2f 73 20  to retrieve o/s 
5c90: 66 69 6c 65 20 68 61 6e 64 6c 65 72 0a 20 2a 20  file handler. * 
5ca0: 20 20 20 66 72 6f 6d 20 74 68 65 20 53 53 4c 20     from the SSL 
5cb0: 73 6f 63 6b 65 74 20 62 61 73 65 64 20 63 68 61  socket based cha
5cc0: 6e 6e 65 6c 2e 0a 20 2a 0a 20 2a 20 52 65 73 75  nnel.. *. * Resu
5cd0: 6c 74 73 3a 0a 20 2a 20 20 20 20 54 68 65 20 61  lts:. *    The a
5ce0: 70 70 72 6f 70 72 69 61 74 65 20 54 63 6c 5f 46  ppropriate Tcl_F
5cf0: 69 6c 65 20 68 61 6e 64 6c 65 20 6f 72 20 4e 55  ile handle or NU
5d00: 4c 4c 20 69 66 20 6e 6f 6e 65 2e 0a 20 2a 0a 20  LL if none.. *. 
5d10: 2a 20 53 69 64 65 20 65 66 66 65 63 74 73 3a 0a  * Side effects:.
5d20: 20 2a 20 20 20 20 4e 6f 6e 65 2e 0a 20 2a 0a 20   *    None.. *. 
5d30: 2a 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 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5d60: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5d70: 2d 2d 2d 2d 0a 20 2a 2f 0a 73 74 61 74 69 63 20  ----. */.static 
5d80: 69 6e 74 20 54 6c 73 47 65 74 48 61 6e 64 6c 65  int TlsGetHandle
5d90: 50 72 6f 63 28 0a 20 20 20 20 76 6f 69 64 20 2a  Proc(.    void *
5da0: 69 6e 73 74 61 6e 63 65 44 61 74 61 2c 20 20 20  instanceData,   
5db0: 20 2f 2a 20 53 6f 63 6b 65 74 20 73 74 61 74 65   /* Socket state
5dc0: 2e 20 2a 2f 0a 20 20 20 20 69 6e 74 20 64 69 72  . */.    int dir
5dd0: 65 63 74 69 6f 6e 2c 09 09 2f 2a 20 54 43 4c 5f  ection,../* TCL_
5de0: 52 45 41 44 41 42 4c 45 20 6f 72 20 54 43 4c 5f  READABLE or TCL_
5df0: 57 52 49 54 41 42 4c 45 20 2a 2f 0a 20 20 20 20  WRITABLE */.    
5e00: 76 6f 69 64 20 2a 2a 68 61 6e 64 6c 65 50 74 72  void **handlePtr
5e10: 29 09 2f 2a 20 48 61 6e 64 6c 65 20 61 73 73 6f  )./* Handle asso
5e20: 63 69 61 74 65 64 20 77 69 74 68 20 74 68 65 20  ciated with the 
5e30: 63 68 61 6e 6e 65 6c 20 2a 2f 0a 7b 0a 20 20 20  channel */.{.   
5e40: 20 53 74 61 74 65 20 2a 73 74 61 74 65 50 74 72   State *statePtr
5e50: 20 3d 20 28 53 74 61 74 65 20 2a 29 69 6e 73 74   = (State *)inst
5e60: 61 6e 63 65 44 61 74 61 3b 0a 0a 20 20 20 20 72  anceData;..    r
5e70: 65 74 75 72 6e 20 54 63 6c 5f 47 65 74 43 68 61  eturn Tcl_GetCha
5e80: 6e 6e 65 6c 48 61 6e 64 6c 65 28 54 6c 73 5f 47  nnelHandle(Tls_G
5e90: 65 74 50 61 72 65 6e 74 28 73 74 61 74 65 50 74  etParent(statePt
5ea0: 72 2c 20 54 4c 53 5f 54 43 4c 5f 46 41 53 54 50  r, TLS_TCL_FASTP
5eb0: 41 54 48 29 2c 20 64 69 72 65 63 74 69 6f 6e 2c  ATH), direction,
5ec0: 20 68 61 6e 64 6c 65 50 74 72 29 3b 0a 7d 0a 0a   handlePtr);.}..
5ed0: 2f 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  /*. *-----------
5ee0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5ef0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5f00: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5f10: 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 0a 20 2a 20 54  --------. *. * T
5f20: 6c 73 4e 6f 74 69 66 79 50 72 6f 63 20 2d 2d 0a  lsNotifyProc --.
5f30: 20 2a 0a 20 2a 20 20 20 20 48 61 6e 64 6c 65 72   *. *    Handler
5f40: 20 63 61 6c 6c 65 64 20 62 79 20 54 63 6c 20 74   called by Tcl t
5f50: 6f 20 69 6e 66 6f 72 6d 20 75 73 20 6f 66 20 61  o inform us of a
5f60: 63 74 69 76 69 74 79 0a 20 2a 20 20 20 20 6f 6e  ctivity. *    on
5f70: 20 74 68 65 20 75 6e 64 65 72 6c 79 69 6e 67 20   the underlying 
5f80: 63 68 61 6e 6e 65 6c 2e 0a 20 2a 0a 20 2a 20 52  channel.. *. * R
5f90: 65 73 75 6c 74 73 3a 0a 20 2a 20 20 20 20 54 79  esults:. *    Ty
5fa0: 70 65 20 6f 66 20 65 76 65 6e 74 20 6f 72 20 30  pe of event or 0
5fb0: 20 69 66 20 66 61 69 6c 65 64 0a 20 2a 0a 20 2a   if failed. *. *
5fc0: 20 53 69 64 65 20 65 66 66 65 63 74 73 3a 0a 20   Side effects:. 
5fd0: 2a 20 20 20 20 4d 61 79 20 70 72 6f 63 65 73 73  *    May process
5fe0: 20 74 68 65 20 69 6e 63 6f 6d 69 6e 67 20 65 76   the incoming ev
5ff0: 65 6e 74 20 62 79 20 69 74 73 65 6c 66 2e 0a 20  ent by itself.. 
6000: 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  *. *------------
6010: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6020: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6030: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6040: 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 2f 0a 0a 73 74 61  -------. */..sta
6050: 74 69 63 20 69 6e 74 20 54 6c 73 4e 6f 74 69 66  tic int TlsNotif
6060: 79 50 72 6f 63 28 0a 20 20 20 20 76 6f 69 64 20  yProc(.    void 
6070: 2a 69 6e 73 74 61 6e 63 65 44 61 74 61 2c 20 20  *instanceData,  
6080: 20 20 2f 2a 20 53 6f 63 6b 65 74 20 73 74 61 74    /* Socket stat
6090: 65 2e 20 2a 2f 0a 20 20 20 20 69 6e 74 20 6d 61  e. */.    int ma
60a0: 73 6b 29 09 09 09 2f 2a 20 74 79 70 65 20 6f 66  sk).../* type of
60b0: 20 65 76 65 6e 74 20 74 68 61 74 20 6f 63 63 75   event that occu
60c0: 72 72 65 64 3a 0a 09 09 09 09 20 2a 20 4f 52 2d  rred:..... * OR-
60d0: 65 64 20 63 6f 6d 62 69 6e 61 74 69 6f 6e 20 6f  ed combination o
60e0: 66 20 54 43 4c 5f 52 45 41 44 41 42 4c 45 20 6f  f TCL_READABLE o
60f0: 72 20 54 43 4c 5f 57 52 49 54 41 42 4c 45 20 2a  r TCL_WRITABLE *
6100: 2f 0a 7b 0a 20 20 20 20 53 74 61 74 65 20 2a 73  /.{.    State *s
6110: 74 61 74 65 50 74 72 20 3d 20 28 53 74 61 74 65  tatePtr = (State
6120: 20 2a 29 69 6e 73 74 61 6e 63 65 44 61 74 61 3b   *)instanceData;
6130: 0a 20 20 20 20 69 6e 74 20 65 72 72 6f 72 43 6f  .    int errorCo
6140: 64 65 3b 0a 0a 20 20 20 20 2f 2a 0a 20 20 20 20  de;..    /*.    
6150: 20 2a 20 41 6e 20 65 76 65 6e 74 20 6f 63 63 75   * An event occu
6160: 72 72 65 64 20 69 6e 20 74 68 65 20 75 6e 64 65  rred in the unde
6170: 72 6c 79 69 6e 67 20 63 68 61 6e 6e 65 6c 2e 20  rlying channel. 
6180: 20 54 68 69 73 0a 20 20 20 20 20 2a 20 74 72 61   This.     * tra
6190: 6e 73 66 6f 72 6d 61 74 69 6f 6e 20 64 6f 65 73  nsformation does
61a0: 6e 27 74 20 70 72 6f 63 65 73 73 20 73 75 63 68  n't process such
61b0: 20 65 76 65 6e 74 73 20 74 68 75 73 20 72 65 74   events thus ret
61c0: 75 72 6e 73 20 74 68 65 0a 20 20 20 20 20 2a 20  urns the.     * 
61d0: 69 6e 63 6f 6d 69 6e 67 20 6d 61 73 6b 20 75 6e  incoming mask un
61e0: 63 68 61 6e 67 65 64 2e 0a 20 20 20 20 20 2a 2f  changed..     */
61f0: 0a 20 20 20 20 69 66 20 28 73 74 61 74 65 50 74  .    if (statePt
6200: 72 2d 3e 74 69 6d 65 72 20 21 3d 20 28 54 63 6c  r->timer != (Tcl
6210: 5f 54 69 6d 65 72 54 6f 6b 65 6e 29 20 4e 55 4c  _TimerToken) NUL
6220: 4c 29 20 7b 0a 09 2f 2a 0a 09 20 2a 20 44 65 6c  L) {../*.. * Del
6230: 65 74 65 20 61 6e 20 65 78 69 73 74 69 6e 67 20  ete an existing 
6240: 74 69 6d 65 72 2e 20 49 74 20 77 61 73 20 6e 6f  timer. It was no
6250: 74 20 66 69 72 65 64 2c 20 79 65 74 20 77 65 20  t fired, yet we 
6260: 61 72 65 0a 09 20 2a 20 68 65 72 65 2c 20 73 6f  are.. * here, so
6270: 20 74 68 65 20 63 68 61 6e 6e 65 6c 20 62 65 6c   the channel bel
6280: 6f 77 20 67 65 6e 65 72 61 74 65 64 20 73 75 63  ow generated suc
6290: 68 20 61 6e 20 65 76 65 6e 74 20 61 6e 64 20 77  h an event and w
62a0: 65 0a 09 20 2a 20 64 6f 6e 27 74 20 68 61 76 65  e.. * don't have
62b0: 20 74 6f 2e 20 54 68 65 20 72 65 6e 65 77 61 6c   to. The renewal
62c0: 20 6f 66 20 74 68 65 20 69 6e 74 65 72 65 73 74   of the interest
62d0: 20 61 66 74 65 72 20 74 68 65 0a 09 20 2a 20 65   after the.. * e
62e0: 78 65 63 75 74 69 6f 6e 20 6f 66 20 63 68 61 6e  xecution of chan
62f0: 6e 65 6c 20 68 61 6e 64 6c 65 72 73 20 77 69 6c  nel handlers wil
6300: 6c 20 65 76 65 6e 74 75 61 6c 6c 79 20 63 61 75  l eventually cau
6310: 73 65 20 75 73 20 74 6f 0a 09 20 2a 20 72 65 63  se us to.. * rec
6320: 72 65 61 74 65 20 74 68 65 20 74 69 6d 65 72 20  reate the timer 
6330: 28 69 6e 20 57 61 74 63 68 50 72 6f 63 29 2e 0a  (in WatchProc)..
6340: 09 20 2a 2f 0a 09 54 63 6c 5f 44 65 6c 65 74 65  . */..Tcl_Delete
6350: 54 69 6d 65 72 48 61 6e 64 6c 65 72 28 73 74 61  TimerHandler(sta
6360: 74 65 50 74 72 2d 3e 74 69 6d 65 72 29 3b 0a 09  tePtr->timer);..
6370: 73 74 61 74 65 50 74 72 2d 3e 74 69 6d 65 72 20  statePtr->timer 
6380: 3d 20 28 54 63 6c 5f 54 69 6d 65 72 54 6f 6b 65  = (Tcl_TimerToke
6390: 6e 29 20 4e 55 4c 4c 3b 0a 20 20 20 20 7d 0a 0a  n) NULL;.    }..
63a0: 20 20 20 20 69 66 20 28 73 74 61 74 65 50 74 72      if (statePtr
63b0: 2d 3e 66 6c 61 67 73 20 26 20 54 4c 53 5f 54 43  ->flags & TLS_TC
63c0: 4c 5f 43 41 4c 4c 42 41 43 4b 29 20 7b 0a 09 64  L_CALLBACK) {..d
63d0: 70 72 69 6e 74 66 28 22 52 65 74 75 72 6e 69 6e  printf("Returnin
63e0: 67 20 30 20 64 75 65 20 74 6f 20 63 61 6c 6c 62  g 0 due to callb
63f0: 61 63 6b 22 29 3b 0a 09 72 65 74 75 72 6e 20 30  ack");..return 0
6400: 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 64 70 72  ;.    }..    dpr
6410: 69 6e 74 66 28 22 43 61 6c 6c 69 6e 67 20 54 6c  intf("Calling Tl
6420: 73 5f 57 61 69 74 46 6f 72 43 6f 6e 6e 65 63 74  s_WaitForConnect
6430: 22 29 3b 0a 20 20 20 20 65 72 72 6f 72 43 6f 64  ");.    errorCod
6440: 65 20 3d 20 30 3b 0a 20 20 20 20 69 66 20 28 54  e = 0;.    if (T
6450: 6c 73 5f 57 61 69 74 46 6f 72 43 6f 6e 6e 65 63  ls_WaitForConnec
6460: 74 28 73 74 61 74 65 50 74 72 2c 20 26 65 72 72  t(statePtr, &err
6470: 6f 72 43 6f 64 65 2c 20 31 29 20 3c 20 30 29 20  orCode, 1) < 0) 
6480: 7b 0a 09 54 6c 73 5f 45 72 72 6f 72 28 73 74 61  {..Tls_Error(sta
6490: 74 65 50 74 72 2c 20 73 74 72 65 72 72 6f 72 28  tePtr, strerror(
64a0: 65 72 72 6f 72 43 6f 64 65 29 29 3b 0a 09 69 66  errorCode));..if
64b0: 20 28 65 72 72 6f 72 43 6f 64 65 20 3d 3d 20 45   (errorCode == E
64c0: 41 47 41 49 4e 29 20 7b 0a 09 20 20 20 20 64 70  AGAIN) {..    dp
64d0: 72 69 6e 74 66 28 22 41 73 79 6e 63 20 66 6c 61  rintf("Async fla
64e0: 67 20 63 6f 75 6c 64 20 62 65 20 73 65 74 20 28  g could be set (
64f0: 64 69 64 6e 27 74 20 63 68 65 63 6b 29 20 61 6e  didn't check) an
6500: 64 20 65 72 72 6f 72 43 6f 64 65 20 3d 3d 20 45  d errorCode == E
6510: 41 47 41 49 4e 3a 20 20 52 65 74 75 72 6e 69 6e  AGAIN:  Returnin
6520: 67 20 30 22 29 3b 0a 0a 09 20 20 20 20 72 65 74  g 0");...    ret
6530: 75 72 6e 20 30 3b 0a 09 7d 0a 0a 09 64 70 72 69  urn 0;..}...dpri
6540: 6e 74 66 28 22 54 6c 73 5f 57 61 69 74 46 6f 72  ntf("Tls_WaitFor
6550: 43 6f 6e 6e 65 63 74 20 72 65 74 75 72 6e 65 64  Connect returned
6560: 20 61 6e 20 65 72 72 6f 72 22 29 3b 0a 20 20 20   an error");.   
6570: 20 7d 0a 0a 20 20 20 20 64 70 72 69 6e 74 66 28   }..    dprintf(
6580: 22 52 65 74 75 72 6e 69 6e 67 20 25 69 22 2c 20  "Returning %i", 
6590: 6d 61 73 6b 29 3b 0a 0a 20 20 20 20 72 65 74 75  mask);..    retu
65a0: 72 6e 20 6d 61 73 6b 3b 0a 7d 0a 0a 2f 2a 0a 20  rn mask;.}../*. 
65b0: 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  *---------------
65c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
65d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
65e0: 2d 2d 2d 2d 2d 2d 2d 2a 0a 20 2a 0a 20 2a 20 20  -------*. *. *  
65f0: 20 20 54 6c 73 43 68 61 6e 6e 65 6c 48 61 6e 64    TlsChannelHand
6600: 6c 65 72 54 69 6d 65 72 20 2d 2d 0a 20 2a 0a 20  lerTimer --. *. 
6610: 2a 20 20 20 20 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  *    -----------
6620: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6630: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6640: 2d 2d 2d 2d 2d 2a 0a 20 2a 20 20 20 20 43 61 6c  -----*. *    Cal
6650: 6c 65 64 20 62 79 20 74 68 65 20 6e 6f 74 69 66  led by the notif
6660: 69 65 72 20 28 2d 3e 20 74 69 6d 65 72 29 20 74  ier (-> timer) t
6670: 6f 20 66 6c 75 73 68 20 6f 75 74 0a 20 2a 20 20  o flush out. *  
6680: 20 20 69 6e 66 6f 72 6d 61 74 69 6f 6e 20 77 61    information wa
6690: 69 74 69 6e 67 20 69 6e 20 63 68 61 6e 6e 65 6c  iting in channel
66a0: 20 62 75 66 66 65 72 73 2e 0a 20 2a 20 20 20 20   buffers.. *    
66b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
66c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
66d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
66e0: 2a 0a 20 2a 0a 20 2a 20 20 20 20 53 69 64 65 20  *. *. *    Side 
66f0: 65 66 66 65 63 74 73 3a 0a 20 2a 20 20 20 20 20  effects:. *     
6700: 20 20 20 41 73 20 6f 66 20 27 54 6c 73 43 68 61     As of 'TlsCha
6710: 6e 6e 65 6c 48 61 6e 64 6c 65 72 27 2e 0a 20 2a  nnelHandler'.. *
6720: 0a 20 2a 20 20 20 20 52 65 73 75 6c 74 3a 0a 20  . *    Result:. 
6730: 2a 20 20 20 20 20 20 20 20 4e 6f 6e 65 2e 0a 20  *        None.. 
6740: 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  *. *------------
6750: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6760: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6770: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2a 0a 20 2a 2f 0a  ----------*. */.
6780: 73 74 61 74 69 63 20 76 6f 69 64 20 54 6c 73 43  static void TlsC
6790: 68 61 6e 6e 65 6c 48 61 6e 64 6c 65 72 54 69 6d  hannelHandlerTim
67a0: 65 72 28 76 6f 69 64 20 2a 63 6c 69 65 6e 74 44  er(void *clientD
67b0: 61 74 61 29 20 7b 0a 20 20 20 20 53 74 61 74 65  ata) {.    State
67c0: 20 2a 73 74 61 74 65 50 74 72 20 3d 20 28 53 74   *statePtr = (St
67d0: 61 74 65 20 2a 29 63 6c 69 65 6e 74 44 61 74 61  ate *)clientData
67e0: 3b 0a 20 20 20 20 69 6e 74 20 6d 61 73 6b 20 3d  ;.    int mask =
67f0: 20 30 3b 0a 0a 20 20 20 20 64 70 72 69 6e 74 66   0;..    dprintf
6800: 28 22 43 61 6c 6c 65 64 22 29 3b 0a 0a 20 20 20  ("Called");..   
6810: 20 73 74 61 74 65 50 74 72 2d 3e 74 69 6d 65 72   statePtr->timer
6820: 20 3d 20 28 54 63 6c 5f 54 69 6d 65 72 54 6f 6b   = (Tcl_TimerTok
6830: 65 6e 29 20 4e 55 4c 4c 3b 0a 0a 20 20 20 20 69  en) NULL;..    i
6840: 66 20 28 42 49 4f 5f 77 70 65 6e 64 69 6e 67 28  f (BIO_wpending(
6850: 73 74 61 74 65 50 74 72 2d 3e 62 69 6f 29 29 20  statePtr->bio)) 
6860: 7b 0a 09 64 70 72 69 6e 74 66 28 22 5b 63 68 61  {..dprintf("[cha
6870: 6e 3d 25 70 5d 20 42 49 4f 20 77 72 69 74 61 62  n=%p] BIO writab
6880: 6c 65 22 2c 20 73 74 61 74 65 50 74 72 2d 3e 73  le", statePtr->s
6890: 65 6c 66 29 3b 0a 0a 09 6d 61 73 6b 20 7c 3d 20  elf);...mask |= 
68a0: 54 43 4c 5f 57 52 49 54 41 42 4c 45 3b 0a 20 20  TCL_WRITABLE;.  
68b0: 20 20 7d 0a 0a 20 20 20 20 69 66 20 28 42 49 4f    }..    if (BIO
68c0: 5f 70 65 6e 64 69 6e 67 28 73 74 61 74 65 50 74  _pending(statePt
68d0: 72 2d 3e 62 69 6f 29 29 20 7b 0a 09 64 70 72 69  r->bio)) {..dpri
68e0: 6e 74 66 28 22 5b 63 68 61 6e 3d 25 70 5d 20 42  ntf("[chan=%p] B
68f0: 49 4f 20 72 65 61 64 61 62 6c 65 22 2c 20 73 74  IO readable", st
6900: 61 74 65 50 74 72 2d 3e 73 65 6c 66 29 3b 0a 0a  atePtr->self);..
6910: 09 6d 61 73 6b 20 7c 3d 20 54 43 4c 5f 52 45 41  .mask |= TCL_REA
6920: 44 41 42 4c 45 3b 0a 20 20 20 20 7d 0a 0a 20 20  DABLE;.    }..  
6930: 20 20 64 70 72 69 6e 74 66 28 22 4e 6f 74 69 66    dprintf("Notif
6940: 79 69 6e 67 20 6f 75 72 73 65 6c 76 65 73 22 29  ying ourselves")
6950: 3b 0a 20 20 20 20 54 63 6c 5f 4e 6f 74 69 66 79  ;.    Tcl_Notify
6960: 43 68 61 6e 6e 65 6c 28 73 74 61 74 65 50 74 72  Channel(statePtr
6970: 2d 3e 73 65 6c 66 2c 20 6d 61 73 6b 29 3b 0a 0a  ->self, mask);..
6980: 20 20 20 20 64 70 72 69 6e 74 66 28 22 52 65 74      dprintf("Ret
6990: 75 72 6e 69 6e 67 22 29 3b 0a 0a 20 20 20 20 72  urning");..    r
69a0: 65 74 75 72 6e 3b 0a 7d 0a 0a 54 63 6c 5f 43 68  eturn;.}..Tcl_Ch
69b0: 61 6e 6e 65 6c 20 54 6c 73 5f 47 65 74 50 61 72  annel Tls_GetPar
69c0: 65 6e 74 28 53 74 61 74 65 20 2a 73 74 61 74 65  ent(State *state
69d0: 50 74 72 2c 20 69 6e 74 20 6d 61 73 6b 46 6c 61  Ptr, int maskFla
69e0: 67 73 29 20 7b 0a 20 20 20 20 64 70 72 69 6e 74  gs) {.    dprint
69f0: 66 28 22 52 65 71 75 65 73 74 65 64 20 74 6f 20  f("Requested to 
6a00: 67 65 74 20 70 61 72 65 6e 74 20 6f 66 20 63 68  get parent of ch
6a10: 61 6e 6e 65 6c 20 25 70 22 2c 20 73 74 61 74 65  annel %p", state
6a20: 50 74 72 2d 3e 73 65 6c 66 29 3b 0a 0a 20 20 20  Ptr->self);..   
6a30: 20 69 66 20 28 28 73 74 61 74 65 50 74 72 2d 3e   if ((statePtr->
6a40: 66 6c 61 67 73 20 26 20 7e 6d 61 73 6b 46 6c 61  flags & ~maskFla
6a50: 67 73 29 20 26 20 54 4c 53 5f 54 43 4c 5f 46 41  gs) & TLS_TCL_FA
6a60: 53 54 50 41 54 48 29 20 7b 0a 09 64 70 72 69 6e  STPATH) {..dprin
6a70: 74 66 28 22 41 73 6b 65 64 20 74 6f 20 67 65 74  tf("Asked to get
6a80: 20 74 68 65 20 70 61 72 65 6e 74 20 63 68 61 6e   the parent chan
6a90: 6e 65 6c 20 77 68 69 6c 65 20 77 65 20 61 72 65  nel while we are
6aa0: 20 75 73 69 6e 67 20 46 61 73 74 50 61 74 68 20   using FastPath 
6ab0: 2d 2d 20 72 65 74 75 72 6e 69 6e 67 20 4e 55 4c  -- returning NUL
6ac0: 4c 22 29 3b 0a 09 72 65 74 75 72 6e 20 4e 55 4c  L");..return NUL
6ad0: 4c 3b 0a 20 20 20 20 7d 0a 20 20 20 20 72 65 74  L;.    }.    ret
6ae0: 75 72 6e 20 54 63 6c 5f 47 65 74 53 74 61 63 6b  urn Tcl_GetStack
6af0: 65 64 43 68 61 6e 6e 65 6c 28 73 74 61 74 65 50  edChannel(stateP
6b00: 74 72 2d 3e 73 65 6c 66 29 3b 0a 7d 0a 0a 2f 2a  tr->self);.}../*
6b10: 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  . *-------------
6b20: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6b30: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6b40: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6b50: 2d 2d 2d 2d 2d 2d 0a 20 2a 0a 20 2a 20 54 6c 73  ------. *. * Tls
6b60: 5f 43 68 61 6e 6e 65 6c 54 79 70 65 20 2d 2d 0a  _ChannelType --.
6b70: 20 2a 0a 20 2a 20 20 20 20 52 65 74 75 72 6e 20   *. *    Return 
6b80: 74 68 65 20 63 6f 72 72 65 63 74 20 54 4c 53 20  the correct TLS 
6b90: 63 68 61 6e 6e 65 6c 20 64 72 69 76 65 72 20 69  channel driver i
6ba0: 6e 66 6f 0a 20 2a 0a 20 2a 20 52 65 73 75 6c 74  nfo. *. * Result
6bb0: 73 3a 0a 20 2a 20 20 20 20 54 68 65 20 63 6f 72  s:. *    The cor
6bc0: 72 65 63 74 20 63 68 61 6e 6e 65 6c 20 64 72 69  rect channel dri
6bd0: 76 65 72 20 66 6f 72 20 74 68 65 20 63 75 72 72  ver for the curr
6be0: 65 6e 74 20 76 65 72 73 69 6f 6e 20 6f 66 20 54  ent version of T
6bf0: 63 6c 2e 0a 20 2a 0a 20 2a 20 53 69 64 65 20 65  cl.. *. * Side e
6c00: 66 66 65 63 74 73 3a 0a 20 2a 20 20 20 20 4e 6f  ffects:. *    No
6c10: 6e 65 2e 0a 20 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d  ne.. *. *-------
6c20: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6c30: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6c40: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6c50: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 2f  ------------. */
6c60: 0a 73 74 61 74 69 63 20 63 6f 6e 73 74 20 54 63  .static const Tc
6c70: 6c 5f 43 68 61 6e 6e 65 6c 54 79 70 65 20 74 6c  l_ChannelType tl
6c80: 73 43 68 61 6e 6e 65 6c 54 79 70 65 20 3d 20 7b  sChannelType = {
6c90: 0a 20 20 20 20 22 74 6c 73 22 2c 09 09 09 2f 2a  .    "tls",.../*
6ca0: 20 54 79 70 65 20 6e 61 6d 65 20 2a 2f 0a 20 20   Type name */.  
6cb0: 20 20 54 43 4c 5f 43 48 41 4e 4e 45 4c 5f 56 45    TCL_CHANNEL_VE
6cc0: 52 53 49 4f 4e 5f 35 2c 09 2f 2a 20 76 35 20 63  RSION_5,./* v5 c
6cd0: 68 61 6e 6e 65 6c 20 2a 2f 0a 20 20 20 20 54 6c  hannel */.    Tl
6ce0: 73 43 6c 6f 73 65 50 72 6f 63 2c 09 09 2f 2a 20  sCloseProc,../* 
6cf0: 43 6c 6f 73 65 20 70 72 6f 63 20 2a 2f 0a 20 20  Close proc */.  
6d00: 20 20 54 6c 73 49 6e 70 75 74 50 72 6f 63 2c 09    TlsInputProc,.
6d10: 09 2f 2a 20 49 6e 70 75 74 20 70 72 6f 63 20 2a  ./* Input proc *
6d20: 2f 0a 20 20 20 20 54 6c 73 4f 75 74 70 75 74 50  /.    TlsOutputP
6d30: 72 6f 63 2c 09 09 2f 2a 20 4f 75 74 70 75 74 20  roc,../* Output 
6d40: 70 72 6f 63 20 2a 2f 0a 20 20 20 20 30 2c 09 09  proc */.    0,..
6d50: 09 2f 2a 20 53 65 65 6b 20 70 72 6f 63 20 2a 2f  ./* Seek proc */
6d60: 0a 20 20 20 20 54 6c 73 53 65 74 4f 70 74 69 6f  .    TlsSetOptio
6d70: 6e 50 72 6f 63 2c 09 09 2f 2a 20 53 65 74 20 6f  nProc,../* Set o
6d80: 70 74 69 6f 6e 20 70 72 6f 63 20 2a 2f 0a 20 20  ption proc */.  
6d90: 20 20 54 6c 73 47 65 74 4f 70 74 69 6f 6e 50 72    TlsGetOptionPr
6da0: 6f 63 2c 09 09 2f 2a 20 47 65 74 20 6f 70 74 69  oc,../* Get opti
6db0: 6f 6e 20 70 72 6f 63 20 2a 2f 0a 20 20 20 20 54  on proc */.    T
6dc0: 6c 73 57 61 74 63 68 50 72 6f 63 2c 09 09 2f 2a  lsWatchProc,../*
6dd0: 20 49 6e 69 74 69 61 6c 69 7a 65 20 6e 6f 74 69   Initialize noti
6de0: 66 69 65 72 20 2a 2f 0a 20 20 20 20 54 6c 73 47  fier */.    TlsG
6df0: 65 74 48 61 6e 64 6c 65 50 72 6f 63 2c 09 09 2f  etHandleProc,../
6e00: 2a 20 47 65 74 20 4f 53 20 68 61 6e 64 6c 65 73  * Get OS handles
6e10: 20 6f 75 74 20 6f 66 20 63 68 61 6e 6e 65 6c 20   out of channel 
6e20: 2a 2f 0a 20 20 20 20 54 6c 73 43 6c 6f 73 65 32  */.    TlsClose2
6e30: 50 72 6f 63 2c 09 09 2f 2a 20 63 6c 6f 73 65 32  Proc,../* close2
6e40: 70 72 6f 63 20 2a 2f 0a 20 20 20 20 54 6c 73 42  proc */.    TlsB
6e50: 6c 6f 63 6b 4d 6f 64 65 50 72 6f 63 2c 09 09 2f  lockModeProc,../
6e60: 2a 20 53 65 74 20 62 6c 6f 63 6b 69 6e 67 2f 6e  * Set blocking/n
6e70: 6f 6e 62 6c 6f 63 6b 69 6e 67 20 6d 6f 64 65 2a  onblocking mode*
6e80: 2f 0a 20 20 20 20 30 2c 09 09 09 2f 2a 20 46 6c  /.    0,.../* Fl
6e90: 75 73 68 20 70 72 6f 63 20 2a 2f 0a 20 20 20 20  ush proc */.    
6ea0: 54 6c 73 4e 6f 74 69 66 79 50 72 6f 63 2c 09 09  TlsNotifyProc,..
6eb0: 2f 2a 20 48 61 6e 64 6c 69 6e 67 20 6f 66 20 65  /* Handling of e
6ec0: 76 65 6e 74 73 20 62 75 62 62 6c 69 6e 67 20 75  vents bubbling u
6ed0: 70 20 2a 2f 0a 20 20 20 20 30 2c 09 09 09 2f 2a  p */.    0,.../*
6ee0: 20 57 69 64 65 20 73 65 65 6b 20 70 72 6f 63 20   Wide seek proc 
6ef0: 2a 2f 0a 20 20 20 20 4e 55 4c 4c 2c 09 09 09 2f  */.    NULL,.../
6f00: 2a 20 54 68 72 65 61 64 20 61 63 74 69 6f 6e 20  * Thread action 
6f10: 2a 2f 0a 20 20 20 20 4e 55 4c 4c 09 09 09 2f 2a  */.    NULL.../*
6f20: 20 54 72 75 6e 63 61 74 65 20 2a 2f 0a 7d 3b 0a   Truncate */.};.
6f30: 0a 63 6f 6e 73 74 20 54 63 6c 5f 43 68 61 6e 6e  .const Tcl_Chann
6f40: 65 6c 54 79 70 65 20 2a 54 6c 73 5f 43 68 61 6e  elType *Tls_Chan
6f50: 6e 65 6c 54 79 70 65 28 76 6f 69 64 29 20 7b 0a  nelType(void) {.
6f60: 20 20 20 20 72 65 74 75 72 6e 20 26 74 6c 73 43      return &tlsC
6f70: 68 61 6e 6e 65 6c 54 79 70 65 3b 0a 7d 0a        hannelType;.}.