Move socket setup behind ssl structure setup.
If socket setup fail, ssl structure setup won't be called. And the order of them do not affect final result, but it will break ssl setup negative tests. Change the order can fix that. issue: #4844 Change-Id: I2488ed5f74773421eb1eac0cfd7f1ce4fbb0b32d Signed-off-by: Jerry Yu <jerry.h.yu@arm.com>
This commit is contained in:
parent
b1dc59a125
commit
2a572cf376
2 changed files with 54 additions and 55 deletions
|
@ -1592,41 +1592,7 @@ int main( int argc, char *argv[] )
|
||||||
#endif /* MBEDTLS_X509_CRT_PARSE_C */
|
#endif /* MBEDTLS_X509_CRT_PARSE_C */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* 2. Start the connection
|
* 2. Setup stuff
|
||||||
*/
|
|
||||||
if( opt.server_addr == NULL)
|
|
||||||
opt.server_addr = opt.server_name;
|
|
||||||
|
|
||||||
mbedtls_printf( " . Connecting to %s/%s/%s...",
|
|
||||||
opt.transport == MBEDTLS_SSL_TRANSPORT_STREAM ? "tcp" : "udp",
|
|
||||||
opt.server_addr, opt.server_port );
|
|
||||||
fflush( stdout );
|
|
||||||
|
|
||||||
if( ( ret = mbedtls_net_connect( &server_fd,
|
|
||||||
opt.server_addr, opt.server_port,
|
|
||||||
opt.transport == MBEDTLS_SSL_TRANSPORT_STREAM ?
|
|
||||||
MBEDTLS_NET_PROTO_TCP : MBEDTLS_NET_PROTO_UDP ) ) != 0 )
|
|
||||||
{
|
|
||||||
mbedtls_printf( " failed\n ! mbedtls_net_connect returned -0x%x\n\n",
|
|
||||||
(unsigned int) -ret );
|
|
||||||
goto exit;
|
|
||||||
}
|
|
||||||
|
|
||||||
if( opt.nbio > 0 )
|
|
||||||
ret = mbedtls_net_set_nonblock( &server_fd );
|
|
||||||
else
|
|
||||||
ret = mbedtls_net_set_block( &server_fd );
|
|
||||||
if( ret != 0 )
|
|
||||||
{
|
|
||||||
mbedtls_printf( " failed\n ! net_set_(non)block() returned -0x%x\n\n",
|
|
||||||
(unsigned int) -ret );
|
|
||||||
goto exit;
|
|
||||||
}
|
|
||||||
|
|
||||||
mbedtls_printf( " ok\n" );
|
|
||||||
|
|
||||||
/*
|
|
||||||
* 3. Setup stuff
|
|
||||||
*/
|
*/
|
||||||
mbedtls_printf( " . Setting up the SSL/TLS structure..." );
|
mbedtls_printf( " . Setting up the SSL/TLS structure..." );
|
||||||
fflush( stdout );
|
fflush( stdout );
|
||||||
|
@ -1978,6 +1944,40 @@ int main( int argc, char *argv[] )
|
||||||
|
|
||||||
mbedtls_printf( " ok\n" );
|
mbedtls_printf( " ok\n" );
|
||||||
|
|
||||||
|
/*
|
||||||
|
* 3. Start the connection
|
||||||
|
*/
|
||||||
|
if( opt.server_addr == NULL)
|
||||||
|
opt.server_addr = opt.server_name;
|
||||||
|
|
||||||
|
mbedtls_printf( " . Connecting to %s/%s/%s...",
|
||||||
|
opt.transport == MBEDTLS_SSL_TRANSPORT_STREAM ? "tcp" : "udp",
|
||||||
|
opt.server_addr, opt.server_port );
|
||||||
|
fflush( stdout );
|
||||||
|
|
||||||
|
if( ( ret = mbedtls_net_connect( &server_fd,
|
||||||
|
opt.server_addr, opt.server_port,
|
||||||
|
opt.transport == MBEDTLS_SSL_TRANSPORT_STREAM ?
|
||||||
|
MBEDTLS_NET_PROTO_TCP : MBEDTLS_NET_PROTO_UDP ) ) != 0 )
|
||||||
|
{
|
||||||
|
mbedtls_printf( " failed\n ! mbedtls_net_connect returned -0x%x\n\n",
|
||||||
|
(unsigned int) -ret );
|
||||||
|
goto exit;
|
||||||
|
}
|
||||||
|
|
||||||
|
if( opt.nbio > 0 )
|
||||||
|
ret = mbedtls_net_set_nonblock( &server_fd );
|
||||||
|
else
|
||||||
|
ret = mbedtls_net_set_block( &server_fd );
|
||||||
|
if( ret != 0 )
|
||||||
|
{
|
||||||
|
mbedtls_printf( " failed\n ! net_set_(non)block() returned -0x%x\n\n",
|
||||||
|
(unsigned int) -ret );
|
||||||
|
goto exit;
|
||||||
|
}
|
||||||
|
|
||||||
|
mbedtls_printf( " ok\n" );
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* 4. Handshake
|
* 4. Handshake
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -2398,26 +2398,7 @@ int main( int argc, char *argv[] )
|
||||||
#endif /* SNI_OPTION */
|
#endif /* SNI_OPTION */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* 2. Setup the listening TCP socket
|
* 2. Setup stuff
|
||||||
*/
|
|
||||||
mbedtls_printf( " . Bind on %s://%s:%s/ ...",
|
|
||||||
opt.transport == MBEDTLS_SSL_TRANSPORT_STREAM ? "tcp" : "udp",
|
|
||||||
opt.server_addr ? opt.server_addr : "*",
|
|
||||||
opt.server_port );
|
|
||||||
fflush( stdout );
|
|
||||||
|
|
||||||
if( ( ret = mbedtls_net_bind( &listen_fd, opt.server_addr, opt.server_port,
|
|
||||||
opt.transport == MBEDTLS_SSL_TRANSPORT_STREAM ?
|
|
||||||
MBEDTLS_NET_PROTO_TCP : MBEDTLS_NET_PROTO_UDP ) ) != 0 )
|
|
||||||
{
|
|
||||||
mbedtls_printf( " failed\n ! mbedtls_net_bind returned -0x%x\n\n", (unsigned int) -ret );
|
|
||||||
goto exit;
|
|
||||||
}
|
|
||||||
|
|
||||||
mbedtls_printf( " ok\n" );
|
|
||||||
|
|
||||||
/*
|
|
||||||
* 3. Setup stuff
|
|
||||||
*/
|
*/
|
||||||
mbedtls_printf( " . Setting up the SSL/TLS structure..." );
|
mbedtls_printf( " . Setting up the SSL/TLS structure..." );
|
||||||
fflush( stdout );
|
fflush( stdout );
|
||||||
|
@ -2911,6 +2892,24 @@ int main( int argc, char *argv[] )
|
||||||
|
|
||||||
mbedtls_printf( " ok\n" );
|
mbedtls_printf( " ok\n" );
|
||||||
|
|
||||||
|
/*
|
||||||
|
* 3. Setup the listening TCP socket
|
||||||
|
*/
|
||||||
|
mbedtls_printf( " . Bind on %s://%s:%s/ ...",
|
||||||
|
opt.transport == MBEDTLS_SSL_TRANSPORT_STREAM ? "tcp" : "udp",
|
||||||
|
opt.server_addr ? opt.server_addr : "*",
|
||||||
|
opt.server_port );
|
||||||
|
fflush( stdout );
|
||||||
|
|
||||||
|
if( ( ret = mbedtls_net_bind( &listen_fd, opt.server_addr, opt.server_port,
|
||||||
|
opt.transport == MBEDTLS_SSL_TRANSPORT_STREAM ?
|
||||||
|
MBEDTLS_NET_PROTO_TCP : MBEDTLS_NET_PROTO_UDP ) ) != 0 )
|
||||||
|
{
|
||||||
|
mbedtls_printf( " failed\n ! mbedtls_net_bind returned -0x%x\n\n", (unsigned int) -ret );
|
||||||
|
goto exit;
|
||||||
|
}
|
||||||
|
mbedtls_printf( " ok\n" );
|
||||||
|
|
||||||
reset:
|
reset:
|
||||||
#if !defined(_WIN32)
|
#if !defined(_WIN32)
|
||||||
if( received_sigterm )
|
if( received_sigterm )
|
||||||
|
|
Loading…
Reference in a new issue