Enable multi-block support by default.

(cherry picked from commit 77a27a5066e8c0975d78be635ed356749a6f16db)
This commit is contained in:
Andy Polyakov 2014-06-11 20:40:51 +02:00
parent fb2f9f266c
commit d85a772ec3
3 changed files with 34 additions and 10 deletions

View File

@ -731,7 +731,6 @@ my %disabled = ( # "what" => "comment" [or special keyword "experimental
"jpake" => "experimental",
"libunbound" => "experimental",
"md2" => "default",
"multiblock" => "experimental",
"rc5" => "default",
"rfc3779" => "default",
"sctp" => "default",

View File

@ -2176,7 +2176,8 @@ end:
int doit(SSL *s_ssl, SSL *c_ssl, long count)
{
MS_STATIC char cbuf[1024*8],sbuf[1024*8];
char *cbuf=NULL,*sbuf=NULL;
long bufsiz;
long cw_num=count,cr_num=count;
long sw_num=count,sr_num=count;
int ret=1;
@ -2189,9 +2190,15 @@ int doit(SSL *s_ssl, SSL *c_ssl, long count)
int done=0;
int c_write,s_write;
int do_server=0,do_client=0;
int max_frag = 5*1024;
memset(cbuf,0,sizeof(cbuf));
memset(sbuf,0,sizeof(sbuf));
bufsiz = count>40*1024 ? 40*1024 : count;
if ((cbuf = OPENSSL_malloc(bufsiz))==NULL) goto err;
if ((sbuf = OPENSSL_malloc(bufsiz))==NULL) goto err;
memset(cbuf,0,bufsiz);
memset(sbuf,0,bufsiz);
c_to_s=BIO_new(BIO_s_mem());
s_to_c=BIO_new(BIO_s_mem());
@ -2211,10 +2218,12 @@ int doit(SSL *s_ssl, SSL *c_ssl, long count)
SSL_set_connect_state(c_ssl);
SSL_set_bio(c_ssl,s_to_c,c_to_s);
SSL_set_max_send_fragment(c_ssl,max_frag);
BIO_set_ssl(c_bio,c_ssl,BIO_NOCLOSE);
SSL_set_accept_state(s_ssl);
SSL_set_bio(s_ssl,c_to_s,s_to_c);
SSL_set_max_send_fragment(s_ssl,max_frag);
BIO_set_ssl(s_bio,s_ssl,BIO_NOCLOSE);
c_r=0; s_r=1;
@ -2265,8 +2274,8 @@ int doit(SSL *s_ssl, SSL *c_ssl, long count)
{
if (c_write)
{
j = (cw_num > (long)sizeof(cbuf)) ?
(int)sizeof(cbuf) : (int)cw_num;
j = (cw_num > bufsiz) ?
(int)bufsiz : (int)cw_num;
i=BIO_write(c_bio,cbuf,j);
if (i < 0)
{
@ -2299,11 +2308,13 @@ int doit(SSL *s_ssl, SSL *c_ssl, long count)
s_r=1;
c_write=0;
cw_num-=i;
if (max_frag>1029)
SSL_set_max_send_fragment(c_ssl,max_frag-=5);
}
}
else
{
i=BIO_read(c_bio,cbuf,sizeof(cbuf));
i=BIO_read(c_bio,cbuf,bufsiz);
if (i < 0)
{
c_r=0;
@ -2351,7 +2362,7 @@ int doit(SSL *s_ssl, SSL *c_ssl, long count)
{
if (!s_write)
{
i=BIO_read(s_bio,sbuf,sizeof(cbuf));
i=BIO_read(s_bio,sbuf,bufsiz);
if (i < 0)
{
s_r=0;
@ -2396,8 +2407,8 @@ int doit(SSL *s_ssl, SSL *c_ssl, long count)
}
else
{
j = (sw_num > (long)sizeof(sbuf)) ?
(int)sizeof(sbuf) : (int)sw_num;
j = (sw_num > bufsiz) ?
(int)bufsiz : (int)sw_num;
i=BIO_write(s_bio,sbuf,j);
if (i < 0)
{
@ -2432,6 +2443,8 @@ int doit(SSL *s_ssl, SSL *c_ssl, long count)
c_r=1;
if (sw_num <= 0)
done|=S_DONE;
if (max_frag>1029)
SSL_set_max_send_fragment(s_ssl,max_frag-=5);
}
}
}
@ -2480,6 +2493,10 @@ err:
if (s_to_c != NULL) BIO_free(s_to_c);
if (c_bio != NULL) BIO_free_all(c_bio);
if (s_bio != NULL) BIO_free_all(s_bio);
if (cbuf) OPENSSL_free(cbuf);
if (sbuf) OPENSSL_free(sbuf);
return(ret);
}

View File

@ -206,4 +206,12 @@ else
$ssltest -bio_pair -tls1 -cipher SRP -srpuser test -srppass abc123
fi
#############################################################################
# Multi-buffer tests
if [ -z "$extra" -a `uname -m` = "x86_64" ]; then
$ssltest -cipher AES128-SHA -bytes 8m || exit 1
$ssltest -cipher AES128-SHA256 -bytes 8m || exit 1
fi
exit 0