Hex Artifact Content

Artifact d750d9a25498a5745aafdf4669f35b4172f55582:


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: 0a 20 2a 20 24 48 65 61 64 65 72 3a 20 2f 68 6f  . * $Header: /ho
0050: 6d 65 2f 72 6b 65 65 6e 65 2f 74 6d 70 2f 63 76  me/rkeene/tmp/cv
0060: 73 32 66 6f 73 73 69 6c 2f 2e 2e 2f 74 63 6c 74  s2fossil/../tclt
0070: 6c 73 2f 74 6c 73 2f 74 6c 73 2f 74 6c 73 49 4f  ls/tls/tls/tlsIO
0080: 2e 63 2c 76 20 31 2e 37 2e 32 2e 33 20 32 30 30  .c,v 1.7.2.3 200
0090: 30 2f 30 37 2f 32 31 20 30 35 3a 33 32 3a 35 37  0/07/21 05:32:57
00a0: 20 68 6f 62 62 73 20 45 78 70 20 24 0a 20 2a 0a   hobbs Exp $. *.
00b0: 20 2a 20 54 4c 53 20 28 61 6b 61 20 53 53 4c 29   * TLS (aka SSL)
00c0: 20 43 68 61 6e 6e 65 6c 20 2d 20 63 61 6e 20 62   Channel - can b
00d0: 65 20 6c 61 79 65 72 65 64 20 6f 6e 20 61 6e 79  e layered on any
00e0: 20 62 69 2d 64 69 72 65 63 74 69 6f 6e 61 6c 0a   bi-directional.
00f0: 20 2a 20 54 63 6c 5f 43 68 61 6e 6e 65 6c 20 28   * Tcl_Channel (
0100: 4e 6f 74 65 3a 20 52 65 71 75 69 72 65 73 20 54  Note: Requires T
0110: 72 66 20 43 6f 72 65 20 50 61 74 63 68 29 0a 20  rf Core Patch). 
0120: 2a 0a 20 2a 20 54 68 69 73 20 77 61 73 20 62 75  *. * This was bu
0130: 69 6c 74 20 66 72 6f 6d 20 73 63 72 61 74 63 68  ilt from scratch
0140: 20 62 61 73 65 64 20 75 70 6f 6e 20 6f 62 73 65   based upon obse
0150: 72 76 61 74 69 6f 6e 20 6f 66 20 4f 70 65 6e 53  rvation of OpenS
0160: 53 4c 20 30 2e 39 2e 32 42 0a 20 2a 0a 20 2a 20  SL 0.9.2B. *. * 
0170: 41 64 64 69 74 69 6f 6e 20 63 72 65 64 69 74 20  Addition credit 
0180: 69 73 20 64 75 65 20 66 6f 72 20 41 6e 64 72 65  is due for Andre
0190: 61 73 20 4b 75 70 72 69 65 73 20 28 61 2e 6b 75  as Kupries (a.ku
01a0: 70 72 69 65 73 40 77 65 73 74 65 6e 64 2e 63 6f  pries@westend.co
01b0: 6d 29 2c 20 66 6f 72 0a 20 2a 20 70 72 6f 76 69  m), for. * provi
01c0: 64 69 6e 67 20 74 68 65 20 54 63 6c 5f 52 65 70  ding the Tcl_Rep
01d0: 6c 61 63 65 43 68 61 6e 6e 65 6c 20 6d 65 63 68  laceChannel mech
01e0: 61 6e 69 73 6d 20 61 6e 64 20 77 6f 72 6b 69 6e  anism and workin
01f0: 67 20 63 6c 6f 73 65 6c 79 20 77 69 74 68 20 6d  g closely with m
0200: 65 0a 20 2a 20 74 6f 20 65 6e 68 61 6e 63 65 20  e. * to enhance 
0210: 69 74 20 74 6f 20 73 75 70 70 6f 72 74 20 66 75  it to support fu
0220: 6c 6c 20 66 69 6c 65 65 76 65 6e 74 20 73 65 6d  ll fileevent sem
0230: 61 6e 74 69 63 73 2e 0a 20 2a 0a 20 2a 20 41 6c  antics.. *. * Al
0240: 73 6f 20 77 6f 72 6b 20 64 6f 6e 65 20 62 79 20  so work done by 
0250: 74 68 65 20 66 6f 6c 6c 6f 77 20 70 65 6f 70 6c  the follow peopl
0260: 65 20 70 72 6f 76 69 64 65 64 20 74 68 65 20 69  e provided the i
0270: 6d 70 65 74 75 73 20 74 6f 20 64 6f 20 74 68 69  mpetus to do thi
0280: 73 20 22 72 69 67 68 74 22 3a 0a 20 2a 09 74 63  s "right":. *.tc
0290: 6c 53 53 4c 20 28 43 6f 6c 69 6e 20 4d 63 43 6f  lSSL (Colin McCo
02a0: 72 6d 61 63 6b 2c 20 53 68 61 72 65 64 20 54 65  rmack, Shared Te
02b0: 63 68 6e 6f 6c 6f 67 79 29 0a 20 2a 09 53 53 4c  chnology). *.SSL
02c0: 74 63 6c 20 28 50 65 74 65 72 20 41 6e 74 6d 61  tcl (Peter Antma
02d0: 6e 29 0a 20 2a 0a 20 2a 2f 0a 0a 23 69 6e 63 6c  n). *. */..#incl
02e0: 75 64 65 20 22 74 6c 73 49 6e 74 2e 68 22 0a 0a  ude "tlsInt.h"..
02f0: 2f 2a 0a 20 2a 20 45 78 74 65 72 6e 61 6c 20 66  /*. * External f
0300: 75 6e 63 74 69 6f 6e 73 0a 20 2a 2f 0a 0a 2f 2a  unctions. */../*
0310: 0a 20 2a 20 4c 6f 63 61 6c 20 44 65 66 69 6e 65  . * Local Define
0320: 73 0a 20 2a 2f 0a 0a 2f 2a 0a 20 2a 20 46 6f 72  s. */../*. * For
0330: 77 61 72 64 20 64 65 63 6c 61 72 61 74 69 6f 6e  ward declaration
0340: 73 0a 20 2a 2f 0a 0a 73 74 61 74 69 63 20 69 6e  s. */..static in
0350: 74 09 54 6c 73 42 6c 6f 63 6b 4d 6f 64 65 50 72  t.TlsBlockModePr
0360: 6f 63 20 5f 41 4e 53 49 5f 41 52 47 53 5f 28 28  oc _ANSI_ARGS_((
0370: 43 6c 69 65 6e 74 44 61 74 61 20 69 6e 73 74 61  ClientData insta
0380: 6e 63 65 44 61 74 61 2c 0a 09 09 09 69 6e 74 20  nceData,....int 
0390: 6d 6f 64 65 29 29 3b 0a 73 74 61 74 69 63 20 69  mode));.static i
03a0: 6e 74 09 54 6c 73 43 6c 6f 73 65 50 72 6f 63 20  nt.TlsCloseProc 
03b0: 5f 41 4e 53 49 5f 41 52 47 53 5f 20 28 28 43 6c  _ANSI_ARGS_ ((Cl
03c0: 69 65 6e 74 44 61 74 61 20 69 6e 73 74 61 6e 63  ientData instanc
03d0: 65 44 61 74 61 2c 0a 09 09 09 54 63 6c 5f 49 6e  eData,....Tcl_In
03e0: 74 65 72 70 20 2a 69 6e 74 65 72 70 29 29 3b 0a  terp *interp));.
03f0: 73 74 61 74 69 63 20 69 6e 74 09 54 6c 73 49 6e  static int.TlsIn
0400: 70 75 74 50 72 6f 63 20 5f 41 4e 53 49 5f 41 52  putProc _ANSI_AR
0410: 47 53 5f 28 28 43 6c 69 65 6e 74 44 61 74 61 20  GS_((ClientData 
0420: 69 6e 73 74 61 6e 63 65 44 61 74 61 2c 0a 09 09  instanceData,...
0430: 09 63 68 61 72 20 2a 62 75 66 2c 20 69 6e 74 20  .char *buf, int 
0440: 62 75 66 53 69 7a 65 2c 20 69 6e 74 20 2a 65 72  bufSize, int *er
0450: 72 6f 72 43 6f 64 65 50 74 72 29 29 3b 0a 73 74  rorCodePtr));.st
0460: 61 74 69 63 20 69 6e 74 09 54 6c 73 4f 75 74 70  atic int.TlsOutp
0470: 75 74 50 72 6f 63 20 5f 41 4e 53 49 5f 41 52 47  utProc _ANSI_ARG
0480: 53 5f 28 28 43 6c 69 65 6e 74 44 61 74 61 20 69  S_((ClientData i
0490: 6e 73 74 61 6e 63 65 44 61 74 61 2c 0a 09 09 09  nstanceData,....
04a0: 63 68 61 72 20 2a 62 75 66 2c 20 69 6e 74 20 74  char *buf, int t
04b0: 6f 57 72 69 74 65 2c 20 69 6e 74 20 2a 65 72 72  oWrite, int *err
04c0: 6f 72 43 6f 64 65 50 74 72 29 29 3b 0a 73 74 61  orCodePtr));.sta
04d0: 74 69 63 20 69 6e 74 09 54 6c 73 47 65 74 4f 70  tic int.TlsGetOp
04e0: 74 69 6f 6e 50 72 6f 63 20 5f 41 4e 53 49 5f 41  tionProc _ANSI_A
04f0: 52 47 53 5f 20 28 28 43 6c 69 65 6e 74 44 61 74  RGS_ ((ClientDat
0500: 61 20 69 6e 73 74 61 6e 63 65 44 61 74 61 2c 0a  a instanceData,.
0510: 09 09 09 54 63 6c 5f 49 6e 74 65 72 70 20 2a 69  ...Tcl_Interp *i
0520: 6e 74 65 72 70 2c 20 63 68 61 72 20 2a 6f 70 74  nterp, char *opt
0530: 69 6f 6e 4e 61 6d 65 2c 0a 09 09 09 54 63 6c 5f  ionName,....Tcl_
0540: 44 53 74 72 69 6e 67 20 2a 64 73 50 74 72 29 29  DString *dsPtr))
0550: 3b 0a 73 74 61 74 69 63 20 76 6f 69 64 09 54 6c  ;.static void.Tl
0560: 73 57 61 74 63 68 50 72 6f 63 20 5f 41 4e 53 49  sWatchProc _ANSI
0570: 5f 41 52 47 53 5f 28 28 43 6c 69 65 6e 74 44 61  _ARGS_((ClientDa
0580: 74 61 20 69 6e 73 74 61 6e 63 65 44 61 74 61 2c  ta instanceData,
0590: 20 69 6e 74 20 6d 61 73 6b 29 29 3b 0a 73 74 61   int mask));.sta
05a0: 74 69 63 20 69 6e 74 09 54 6c 73 47 65 74 48 61  tic int.TlsGetHa
05b0: 6e 64 6c 65 50 72 6f 63 20 5f 41 4e 53 49 5f 41  ndleProc _ANSI_A
05c0: 52 47 53 5f 20 28 28 43 6c 69 65 6e 74 44 61 74  RGS_ ((ClientDat
05d0: 61 20 69 6e 73 74 61 6e 63 65 44 61 74 61 2c 0a  a instanceData,.
05e0: 09 09 09 69 6e 74 20 64 69 72 65 63 74 69 6f 6e  ...int direction
05f0: 2c 20 43 6c 69 65 6e 74 44 61 74 61 20 2a 68 61  , ClientData *ha
0600: 6e 64 6c 65 50 74 72 29 29 3b 0a 73 74 61 74 69  ndlePtr));.stati
0610: 63 20 69 6e 74 09 54 6c 73 4e 6f 74 69 66 79 50  c int.TlsNotifyP
0620: 72 6f 63 20 5f 41 4e 53 49 5f 41 52 47 53 5f 20  roc _ANSI_ARGS_ 
0630: 28 28 43 6c 69 65 6e 74 44 61 74 61 20 69 6e 73  ((ClientData ins
0640: 74 61 6e 63 65 44 61 74 61 2c 0a 09 09 09 69 6e  tanceData,....in
0650: 74 20 6d 61 73 6b 29 29 3b 0a 73 74 61 74 69 63  t mask));.static
0660: 20 76 6f 69 64 09 54 6c 73 43 68 61 6e 6e 65 6c   void.TlsChannel
0670: 48 61 6e 64 6c 65 72 20 5f 41 4e 53 49 5f 41 52  Handler _ANSI_AR
0680: 47 53 5f 20 28 28 43 6c 69 65 6e 74 44 61 74 61  GS_ ((ClientData
0690: 20 63 6c 69 65 6e 74 44 61 74 61 2c 0a 09 09 09   clientData,....
06a0: 69 6e 74 20 6d 61 73 6b 29 29 3b 0a 73 74 61 74  int mask));.stat
06b0: 69 63 20 76 6f 69 64 09 54 6c 73 43 68 61 6e 6e  ic void.TlsChann
06c0: 65 6c 48 61 6e 64 6c 65 72 54 69 6d 65 72 20 5f  elHandlerTimer _
06d0: 41 4e 53 49 5f 41 52 47 53 5f 20 28 28 43 6c 69  ANSI_ARGS_ ((Cli
06e0: 65 6e 74 44 61 74 61 20 63 6c 69 65 6e 74 44 61  entData clientDa
06f0: 74 61 29 29 3b 0a 0a 2f 2a 0a 20 2a 20 54 68 69  ta));../*. * Thi
0700: 73 20 73 74 72 75 63 74 75 72 65 20 64 65 73 63  s structure desc
0710: 72 69 62 65 73 20 74 68 65 20 63 68 61 6e 6e 65  ribes the channe
0720: 6c 20 74 79 70 65 20 73 74 72 75 63 74 75 72 65  l type structure
0730: 20 66 6f 72 20 54 43 50 20 73 6f 63 6b 65 74 0a   for TCP socket.
0740: 20 2a 20 62 61 73 65 64 20 49 4f 3a 0a 20 2a 2f   * based IO:. */
0750: 0a 23 69 66 64 65 66 20 54 43 4c 5f 43 48 41 4e  .#ifdef TCL_CHAN
0760: 4e 45 4c 5f 56 45 52 53 49 4f 4e 5f 32 0a 73 74  NEL_VERSION_2.st
0770: 61 74 69 63 20 54 63 6c 5f 43 68 61 6e 6e 65 6c  atic Tcl_Channel
0780: 54 79 70 65 20 74 6c 73 43 68 61 6e 6e 65 6c 54  Type tlsChannelT
0790: 79 70 65 20 3d 20 7b 0a 20 20 20 20 22 74 6c 73  ype = {.    "tls
07a0: 22 2c 09 09 2f 2a 20 54 79 70 65 20 6e 61 6d 65  ",../* Type name
07b0: 2e 20 2a 2f 0a 20 20 20 20 54 43 4c 5f 43 48 41  . */.    TCL_CHA
07c0: 4e 4e 45 4c 5f 56 45 52 53 49 4f 4e 5f 32 2c 09  NNEL_VERSION_2,.
07d0: 2f 2a 20 41 20 76 32 20 63 68 61 6e 6e 65 6c 20  /* A v2 channel 
07e0: 28 38 2e 33 2e 32 2f 38 2e 34 61 32 2b 29 20 2a  (8.3.2/8.4a2+) *
07f0: 2f 0a 20 20 20 20 54 6c 73 43 6c 6f 73 65 50 72  /.    TlsClosePr
0800: 6f 63 2c 09 2f 2a 20 43 6c 6f 73 65 20 70 72 6f  oc,./* Close pro
0810: 63 2e 20 2a 2f 0a 20 20 20 20 54 6c 73 49 6e 70  c. */.    TlsInp
0820: 75 74 50 72 6f 63 2c 09 2f 2a 20 49 6e 70 75 74  utProc,./* Input
0830: 20 70 72 6f 63 2e 20 2a 2f 0a 20 20 20 20 54 6c   proc. */.    Tl
0840: 73 4f 75 74 70 75 74 50 72 6f 63 2c 09 2f 2a 20  sOutputProc,./* 
0850: 4f 75 74 70 75 74 20 70 72 6f 63 2e 20 2a 2f 0a  Output proc. */.
0860: 20 20 20 20 4e 55 4c 4c 2c 09 09 2f 2a 20 53 65      NULL,../* Se
0870: 65 6b 20 70 72 6f 63 2e 20 2a 2f 0a 20 20 20 20  ek proc. */.    
0880: 4e 55 4c 4c 2c 09 09 2f 2a 20 53 65 74 20 6f 70  NULL,../* Set op
0890: 74 69 6f 6e 20 70 72 6f 63 2e 20 2a 2f 0a 20 20  tion proc. */.  
08a0: 20 20 54 6c 73 47 65 74 4f 70 74 69 6f 6e 50 72    TlsGetOptionPr
08b0: 6f 63 2c 09 2f 2a 20 47 65 74 20 6f 70 74 69 6f  oc,./* Get optio
08c0: 6e 20 70 72 6f 63 2e 20 2a 2f 0a 20 20 20 20 54  n proc. */.    T
08d0: 6c 73 57 61 74 63 68 50 72 6f 63 2c 09 2f 2a 20  lsWatchProc,./* 
08e0: 49 6e 69 74 69 61 6c 69 7a 65 20 6e 6f 74 69 66  Initialize notif
08f0: 69 65 72 2e 20 2a 2f 0a 20 20 20 20 54 6c 73 47  ier. */.    TlsG
0900: 65 74 48 61 6e 64 6c 65 50 72 6f 63 2c 09 2f 2a  etHandleProc,./*
0910: 20 47 65 74 20 66 69 6c 65 20 68 61 6e 64 6c 65   Get file handle
0920: 20 6f 75 74 20 6f 66 20 63 68 61 6e 6e 65 6c 2e   out of channel.
0930: 20 2a 2f 0a 20 20 20 20 4e 55 4c 4c 2c 09 09 2f   */.    NULL,../
0940: 2a 20 43 6c 6f 73 65 32 50 72 6f 63 2e 20 2a 2f  * Close2Proc. */
0950: 0a 20 20 20 20 54 6c 73 42 6c 6f 63 6b 4d 6f 64  .    TlsBlockMod
0960: 65 50 72 6f 63 2c 09 2f 2a 20 53 65 74 20 62 6c  eProc,./* Set bl
0970: 6f 63 6b 69 6e 67 2f 6e 6f 6e 62 6c 6f 63 6b 69  ocking/nonblocki
0980: 6e 67 20 6d 6f 64 65 2e 2a 2f 0a 20 20 20 20 4e  ng mode.*/.    N
0990: 55 4c 4c 2c 09 09 2f 2a 20 46 6c 75 73 68 50 72  ULL,../* FlushPr
09a0: 6f 63 2e 20 2a 2f 0a 20 20 20 20 54 6c 73 4e 6f  oc. */.    TlsNo
09b0: 74 69 66 79 50 72 6f 63 2c 09 2f 2a 20 68 61 6e  tifyProc,./* han
09c0: 64 6c 65 72 50 72 6f 63 2e 20 2a 2f 0a 7d 3b 0a  dlerProc. */.};.
09d0: 23 65 6c 73 65 0a 73 74 61 74 69 63 20 54 63 6c  #else.static Tcl
09e0: 5f 43 68 61 6e 6e 65 6c 54 79 70 65 20 74 6c 73  _ChannelType tls
09f0: 43 68 61 6e 6e 65 6c 54 79 70 65 20 3d 20 7b 0a  ChannelType = {.
0a00: 20 20 20 20 22 74 6c 73 22 2c 09 09 2f 2a 20 54      "tls",../* T
0a10: 79 70 65 20 6e 61 6d 65 2e 20 2a 2f 0a 20 20 20  ype name. */.   
0a20: 20 54 6c 73 42 6c 6f 63 6b 4d 6f 64 65 50 72 6f   TlsBlockModePro
0a30: 63 2c 09 2f 2a 20 53 65 74 20 62 6c 6f 63 6b 69  c,./* Set blocki
0a40: 6e 67 2f 6e 6f 6e 62 6c 6f 63 6b 69 6e 67 20 6d  ng/nonblocking m
0a50: 6f 64 65 2e 2a 2f 0a 20 20 20 20 54 6c 73 43 6c  ode.*/.    TlsCl
0a60: 6f 73 65 50 72 6f 63 2c 09 2f 2a 20 43 6c 6f 73  oseProc,./* Clos
0a70: 65 20 70 72 6f 63 2e 20 2a 2f 0a 20 20 20 20 54  e proc. */.    T
0a80: 6c 73 49 6e 70 75 74 50 72 6f 63 2c 09 2f 2a 20  lsInputProc,./* 
0a90: 49 6e 70 75 74 20 70 72 6f 63 2e 20 2a 2f 0a 20  Input proc. */. 
0aa0: 20 20 20 54 6c 73 4f 75 74 70 75 74 50 72 6f 63     TlsOutputProc
0ab0: 2c 09 2f 2a 20 4f 75 74 70 75 74 20 70 72 6f 63  ,./* Output proc
0ac0: 2e 20 2a 2f 0a 20 20 20 20 4e 55 4c 4c 2c 09 09  . */.    NULL,..
0ad0: 2f 2a 20 53 65 65 6b 20 70 72 6f 63 2e 20 2a 2f  /* Seek proc. */
0ae0: 0a 20 20 20 20 4e 55 4c 4c 2c 09 09 2f 2a 20 53  .    NULL,../* S
0af0: 65 74 20 6f 70 74 69 6f 6e 20 70 72 6f 63 2e 20  et option proc. 
0b00: 2a 2f 0a 20 20 20 20 54 6c 73 47 65 74 4f 70 74  */.    TlsGetOpt
0b10: 69 6f 6e 50 72 6f 63 2c 09 2f 2a 20 47 65 74 20  ionProc,./* Get 
0b20: 6f 70 74 69 6f 6e 20 70 72 6f 63 2e 20 2a 2f 0a  option proc. */.
0b30: 20 20 20 20 54 6c 73 57 61 74 63 68 50 72 6f 63      TlsWatchProc
0b40: 2c 09 2f 2a 20 49 6e 69 74 69 61 6c 69 7a 65 20  ,./* Initialize 
0b50: 6e 6f 74 69 66 69 65 72 2e 20 2a 2f 0a 20 20 20  notifier. */.   
0b60: 20 54 6c 73 47 65 74 48 61 6e 64 6c 65 50 72 6f   TlsGetHandlePro
0b70: 63 2c 09 2f 2a 20 47 65 74 20 66 69 6c 65 20 68  c,./* Get file h
0b80: 61 6e 64 6c 65 20 6f 75 74 20 6f 66 20 63 68 61  andle out of cha
0b90: 6e 6e 65 6c 2e 20 2a 2f 0a 7d 3b 0a 23 65 6e 64  nnel. */.};.#end
0ba0: 69 66 0a 0a 54 63 6c 5f 43 68 61 6e 6e 65 6c 54  if..Tcl_ChannelT
0bb0: 79 70 65 20 2a 54 6c 73 5f 43 68 61 6e 6e 65 6c  ype *Tls_Channel
0bc0: 54 79 70 65 28 29 0a 7b 0a 20 20 20 20 72 65 74  Type().{.    ret
0bd0: 75 72 6e 20 26 74 6c 73 43 68 61 6e 6e 65 6c 54  urn &tlsChannelT
0be0: 79 70 65 3b 0a 7d 0a 0c 0a 2f 2a 0a 20 2a 2d 2d  ype;.}.../*. *--
0bf0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0c00: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0c10: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0c20: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0c30: 2d 0a 20 2a 0a 20 2a 20 54 6c 73 42 6c 6f 63 6b  -. *. * TlsBlock
0c40: 4d 6f 64 65 50 72 6f 63 20 2d 2d 0a 20 2a 0a 20  ModeProc --. *. 
0c50: 2a 09 54 68 69 73 20 70 72 6f 63 65 64 75 72 65  *.This procedure
0c60: 20 69 73 20 69 6e 76 6f 6b 65 64 20 62 79 20 74   is invoked by t
0c70: 68 65 20 67 65 6e 65 72 69 63 20 49 4f 20 6c 65  he generic IO le
0c80: 76 65 6c 0a 20 2a 20 20 20 20 20 20 20 74 6f 20  vel. *       to 
0c90: 73 65 74 20 62 6c 6f 63 6b 69 6e 67 20 61 6e 64  set blocking and
0ca0: 20 6e 6f 6e 62 6c 6f 63 6b 69 6e 67 20 6d 6f 64   nonblocking mod
0cb0: 65 73 0a 20 2a 20 52 65 73 75 6c 74 73 3a 0a 20  es. * Results:. 
0cc0: 2a 09 30 20 69 66 20 73 75 63 63 65 73 73 66 75  *.0 if successfu
0cd0: 6c 2c 20 65 72 72 6e 6f 20 77 68 65 6e 20 66 61  l, errno when fa
0ce0: 69 6c 65 64 2e 0a 20 2a 0a 20 2a 20 53 69 64 65  iled.. *. * Side
0cf0: 20 65 66 66 65 63 74 73 3a 0a 20 2a 09 53 65 74   effects:. *.Set
0d00: 73 20 74 68 65 20 64 65 76 69 63 65 20 69 6e 74  s the device int
0d10: 6f 20 62 6c 6f 63 6b 69 6e 67 20 6f 72 20 6e 6f  o blocking or no
0d20: 6e 62 6c 6f 63 6b 69 6e 67 20 6d 6f 64 65 2e 0a  nblocking mode..
0d30: 20 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d   *. *-----------
0d40: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0d50: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0d60: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0d70: 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 2f 0a 0a 73 74  --------. */..st
0d80: 61 74 69 63 20 69 6e 74 0a 54 6c 73 42 6c 6f 63  atic int.TlsBloc
0d90: 6b 4d 6f 64 65 50 72 6f 63 28 43 6c 69 65 6e 74  kModeProc(Client
0da0: 44 61 74 61 20 69 6e 73 74 61 6e 63 65 44 61 74  Data instanceDat
0db0: 61 2c 09 2f 2a 20 53 6f 63 6b 65 74 20 73 74 61  a,./* Socket sta
0dc0: 74 65 2e 20 2a 2f 0a 20 20 20 20 20 20 20 20 20  te. */.         
0dd0: 20 20 20 20 20 20 20 20 69 6e 74 20 6d 6f 64 65          int mode
0de0: 29 09 09 09 2f 2a 20 54 68 65 20 6d 6f 64 65 20  ).../* The mode 
0df0: 74 6f 20 73 65 74 2e 20 43 61 6e 20 62 65 20 6f  to set. Can be o
0e00: 6e 65 20 6f 66 0a 09 09 09 09 09 09 2a 20 54 43  ne of.......* TC
0e10: 4c 5f 4d 4f 44 45 5f 42 4c 4f 43 4b 49 4e 47 20  L_MODE_BLOCKING 
0e20: 6f 72 0a 09 09 09 09 09 09 2a 20 54 43 4c 5f 4d  or.......* TCL_M
0e30: 4f 44 45 5f 4e 4f 4e 42 4c 4f 43 4b 49 4e 47 2e  ODE_NONBLOCKING.
0e40: 20 2a 2f 0a 7b 0a 20 20 20 20 53 74 61 74 65 20   */.{.    State 
0e50: 2a 73 74 61 74 65 50 74 72 20 3d 20 28 53 74 61  *statePtr = (Sta
0e60: 74 65 20 2a 29 20 69 6e 73 74 61 6e 63 65 44 61  te *) instanceDa
0e70: 74 61 3b 0a 0a 20 20 20 20 69 66 20 28 6d 6f 64  ta;..    if (mod
0e80: 65 20 3d 3d 20 54 43 4c 5f 4d 4f 44 45 5f 4e 4f  e == TCL_MODE_NO
0e90: 4e 42 4c 4f 43 4b 49 4e 47 29 20 7b 0a 09 73 74  NBLOCKING) {..st
0ea0: 61 74 65 50 74 72 2d 3e 66 6c 61 67 73 20 7c 3d  atePtr->flags |=
0eb0: 20 54 4c 53 5f 54 43 4c 5f 41 53 59 4e 43 3b 0a   TLS_TCL_ASYNC;.
0ec0: 20 20 20 20 7d 20 65 6c 73 65 20 7b 0a 09 73 74      } else {..st
0ed0: 61 74 65 50 74 72 2d 3e 66 6c 61 67 73 20 26 3d  atePtr->flags &=
0ee0: 20 7e 28 54 4c 53 5f 54 43 4c 5f 41 53 59 4e 43   ~(TLS_TCL_ASYNC
0ef0: 29 3b 0a 20 20 20 20 7d 0a 23 69 66 64 65 66 20  );.    }.#ifdef 
0f00: 54 43 4c 5f 43 48 41 4e 4e 45 4c 5f 56 45 52 53  TCL_CHANNEL_VERS
0f10: 49 4f 4e 5f 32 0a 20 20 20 20 72 65 74 75 72 6e  ION_2.    return
0f20: 20 30 3b 0a 23 65 6c 73 65 0a 20 20 20 20 72 65   0;.#else.    re
0f30: 74 75 72 6e 20 54 63 6c 5f 53 65 74 43 68 61 6e  turn Tcl_SetChan
0f40: 6e 65 6c 4f 70 74 69 6f 6e 28 73 74 61 74 65 50  nelOption(stateP
0f50: 74 72 2d 3e 69 6e 74 65 72 70 2c 20 54 6c 73 5f  tr->interp, Tls_
0f60: 47 65 74 50 61 72 65 6e 74 28 73 74 61 74 65 50  GetParent(stateP
0f70: 74 72 29 2c 0a 09 09 22 2d 62 6c 6f 63 6b 69 6e  tr),..."-blockin
0f80: 67 22 2c 20 28 6d 6f 64 65 20 3d 3d 20 54 43 4c  g", (mode == TCL
0f90: 5f 4d 4f 44 45 5f 4e 4f 4e 42 4c 4f 43 4b 49 4e  _MODE_NONBLOCKIN
0fa0: 47 29 20 3f 20 22 30 22 20 3a 20 22 31 22 29 3b  G) ? "0" : "1");
0fb0: 0a 23 65 6e 64 69 66 0a 7d 0a 0c 0a 2f 2a 0a 20  .#endif.}.../*. 
0fc0: 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  *---------------
0fd0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0fe0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0ff0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1000: 2d 2d 2d 2d 0a 20 2a 0a 20 2a 20 54 6c 73 43 6c  ----. *. * TlsCl
1010: 6f 73 65 50 72 6f 63 20 2d 2d 0a 20 2a 0a 20 2a  oseProc --. *. *
1020: 09 54 68 69 73 20 70 72 6f 63 65 64 75 72 65 20  .This procedure 
1030: 69 73 20 69 6e 76 6f 6b 65 64 20 62 79 20 74 68  is invoked by th
1040: 65 20 67 65 6e 65 72 69 63 20 49 4f 20 6c 65 76  e generic IO lev
1050: 65 6c 20 74 6f 20 70 65 72 66 6f 72 6d 0a 20 2a  el to perform. *
1060: 09 63 68 61 6e 6e 65 6c 2d 74 79 70 65 2d 73 70  .channel-type-sp
1070: 65 63 69 66 69 63 20 63 6c 65 61 6e 75 70 20 77  ecific cleanup w
1080: 68 65 6e 20 61 20 53 53 4c 20 73 6f 63 6b 65 74  hen a SSL socket
1090: 20 62 61 73 65 64 20 63 68 61 6e 6e 65 6c 0a 20   based channel. 
10a0: 2a 09 69 73 20 63 6c 6f 73 65 64 2e 0a 20 2a 0a  *.is closed.. *.
10b0: 20 2a 09 4e 6f 74 65 3a 20 77 65 20 6c 65 61 76   *.Note: we leav
10c0: 65 20 74 68 65 20 75 6e 64 65 72 6c 79 69 6e 67  e the underlying
10d0: 20 73 6f 63 6b 65 74 20 61 6c 6f 6e 65 2c 20 69   socket alone, i
10e0: 73 20 74 68 69 73 20 72 69 67 68 74 3f 0a 20 2a  s this right?. *
10f0: 0a 20 2a 20 52 65 73 75 6c 74 73 3a 0a 20 2a 09  . * Results:. *.
1100: 30 20 69 66 20 73 75 63 63 65 73 73 66 75 6c 2c  0 if successful,
1110: 20 74 68 65 20 76 61 6c 75 65 20 6f 66 20 54 63   the value of Tc
1120: 6c 5f 47 65 74 45 72 72 6e 6f 28 29 20 69 66 20  l_GetErrno() if 
1130: 66 61 69 6c 65 64 2e 0a 20 2a 0a 20 2a 20 53 69  failed.. *. * Si
1140: 64 65 20 65 66 66 65 63 74 73 3a 0a 20 2a 09 43  de effects:. *.C
1150: 6c 6f 73 65 73 20 74 68 65 20 73 6f 63 6b 65 74  loses the socket
1160: 20 6f 66 20 74 68 65 20 63 68 61 6e 6e 65 6c 2e   of the channel.
1170: 0a 20 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  . *. *----------
1180: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1190: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
11a0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
11b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 2f 0a 73 74  ---------. */.st
11c0: 61 74 69 63 20 69 6e 74 0a 54 6c 73 43 6c 6f 73  atic int.TlsClos
11d0: 65 50 72 6f 63 28 43 6c 69 65 6e 74 44 61 74 61  eProc(ClientData
11e0: 20 69 6e 73 74 61 6e 63 65 44 61 74 61 2c 09 2f   instanceData,./
11f0: 2a 20 54 68 65 20 73 6f 63 6b 65 74 20 74 6f 20  * The socket to 
1200: 63 6c 6f 73 65 2e 20 2a 2f 0a 20 20 20 20 20 20  close. */.      
1210: 20 20 20 20 20 20 20 54 63 6c 5f 49 6e 74 65 72         Tcl_Inter
1220: 70 20 2a 69 6e 74 65 72 70 29 09 2f 2a 20 46 6f  p *interp)./* Fo
1230: 72 20 65 72 72 6f 72 20 72 65 70 6f 72 74 69 6e  r error reportin
1240: 67 20 2d 20 75 6e 75 73 65 64 2e 20 2a 2f 0a 7b  g - unused. */.{
1250: 0a 20 20 20 20 53 74 61 74 65 20 2a 73 74 61 74  .    State *stat
1260: 65 50 74 72 20 3d 20 28 53 74 61 74 65 20 2a 29  ePtr = (State *)
1270: 20 69 6e 73 74 61 6e 63 65 44 61 74 61 3b 0a 0a   instanceData;..
1280: 20 20 20 20 64 70 72 69 6e 74 66 28 73 74 64 65      dprintf(stde
1290: 72 72 2c 22 5c 6e 54 6c 73 43 6c 6f 73 65 50 72  rr,"\nTlsClosePr
12a0: 6f 63 28 30 78 25 78 29 22 2c 20 73 74 61 74 65  oc(0x%x)", state
12b0: 50 74 72 29 3b 0a 0a 23 69 66 6e 64 65 66 20 54  Ptr);..#ifndef T
12c0: 43 4c 5f 43 48 41 4e 4e 45 4c 5f 56 45 52 53 49  CL_CHANNEL_VERSI
12d0: 4f 4e 5f 32 0a 20 20 20 20 2f 2a 0a 20 20 20 20  ON_2.    /*.    
12e0: 20 2a 20 52 65 6d 6f 76 65 20 65 76 65 6e 74 20   * Remove event 
12f0: 68 61 6e 64 6c 65 72 20 74 6f 20 75 6e 64 65 72  handler to under
1300: 6c 79 69 6e 67 20 63 68 61 6e 6e 65 6c 2c 20 74  lying channel, t
1310: 68 69 73 20 63 6f 75 6c 64 0a 20 20 20 20 20 2a  his could.     *
1320: 20 62 65 20 62 65 63 61 75 73 65 20 77 65 20 61   be because we a
1330: 72 65 20 63 6c 6f 73 69 6e 67 20 66 6f 72 20 72  re closing for r
1340: 65 61 6c 2c 20 6f 72 20 62 65 69 6e 67 20 22 75  eal, or being "u
1350: 6e 73 74 61 63 6b 65 64 22 2e 0a 20 20 20 20 20  nstacked"..     
1360: 2a 2f 0a 0a 20 20 20 20 54 63 6c 5f 44 65 6c 65  */..    Tcl_Dele
1370: 74 65 43 68 61 6e 6e 65 6c 48 61 6e 64 6c 65 72  teChannelHandler
1380: 28 54 6c 73 5f 47 65 74 50 61 72 65 6e 74 28 73  (Tls_GetParent(s
1390: 74 61 74 65 50 74 72 29 2c 0a 09 54 6c 73 43 68  tatePtr),..TlsCh
13a0: 61 6e 6e 65 6c 48 61 6e 64 6c 65 72 2c 20 28 43  annelHandler, (C
13b0: 6c 69 65 6e 74 44 61 74 61 29 20 73 74 61 74 65  lientData) state
13c0: 50 74 72 29 3b 0a 23 65 6e 64 69 66 0a 0a 20 20  Ptr);.#endif..  
13d0: 20 20 54 6c 73 5f 43 6c 65 61 6e 28 73 74 61 74    Tls_Clean(stat
13e0: 65 50 74 72 29 3b 0a 20 20 20 20 54 63 6c 5f 45  ePtr);.    Tcl_E
13f0: 76 65 6e 74 75 61 6c 6c 79 46 72 65 65 28 20 28  ventuallyFree( (
1400: 43 6c 69 65 6e 74 44 61 74 61 29 73 74 61 74 65  ClientData)state
1410: 50 74 72 2c 20 54 6c 73 5f 46 72 65 65 29 3b 0a  Ptr, Tls_Free);.
1420: 20 20 20 20 72 65 74 75 72 6e 20 54 43 4c 5f 4f      return TCL_O
1430: 4b 3b 0a 7d 0a 0c 0a 2f 2a 0a 20 2a 2d 2d 2d 2d  K;.}.../*. *----
1440: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1450: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1460: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1470: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a  ---------------.
1480: 20 2a 0a 20 2a 20 54 6c 73 49 6e 70 75 74 50 72   *. * TlsInputPr
1490: 6f 63 20 2d 2d 0a 20 2a 0a 20 2a 09 54 68 69 73  oc --. *. *.This
14a0: 20 70 72 6f 63 65 64 75 72 65 20 69 73 20 69 6e   procedure is in
14b0: 76 6f 6b 65 64 20 62 79 20 74 68 65 20 67 65 6e  voked by the gen
14c0: 65 72 69 63 20 49 4f 20 6c 65 76 65 6c 0a 20 2a  eric IO level. *
14d0: 20 20 20 20 20 20 20 74 6f 20 72 65 61 64 20 69         to read i
14e0: 6e 70 75 74 20 66 72 6f 6d 20 61 20 53 53 4c 20  nput from a SSL 
14f0: 73 6f 63 6b 65 74 20 62 61 73 65 64 20 63 68 61  socket based cha
1500: 6e 6e 65 6c 2e 0a 20 2a 0a 20 2a 20 52 65 73 75  nnel.. *. * Resu
1510: 6c 74 73 3a 0a 20 2a 09 54 68 65 20 6e 75 6d 62  lts:. *.The numb
1520: 65 72 20 6f 66 20 62 79 74 65 73 20 72 65 61 64  er of bytes read
1530: 20 69 73 20 72 65 74 75 72 6e 65 64 20 6f 72 20   is returned or 
1540: 2d 31 20 6f 6e 20 65 72 72 6f 72 2e 20 41 6e 20  -1 on error. An 
1550: 6f 75 74 70 75 74 0a 20 2a 09 61 72 67 75 6d 65  output. *.argume
1560: 6e 74 20 63 6f 6e 74 61 69 6e 73 20 74 68 65 20  nt contains the 
1570: 50 4f 53 49 58 20 65 72 72 6f 72 20 63 6f 64 65  POSIX error code
1580: 20 6f 6e 20 65 72 72 6f 72 2c 20 6f 72 20 7a 65   on error, or ze
1590: 72 6f 20 69 66 20 6e 6f 0a 20 2a 09 65 72 72 6f  ro if no. *.erro
15a0: 72 20 6f 63 63 75 72 72 65 64 2e 0a 20 2a 0a 20  r occurred.. *. 
15b0: 2a 20 53 69 64 65 20 65 66 66 65 63 74 73 3a 0a  * Side effects:.
15c0: 20 2a 09 52 65 61 64 73 20 69 6e 70 75 74 20 66   *.Reads input f
15d0: 72 6f 6d 20 74 68 65 20 69 6e 70 75 74 20 64 65  rom the input de
15e0: 76 69 63 65 20 6f 66 20 74 68 65 20 63 68 61 6e  vice of the chan
15f0: 6e 65 6c 2e 0a 20 2a 0a 20 2a 2d 2d 2d 2d 2d 2d  nel.. *. *------
1600: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1610: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1620: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1630: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a  -------------. *
1640: 2f 0a 0a 73 74 61 74 69 63 20 69 6e 74 0a 54 6c  /..static int.Tl
1650: 73 49 6e 70 75 74 50 72 6f 63 28 43 6c 69 65 6e  sInputProc(Clien
1660: 74 44 61 74 61 20 69 6e 73 74 61 6e 63 65 44 61  tData instanceDa
1670: 74 61 2c 09 2f 2a 20 53 6f 63 6b 65 74 20 73 74  ta,./* Socket st
1680: 61 74 65 2e 20 2a 2f 0a 20 20 20 20 20 20 20 20  ate. */.        
1690: 20 20 20 20 20 63 68 61 72 20 2a 62 75 66 2c 09       char *buf,.
16a0: 09 09 2f 2a 20 57 68 65 72 65 20 74 6f 20 73 74  ../* Where to st
16b0: 6f 72 65 20 64 61 74 61 20 72 65 61 64 2e 20 2a  ore data read. *
16c0: 2f 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 69  /.             i
16d0: 6e 74 20 62 75 66 53 69 7a 65 2c 09 09 2f 2a 20  nt bufSize,../* 
16e0: 48 6f 77 20 6d 75 63 68 20 73 70 61 63 65 20 69  How much space i
16f0: 73 20 61 76 61 69 6c 61 62 6c 65 0a 20 20 20 20  s available.    
1700: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1710: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1720: 20 20 20 20 20 2a 20 69 6e 20 74 68 65 20 62 75       * in the bu
1730: 66 66 65 72 3f 20 2a 2f 0a 20 20 20 20 20 20 20  ffer? */.       
1740: 20 20 20 20 20 20 69 6e 74 20 2a 65 72 72 6f 72        int *error
1750: 43 6f 64 65 50 74 72 29 09 09 2f 2a 20 57 68 65  CodePtr)../* Whe
1760: 72 65 20 74 6f 20 73 74 6f 72 65 20 65 72 72 6f  re to store erro
1770: 72 20 63 6f 64 65 2e 20 2a 2f 0a 7b 0a 20 20 20  r code. */.{.   
1780: 20 53 74 61 74 65 20 2a 73 74 61 74 65 50 74 72   State *statePtr
1790: 20 3d 20 28 53 74 61 74 65 20 2a 29 20 69 6e 73   = (State *) ins
17a0: 74 61 6e 63 65 44 61 74 61 3b 0a 20 20 20 20 69  tanceData;.    i
17b0: 6e 74 20 62 79 74 65 73 52 65 61 64 3b 09 09 09  nt bytesRead;...
17c0: 2f 2a 20 48 6f 77 20 6d 61 6e 79 20 62 79 74 65  /* How many byte
17d0: 73 20 77 65 72 65 20 72 65 61 64 3f 20 2a 2f 0a  s were read? */.
17e0: 0a 20 20 20 20 2a 65 72 72 6f 72 43 6f 64 65 50  .    *errorCodeP
17f0: 74 72 20 3d 20 30 3b 0a 0a 20 20 20 20 64 70 72  tr = 0;..    dpr
1800: 69 6e 74 66 28 73 74 64 65 72 72 2c 22 5c 6e 42  intf(stderr,"\nB
1810: 49 4f 5f 72 65 61 64 28 25 64 29 22 2c 20 62 75  IO_read(%d)", bu
1820: 66 53 69 7a 65 29 3b 0a 0a 20 20 20 20 69 66 20  fSize);..    if 
1830: 28 21 53 53 4c 5f 69 73 5f 69 6e 69 74 5f 66 69  (!SSL_is_init_fi
1840: 6e 69 73 68 65 64 28 73 74 61 74 65 50 74 72 2d  nished(statePtr-
1850: 3e 73 73 6c 29 29 20 7b 0a 09 62 79 74 65 73 52  >ssl)) {..bytesR
1860: 65 61 64 20 3d 20 54 6c 73 5f 57 61 69 74 46 6f  ead = Tls_WaitFo
1870: 72 43 6f 6e 6e 65 63 74 28 73 74 61 74 65 50 74  rConnect(statePt
1880: 72 2c 20 65 72 72 6f 72 43 6f 64 65 50 74 72 29  r, errorCodePtr)
1890: 3b 0a 09 69 66 20 28 62 79 74 65 73 52 65 61 64  ;..if (bytesRead
18a0: 20 3c 3d 20 30 29 20 7b 0a 09 20 20 20 20 67 6f   <= 0) {..    go
18b0: 74 6f 20 69 6e 70 75 74 3b 0a 09 7d 0a 20 20 20  to input;..}.   
18c0: 20 7d 0a 20 20 20 20 69 66 20 28 73 74 61 74 65   }.    if (state
18d0: 50 74 72 2d 3e 66 6c 61 67 73 20 26 20 54 4c 53  Ptr->flags & TLS
18e0: 5f 54 43 4c 5f 49 4e 49 54 29 20 7b 0a 09 73 74  _TCL_INIT) {..st
18f0: 61 74 65 50 74 72 2d 3e 66 6c 61 67 73 20 26 3d  atePtr->flags &=
1900: 20 7e 28 54 4c 53 5f 54 43 4c 5f 49 4e 49 54 29   ~(TLS_TCL_INIT)
1910: 3b 0a 20 20 20 20 7d 0a 20 20 20 20 62 79 74 65  ;.    }.    byte
1920: 73 52 65 61 64 20 3d 20 42 49 4f 5f 72 65 61 64  sRead = BIO_read
1930: 28 73 74 61 74 65 50 74 72 2d 3e 62 69 6f 2c 20  (statePtr->bio, 
1940: 62 75 66 2c 20 62 75 66 53 69 7a 65 29 3b 0a 20  buf, bufSize);. 
1950: 20 20 20 64 70 72 69 6e 74 66 28 73 74 64 65 72     dprintf(stder
1960: 72 2c 22 5c 6e 42 49 4f 5f 72 65 61 64 20 2d 3e  r,"\nBIO_read ->
1970: 20 25 64 22 2c 20 62 79 74 65 73 52 65 61 64 29   %d", bytesRead)
1980: 3b 0a 0a 20 20 20 20 69 66 20 28 62 79 74 65 73  ;..    if (bytes
1990: 52 65 61 64 20 3c 20 30 29 20 7b 0a 09 69 6e 74  Read < 0) {..int
19a0: 20 65 72 72 20 3d 20 53 53 4c 5f 67 65 74 5f 65   err = SSL_get_e
19b0: 72 72 6f 72 28 73 74 61 74 65 50 74 72 2d 3e 73  rror(statePtr->s
19c0: 73 6c 2c 20 62 79 74 65 73 52 65 61 64 29 3b 0a  sl, bytesRead);.
19d0: 0a 09 69 66 20 28 65 72 72 20 3d 3d 20 53 53 4c  ..if (err == SSL
19e0: 5f 45 52 52 4f 52 5f 53 53 4c 29 20 7b 0a 09 20  _ERROR_SSL) {.. 
19f0: 20 20 20 54 6c 73 5f 45 72 72 6f 72 28 73 74 61     Tls_Error(sta
1a00: 74 65 50 74 72 2c 20 53 53 4c 5f 45 52 52 4f 52  tePtr, SSL_ERROR
1a10: 28 73 74 61 74 65 50 74 72 2d 3e 73 73 6c 2c 20  (statePtr->ssl, 
1a20: 62 79 74 65 73 52 65 61 64 29 29 3b 0a 09 20 20  bytesRead));..  
1a30: 20 20 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 20    *errorCodePtr 
1a40: 3d 20 45 43 4f 4e 4e 41 42 4f 52 54 45 44 3b 0a  = ECONNABORTED;.
1a50: 09 20 20 20 20 67 6f 74 6f 20 69 6e 70 75 74 3b  .    goto input;
1a60: 0a 09 7d 20 65 6c 73 65 20 69 66 20 28 42 49 4f  ..} else if (BIO
1a70: 5f 73 68 6f 75 6c 64 5f 72 65 74 72 79 28 73 74  _should_retry(st
1a80: 61 74 65 50 74 72 2d 3e 62 69 6f 29 29 20 7b 0a  atePtr->bio)) {.
1a90: 09 20 20 20 20 64 70 72 69 6e 74 66 28 73 74 64  .    dprintf(std
1aa0: 65 72 72 2c 22 52 45 21 20 22 29 3b 0a 09 20 20  err,"RE! ");..  
1ab0: 20 20 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 20    *errorCodePtr 
1ac0: 3d 20 45 41 47 41 49 4e 3b 0a 09 20 20 20 20 67  = EAGAIN;..    g
1ad0: 6f 74 6f 20 69 6e 70 75 74 3b 0a 09 7d 0a 09 69  oto input;..}..i
1ae0: 66 20 28 54 63 6c 5f 47 65 74 45 72 72 6e 6f 28  f (Tcl_GetErrno(
1af0: 29 20 3d 3d 20 45 43 4f 4e 4e 52 45 53 45 54 29  ) == ECONNRESET)
1b00: 20 7b 0a 09 20 20 20 20 2f 2a 20 53 6f 66 74 20   {..    /* Soft 
1b10: 45 4f 46 20 2a 2f 0a 09 20 20 20 20 62 79 74 65  EOF */..    byte
1b20: 73 52 65 61 64 20 3d 20 30 3b 0a 09 20 20 20 20  sRead = 0;..    
1b30: 67 6f 74 6f 20 69 6e 70 75 74 3b 0a 09 7d 20 65  goto input;..} e
1b40: 6c 73 65 20 7b 0a 09 20 20 20 20 2a 65 72 72 6f  lse {..    *erro
1b50: 72 43 6f 64 65 50 74 72 20 3d 20 54 63 6c 5f 47  rCodePtr = Tcl_G
1b60: 65 74 45 72 72 6e 6f 28 29 3b 0a 09 20 20 20 20  etErrno();..    
1b70: 67 6f 74 6f 20 69 6e 70 75 74 3b 0a 09 7d 0a 20  goto input;..}. 
1b80: 20 20 20 7d 0a 69 6e 70 75 74 3a 0a 20 20 20 20     }.input:.    
1b90: 64 70 72 69 6e 74 66 28 73 74 64 65 72 72 2c 20  dprintf(stderr, 
1ba0: 22 5c 6e 49 6e 70 75 74 28 25 64 29 20 2d 3e 20  "\nInput(%d) -> 
1bb0: 25 64 20 5b 25 64 5d 22 2c 20 62 75 66 53 69 7a  %d [%d]", bufSiz
1bc0: 65 2c 20 62 79 74 65 73 52 65 61 64 2c 20 2a 65  e, bytesRead, *e
1bd0: 72 72 6f 72 43 6f 64 65 50 74 72 29 3b 0a 20 20  rrorCodePtr);.  
1be0: 20 20 72 65 74 75 72 6e 20 62 79 74 65 73 52 65    return bytesRe
1bf0: 61 64 3b 0a 7d 0a 0c 0a 2f 2a 0a 20 2a 2d 2d 2d  ad;.}.../*. *---
1c00: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1c10: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1c20: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1c30: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1c40: 0a 20 2a 0a 20 2a 20 54 6c 73 4f 75 74 70 75 74  . *. * TlsOutput
1c50: 50 72 6f 63 20 2d 2d 0a 20 2a 0a 20 2a 09 54 68  Proc --. *. *.Th
1c60: 69 73 20 70 72 6f 63 65 64 75 72 65 20 69 73 20  is procedure is 
1c70: 69 6e 76 6f 6b 65 64 20 62 79 20 74 68 65 20 67  invoked by the g
1c80: 65 6e 65 72 69 63 20 49 4f 20 6c 65 76 65 6c 0a  eneric IO level.
1c90: 20 2a 20 20 20 20 20 20 20 74 6f 20 77 72 69 74   *       to writ
1ca0: 65 20 6f 75 74 70 75 74 20 74 6f 20 61 20 53 53  e output to a SS
1cb0: 4c 20 73 6f 63 6b 65 74 20 62 61 73 65 64 20 63  L socket based c
1cc0: 68 61 6e 6e 65 6c 2e 0a 20 2a 0a 20 2a 20 52 65  hannel.. *. * Re
1cd0: 73 75 6c 74 73 3a 0a 20 2a 09 54 68 65 20 6e 75  sults:. *.The nu
1ce0: 6d 62 65 72 20 6f 66 20 62 79 74 65 73 20 77 72  mber of bytes wr
1cf0: 69 74 74 65 6e 20 69 73 20 72 65 74 75 72 6e 65  itten is returne
1d00: 64 2e 20 41 6e 20 6f 75 74 70 75 74 20 61 72 67  d. An output arg
1d10: 75 6d 65 6e 74 20 69 73 0a 20 2a 09 73 65 74 20  ument is. *.set 
1d20: 74 6f 20 61 20 50 4f 53 49 58 20 65 72 72 6f 72  to a POSIX error
1d30: 20 63 6f 64 65 20 69 66 20 61 6e 20 65 72 72 6f   code if an erro
1d40: 72 20 6f 63 63 75 72 72 65 64 2c 20 6f 72 20 7a  r occurred, or z
1d50: 65 72 6f 2e 0a 20 2a 0a 20 2a 20 53 69 64 65 20  ero.. *. * Side 
1d60: 65 66 66 65 63 74 73 3a 0a 20 2a 09 57 72 69 74  effects:. *.Writ
1d70: 65 73 20 6f 75 74 70 75 74 20 6f 6e 20 74 68 65  es output on the
1d80: 20 6f 75 74 70 75 74 20 64 65 76 69 63 65 20 6f   output device o
1d90: 66 20 74 68 65 20 63 68 61 6e 6e 65 6c 2e 0a 20  f the channel.. 
1da0: 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  *. *------------
1db0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1dc0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1dd0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1de0: 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 2f 0a 0a 73 74 61  -------. */..sta
1df0: 74 69 63 20 69 6e 74 0a 54 6c 73 4f 75 74 70 75  tic int.TlsOutpu
1e00: 74 50 72 6f 63 28 43 6c 69 65 6e 74 44 61 74 61  tProc(ClientData
1e10: 20 69 6e 73 74 61 6e 63 65 44 61 74 61 2c 09 2f   instanceData,./
1e20: 2a 20 53 6f 63 6b 65 74 20 73 74 61 74 65 2e 20  * Socket state. 
1e30: 2a 2f 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  */.             
1e40: 20 63 68 61 72 20 2a 62 75 66 2c 09 09 09 2f 2a   char *buf,.../*
1e50: 20 54 68 65 20 64 61 74 61 20 62 75 66 66 65 72   The data buffer
1e60: 2e 20 2a 2f 0a 20 20 20 20 20 20 20 20 20 20 20  . */.           
1e70: 20 20 20 69 6e 74 20 74 6f 57 72 69 74 65 2c 09     int toWrite,.
1e80: 09 2f 2a 20 48 6f 77 20 6d 61 6e 79 20 62 79 74  ./* How many byt
1e90: 65 73 20 74 6f 20 77 72 69 74 65 3f 20 2a 2f 0a  es to write? */.
1ea0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 69 6e                in
1eb0: 74 20 2a 65 72 72 6f 72 43 6f 64 65 50 74 72 29  t *errorCodePtr)
1ec0: 09 2f 2a 20 57 68 65 72 65 20 74 6f 20 73 74 6f  ./* Where to sto
1ed0: 72 65 20 65 72 72 6f 72 20 63 6f 64 65 2e 20 2a  re error code. *
1ee0: 2f 0a 7b 0a 20 20 20 20 53 74 61 74 65 20 2a 73  /.{.    State *s
1ef0: 74 61 74 65 50 74 72 20 3d 20 28 53 74 61 74 65  tatePtr = (State
1f00: 20 2a 29 20 69 6e 73 74 61 6e 63 65 44 61 74 61   *) instanceData
1f10: 3b 0a 20 20 20 20 69 6e 74 20 77 72 69 74 74 65  ;.    int writte
1f20: 6e 2c 20 65 72 72 3b 0a 0a 20 20 20 20 2a 65 72  n, err;..    *er
1f30: 72 6f 72 43 6f 64 65 50 74 72 20 3d 20 30 3b 0a  rorCodePtr = 0;.
1f40: 0a 20 20 20 20 64 70 72 69 6e 74 66 28 73 74 64  .    dprintf(std
1f50: 65 72 72 2c 22 5c 6e 42 49 4f 5f 77 72 69 74 65  err,"\nBIO_write
1f60: 28 25 64 29 22 2c 20 74 6f 57 72 69 74 65 29 3b  (%d)", toWrite);
1f70: 0a 0a 20 20 20 20 69 66 20 28 21 53 53 4c 5f 69  ..    if (!SSL_i
1f80: 73 5f 69 6e 69 74 5f 66 69 6e 69 73 68 65 64 28  s_init_finished(
1f90: 73 74 61 74 65 50 74 72 2d 3e 73 73 6c 29 29 20  statePtr->ssl)) 
1fa0: 7b 0a 09 77 72 69 74 74 65 6e 20 3d 20 54 6c 73  {..written = Tls
1fb0: 5f 57 61 69 74 46 6f 72 43 6f 6e 6e 65 63 74 28  _WaitForConnect(
1fc0: 73 74 61 74 65 50 74 72 2c 20 65 72 72 6f 72 43  statePtr, errorC
1fd0: 6f 64 65 50 74 72 29 3b 0a 09 69 66 20 28 77 72  odePtr);..if (wr
1fe0: 69 74 74 65 6e 20 3c 3d 20 30 29 20 7b 0a 09 20  itten <= 0) {.. 
1ff0: 20 20 20 67 6f 74 6f 20 6f 75 74 70 75 74 3b 0a     goto output;.
2000: 09 7d 0a 20 20 20 20 7d 0a 20 20 20 20 69 66 20  .}.    }.    if 
2010: 28 73 74 61 74 65 50 74 72 2d 3e 66 6c 61 67 73  (statePtr->flags
2020: 20 26 20 54 4c 53 5f 54 43 4c 5f 49 4e 49 54 29   & TLS_TCL_INIT)
2030: 20 7b 0a 09 73 74 61 74 65 50 74 72 2d 3e 66 6c   {..statePtr->fl
2040: 61 67 73 20 26 3d 20 7e 28 54 4c 53 5f 54 43 4c  ags &= ~(TLS_TCL
2050: 5f 49 4e 49 54 29 3b 0a 20 20 20 20 7d 0a 20 20  _INIT);.    }.  
2060: 20 20 69 66 20 28 74 6f 57 72 69 74 65 20 3d 3d    if (toWrite ==
2070: 20 30 29 20 7b 0a 09 64 70 72 69 6e 74 66 28 73   0) {..dprintf(s
2080: 74 64 65 72 72 2c 20 22 7a 65 72 6f 2d 77 72 69  tderr, "zero-wri
2090: 74 65 5c 6e 22 29 3b 0a 09 42 49 4f 5f 66 6c 75  te\n");..BIO_flu
20a0: 73 68 28 73 74 61 74 65 50 74 72 2d 3e 62 69 6f  sh(statePtr->bio
20b0: 29 3b 0a 09 77 72 69 74 74 65 6e 20 3d 20 30 3b  );..written = 0;
20c0: 0a 09 67 6f 74 6f 20 6f 75 74 70 75 74 3b 0a 20  ..goto output;. 
20d0: 20 20 20 7d 20 65 6c 73 65 20 7b 0a 09 77 72 69     } else {..wri
20e0: 74 74 65 6e 20 3d 20 42 49 4f 5f 77 72 69 74 65  tten = BIO_write
20f0: 28 73 74 61 74 65 50 74 72 2d 3e 62 69 6f 2c 20  (statePtr->bio, 
2100: 62 75 66 2c 20 74 6f 57 72 69 74 65 29 3b 0a 09  buf, toWrite);..
2110: 64 70 72 69 6e 74 66 28 73 74 64 65 72 72 2c 22  dprintf(stderr,"
2120: 5c 6e 42 49 4f 5f 77 72 69 74 65 28 25 64 29 20  \nBIO_write(%d) 
2130: 2d 3e 20 5b 25 64 5d 22 2c 20 74 6f 57 72 69 74  -> [%d]", toWrit
2140: 65 2c 20 77 72 69 74 74 65 6e 29 3b 0a 20 20 20  e, written);.   
2150: 20 7d 0a 20 20 20 20 69 66 20 28 77 72 69 74 74   }.    if (writt
2160: 65 6e 20 3c 20 30 20 7c 7c 20 77 72 69 74 74 65  en < 0 || writte
2170: 6e 20 3d 3d 20 30 29 20 7b 0a 09 73 77 69 74 63  n == 0) {..switc
2180: 68 20 28 28 65 72 72 20 3d 20 53 53 4c 5f 67 65  h ((err = SSL_ge
2190: 74 5f 65 72 72 6f 72 28 73 74 61 74 65 50 74 72  t_error(statePtr
21a0: 2d 3e 73 73 6c 2c 20 77 72 69 74 74 65 6e 29 29  ->ssl, written))
21b0: 29 20 7b 0a 09 63 61 73 65 20 53 53 4c 5f 45 52  ) {..case SSL_ER
21c0: 52 4f 52 5f 4e 4f 4e 45 3a 0a 09 20 20 20 20 69  ROR_NONE:..    i
21d0: 66 20 28 77 72 69 74 74 65 6e 20 3c 3d 20 30 29  f (written <= 0)
21e0: 20 7b 0a 09 09 77 72 69 74 74 65 6e 20 3d 20 30   {...written = 0
21f0: 3b 0a 09 09 67 6f 74 6f 20 6f 75 74 70 75 74 3b  ;...goto output;
2200: 0a 09 20 20 20 20 7d 0a 09 20 20 20 20 62 72 65  ..    }..    bre
2210: 61 6b 3b 0a 09 63 61 73 65 20 53 53 4c 5f 45 52  ak;..case SSL_ER
2220: 52 4f 52 5f 57 41 4e 54 5f 57 52 49 54 45 3a 0a  ROR_WANT_WRITE:.
2230: 09 20 20 20 20 64 70 72 69 6e 74 66 28 73 74 64  .    dprintf(std
2240: 65 72 72 2c 22 77 72 69 74 65 20 57 20 42 4c 4f  err,"write W BLO
2250: 43 4b 5c 6e 22 29 3b 0a 09 20 20 20 20 62 72 65  CK\n");..    bre
2260: 61 6b 3b 0a 09 63 61 73 65 20 53 53 4c 5f 45 52  ak;..case SSL_ER
2270: 52 4f 52 5f 57 41 4e 54 5f 52 45 41 44 3a 0a 09  ROR_WANT_READ:..
2280: 20 20 20 20 64 70 72 69 6e 74 66 28 73 74 64 65      dprintf(stde
2290: 72 72 2c 22 77 72 69 74 65 20 52 20 42 4c 4f 43  rr,"write R BLOC
22a0: 4b 5c 6e 22 29 3b 0a 09 20 20 20 20 62 72 65 61  K\n");..    brea
22b0: 6b 3b 0a 09 63 61 73 65 20 53 53 4c 5f 45 52 52  k;..case SSL_ERR
22c0: 4f 52 5f 57 41 4e 54 5f 58 35 30 39 5f 4c 4f 4f  OR_WANT_X509_LOO
22d0: 4b 55 50 3a 0a 09 20 20 20 20 64 70 72 69 6e 74  KUP:..    dprint
22e0: 66 28 73 74 64 65 72 72 2c 22 77 72 69 74 65 20  f(stderr,"write 
22f0: 58 20 42 4c 4f 43 4b 5c 6e 22 29 3b 0a 09 20 20  X BLOCK\n");..  
2300: 20 20 62 72 65 61 6b 3b 0a 09 63 61 73 65 20 53    break;..case S
2310: 53 4c 5f 45 52 52 4f 52 5f 5a 45 52 4f 5f 52 45  SL_ERROR_ZERO_RE
2320: 54 55 52 4e 3a 0a 09 20 20 20 20 64 70 72 69 6e  TURN:..    dprin
2330: 74 66 28 73 74 64 65 72 72 2c 22 63 6c 6f 73 65  tf(stderr,"close
2340: 64 5c 6e 22 29 3b 0a 09 20 20 20 20 77 72 69 74  d\n");..    writ
2350: 74 65 6e 20 3d 20 30 3b 0a 09 20 20 20 20 67 6f  ten = 0;..    go
2360: 74 6f 20 6f 75 74 70 75 74 3b 0a 09 63 61 73 65  to output;..case
2370: 20 53 53 4c 5f 45 52 52 4f 52 5f 53 59 53 43 41   SSL_ERROR_SYSCA
2380: 4c 4c 3a 0a 09 20 20 20 20 2a 65 72 72 6f 72 43  LL:..    *errorC
2390: 6f 64 65 50 74 72 20 3d 20 54 63 6c 5f 47 65 74  odePtr = Tcl_Get
23a0: 45 72 72 6e 6f 28 29 3b 0a 09 20 20 20 20 64 70  Errno();..    dp
23b0: 72 69 6e 74 66 28 73 74 64 65 72 72 2c 22 5b 25  rintf(stderr,"[%
23c0: 64 5d 20 73 79 73 63 61 6c 6c 20 65 72 72 72 3a  d] syscall errr:
23d0: 20 25 64 5c 6e 22 2c 20 77 72 69 74 74 65 6e 2c   %d\n", written,
23e0: 20 54 63 6c 5f 47 65 74 45 72 72 6e 6f 28 29 29   Tcl_GetErrno())
23f0: 3b 0a 09 20 20 20 20 77 72 69 74 74 65 6e 20 3d  ;..    written =
2400: 20 2d 31 3b 0a 09 20 20 20 20 67 6f 74 6f 20 6f   -1;..    goto o
2410: 75 74 70 75 74 3b 0a 09 63 61 73 65 20 53 53 4c  utput;..case SSL
2420: 5f 45 52 52 4f 52 5f 53 53 4c 3a 0a 09 20 20 20  _ERROR_SSL:..   
2430: 20 54 6c 73 5f 45 72 72 6f 72 28 73 74 61 74 65   Tls_Error(state
2440: 50 74 72 2c 20 53 53 4c 5f 45 52 52 4f 52 28 73  Ptr, SSL_ERROR(s
2450: 74 61 74 65 50 74 72 2d 3e 73 73 6c 2c 20 77 72  tatePtr->ssl, wr
2460: 69 74 74 65 6e 29 29 3b 0a 09 20 20 20 20 2a 65  itten));..    *e
2470: 72 72 6f 72 43 6f 64 65 50 74 72 20 3d 20 45 43  rrorCodePtr = EC
2480: 4f 4e 4e 41 42 4f 52 54 45 44 3b 0a 09 20 20 20  ONNABORTED;..   
2490: 20 77 72 69 74 74 65 6e 20 3d 20 2d 31 3b 0a 09   written = -1;..
24a0: 20 20 20 20 67 6f 74 6f 20 6f 75 74 70 75 74 3b      goto output;
24b0: 0a 09 64 65 66 61 75 6c 74 3a 0a 09 20 20 20 20  ..default:..    
24c0: 64 70 72 69 6e 74 66 28 73 74 64 65 72 72 2c 22  dprintf(stderr,"
24d0: 75 6e 6b 6e 6f 77 6e 20 65 72 72 3a 20 25 64 5c  unknown err: %d\
24e0: 6e 22 2c 20 65 72 72 29 3b 0a 09 7d 0a 20 20 20  n", err);..}.   
24f0: 20 7d 0a 6f 75 74 70 75 74 3a 0a 20 20 20 20 64   }.output:.    d
2500: 70 72 69 6e 74 66 28 73 74 64 65 72 72 2c 20 22  printf(stderr, "
2510: 5c 6e 4f 75 74 70 75 74 28 25 64 29 20 2d 3e 20  \nOutput(%d) -> 
2520: 25 64 22 2c 20 74 6f 57 72 69 74 65 2c 20 77 72  %d", toWrite, wr
2530: 69 74 74 65 6e 29 3b 0a 20 20 20 20 72 65 74 75  itten);.    retu
2540: 72 6e 20 77 72 69 74 74 65 6e 3b 0a 7d 0a 0c 0a  rn written;.}...
2550: 2f 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  /*. *-----------
2560: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2570: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2580: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2590: 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 0a 20 2a 20 54  --------. *. * T
25a0: 6c 73 47 65 74 4f 70 74 69 6f 6e 50 72 6f 63 20  lsGetOptionProc 
25b0: 2d 2d 0a 20 2a 0a 20 2a 09 43 6f 6d 70 75 74 65  --. *. *.Compute
25c0: 73 20 61 6e 20 6f 70 74 69 6f 6e 20 76 61 6c 75  s an option valu
25d0: 65 20 66 6f 72 20 61 20 53 53 4c 20 73 6f 63 6b  e for a SSL sock
25e0: 65 74 20 62 61 73 65 64 20 63 68 61 6e 6e 65 6c  et based channel
25f0: 2c 20 6f 72 20 61 0a 20 2a 09 6c 69 73 74 20 6f  , or a. *.list o
2600: 66 20 61 6c 6c 20 6f 70 74 69 6f 6e 73 20 61 6e  f all options an
2610: 64 20 74 68 65 69 72 20 76 61 6c 75 65 73 2e 0a  d their values..
2620: 20 2a 0a 20 2a 09 4e 6f 74 65 3a 20 54 68 69 73   *. *.Note: This
2630: 20 63 6f 64 65 20 69 73 20 62 61 73 65 64 20 6f   code is based o
2640: 6e 20 63 6f 64 65 20 63 6f 6e 74 72 69 62 75 74  n code contribut
2650: 65 64 20 62 79 20 4a 6f 68 6e 20 48 61 78 62 79  ed by John Haxby
2660: 2e 0a 20 2a 0a 20 2a 20 52 65 73 75 6c 74 73 3a  .. *. * Results:
2670: 0a 20 2a 09 41 20 73 74 61 6e 64 61 72 64 20 54  . *.A standard T
2680: 63 6c 20 72 65 73 75 6c 74 2e 20 54 68 65 20 76  cl result. The v
2690: 61 6c 75 65 20 6f 66 20 74 68 65 20 73 70 65 63  alue of the spec
26a0: 69 66 69 65 64 20 6f 70 74 69 6f 6e 20 6f 72 20  ified option or 
26b0: 61 0a 20 2a 09 6c 69 73 74 20 6f 66 20 61 6c 6c  a. *.list of all
26c0: 20 6f 70 74 69 6f 6e 73 20 61 6e 64 09 74 68 65   options and.the
26d0: 69 72 20 76 61 6c 75 65 73 20 69 73 20 72 65 74  ir values is ret
26e0: 75 72 6e 65 64 20 69 6e 20 74 68 65 0a 20 2a 09  urned in the. *.
26f0: 73 75 70 70 6c 69 65 64 20 44 53 74 72 69 6e 67  supplied DString
2700: 2e 0a 20 2a 0a 20 2a 20 53 69 64 65 20 65 66 66  .. *. * Side eff
2710: 65 63 74 73 3a 0a 20 2a 09 4e 6f 6e 65 2e 0a 20  ects:. *.None.. 
2720: 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  *. *------------
2730: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2740: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2750: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2760: 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 2f 0a 73 74 61 74  -------. */.stat
2770: 69 63 20 69 6e 74 0a 54 6c 73 47 65 74 4f 70 74  ic int.TlsGetOpt
2780: 69 6f 6e 50 72 6f 63 28 43 6c 69 65 6e 74 44 61  ionProc(ClientDa
2790: 74 61 20 69 6e 73 74 61 6e 63 65 44 61 74 61 2c  ta instanceData,
27a0: 09 2f 2a 20 53 6f 63 6b 65 74 20 73 74 61 74 65  ./* Socket state
27b0: 2e 20 2a 2f 0a 20 20 20 20 20 20 20 20 20 20 20  . */.           
27c0: 20 20 20 20 20 20 54 63 6c 5f 49 6e 74 65 72 70        Tcl_Interp
27d0: 20 2a 69 6e 74 65 72 70 2c 09 09 2f 2a 20 46 6f   *interp,../* Fo
27e0: 72 20 65 72 72 6f 72 73 20 2d 20 63 61 6e 20 62  r errors - can b
27f0: 65 20 4e 55 4c 4c 2e 20 2a 2f 0a 20 20 20 20 20  e NULL. */.     
2800: 20 20 20 20 20 20 20 20 20 20 20 20 63 68 61 72              char
2810: 20 2a 6f 70 74 69 6f 6e 4e 61 6d 65 2c 09 09 2f   *optionName,../
2820: 2a 20 4e 61 6d 65 20 6f 66 20 74 68 65 20 6f 70  * Name of the op
2830: 74 69 6f 6e 20 74 6f 0a 20 20 20 20 20 20 20 20  tion to.        
2840: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2850: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2860: 20 20 20 20 20 20 20 20 20 2a 20 72 65 74 72 69           * retri
2870: 65 76 65 20 74 68 65 20 76 61 6c 75 65 20 66 6f  eve the value fo
2880: 72 2c 20 6f 72 0a 20 20 20 20 20 20 20 20 20 20  r, or.          
2890: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
28a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
28b0: 20 20 20 20 20 20 20 2a 20 4e 55 4c 4c 20 74 6f         * NULL to
28c0: 20 67 65 74 20 61 6c 6c 20 6f 70 74 69 6f 6e 73   get all options
28d0: 20 61 6e 64 0a 20 20 20 20 20 20 20 20 20 20 20   and.           
28e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
28f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2900: 20 20 20 20 20 20 2a 20 74 68 65 69 72 20 76 61        * their va
2910: 6c 75 65 73 2e 20 2a 2f 0a 20 20 20 20 20 20 20  lues. */.       
2920: 20 20 20 20 20 20 20 20 20 20 54 63 6c 5f 44 53            Tcl_DS
2930: 74 72 69 6e 67 20 2a 64 73 50 74 72 29 09 20 20  tring *dsPtr).  
2940: 20 20 20 20 20 20 20 2f 2a 20 57 68 65 72 65 20         /* Where 
2950: 74 6f 20 73 74 6f 72 65 20 74 68 65 20 63 6f 6d  to store the com
2960: 70 75 74 65 64 20 76 61 6c 75 65 0a 20 20 20 20  puted value.    
2970: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2980: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2990: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2a 20                * 
29a0: 69 6e 69 74 69 61 6c 69 7a 65 64 20 62 79 20 63  initialized by c
29b0: 61 6c 6c 65 72 2e 20 2a 2f 0a 7b 0a 23 69 66 64  aller. */.{.#ifd
29c0: 65 66 20 54 43 4c 5f 43 48 41 4e 4e 45 4c 5f 56  ef TCL_CHANNEL_V
29d0: 45 52 53 49 4f 4e 5f 32 0a 20 20 20 20 53 74 61  ERSION_2.    Sta
29e0: 74 65 20 2a 73 74 61 74 65 50 74 72 20 3d 20 28  te *statePtr = (
29f0: 53 74 61 74 65 20 2a 29 20 69 6e 73 74 61 6e 63  State *) instanc
2a00: 65 44 61 74 61 3b 0a 20 20 20 20 54 63 6c 5f 43  eData;.    Tcl_C
2a10: 68 61 6e 6e 65 6c 20 64 6f 77 6e 43 68 61 6e 20  hannel downChan 
2a20: 3d 20 54 6c 73 5f 47 65 74 50 61 72 65 6e 74 28  = Tls_GetParent(
2a30: 73 74 61 74 65 50 74 72 29 3b 0a 20 20 20 20 54  statePtr);.    T
2a40: 63 6c 5f 44 72 69 76 65 72 47 65 74 4f 70 74 69  cl_DriverGetOpti
2a50: 6f 6e 50 72 6f 63 20 2a 67 65 74 4f 70 74 69 6f  onProc *getOptio
2a60: 6e 50 72 6f 63 3b 0a 0a 20 20 20 20 67 65 74 4f  nProc;..    getO
2a70: 70 74 69 6f 6e 50 72 6f 63 20 3d 20 54 63 6c 5f  ptionProc = Tcl_
2a80: 43 68 61 6e 6e 65 6c 47 65 74 4f 70 74 69 6f 6e  ChannelGetOption
2a90: 50 72 6f 63 28 54 63 6c 5f 47 65 74 43 68 61 6e  Proc(Tcl_GetChan
2aa0: 6e 65 6c 54 79 70 65 28 64 6f 77 6e 43 68 61 6e  nelType(downChan
2ab0: 29 29 3b 0a 20 20 20 20 69 66 20 28 67 65 74 4f  ));.    if (getO
2ac0: 70 74 69 6f 6e 50 72 6f 63 20 21 3d 20 4e 55 4c  ptionProc != NUL
2ad0: 4c 29 20 7b 0a 09 72 65 74 75 72 6e 20 28 2a 67  L) {..return (*g
2ae0: 65 74 4f 70 74 69 6f 6e 50 72 6f 63 29 28 54 63  etOptionProc)(Tc
2af0: 6c 5f 47 65 74 43 68 61 6e 6e 65 6c 49 6e 73 74  l_GetChannelInst
2b00: 61 6e 63 65 44 61 74 61 28 64 6f 77 6e 43 68 61  anceData(downCha
2b10: 6e 29 2c 0a 09 09 69 6e 74 65 72 70 2c 20 6f 70  n),...interp, op
2b20: 74 69 6f 6e 4e 61 6d 65 2c 20 64 73 50 74 72 29  tionName, dsPtr)
2b30: 3b 0a 20 20 20 20 7d 20 65 6c 73 65 20 69 66 20  ;.    } else if 
2b40: 28 6f 70 74 69 6f 6e 4e 61 6d 65 20 3d 3d 20 28  (optionName == (
2b50: 63 68 61 72 2a 29 20 4e 55 4c 4c 29 20 7b 0a 09  char*) NULL) {..
2b60: 2f 2a 0a 09 20 2a 20 52 65 71 75 65 73 74 20 69  /*.. * Request i
2b70: 73 20 71 75 65 72 79 20 66 6f 72 20 61 6c 6c 20  s query for all 
2b80: 6f 70 74 69 6f 6e 73 2c 20 74 68 69 73 20 69 73  options, this is
2b90: 20 6f 6b 2e 0a 09 20 2a 2f 0a 09 72 65 74 75 72   ok... */..retur
2ba0: 6e 20 54 43 4c 5f 4f 4b 3b 0a 20 20 20 20 7d 0a  n TCL_OK;.    }.
2bb0: 20 20 20 20 2f 2a 0a 20 20 20 20 20 2a 20 52 65      /*.     * Re
2bc0: 71 75 65 73 74 20 66 6f 72 20 61 20 73 70 65 63  quest for a spec
2bd0: 69 66 69 63 20 6f 70 74 69 6f 6e 20 68 61 73 20  ific option has 
2be0: 74 6f 20 66 61 69 6c 2c 20 77 65 20 64 6f 6e 27  to fail, we don'
2bf0: 74 20 68 61 76 65 20 61 6e 79 2e 0a 20 20 20 20  t have any..    
2c00: 20 2a 2f 0a 20 20 20 20 72 65 74 75 72 6e 20 54   */.    return T
2c10: 43 4c 5f 45 52 52 4f 52 3b 0a 23 65 6c 73 65 0a  CL_ERROR;.#else.
2c20: 20 20 20 20 53 74 61 74 65 20 2a 73 74 61 74 65      State *state
2c30: 50 74 72 20 3d 20 28 53 74 61 74 65 20 2a 29 20  Ptr = (State *) 
2c40: 69 6e 73 74 61 6e 63 65 44 61 74 61 3b 0a 20 20  instanceData;.  
2c50: 20 20 73 69 7a 65 5f 74 20 6c 65 6e 20 3d 20 30    size_t len = 0
2c60: 3b 0a 0a 20 20 20 20 69 66 20 28 6f 70 74 69 6f  ;..    if (optio
2c70: 6e 4e 61 6d 65 20 21 3d 20 28 63 68 61 72 20 2a  nName != (char *
2c80: 29 20 4e 55 4c 4c 29 20 7b 0a 20 20 20 20 20 20  ) NULL) {.      
2c90: 20 20 6c 65 6e 20 3d 20 73 74 72 6c 65 6e 28 6f    len = strlen(o
2ca0: 70 74 69 6f 6e 4e 61 6d 65 29 3b 0a 20 20 20 20  ptionName);.    
2cb0: 7d 0a 23 69 66 20 30 0a 20 20 20 20 69 66 20 28  }.#if 0.    if (
2cc0: 28 6c 65 6e 20 3d 3d 20 30 29 20 7c 7c 0a 20 20  (len == 0) ||.  
2cd0: 20 20 20 20 20 20 28 28 6c 65 6e 20 3e 20 31 29        ((len > 1)
2ce0: 20 26 26 20 28 6f 70 74 69 6f 6e 4e 61 6d 65 5b   && (optionName[
2cf0: 31 5d 20 3d 3d 20 27 63 27 29 20 26 26 0a 20 20  1] == 'c') &&.  
2d00: 20 20 20 20 20 20 20 28 73 74 72 6e 63 6d 70 28         (strncmp(
2d10: 6f 70 74 69 6f 6e 4e 61 6d 65 2c 20 22 2d 63 69  optionName, "-ci
2d20: 70 68 65 72 22 2c 20 6c 65 6e 29 20 3d 3d 20 30  pher", len) == 0
2d30: 29 29 29 20 7b 0a 20 20 20 20 20 20 20 20 69 66  ))) {.        if
2d40: 20 28 6c 65 6e 20 3d 3d 20 30 29 20 7b 0a 20 20   (len == 0) {.  
2d50: 20 20 20 20 20 20 20 20 20 20 54 63 6c 5f 44 53            Tcl_DS
2d60: 74 72 69 6e 67 41 70 70 65 6e 64 45 6c 65 6d 65  tringAppendEleme
2d70: 6e 74 28 64 73 50 74 72 2c 20 22 2d 63 69 70 68  nt(dsPtr, "-ciph
2d80: 65 72 22 29 3b 0a 20 20 20 20 20 20 20 20 7d 0a  er");.        }.
2d90: 20 20 20 20 20 20 20 20 54 63 6c 5f 44 53 74 72          Tcl_DStr
2da0: 69 6e 67 41 70 70 65 6e 64 45 6c 65 6d 65 6e 74  ingAppendElement
2db0: 28 64 73 50 74 72 2c 20 53 53 4c 5f 67 65 74 5f  (dsPtr, SSL_get_
2dc0: 63 69 70 68 65 72 28 73 74 61 74 65 50 74 72 2d  cipher(statePtr-
2dd0: 3e 73 73 6c 29 29 3b 0a 20 20 20 20 20 20 20 20  >ssl));.        
2de0: 69 66 20 28 6c 65 6e 29 20 7b 0a 20 20 20 20 20  if (len) {.     
2df0: 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 54 43         return TC
2e00: 4c 5f 4f 4b 3b 0a 20 20 20 20 20 20 20 20 7d 0a  L_OK;.        }.
2e10: 20 20 20 20 7d 0a 23 65 6e 64 69 66 0a 20 20 20      }.#endif.   
2e20: 20 72 65 74 75 72 6e 20 54 43 4c 5f 4f 4b 3b 0a   return TCL_OK;.
2e30: 23 65 6e 64 69 66 0a 7d 0a 0c 0a 2f 2a 0a 20 2a  #endif.}.../*. *
2e40: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2e50: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2e60: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2e70: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2e80: 2d 2d 2d 0a 20 2a 0a 20 2a 20 54 6c 73 57 61 74  ---. *. * TlsWat
2e90: 63 68 50 72 6f 63 20 2d 2d 0a 20 2a 0a 20 2a 09  chProc --. *. *.
2ea0: 49 6e 69 74 69 61 6c 69 7a 65 20 74 68 65 20 6e  Initialize the n
2eb0: 6f 74 69 66 69 65 72 20 74 6f 20 77 61 74 63 68  otifier to watch
2ec0: 20 54 63 6c 5f 46 69 6c 65 73 20 66 72 6f 6d 20   Tcl_Files from 
2ed0: 74 68 69 73 20 63 68 61 6e 6e 65 6c 2e 0a 20 2a  this channel.. *
2ee0: 0a 20 2a 20 52 65 73 75 6c 74 73 3a 0a 20 2a 09  . * Results:. *.
2ef0: 4e 6f 6e 65 2e 0a 20 2a 0a 20 2a 20 53 69 64 65  None.. *. * Side
2f00: 20 65 66 66 65 63 74 73 3a 0a 20 2a 09 53 65 74   effects:. *.Set
2f10: 73 20 75 70 20 74 68 65 20 6e 6f 74 69 66 69 65  s up the notifie
2f20: 72 20 73 6f 20 74 68 61 74 20 61 20 66 75 74 75  r so that a futu
2f30: 72 65 20 65 76 65 6e 74 20 6f 6e 20 74 68 65 20  re event on the 
2f40: 63 68 61 6e 6e 65 6c 0a 20 2a 09 77 69 6c 6c 20  channel. *.will 
2f50: 62 65 20 73 65 65 6e 20 62 79 20 54 63 6c 2e 0a  be seen by Tcl..
2f60: 20 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d   *. *-----------
2f70: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2f80: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2f90: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2fa0: 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 2f 0a 0a 73 74  --------. */..st
2fb0: 61 74 69 63 20 76 6f 69 64 0a 54 6c 73 57 61 74  atic void.TlsWat
2fc0: 63 68 50 72 6f 63 28 43 6c 69 65 6e 74 44 61 74  chProc(ClientDat
2fd0: 61 20 69 6e 73 74 61 6e 63 65 44 61 74 61 2c 09  a instanceData,.
2fe0: 2f 2a 20 54 68 65 20 73 6f 63 6b 65 74 20 73 74  /* The socket st
2ff0: 61 74 65 2e 20 2a 2f 0a 20 20 20 20 20 20 20 20  ate. */.        
3000: 20 20 20 20 20 69 6e 74 20 6d 61 73 6b 29 09 09       int mask)..
3010: 09 2f 2a 20 45 76 65 6e 74 73 20 6f 66 20 69 6e  ./* Events of in
3020: 74 65 72 65 73 74 3b 20 61 6e 20 4f 52 2d 65 64  terest; an OR-ed
3030: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
3040: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3050: 20 20 20 20 20 20 20 20 20 20 2a 20 63 6f 6d 62            * comb
3060: 69 6e 61 74 69 6f 6e 20 6f 66 20 54 43 4c 5f 52  ination of TCL_R
3070: 45 41 44 41 42 4c 45 2c 0a 20 20 20 20 20 20 20  EADABLE,.       
3080: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3090: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
30a0: 20 20 2a 20 54 43 4c 5f 57 52 49 54 41 42 4c 45    * TCL_WRITABLE
30b0: 20 61 6e 64 20 54 43 4c 5f 45 58 43 45 50 54 49   and TCL_EXCEPTI
30c0: 4f 4e 2e 20 2a 2f 0a 7b 0a 20 20 20 20 53 74 61  ON. */.{.    Sta
30d0: 74 65 20 2a 73 74 61 74 65 50 74 72 20 3d 20 28  te *statePtr = (
30e0: 53 74 61 74 65 20 2a 29 20 69 6e 73 74 61 6e 63  State *) instanc
30f0: 65 44 61 74 61 3b 0a 0a 23 69 66 64 65 66 20 54  eData;..#ifdef T
3100: 43 4c 5f 43 48 41 4e 4e 45 4c 5f 56 45 52 53 49  CL_CHANNEL_VERSI
3110: 4f 4e 5f 32 0a 20 20 20 20 54 63 6c 5f 43 68 61  ON_2.    Tcl_Cha
3120: 6e 6e 65 6c 20 20 20 20 20 64 6f 77 6e 43 68 61  nnel     downCha
3130: 6e 3b 0a 0a 20 20 20 20 73 74 61 74 65 50 74 72  n;..    statePtr
3140: 2d 3e 77 61 74 63 68 4d 61 73 6b 20 3d 20 6d 61  ->watchMask = ma
3150: 73 6b 3b 0a 0a 20 20 20 20 2f 2a 20 4e 6f 20 63  sk;..    /* No c
3160: 68 61 6e 6e 65 6c 20 68 61 6e 64 6c 65 72 73 20  hannel handlers 
3170: 61 6e 79 20 6d 6f 72 65 2e 20 57 65 20 77 69 6c  any more. We wil
3180: 6c 20 62 65 20 6e 6f 74 69 66 69 65 64 20 61 75  l be notified au
3190: 74 6f 6d 61 74 69 63 61 6c 6c 79 0a 20 20 20 20  tomatically.    
31a0: 20 2a 20 61 62 6f 75 74 20 65 76 65 6e 74 73 20   * about events 
31b0: 6f 6e 20 74 68 65 20 63 68 61 6e 6e 65 6c 20 62  on the channel b
31c0: 65 6c 6f 77 20 76 69 61 20 61 20 63 61 6c 6c 20  elow via a call 
31d0: 74 6f 20 6f 75 72 0a 20 20 20 20 20 2a 20 27 54  to our.     * 'T
31e0: 72 61 6e 73 66 6f 72 6d 4e 6f 74 69 66 79 50 72  ransformNotifyPr
31f0: 6f 63 27 2e 20 42 75 74 20 77 65 20 68 61 76 65  oc'. But we have
3200: 20 74 6f 20 70 61 73 73 20 74 68 65 20 69 6e 74   to pass the int
3210: 65 72 65 73 74 20 64 6f 77 6e 20 6e 6f 77 2e 0a  erest down now..
3220: 20 20 20 20 20 2a 20 57 65 20 61 72 65 20 61 6c       * We are al
3230: 6c 6f 77 65 64 20 74 6f 20 61 64 64 20 61 64 64  lowed to add add
3240: 69 74 69 6f 6e 61 6c 20 27 69 6e 74 65 72 65 73  itional 'interes
3250: 74 27 20 74 6f 20 74 68 65 20 6d 61 73 6b 20 69  t' to the mask i
3260: 66 20 77 65 20 77 61 6e 74 0a 20 20 20 20 20 2a  f we want.     *
3270: 20 74 6f 2e 20 42 75 74 20 74 68 69 73 20 74 72   to. But this tr
3280: 61 6e 73 66 6f 72 6d 61 74 69 6f 6e 20 68 61 73  ansformation has
3290: 20 6e 6f 20 73 75 63 68 20 69 6e 74 65 72 65 73   no such interes
32a0: 74 2e 20 49 74 20 6a 75 73 74 20 70 61 73 73 65  t. It just passe
32b0: 73 0a 20 20 20 20 20 2a 20 74 68 65 20 72 65 71  s.     * the req
32c0: 75 65 73 74 20 64 6f 77 6e 2c 20 75 6e 63 68 61  uest down, uncha
32d0: 6e 67 65 64 2e 0a 20 20 20 20 20 2a 2f 0a 0a 20  nged..     */.. 
32e0: 20 20 20 64 6f 77 6e 43 68 61 6e 20 3d 20 54 6c     downChan = Tl
32f0: 73 5f 47 65 74 50 61 72 65 6e 74 28 73 74 61 74  s_GetParent(stat
3300: 65 50 74 72 29 3b 0a 0a 20 20 20 20 28 54 63 6c  ePtr);..    (Tcl
3310: 5f 47 65 74 43 68 61 6e 6e 65 6c 54 79 70 65 28  _GetChannelType(
3320: 64 6f 77 6e 43 68 61 6e 29 29 0a 09 2d 3e 77 61  downChan))..->wa
3330: 74 63 68 50 72 6f 63 28 54 63 6c 5f 47 65 74 43  tchProc(Tcl_GetC
3340: 68 61 6e 6e 65 6c 49 6e 73 74 61 6e 63 65 44 61  hannelInstanceDa
3350: 74 61 28 64 6f 77 6e 43 68 61 6e 29 2c 20 6d 61  ta(downChan), ma
3360: 73 6b 29 3b 0a 0a 20 20 20 20 2f 2a 0a 20 20 20  sk);..    /*.   
3370: 20 20 2a 20 4d 61 6e 61 67 65 6d 65 6e 74 20 6f    * Management o
3380: 66 20 74 68 65 20 69 6e 74 65 72 6e 61 6c 20 74  f the internal t
3390: 69 6d 65 72 2e 0a 20 20 20 20 20 2a 2f 0a 0a 20  imer..     */.. 
33a0: 20 20 20 69 66 20 28 73 74 61 74 65 50 74 72 2d     if (statePtr-
33b0: 3e 74 69 6d 65 72 20 21 3d 20 28 54 63 6c 5f 54  >timer != (Tcl_T
33c0: 69 6d 65 72 54 6f 6b 65 6e 29 20 4e 55 4c 4c 29  imerToken) NULL)
33d0: 20 7b 0a 20 20 20 20 20 20 20 20 54 63 6c 5f 44   {.        Tcl_D
33e0: 65 6c 65 74 65 54 69 6d 65 72 48 61 6e 64 6c 65  eleteTimerHandle
33f0: 72 28 73 74 61 74 65 50 74 72 2d 3e 74 69 6d 65  r(statePtr->time
3400: 72 29 3b 0a 09 73 74 61 74 65 50 74 72 2d 3e 74  r);..statePtr->t
3410: 69 6d 65 72 20 3d 20 28 54 63 6c 5f 54 69 6d 65  imer = (Tcl_Time
3420: 72 54 6f 6b 65 6e 29 20 4e 55 4c 4c 3b 0a 20 20  rToken) NULL;.  
3430: 20 20 7d 0a 20 20 20 20 69 66 20 28 28 6d 61 73    }.    if ((mas
3440: 6b 20 26 20 54 43 4c 5f 52 45 41 44 41 42 4c 45  k & TCL_READABLE
3450: 29 20 26 26 20 54 63 6c 5f 49 6e 70 75 74 42 75  ) && Tcl_InputBu
3460: 66 66 65 72 65 64 28 73 74 61 74 65 50 74 72 2d  ffered(statePtr-
3470: 3e 73 65 6c 66 29 20 3e 20 30 29 20 7b 0a 20 20  >self) > 0) {.  
3480: 20 20 20 20 20 20 2f 2a 0a 09 20 2a 20 54 68 65        /*.. * The
3490: 72 65 20 69 73 20 69 6e 74 65 72 65 73 74 20 69  re is interest i
34a0: 6e 20 72 65 61 64 61 62 6c 65 20 65 76 65 6e 74  n readable event
34b0: 73 20 61 6e 64 20 77 65 20 61 63 74 75 61 6c 6c  s and we actuall
34c0: 79 20 68 61 76 65 0a 09 20 2a 20 64 61 74 61 20  y have.. * data 
34d0: 77 61 69 74 69 6e 67 2c 20 73 6f 20 67 65 6e 65  waiting, so gene
34e0: 72 61 74 65 20 61 20 74 69 6d 65 72 20 74 6f 20  rate a timer to 
34f0: 66 6c 75 73 68 20 74 68 61 74 2e 0a 09 20 2a 2f  flush that... */
3500: 0a 09 73 74 61 74 65 50 74 72 2d 3e 74 69 6d 65  ..statePtr->time
3510: 72 20 3d 20 54 63 6c 5f 43 72 65 61 74 65 54 69  r = Tcl_CreateTi
3520: 6d 65 72 48 61 6e 64 6c 65 72 28 54 4c 53 5f 54  merHandler(TLS_T
3530: 43 4c 5f 44 45 4c 41 59 2c 0a 09 09 54 6c 73 43  CL_DELAY,...TlsC
3540: 68 61 6e 6e 65 6c 48 61 6e 64 6c 65 72 54 69 6d  hannelHandlerTim
3550: 65 72 2c 20 28 43 6c 69 65 6e 74 44 61 74 61 29  er, (ClientData)
3560: 20 73 74 61 74 65 50 74 72 29 3b 0a 20 20 20 20   statePtr);.    
3570: 7d 0a 23 65 6c 73 65 0a 20 20 20 20 69 66 20 28  }.#else.    if (
3580: 6d 61 73 6b 20 3d 3d 20 73 74 61 74 65 50 74 72  mask == statePtr
3590: 2d 3e 77 61 74 63 68 4d 61 73 6b 29 0a 09 72 65  ->watchMask)..re
35a0: 74 75 72 6e 3b 0a 0a 20 20 20 20 69 66 20 28 73  turn;..    if (s
35b0: 74 61 74 65 50 74 72 2d 3e 77 61 74 63 68 4d 61  tatePtr->watchMa
35c0: 73 6b 29 20 7b 0a 09 2f 2a 0a 09 20 2a 20 52 65  sk) {../*.. * Re
35d0: 6d 6f 76 65 20 65 76 65 6e 74 20 68 61 6e 64 6c  move event handl
35e0: 65 72 20 74 6f 20 75 6e 64 65 72 6c 79 69 6e 67  er to underlying
35f0: 20 63 68 61 6e 6e 65 6c 2c 20 74 68 69 73 20 63   channel, this c
3600: 6f 75 6c 64 0a 09 20 2a 20 62 65 20 62 65 63 61  ould.. * be beca
3610: 75 73 65 20 77 65 20 61 72 65 20 63 6c 6f 73 69  use we are closi
3620: 6e 67 20 66 6f 72 20 72 65 61 6c 2c 20 6f 72 20  ng for real, or 
3630: 62 65 69 6e 67 20 22 75 6e 73 74 61 63 6b 65 64  being "unstacked
3640: 22 2e 0a 09 20 2a 2f 0a 0a 09 54 63 6c 5f 44 65  "... */...Tcl_De
3650: 6c 65 74 65 43 68 61 6e 6e 65 6c 48 61 6e 64 6c  leteChannelHandl
3660: 65 72 28 54 6c 73 5f 47 65 74 50 61 72 65 6e 74  er(Tls_GetParent
3670: 28 73 74 61 74 65 50 74 72 29 2c 0a 09 09 54 6c  (statePtr),...Tl
3680: 73 43 68 61 6e 6e 65 6c 48 61 6e 64 6c 65 72 2c  sChannelHandler,
3690: 20 28 43 6c 69 65 6e 74 44 61 74 61 29 20 73 74   (ClientData) st
36a0: 61 74 65 50 74 72 29 3b 0a 20 20 20 20 7d 0a 20  atePtr);.    }. 
36b0: 20 20 20 73 74 61 74 65 50 74 72 2d 3e 77 61 74     statePtr->wat
36c0: 63 68 4d 61 73 6b 20 3d 20 6d 61 73 6b 3b 0a 20  chMask = mask;. 
36d0: 20 20 20 69 66 20 28 73 74 61 74 65 50 74 72 2d     if (statePtr-
36e0: 3e 77 61 74 63 68 4d 61 73 6b 29 20 7b 0a 09 2f  >watchMask) {../
36f0: 2a 0a 09 20 2a 20 53 65 74 75 70 20 61 63 74 69  *.. * Setup acti
3700: 76 65 20 6d 6f 6e 69 74 6f 72 20 66 6f 72 20 65  ve monitor for e
3710: 76 65 6e 74 73 20 6f 6e 20 75 6e 64 65 72 6c 79  vents on underly
3720: 69 6e 67 20 43 68 61 6e 6e 65 6c 2e 0a 09 20 2a  ing Channel... *
3730: 2f 0a 0a 09 54 63 6c 5f 43 72 65 61 74 65 43 68  /...Tcl_CreateCh
3740: 61 6e 6e 65 6c 48 61 6e 64 6c 65 72 28 54 6c 73  annelHandler(Tls
3750: 5f 47 65 74 50 61 72 65 6e 74 28 73 74 61 74 65  _GetParent(state
3760: 50 74 72 29 2c 0a 09 09 73 74 61 74 65 50 74 72  Ptr),...statePtr
3770: 2d 3e 77 61 74 63 68 4d 61 73 6b 2c 20 54 6c 73  ->watchMask, Tls
3780: 43 68 61 6e 6e 65 6c 48 61 6e 64 6c 65 72 2c 20  ChannelHandler, 
3790: 28 43 6c 69 65 6e 74 44 61 74 61 29 20 73 74 61  (ClientData) sta
37a0: 74 65 50 74 72 29 3b 0a 20 20 20 20 7d 0a 23 65  tePtr);.    }.#e
37b0: 6e 64 69 66 0a 7d 0a 0c 0a 2f 2a 0a 20 2a 2d 2d  ndif.}.../*. *--
37c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
37d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
37e0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
37f0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3800: 2d 0a 20 2a 0a 20 2a 20 54 6c 73 47 65 74 48 61  -. *. * TlsGetHa
3810: 6e 64 6c 65 50 72 6f 63 20 2d 2d 0a 20 2a 0a 20  ndleProc --. *. 
3820: 2a 09 43 61 6c 6c 65 64 20 66 72 6f 6d 20 54 63  *.Called from Tc
3830: 6c 5f 47 65 74 43 68 61 6e 6e 65 6c 46 69 6c 65  l_GetChannelFile
3840: 20 74 6f 20 72 65 74 72 69 65 76 65 20 6f 2f 73   to retrieve o/s
3850: 20 66 69 6c 65 20 68 61 6e 64 6c 65 72 0a 20 2a   file handler. *
3860: 09 66 72 6f 6d 20 74 68 65 20 53 53 4c 20 73 6f  .from the SSL so
3870: 63 6b 65 74 20 62 61 73 65 64 20 63 68 61 6e 6e  cket based chann
3880: 65 6c 2e 0a 20 2a 0a 20 2a 20 52 65 73 75 6c 74  el.. *. * Result
3890: 73 3a 0a 20 2a 09 54 68 65 20 61 70 70 72 6f 70  s:. *.The approp
38a0: 72 69 61 74 65 20 54 63 6c 5f 46 69 6c 65 20 6f  riate Tcl_File o
38b0: 72 20 4e 55 4c 4c 20 69 66 20 6e 6f 74 20 70 72  r NULL if not pr
38c0: 65 73 65 6e 74 2e 20 0a 20 2a 0a 20 2a 20 53 69  esent. . *. * Si
38d0: 64 65 20 65 66 66 65 63 74 73 3a 0a 20 2a 09 4e  de effects:. *.N
38e0: 6f 6e 65 2e 0a 20 2a 0a 20 2a 2d 2d 2d 2d 2d 2d  one.. *. *------
38f0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3900: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3910: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3920: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a  -------------. *
3930: 2f 0a 73 74 61 74 69 63 20 69 6e 74 0a 54 6c 73  /.static int.Tls
3940: 47 65 74 48 61 6e 64 6c 65 50 72 6f 63 28 43 6c  GetHandleProc(Cl
3950: 69 65 6e 74 44 61 74 61 20 69 6e 73 74 61 6e 63  ientData instanc
3960: 65 44 61 74 61 2c 09 2f 2a 20 54 68 65 20 73 6f  eData,./* The so
3970: 63 6b 65 74 20 73 74 61 74 65 2e 20 2a 2f 0a 20  cket state. */. 
3980: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3990: 69 6e 74 20 64 69 72 65 63 74 69 6f 6e 2c 09 09  int direction,..
39a0: 2f 2a 20 57 68 69 63 68 20 54 63 6c 5f 46 69 6c  /* Which Tcl_Fil
39b0: 65 20 74 6f 20 72 65 74 72 69 65 76 65 3f 20 2a  e to retrieve? *
39c0: 2f 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  /.              
39d0: 20 20 20 43 6c 69 65 6e 74 44 61 74 61 20 2a 68     ClientData *h
39e0: 61 6e 64 6c 65 50 74 72 29 09 2f 2a 20 57 68 65  andlePtr)./* Whe
39f0: 72 65 20 74 6f 20 73 74 6f 72 65 20 74 68 65 20  re to store the 
3a00: 68 61 6e 64 6c 65 2e 20 20 2a 2f 0a 7b 0a 20 20  handle.  */.{.  
3a10: 20 20 53 74 61 74 65 20 2a 73 74 61 74 65 50 74    State *statePt
3a20: 72 20 3d 20 28 53 74 61 74 65 20 2a 29 20 69 6e  r = (State *) in
3a30: 73 74 61 6e 63 65 44 61 74 61 3b 0a 0a 20 20 20  stanceData;..   
3a40: 20 72 65 74 75 72 6e 20 54 63 6c 5f 47 65 74 43   return Tcl_GetC
3a50: 68 61 6e 6e 65 6c 48 61 6e 64 6c 65 28 54 6c 73  hannelHandle(Tls
3a60: 5f 47 65 74 50 61 72 65 6e 74 28 73 74 61 74 65  _GetParent(state
3a70: 50 74 72 29 2c 20 64 69 72 65 63 74 69 6f 6e 2c  Ptr), direction,
3a80: 20 68 61 6e 64 6c 65 50 74 72 29 3b 0a 7d 0a 0c   handlePtr);.}..
3a90: 0a 2f 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ./*. *----------
3aa0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3ab0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3ac0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3ad0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 0a 20 2a 20  ---------. *. * 
3ae0: 54 6c 73 4e 6f 74 69 66 79 50 72 6f 63 20 2d 2d  TlsNotifyProc --
3af0: 0a 20 2a 0a 20 2a 09 48 61 6e 64 6c 65 72 20 63  . *. *.Handler c
3b00: 61 6c 6c 65 64 20 62 79 20 54 63 6c 20 74 6f 20  alled by Tcl to 
3b10: 69 6e 66 6f 72 6d 20 75 73 20 6f 66 20 61 63 74  inform us of act
3b20: 69 76 69 74 79 0a 20 2a 09 6f 6e 20 74 68 65 20  ivity. *.on the 
3b30: 75 6e 64 65 72 6c 79 69 6e 67 20 63 68 61 6e 6e  underlying chann
3b40: 65 6c 2e 0a 20 2a 0a 20 2a 20 52 65 73 75 6c 74  el.. *. * Result
3b50: 73 3a 0a 20 2a 09 4e 6f 6e 65 2e 0a 20 2a 0a 20  s:. *.None.. *. 
3b60: 2a 20 53 69 64 65 20 65 66 66 65 63 74 73 3a 0a  * Side effects:.
3b70: 20 2a 09 4d 61 79 20 70 72 6f 63 65 73 73 20 74   *.May process t
3b80: 68 65 20 69 6e 63 6f 6d 69 6e 67 20 65 76 65 6e  he incoming even
3b90: 74 20 62 79 20 69 74 73 65 6c 66 2e 0a 20 2a 0a  t by itself.. *.
3ba0: 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d   *--------------
3bb0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3bc0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3bd0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3be0: 2d 2d 2d 2d 2d 0a 20 2a 2f 0a 0a 73 74 61 74 69  -----. */..stati
3bf0: 63 20 69 6e 74 0a 54 6c 73 4e 6f 74 69 66 79 50  c int.TlsNotifyP
3c00: 72 6f 63 28 69 6e 73 74 61 6e 63 65 44 61 74 61  roc(instanceData
3c10: 2c 20 6d 61 73 6b 29 0a 20 20 20 20 43 6c 69 65  , mask).    Clie
3c20: 6e 74 44 61 74 61 09 20 20 20 69 6e 73 74 61 6e  ntData.   instan
3c30: 63 65 44 61 74 61 3b 20 2f 2a 20 54 68 65 20 73  ceData; /* The s
3c40: 74 61 74 65 20 6f 66 20 74 68 65 20 6e 6f 74 69  tate of the noti
3c50: 66 69 65 64 20 74 72 61 6e 73 66 6f 72 6d 61 74  fied transformat
3c60: 69 6f 6e 20 2a 2f 0a 20 20 20 20 69 6e 74 09 09  ion */.    int..
3c70: 20 20 20 6d 61 73 6b 3b 20 20 20 20 20 20 20 2f     mask;       /
3c80: 2a 20 54 68 65 20 6d 61 73 6b 20 6f 66 20 6f 63  * The mask of oc
3c90: 63 75 72 69 6e 67 20 65 76 65 6e 74 73 20 2a 2f  curing events */
3ca0: 0a 7b 0a 20 20 20 20 53 74 61 74 65 20 2a 73 74  .{.    State *st
3cb0: 61 74 65 50 74 72 20 3d 20 28 53 74 61 74 65 20  atePtr = (State 
3cc0: 2a 29 20 69 6e 73 74 61 6e 63 65 44 61 74 61 3b  *) instanceData;
3cd0: 0a 0a 20 20 20 20 2f 2a 0a 20 20 20 20 20 2a 20  ..    /*.     * 
3ce0: 41 6e 20 65 76 65 6e 74 20 6f 63 63 75 72 65 64  An event occured
3cf0: 20 69 6e 20 74 68 65 20 75 6e 64 65 72 6c 79 69   in the underlyi
3d00: 6e 67 20 63 68 61 6e 6e 65 6c 2e 20 20 54 68 69  ng channel.  Thi
3d10: 73 0a 20 20 20 20 20 2a 20 74 72 61 6e 73 66 6f  s.     * transfo
3d20: 72 6d 61 74 69 6f 6e 20 64 6f 65 73 6e 27 74 20  rmation doesn't 
3d30: 70 72 6f 63 65 73 73 20 73 75 63 68 20 65 76 65  process such eve
3d40: 6e 74 73 20 74 68 75 73 20 72 65 74 75 72 6e 73  nts thus returns
3d50: 20 74 68 65 0a 20 20 20 20 20 2a 20 69 6e 63 6f   the.     * inco
3d60: 6d 69 6e 67 20 6d 61 73 6b 20 75 6e 63 68 61 6e  ming mask unchan
3d70: 67 65 64 2e 0a 20 20 20 20 20 2a 2f 0a 0a 20 20  ged..     */..  
3d80: 20 20 69 66 20 28 73 74 61 74 65 50 74 72 2d 3e    if (statePtr->
3d90: 74 69 6d 65 72 20 21 3d 20 28 54 63 6c 5f 54 69  timer != (Tcl_Ti
3da0: 6d 65 72 54 6f 6b 65 6e 29 20 4e 55 4c 4c 29 20  merToken) NULL) 
3db0: 7b 0a 09 2f 2a 0a 09 20 2a 20 44 65 6c 65 74 65  {../*.. * Delete
3dc0: 20 61 6e 20 65 78 69 73 74 69 6e 67 20 74 69 6d   an existing tim
3dd0: 65 72 2e 20 49 74 20 77 61 73 20 6e 6f 74 20 66  er. It was not f
3de0: 69 72 65 64 2c 20 79 65 74 20 77 65 20 61 72 65  ired, yet we are
3df0: 0a 09 20 2a 20 68 65 72 65 2c 20 73 6f 20 74 68  .. * here, so th
3e00: 65 20 63 68 61 6e 6e 65 6c 20 62 65 6c 6f 77 20  e channel below 
3e10: 67 65 6e 65 72 61 74 65 64 20 73 75 63 68 20 61  generated such a
3e20: 6e 20 65 76 65 6e 74 20 61 6e 64 20 77 65 0a 09  n event and we..
3e30: 20 2a 20 64 6f 6e 27 74 20 68 61 76 65 20 74 6f   * don't have to
3e40: 2e 20 54 68 65 20 72 65 6e 65 77 61 6c 20 6f 66  . The renewal of
3e50: 20 74 68 65 20 69 6e 74 65 72 65 73 74 20 61 66   the interest af
3e60: 74 65 72 20 74 68 65 0a 09 20 2a 20 65 78 65 63  ter the.. * exec
3e70: 75 74 69 6f 6e 20 6f 66 20 63 68 61 6e 6e 65 6c  ution of channel
3e80: 20 68 61 6e 64 6c 65 72 73 20 77 69 6c 6c 20 65   handlers will e
3e90: 76 65 6e 74 75 61 6c 6c 79 20 63 61 75 73 65 20  ventually cause 
3ea0: 75 73 20 74 6f 0a 09 20 2a 20 72 65 63 72 65 61  us to.. * recrea
3eb0: 74 65 20 74 68 65 20 74 69 6d 65 72 20 28 69 6e  te the timer (in
3ec0: 20 57 61 74 63 68 50 72 6f 63 29 2e 0a 09 20 2a   WatchProc)... *
3ed0: 2f 0a 0a 09 54 63 6c 5f 44 65 6c 65 74 65 54 69  /...Tcl_DeleteTi
3ee0: 6d 65 72 48 61 6e 64 6c 65 72 28 73 74 61 74 65  merHandler(state
3ef0: 50 74 72 2d 3e 74 69 6d 65 72 29 3b 0a 09 73 74  Ptr->timer);..st
3f00: 61 74 65 50 74 72 2d 3e 74 69 6d 65 72 20 3d 20  atePtr->timer = 
3f10: 28 54 63 6c 5f 54 69 6d 65 72 54 6f 6b 65 6e 29  (Tcl_TimerToken)
3f20: 20 4e 55 4c 4c 3b 0a 20 20 20 20 7d 0a 0a 20 20   NULL;.    }..  
3f30: 20 20 72 65 74 75 72 6e 20 6d 61 73 6b 3b 0a 7d    return mask;.}
3f40: 0a 0c 0a 23 69 66 6e 64 65 66 20 54 43 4c 5f 43  ...#ifndef TCL_C
3f50: 48 41 4e 4e 45 4c 5f 56 45 52 53 49 4f 4e 5f 32  HANNEL_VERSION_2
3f60: 0a 2f 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ./*. *----------
3f70: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3f80: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3f90: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2a 0a 20 2a  ------------*. *
3fa0: 0a 20 2a 20 20 20 20 20 20 54 6c 73 43 68 61 6e  . *      TlsChan
3fb0: 6e 65 6c 48 61 6e 64 6c 65 72 20 2d 2d 0a 20 2a  nelHandler --. *
3fc0: 0a 20 2a 20 20 20 20 20 20 2d 2d 2d 2d 2d 2d 2d  . *      -------
3fd0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3fe0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3ff0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2a 0a 20 2a 20 20 20  ---------*. *   
4000: 20 20 20 48 61 6e 64 6c 65 72 20 63 61 6c 6c 65     Handler calle
4010: 64 20 62 79 20 54 63 6c 20 61 73 20 61 20 72 65  d by Tcl as a re
4020: 73 75 6c 74 20 6f 66 0a 20 2a 20 20 20 20 20 20  sult of. *      
4030: 54 63 6c 5f 43 72 65 61 74 65 43 68 61 6e 6e 65  Tcl_CreateChanne
4040: 6c 48 61 6e 64 6c 65 72 20 2d 20 74 6f 20 69 6e  lHandler - to in
4050: 66 6f 72 6d 20 75 73 20 6f 66 20 61 63 74 69 76  form us of activ
4060: 69 74 79 0a 20 2a 20 20 20 20 20 20 6f 6e 20 74  ity. *      on t
4070: 68 65 20 75 6e 64 65 72 6c 79 69 6e 67 20 63 68  he underlying ch
4080: 61 6e 6e 65 6c 2e 0a 20 2a 20 20 20 20 20 20 2d  annel.. *      -
4090: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
40a0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
40b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2a  ---------------*
40c0: 0a 20 2a 0a 20 2a 20 20 20 20 20 20 53 69 64 65  . *. *      Side
40d0: 65 66 66 65 63 74 73 3a 0a 20 2a 20 20 20 20 20  effects:. *     
40e0: 20 20 20 20 20 20 20 20 20 4d 61 79 20 67 65 6e           May gen
40f0: 65 72 61 74 65 20 73 75 62 73 65 71 75 65 6e 74  erate subsequent
4100: 20 63 61 6c 6c 73 20 74 6f 0a 20 2a 20 20 20 20   calls to. *    
4110: 20 20 20 20 20 20 20 20 20 20 54 63 6c 5f 4e 6f            Tcl_No
4120: 74 69 66 79 43 68 61 6e 6e 65 6c 2e 0a 20 2a 0a  tifyChannel.. *.
4130: 20 2a 20 20 20 20 20 20 52 65 73 75 6c 74 3a 0a   *      Result:.
4140: 20 2a 20 20 20 20 20 20 20 20 20 20 20 20 20 20   *              
4150: 4e 6f 6e 65 2e 0a 20 2a 0a 20 2a 2d 2d 2d 2d 2d  None.. *. *-----
4160: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4170: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4180: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4190: 2d 2a 0a 20 2a 2f 0a 0a 73 74 61 74 69 63 20 76  -*. */..static v
41a0: 6f 69 64 0a 54 6c 73 43 68 61 6e 6e 65 6c 48 61  oid.TlsChannelHa
41b0: 6e 64 6c 65 72 20 28 63 6c 69 65 6e 74 44 61 74  ndler (clientDat
41c0: 61 2c 20 6d 61 73 6b 29 0a 20 20 20 20 43 6c 69  a, mask).    Cli
41d0: 65 6e 74 44 61 74 61 20 20 20 20 20 63 6c 69 65  entData     clie
41e0: 6e 74 44 61 74 61 3b 0a 20 20 20 20 69 6e 74 20  ntData;.    int 
41f0: 20 20 20 20 20 20 20 20 20 20 20 6d 61 73 6b 3b             mask;
4200: 0a 7b 0a 20 20 20 20 53 74 61 74 65 20 2a 73 74  .{.    State *st
4210: 61 74 65 50 74 72 20 3d 20 28 53 74 61 74 65 20  atePtr = (State 
4220: 2a 29 20 63 6c 69 65 6e 74 44 61 74 61 3b 0a 0a  *) clientData;..
4230: 64 70 72 69 6e 74 66 28 73 74 64 65 72 72 2c 20  dprintf(stderr, 
4240: 22 48 41 4e 44 4c 45 52 28 30 78 25 78 29 5c 6e  "HANDLER(0x%x)\n
4250: 22 2c 20 6d 61 73 6b 29 3b 0a 20 20 20 20 54 63  ", mask);.    Tc
4260: 6c 5f 50 72 65 73 65 72 76 65 28 20 28 43 6c 69  l_Preserve( (Cli
4270: 65 6e 74 44 61 74 61 29 73 74 61 74 65 50 74 72  entData)statePtr
4280: 29 3b 0a 0a 20 20 20 20 69 66 20 28 6d 61 73 6b  );..    if (mask
4290: 20 26 20 54 43 4c 5f 52 45 41 44 41 42 4c 45 29   & TCL_READABLE)
42a0: 20 7b 0a 09 42 49 4f 5f 73 65 74 5f 66 6c 61 67   {..BIO_set_flag
42b0: 73 28 73 74 61 74 65 50 74 72 2d 3e 70 5f 62 69  s(statePtr->p_bi
42c0: 6f 2c 20 42 49 4f 5f 46 4c 41 47 53 5f 52 45 41  o, BIO_FLAGS_REA
42d0: 44 29 3b 0a 20 20 20 20 7d 20 65 6c 73 65 20 7b  D);.    } else {
42e0: 0a 09 42 49 4f 5f 63 6c 65 61 72 5f 66 6c 61 67  ..BIO_clear_flag
42f0: 73 28 73 74 61 74 65 50 74 72 2d 3e 70 5f 62 69  s(statePtr->p_bi
4300: 6f 2c 20 42 49 4f 5f 46 4c 41 47 53 5f 52 45 41  o, BIO_FLAGS_REA
4310: 44 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69  D);.    }..    i
4320: 66 20 28 6d 61 73 6b 20 26 20 54 43 4c 5f 57 52  f (mask & TCL_WR
4330: 49 54 41 42 4c 45 29 20 7b 0a 09 42 49 4f 5f 73  ITABLE) {..BIO_s
4340: 65 74 5f 66 6c 61 67 73 28 73 74 61 74 65 50 74  et_flags(statePt
4350: 72 2d 3e 70 5f 62 69 6f 2c 20 42 49 4f 5f 46 4c  r->p_bio, BIO_FL
4360: 41 47 53 5f 57 52 49 54 45 29 3b 0a 20 20 20 20  AGS_WRITE);.    
4370: 7d 20 65 6c 73 65 20 7b 0a 09 42 49 4f 5f 63 6c  } else {..BIO_cl
4380: 65 61 72 5f 66 6c 61 67 73 28 73 74 61 74 65 50  ear_flags(stateP
4390: 74 72 2d 3e 70 5f 62 69 6f 2c 20 42 49 4f 5f 46  tr->p_bio, BIO_F
43a0: 4c 41 47 53 5f 57 52 49 54 45 29 3b 0a 20 20 20  LAGS_WRITE);.   
43b0: 20 7d 0a 0a 20 20 20 20 6d 61 73 6b 20 3d 20 30   }..    mask = 0
43c0: 3b 0a 20 20 20 20 69 66 20 28 42 49 4f 5f 77 70  ;.    if (BIO_wp
43d0: 65 6e 64 69 6e 67 28 73 74 61 74 65 50 74 72 2d  ending(statePtr-
43e0: 3e 62 69 6f 29 29 20 7b 0a 09 6d 61 73 6b 20 7c  >bio)) {..mask |
43f0: 3d 20 54 43 4c 5f 57 52 49 54 41 42 4c 45 3b 0a  = TCL_WRITABLE;.
4400: 20 20 20 20 7d 0a 20 20 20 20 69 66 20 28 42 49      }.    if (BI
4410: 4f 5f 70 65 6e 64 69 6e 67 28 73 74 61 74 65 50  O_pending(stateP
4420: 74 72 2d 3e 62 69 6f 29 29 20 7b 0a 09 6d 61 73  tr->bio)) {..mas
4430: 6b 20 7c 3d 20 54 43 4c 5f 52 45 41 44 41 42 4c  k |= TCL_READABL
4440: 45 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2a  E;.    }..    /*
4450: 0a 20 20 20 20 20 2a 20 54 68 65 20 66 6f 6c 6c  .     * The foll
4460: 6f 77 69 6e 67 20 4e 6f 74 69 66 79 43 68 61 6e  owing NotifyChan
4470: 6e 65 6c 20 63 61 6c 6c 73 20 73 65 65 6d 73 20  nel calls seems 
4480: 74 6f 20 62 65 20 69 6d 70 6f 72 74 61 6e 74 2c  to be important,
4490: 20 62 75 74 0a 20 20 20 20 20 2a 20 77 65 20 64   but.     * we d
44a0: 6f 6e 27 74 20 6b 6e 6f 77 20 77 68 79 2e 20 20  on't know why.  
44b0: 49 74 20 6c 6f 6f 6b 73 20 6c 69 6b 65 20 69 66  It looks like if
44c0: 20 74 68 65 20 6d 61 73 6b 20 69 73 20 65 76 65   the mask is eve
44d0: 72 20 6e 6f 6e 2d 7a 65 72 6f 0a 20 20 20 20 20  r non-zero.     
44e0: 2a 20 74 68 61 74 20 69 74 20 77 69 6c 6c 20 65  * that it will e
44f0: 6e 74 65 72 20 61 6e 20 69 6e 66 69 6e 69 74 65  nter an infinite
4500: 20 6c 6f 6f 70 2e 0a 20 20 20 20 20 2a 0a 20 20   loop..     *.  
4510: 20 20 20 2a 20 4e 6f 74 69 66 79 20 74 68 65 20     * Notify the 
4520: 75 70 70 65 72 20 63 68 61 6e 6e 65 6c 20 6f 66  upper channel of
4530: 20 74 68 65 20 63 75 72 72 65 6e 74 20 42 49 4f   the current BIO
4540: 20 73 74 61 74 65 20 73 6f 20 74 68 65 20 65 76   state so the ev
4550: 65 6e 74 0a 20 20 20 20 20 2a 20 63 6f 6e 74 69  ent.     * conti
4560: 6e 75 65 73 20 74 6f 20 70 72 6f 70 61 67 61 74  nues to propagat
4570: 65 20 75 70 20 74 68 65 20 63 68 61 69 6e 2e 0a  e up the chain..
4580: 20 20 20 20 20 2a 0a 20 20 20 20 20 2a 20 73 74       *.     * st
4590: 61 6e 74 6f 6e 3a 20 49 74 20 6c 6f 6f 6b 73 20  anton: It looks 
45a0: 6c 69 6b 65 20 74 68 69 73 20 63 6f 75 6c 64 20  like this could 
45b0: 72 65 73 75 6c 74 20 69 6e 20 61 6e 20 69 6e 66  result in an inf
45c0: 69 6e 69 74 65 20 6c 6f 6f 70 20 69 66 0a 20 20  inite loop if.  
45d0: 20 20 20 2a 20 74 68 65 20 75 70 70 65 72 20 63     * the upper c
45e0: 68 61 6e 6e 65 6c 20 64 6f 65 73 6e 27 74 20 63  hannel doesn't c
45f0: 61 75 73 65 20 43 68 61 6e 6e 65 6c 48 61 6e 64  ause ChannelHand
4600: 6c 65 72 20 74 6f 20 62 65 20 72 65 6d 6f 76 65  ler to be remove
4610: 64 0a 20 20 20 20 20 2a 20 62 65 66 6f 72 65 20  d.     * before 
4620: 54 63 6c 5f 4e 6f 74 69 66 79 43 68 61 6e 6e 65  Tcl_NotifyChanne
4630: 6c 20 63 61 6c 6c 73 20 63 68 61 6e 6e 65 6c 20  l calls channel 
4640: 68 61 6e 64 6c 65 72 73 20 6f 6e 20 74 68 65 20  handlers on the 
4650: 6c 6f 77 65 72 20 63 68 61 6e 6e 65 6c 2e 0a 20  lower channel.. 
4660: 20 20 20 20 2a 2f 0a 20 20 20 20 0a 20 20 20 20      */.    .    
4670: 54 63 6c 5f 4e 6f 74 69 66 79 43 68 61 6e 6e 65  Tcl_NotifyChanne
4680: 6c 28 73 74 61 74 65 50 74 72 2d 3e 73 65 6c 66  l(statePtr->self
4690: 2c 20 6d 61 73 6b 29 3b 0a 20 20 20 20 0a 20 20  , mask);.    .  
46a0: 20 20 69 66 20 28 73 74 61 74 65 50 74 72 2d 3e    if (statePtr->
46b0: 74 69 6d 65 72 20 21 3d 20 28 54 63 6c 5f 54 69  timer != (Tcl_Ti
46c0: 6d 65 72 54 6f 6b 65 6e 29 4e 55 4c 4c 29 20 7b  merToken)NULL) {
46d0: 0a 09 54 63 6c 5f 44 65 6c 65 74 65 54 69 6d 65  ..Tcl_DeleteTime
46e0: 72 48 61 6e 64 6c 65 72 28 73 74 61 74 65 50 74  rHandler(statePt
46f0: 72 2d 3e 74 69 6d 65 72 29 3b 0a 09 73 74 61 74  r->timer);..stat
4700: 65 50 74 72 2d 3e 74 69 6d 65 72 20 3d 20 28 54  ePtr->timer = (T
4710: 63 6c 5f 54 69 6d 65 72 54 6f 6b 65 6e 29 4e 55  cl_TimerToken)NU
4720: 4c 4c 3b 0a 20 20 20 20 7d 0a 20 20 20 20 69 66  LL;.    }.    if
4730: 20 28 28 6d 61 73 6b 20 26 20 54 43 4c 5f 52 45   ((mask & TCL_RE
4740: 41 44 41 42 4c 45 29 20 26 26 20 54 63 6c 5f 49  ADABLE) && Tcl_I
4750: 6e 70 75 74 42 75 66 66 65 72 65 64 28 73 74 61  nputBuffered(sta
4760: 74 65 50 74 72 2d 3e 73 65 6c 66 29 20 3e 20 30  tePtr->self) > 0
4770: 29 20 7b 0a 09 2f 2a 0a 09 20 2a 20 44 61 74 61  ) {../*.. * Data
4780: 20 69 73 20 77 61 69 74 69 6e 67 2c 20 66 6c 75   is waiting, flu
4790: 73 68 20 69 74 20 6f 75 74 20 69 6e 20 73 68 6f  sh it out in sho
47a0: 72 74 20 74 69 6d 65 0a 09 20 2a 2f 0a 09 73 74  rt time.. */..st
47b0: 61 74 65 50 74 72 2d 3e 74 69 6d 65 72 20 3d 20  atePtr->timer = 
47c0: 54 63 6c 5f 43 72 65 61 74 65 54 69 6d 65 72 48  Tcl_CreateTimerH
47d0: 61 6e 64 6c 65 72 28 54 4c 53 5f 54 43 4c 5f 44  andler(TLS_TCL_D
47e0: 45 4c 41 59 2c 0a 09 09 54 6c 73 43 68 61 6e 6e  ELAY,...TlsChann
47f0: 65 6c 48 61 6e 64 6c 65 72 54 69 6d 65 72 2c 20  elHandlerTimer, 
4800: 28 43 6c 69 65 6e 74 44 61 74 61 29 20 73 74 61  (ClientData) sta
4810: 74 65 50 74 72 29 3b 0a 20 20 20 20 7d 0a 20 20  tePtr);.    }.  
4820: 20 20 54 63 6c 5f 52 65 6c 65 61 73 65 28 20 28    Tcl_Release( (
4830: 43 6c 69 65 6e 74 44 61 74 61 29 73 74 61 74 65  ClientData)state
4840: 50 74 72 29 3b 0a 7d 0a 23 65 6e 64 69 66 0a 0c  Ptr);.}.#endif..
4850: 0a 2f 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ./*. *----------
4860: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4870: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4880: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2a 0a 20 2a  ------------*. *
4890: 0a 20 2a 09 54 6c 73 43 68 61 6e 6e 65 6c 48 61  . *.TlsChannelHa
48a0: 6e 64 6c 65 72 54 69 6d 65 72 20 2d 2d 0a 20 2a  ndlerTimer --. *
48b0: 0a 20 2a 09 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  . *.------------
48c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
48d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
48e0: 2d 2d 2d 2d 2a 0a 20 2a 09 43 61 6c 6c 65 64 20  ----*. *.Called 
48f0: 62 79 20 74 68 65 20 6e 6f 74 69 66 69 65 72 20  by the notifier 
4900: 28 2d 3e 20 74 69 6d 65 72 29 20 74 6f 20 66 6c  (-> timer) to fl
4910: 75 73 68 20 6f 75 74 0a 20 2a 09 69 6e 66 6f 72  ush out. *.infor
4920: 6d 61 74 69 6f 6e 20 77 61 69 74 69 6e 67 20 69  mation waiting i
4930: 6e 20 63 68 61 6e 6e 65 6c 20 62 75 66 66 65 72  n channel buffer
4940: 73 2e 0a 20 2a 09 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  s.. *.----------
4950: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4960: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4970: 2d 2d 2d 2d 2d 2d 2a 0a 20 2a 0a 20 2a 09 53 69  ------*. *. *.Si
4980: 64 65 65 66 66 65 63 74 73 3a 0a 20 2a 09 09 41  deeffects:. *..A
4990: 73 20 6f 66 20 27 54 6c 73 43 68 61 6e 6e 65 6c  s of 'TlsChannel
49a0: 48 61 6e 64 6c 65 72 27 2e 0a 20 2a 0a 20 2a 09  Handler'.. *. *.
49b0: 52 65 73 75 6c 74 3a 0a 20 2a 09 09 4e 6f 6e 65  Result:. *..None
49c0: 2e 0a 20 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d  .. *. *---------
49d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
49e0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
49f0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2a 0a 20  -------------*. 
4a00: 2a 2f 0a 0a 73 74 61 74 69 63 20 76 6f 69 64 0a  */..static void.
4a10: 54 6c 73 43 68 61 6e 6e 65 6c 48 61 6e 64 6c 65  TlsChannelHandle
4a20: 72 54 69 6d 65 72 20 28 63 6c 69 65 6e 74 44 61  rTimer (clientDa
4a30: 74 61 29 0a 43 6c 69 65 6e 74 44 61 74 61 20 63  ta).ClientData c
4a40: 6c 69 65 6e 74 44 61 74 61 3b 20 2f 2a 20 54 72  lientData; /* Tr
4a50: 61 6e 73 66 6f 72 6d 61 74 69 6f 6e 20 74 6f 20  ansformation to 
4a60: 71 75 65 72 79 20 2a 2f 0a 7b 0a 20 20 20 20 53  query */.{.    S
4a70: 74 61 74 65 20 2a 73 74 61 74 65 50 74 72 20 3d  tate *statePtr =
4a80: 20 28 53 74 61 74 65 20 2a 29 20 63 6c 69 65 6e   (State *) clien
4a90: 74 44 61 74 61 3b 0a 20 20 20 20 69 6e 74 20 6d  tData;.    int m
4aa0: 61 73 6b 20 3d 20 30 3b 0a 0a 20 20 20 20 73 74  ask = 0;..    st
4ab0: 61 74 65 50 74 72 2d 3e 74 69 6d 65 72 20 3d 20  atePtr->timer = 
4ac0: 28 54 63 6c 5f 54 69 6d 65 72 54 6f 6b 65 6e 29  (Tcl_TimerToken)
4ad0: 20 4e 55 4c 4c 3b 0a 0a 20 20 20 20 69 66 20 28   NULL;..    if (
4ae0: 42 49 4f 5f 77 70 65 6e 64 69 6e 67 28 73 74 61  BIO_wpending(sta
4af0: 74 65 50 74 72 2d 3e 62 69 6f 29 29 20 7b 0a 09  tePtr->bio)) {..
4b00: 6d 61 73 6b 20 7c 3d 20 54 43 4c 5f 57 52 49 54  mask |= TCL_WRIT
4b10: 41 42 4c 45 3b 0a 20 20 20 20 7d 0a 20 20 20 20  ABLE;.    }.    
4b20: 69 66 20 28 42 49 4f 5f 70 65 6e 64 69 6e 67 28  if (BIO_pending(
4b30: 73 74 61 74 65 50 74 72 2d 3e 62 69 6f 29 29 20  statePtr->bio)) 
4b40: 7b 0a 09 6d 61 73 6b 20 7c 3d 20 54 43 4c 5f 52  {..mask |= TCL_R
4b50: 45 41 44 41 42 4c 45 3b 0a 20 20 20 20 7d 0a 20  EADABLE;.    }. 
4b60: 20 20 20 54 63 6c 5f 4e 6f 74 69 66 79 43 68 61     Tcl_NotifyCha
4b70: 6e 6e 65 6c 28 73 74 61 74 65 50 74 72 2d 3e 73  nnel(statePtr->s
4b80: 65 6c 66 2c 20 6d 61 73 6b 29 3b 0a 7d 0a 0c 0a  elf, mask);.}...
4b90: 2f 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  /*. *-----------
4ba0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4bb0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4bc0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2a 0a 20 2a 0a  -----------*. *.
4bd0: 20 2a 09 54 6c 73 5f 57 61 69 74 46 6f 72 43 6f   *.Tls_WaitForCo
4be0: 6e 6e 65 63 74 20 2d 2d 0a 20 2a 0a 20 2a 09 53  nnect --. *. *.S
4bf0: 69 64 65 65 66 66 65 63 74 73 3a 0a 20 2a 09 09  ideeffects:. *..
4c00: 49 73 73 75 65 73 20 53 53 4c 5f 61 63 63 65 70  Issues SSL_accep
4c10: 74 20 6f 72 20 53 53 4c 5f 63 6f 6e 6e 65 63 74  t or SSL_connect
4c20: 0a 20 2a 0a 20 2a 09 52 65 73 75 6c 74 3a 0a 20  . *. *.Result:. 
4c30: 2a 09 09 4e 6f 6e 65 2e 0a 20 2a 0a 20 2a 2d 2d  *..None.. *. *--
4c40: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4c50: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4c60: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4c70: 2d 2d 2d 2d 2a 0a 20 2a 2f 0a 69 6e 74 0a 54 6c  ----*. */.int.Tl
4c80: 73 5f 57 61 69 74 46 6f 72 43 6f 6e 6e 65 63 74  s_WaitForConnect
4c90: 28 20 73 74 61 74 65 50 74 72 2c 20 65 72 72 6f  ( statePtr, erro
4ca0: 72 43 6f 64 65 50 74 72 29 0a 20 20 20 20 53 74  rCodePtr).    St
4cb0: 61 74 65 20 2a 73 74 61 74 65 50 74 72 3b 0a 20  ate *statePtr;. 
4cc0: 20 20 20 69 6e 74 20 2a 65 72 72 6f 72 43 6f 64     int *errorCod
4cd0: 65 50 74 72 3b 09 09 2f 2a 20 57 68 65 72 65 20  ePtr;../* Where 
4ce0: 74 6f 20 73 74 6f 72 65 20 65 72 72 6f 72 20 63  to store error c
4cf0: 6f 64 65 2e 20 2a 2f 0a 7b 0a 20 20 20 20 69 6e  ode. */.{.    in
4d00: 74 20 65 72 72 3b 0a 0a 20 20 20 20 64 70 72 69  t err;..    dpri
4d10: 6e 74 66 28 73 74 64 65 72 72 2c 22 5c 6e 57 61  ntf(stderr,"\nWa
4d20: 69 74 46 6f 72 43 6f 6e 6e 65 63 74 28 30 78 25  itForConnect(0x%
4d30: 78 29 22 2c 20 73 74 61 74 65 50 74 72 29 3b 0a  x)", statePtr);.
4d40: 0a 20 20 20 20 66 6f 72 20 28 3b 3b 29 20 7b 0a  .    for (;;) {.
4d50: 09 2f 2a 20 4e 6f 74 20 69 6e 69 74 69 61 6c 69  ./* Not initiali
4d60: 7a 65 64 20 79 65 74 21 20 2a 2f 0a 09 69 66 20  zed yet! */..if 
4d70: 28 73 74 61 74 65 50 74 72 2d 3e 66 6c 61 67 73  (statePtr->flags
4d80: 20 26 20 54 4c 53 5f 54 43 4c 5f 53 45 52 56 45   & TLS_TCL_SERVE
4d90: 52 29 20 7b 0a 09 20 20 20 20 65 72 72 20 3d 20  R) {..    err = 
4da0: 53 53 4c 5f 61 63 63 65 70 74 28 73 74 61 74 65  SSL_accept(state
4db0: 50 74 72 2d 3e 73 73 6c 29 3b 0a 09 7d 20 65 6c  Ptr->ssl);..} el
4dc0: 73 65 20 7b 0a 09 20 20 20 20 65 72 72 20 3d 20  se {..    err = 
4dd0: 53 53 4c 5f 63 6f 6e 6e 65 63 74 28 73 74 61 74  SSL_connect(stat
4de0: 65 50 74 72 2d 3e 73 73 6c 29 3b 0a 09 7d 0a 09  ePtr->ssl);..}..
4df0: 2f 2a 53 53 4c 5f 77 72 69 74 65 28 73 74 61 74  /*SSL_write(stat
4e00: 65 50 74 72 2d 3e 73 73 6c 2c 20 28 63 68 61 72  ePtr->ssl, (char
4e10: 2a 29 26 65 72 72 2c 20 30 29 3b 09 48 41 43 4b  *)&err, 0);.HACK
4e20: 21 21 21 20 2a 2f 0a 09 69 66 20 28 65 72 72 20  !!! */..if (err 
4e30: 3e 20 30 29 20 7b 0a 09 20 20 20 20 42 49 4f 5f  > 0) {..    BIO_
4e40: 66 6c 75 73 68 28 73 74 61 74 65 50 74 72 2d 3e  flush(statePtr->
4e50: 62 69 6f 29 3b 0a 09 7d 0a 0a 09 69 66 20 28 65  bio);..}...if (e
4e60: 72 72 20 3c 3d 20 30 29 20 7b 0a 09 20 20 20 20  rr <= 0) {..    
4e70: 69 6e 74 20 72 63 20 3d 20 53 53 4c 5f 67 65 74  int rc = SSL_get
4e80: 5f 65 72 72 6f 72 28 73 74 61 74 65 50 74 72 2d  _error(statePtr-
4e90: 3e 73 73 6c 2c 20 65 72 72 29 3b 0a 0a 09 20 20  >ssl, err);...  
4ea0: 20 20 69 66 20 28 72 63 20 3d 3d 20 53 53 4c 5f    if (rc == SSL_
4eb0: 45 52 52 4f 52 5f 53 53 4c 29 20 7b 0a 09 09 54  ERROR_SSL) {...T
4ec0: 6c 73 5f 45 72 72 6f 72 28 73 74 61 74 65 50 74  ls_Error(statePt
4ed0: 72 2c 0a 09 09 09 28 63 68 61 72 20 2a 29 45 52  r,....(char *)ER
4ee0: 52 5f 72 65 61 73 6f 6e 5f 65 72 72 6f 72 5f 73  R_reason_error_s
4ef0: 74 72 69 6e 67 28 45 52 52 5f 67 65 74 5f 65 72  tring(ERR_get_er
4f00: 72 6f 72 28 29 29 29 3b 0a 09 09 2a 65 72 72 6f  ror()));...*erro
4f10: 72 43 6f 64 65 50 74 72 20 3d 20 45 43 4f 4e 4e  rCodePtr = ECONN
4f20: 41 42 4f 52 54 45 44 3b 0a 09 09 72 65 74 75 72  ABORTED;...retur
4f30: 6e 20 2d 31 3b 0a 09 20 20 20 20 7d 20 65 6c 73  n -1;..    } els
4f40: 65 20 69 66 20 28 42 49 4f 5f 73 68 6f 75 6c 64  e if (BIO_should
4f50: 5f 72 65 74 72 79 28 73 74 61 74 65 50 74 72 2d  _retry(statePtr-
4f60: 3e 62 69 6f 29 29 20 7b 0a 09 09 69 66 20 28 73  >bio)) {...if (s
4f70: 74 61 74 65 50 74 72 2d 3e 66 6c 61 67 73 20 26  tatePtr->flags &
4f80: 20 54 4c 53 5f 54 43 4c 5f 41 53 59 4e 43 29 20   TLS_TCL_ASYNC) 
4f90: 7b 0a 09 09 20 20 20 20 64 70 72 69 6e 74 66 28  {...    dprintf(
4fa0: 73 74 64 65 72 72 2c 22 45 21 20 22 29 3b 0a 09  stderr,"E! ");..
4fb0: 09 20 20 20 20 2a 65 72 72 6f 72 43 6f 64 65 50  .    *errorCodeP
4fc0: 74 72 20 3d 20 45 41 47 41 49 4e 3b 0a 09 09 20  tr = EAGAIN;... 
4fd0: 20 20 20 72 65 74 75 72 6e 20 2d 31 3b 0a 09 09     return -1;...
4fe0: 7d 20 65 6c 73 65 20 7b 0a 09 09 20 20 20 20 63  } else {...    c
4ff0: 6f 6e 74 69 6e 75 65 3b 0a 09 09 7d 0a 09 20 20  ontinue;...}..  
5000: 20 20 7d 20 65 6c 73 65 20 69 66 20 28 65 72 72    } else if (err
5010: 20 3d 3d 20 30 29 20 7b 0a 09 09 64 70 72 69 6e   == 0) {...dprin
5020: 74 66 28 73 74 64 65 72 72 2c 22 43 52 21 20 22  tf(stderr,"CR! "
5030: 29 3b 0a 09 09 2a 65 72 72 6f 72 43 6f 64 65 50  );...*errorCodeP
5040: 74 72 20 3d 20 45 43 4f 4e 4e 52 45 53 45 54 3b  tr = ECONNRESET;
5050: 0a 09 09 72 65 74 75 72 6e 20 2d 31 3b 0a 09 20  ...return -1;.. 
5060: 20 20 20 7d 0a 09 20 20 20 20 69 66 20 28 73 74     }..    if (st
5070: 61 74 65 50 74 72 2d 3e 66 6c 61 67 73 20 26 20  atePtr->flags & 
5080: 54 4c 53 5f 54 43 4c 5f 53 45 52 56 45 52 29 20  TLS_TCL_SERVER) 
5090: 7b 0a 09 09 65 72 72 20 3d 20 53 53 4c 5f 67 65  {...err = SSL_ge
50a0: 74 5f 76 65 72 69 66 79 5f 72 65 73 75 6c 74 28  t_verify_result(
50b0: 73 74 61 74 65 50 74 72 2d 3e 73 73 6c 29 3b 0a  statePtr->ssl);.
50c0: 09 09 69 66 20 28 65 72 72 20 21 3d 20 58 35 30  ..if (err != X50
50d0: 39 5f 56 5f 4f 4b 29 20 7b 0a 09 09 20 20 20 20  9_V_OK) {...    
50e0: 54 6c 73 5f 45 72 72 6f 72 28 73 74 61 74 65 50  Tls_Error(stateP
50f0: 74 72 2c 0a 09 09 09 20 20 20 20 28 63 68 61 72  tr,....    (char
5100: 20 2a 29 58 35 30 39 5f 76 65 72 69 66 79 5f 63   *)X509_verify_c
5110: 65 72 74 5f 65 72 72 6f 72 5f 73 74 72 69 6e 67  ert_error_string
5120: 28 65 72 72 29 29 3b 0a 09 09 20 20 20 20 2a 65  (err));...    *e
5130: 72 72 6f 72 43 6f 64 65 50 74 72 20 3d 20 45 43  rrorCodePtr = EC
5140: 4f 4e 4e 41 42 4f 52 54 45 44 3b 0a 09 09 20 20  ONNABORTED;...  
5150: 20 20 72 65 74 75 72 6e 20 2d 31 3b 0a 09 09 7d    return -1;...}
5160: 0a 09 20 20 20 20 7d 0a 09 20 20 20 20 2a 65 72  ..    }..    *er
5170: 72 6f 72 43 6f 64 65 50 74 72 20 3d 20 54 63 6c  rorCodePtr = Tcl
5180: 5f 47 65 74 45 72 72 6e 6f 28 29 3b 0a 09 20 20  _GetErrno();..  
5190: 20 20 64 70 72 69 6e 74 66 28 73 74 64 65 72 72    dprintf(stderr
51a0: 2c 22 45 52 52 28 25 64 2c 20 25 64 29 20 22 2c  ,"ERR(%d, %d) ",
51b0: 20 72 63 2c 20 2a 65 72 72 6f 72 43 6f 64 65 50   rc, *errorCodeP
51c0: 74 72 29 3b 0a 09 20 20 20 20 72 65 74 75 72 6e  tr);..    return
51d0: 20 2d 31 3b 0a 09 7d 0a 09 64 70 72 69 6e 74 66   -1;..}..dprintf
51e0: 28 73 74 64 65 72 72 2c 22 52 30 21 20 22 29 3b  (stderr,"R0! ");
51f0: 0a 09 72 65 74 75 72 6e 20 31 3b 0a 20 20 20 20  ..return 1;.    
5200: 7d 0a 7d 0a 0a 54 63 6c 5f 43 68 61 6e 6e 65 6c  }.}..Tcl_Channel
5210: 0a 54 6c 73 5f 47 65 74 50 61 72 65 6e 74 28 20  .Tls_GetParent( 
5220: 73 74 61 74 65 50 74 72 20 29 0a 20 20 20 20 53  statePtr ).    S
5230: 74 61 74 65 20 2a 73 74 61 74 65 50 74 72 3b 0a  tate *statePtr;.
5240: 7b 0a 23 69 66 64 65 66 20 54 43 4c 5f 43 48 41  {.#ifdef TCL_CHA
5250: 4e 4e 45 4c 5f 56 45 52 53 49 4f 4e 5f 32 0a 20  NNEL_VERSION_2. 
5260: 20 20 20 72 65 74 75 72 6e 20 54 63 6c 5f 47 65     return Tcl_Ge
5270: 74 53 74 61 63 6b 65 64 43 68 61 6e 6e 65 6c 28  tStackedChannel(
5280: 73 74 61 74 65 50 74 72 2d 3e 73 65 6c 66 29 3b  statePtr->self);
5290: 0a 23 65 6c 73 65 0a 23 69 66 20 54 43 4c 5f 4d  .#else.#if TCL_M
52a0: 41 4a 4f 52 5f 56 45 52 53 49 4f 4e 20 3d 3d 20  AJOR_VERSION == 
52b0: 38 20 26 26 20 54 43 4c 5f 4d 49 4e 4f 52 5f 56  8 && TCL_MINOR_V
52c0: 45 52 53 49 4f 4e 20 3c 20 32 0a 20 20 20 20 72  ERSION < 2.    r
52d0: 65 74 75 72 6e 20 73 74 61 74 65 50 74 72 2d 3e  eturn statePtr->
52e0: 70 61 72 65 6e 74 3b 0a 23 65 6c 73 65 0a 20 20  parent;.#else.  
52f0: 20 20 2f 2a 20 54 68 65 20 72 65 61 73 6f 6e 20    /* The reason 
5300: 66 6f 72 20 74 68 65 20 65 78 69 73 74 65 6e 63  for the existenc
5310: 65 20 6f 66 20 74 68 69 73 20 70 72 6f 63 65 64  e of this proced
5320: 75 72 65 20 69 73 0a 20 20 20 20 20 2a 20 74 68  ure is.     * th
5330: 65 20 66 61 63 74 20 74 68 61 74 20 73 74 61 63  e fact that stac
5340: 6b 69 6e 67 20 61 20 74 72 61 6e 73 66 6f 72 6d  king a transform
5350: 20 6f 76 65 72 20 61 6e 6f 74 68 65 72 0a 20 20   over another.  
5360: 20 20 20 2a 20 74 72 61 6e 73 66 6f 72 6d 20 77     * transform w
5370: 69 6c 6c 20 6c 65 61 76 65 20 6f 75 72 20 69 6e  ill leave our in
5380: 74 65 72 6e 61 6c 20 70 6f 69 6e 74 65 72 20 75  ternal pointer u
5390: 6e 63 68 61 6e 67 65 64 2c 0a 20 20 20 20 20 2a  nchanged,.     *
53a0: 20 61 6e 64 20 74 68 75 73 20 70 6f 69 6e 74 69   and thus pointi
53b0: 6e 67 20 74 6f 20 74 68 65 20 6e 65 77 20 74 72  ng to the new tr
53c0: 61 6e 73 66 6f 72 6d 2c 20 61 6e 64 20 6e 6f 74  ansform, and not
53d0: 20 74 68 65 0a 20 20 20 20 20 2a 20 43 68 61 6e   the.     * Chan
53e0: 6e 65 6c 20 73 74 72 75 63 74 75 72 65 20 63 6f  nel structure co
53f0: 6e 74 61 69 6e 69 6e 67 20 74 68 65 20 73 61 76  ntaining the sav
5400: 65 64 20 73 74 61 74 65 20 6f 66 20 74 68 69 73  ed state of this
5410: 0a 20 20 20 20 20 2a 20 74 72 61 6e 73 66 6f 72  .     * transfor
5420: 6d 2e 20 54 68 69 73 20 69 73 20 74 68 65 20 70  m. This is the p
5430: 72 69 63 65 20 74 6f 20 70 61 79 20 66 6f 72 20  rice to pay for 
5440: 6c 65 61 76 69 6e 67 0a 20 20 20 20 20 2a 20 54  leaving.     * T
5450: 63 6c 5f 43 68 61 6e 6e 65 6c 20 72 65 66 65 72  cl_Channel refer
5460: 65 6e 63 65 73 20 69 6e 74 61 63 74 2e 20 54 68  ences intact. Th
5470: 65 20 6f 6e 6c 79 20 6f 74 68 65 72 20 73 6f 6c  e only other sol
5480: 75 74 69 6f 6e 0a 20 20 20 20 20 2a 20 69 73 20  ution.     * is 
5490: 61 6e 20 65 78 74 65 6e 73 69 6f 6e 20 6f 66 20  an extension of 
54a0: 54 63 6c 5f 43 68 61 6e 6e 65 6c 54 79 70 65 20  Tcl_ChannelType 
54b0: 77 69 74 68 20 61 6e 6f 74 68 65 72 20 64 72 69  with another dri
54c0: 76 65 72 0a 20 20 20 20 20 2a 20 70 72 6f 63 65  ver.     * proce
54d0: 64 75 72 65 20 74 6f 20 6e 6f 74 69 66 79 20 61  dure to notify a
54e0: 20 43 68 61 6e 6e 65 6c 20 61 62 6f 75 74 20 74   Channel about t
54f0: 68 65 20 28 75 6e 29 73 74 61 63 6b 69 6e 67 2e  he (un)stacking.
5500: 0a 20 20 20 20 20 2a 0a 20 20 20 20 20 2a 20 49  .     *.     * I
5510: 74 20 77 61 6c 6b 73 20 74 68 65 20 63 68 61 69  t walks the chai
5520: 6e 20 6f 66 20 43 68 61 6e 6e 65 6c 20 73 74 72  n of Channel str
5530: 75 63 74 75 72 65 73 20 75 6e 74 69 6c 20 69 74  uctures until it
5540: 0a 20 20 20 20 20 2a 20 66 69 6e 64 73 20 74 68  .     * finds th
5550: 65 20 6f 6e 65 20 70 6f 69 6e 74 69 6e 67 20 68  e one pointing h
5560: 61 76 69 6e 67 20 27 63 74 72 6c 27 20 61 73 20  aving 'ctrl' as 
5570: 69 6e 73 74 61 6e 63 65 44 61 74 61 0a 20 20 20  instanceData.   
5580: 20 20 2a 20 61 6e 64 20 74 68 65 6e 20 72 65 74    * and then ret
5590: 75 72 6e 73 20 74 68 65 20 73 75 70 65 72 63 65  urns the superce
55a0: 64 69 6e 67 20 63 68 61 6e 6e 65 6c 20 74 6f 20  ding channel to 
55b0: 74 68 61 74 2e 20 28 41 4b 29 0a 20 20 20 20 20  that. (AK).     
55c0: 2a 2f 0a 20 0a 20 20 20 20 54 63 6c 5f 43 68 61  */. .    Tcl_Cha
55d0: 6e 6e 65 6c 20 73 65 6c 66 20 3d 20 73 74 61 74  nnel self = stat
55e0: 65 50 74 72 2d 3e 73 65 6c 66 3b 0a 20 20 20 20  ePtr->self;.    
55f0: 54 63 6c 5f 43 68 61 6e 6e 65 6c 20 6e 65 78 74  Tcl_Channel next
5600: 3b 0a 0a 20 20 20 20 77 68 69 6c 65 20 28 28 43  ;..    while ((C
5610: 6c 69 65 6e 74 44 61 74 61 29 20 73 74 61 74 65  lientData) state
5620: 50 74 72 20 21 3d 20 54 63 6c 5f 47 65 74 43 68  Ptr != Tcl_GetCh
5630: 61 6e 6e 65 6c 49 6e 73 74 61 6e 63 65 44 61 74  annelInstanceDat
5640: 61 20 28 73 65 6c 66 29 29 20 7b 0a 09 6e 65 78  a (self)) {..nex
5650: 74 20 3d 20 54 63 6c 5f 47 65 74 53 74 61 63 6b  t = Tcl_GetStack
5660: 65 64 43 68 61 6e 6e 65 6c 20 28 73 65 6c 66 29  edChannel (self)
5670: 3b 0a 09 69 66 20 28 6e 65 78 74 20 3d 3d 20 28  ;..if (next == (
5680: 54 63 6c 5f 43 68 61 6e 6e 65 6c 29 20 4e 55 4c  Tcl_Channel) NUL
5690: 4c 29 20 7b 0a 09 20 20 20 20 2f 2a 20 30 39 2f  L) {..    /* 09/
56a0: 32 34 2f 31 39 39 39 20 55 6e 73 74 61 63 6b 69  24/1999 Unstacki
56b0: 6e 67 20 62 75 67 2c 0a 09 20 20 20 20 20 2a 20  ng bug,..     * 
56c0: 66 6f 75 6e 64 20 62 79 20 4d 61 74 74 20 4e 65  found by Matt Ne
56d0: 77 6d 61 6e 20 3c 6d 61 74 74 40 73 65 6e 73 75  wman <matt@sensu
56e0: 73 2e 6f 72 67 3e 2e 0a 09 20 20 20 20 20 2a 0a  s.org>...     *.
56f0: 09 20 20 20 20 20 2a 20 57 65 20 77 65 72 65 20  .     * We were 
5700: 75 6e 61 62 6c 65 20 74 6f 20 66 69 6e 64 20 74  unable to find t
5710: 68 65 20 63 68 61 6e 6e 65 6c 20 73 74 72 75 63  he channel struc
5720: 74 75 72 65 20 66 6f 72 20 74 68 69 73 0a 09 20  ture for this.. 
5730: 20 20 20 20 2a 20 74 72 61 6e 73 66 6f 72 6d 61      * transforma
5740: 74 69 6f 6e 20 69 6e 20 74 68 65 20 63 68 61 69  tion in the chai
5750: 6e 20 6f 66 20 73 74 61 63 6b 65 64 20 63 68 61  n of stacked cha
5760: 6e 6e 65 6c 2e 20 54 68 69 73 0a 09 20 20 20 20  nnel. This..    
5770: 20 2a 20 6d 65 61 6e 73 20 74 68 61 74 20 77 65   * means that we
5780: 20 61 72 65 20 63 75 72 72 65 6e 74 6c 79 20 69   are currently i
5790: 6e 20 74 68 65 20 70 72 6f 63 65 73 73 20 6f 66  n the process of
57a0: 20 75 6e 73 74 61 63 6b 69 6e 67 0a 09 20 20 20   unstacking..   
57b0: 20 20 2a 20 69 74 20 2a 61 6e 64 2a 20 74 68 65    * it *and* the
57c0: 72 65 20 77 65 72 65 20 73 6f 6d 65 20 62 79 74  re were some byt
57d0: 65 73 20 77 61 69 74 69 6e 67 20 77 68 69 63 68  es waiting which
57e0: 20 61 72 65 20 6e 6f 77 0a 09 20 20 20 20 20 2a   are now..     *
57f0: 20 66 6c 75 73 68 65 64 2e 20 49 6e 20 74 68 69   flushed. In thi
5800: 73 20 73 69 74 75 61 74 69 6f 6e 20 74 68 65 20  s situation the 
5810: 70 6f 69 6e 74 65 72 20 74 6f 20 74 68 65 20 63  pointer to the c
5820: 68 61 6e 6e 65 6c 0a 09 20 20 20 20 20 2a 20 69  hannel..     * i
5830: 74 73 65 6c 66 20 61 6c 72 65 61 64 79 20 72 65  tself already re
5840: 66 65 72 73 20 74 6f 20 74 68 65 20 70 61 72 65  fers to the pare
5850: 6e 74 20 63 68 61 6e 6e 65 6c 20 77 65 20 68 61  nt channel we ha
5860: 76 65 20 74 6f 0a 09 20 20 20 20 20 2a 20 77 72  ve to..     * wr
5870: 69 74 65 20 74 68 65 20 62 79 74 65 73 20 69 6e  ite the bytes in
5880: 74 6f 2c 20 73 6f 20 77 65 20 72 65 74 75 72 6e  to, so we return
5890: 20 74 68 61 74 2e 0a 09 20 20 20 20 20 2a 2f 0a   that...     */.
58a0: 09 20 20 20 20 72 65 74 75 72 6e 20 73 74 61 74  .    return stat
58b0: 65 50 74 72 2d 3e 73 65 6c 66 3b 0a 09 7d 0a 09  ePtr->self;..}..
58c0: 73 65 6c 66 20 3d 20 6e 65 78 74 3b 0a 20 20 20  self = next;.   
58d0: 20 7d 0a 0a 20 20 20 20 72 65 74 75 72 6e 20 54   }..    return T
58e0: 63 6c 5f 47 65 74 53 74 61 63 6b 65 64 43 68 61  cl_GetStackedCha
58f0: 6e 6e 65 6c 20 28 73 65 6c 66 29 3b 0a 23 65 6e  nnel (self);.#en
5900: 64 69 66 0a 23 65 6e 64 69 66 0a 7d 0a           dif.#endif.}.