mirror of
				https://github.com/cuberite/polarssl.git
				synced 2025-11-04 04:32:24 -05:00 
			
		
		
		
	- Added random generation example application
This commit is contained in:
		
							parent
							
								
									dbee2cad7d
								
							
						
					
					
						commit
						fc36d16e84
					
				@ -1,6 +1,7 @@
 | 
				
			|||||||
add_subdirectory(aes)
 | 
					add_subdirectory(aes)
 | 
				
			||||||
add_subdirectory(hash)
 | 
					add_subdirectory(hash)
 | 
				
			||||||
add_subdirectory(pkey)
 | 
					add_subdirectory(pkey)
 | 
				
			||||||
 | 
					add_subdirectory(random)
 | 
				
			||||||
add_subdirectory(ssl)
 | 
					add_subdirectory(ssl)
 | 
				
			||||||
add_subdirectory(test)
 | 
					add_subdirectory(test)
 | 
				
			||||||
add_subdirectory(x509)
 | 
					add_subdirectory(x509)
 | 
				
			||||||
 | 
				
			|||||||
@ -15,9 +15,10 @@ APPS =	aes/aescrypt2	aes/crypt_and_hash	\
 | 
				
			|||||||
	pkey/mpi_demo		pkey/rsa_genkey		\
 | 
						pkey/mpi_demo		pkey/rsa_genkey		\
 | 
				
			||||||
	pkey/rsa_sign		pkey/rsa_verify		\
 | 
						pkey/rsa_sign		pkey/rsa_verify		\
 | 
				
			||||||
	ssl/ssl_client1		ssl/ssl_client2		\
 | 
						ssl/ssl_client1		ssl/ssl_client2		\
 | 
				
			||||||
	ssl/ssl_server		test/ssl_cert_test	\
 | 
						ssl/ssl_server		random/gen_random	\
 | 
				
			||||||
	test/benchmark		test/selftest		\
 | 
						test/ssl_cert_test	test/benchmark		\
 | 
				
			||||||
	test/ssl_test		x509/cert_app
 | 
						test/selftest		test/ssl_test		\
 | 
				
			||||||
 | 
						x509/cert_app
 | 
				
			||||||
 | 
					
 | 
				
			||||||
.SILENT:
 | 
					.SILENT:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -79,6 +80,10 @@ pkey/rsa_verify: pkey/rsa_verify.c ../library/libpolarssl.a
 | 
				
			|||||||
	echo   "  CC    pkey/rsa_verify.c"
 | 
						echo   "  CC    pkey/rsa_verify.c"
 | 
				
			||||||
	$(CC) $(CFLAGS) $(OFLAGS) pkey/rsa_verify.c  $(LDFLAGS) -o $@
 | 
						$(CC) $(CFLAGS) $(OFLAGS) pkey/rsa_verify.c  $(LDFLAGS) -o $@
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					random/gen_random: random/gen_random.c ../library/libpolarssl.a
 | 
				
			||||||
 | 
						echo   "  CC    random/gen_random.c"
 | 
				
			||||||
 | 
						$(CC) $(CFLAGS) $(OFLAGS) random/gen_random.c $(LDFLAGS) -o $@
 | 
				
			||||||
 | 
					
 | 
				
			||||||
ssl/ssl_client1: ssl/ssl_client1.c ../library/libpolarssl.a
 | 
					ssl/ssl_client1: ssl/ssl_client1.c ../library/libpolarssl.a
 | 
				
			||||||
	echo   "  CC    ssl/ssl_client1.c"
 | 
						echo   "  CC    ssl/ssl_client1.c"
 | 
				
			||||||
	$(CC) $(CFLAGS) $(OFLAGS) ssl/ssl_client1.c  $(LDFLAGS) -o $@
 | 
						$(CC) $(CFLAGS) $(OFLAGS) ssl/ssl_client1.c  $(LDFLAGS) -o $@
 | 
				
			||||||
 | 
				
			|||||||
							
								
								
									
										6
									
								
								programs/random/CMakeLists.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								programs/random/CMakeLists.txt
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,6 @@
 | 
				
			|||||||
 | 
					add_executable(gen_random gen_random.c)
 | 
				
			||||||
 | 
					target_link_libraries(gen_random polarssl)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					INSTALL(TARGETS gen_random
 | 
				
			||||||
 | 
					        DESTINATION "bin"
 | 
				
			||||||
 | 
					        PERMISSIONS OWNER_READ OWNER_WRITE OWNER_EXECUTE GROUP_READ GROUP_EXECUTE WORLD_READ WORLD_EXECUTE)
 | 
				
			||||||
							
								
								
									
										72
									
								
								programs/random/gen_random.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										72
									
								
								programs/random/gen_random.c
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,72 @@
 | 
				
			|||||||
 | 
					/**
 | 
				
			||||||
 | 
					 *  \brief Generate random data into a file
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 *  Copyright (C) 2006-2010, Brainspark B.V.
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 *  This file is part of PolarSSL (http://www.polarssl.org)
 | 
				
			||||||
 | 
					 *  Lead Maintainer: Paul Bakker <polarssl_maintainer at polarssl.org>
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 *  All rights reserved.
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 *  This program is free software; you can redistribute it and/or modify
 | 
				
			||||||
 | 
					 *  it under the terms of the GNU General Public License as published by
 | 
				
			||||||
 | 
					 *  the Free Software Foundation; either version 2 of the License, or
 | 
				
			||||||
 | 
					 *  (at your option) any later version.
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 *  This program is distributed in the hope that it will be useful,
 | 
				
			||||||
 | 
					 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 | 
				
			||||||
 | 
					 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | 
				
			||||||
 | 
					 *  GNU General Public License for more details.
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 *  You should have received a copy of the GNU General Public License along
 | 
				
			||||||
 | 
					 *  with this program; if not, write to the Free Software Foundation, Inc.,
 | 
				
			||||||
 | 
					 *  51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "polarssl/config.h"
 | 
				
			||||||
 | 
					#include "polarssl/havege.h"
 | 
				
			||||||
 | 
					#include <time.h>
 | 
				
			||||||
 | 
					#include <stdio.h>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					int main( int argc, char *argv[] )
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    FILE *f;
 | 
				
			||||||
 | 
					    time_t t;
 | 
				
			||||||
 | 
					    int i, j, k;
 | 
				
			||||||
 | 
					    havege_state hs;
 | 
				
			||||||
 | 
					    unsigned char buf[1024];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if( argc < 2 )
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        fprintf( stderr, "usage: %s <output filename>\n", argv[0] );
 | 
				
			||||||
 | 
					        return( 1 );
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if( ( f = fopen( argv[1], "wb+" ) ) == NULL )
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        printf( "failed to open '%s' for writing.\n", argv[0] );
 | 
				
			||||||
 | 
					        return( 1 );
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    havege_init( &hs );
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    t = time( NULL );
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    for( i = 0, k = 768; i < k; i++ )
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        for( j = 0; j < (int) sizeof( buf ); j++ )
 | 
				
			||||||
 | 
					            buf[j] = havege_rand( &hs );
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        fwrite( buf, sizeof( buf ), 1, f );
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        printf( "Generating 32Mb of data in file '%s'... %04.1f" \
 | 
				
			||||||
 | 
					                "%% done\r", argv[1], (100 * (float) (i + 1)) / k );
 | 
				
			||||||
 | 
					        fflush( stdout );
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if( t == time( NULL ) )
 | 
				
			||||||
 | 
					        t--;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    fclose( f );
 | 
				
			||||||
 | 
					    return( 0 );
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user