Remove bugs/ and crypto/threads/
Reviewed-by: Rich Salz <rsalz@openssl.org> Reviewed-by: Richard Levitte <levitte@openssl.org>
This commit is contained in:
parent
8cbb048c3e
commit
dad0b512e6
18 changed files with 0 additions and 1973 deletions
7
bugs/MS
7
bugs/MS
|
@ -1,7 +0,0 @@
|
|||
If you use the function that does an fopen inside the DLL, it's malloc
|
||||
will be used and when the function is then written inside, more
|
||||
hassles
|
||||
....
|
||||
|
||||
|
||||
think about it.
|
49
bugs/SSLv3
49
bugs/SSLv3
|
@ -1,49 +0,0 @@
|
|||
So far...
|
||||
|
||||
ssl3.netscape.com:443 does not support client side dynamic
|
||||
session-renegotiation.
|
||||
|
||||
ssl3.netscape.com:444 (asks for client cert) sends out all the CA RDN
|
||||
in an invalid format (the outer sequence is removed).
|
||||
|
||||
Netscape-Commerce/1.12, when talking SSLv2, accepts a 32 byte
|
||||
challenge but then appears to only use 16 bytes when generating the
|
||||
encryption keys. Using 16 bytes is ok but it should be ok to use 32.
|
||||
According to the SSLv3 spec, one should use 32 bytes for the challenge
|
||||
when opperating in SSLv2/v3 compatablity mode, but as mentioned above,
|
||||
this breaks this server so 16 bytes is the way to go.
|
||||
|
||||
www.microsoft.com - when talking SSLv2, if session-id reuse is
|
||||
performed, the session-id passed back in the server-finished message
|
||||
is different from the one decided upon.
|
||||
|
||||
ssl3.netscape.com:443, first a connection is established with RC4-MD5.
|
||||
If it is then resumed, we end up using DES-CBC3-SHA. It should be
|
||||
RC4-MD5 according to 7.6.1.3, 'cipher_suite'.
|
||||
Netscape-Enterprise/2.01 (https://merchant.netscape.com) has this bug.
|
||||
It only really shows up when connecting via SSLv2/v3 then reconnecting
|
||||
via SSLv3. The cipher list changes....
|
||||
NEW INFORMATION. Try connecting with a cipher list of just
|
||||
DES-CBC-SHA:RC4-MD5. For some weird reason, each new connection uses
|
||||
RC4-MD5, but a re-connect tries to use DES-CBC-SHA. So netscape, when
|
||||
doing a re-connect, always takes the first cipher in the cipher list.
|
||||
|
||||
If we accept a netscape connection, demand a client cert, have a
|
||||
non-self-signed CA which does not have it's CA in netscape, and the
|
||||
browser has a cert, it will crash/hang. Works for 3.x and 4.xbeta
|
||||
|
||||
Netscape browsers do not really notice the server sending a
|
||||
close notify message. I was sending one, and then some invalid data.
|
||||
netscape complained of an invalid mac. (a fork()ed child doing a
|
||||
SSL_shutdown() and still sharing the socket with its parent).
|
||||
|
||||
Netscape, when using export ciphers, will accept a 1024 bit temporary
|
||||
RSA key. It is supposed to only accept 512.
|
||||
|
||||
If Netscape connects to a server which requests a client certificate
|
||||
it will frequently hang after the user has selected one and never
|
||||
complete the connection. Hitting "Stop" and reload fixes this and
|
||||
all subsequent connections work fine. This appears to be because
|
||||
Netscape wont read any new records in when it is awaiting a server
|
||||
done message at this point. The fix is to send the certificate request
|
||||
and server done messages in one record.
|
92
bugs/alpha.c
92
bugs/alpha.c
|
@ -1,92 +0,0 @@
|
|||
/* bugs/alpha.c */
|
||||
/* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com)
|
||||
* All rights reserved.
|
||||
*
|
||||
* This package is an SSL implementation written
|
||||
* by Eric Young (eay@cryptsoft.com).
|
||||
* The implementation was written so as to conform with Netscapes SSL.
|
||||
*
|
||||
* This library is free for commercial and non-commercial use as long as
|
||||
* the following conditions are aheared to. The following conditions
|
||||
* apply to all code found in this distribution, be it the RC4, RSA,
|
||||
* lhash, DES, etc., code; not just the SSL code. The SSL documentation
|
||||
* included with this distribution is covered by the same copyright terms
|
||||
* except that the holder is Tim Hudson (tjh@cryptsoft.com).
|
||||
*
|
||||
* Copyright remains Eric Young's, and as such any Copyright notices in
|
||||
* the code are not to be removed.
|
||||
* If this package is used in a product, Eric Young should be given attribution
|
||||
* as the author of the parts of the library used.
|
||||
* This can be in the form of a textual message at program startup or
|
||||
* in documentation (online or textual) provided with the package.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions
|
||||
* are met:
|
||||
* 1. Redistributions of source code must retain the copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* 2. Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in the
|
||||
* documentation and/or other materials provided with the distribution.
|
||||
* 3. All advertising materials mentioning features or use of this software
|
||||
* must display the following acknowledgement:
|
||||
* "This product includes cryptographic software written by
|
||||
* Eric Young (eay@cryptsoft.com)"
|
||||
* The word 'cryptographic' can be left out if the rouines from the library
|
||||
* being used are not cryptographic related :-).
|
||||
* 4. If you include any Windows specific code (or a derivative thereof) from
|
||||
* the apps directory (application code) you must include an acknowledgement:
|
||||
* "This product includes software written by Tim Hudson (tjh@cryptsoft.com)"
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY ERIC YOUNG ``AS IS'' AND
|
||||
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||
* ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
||||
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
||||
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
||||
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
||||
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||
* SUCH DAMAGE.
|
||||
*
|
||||
* The licence and distribution terms for any publically available version or
|
||||
* derivative of this code cannot be changed. i.e. this code cannot simply be
|
||||
* copied and put under another distribution licence
|
||||
* [including the GNU Public Licence.]
|
||||
*/
|
||||
|
||||
/*
|
||||
* while not exactly a bug (ASN1 C leaves this undefined) it is something to
|
||||
* watch out for. This was fine on linux/NT/Solaris but not Alpha
|
||||
*/
|
||||
|
||||
/*-
|
||||
* it is basically an example of
|
||||
* func(*(a++),*(a++))
|
||||
* which parameter is evaluated first? It is not defined in ASN1 C.
|
||||
*/
|
||||
|
||||
#include <stdio.h>
|
||||
|
||||
#define TYPE unsigned int
|
||||
|
||||
void func(a, b)
|
||||
TYPE *a;
|
||||
TYPE b;
|
||||
{
|
||||
printf("%ld -1 == %ld\n", a[0], b);
|
||||
}
|
||||
|
||||
main()
|
||||
{
|
||||
TYPE data[5] = { 1L, 2L, 3L, 4L, 5L };
|
||||
TYPE *p;
|
||||
int i;
|
||||
|
||||
p = data;
|
||||
|
||||
for (i = 0; i < 4; i++) {
|
||||
func(p, *(p++));
|
||||
}
|
||||
}
|
|
@ -1,60 +0,0 @@
|
|||
/* NOCW */
|
||||
/* sgibug.c */
|
||||
/* bug found by Eric Young (eay@mincom.oz.au) May 95 */
|
||||
|
||||
#include <stdio.h>
|
||||
|
||||
/*
|
||||
* This compiler bug it present on IRIX 5.3, 5.1 and 4.0.5 (these are the
|
||||
* only versions of IRIX I have access to. defining FIXBUG removes the bug.
|
||||
* (bug is still present in IRIX 6.3 according to Gage
|
||||
* <agage@forgetmenot.Mines.EDU>
|
||||
*/
|
||||
|
||||
/*-
|
||||
* Compare the output from
|
||||
* cc sgiccbug.c; ./a.out
|
||||
* and
|
||||
* cc -O sgiccbug.c; ./a.out
|
||||
*/
|
||||
|
||||
static unsigned long a[4] =
|
||||
{ 0x01234567, 0x89ABCDEF, 0xFEDCBA98, 0x76543210 };
|
||||
static unsigned long b[4] =
|
||||
{ 0x89ABCDEF, 0xFEDCBA98, 0x76543210, 0x01234567 };
|
||||
static unsigned long c[4] =
|
||||
{ 0x77777778, 0x8ACF1357, 0x88888888, 0x7530ECA9 };
|
||||
|
||||
main()
|
||||
{
|
||||
unsigned long r[4];
|
||||
sub(r, a, b);
|
||||
fprintf(stderr, "input a= %08X %08X %08X %08X\n", a[3], a[2], a[1], a[0]);
|
||||
fprintf(stderr, "input b= %08X %08X %08X %08X\n", b[3], b[2], b[1], b[0]);
|
||||
fprintf(stderr, "output = %08X %08X %08X %08X\n", r[3], r[2], r[1], r[0]);
|
||||
fprintf(stderr, "correct= %08X %08X %08X %08X\n", c[3], c[2], c[1], c[0]);
|
||||
}
|
||||
|
||||
int sub(r, a, b)
|
||||
unsigned long *r, *a, *b;
|
||||
{
|
||||
register unsigned long t1, t2, *ap, *bp, *rp;
|
||||
int i, carry;
|
||||
#ifdef FIXBUG
|
||||
unsigned long dummy;
|
||||
#endif
|
||||
|
||||
ap = a;
|
||||
bp = b;
|
||||
rp = r;
|
||||
carry = 0;
|
||||
for (i = 0; i < 4; i++) {
|
||||
t1 = *(ap++);
|
||||
t2 = *(bp++);
|
||||
t1 = (t1 - t2);
|
||||
#ifdef FIXBUG
|
||||
dummy = t1;
|
||||
#endif
|
||||
*(rp++) = t1 & 0xffffffff;
|
||||
}
|
||||
}
|
|
@ -1,26 +0,0 @@
|
|||
The February 9th, 1995 version of the SSL document differs from
|
||||
https://www.netscape.com in the following ways.
|
||||
=====
|
||||
The key material for generating a SSL_CK_DES_64_CBC_WITH_MD5 key is
|
||||
KEY-MATERIAL-0 = MD5[MASTER-KEY,"0",CHALLENGE,CONNECTION-ID]
|
||||
not
|
||||
KEY-MATERIAL-0 = MD5[MASTER-KEY,CHALLENGE,CONNECTION-ID]
|
||||
as specified in the documentation.
|
||||
=====
|
||||
From the section 2.6 Server Only Protocol Messages
|
||||
|
||||
If the SESSION-ID-HIT flag is non-zero then the CERTIFICATE-TYPE,
|
||||
CERTIFICATE-LENGTH and CIPHER-SPECS-LENGTH fields will be zero.
|
||||
|
||||
This is not true for https://www.netscape.com. The CERTIFICATE-TYPE
|
||||
is returned as 1.
|
||||
=====
|
||||
I have not tested the following but it is reported by holtzman@mit.edu.
|
||||
|
||||
SSLref clients wait to receive a server-verify before they send a
|
||||
client-finished. Besides this not being evident from the examples in
|
||||
2.2.1, it makes more sense to always send all packets you can before
|
||||
reading. SSLeay was waiting in the server to receive a client-finish
|
||||
before sending the server-verify :-). I have changed SSLeay to send a
|
||||
server-verify before trying to read the client-finished.
|
||||
|
132
bugs/stream.c
132
bugs/stream.c
|
@ -1,132 +0,0 @@
|
|||
/* bugs/stream.c */
|
||||
/* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com)
|
||||
* All rights reserved.
|
||||
*
|
||||
* This package is an SSL implementation written
|
||||
* by Eric Young (eay@cryptsoft.com).
|
||||
* The implementation was written so as to conform with Netscapes SSL.
|
||||
*
|
||||
* This library is free for commercial and non-commercial use as long as
|
||||
* the following conditions are aheared to. The following conditions
|
||||
* apply to all code found in this distribution, be it the RC4, RSA,
|
||||
* lhash, DES, etc., code; not just the SSL code. The SSL documentation
|
||||
* included with this distribution is covered by the same copyright terms
|
||||
* except that the holder is Tim Hudson (tjh@cryptsoft.com).
|
||||
*
|
||||
* Copyright remains Eric Young's, and as such any Copyright notices in
|
||||
* the code are not to be removed.
|
||||
* If this package is used in a product, Eric Young should be given attribution
|
||||
* as the author of the parts of the library used.
|
||||
* This can be in the form of a textual message at program startup or
|
||||
* in documentation (online or textual) provided with the package.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions
|
||||
* are met:
|
||||
* 1. Redistributions of source code must retain the copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* 2. Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in the
|
||||
* documentation and/or other materials provided with the distribution.
|
||||
* 3. All advertising materials mentioning features or use of this software
|
||||
* must display the following acknowledgement:
|
||||
* "This product includes cryptographic software written by
|
||||
* Eric Young (eay@cryptsoft.com)"
|
||||
* The word 'cryptographic' can be left out if the rouines from the library
|
||||
* being used are not cryptographic related :-).
|
||||
* 4. If you include any Windows specific code (or a derivative thereof) from
|
||||
* the apps directory (application code) you must include an acknowledgement:
|
||||
* "This product includes software written by Tim Hudson (tjh@cryptsoft.com)"
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY ERIC YOUNG ``AS IS'' AND
|
||||
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||
* ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
||||
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
||||
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
||||
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
||||
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||
* SUCH DAMAGE.
|
||||
*
|
||||
* The licence and distribution terms for any publically available version or
|
||||
* derivative of this code cannot be changed. i.e. this code cannot simply be
|
||||
* copied and put under another distribution licence
|
||||
* [including the GNU Public Licence.]
|
||||
*/
|
||||
|
||||
#include <stdio.h>
|
||||
#include <openssl/rc4.h>
|
||||
#ifdef OPENSSL_NO_DES
|
||||
# include <des.h>
|
||||
#else
|
||||
# include <openssl/des.h>
|
||||
#endif
|
||||
|
||||
/*
|
||||
* show how stream ciphers are not very good. The mac has no affect on RC4
|
||||
* while it does for cfb DES
|
||||
*/
|
||||
|
||||
main()
|
||||
{
|
||||
fprintf(stderr, "rc4\n");
|
||||
rc4();
|
||||
fprintf(stderr, "cfb des\n");
|
||||
des();
|
||||
}
|
||||
|
||||
int des()
|
||||
{
|
||||
des_key_schedule ks;
|
||||
des_cblock iv, key;
|
||||
int num;
|
||||
static char *keystr = "01234567";
|
||||
static char *in1 = "0123456789ABCEDFdata 12345";
|
||||
static char *in2 = "9876543210abcdefdata 12345";
|
||||
unsigned char out[100];
|
||||
int i;
|
||||
|
||||
des_set_key((des_cblock *)keystr, ks);
|
||||
|
||||
num = 0;
|
||||
memset(iv, 0, 8);
|
||||
des_cfb64_encrypt(in1, out, 26, ks, (des_cblock *)iv, &num, 1);
|
||||
for (i = 0; i < 26; i++)
|
||||
fprintf(stderr, "%02X ", out[i]);
|
||||
fprintf(stderr, "\n");
|
||||
|
||||
num = 0;
|
||||
memset(iv, 0, 8);
|
||||
des_cfb64_encrypt(in2, out, 26, ks, (des_cblock *)iv, &num, 1);
|
||||
for (i = 0; i < 26; i++)
|
||||
fprintf(stderr, "%02X ", out[i]);
|
||||
fprintf(stderr, "\n");
|
||||
}
|
||||
|
||||
int rc4()
|
||||
{
|
||||
static char *keystr = "0123456789abcdef";
|
||||
RC4_KEY key;
|
||||
unsigned char in[100], out[100];
|
||||
int i;
|
||||
|
||||
RC4_set_key(&key, 16, keystr);
|
||||
in[0] = '\0';
|
||||
strcpy(in, "0123456789ABCEDFdata 12345");
|
||||
RC4(key, 26, in, out);
|
||||
|
||||
for (i = 0; i < 26; i++)
|
||||
fprintf(stderr, "%02X ", out[i]);
|
||||
fprintf(stderr, "\n");
|
||||
|
||||
RC4_set_key(&key, 16, keystr);
|
||||
in[0] = '\0';
|
||||
strcpy(in, "9876543210abcdefdata 12345");
|
||||
RC4(key, 26, in, out);
|
||||
|
||||
for (i = 0; i < 26; i++)
|
||||
fprintf(stderr, "%02X ", out[i]);
|
||||
fprintf(stderr, "\n");
|
||||
}
|
|
@ -1,44 +0,0 @@
|
|||
#include <stdio.h>
|
||||
|
||||
/*-
|
||||
* This is a cc optimiser bug for ultrix 4.3, mips CPU.
|
||||
* What happens is that the compiler, due to the (a)&7,
|
||||
* does
|
||||
* i=a&7;
|
||||
* i--;
|
||||
* i*=4;
|
||||
* Then uses i as the offset into a jump table.
|
||||
* The problem is that a value of 0 generates an offset of
|
||||
* 0xfffffffc.
|
||||
*/
|
||||
|
||||
main()
|
||||
{
|
||||
f(5);
|
||||
f(0);
|
||||
}
|
||||
|
||||
int f(a)
|
||||
int a;
|
||||
{
|
||||
switch (a & 7) {
|
||||
case 7:
|
||||
printf("7\n");
|
||||
case 6:
|
||||
printf("6\n");
|
||||
case 5:
|
||||
printf("5\n");
|
||||
case 4:
|
||||
printf("4\n");
|
||||
case 3:
|
||||
printf("3\n");
|
||||
case 2:
|
||||
printf("2\n");
|
||||
case 1:
|
||||
printf("1\n");
|
||||
#ifdef FIX_BUG
|
||||
case 0:
|
||||
;
|
||||
#endif
|
||||
}
|
||||
}
|
File diff suppressed because it is too large
Load diff
|
@ -1,79 +0,0 @@
|
|||
@echo off
|
||||
rem batch file to build multi-thread test ( mttest.nlm )
|
||||
|
||||
rem command line arguments:
|
||||
rem debug => build using debug settings
|
||||
|
||||
rem
|
||||
rem After building, copy mttest.nlm to the server and run it, you'll probably
|
||||
rem want to redirect stdout and stderr. An example command line would be
|
||||
rem "mttest.nlm -thread 20 -loops 10 -CAfile \openssl\apps\server.pem >mttest.out 2>mttest.err"
|
||||
rem
|
||||
|
||||
del mttest.nlm
|
||||
|
||||
set BLD_DEBUG=
|
||||
set CFLAGS=
|
||||
set LFLAGS=
|
||||
set LIBS=
|
||||
|
||||
if "%1" == "DEBUG" set BLD_DEBUG=YES
|
||||
if "%1" == "debug" set BLD_DEBUG=YES
|
||||
|
||||
if "%MWCIncludes%" == "" goto inc_error
|
||||
if "%PRELUDE%" == "" goto prelude_error
|
||||
if "%IMPORTS%" == "" goto imports_error
|
||||
|
||||
set CFLAGS=-c -I..\..\outinc_nw -nosyspath -DOPENSSL_SYS_NETWARE -opt off -g -sym internal -maxerrors 20
|
||||
|
||||
if "%BLD_DEBUG%" == "YES" set LIBS=..\..\out_nw.dbg\ssl.lib ..\..\out_nw.dbg\crypto.lib
|
||||
if "%BLD_DEBUG%" == "" set LIBS=..\..\out_nw\ssl.lib ..\..\out_nw\crypto.lib
|
||||
|
||||
set LFLAGS=-msgstyle gcc -zerobss -stacksize 32768 -nostdlib -sym internal
|
||||
|
||||
rem generate command file for metrowerks
|
||||
echo.
|
||||
echo Generating Metrowerks command file: mttest.def
|
||||
echo # dynamically generated command file for metrowerks build > mttest.def
|
||||
echo IMPORT @%IMPORTS%\clib.imp >> mttest.def
|
||||
echo IMPORT @%IMPORTS%\threads.imp >> mttest.def
|
||||
echo IMPORT @%IMPORTS%\ws2nlm.imp >> mttest.def
|
||||
echo IMPORT GetProcessSwitchCount >> mttest.def
|
||||
echo MODULE clib >> mttest.def
|
||||
|
||||
rem compile
|
||||
echo.
|
||||
echo Compiling mttest.c
|
||||
mwccnlm.exe mttest.c %CFLAGS%
|
||||
if errorlevel 1 goto end
|
||||
|
||||
rem link
|
||||
echo.
|
||||
echo Linking mttest.nlm
|
||||
mwldnlm.exe %LFLAGS% -screenname mttest -commandfile mttest.def mttest.o "%PRELUDE%" %LIBS% -o mttest.nlm
|
||||
if errorlevel 1 goto end
|
||||
|
||||
goto end
|
||||
|
||||
:inc_error
|
||||
echo.
|
||||
echo Environment variable MWCIncludes is not set - see install.nw
|
||||
goto end
|
||||
|
||||
:prelude_error
|
||||
echo.
|
||||
echo Environment variable PRELUDE is not set - see install.nw
|
||||
goto end
|
||||
|
||||
:imports_error
|
||||
echo.
|
||||
echo Environment variable IMPORTS is not set - see install.nw
|
||||
goto end
|
||||
|
||||
|
||||
:end
|
||||
set BLD_DEBUG=
|
||||
set CFLAGS=
|
||||
set LFLAGS=
|
||||
set LIBS=
|
||||
|
|
@ -1,4 +0,0 @@
|
|||
#!/bin/sh
|
||||
/bin/rm -f mttest
|
||||
cc -p -DSOLARIS -I../../include -g mttest.c -o mttest -L/usr/lib/libc -ldl -L../.. -lthread -lssl -lcrypto -lnsl -lsocket
|
||||
|
|
@ -1,4 +0,0 @@
|
|||
del mttest.exe
|
||||
|
||||
purify cl /O2 -DWIN32 /MD -I..\..\out mttest.c /Femttest ..\..\out\ssl32.lib ..\..\out\crypt32.lib
|
||||
|
|
@ -1,9 +0,0 @@
|
|||
#!/bin/sh
|
||||
#
|
||||
# build using pthreads
|
||||
#
|
||||
# http://www.mit.edu:8001/people/proven/pthreads.html
|
||||
#
|
||||
/bin/rm -f mttest
|
||||
pgcc -DPTHREADS -I../../include -g mttest.c -o mttest -L../.. -lssl -lcrypto
|
||||
|
|
@ -1,6 +0,0 @@
|
|||
#!/bin/sh
|
||||
#
|
||||
# build using pthreads where it's already built into the system
|
||||
#
|
||||
/bin/rm -f mttest
|
||||
gcc -DPTHREADS -I../../include -g mttest.c -o mttest -L../.. -lssl -lcrypto -lpthread -ldl
|
|
@ -1,14 +0,0 @@
|
|||
$! To compile mttest on VMS.
|
||||
$!
|
||||
$! WARNING: only tested with DEC C so far.
|
||||
$
|
||||
$ if (f$getsyi("cpu").lt.128)
|
||||
$ then
|
||||
$ arch := VAX
|
||||
$ else
|
||||
$ arch = f$edit( f$getsyi( "ARCH_NAME"), "UPCASE")
|
||||
$ if (arch .eqs. "") then arch = "UNK"
|
||||
$ endif
|
||||
$ define/user openssl [--.include.openssl]
|
||||
$ cc/def=PTHREADS mttest.c
|
||||
$ link mttest,[--.'arch'.exe.ssl]libssl/lib,[--.'arch'.exe.crypto]libcrypto/lib
|
|
@ -1,4 +0,0 @@
|
|||
#!/bin/sh
|
||||
/bin/rm -f mttest
|
||||
purify cc -DSOLARIS -I../../include -g mttest.c -o mttest -L../.. -lthread -lssl -lcrypto -lnsl -lsocket
|
||||
|
|
@ -1,4 +0,0 @@
|
|||
#!/bin/sh
|
||||
/bin/rm -f mttest
|
||||
cc -DSOLARIS -I../../include -g mttest.c -o mttest -L../.. -lthread -lssl -lcrypto -lnsl -lsocket
|
||||
|
|
@ -1,364 +0,0 @@
|
|||
/* crypto/threads/th-lock.c */
|
||||
/* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com)
|
||||
* All rights reserved.
|
||||
*
|
||||
* This package is an SSL implementation written
|
||||
* by Eric Young (eay@cryptsoft.com).
|
||||
* The implementation was written so as to conform with Netscapes SSL.
|
||||
*
|
||||
* This library is free for commercial and non-commercial use as long as
|
||||
* the following conditions are aheared to. The following conditions
|
||||
* apply to all code found in this distribution, be it the RC4, RSA,
|
||||
* lhash, DES, etc., code; not just the SSL code. The SSL documentation
|
||||
* included with this distribution is covered by the same copyright terms
|
||||
* except that the holder is Tim Hudson (tjh@cryptsoft.com).
|
||||
*
|
||||
* Copyright remains Eric Young's, and as such any Copyright notices in
|
||||
* the code are not to be removed.
|
||||
* If this package is used in a product, Eric Young should be given attribution
|
||||
* as the author of the parts of the library used.
|
||||
* This can be in the form of a textual message at program startup or
|
||||
* in documentation (online or textual) provided with the package.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions
|
||||
* are met:
|
||||
* 1. Redistributions of source code must retain the copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* 2. Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in the
|
||||
* documentation and/or other materials provided with the distribution.
|
||||
* 3. All advertising materials mentioning features or use of this software
|
||||
* must display the following acknowledgement:
|
||||
* "This product includes cryptographic software written by
|
||||
* Eric Young (eay@cryptsoft.com)"
|
||||
* The word 'cryptographic' can be left out if the rouines from the library
|
||||
* being used are not cryptographic related :-).
|
||||
* 4. If you include any Windows specific code (or a derivative thereof) from
|
||||
* the apps directory (application code) you must include an acknowledgement:
|
||||
* "This product includes software written by Tim Hudson (tjh@cryptsoft.com)"
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY ERIC YOUNG ``AS IS'' AND
|
||||
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||
* ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
||||
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
||||
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
||||
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
||||
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||
* SUCH DAMAGE.
|
||||
*
|
||||
* The licence and distribution terms for any publically available version or
|
||||
* derivative of this code cannot be changed. i.e. this code cannot simply be
|
||||
* copied and put under another distribution licence
|
||||
* [including the GNU Public Licence.]
|
||||
*/
|
||||
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
#include <errno.h>
|
||||
#ifdef LINUX
|
||||
# include <typedefs.h>
|
||||
#endif
|
||||
#ifdef OPENSSL_SYS_WIN32
|
||||
# include <windows.h>
|
||||
#endif
|
||||
#ifdef SOLARIS
|
||||
# include <synch.h>
|
||||
# include <thread.h>
|
||||
#endif
|
||||
#ifdef IRIX
|
||||
# include <ulocks.h>
|
||||
# include <sys/prctl.h>
|
||||
#endif
|
||||
#ifdef PTHREADS
|
||||
# include <pthread.h>
|
||||
#endif
|
||||
#include <openssl/lhash.h>
|
||||
#include <openssl/crypto.h>
|
||||
#include <openssl/buffer.h>
|
||||
#include "../../e_os.h"
|
||||
#include <openssl/x509.h>
|
||||
#include <openssl/ssl.h>
|
||||
#include <openssl/err.h>
|
||||
|
||||
void CRYPTO_thread_setup(void);
|
||||
void CRYPTO_thread_cleanup(void);
|
||||
|
||||
static void irix_locking_callback(int mode, int type, char *file, int line);
|
||||
static void solaris_locking_callback(int mode, int type, char *file,
|
||||
int line);
|
||||
static void win32_locking_callback(int mode, int type, char *file, int line);
|
||||
static void pthreads_locking_callback(int mode, int type, char *file,
|
||||
int line);
|
||||
|
||||
static unsigned long irix_thread_id(void);
|
||||
static unsigned long solaris_thread_id(void);
|
||||
static unsigned long pthreads_thread_id(void);
|
||||
|
||||
/*-
|
||||
* usage:
|
||||
* CRYPTO_thread_setup();
|
||||
* application code
|
||||
* CRYPTO_thread_cleanup();
|
||||
*/
|
||||
|
||||
#define THREAD_STACK_SIZE (16*1024)
|
||||
|
||||
#ifdef OPENSSL_SYS_WIN32
|
||||
|
||||
static HANDLE *lock_cs;
|
||||
|
||||
void CRYPTO_thread_setup(void)
|
||||
{
|
||||
int i;
|
||||
|
||||
lock_cs = OPENSSL_malloc(CRYPTO_num_locks() * sizeof(HANDLE));
|
||||
if (!lock_cs) {
|
||||
/* Nothing we can do about this...void function! */
|
||||
return;
|
||||
}
|
||||
for (i = 0; i < CRYPTO_num_locks(); i++) {
|
||||
lock_cs[i] = CreateMutex(NULL, FALSE, NULL);
|
||||
}
|
||||
|
||||
CRYPTO_set_locking_callback((void (*)(int, int, char *, int))
|
||||
win32_locking_callback);
|
||||
/* id callback defined */
|
||||
return (1);
|
||||
}
|
||||
|
||||
static void CRYPTO_thread_cleanup(void)
|
||||
{
|
||||
int i;
|
||||
|
||||
CRYPTO_set_locking_callback(NULL);
|
||||
for (i = 0; i < CRYPTO_num_locks(); i++)
|
||||
CloseHandle(lock_cs[i]);
|
||||
OPENSSL_free(lock_cs);
|
||||
}
|
||||
|
||||
void win32_locking_callback(int mode, int type, char *file, int line)
|
||||
{
|
||||
if (mode & CRYPTO_LOCK) {
|
||||
WaitForSingleObject(lock_cs[type], INFINITE);
|
||||
} else {
|
||||
ReleaseMutex(lock_cs[type]);
|
||||
}
|
||||
}
|
||||
|
||||
#endif /* OPENSSL_SYS_WIN32 */
|
||||
|
||||
#ifdef SOLARIS
|
||||
|
||||
# define USE_MUTEX
|
||||
|
||||
# ifdef USE_MUTEX
|
||||
static mutex_t *lock_cs;
|
||||
# else
|
||||
static rwlock_t *lock_cs;
|
||||
# endif
|
||||
static long *lock_count;
|
||||
|
||||
void CRYPTO_thread_setup(void)
|
||||
{
|
||||
int i;
|
||||
|
||||
# ifdef USE_MUTEX
|
||||
lock_cs = OPENSSL_malloc(CRYPTO_num_locks() * sizeof(mutex_t));
|
||||
# else
|
||||
lock_cs = OPENSSL_malloc(CRYPTO_num_locks() * sizeof(rwlock_t));
|
||||
# endif
|
||||
if (!lock_cs) {
|
||||
/* Nothing we can do about this...void function! */
|
||||
return;
|
||||
}
|
||||
lock_count = OPENSSL_malloc(CRYPTO_num_locks() * sizeof(long));
|
||||
for (i = 0; i < CRYPTO_num_locks(); i++) {
|
||||
lock_count[i] = 0;
|
||||
# ifdef USE_MUTEX
|
||||
mutex_init(&(lock_cs[i]), USYNC_THREAD, NULL);
|
||||
# else
|
||||
rwlock_init(&(lock_cs[i]), USYNC_THREAD, NULL);
|
||||
# endif
|
||||
}
|
||||
|
||||
CRYPTO_set_id_callback((unsigned long (*)())solaris_thread_id);
|
||||
CRYPTO_set_locking_callback((void (*)())solaris_locking_callback);
|
||||
}
|
||||
|
||||
void CRYPTO_thread_cleanup(void)
|
||||
{
|
||||
int i;
|
||||
|
||||
CRYPTO_set_locking_callback(NULL);
|
||||
for (i = 0; i < CRYPTO_num_locks(); i++) {
|
||||
# ifdef USE_MUTEX
|
||||
mutex_destroy(&(lock_cs[i]));
|
||||
# else
|
||||
rwlock_destroy(&(lock_cs[i]));
|
||||
# endif
|
||||
}
|
||||
OPENSSL_free(lock_cs);
|
||||
OPENSSL_free(lock_count);
|
||||
}
|
||||
|
||||
void solaris_locking_callback(int mode, int type, char *file, int line)
|
||||
{
|
||||
if (mode & CRYPTO_LOCK) {
|
||||
# ifdef USE_MUTEX
|
||||
mutex_lock(&(lock_cs[type]));
|
||||
# else
|
||||
if (mode & CRYPTO_READ)
|
||||
rw_rdlock(&(lock_cs[type]));
|
||||
else
|
||||
rw_wrlock(&(lock_cs[type]));
|
||||
# endif
|
||||
lock_count[type]++;
|
||||
} else {
|
||||
# ifdef USE_MUTEX
|
||||
mutex_unlock(&(lock_cs[type]));
|
||||
# else
|
||||
rw_unlock(&(lock_cs[type]));
|
||||
# endif
|
||||
}
|
||||
}
|
||||
|
||||
unsigned long solaris_thread_id(void)
|
||||
{
|
||||
unsigned long ret;
|
||||
|
||||
ret = (unsigned long)thr_self();
|
||||
return (ret);
|
||||
}
|
||||
#endif /* SOLARIS */
|
||||
|
||||
#ifdef IRIX
|
||||
/* I don't think this works..... */
|
||||
|
||||
static usptr_t *arena;
|
||||
static usema_t **lock_cs;
|
||||
|
||||
void CRYPTO_thread_setup(void)
|
||||
{
|
||||
int i;
|
||||
char filename[20];
|
||||
|
||||
lock_cs = OPENSSL_malloc(CRYPTO_num_locks() * sizeof(usema_t *));
|
||||
if (!lock_cs) {
|
||||
/* Nothing we can do about this...void function! */
|
||||
return;
|
||||
}
|
||||
|
||||
strcpy(filename, "/tmp/mttest.XXXXXX");
|
||||
mktemp(filename);
|
||||
|
||||
usconfig(CONF_STHREADIOOFF);
|
||||
usconfig(CONF_STHREADMALLOCOFF);
|
||||
usconfig(CONF_INITUSERS, 100);
|
||||
usconfig(CONF_LOCKTYPE, US_DEBUGPLUS);
|
||||
arena = usinit(filename);
|
||||
unlink(filename);
|
||||
|
||||
for (i = 0; i < CRYPTO_num_locks(); i++) {
|
||||
lock_cs[i] = usnewsema(arena, 1);
|
||||
}
|
||||
|
||||
CRYPTO_set_id_callback((unsigned long (*)())irix_thread_id);
|
||||
CRYPTO_set_locking_callback((void (*)())irix_locking_callback);
|
||||
}
|
||||
|
||||
void CRYPTO_thread_cleanup(void)
|
||||
{
|
||||
int i;
|
||||
|
||||
CRYPTO_set_locking_callback(NULL);
|
||||
for (i = 0; i < CRYPTO_num_locks(); i++) {
|
||||
char buf[10];
|
||||
|
||||
sprintf(buf, "%2d:", i);
|
||||
usdumpsema(lock_cs[i], stdout, buf);
|
||||
usfreesema(lock_cs[i], arena);
|
||||
}
|
||||
OPENSSL_free(lock_cs);
|
||||
}
|
||||
|
||||
void irix_locking_callback(int mode, int type, char *file, int line)
|
||||
{
|
||||
if (mode & CRYPTO_LOCK) {
|
||||
uspsema(lock_cs[type]);
|
||||
} else {
|
||||
usvsema(lock_cs[type]);
|
||||
}
|
||||
}
|
||||
|
||||
unsigned long irix_thread_id(void)
|
||||
{
|
||||
unsigned long ret;
|
||||
|
||||
ret = (unsigned long)getpid();
|
||||
return (ret);
|
||||
}
|
||||
#endif /* IRIX */
|
||||
|
||||
/* Linux and a few others */
|
||||
#ifdef PTHREADS
|
||||
|
||||
static pthread_mutex_t *lock_cs;
|
||||
static long *lock_count;
|
||||
|
||||
void CRYPTO_thread_setup(void)
|
||||
{
|
||||
int i;
|
||||
|
||||
lock_cs = OPENSSL_malloc(CRYPTO_num_locks() * sizeof(pthread_mutex_t));
|
||||
lock_count = OPENSSL_malloc(CRYPTO_num_locks() * sizeof(long));
|
||||
if (!lock_cs || !lock_count) {
|
||||
/* Nothing we can do about this...void function! */
|
||||
OPENSSL_free(lock_cs);
|
||||
OPENSSL_free(lock_count);
|
||||
return;
|
||||
}
|
||||
for (i = 0; i < CRYPTO_num_locks(); i++) {
|
||||
lock_count[i] = 0;
|
||||
pthread_mutex_init(&(lock_cs[i]), NULL);
|
||||
}
|
||||
|
||||
CRYPTO_set_id_callback((unsigned long (*)())pthreads_thread_id);
|
||||
CRYPTO_set_locking_callback((void (*)())pthreads_locking_callback);
|
||||
}
|
||||
|
||||
void thread_cleanup(void)
|
||||
{
|
||||
int i;
|
||||
|
||||
CRYPTO_set_locking_callback(NULL);
|
||||
for (i = 0; i < CRYPTO_num_locks(); i++) {
|
||||
pthread_mutex_destroy(&(lock_cs[i]));
|
||||
}
|
||||
OPENSSL_free(lock_cs);
|
||||
OPENSSL_free(lock_count);
|
||||
}
|
||||
|
||||
void pthreads_locking_callback(int mode, int type, char *file, int line)
|
||||
{
|
||||
if (mode & CRYPTO_LOCK) {
|
||||
pthread_mutex_lock(&(lock_cs[type]));
|
||||
lock_count[type]++;
|
||||
} else {
|
||||
pthread_mutex_unlock(&(lock_cs[type]));
|
||||
}
|
||||
}
|
||||
|
||||
unsigned long pthreads_thread_id(void)
|
||||
{
|
||||
unsigned long ret;
|
||||
|
||||
ret = (unsigned long)pthread_self();
|
||||
return (ret);
|
||||
}
|
||||
|
||||
#endif /* PTHREADS */
|
|
@ -1,4 +0,0 @@
|
|||
del mttest.exe
|
||||
|
||||
cl /O2 -DWIN32 /MD -I..\..\out mttest.c /Femttest ..\..\out\ssleay32.lib ..\..\out\libeay32.lib
|
||||
|
Loading…
Reference in a new issue