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
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…
x
Reference in New Issue
Block a user