Compare commits
	
		
			11 Commits
		
	
	
		
			OpenSSL-fi
			...
			OpenSSL_1_
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 
						 | 
					e614ec4769 | ||
| 
						 | 
					a6b03f4138 | ||
| 
						 | 
					809fa4cc59 | ||
| 
						 | 
					463f448595 | ||
| 
						 | 
					5cd0cf8cce | ||
| 
						 | 
					49cb959494 | ||
| 
						 | 
					783a73c47f | ||
| 
						 | 
					99bf516908 | ||
| 
						 | 
					a26c372cfc | ||
| 
						 | 
					ed5ac22e5b | ||
| 
						 | 
					3d11b8f896 | 
@@ -3,6 +3,8 @@ libcrypto.pc
 | 
				
			|||||||
libssl.pc
 | 
					libssl.pc
 | 
				
			||||||
MINFO
 | 
					MINFO
 | 
				
			||||||
makefile.one
 | 
					makefile.one
 | 
				
			||||||
 | 
					tmp
 | 
				
			||||||
 | 
					out
 | 
				
			||||||
outinc
 | 
					outinc
 | 
				
			||||||
rehash.time
 | 
					rehash.time
 | 
				
			||||||
testlog
 | 
					testlog
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,25 +0,0 @@
 | 
				
			|||||||
The OpenSSL project depends on volunteer efforts and financial support from
 | 
					 | 
				
			||||||
the end user community. That support comes in the form of donations and paid
 | 
					 | 
				
			||||||
sponsorships, software support contracts, paid consulting services
 | 
					 | 
				
			||||||
and commissioned software development.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
Since all these activities support the continued development and improvement
 | 
					 | 
				
			||||||
of OpenSSL we consider all these clients and customers as sponsors of the
 | 
					 | 
				
			||||||
OpenSSL project.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
We would like to identify and thank the following such sponsors for their past
 | 
					 | 
				
			||||||
or current significant support of the OpenSSL project:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
Very significant support:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	OpenGear: www.opengear.com
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
Significant support:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	PSW Group: www.psw.net
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
Please note that we ask permission to identify sponsors and that some sponsors
 | 
					 | 
				
			||||||
we consider eligible for inclusion here have requested to remain anonymous.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
Additional sponsorship or financial support is always welcome: for more
 | 
					 | 
				
			||||||
information please contact the OpenSSL Software Foundation.
 | 
					 | 
				
			||||||
							
								
								
									
										934
									
								
								CHANGES
									
									
									
									
									
								
							
							
						
						
									
										934
									
								
								CHANGES
									
									
									
									
									
								
							@@ -2,643 +2,7 @@
 | 
				
			|||||||
 OpenSSL CHANGES
 | 
					 OpenSSL CHANGES
 | 
				
			||||||
 _______________
 | 
					 _______________
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 Changes between 1.0.1 and 1.1.0  [xx XXX xxxx]
 | 
					 Changes between 0.9.8k and 1.0  [xx XXX xxxx]
 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add flag to EC_KEY to use cofactor ECDH if set.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Update fips_test_suite to support multiple command line options. New
 | 
					 | 
				
			||||||
     test to induce all self test errors in sequence and check expected
 | 
					 | 
				
			||||||
     failures.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add FIPS_{rsa,dsa,ecdsa}_{sign,verify} functions which digest and
 | 
					 | 
				
			||||||
     sign or verify all in one operation.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add fips_algvs: a multicall fips utility incorporaing all the algorithm
 | 
					 | 
				
			||||||
     test programs and fips_test_suite. Includes functionality to parse
 | 
					 | 
				
			||||||
     the minimal script output of fipsalgest.pl directly.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add authorisation parameter to FIPS_module_mode_set().
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add FIPS selftest for ECDH algorithm using P-224 and B-233 curves.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Use separate DRBG fields for internal and external flags. New function
 | 
					 | 
				
			||||||
     FIPS_drbg_health_check() to perform on demand health checking. Add
 | 
					 | 
				
			||||||
     generation tests to fips_test_suite with reduced health check interval to 
 | 
					 | 
				
			||||||
     demonstrate periodic health checking. Add "nodh" option to
 | 
					 | 
				
			||||||
     fips_test_suite to skip very slow DH test.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) New function FIPS_get_cipherbynid() to lookup FIPS supported ciphers
 | 
					 | 
				
			||||||
     based on NID.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) More extensive health check for DRBG checking many more failure modes.
 | 
					 | 
				
			||||||
     New function FIPS_selftest_drbg_all() to handle every possible DRBG
 | 
					 | 
				
			||||||
     combination: call this in fips_test_suite.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add support for Dual EC DRBG from SP800-90. Update DRBG algorithm test
 | 
					 | 
				
			||||||
     and POST to handle Dual EC cases.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add support for canonical generation of DSA parameter 'g'. See 
 | 
					 | 
				
			||||||
     FIPS 186-3 A.2.3.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add support for HMAC DRBG from SP800-90. Update DRBG algorithm test and
 | 
					 | 
				
			||||||
     POST to handle HMAC cases.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add functions FIPS_module_version() and FIPS_module_version_text()
 | 
					 | 
				
			||||||
     to return numberical and string versions of the FIPS module number.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Rename FIPS_mode_set and FIPS_mode to FIPS_module_mode_set and
 | 
					 | 
				
			||||||
     FIPS_module_mode. FIPS_mode and FIPS_mode_set will be implmeneted
 | 
					 | 
				
			||||||
     outside the validated module in the FIPS capable OpenSSL.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Minor change to DRBG entropy callback semantics. In some cases
 | 
					 | 
				
			||||||
     there is no mutiple of the block length between min_len and
 | 
					 | 
				
			||||||
     max_len. Allow the callback to return more than max_len bytes
 | 
					 | 
				
			||||||
     of entropy but discard any extra: it is the callback's responsibility
 | 
					 | 
				
			||||||
     to ensure that the extra data discarded does not impact the
 | 
					 | 
				
			||||||
     requested amount of entropy.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add PRNG security strength checks to RSA, DSA and ECDSA using 
 | 
					 | 
				
			||||||
     information in FIPS186-3, SP800-57 and SP800-131A.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) CCM support via EVP. Interface is very similar to GCM case except we
 | 
					 | 
				
			||||||
     must supply all data in one chunk (i.e. no update, final) and the
 | 
					 | 
				
			||||||
     message length must be supplied if AAD is used. Add algorithm test
 | 
					 | 
				
			||||||
     support.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Initial version of POST overhaul. Add POST callback to allow the status
 | 
					 | 
				
			||||||
     of POST to be monitored and/or failures induced. Modify fips_test_suite
 | 
					 | 
				
			||||||
     to use callback. Always run all selftests even if one fails.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) XTS support including algorithm test driver in the fips_gcmtest program.
 | 
					 | 
				
			||||||
     Note: this does increase the maximum key length from 32 to 64 bytes but
 | 
					 | 
				
			||||||
     there should be no binary compatibility issues as existing applications
 | 
					 | 
				
			||||||
     will never use XTS mode.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Extensive reorganisation of FIPS PRNG behaviour. Remove all dependencies
 | 
					 | 
				
			||||||
     to OpenSSL RAND code and replace with a tiny FIPS RAND API which also
 | 
					 | 
				
			||||||
     performs algorithm blocking for unapproved PRNG types. Also do not
 | 
					 | 
				
			||||||
     set PRNG type in FIPS_mode_set(): leave this to the application.
 | 
					 | 
				
			||||||
     Add default OpenSSL DRBG handling: sets up FIPS PRNG and seeds with
 | 
					 | 
				
			||||||
     the standard OpenSSL PRNG: set additional data to a date time vector.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Rename old X9.31 PRNG functions of the form FIPS_rand* to FIPS_x931*.
 | 
					 | 
				
			||||||
     This shouldn't present any incompatibility problems because applications
 | 
					 | 
				
			||||||
     shouldn't be using these directly and any that are will need to rethink
 | 
					 | 
				
			||||||
     anyway as the X9.31 PRNG is now deprecated by FIPS 140-2
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Extensive self tests and health checking required by SP800-90 DRBG.
 | 
					 | 
				
			||||||
     Remove strength parameter from FIPS_drbg_instantiate and always
 | 
					 | 
				
			||||||
     instantiate at maximum supported strength.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add ECDH code to fips module and fips_ecdhvs for primitives only testing.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) New algorithm test program fips_dhvs to handle DH primitives only testing.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) New function DH_compute_key_padded() to compute a DH key and pad with
 | 
					 | 
				
			||||||
     leading zeroes if needed: this complies with SP800-56A et al.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Initial implementation of SP800-90 DRBGs for Hash and CTR. Not used by
 | 
					 | 
				
			||||||
     anything, incomplete, subject to change and largely untested at present.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Modify fipscanisteronly build option to only build the necessary object
 | 
					 | 
				
			||||||
     files by filtering FIPS_EX_OBJ through a perl script in crypto/Makefile.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add experimental option FIPSSYMS to give all symbols in
 | 
					 | 
				
			||||||
     fipscanister.o and FIPS or fips prefix. This will avoid
 | 
					 | 
				
			||||||
     conflicts with future versions of OpenSSL. Add perl script
 | 
					 | 
				
			||||||
     util/fipsas.pl to preprocess assembly language source files
 | 
					 | 
				
			||||||
     and rename any affected symbols.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add selftest checks and algorithm block of non-fips algorithms in
 | 
					 | 
				
			||||||
     FIPS mode. Remove DES2 from selftests.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add ECDSA code to fips module. Add tiny fips_ecdsa_check to just
 | 
					 | 
				
			||||||
     return internal method without any ENGINE dependencies. Add new
 | 
					 | 
				
			||||||
     tiny fips sign and verify functions.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) New build option no-ec2m to disable characteristic 2 code.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) New build option "fipscanisteronly". This only builds fipscanister.o
 | 
					 | 
				
			||||||
     and (currently) associated fips utilities. Uses the file Makefile.fips
 | 
					 | 
				
			||||||
     instead of Makefile.org as the prototype.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add some FIPS mode restrictions to GCM. Add internal IV generator.
 | 
					 | 
				
			||||||
     Update fips_gcmtest to use IV generator.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Initial, experimental EVP support for AES-GCM. AAD can be input by
 | 
					 | 
				
			||||||
     setting output buffer to NULL. The *Final function must be
 | 
					 | 
				
			||||||
     called although it will not retrieve any additional data. The tag
 | 
					 | 
				
			||||||
     can be set or retrieved with a ctrl. The IV length is by default 12
 | 
					 | 
				
			||||||
     bytes (96 bits) but can be set to an alternative value. If the IV
 | 
					 | 
				
			||||||
     length exceeds the maximum IV length (currently 16 bytes) it cannot be
 | 
					 | 
				
			||||||
     set before the key. 
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) New flag in ciphers: EVP_CIPH_FLAG_CUSTOM_CIPHER. This means the
 | 
					 | 
				
			||||||
     underlying do_cipher function handles all cipher semantics itself
 | 
					 | 
				
			||||||
     including padding and finalisation. This is useful if (for example)
 | 
					 | 
				
			||||||
     an ENGINE cipher handles block padding itself. The behaviour of
 | 
					 | 
				
			||||||
     do_cipher is subtly changed if this flag is set: the return value
 | 
					 | 
				
			||||||
     is the number of characters written to the output buffer (zero is
 | 
					 | 
				
			||||||
     no longer an error code) or a negative error code. Also if the
 | 
					 | 
				
			||||||
     input buffer is NULL and length 0 finalisation should be performed.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) If a candidate issuer certificate is already part of the constructed
 | 
					 | 
				
			||||||
     path ignore it: new debug notification X509_V_ERR_PATH_LOOP for this case.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Improve forward-security support: add functions
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
       void SSL_CTX_set_not_resumable_session_callback(SSL_CTX *ctx, int (*cb)(SSL *ssl, int is_forward_secure))
 | 
					 | 
				
			||||||
       void SSL_set_not_resumable_session_callback(SSL *ssl, int (*cb)(SSL *ssl, int is_forward_secure))
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
     for use by SSL/TLS servers; the callback function will be called whenever a
 | 
					 | 
				
			||||||
     new session is created, and gets to decide whether the session may be
 | 
					 | 
				
			||||||
     cached to make it resumable (return 0) or not (return 1).  (As by the
 | 
					 | 
				
			||||||
     SSL/TLS protocol specifications, the session_id sent by the server will be
 | 
					 | 
				
			||||||
     empty to indicate that the session is not resumable; also, the server will
 | 
					 | 
				
			||||||
     not generate RFC 4507 (RFC 5077) session tickets.)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
     A simple reasonable callback implementation is to return is_forward_secure.
 | 
					 | 
				
			||||||
     This parameter will be set to 1 or 0 depending on the ciphersuite selected
 | 
					 | 
				
			||||||
     by the SSL/TLS server library, indicating whether it can provide forward
 | 
					 | 
				
			||||||
     security.
 | 
					 | 
				
			||||||
     [Emilia K<>sper <emilia.kasper@esat.kuleuven.be> (Google)]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add Next Protocol Negotiation,
 | 
					 | 
				
			||||||
     http://tools.ietf.org/html/draft-agl-tls-nextprotoneg-00. Can be
 | 
					 | 
				
			||||||
     disabled with a no-npn flag to config or Configure. Code donated
 | 
					 | 
				
			||||||
     by Google.
 | 
					 | 
				
			||||||
     [Adam Langley <agl@google.com> and Ben Laurie]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) New function OPENSSL_gmtime_diff to find the difference in days
 | 
					 | 
				
			||||||
     and seconds between two tm structures. This will be used to provide
 | 
					 | 
				
			||||||
     additional functionality for ASN1_TIME.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add -trusted_first option which attempts to find certificates in the
 | 
					 | 
				
			||||||
     trusted store even if an untrusted chain is also supplied.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Initial experimental support for explicitly trusted non-root CAs. 
 | 
					 | 
				
			||||||
     OpenSSL still tries to build a complete chain to a root but if an
 | 
					 | 
				
			||||||
     intermediate CA has a trust setting included that is used. The first
 | 
					 | 
				
			||||||
     setting is used: whether to trust or reject.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) New -verify_name option in command line utilities to set verification
 | 
					 | 
				
			||||||
     parameters by name.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Initial CMAC implementation. WARNING: EXPERIMENTAL, API MAY CHANGE.
 | 
					 | 
				
			||||||
     Add CMAC pkey methods.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Experimental regnegotiation in s_server -www mode. If the client 
 | 
					 | 
				
			||||||
     browses /reneg connection is renegotiated. If /renegcert it is
 | 
					 | 
				
			||||||
     renegotiated requesting a certificate.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add an "external" session cache for debugging purposes to s_server. This
 | 
					 | 
				
			||||||
     should help trace issues which normally are only apparent in deployed
 | 
					 | 
				
			||||||
     multi-process servers.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Extensive audit of libcrypto with DEBUG_UNUSED. Fix many cases where
 | 
					 | 
				
			||||||
     return value is ignored. NB. The functions RAND_add(), RAND_seed(),
 | 
					 | 
				
			||||||
     BIO_set_cipher() and some obscure PEM functions were changed so they
 | 
					 | 
				
			||||||
     can now return an error. The RAND changes required a change to the
 | 
					 | 
				
			||||||
     RAND_METHOD structure.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) New macro __owur for "OpenSSL Warn Unused Result". This makes use of
 | 
					 | 
				
			||||||
     a gcc attribute to warn if the result of a function is ignored. This
 | 
					 | 
				
			||||||
     is enable if DEBUG_UNUSED is set. Add to several functions in evp.h
 | 
					 | 
				
			||||||
     whose return value is often ignored. 
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
  
 | 
					 | 
				
			||||||
 Changes between 1.0.0f and 1.0.1  [xx XXX xxxx]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add optional 64-bit optimized implementations of elliptic curves NIST-P224,
 | 
					 | 
				
			||||||
     NIST-P256, NIST-P521, with constant-time single point multiplication on
 | 
					 | 
				
			||||||
     typical inputs. Compiler support for the nonstandard type __uint128_t is
 | 
					 | 
				
			||||||
     required to use this (present in gcc 4.4 and later, for 64-bit builds).
 | 
					 | 
				
			||||||
     Code made available under Apache License version 2.0.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
     Specify "enable-ec_nistp_64_gcc_128" on the Configure (or config) command
 | 
					 | 
				
			||||||
     line to include this in your build of OpenSSL, and run "make depend" (or
 | 
					 | 
				
			||||||
     "make update"). This enables the following EC_METHODs:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
         EC_GFp_nistp224_method()
 | 
					 | 
				
			||||||
         EC_GFp_nistp256_method()
 | 
					 | 
				
			||||||
         EC_GFp_nistp521_method()
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
     EC_GROUP_new_by_curve_name() will automatically use these (while
 | 
					 | 
				
			||||||
     EC_GROUP_new_curve_GFp() currently prefers the more flexible
 | 
					 | 
				
			||||||
     implementations).
 | 
					 | 
				
			||||||
     [Emilia K<>sper, Adam Langley, Bodo Moeller (Google)]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Use type ossl_ssize_t instad of ssize_t which isn't available on
 | 
					 | 
				
			||||||
     all platforms. Move ssize_t definition from e_os.h to the public
 | 
					 | 
				
			||||||
     header file e_os2.h as it now appears in public header file cms.h
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) New -sigopt option to the ca, req and x509 utilities. Additional
 | 
					 | 
				
			||||||
     signature parameters can be passed using this option and in
 | 
					 | 
				
			||||||
     particular PSS. 
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add RSA PSS signing function. This will generate and set the
 | 
					 | 
				
			||||||
     appropriate AlgorithmIdentifiers for PSS based on those in the
 | 
					 | 
				
			||||||
     corresponding EVP_MD_CTX structure. No application support yet.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Support for companion algorithm specific ASN1 signing routines.
 | 
					 | 
				
			||||||
     New function ASN1_item_sign_ctx() signs a pre-initialised
 | 
					 | 
				
			||||||
     EVP_MD_CTX structure and sets AlgorithmIdentifiers based on
 | 
					 | 
				
			||||||
     the appropriate parameters.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add new algorithm specific ASN1 verification initialisation function
 | 
					 | 
				
			||||||
     to EVP_PKEY_ASN1_METHOD: this is not in EVP_PKEY_METHOD since the ASN1
 | 
					 | 
				
			||||||
     handling will be the same no matter what EVP_PKEY_METHOD is used.
 | 
					 | 
				
			||||||
     Add a PSS handler to support verification of PSS signatures: checked
 | 
					 | 
				
			||||||
     against a number of sample certificates.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add signature printing for PSS. Add PSS OIDs.
 | 
					 | 
				
			||||||
     [Steve Henson, Martin Kaiser <lists@kaiser.cx>]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add algorithm specific signature printing. An individual ASN1 method
 | 
					 | 
				
			||||||
     can now print out signatures instead of the standard hex dump. 
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
     More complex signatures (e.g. PSS) can print out more meaningful
 | 
					 | 
				
			||||||
     information. Include DSA version that prints out the signature
 | 
					 | 
				
			||||||
     parameters r, s.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Password based recipient info support for CMS library: implementing
 | 
					 | 
				
			||||||
     RFC3211.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Split password based encryption into PBES2 and PBKDF2 functions. This
 | 
					 | 
				
			||||||
     neatly separates the code into cipher and PBE sections and is required
 | 
					 | 
				
			||||||
     for some algorithms that split PBES2 into separate pieces (such as
 | 
					 | 
				
			||||||
     password based CMS).
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Session-handling fixes:
 | 
					 | 
				
			||||||
     - Fix handling of connections that are resuming with a session ID,
 | 
					 | 
				
			||||||
       but also support Session Tickets.
 | 
					 | 
				
			||||||
     - Fix a bug that suppressed issuing of a new ticket if the client
 | 
					 | 
				
			||||||
       presented a ticket with an expired session.
 | 
					 | 
				
			||||||
     - Try to set the ticket lifetime hint to something reasonable.
 | 
					 | 
				
			||||||
     - Make tickets shorter by excluding irrelevant information.
 | 
					 | 
				
			||||||
     - On the client side, don't ignore renewed tickets.
 | 
					 | 
				
			||||||
     [Adam Langley, Bodo Moeller (Google)]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Fix PSK session representation.
 | 
					 | 
				
			||||||
     [Bodo Moeller]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add RC4-MD5 and AESNI-SHA1 "stitched" implementations.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
     This work was sponsored by Intel.
 | 
					 | 
				
			||||||
     [Andy Polyakov]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add GCM support to TLS library. Some custom code is needed to split
 | 
					 | 
				
			||||||
     the IV between the fixed (from PRF) and explicit (from TLS record)
 | 
					 | 
				
			||||||
     portions. This adds all GCM ciphersuites supported by RFC5288 and 
 | 
					 | 
				
			||||||
     RFC5289. Generalise some AES* cipherstrings to inlclude GCM and
 | 
					 | 
				
			||||||
     add a special AESGCM string for GCM only.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Expand range of ctrls for AES GCM. Permit setting invocation
 | 
					 | 
				
			||||||
     field on decrypt and retrieval of invocation field only on encrypt.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add HMAC ECC ciphersuites from RFC5289. Include SHA384 PRF support.
 | 
					 | 
				
			||||||
     As required by RFC5289 these ciphersuites cannot be used if for
 | 
					 | 
				
			||||||
     versions of TLS earlier than 1.2.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) For FIPS capable OpenSSL interpret a NULL default public key method
 | 
					 | 
				
			||||||
     as unset and return the appopriate default but do *not* set the default.
 | 
					 | 
				
			||||||
     This means we can return the appopriate method in applications that
 | 
					 | 
				
			||||||
     swicth between FIPS and non-FIPS modes.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Redirect HMAC and CMAC operations to FIPS module in FIPS mode. If an
 | 
					 | 
				
			||||||
     ENGINE is used then we cannot handle that in the FIPS module so we
 | 
					 | 
				
			||||||
     keep original code iff non-FIPS operations are allowed.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add -attime option to openssl verify.
 | 
					 | 
				
			||||||
     [Peter Eckersley <pde@eff.org> and Ben Laurie]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Redirect DSA and DH operations to FIPS module in FIPS mode.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Redirect ECDSA and ECDH operations to FIPS module in FIPS mode. Also use
 | 
					 | 
				
			||||||
     FIPS EC methods unconditionally for now.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) New build option no-ec2m to disable characteristic 2 code.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Backport libcrypto audit of return value checking from 1.1.0-dev; not
 | 
					 | 
				
			||||||
     all cases can be covered as some introduce binary incompatibilities.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Redirect RSA operations to FIPS module including keygen,
 | 
					 | 
				
			||||||
     encrypt, decrypt, sign and verify. Block use of non FIPS RSA methods.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add similar low level API blocking to ciphers.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Low level digest APIs are not approved in FIPS mode: any attempt
 | 
					 | 
				
			||||||
     to use these will cause a fatal error. Applications that *really* want
 | 
					 | 
				
			||||||
     to use them can use the private_* version instead.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Redirect cipher operations to FIPS module for FIPS builds. 
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Redirect digest operations to FIPS module for FIPS builds. 
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Update build system to add "fips" flag which will link in fipscanister.o
 | 
					 | 
				
			||||||
     for static and shared library builds embedding a signature if needed.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Output TLS supported curves in preference order instead of numerical
 | 
					 | 
				
			||||||
     order. This is currently hardcoded for the highest order curves first.
 | 
					 | 
				
			||||||
     This should be configurable so applications can judge speed vs strength.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add TLS v1.2 server support for client authentication. 
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add support for FIPS mode in ssl library: disable SSLv3, non-FIPS ciphers
 | 
					 | 
				
			||||||
     and enable MD5.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Functions FIPS_mode_set() and FIPS_mode() which call the underlying
 | 
					 | 
				
			||||||
     FIPS modules versions.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add TLS v1.2 client side support for client authentication. Keep cache
 | 
					 | 
				
			||||||
     of handshake records longer as we don't know the hash algorithm to use
 | 
					 | 
				
			||||||
     until after the certificate request message is received.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Initial TLS v1.2 client support. Add a default signature algorithms
 | 
					 | 
				
			||||||
     extension including all the algorithms we support. Parse new signature
 | 
					 | 
				
			||||||
     format in client key exchange. Relax some ECC signing restrictions for
 | 
					 | 
				
			||||||
     TLS v1.2 as indicated in RFC5246.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add server support for TLS v1.2 signature algorithms extension. Switch
 | 
					 | 
				
			||||||
     to new signature format when needed using client digest preference.
 | 
					 | 
				
			||||||
     All server ciphersuites should now work correctly in TLS v1.2. No client
 | 
					 | 
				
			||||||
     support yet and no support for client certificates.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Initial TLS v1.2 support. Add new SHA256 digest to ssl code, switch
 | 
					 | 
				
			||||||
     to SHA256 for PRF when using TLS v1.2 and later. Add new SHA256 based
 | 
					 | 
				
			||||||
     ciphersuites. At present only RSA key exchange ciphersuites work with
 | 
					 | 
				
			||||||
     TLS v1.2. Add new option for TLS v1.2 replacing the old and obsolete
 | 
					 | 
				
			||||||
     SSL_OP_PKCS1_CHECK flags with SSL_OP_NO_TLSv1_2. New TLSv1.2 methods
 | 
					 | 
				
			||||||
     and version checking.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) New option OPENSSL_NO_SSL_INTERN. If an application can be compiled
 | 
					 | 
				
			||||||
     with this defined it will not be affected by any changes to ssl internal
 | 
					 | 
				
			||||||
     structures. Add several utility functions to allow openssl application
 | 
					 | 
				
			||||||
     to work with OPENSSL_NO_SSL_INTERN defined.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add SRP support.
 | 
					 | 
				
			||||||
     [Tom Wu <tjw@cs.stanford.edu> and Ben Laurie]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add functions to copy EVP_PKEY_METHOD and retrieve flags and id.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Permit abbreviated handshakes when renegotiating using the function
 | 
					 | 
				
			||||||
     SSL_renegotiate_abbreviated().
 | 
					 | 
				
			||||||
     [Robin Seggelmann <seggelmann@fh-muenster.de>]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add call to ENGINE_register_all_complete() to
 | 
					 | 
				
			||||||
     ENGINE_load_builtin_engines(), so some implementations get used
 | 
					 | 
				
			||||||
     automatically instead of needing explicit application support.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add support for TLS key exporter as described in RFC5705.
 | 
					 | 
				
			||||||
     [Robin Seggelmann <seggelmann@fh-muenster.de>, Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Initial TLSv1.1 support. Since TLSv1.1 is very similar to TLS v1.0 only
 | 
					 | 
				
			||||||
     a few changes are required:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
       Add SSL_OP_NO_TLSv1_1 flag.
 | 
					 | 
				
			||||||
       Add TLSv1_1 methods.
 | 
					 | 
				
			||||||
       Update version checking logic to handle version 1.1.
 | 
					 | 
				
			||||||
       Add explicit IV handling (ported from DTLS code).
 | 
					 | 
				
			||||||
       Add command line options to s_client/s_server.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 Changes between 1.0.0e and 1.0.0f [xx XXX xxxx]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Fix handling of BN_BLINDING: now BN_BLINDING_invert_ex (rather than
 | 
					 | 
				
			||||||
     BN_BLINDING_invert_ex) calls BN_BLINDING_update, ensuring that concurrent
 | 
					 | 
				
			||||||
     threads won't reuse the same blinding coefficients.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
     This also avoids the need to obtain the CRYPTO_LOCK_RSA_BLINDING
 | 
					 | 
				
			||||||
     lock to call BN_BLINDING_invert_ex, and avoids one use of
 | 
					 | 
				
			||||||
     BN_BLINDING_update for each BN_BLINDING structure (previously,
 | 
					 | 
				
			||||||
     the last update always remained unused).
 | 
					 | 
				
			||||||
     [Emilia K<>sper (Google)]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) In ssl3_clear, preserve s3->init_extra along with s3->rbuf.
 | 
					 | 
				
			||||||
     [Bob Buckholz (Google)]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 Changes between 1.0.0d and 1.0.0e [6 Sep 2011]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Fix bug where CRLs with nextUpdate in the past are sometimes accepted
 | 
					 | 
				
			||||||
     by initialising X509_STORE_CTX properly. (CVE-2011-3207)
 | 
					 | 
				
			||||||
     [Kaspar Brand <ossl@velox.ch>]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Fix SSL memory handling for (EC)DH ciphersuites, in particular
 | 
					 | 
				
			||||||
     for multi-threaded use of ECDH. (CVE-2011-3210)
 | 
					 | 
				
			||||||
     [Adam Langley (Google)]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Fix x509_name_ex_d2i memory leak on bad inputs.
 | 
					 | 
				
			||||||
     [Bodo Moeller]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Remove hard coded ecdsaWithSHA1 signature tests in ssl code and check
 | 
					 | 
				
			||||||
     signature public key algorithm by using OID xref utilities instead.
 | 
					 | 
				
			||||||
     Before this you could only use some ECC ciphersuites with SHA1 only.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add protection against ECDSA timing attacks as mentioned in the paper
 | 
					 | 
				
			||||||
     by Billy Bob Brumley and Nicola Tuveri, see:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	http://eprint.iacr.org/2011/232.pdf
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
     [Billy Bob Brumley and Nicola Tuveri]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 Changes between 1.0.0c and 1.0.0d [8 Feb 2011]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Fix parsing of OCSP stapling ClientHello extension. CVE-2011-0014
 | 
					 | 
				
			||||||
     [Neel Mehta, Adam Langley, Bodo Moeller (Google)]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Fix bug in string printing code: if *any* escaping is enabled we must
 | 
					 | 
				
			||||||
     escape the escape character (backslash) or the resulting string is
 | 
					 | 
				
			||||||
     ambiguous.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 Changes between 1.0.0b and 1.0.0c  [2 Dec 2010]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Disable code workaround for ancient and obsolete Netscape browsers
 | 
					 | 
				
			||||||
     and servers: an attacker can use it in a ciphersuite downgrade attack.
 | 
					 | 
				
			||||||
     Thanks to Martin Rex for discovering this bug. CVE-2010-4180
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Fixed J-PAKE implementation error, originally discovered by
 | 
					 | 
				
			||||||
     Sebastien Martini, further info and confirmation from Stefan
 | 
					 | 
				
			||||||
     Arentz and Feng Hao. Note that this fix is a security fix. CVE-2010-4252
 | 
					 | 
				
			||||||
     [Ben Laurie]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 Changes between 1.0.0a and 1.0.0b  [16 Nov 2010]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Fix extension code to avoid race conditions which can result in a buffer
 | 
					 | 
				
			||||||
     overrun vulnerability: resumed sessions must not be modified as they can
 | 
					 | 
				
			||||||
     be shared by multiple threads. CVE-2010-3864
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Fix WIN32 build system to correctly link an ENGINE directory into
 | 
					 | 
				
			||||||
     a DLL. 
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 Changes between 1.0.0 and 1.0.0a  [01 Jun 2010]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Check return value of int_rsa_verify in pkey_rsa_verifyrecover 
 | 
					 | 
				
			||||||
     (CVE-2010-1633)
 | 
					 | 
				
			||||||
     [Steve Henson, Peter-Michael Hager <hager@dortmund.net>]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 Changes between 0.9.8n and 1.0.0  [29 Mar 2010]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add "missing" function EVP_CIPHER_CTX_copy(). This copies a cipher
 | 
					 | 
				
			||||||
     context. The operation can be customised via the ctrl mechanism in
 | 
					 | 
				
			||||||
     case ENGINEs want to include additional functionality.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Tolerate yet another broken PKCS#8 key format: private key value negative.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add new -subject_hash_old and -issuer_hash_old options to x509 utility to
 | 
					 | 
				
			||||||
     output hashes compatible with older versions of OpenSSL.
 | 
					 | 
				
			||||||
     [Willy Weisz <weisz@vcpc.univie.ac.at>]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Fix compression algorithm handling: if resuming a session use the
 | 
					 | 
				
			||||||
     compression algorithm of the resumed session instead of determining
 | 
					 | 
				
			||||||
     it from client hello again. Don't allow server to change algorithm.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add load_crls() function to apps tidying load_certs() too. Add option
 | 
					 | 
				
			||||||
     to verify utility to allow additional CRLs to be included.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Update OCSP request code to permit adding custom headers to the request:
 | 
					 | 
				
			||||||
     some responders need this.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) The function EVP_PKEY_sign() returns <=0 on error: check return code
 | 
					 | 
				
			||||||
     correctly.
 | 
					 | 
				
			||||||
     [Julia Lawall <julia@diku.dk>]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Update verify callback code in apps/s_cb.c and apps/verify.c, it
 | 
					 | 
				
			||||||
     needlessly dereferenced structures, used obsolete functions and
 | 
					 | 
				
			||||||
     didn't handle all updated verify codes correctly.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Disable MD2 in the default configuration.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) In BIO_pop() and BIO_push() use the ctrl argument (which was NULL) to
 | 
					 | 
				
			||||||
     indicate the initial BIO being pushed or popped. This makes it possible
 | 
					 | 
				
			||||||
     to determine whether the BIO is the one explicitly called or as a result
 | 
					 | 
				
			||||||
     of the ctrl being passed down the chain. Fix BIO_pop() and SSL BIOs so
 | 
					 | 
				
			||||||
     it handles reference counts correctly and doesn't zero out the I/O bio
 | 
					 | 
				
			||||||
     when it is not being explicitly popped. WARNING: applications which
 | 
					 | 
				
			||||||
     included workarounds for the old buggy behaviour will need to be modified
 | 
					 | 
				
			||||||
     or they could free up already freed BIOs.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Extend the uni2asc/asc2uni => OPENSSL_uni2asc/OPENSSL_asc2uni
 | 
					 | 
				
			||||||
     renaming to all platforms (within the 0.9.8 branch, this was
 | 
					 | 
				
			||||||
     done conditionally on Netware platforms to avoid a name clash).
 | 
					 | 
				
			||||||
     [Guenter <lists@gknw.net>]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add ECDHE and PSK support to DTLS.
 | 
					 | 
				
			||||||
     [Michael Tuexen <tuexen@fh-muenster.de>]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add CHECKED_STACK_OF macro to safestack.h, otherwise safestack can't
 | 
					 | 
				
			||||||
     be used on C++.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add "missing" function EVP_MD_flags() (without this the only way to
 | 
					 | 
				
			||||||
     retrieve a digest flags is by accessing the structure directly. Update
 | 
					 | 
				
			||||||
     EVP_MD_do_all*() and EVP_CIPHER_do_all*() to include the name a digest
 | 
					 | 
				
			||||||
     or cipher is registered as in the "from" argument. Print out all
 | 
					 | 
				
			||||||
     registered digests in the dgst usage message instead of manually 
 | 
					 | 
				
			||||||
     attempting to work them out.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) If no SSLv2 ciphers are used don't use an SSLv2 compatible client hello:
 | 
					 | 
				
			||||||
     this allows the use of compression and extensions. Change default cipher
 | 
					 | 
				
			||||||
     string to remove SSLv2 ciphersuites. This effectively avoids ancient SSLv2
 | 
					 | 
				
			||||||
     by default unless an application cipher string requests it.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Alter match criteria in PKCS12_parse(). It used to try to use local
 | 
					 | 
				
			||||||
     key ids to find matching certificates and keys but some PKCS#12 files
 | 
					 | 
				
			||||||
     don't follow the (somewhat unwritten) rules and this strategy fails.
 | 
					 | 
				
			||||||
     Now just gather all certificates together and the first private key
 | 
					 | 
				
			||||||
     then look for the first certificate that matches the key.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
  *) Support use of registered digest and cipher names for dgst and cipher
 | 
					  *) Support use of registered digest and cipher names for dgst and cipher
 | 
				
			||||||
     commands instead of having to add each one as a special case. So now
 | 
					     commands instead of having to add each one as a special case. So now
 | 
				
			||||||
@@ -1398,285 +762,12 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
  *) Change 'Configure' script to enable Camellia by default.
 | 
					  *) Change 'Configure' script to enable Camellia by default.
 | 
				
			||||||
     [NTT]
 | 
					     [NTT]
 | 
				
			||||||
  
 | 
					 | 
				
			||||||
 Changes between 0.9.8r and 0.9.8s [xx XXX xxxx]
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
  *) Fix handling of BN_BLINDING: now BN_BLINDING_invert_ex (rather than
 | 
					 Changes between 0.9.8k and 0.9.8l  [xx XXX xxxx]
 | 
				
			||||||
     BN_BLINDING_invert_ex) calls BN_BLINDING_update, ensuring that concurrent
 | 
					 | 
				
			||||||
     threads won't reuse the same blinding coefficients.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
     This also avoids the need to obtain the CRYPTO_LOCK_RSA_BLINDING
 | 
					 | 
				
			||||||
     lock to call BN_BLINDING_invert_ex, and avoids one use of
 | 
					 | 
				
			||||||
     BN_BLINDING_update for each BN_BLINDING structure (previously,
 | 
					 | 
				
			||||||
     the last update always remained unused).
 | 
					 | 
				
			||||||
     [Emilia K<>sper (Google)]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Fix SSL memory handling for (EC)DH ciphersuites, in particular
 | 
					 | 
				
			||||||
     for multi-threaded use of ECDH.
 | 
					 | 
				
			||||||
     [Adam Langley (Google)]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Fix x509_name_ex_d2i memory leak on bad inputs.
 | 
					 | 
				
			||||||
     [Bodo Moeller]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add protection against ECDSA timing attacks as mentioned in the paper
 | 
					 | 
				
			||||||
     by Billy Bob Brumley and Nicola Tuveri, see:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	http://eprint.iacr.org/2011/232.pdf
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
     [Billy Bob Brumley and Nicola Tuveri]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 Changes between 0.9.8q and 0.9.8r [8 Feb 2011]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Fix parsing of OCSP stapling ClientHello extension. CVE-2011-0014
 | 
					 | 
				
			||||||
     [Neel Mehta, Adam Langley, Bodo Moeller (Google)]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Fix bug in string printing code: if *any* escaping is enabled we must
 | 
					 | 
				
			||||||
     escape the escape character (backslash) or the resulting string is
 | 
					 | 
				
			||||||
     ambiguous.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 Changes between 0.9.8p and 0.9.8q [2 Dec 2010]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Disable code workaround for ancient and obsolete Netscape browsers
 | 
					 | 
				
			||||||
     and servers: an attacker can use it in a ciphersuite downgrade attack.
 | 
					 | 
				
			||||||
     Thanks to Martin Rex for discovering this bug. CVE-2010-4180
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Fixed J-PAKE implementation error, originally discovered by
 | 
					 | 
				
			||||||
     Sebastien Martini, further info and confirmation from Stefan
 | 
					 | 
				
			||||||
     Arentz and Feng Hao. Note that this fix is a security fix. CVE-2010-4252
 | 
					 | 
				
			||||||
     [Ben Laurie]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 Changes between 0.9.8o and 0.9.8p [16 Nov 2010]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Fix extension code to avoid race conditions which can result in a buffer
 | 
					 | 
				
			||||||
     overrun vulnerability: resumed sessions must not be modified as they can
 | 
					 | 
				
			||||||
     be shared by multiple threads. CVE-2010-3864
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Fix for double free bug in ssl/s3_clnt.c CVE-2010-2939
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Don't reencode certificate when calculating signature: cache and use
 | 
					 | 
				
			||||||
     the original encoding instead. This makes signature verification of
 | 
					 | 
				
			||||||
     some broken encodings work correctly.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) ec2_GF2m_simple_mul bugfix: compute correct result if the output EC_POINT
 | 
					 | 
				
			||||||
     is also one of the inputs.
 | 
					 | 
				
			||||||
     [Emilia K<>sper <emilia.kasper@esat.kuleuven.be> (Google)]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Don't repeatedly append PBE algorithms to table if they already exist.
 | 
					 | 
				
			||||||
     Sort table on each new add. This effectively makes the table read only
 | 
					 | 
				
			||||||
     after all algorithms are added and subsequent calls to PKCS12_pbe_add
 | 
					 | 
				
			||||||
     etc are non-op.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 Changes between 0.9.8n and 0.9.8o [01 Jun 2010]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  [NB: OpenSSL 0.9.8o and later 0.9.8 patch levels were released after
 | 
					 | 
				
			||||||
  OpenSSL 1.0.0.]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Correct a typo in the CMS ASN1 module which can result in invalid memory
 | 
					 | 
				
			||||||
     access or freeing data twice (CVE-2010-0742)
 | 
					 | 
				
			||||||
     [Steve Henson, Ronald Moesbergen <intercommit@gmail.com>]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add SHA2 algorithms to SSL_library_init(). SHA2 is becoming far more
 | 
					 | 
				
			||||||
     common in certificates and some applications which only call
 | 
					 | 
				
			||||||
     SSL_library_init and not OpenSSL_add_all_algorithms() will fail.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) VMS fixes: 
 | 
					 | 
				
			||||||
     Reduce copying into .apps and .test in makevms.com
 | 
					 | 
				
			||||||
     Don't try to use blank CA certificate in CA.com
 | 
					 | 
				
			||||||
     Allow use of C files from original directories in maketests.com
 | 
					 | 
				
			||||||
     [Steven M. Schweda" <sms@antinode.info>]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 Changes between 0.9.8m and 0.9.8n [24 Mar 2010]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) When rejecting SSL/TLS records due to an incorrect version number, never
 | 
					 | 
				
			||||||
     update s->server with a new major version number.  As of
 | 
					 | 
				
			||||||
     - OpenSSL 0.9.8m if 'short' is a 16-bit type,
 | 
					 | 
				
			||||||
     - OpenSSL 0.9.8f if 'short' is longer than 16 bits,
 | 
					 | 
				
			||||||
     the previous behavior could result in a read attempt at NULL when
 | 
					 | 
				
			||||||
     receiving specific incorrect SSL/TLS records once record payload
 | 
					 | 
				
			||||||
     protection is active.  (CVE-2010-0740)
 | 
					 | 
				
			||||||
     [Bodo Moeller, Adam Langley <agl@chromium.org>]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Fix for CVE-2010-0433 where some kerberos enabled versions of OpenSSL 
 | 
					 | 
				
			||||||
     could be crashed if the relevant tables were not present (e.g. chrooted).
 | 
					 | 
				
			||||||
     [Tomas Hoger <thoger@redhat.com>]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 Changes between 0.9.8l and 0.9.8m [25 Feb 2010]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Always check bn_wexpend() return values for failure.  (CVE-2009-3245)
 | 
					 | 
				
			||||||
     [Martin Olsson, Neel Mehta]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Fix X509_STORE locking: Every 'objs' access requires a lock (to
 | 
					 | 
				
			||||||
     accommodate for stack sorting, always a write lock!).
 | 
					 | 
				
			||||||
     [Bodo Moeller]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) On some versions of WIN32 Heap32Next is very slow. This can cause
 | 
					 | 
				
			||||||
     excessive delays in the RAND_poll(): over a minute. As a workaround
 | 
					 | 
				
			||||||
     include a time check in the inner Heap32Next loop too.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) The code that handled flushing of data in SSL/TLS originally used the
 | 
					 | 
				
			||||||
     BIO_CTRL_INFO ctrl to see if any data was pending first. This caused
 | 
					 | 
				
			||||||
     the problem outlined in PR#1949. The fix suggested there however can
 | 
					 | 
				
			||||||
     trigger problems with buggy BIO_CTRL_WPENDING (e.g. some versions
 | 
					 | 
				
			||||||
     of Apache). So instead simplify the code to flush unconditionally.
 | 
					 | 
				
			||||||
     This should be fine since flushing with no data to flush is a no op.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Handle TLS versions 2.0 and later properly and correctly use the
 | 
					 | 
				
			||||||
     highest version of TLS/SSL supported. Although TLS >= 2.0 is some way
 | 
					 | 
				
			||||||
     off ancient servers have a habit of sticking around for a while...
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Modify compression code so it frees up structures without using the
 | 
					 | 
				
			||||||
     ex_data callbacks. This works around a problem where some applications
 | 
					 | 
				
			||||||
     call CRYPTO_cleanup_all_ex_data() before application exit (e.g. when
 | 
					 | 
				
			||||||
     restarting) then use compression (e.g. SSL with compression) later.
 | 
					 | 
				
			||||||
     This results in significant per-connection memory leaks and
 | 
					 | 
				
			||||||
     has caused some security issues including CVE-2008-1678 and
 | 
					 | 
				
			||||||
     CVE-2009-4355.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Constify crypto/cast (i.e., <openssl/cast.h>): a CAST_KEY doesn't
 | 
					 | 
				
			||||||
     change when encrypting or decrypting.
 | 
					 | 
				
			||||||
     [Bodo Moeller]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add option SSL_OP_LEGACY_SERVER_CONNECT which will allow clients to
 | 
					 | 
				
			||||||
     connect and renegotiate with servers which do not support RI.
 | 
					 | 
				
			||||||
     Until RI is more widely deployed this option is enabled by default.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add "missing" ssl ctrls to clear options and mode.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) If client attempts to renegotiate and doesn't support RI respond with
 | 
					 | 
				
			||||||
     a no_renegotiation alert as required by RFC5746.  Some renegotiating
 | 
					 | 
				
			||||||
     TLS clients will continue a connection gracefully when they receive
 | 
					 | 
				
			||||||
     the alert. Unfortunately OpenSSL mishandled this alert and would hang
 | 
					 | 
				
			||||||
     waiting for a server hello which it will never receive. Now we treat a
 | 
					 | 
				
			||||||
     received no_renegotiation alert as a fatal error. This is because
 | 
					 | 
				
			||||||
     applications requesting a renegotiation might well expect it to succeed
 | 
					 | 
				
			||||||
     and would have no code in place to handle the server denying it so the
 | 
					 | 
				
			||||||
     only safe thing to do is to terminate the connection.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add ctrl macro SSL_get_secure_renegotiation_support() which returns 1 if
 | 
					 | 
				
			||||||
     peer supports secure renegotiation and 0 otherwise. Print out peer
 | 
					 | 
				
			||||||
     renegotiation support in s_client/s_server.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Replace the highly broken and deprecated SPKAC certification method with
 | 
					 | 
				
			||||||
     the updated NID creation version. This should correctly handle UTF8.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Implement RFC5746. Re-enable renegotiation but require the extension
 | 
					 | 
				
			||||||
     as needed. Unfortunately, SSL3_FLAGS_ALLOW_UNSAFE_LEGACY_RENEGOTIATION
 | 
					 | 
				
			||||||
     turns out to be a bad idea. It has been replaced by
 | 
					 | 
				
			||||||
     SSL_OP_ALLOW_UNSAFE_LEGACY_RENEGOTIATION which can be set with
 | 
					 | 
				
			||||||
     SSL_CTX_set_options(). This is really not recommended unless you
 | 
					 | 
				
			||||||
     know what you are doing.
 | 
					 | 
				
			||||||
     [Eric Rescorla <ekr@networkresonance.com>, Ben Laurie, Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Fixes to stateless session resumption handling. Use initial_ctx when
 | 
					 | 
				
			||||||
     issuing and attempting to decrypt tickets in case it has changed during
 | 
					 | 
				
			||||||
     servername handling. Use a non-zero length session ID when attempting
 | 
					 | 
				
			||||||
     stateless session resumption: this makes it possible to determine if
 | 
					 | 
				
			||||||
     a resumption has occurred immediately after receiving server hello
 | 
					 | 
				
			||||||
     (several places in OpenSSL subtly assume this) instead of later in
 | 
					 | 
				
			||||||
     the handshake.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) The functions ENGINE_ctrl(), OPENSSL_isservice(),
 | 
					 | 
				
			||||||
     CMS_get1_RecipientRequest() and RAND_bytes() can return <=0 on error
 | 
					 | 
				
			||||||
     fixes for a few places where the return code is not checked
 | 
					 | 
				
			||||||
     correctly.
 | 
					 | 
				
			||||||
     [Julia Lawall <julia@diku.dk>]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add --strict-warnings option to Configure script to include devteam
 | 
					 | 
				
			||||||
     warnings in other configurations.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add support for --libdir option and LIBDIR variable in makefiles. This
 | 
					 | 
				
			||||||
     makes it possible to install openssl libraries in locations which
 | 
					 | 
				
			||||||
     have names other than "lib", for example "/usr/lib64" which some
 | 
					 | 
				
			||||||
     systems need.
 | 
					 | 
				
			||||||
     [Steve Henson, based on patch from Jeremy Utley]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Don't allow the use of leading 0x80 in OIDs. This is a violation of
 | 
					 | 
				
			||||||
     X690 8.9.12 and can produce some misleading textual output of OIDs.
 | 
					 | 
				
			||||||
     [Steve Henson, reported by Dan Kaminsky]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Delete MD2 from algorithm tables. This follows the recommendation in
 | 
					 | 
				
			||||||
     several standards that it is not used in new applications due to
 | 
					 | 
				
			||||||
     several cryptographic weaknesses. For binary compatibility reasons
 | 
					 | 
				
			||||||
     the MD2 API is still compiled in by default.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Add compression id to {d2i,i2d}_SSL_SESSION so it is correctly saved
 | 
					 | 
				
			||||||
     and restored.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Rename uni2asc and asc2uni functions to OPENSSL_uni2asc and
 | 
					 | 
				
			||||||
     OPENSSL_asc2uni conditionally on Netware platforms to avoid a name
 | 
					 | 
				
			||||||
     clash.
 | 
					 | 
				
			||||||
     [Guenter <lists@gknw.net>]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Fix the server certificate chain building code to use X509_verify_cert(),
 | 
					 | 
				
			||||||
     it used to have an ad-hoc builder which was unable to cope with anything
 | 
					 | 
				
			||||||
     other than a simple chain.
 | 
					 | 
				
			||||||
     [David Woodhouse <dwmw2@infradead.org>, Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Don't check self signed certificate signatures in X509_verify_cert()
 | 
					 | 
				
			||||||
     by default (a flag can override this): it just wastes time without
 | 
					 | 
				
			||||||
     adding any security. As a useful side effect self signed root CAs
 | 
					 | 
				
			||||||
     with non-FIPS digests are now usable in FIPS mode.
 | 
					 | 
				
			||||||
     [Steve Henson]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) In dtls1_process_out_of_seq_message() the check if the current message
 | 
					 | 
				
			||||||
     is already buffered was missing. For every new message was memory
 | 
					 | 
				
			||||||
     allocated, allowing an attacker to perform an denial of service attack
 | 
					 | 
				
			||||||
     with sending out of seq handshake messages until there is no memory
 | 
					 | 
				
			||||||
     left. Additionally every future messege was buffered, even if the
 | 
					 | 
				
			||||||
     sequence number made no sense and would be part of another handshake.
 | 
					 | 
				
			||||||
     So only messages with sequence numbers less than 10 in advance will be
 | 
					 | 
				
			||||||
     buffered.  (CVE-2009-1378)
 | 
					 | 
				
			||||||
     [Robin Seggelmann, discovered by Daniel Mentz] 	
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Records are buffered if they arrive with a future epoch to be
 | 
					 | 
				
			||||||
     processed after finishing the corresponding handshake. There is
 | 
					 | 
				
			||||||
     currently no limitation to this buffer allowing an attacker to perform
 | 
					 | 
				
			||||||
     a DOS attack with sending records with future epochs until there is no
 | 
					 | 
				
			||||||
     memory left. This patch adds the pqueue_size() function to detemine
 | 
					 | 
				
			||||||
     the size of a buffer and limits the record buffer to 100 entries.
 | 
					 | 
				
			||||||
     (CVE-2009-1377)
 | 
					 | 
				
			||||||
     [Robin Seggelmann, discovered by Daniel Mentz] 	
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Keep a copy of frag->msg_header.frag_len so it can be used after the
 | 
					 | 
				
			||||||
     parent structure is freed.  (CVE-2009-1379)
 | 
					 | 
				
			||||||
     [Daniel Mentz] 	
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Handle non-blocking I/O properly in SSL_shutdown() call.
 | 
					 | 
				
			||||||
     [Darryl Miles <darryl-mailinglists@netbauds.net>]
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
  *) Add 2.5.4.* OIDs
 | 
					  *) Add 2.5.4.* OIDs
 | 
				
			||||||
     [Ilya O. <vrghost@gmail.com>]
 | 
					     [Ilya O. <vrghost@gmail.com>]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 Changes between 0.9.8k and 0.9.8l  [5 Nov 2009]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Disable renegotiation completely - this fixes a severe security
 | 
					 | 
				
			||||||
     problem (CVE-2009-3555) at the cost of breaking all
 | 
					 | 
				
			||||||
     renegotiation. Renegotiation can be re-enabled by setting
 | 
					 | 
				
			||||||
     SSL3_FLAGS_ALLOW_UNSAFE_LEGACY_RENEGOTIATION in s3->flags at
 | 
					 | 
				
			||||||
     run-time. This is really not recommended unless you know what
 | 
					 | 
				
			||||||
     you're doing.
 | 
					 | 
				
			||||||
     [Ben Laurie]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 Changes between 0.9.8j and 0.9.8k  [25 Mar 2009]
 | 
					 Changes between 0.9.8j and 0.9.8k  [25 Mar 2009]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  *) Don't set val to NULL when freeing up structures, it is freed up by
 | 
					  *) Don't set val to NULL when freeing up structures, it is freed up by
 | 
				
			||||||
@@ -1715,12 +806,12 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
  *) Support NumericString type for name components.
 | 
					  *) Support NumericString type for name components.
 | 
				
			||||||
     [Steve Henson]
 | 
					     [Steve Henson]
 | 
				
			||||||
 | 
					  
 | 
				
			||||||
  *) Allow CC in the environment to override the automatically chosen
 | 
					  *) Allow CC in the environment to override the automatically chosen
 | 
				
			||||||
     compiler. Note that nothing is done to ensure flags work with the
 | 
					     compiler. Note that nothing is done to ensure flags work with the
 | 
				
			||||||
     chosen compiler.
 | 
					     chosen compiler.
 | 
				
			||||||
     [Ben Laurie]
 | 
					     [Ben Laurie]
 | 
				
			||||||
 | 
					  
 | 
				
			||||||
 Changes between 0.9.8i and 0.9.8j  [07 Jan 2009]
 | 
					 Changes between 0.9.8i and 0.9.8j  [07 Jan 2009]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  *) Properly check EVP_VerifyFinal() and similar return values
 | 
					  *) Properly check EVP_VerifyFinal() and similar return values
 | 
				
			||||||
@@ -1761,10 +852,6 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
 Changes between 0.9.8h and 0.9.8i  [15 Sep 2008]
 | 
					 Changes between 0.9.8h and 0.9.8i  [15 Sep 2008]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  *) Fix NULL pointer dereference if a DTLS server received
 | 
					 | 
				
			||||||
     ChangeCipherSpec as first record (CVE-2009-1386).
 | 
					 | 
				
			||||||
     [PR #1679]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  *) Fix a state transitition in s3_srvr.c and d1_srvr.c
 | 
					  *) Fix a state transitition in s3_srvr.c and d1_srvr.c
 | 
				
			||||||
     (was using SSL3_ST_CW_CLNT_HELLO_B, should be ..._ST_SW_SRVR_...).
 | 
					     (was using SSL3_ST_CW_CLNT_HELLO_B, should be ..._ST_SW_SRVR_...).
 | 
				
			||||||
     [Nagendra Modadugu]
 | 
					     [Nagendra Modadugu]
 | 
				
			||||||
@@ -3168,6 +2255,19 @@
 | 
				
			|||||||
     differing sizes.
 | 
					     differing sizes.
 | 
				
			||||||
     [Richard Levitte]
 | 
					     [Richard Levitte]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 Changes between 0.9.7m and 0.9.7n  [xx XXX xxxx]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  *) In the SSL/TLS server implementation, be strict about session ID
 | 
				
			||||||
 | 
					     context matching (which matters if an application uses a single
 | 
				
			||||||
 | 
					     external cache for different purposes).  Previously,
 | 
				
			||||||
 | 
					     out-of-context reuse was forbidden only if SSL_VERIFY_PEER was
 | 
				
			||||||
 | 
					     set.  This did ensure strict client verification, but meant that,
 | 
				
			||||||
 | 
					     with applications using a single external cache for quite
 | 
				
			||||||
 | 
					     different requirements, clients could circumvent ciphersuite
 | 
				
			||||||
 | 
					     restrictions for a given session ID context by starting a session
 | 
				
			||||||
 | 
					     in a different context.
 | 
				
			||||||
 | 
					     [Bodo Moeller]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 Changes between 0.9.7l and 0.9.7m  [23 Feb 2007]
 | 
					 Changes between 0.9.7l and 0.9.7m  [23 Feb 2007]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  *) Cleanse PEM buffers before freeing them since they may contain 
 | 
					  *) Cleanse PEM buffers before freeing them since they may contain 
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -148,7 +148,7 @@ eric (about to go bushwalking for the 4 day easter break :-)
 | 
				
			|||||||
      This would tend to cause memory overwrites since SSLv3 has
 | 
					      This would tend to cause memory overwrites since SSLv3 has
 | 
				
			||||||
      a maximum packet size of 16k.  If your program uses
 | 
					      a maximum packet size of 16k.  If your program uses
 | 
				
			||||||
      buffers <= 16k, you would probably never see this problem.
 | 
					      buffers <= 16k, you would probably never see this problem.
 | 
				
			||||||
    - Fixed a few errors that were cause by malloc() not returning
 | 
					    - Fixed a new errors that were cause by malloc() not returning
 | 
				
			||||||
      0 initialised memory..
 | 
					      0 initialised memory..
 | 
				
			||||||
    - SSL_OP_NETSCAPE_CA_DN_BUG was being switched on when using
 | 
					    - SSL_OP_NETSCAPE_CA_DN_BUG was being switched on when using
 | 
				
			||||||
      SSL_CTX_set_options(ssl_ctx,SSL_OP_ALL); which was a bad thing
 | 
					      SSL_CTX_set_options(ssl_ctx,SSL_OP_ALL); which was a bad thing
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										470
									
								
								Configure
									
									
									
									
									
								
							
							
						
						
									
										470
									
								
								Configure
									
									
									
									
									
								
							@@ -104,8 +104,6 @@ my $usage="Usage: Configure [no-<cipher> ...] [enable-<cipher> ...] [experimenta
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
my $gcc_devteam_warn = "-Wall -pedantic -DPEDANTIC -Wno-long-long -Wsign-compare -Wmissing-prototypes -Wshadow -Wformat -Werror -DCRYPTO_MDEBUG_ALL -DCRYPTO_MDEBUG_ABORT -DREF_CHECK -DOPENSSL_NO_DEPRECATED";
 | 
					my $gcc_devteam_warn = "-Wall -pedantic -DPEDANTIC -Wno-long-long -Wsign-compare -Wmissing-prototypes -Wshadow -Wformat -Werror -DCRYPTO_MDEBUG_ALL -DCRYPTO_MDEBUG_ABORT -DREF_CHECK -DOPENSSL_NO_DEPRECATED";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
my $strict_warnings = 0;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
my $x86_gcc_des="DES_PTR DES_RISC1 DES_UNROLL";
 | 
					my $x86_gcc_des="DES_PTR DES_RISC1 DES_UNROLL";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# MD2_CHAR slags pentium pros
 | 
					# MD2_CHAR slags pentium pros
 | 
				
			||||||
@@ -123,24 +121,21 @@ my $tlib="-lnsl -lsocket";
 | 
				
			|||||||
my $bits1="THIRTY_TWO_BIT ";
 | 
					my $bits1="THIRTY_TWO_BIT ";
 | 
				
			||||||
my $bits2="SIXTY_FOUR_BIT ";
 | 
					my $bits2="SIXTY_FOUR_BIT ";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
my $x86_asm="x86cpuid.o:bn-586.o co-586.o x86-mont.o x86-gf2m.o:des-586.o crypt586.o:aes-586.o vpaes-x86.o aesni-x86.o:bf-586.o:md5-586.o:sha1-586.o sha256-586.o sha512-586.o:cast-586.o:rc4-586.o:rmd-586.o:rc5-586.o:wp_block.o wp-mmx.o:cmll-x86.o:ghash-x86.o:e_padlock-x86.o";
 | 
					my $x86_asm="x86cpuid.o:bn-586.o co-586.o x86-mont.o:des-586.o crypt586.o:aes-586.o:bf-586.o:md5-586.o:sha1-586.o sha256-586.o sha512-586.o:cast-586.o:rc4-586.o:rmd-586.o:rc5-586.o:wp_block.o wp-mmx.o:cmll-x86.o";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
my $x86_elf_asm="$x86_asm:elf";
 | 
					my $x86_elf_asm="$x86_asm:elf";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
my $x86_64_asm="x86_64cpuid.o:x86_64-gcc.o x86_64-mont.o x86_64-mont5.o x86_64-gf2m.o modexp512-x86_64.o::aes-x86_64.o vpaes-x86_64.o bsaes-x86_64.o aesni-x86_64.o aesni-sha1-x86_64.o::md5-x86_64.o:sha1-x86_64.o sha256-x86_64.o sha512-x86_64.o::rc4-x86_64.o rc4-md5-x86_64.o:::wp-x86_64.o:cmll-x86_64.o cmll_misc.o:ghash-x86_64.o:e_padlock-x86_64.o";
 | 
					my $x86_64_asm="x86_64cpuid.o:x86_64-gcc.o x86_64-mont.o::aes-x86_64.o::md5-x86_64.o:sha1-x86_64.o sha256-x86_64.o sha512-x86_64.o::rc4-x86_64.o:::wp-x86_64.o:cmll-x86_64.o cmll_misc.o";
 | 
				
			||||||
my $ia64_asm="ia64cpuid.o:bn-ia64.o ia64-mont.o::aes_core.o aes_cbc.o aes-ia64.o::md5-ia64.o:sha1-ia64.o sha256-ia64.o sha512-ia64.o::rc4-ia64.o rc4_skey.o:::::ghash-ia64.o::void";
 | 
					my $ia64_asm="ia64cpuid.o:bn-ia64.o::aes_core.o aes_cbc.o aes-ia64.o::md5-ia64.o:sha1-ia64.o sha256-ia64.o sha512-ia64.o::rc4-ia64.o rc4_skey.o:::::void";
 | 
				
			||||||
my $sparcv9_asm="sparcv9cap.o sparccpuid.o:bn-sparcv9.o sparcv9-mont.o sparcv9a-mont.o:des_enc-sparc.o fcrypt_b.o:aes_core.o aes_cbc.o aes-sparcv9.o:::sha1-sparcv9.o sha256-sparcv9.o sha512-sparcv9.o:::::::ghash-sparcv9.o::void";
 | 
					my $sparcv9_asm="sparcv9cap.o sparccpuid.o:bn-sparcv9.o sparcv9-mont.o sparcv9a-mont.o:des_enc-sparc.o fcrypt_b.o:aes_core.o aes_cbc.o aes-sparcv9.o:::sha1-sparcv9.o sha256-sparcv9.o sha512-sparcv9.o:::::::void";
 | 
				
			||||||
my $sparcv8_asm=":sparcv8.o:des_enc-sparc.o fcrypt_b.o:::::::::::::void";
 | 
					my $sparcv8_asm=":sparcv8.o:des_enc-sparc.o fcrypt_b.o:::::::::::void";
 | 
				
			||||||
my $alpha_asm="alphacpuid.o:bn_asm.o alpha-mont.o:::::sha1-alpha.o:::::::ghash-alpha.o::void";
 | 
					my $alpha_asm="alphacpuid.o:bn_asm.o alpha-mont.o::::::::::::void";
 | 
				
			||||||
my $mips32_asm=":bn-mips.o::aes_cbc.o aes-mips.o:::sha1-mips.o sha256-mips.o::::::::";
 | 
					my $mips3_asm=":bn-mips3.o::::::::::::void";
 | 
				
			||||||
my $mips64_asm=":bn-mips.o mips-mont.o::aes_cbc.o aes-mips.o:::sha1-mips.o sha256-mips.o sha512-mips.o::::::::";
 | 
					my $s390x_asm="s390xcpuid.o:bn-s390x.o s390x-mont.o::aes-s390x.o:::sha1-s390x.o sha256-s390x.o sha512-s390x.o::rc4-s390x.o:::::void";
 | 
				
			||||||
my $s390x_asm="s390xcap.o s390xcpuid.o:bn-s390x.o s390x-mont.o s390x-gf2m.o::aes_ctr.o aes-s390x.o:::sha1-s390x.o sha256-s390x.o sha512-s390x.o::rc4-s390x.o:::::ghash-s390x.o:";
 | 
					my $armv4_asm=":bn_asm.o armv4-mont.o::aes_cbc.o aes-armv4.o:::sha1-armv4-large.o sha256-armv4.o sha512-armv4.o:::::::void";
 | 
				
			||||||
my $armv4_asm="armcap.o armv4cpuid.o:bn_asm.o armv4-mont.o armv4-gf2m.o::aes_cbc.o aes-armv4.o:::sha1-armv4-large.o sha256-armv4.o sha512-armv4.o:::::::ghash-armv4.o::void";
 | 
					my $ppc32_asm="ppccpuid.o:bn-ppc.o::aes_core.o aes_cbc.o aes-ppc.o:::sha1-ppc.o sha256-ppc.o::::::";
 | 
				
			||||||
my $parisc11_asm="pariscid.o:bn_asm.o parisc-mont.o::aes_core.o aes_cbc.o aes-parisc.o:::sha1-parisc.o sha256-parisc.o sha512-parisc.o::rc4-parisc.o:::::ghash-parisc.o::32";
 | 
					my $ppc64_asm="ppccpuid.o:bn-ppc.o ppc-mont.o::aes_core.o aes_cbc.o aes-ppc.o:::sha1-ppc.o sha256-ppc.o sha512-ppc.o::::::";
 | 
				
			||||||
my $parisc20_asm="pariscid.o:pa-risc2W.o parisc-mont.o::aes_core.o aes_cbc.o aes-parisc.o:::sha1-parisc.o sha256-parisc.o sha512-parisc.o::rc4-parisc.o:::::ghash-parisc.o::64";
 | 
					my $no_asm=":::::::::::::void";
 | 
				
			||||||
my $ppc32_asm="ppccpuid.o ppccap.o:bn-ppc.o ppc-mont.o ppc64-mont.o::aes_core.o aes_cbc.o aes-ppc.o:::sha1-ppc.o sha256-ppc.o::::::::";
 | 
					 | 
				
			||||||
my $ppc64_asm="ppccpuid.o ppccap.o:bn-ppc.o ppc-mont.o ppc64-mont.o::aes_core.o aes_cbc.o aes-ppc.o:::sha1-ppc.o sha256-ppc.o sha512-ppc.o::::::::";
 | 
					 | 
				
			||||||
my $no_asm=":::::::::::::::void";
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
# As for $BSDthreads. Idea is to maintain "collective" set of flags,
 | 
					# As for $BSDthreads. Idea is to maintain "collective" set of flags,
 | 
				
			||||||
# which would cover all BSD flavors. -pthread applies to them all, 
 | 
					# which would cover all BSD flavors. -pthread applies to them all, 
 | 
				
			||||||
@@ -151,7 +146,7 @@ my $no_asm=":::::::::::::::void";
 | 
				
			|||||||
# seems to be sufficient?
 | 
					# seems to be sufficient?
 | 
				
			||||||
my $BSDthreads="-pthread -D_THREAD_SAFE -D_REENTRANT";
 | 
					my $BSDthreads="-pthread -D_THREAD_SAFE -D_REENTRANT";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#config-string	$cc : $cflags : $unistd : $thread_cflag : $sys_id : $lflags : $bn_ops : $cpuid_obj : $bn_obj : $des_obj : $aes_obj : $bf_obj : $md5_obj : $sha1_obj : $cast_obj : $rc4_obj : $rmd160_obj : $rc5_obj : $wp_obj : $cmll_obj : $modes_obj : $engines_obj : $dso_scheme : $shared_target : $shared_cflag : $shared_ldflag : $shared_extension : $ranlib : $arflags : $multilib
 | 
					#config-string	$cc : $cflags : $unistd : $thread_cflag : $sys_id : $lflags : $bn_ops : $cpuid_obj : $bn_obj : $des_obj : $aes_obj : $bf_obj : $md5_obj : $sha1_obj : $cast_obj : $rc4_obj : $rmd160_obj : $rc5_obj : $wp_obj : $cmll_obj : $dso_scheme : $shared_target : $shared_cflag : $shared_ldflag : $shared_extension : $ranlib : $arflags : $multilib
 | 
				
			||||||
 | 
					
 | 
				
			||||||
my %table=(
 | 
					my %table=(
 | 
				
			||||||
# File 'TABLE' (created by 'make TABLE') contains the data from this list,
 | 
					# File 'TABLE' (created by 'make TABLE') contains the data from this list,
 | 
				
			||||||
@@ -166,32 +161,29 @@ my %table=(
 | 
				
			|||||||
# Our development configs
 | 
					# Our development configs
 | 
				
			||||||
"purify",	"purify gcc:-g -DPURIFY -Wall::(unknown)::-lsocket -lnsl::::",
 | 
					"purify",	"purify gcc:-g -DPURIFY -Wall::(unknown)::-lsocket -lnsl::::",
 | 
				
			||||||
"debug",	"gcc:-DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_CTX_DEBUG -DCRYPTO_MDEBUG -DOPENSSL_NO_ASM -ggdb -g2 -Wformat -Wshadow -Wmissing-prototypes -Wmissing-declarations -Werror::(unknown)::-lefence::::",
 | 
					"debug",	"gcc:-DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_CTX_DEBUG -DCRYPTO_MDEBUG -DOPENSSL_NO_ASM -ggdb -g2 -Wformat -Wshadow -Wmissing-prototypes -Wmissing-declarations -Werror::(unknown)::-lefence::::",
 | 
				
			||||||
"debug-ben",	"gcc:$gcc_devteam_warn -DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_CTX_DEBUG -DCRYPTO_MDEBUG -DDEBUG_SAFESTACK -O2 -pipe::(unknown):::::",
 | 
					"debug-ben",	"gcc:-DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_CTX_DEBUG -DCRYPTO_MDEBUG -DPEDANTIC -DDEBUG_SAFESTACK -O2 -pedantic -Wall -Wshadow -Werror -pipe::(unknown):::::bn86-elf.o co86-elf.o",
 | 
				
			||||||
"debug-ben-openbsd","gcc:-DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_CTX_DEBUG -DCRYPTO_MDEBUG -DPEDANTIC -DDEBUG_SAFESTACK -DOPENSSL_OPENBSD_DEV_CRYPTO -DOPENSSL_NO_ASM -O2 -pedantic -Wall -Wshadow -Werror -pipe::(unknown)::::",
 | 
					"debug-ben-openbsd","gcc:-DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_CTX_DEBUG -DCRYPTO_MDEBUG -DPEDANTIC -DDEBUG_SAFESTACK -DOPENSSL_OPENBSD_DEV_CRYPTO -DOPENSSL_NO_ASM -O2 -pedantic -Wall -Wshadow -Werror -pipe::(unknown)::::",
 | 
				
			||||||
"debug-ben-openbsd-debug","gcc:-DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_CTX_DEBUG -DCRYPTO_MDEBUG -DPEDANTIC -DDEBUG_SAFESTACK -DOPENSSL_OPENBSD_DEV_CRYPTO -DOPENSSL_NO_ASM -g3 -O2 -pedantic -Wall -Wshadow -Werror -pipe::(unknown)::::",
 | 
					"debug-ben-openbsd-debug","gcc:-DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_CTX_DEBUG -DCRYPTO_MDEBUG -DPEDANTIC -DDEBUG_SAFESTACK -DOPENSSL_OPENBSD_DEV_CRYPTO -DOPENSSL_NO_ASM -g3 -O2 -pedantic -Wall -Wshadow -Werror -pipe::(unknown)::::",
 | 
				
			||||||
"debug-ben-debug",	"gcc:$gcc_devteam_warn -DBN_DEBUG -DCONF_DEBUG -DDEBUG_SAFESTACK -g3 -O2 -pipe::(unknown)::::::",
 | 
					"debug-ben-debug",	"gcc:$gcc_devteam_warn -DBN_DEBUG -DCONF_DEBUG -DBN_CTX_DEBUG -DDEBUG_SAFESTACK -g3 -O2 -pipe::(unknown)::::::",
 | 
				
			||||||
"debug-ben-no-opt",	"gcc: -Wall -Wmissing-prototypes -Wstrict-prototypes -Wmissing-declarations -DDEBUG_SAFESTACK -DCRYPTO_MDEBUG -Werror -DL_ENDIAN -DTERMIOS -Wall -g3::(unknown)::::::",
 | 
					"debug-ben-no-opt",	"gcc: -Wall -Wmissing-prototypes -Wstrict-prototypes -Wmissing-declarations -DDEBUG_SAFESTACK -DCRYPTO_MDEBUG -Werror -DL_ENDIAN -DTERMIOS -Wall -g3::(unknown)::::::",
 | 
				
			||||||
"debug-ben-strict",	"gcc:-DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_CTX_DEBUG -DCRYPTO_MDEBUG -DCONST_STRICT -O2 -Wall -Wshadow -Werror -Wpointer-arith -Wcast-qual -Wwrite-strings -pipe::(unknown)::::::",
 | 
					"debug-ben-strict",	"gcc:-DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_CTX_DEBUG -DCRYPTO_MDEBUG -DCONST_STRICT -O2 -Wall -Wshadow -Werror -Wpointer-arith -Wcast-qual -Wwrite-strings -pipe::(unknown)::::::",
 | 
				
			||||||
"debug-rse","cc:-DTERMIOS -DL_ENDIAN -pipe -O -g -ggdb3 -Wall::(unknown):::BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}",
 | 
					"debug-rse","cc:-DTERMIOS -DL_ENDIAN -pipe -O -g -ggdb3 -Wall::(unknown):::BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}",
 | 
				
			||||||
"debug-bodo",	"gcc:$gcc_devteam_warn -DBN_DEBUG -DBN_DEBUG_RAND -DCONF_DEBUG -DBIO_PAIR_DEBUG -m64 -DL_ENDIAN -DTERMIO -g -DMD32_REG_T=int::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_INT DES_UNROLL:${x86_64_asm}:elf:dlfcn:linux-shared:-fPIC:-m64:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::64",
 | 
					"debug-bodo",	"gcc:-DL_ENDIAN -DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DBIO_PAIR_DEBUG -DPEDANTIC -g -march=i486 -pedantic -Wshadow -Wall -Wcast-align -Wstrict-prototypes -Wmissing-prototypes -Wno-long-long -Wundef -Wconversion::-D_REENTRANT:::BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}",
 | 
				
			||||||
"debug-ulf", "gcc:-DTERMIOS -DL_ENDIAN -march=i486 -Wall -DBN_DEBUG -DBN_DEBUG_RAND -DREF_CHECK -DCONF_DEBUG -DBN_CTX_DEBUG -DCRYPTO_MDEBUG -DOPENSSL_NO_ASM -g -Wformat -Wshadow -Wmissing-prototypes -Wmissing-declarations:::CYGWIN32:::${no_asm}:win32:cygwin-shared:::.dll",
 | 
					"debug-ulf", "gcc:-DTERMIOS -DL_ENDIAN -march=i486 -Wall -DBN_DEBUG -DBN_DEBUG_RAND -DREF_CHECK -DCONF_DEBUG -DBN_CTX_DEBUG -DCRYPTO_MDEBUG -DOPENSSL_NO_ASM -g -Wformat -Wshadow -Wmissing-prototypes -Wmissing-declarations:::CYGWIN32:::${no_asm}:win32:cygwin-shared:::.dll",
 | 
				
			||||||
"debug-steve64", "gcc:$gcc_devteam_warn -m64 -DL_ENDIAN -DTERMIO -DCONF_DEBUG -DDEBUG_SAFESTACK -g::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_INT DES_UNROLL:${x86_64_asm}:elf:dlfcn:linux-shared:-fPIC:-m64:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"debug-steve64", "gcc:$gcc_devteam_warn -m64 -DL_ENDIAN -DTERMIO -DCONF_DEBUG -DDEBUG_SAFESTACK -g -DMD32_REG_T=int::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG RC4_CHUNK BF_PTR2 DES_INT DES_UNROLL:${x86_64_asm}:elf:dlfcn:linux-shared:-fPIC:-m64:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
"debug-steve32", "gcc:$gcc_devteam_warn -m32 -DL_ENDIAN -DCONF_DEBUG -DDEBUG_SAFESTACK -g -pipe::-D_REENTRANT::-rdynamic -ldl:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}:dlfcn:linux-shared:-fPIC:-m32:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"debug-steve32", "gcc:$gcc_devteam_warn -m32 -DL_ENDIAN -DCONF_DEBUG -DDEBUG_SAFESTACK -g -pipe::-D_REENTRANT::-rdynamic -ldl:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}:dlfcn:linux-shared:-fPIC:-m32:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
"debug-steve-opt", "gcc:$gcc_devteam_warn -m64 -O3 -DL_ENDIAN -DTERMIO -DCONF_DEBUG -DDEBUG_SAFESTACK -g::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_INT DES_UNROLL:${x86_64_asm}:elf:dlfcn:linux-shared:-fPIC:-m64:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"debug-steve-opt", "gcc:$gcc_devteam_warn -m64 -O3 -DL_ENDIAN -DTERMIO -DCONF_DEBUG -DDEBUG_SAFESTACK -g -DMD32_REG_T=int::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG RC4_CHUNK BF_PTR2 DES_INT DES_UNROLL:${x86_64_asm}:elf:dlfcn:linux-shared:-fPIC:-m64:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
"debug-levitte-linux-elf","gcc:-DLEVITTE_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_DEBUG -DBN_DEBUG_RAND -DCRYPTO_MDEBUG -DENGINE_CONF_DEBUG -DL_ENDIAN -DTERMIO -D_POSIX_SOURCE -DPEDANTIC -ggdb -g3 -mcpu=i486 -pedantic -ansi -Wall -Wshadow -Wcast-align -Wstrict-prototypes -Wmissing-prototypes -Wno-long-long -Wundef -Wconversion -pipe::-D_REENTRANT::-ldl:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"debug-levitte-linux-elf","gcc:-DLEVITTE_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_DEBUG -DBN_DEBUG_RAND -DCRYPTO_MDEBUG -DENGINE_CONF_DEBUG -DL_ENDIAN -DTERMIO -D_POSIX_SOURCE -DPEDANTIC -ggdb -g3 -mcpu=i486 -pedantic -ansi -Wall -Wshadow -Wcast-align -Wstrict-prototypes -Wmissing-prototypes -Wno-long-long -Wundef -Wconversion -pipe::-D_REENTRANT::-ldl:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
"debug-levitte-linux-noasm","gcc:-DLEVITTE_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_DEBUG -DBN_DEBUG_RAND -DCRYPTO_MDEBUG -DENGINE_CONF_DEBUG -DOPENSSL_NO_ASM -DL_ENDIAN -DTERMIO -D_POSIX_SOURCE -DPEDANTIC -ggdb -g3 -mcpu=i486 -pedantic -ansi -Wall -Wshadow -Wcast-align -Wstrict-prototypes -Wmissing-prototypes -Wno-long-long -Wundef -Wconversion -pipe::-D_REENTRANT::-ldl:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${no_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"debug-levitte-linux-noasm","gcc:-DLEVITTE_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_DEBUG -DBN_DEBUG_RAND -DCRYPTO_MDEBUG -DENGINE_CONF_DEBUG -DOPENSSL_NO_ASM -DL_ENDIAN -DTERMIO -D_POSIX_SOURCE -DPEDANTIC -ggdb -g3 -mcpu=i486 -pedantic -ansi -Wall -Wshadow -Wcast-align -Wstrict-prototypes -Wmissing-prototypes -Wno-long-long -Wundef -Wconversion -pipe::-D_REENTRANT::-ldl:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${no_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
"debug-levitte-linux-elf-extreme","gcc:-DLEVITTE_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_DEBUG -DBN_DEBUG_RAND -DCRYPTO_MDEBUG -DENGINE_CONF_DEBUG -DL_ENDIAN -DTERMIO -D_POSIX_SOURCE -DPEDANTIC -ggdb -g3 -mcpu=i486 -pedantic -ansi -Wall -W -Wundef -Wshadow -Wcast-align -Wstrict-prototypes -Wmissing-prototypes -Wno-long-long -Wundef -Wconversion -pipe::-D_REENTRANT::-ldl:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"debug-levitte-linux-elf-extreme","gcc:-DLEVITTE_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_DEBUG -DBN_DEBUG_RAND -DCRYPTO_MDEBUG -DENGINE_CONF_DEBUG -DL_ENDIAN -DTERMIO -D_POSIX_SOURCE -DPEDANTIC -ggdb -g3 -mcpu=i486 -pedantic -ansi -Wall -W -Wundef -Wshadow -Wcast-align -Wstrict-prototypes -Wmissing-prototypes -Wno-long-long -Wundef -Wconversion -pipe::-D_REENTRANT::-ldl:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
"debug-levitte-linux-noasm-extreme","gcc:-DLEVITTE_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_DEBUG -DBN_DEBUG_RAND -DCRYPTO_MDEBUG -DENGINE_CONF_DEBUG -DOPENSSL_NO_ASM -DL_ENDIAN -DTERMIO -D_POSIX_SOURCE -DPEDANTIC -ggdb -g3 -mcpu=i486 -pedantic -ansi -Wall -W -Wundef -Wshadow -Wcast-align -Wstrict-prototypes -Wmissing-prototypes -Wno-long-long -Wundef -Wconversion -pipe::-D_REENTRANT::-ldl:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${no_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"debug-levitte-linux-noasm-extreme","gcc:-DLEVITTE_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_DEBUG -DBN_DEBUG_RAND -DCRYPTO_MDEBUG -DENGINE_CONF_DEBUG -DOPENSSL_NO_ASM -DL_ENDIAN -DTERMIO -D_POSIX_SOURCE -DPEDANTIC -ggdb -g3 -mcpu=i486 -pedantic -ansi -Wall -W -Wundef -Wshadow -Wcast-align -Wstrict-prototypes -Wmissing-prototypes -Wno-long-long -Wundef -Wconversion -pipe::-D_REENTRANT::-ldl:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${no_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
"debug-geoff32","gcc:-DBN_DEBUG -DBN_DEBUG_RAND -DBN_STRICT -DPURIFY -DOPENSSL_NO_DEPRECATED -DOPENSSL_NO_ASM -DOPENSSL_NO_INLINE_ASM -DL_ENDIAN -DTERMIO -DPEDANTIC -O1 -ggdb2 -Wall -Werror -Wundef -pedantic -Wshadow -Wpointer-arith -Wbad-function-cast -Wcast-align -Wsign-compare -Wmissing-prototypes -Wmissing-declarations -Wno-long-long::-D_REENTRANT::-ldl:BN_LLONG:${no_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"debug-geoff32","gcc:-DBN_DEBUG -DBN_DEBUG_RAND -DBN_STRICT -DPURIFY -DOPENSSL_NO_DEPRECATED -DOPENSSL_NO_ASM -DOPENSSL_NO_INLINE_ASM -DL_ENDIAN -DTERMIO -DPEDANTIC -DMD32_REG_T=int -O1 -ggdb2 -Wall -Werror -Wundef -pedantic -Wshadow -Wpointer-arith -Wbad-function-cast -Wcast-align -Wsign-compare -Wmissing-prototypes -Wmissing-declarations -Wno-long-long::-D_REENTRANT::-ldl:BN_LLONG:${no_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
"debug-geoff64","gcc:-DBN_DEBUG -DBN_DEBUG_RAND -DBN_STRICT -DPURIFY -DOPENSSL_NO_DEPRECATED -DOPENSSL_NO_ASM -DOPENSSL_NO_INLINE_ASM -DL_ENDIAN -DTERMIO -DPEDANTIC -O1 -ggdb2 -Wall -Werror -Wundef -pedantic -Wshadow -Wpointer-arith -Wbad-function-cast -Wcast-align -Wsign-compare -Wmissing-prototypes -Wmissing-declarations -Wno-long-long::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG RC4_CHAR RC4_CHUNK DES_INT DES_UNROLL BF_PTR:${no_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"debug-geoff64","gcc:-DBN_DEBUG -DBN_DEBUG_RAND -DBN_STRICT -DPURIFY -DOPENSSL_NO_DEPRECATED -DOPENSSL_NO_ASM -DOPENSSL_NO_INLINE_ASM -DL_ENDIAN -DTERMIO -DPEDANTIC -DMD32_REG_T=int -O1 -ggdb2 -Wall -Werror -Wundef -pedantic -Wshadow -Wpointer-arith -Wbad-function-cast -Wcast-align -Wsign-compare -Wmissing-prototypes -Wmissing-declarations -Wno-long-long::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG RC4_CHAR RC4_CHUNK DES_INT DES_UNROLL BF_PTR:${no_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
"debug-linux-pentium","gcc:-DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_CTX_DEBUG -DCRYPTO_MDEBUG -DL_ENDIAN -DTERMIO -g -mcpu=pentium -Wall::-D_REENTRANT::-ldl:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}:dlfcn",
 | 
					"debug-linux-pentium","gcc:-DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_CTX_DEBUG -DCRYPTO_MDEBUG -DL_ENDIAN -DTERMIO -g -mcpu=pentium -Wall::-D_REENTRANT::-ldl:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}:dlfcn",
 | 
				
			||||||
"debug-linux-ppro","gcc:-DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_CTX_DEBUG -DCRYPTO_MDEBUG -DL_ENDIAN -DTERMIO -g -mcpu=pentiumpro -Wall::-D_REENTRANT::-ldl:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}:dlfcn",
 | 
					"debug-linux-ppro","gcc:-DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_CTX_DEBUG -DCRYPTO_MDEBUG -DL_ENDIAN -DTERMIO -g -mcpu=pentiumpro -Wall::-D_REENTRANT::-ldl:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}:dlfcn",
 | 
				
			||||||
"debug-linux-elf","gcc:-DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_CTX_DEBUG -DCRYPTO_MDEBUG -DL_ENDIAN -DTERMIO -g -march=i486 -Wall::-D_REENTRANT::-lefence -ldl:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"debug-linux-elf","gcc:-DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_CTX_DEBUG -DCRYPTO_MDEBUG -DL_ENDIAN -DTERMIO -g -march=i486 -Wall::-D_REENTRANT::-lefence -ldl:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
"debug-linux-elf-noefence","gcc:-DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_CTX_DEBUG -DCRYPTO_MDEBUG -DL_ENDIAN -DTERMIO -g -march=i486 -Wall::-D_REENTRANT::-ldl:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"debug-linux-elf-noefence","gcc:-DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_CTX_DEBUG -DCRYPTO_MDEBUG -DL_ENDIAN -DTERMIO -g -march=i486 -Wall::-D_REENTRANT::-ldl:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
"debug-linux-ia32-aes", "gcc:-DAES_EXPERIMENTAL -DL_ENDIAN -DTERMIO -O3 -fomit-frame-pointer -Wall::-D_REENTRANT::-ldl:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:x86cpuid.o:bn-586.o co-586.o x86-mont.o:des-586.o crypt586.o:aes_x86core.o aes_cbc.o aesni-x86.o:bf-586.o:md5-586.o:sha1-586.o sha256-586.o sha512-586.o:cast-586.o:rc4-586.o:rmd-586.o:rc5-586.o:wp_block.o wp-mmx.o::ghash-x86.o:e_padlock-x86.o:elf:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"debug-linux-ia32-aes", "gcc:-DAES_EXPERIMENTAL -DL_ENDIAN -DTERMIO -O3 -fomit-frame-pointer -Wall::-D_REENTRANT::-ldl:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:x86cpuid.o:bn-586.o co-586.o x86-mont.o:des-586.o crypt586.o:aes_x86core.o aes_cbc.o:bf-586.o:md5-586.o:sha1-586.o sha256-586.o sha512-586.o:cast-586.o:rc4-586.o:rmd-586.o:rc5-586.o:wp_block.o wp-mmx.o::elf:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
"debug-linux-generic32","gcc:-DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DCRYPTO_MDEBUG -DTERMIO -g -Wall::-D_REENTRANT::-ldl:BN_LLONG RC4_CHAR RC4_CHUNK DES_INT DES_UNROLL BF_PTR:${no_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					 | 
				
			||||||
"debug-linux-generic64","gcc:-DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DCRYPTO_MDEBUG -DTERMIO -g -Wall::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG RC4_CHAR RC4_CHUNK DES_INT DES_UNROLL BF_PTR:${no_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					 | 
				
			||||||
"debug-linux-x86_64","gcc:-DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DCRYPTO_MDEBUG -m64 -DL_ENDIAN -DTERMIO -g -Wall::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_INT DES_UNROLL:${x86_64_asm}:elf:dlfcn:linux-shared:-fPIC:-m64:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::64",
 | 
					 | 
				
			||||||
"dist",		"cc:-O::(unknown)::::::",
 | 
					"dist",		"cc:-O::(unknown)::::::",
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Basic configs that should work on any (32 and less bit) box
 | 
					# Basic configs that should work on any (32 and less bit) box
 | 
				
			||||||
@@ -199,8 +191,8 @@ my %table=(
 | 
				
			|||||||
"cc",		"cc:-O::(unknown)::::::",
 | 
					"cc",		"cc:-O::(unknown)::::::",
 | 
				
			||||||
 | 
					
 | 
				
			||||||
####VOS Configurations
 | 
					####VOS Configurations
 | 
				
			||||||
"vos-gcc","gcc:-O3 -Wall -D_POSIX_C_SOURCE=200112L -D_BSD -D_VOS_EXTENDED_NAMES -DB_ENDIAN::(unknown):VOS:-Wl,-map:BN_LLONG:${no_asm}:::::.so:",
 | 
					"vos-gcc","gcc:-O3 -Wall -D_POSIX_C_SOURCE=200112L -D_BSD -DB_ENDIAN::(unknown):VOS:-Wl,-map:BN_LLONG:${no_asm}:::::.so:",
 | 
				
			||||||
"debug-vos-gcc","gcc:-O0 -g -Wall -D_POSIX_C_SOURCE=200112L -D_BSD -D_VOS_EXTENDED_NAMES -DB_ENDIAN -DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DCRYPTO_MDEBUG::(unknown):VOS:-Wl,-map:BN_LLONG:${no_asm}:::::.so:",
 | 
					"debug-vos-gcc","gcc:-O0 -g -Wall -D_POSIX_C_SOURCE=200112L -D_BSD -DB_ENDIAN -DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DCRYPTO_MDEBUG::(unknown):VOS:-Wl,-map:BN_LLONG:${no_asm}:::::.so:",
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#### Solaris x86 with GNU C setups
 | 
					#### Solaris x86 with GNU C setups
 | 
				
			||||||
# -DOPENSSL_NO_INLINE_ASM switches off inline assembler. We have to do it
 | 
					# -DOPENSSL_NO_INLINE_ASM switches off inline assembler. We have to do it
 | 
				
			||||||
@@ -217,11 +209,11 @@ my %table=(
 | 
				
			|||||||
# actually recommend to consider using gcc shared build even with vendor
 | 
					# actually recommend to consider using gcc shared build even with vendor
 | 
				
			||||||
# compiler:-)
 | 
					# compiler:-)
 | 
				
			||||||
#						<appro@fy.chalmers.se>
 | 
					#						<appro@fy.chalmers.se>
 | 
				
			||||||
"solaris64-x86_64-gcc","gcc:-m64 -O3 -Wall -DL_ENDIAN::-D_REENTRANT::-lsocket -lnsl -ldl:SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_INT DES_UNROLL:${x86_64_asm}:elf:dlfcn:solaris-shared:-fPIC:-m64 -shared -static-libgcc:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::/64",
 | 
					"solaris64-x86_64-gcc","gcc:-m64 -O3 -Wall -DL_ENDIAN -DMD32_REG_T=int::-D_REENTRANT::-lsocket -lnsl -ldl:SIXTY_FOUR_BIT_LONG RC4_CHUNK BF_PTR2 DES_INT DES_UNROLL:${x86_64_asm}:elf:dlfcn:solaris-shared:-fPIC:-m64 -shared -static-libgcc:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::/64",
 | 
				
			||||||
 
 | 
					 
 | 
				
			||||||
#### Solaris x86 with Sun C setups
 | 
					#### Solaris x86 with Sun C setups
 | 
				
			||||||
"solaris-x86-cc","cc:-fast -O -Xa::-D_REENTRANT::-lsocket -lnsl -ldl:BN_LLONG RC4_CHAR RC4_CHUNK DES_PTR DES_UNROLL BF_PTR:${no_asm}:dlfcn:solaris-shared:-KPIC:-G -dy -z text:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"solaris-x86-cc","cc:-fast -O -Xa::-D_REENTRANT::-lsocket -lnsl -ldl:BN_LLONG RC4_CHAR RC4_CHUNK DES_PTR DES_UNROLL BF_PTR:${no_asm}:dlfcn:solaris-shared:-KPIC:-G -dy -z text:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
"solaris64-x86_64-cc","cc:-fast -xarch=amd64 -xstrconst -Xa -DL_ENDIAN::-D_REENTRANT::-lsocket -lnsl -ldl:SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_INT DES_UNROLL:${x86_64_asm}:elf:dlfcn:solaris-shared:-KPIC:-xarch=amd64 -G -dy -z text:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::/64",
 | 
					"solaris64-x86_64-cc","cc:-fast -xarch=amd64 -xstrconst -Xa -DL_ENDIAN::-D_REENTRANT::-lsocket -lnsl -ldl:SIXTY_FOUR_BIT_LONG RC4_CHUNK BF_PTR2 DES_INT DES_UNROLL:${x86_64_asm}:elf:dlfcn:solaris-shared:-KPIC:-xarch=amd64 -G -dy -z text:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::/64",
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#### SPARC Solaris with GNU C setups
 | 
					#### SPARC Solaris with GNU C setups
 | 
				
			||||||
"solaris-sparcv7-gcc","gcc:-O3 -fomit-frame-pointer -Wall -DB_ENDIAN -DBN_DIV2W::-D_REENTRANT::-lsocket -lnsl -ldl:BN_LLONG RC4_CHAR RC4_CHUNK DES_UNROLL BF_PTR:${no_asm}:dlfcn:solaris-shared:-fPIC:-shared:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"solaris-sparcv7-gcc","gcc:-O3 -fomit-frame-pointer -Wall -DB_ENDIAN -DBN_DIV2W::-D_REENTRANT::-lsocket -lnsl -ldl:BN_LLONG RC4_CHAR RC4_CHUNK DES_UNROLL BF_PTR:${no_asm}:dlfcn:solaris-shared:-fPIC:-shared:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
@@ -251,16 +243,16 @@ my %table=(
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
#### IRIX 5.x configs
 | 
					#### IRIX 5.x configs
 | 
				
			||||||
# -mips2 flag is added by ./config when appropriate.
 | 
					# -mips2 flag is added by ./config when appropriate.
 | 
				
			||||||
"irix-gcc","gcc:-O3 -DTERMIOS -DB_ENDIAN::(unknown):::BN_LLONG MD2_CHAR RC4_INDEX RC4_CHAR RC4_CHUNK DES_UNROLL DES_RISC2 DES_PTR BF_PTR:${mips32_asm}:o32:dlfcn:irix-shared:::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"irix-gcc","gcc:-O3 -DTERMIOS -DB_ENDIAN::(unknown):::BN_LLONG MD2_CHAR RC4_INDEX RC4_CHAR RC4_CHUNK DES_UNROLL DES_RISC2 DES_PTR BF_PTR:${no_asm}:dlfcn:irix-shared:::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
"irix-cc", "cc:-O2 -use_readonly_const -DTERMIOS -DB_ENDIAN::(unknown):::BN_LLONG RC4_CHAR RC4_CHUNK DES_PTR DES_RISC2 DES_UNROLL BF_PTR:${mips32_asm}:o32:dlfcn:irix-shared:::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"irix-cc", "cc:-O2 -use_readonly_const -DTERMIOS -DB_ENDIAN::(unknown):::BN_LLONG RC4_CHAR RC4_CHUNK DES_PTR DES_RISC2 DES_UNROLL BF_PTR:${no_asm}:dlfcn:irix-shared:::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
#### IRIX 6.x configs
 | 
					#### IRIX 6.x configs
 | 
				
			||||||
# Only N32 and N64 ABIs are supported. If you need O32 ABI build, invoke
 | 
					# Only N32 and N64 ABIs are supported. If you need O32 ABI build, invoke
 | 
				
			||||||
# './Configure irix-cc -o32' manually.
 | 
					# './Configure irix-cc -o32' manually.
 | 
				
			||||||
"irix-mips3-gcc","gcc:-mabi=n32 -O3 -DTERMIOS -DB_ENDIAN -DBN_DIV3W::-D_SGI_MP_SOURCE:::MD2_CHAR RC4_INDEX RC4_CHAR RC4_CHUNK_LL DES_UNROLL DES_RISC2 DES_PTR BF_PTR SIXTY_FOUR_BIT:${mips64_asm}:n32:dlfcn:irix-shared::-mabi=n32:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::32",
 | 
					"irix-mips3-gcc","gcc:-mabi=n32 -O3 -DTERMIOS -DB_ENDIAN -DBN_DIV3W::-D_SGI_MP_SOURCE:::MD2_CHAR RC4_INDEX RC4_CHAR RC4_CHUNK_LL DES_UNROLL DES_RISC2 DES_PTR BF_PTR SIXTY_FOUR_BIT:${mips3_asm}:dlfcn:irix-shared::-mabi=n32:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::32",
 | 
				
			||||||
"irix-mips3-cc", "cc:-n32 -mips3 -O2 -use_readonly_const -G0 -rdata_shared -DTERMIOS -DB_ENDIAN -DBN_DIV3W::-D_SGI_MP_SOURCE:::DES_PTR RC4_CHAR RC4_CHUNK_LL DES_RISC2 DES_UNROLL BF_PTR SIXTY_FOUR_BIT:${mips64_asm}:n32:dlfcn:irix-shared::-n32:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::32",
 | 
					"irix-mips3-cc", "cc:-n32 -mips3 -O2 -use_readonly_const -G0 -rdata_shared -DTERMIOS -DB_ENDIAN -DBN_DIV3W::-D_SGI_MP_SOURCE:::DES_PTR RC4_CHAR RC4_CHUNK_LL DES_RISC2 DES_UNROLL BF_PTR SIXTY_FOUR_BIT:${mips3_asm}:dlfcn:irix-shared::-n32:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::32",
 | 
				
			||||||
# N64 ABI builds.
 | 
					# N64 ABI builds.
 | 
				
			||||||
"irix64-mips4-gcc","gcc:-mabi=64 -mips4 -O3 -DTERMIOS -DB_ENDIAN -DBN_DIV3W::-D_SGI_MP_SOURCE:::RC4_CHAR RC4_CHUNK DES_RISC2 DES_UNROLL SIXTY_FOUR_BIT_LONG:${mips64_asm}:64:dlfcn:irix-shared::-mabi=64:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::64",
 | 
					"irix64-mips4-gcc","gcc:-mabi=64 -mips4 -O3 -DTERMIOS -DB_ENDIAN -DBN_DIV3W::-D_SGI_MP_SOURCE:::RC4_CHAR RC4_CHUNK DES_RISC2 DES_UNROLL SIXTY_FOUR_BIT_LONG:${mips3_asm}:dlfcn:irix-shared::-mabi=64:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::64",
 | 
				
			||||||
"irix64-mips4-cc", "cc:-64 -mips4 -O2 -use_readonly_const -G0 -rdata_shared -DTERMIOS -DB_ENDIAN -DBN_DIV3W::-D_SGI_MP_SOURCE:::RC4_CHAR RC4_CHUNK DES_RISC2 DES_UNROLL SIXTY_FOUR_BIT_LONG:${mips64_asm}:64:dlfcn:irix-shared::-64:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::64",
 | 
					"irix64-mips4-cc", "cc:-64 -mips4 -O2 -use_readonly_const -G0 -rdata_shared -DTERMIOS -DB_ENDIAN -DBN_DIV3W::-D_SGI_MP_SOURCE:::RC4_CHAR RC4_CHUNK DES_RISC2 DES_UNROLL SIXTY_FOUR_BIT_LONG:${mips3_asm}:dlfcn:irix-shared::-64:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::64",
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#### Unified HP-UX ANSI C configs.
 | 
					#### Unified HP-UX ANSI C configs.
 | 
				
			||||||
# Special notes:
 | 
					# Special notes:
 | 
				
			||||||
@@ -293,18 +285,17 @@ my %table=(
 | 
				
			|||||||
# Since there is mention of this in shlib/hpux10-cc.sh
 | 
					# Since there is mention of this in shlib/hpux10-cc.sh
 | 
				
			||||||
"hpux-parisc-cc-o4","cc:-Ae +O4 +ESlit -z -DB_ENDIAN -DBN_DIV2W -DMD32_XARRAY::-D_REENTRANT::-ldld:BN_LLONG DES_PTR DES_UNROLL DES_RISC1:${no_asm}:dl:hpux-shared:+Z:-b:.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"hpux-parisc-cc-o4","cc:-Ae +O4 +ESlit -z -DB_ENDIAN -DBN_DIV2W -DMD32_XARRAY::-D_REENTRANT::-ldld:BN_LLONG DES_PTR DES_UNROLL DES_RISC1:${no_asm}:dl:hpux-shared:+Z:-b:.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
"hpux-parisc-gcc","gcc:-O3 -DB_ENDIAN -DBN_DIV2W::-D_REENTRANT::-Wl,+s -ldld:BN_LLONG DES_PTR DES_UNROLL DES_RISC1:${no_asm}:dl:hpux-shared:-fPIC:-shared:.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"hpux-parisc-gcc","gcc:-O3 -DB_ENDIAN -DBN_DIV2W::-D_REENTRANT::-Wl,+s -ldld:BN_LLONG DES_PTR DES_UNROLL DES_RISC1:${no_asm}:dl:hpux-shared:-fPIC:-shared:.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
"hpux-parisc1_1-gcc","gcc:-O3 -DB_ENDIAN -DBN_DIV2W::-D_REENTRANT::-Wl,+s -ldld:BN_LLONG DES_PTR DES_UNROLL DES_RISC1:${parisc11_asm}:dl:hpux-shared:-fPIC:-shared:.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"hpux-parisc2-gcc","gcc:-march=2.0 -O3 -DB_ENDIAN -D_REENTRANT::::-Wl,+s -ldld:SIXTY_FOUR_BIT RC4_CHAR RC4_CHUNK DES_PTR DES_UNROLL DES_RISC1::pa-risc2.o::::::::::::void:dl:hpux-shared:-fPIC:-shared:.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
"hpux-parisc2-gcc","gcc:-march=2.0 -O3 -DB_ENDIAN -D_REENTRANT::::-Wl,+s -ldld:SIXTY_FOUR_BIT RC4_CHAR RC4_CHUNK DES_PTR DES_UNROLL DES_RISC1::pa-risc2.o::::::::::::::void:dl:hpux-shared:-fPIC:-shared:.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"hpux64-parisc2-gcc","gcc:-O3 -DB_ENDIAN -D_REENTRANT::::-ldl:SIXTY_FOUR_BIT_LONG MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT::pa-risc2W.o::::::::::::void:dlfcn:hpux-shared:-fpic:-shared:.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::/pa20_64",
 | 
				
			||||||
"hpux64-parisc2-gcc","gcc:-O3 -DB_ENDIAN -D_REENTRANT::::-ldl:SIXTY_FOUR_BIT_LONG MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT::pa-risc2W.o::::::::::::::void:dlfcn:hpux-shared:-fpic:-shared:.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::/pa20_64",
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
# More attempts at unified 10.X and 11.X targets for HP C compiler.
 | 
					# More attempts at unified 10.X and 11.X targets for HP C compiler.
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
# Chris Ruemmler <ruemmler@cup.hp.com>
 | 
					# Chris Ruemmler <ruemmler@cup.hp.com>
 | 
				
			||||||
# Kevin Steves <ks@hp.se>
 | 
					# Kevin Steves <ks@hp.se>
 | 
				
			||||||
"hpux-parisc-cc","cc:+O3 +Optrs_strongly_typed -Ae +ESlit -DB_ENDIAN -DBN_DIV2W -DMD32_XARRAY::-D_REENTRANT::-Wl,+s -ldld:MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT:${no_asm}:dl:hpux-shared:+Z:-b:.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"hpux-parisc-cc","cc:+O3 +Optrs_strongly_typed -Ae +ESlit -DB_ENDIAN -DBN_DIV2W -DMD32_XARRAY::-D_REENTRANT::-Wl,+s -ldld:MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT:${no_asm}:dl:hpux-shared:+Z:-b:.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
"hpux-parisc1_1-cc","cc:+DA1.1 +O3 +Optrs_strongly_typed -Ae +ESlit -DB_ENDIAN -DMD32_XARRAY::-D_REENTRANT::-Wl,+s -ldld:MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT:${parisc11_asm}:dl:hpux-shared:+Z:-b:.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::/pa1.1",
 | 
					"hpux-parisc1_0-cc","cc:+DAportable +O3 +Optrs_strongly_typed -Ae +ESlit -DB_ENDIAN -DMD32_XARRAY::-D_REENTRANT::-Wl,+s -ldld:MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT:${no_asm}:dl:hpux-shared:+Z:-b:.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
"hpux-parisc2-cc","cc:+DA2.0 +DS2.0 +O3 +Optrs_strongly_typed -Ae +ESlit -DB_ENDIAN -DMD32_XARRAY -D_REENTRANT::::-Wl,+s -ldld:SIXTY_FOUR_BIT MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT::pa-risc2.o::::::::::::::void:dl:hpux-shared:+Z:-b:.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"hpux-parisc2-cc","cc:+DA2.0 +DS2.0 +O3 +Optrs_strongly_typed -Ae +ESlit -DB_ENDIAN -DMD32_XARRAY -D_REENTRANT::::-Wl,+s -ldld:SIXTY_FOUR_BIT MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT::pa-risc2.o::::::::::::void:dl:hpux-shared:+Z:-b:.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
"hpux64-parisc2-cc","cc:+DD64 +O3 +Optrs_strongly_typed -Ae +ESlit -DB_ENDIAN -DMD32_XARRAY -D_REENTRANT::::-ldl:SIXTY_FOUR_BIT_LONG MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT:${parisc20_asm}:dlfcn:hpux-shared:+Z:+DD64 -b:.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::/pa20_64",
 | 
					"hpux64-parisc2-cc","cc:+DD64 +O3 +Optrs_strongly_typed -Ae +ESlit -DB_ENDIAN -DMD32_XARRAY -D_REENTRANT::::-ldl:SIXTY_FOUR_BIT_LONG MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT::pa-risc2W.o::::::::::::void:dlfcn:hpux-shared:+Z:+DD64 -b:.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::/pa20_64",
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# HP/UX IA-64 targets
 | 
					# HP/UX IA-64 targets
 | 
				
			||||||
"hpux-ia64-cc","cc:-Ae +DD32 +O2 +Olit=all -z -DB_ENDIAN -D_REENTRANT::::-ldl:SIXTY_FOUR_BIT MD2_CHAR RC4_INDEX DES_UNROLL DES_RISC1 DES_INT:${ia64_asm}:dlfcn:hpux-shared:+Z:+DD32 -b:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::/hpux32",
 | 
					"hpux-ia64-cc","cc:-Ae +DD32 +O2 +Olit=all -z -DB_ENDIAN -D_REENTRANT::::-ldl:SIXTY_FOUR_BIT MD2_CHAR RC4_INDEX DES_UNROLL DES_RISC1 DES_INT:${ia64_asm}:dlfcn:hpux-shared:+Z:+DD32 -b:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::/hpux32",
 | 
				
			||||||
@@ -355,22 +346,8 @@ my %table=(
 | 
				
			|||||||
"linux-ia64",	"gcc:-DL_ENDIAN -DTERMIO -O3 -Wall::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_UNROLL DES_INT:${ia64_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"linux-ia64",	"gcc:-DL_ENDIAN -DTERMIO -O3 -Wall::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_UNROLL DES_INT:${ia64_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
"linux-ia64-ecc","ecc:-DL_ENDIAN -DTERMIO -O2 -Wall -no_cpprt::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_INT:${ia64_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"linux-ia64-ecc","ecc:-DL_ENDIAN -DTERMIO -O2 -Wall -no_cpprt::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_INT:${ia64_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
"linux-ia64-icc","icc:-DL_ENDIAN -DTERMIO -O2 -Wall -no_cpprt::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_RISC1 DES_INT:${ia64_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"linux-ia64-icc","icc:-DL_ENDIAN -DTERMIO -O2 -Wall -no_cpprt::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_RISC1 DES_INT:${ia64_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
"linux-x86_64",	"gcc:-m64 -DL_ENDIAN -DTERMIO -O3 -Wall::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_INT DES_UNROLL:${x86_64_asm}:elf:dlfcn:linux-shared:-fPIC:-m64:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::64",
 | 
					"linux-x86_64",	"gcc:-m64 -DL_ENDIAN -DTERMIO -O3 -Wall -DMD32_REG_T=int::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG RC4_CHUNK BF_PTR2 DES_INT DES_UNROLL:${x86_64_asm}:elf:dlfcn:linux-shared:-fPIC:-m64:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::64",
 | 
				
			||||||
"linux64-s390x",	"gcc:-m64 -DB_ENDIAN -DTERMIO -O3 -Wall::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG RC4_CHAR RC4_CHUNK DES_INT DES_UNROLL:${s390x_asm}:64:dlfcn:linux-shared:-fPIC:-m64:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::64",
 | 
					"linux-s390x",	"gcc:-m64 -DB_ENDIAN -DTERMIO -O3 -Wall::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG RC4_CHAR RC4_CHUNK DES_INT DES_UNROLL:${s390x_asm}:dlfcn:linux-shared:-fPIC:-m64:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::64",
 | 
				
			||||||
#### So called "highgprs" target for z/Architecture CPUs
 | 
					 | 
				
			||||||
# "Highgprs" is kernel feature first implemented in Linux 2.6.32, see
 | 
					 | 
				
			||||||
# /proc/cpuinfo. The idea is to preserve most significant bits of
 | 
					 | 
				
			||||||
# general purpose registers not only upon 32-bit process context
 | 
					 | 
				
			||||||
# switch, but even on asynchronous signal delivery to such process.
 | 
					 | 
				
			||||||
# This makes it possible to deploy 64-bit instructions even in legacy
 | 
					 | 
				
			||||||
# application context and achieve better [or should we say adequate]
 | 
					 | 
				
			||||||
# performance. The build is binary compatible with linux-generic32,
 | 
					 | 
				
			||||||
# and the idea is to be able to install the resulting libcrypto.so
 | 
					 | 
				
			||||||
# alongside generic one, e.g. as /lib/highgprs/libcrypto.so.x.y, for
 | 
					 | 
				
			||||||
# ldconfig and run-time linker to autodiscover. Unfortunately it
 | 
					 | 
				
			||||||
# doesn't work just yet, because of couple of bugs in glibc
 | 
					 | 
				
			||||||
# sysdeps/s390/dl-procinfo.c affecting ldconfig and ld.so.1...
 | 
					 | 
				
			||||||
"linux32-s390x",	"gcc:-m31 -Wa,-mzarch -DB_ENDIAN -DTERMIO -O3 -Wall::-D_REENTRANT::-ldl:BN_LLONG RC4_CHAR RC4_CHUNK DES_INT DES_UNROLL:".eval{my $asm=$s390x_asm;$asm=~s/bn\-s390x\.o/bn_asm.o/;$asm}.":31:dlfcn:linux-shared:-fPIC:-m31:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::/highgprs",
 | 
					 | 
				
			||||||
#### SPARC Linux setups
 | 
					#### SPARC Linux setups
 | 
				
			||||||
# Ray Miller <ray.miller@computing-services.oxford.ac.uk> has patiently
 | 
					# Ray Miller <ray.miller@computing-services.oxford.ac.uk> has patiently
 | 
				
			||||||
# assisted with debugging of following two configs.
 | 
					# assisted with debugging of following two configs.
 | 
				
			||||||
@@ -398,11 +375,6 @@ my %table=(
 | 
				
			|||||||
"linux-alpha-ccc","ccc:-fast -readonly_strings -DL_ENDIAN -DTERMIO::-D_REENTRANT:::SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_INT DES_PTR DES_RISC1 DES_UNROLL:${alpha_asm}",
 | 
					"linux-alpha-ccc","ccc:-fast -readonly_strings -DL_ENDIAN -DTERMIO::-D_REENTRANT:::SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_INT DES_PTR DES_RISC1 DES_UNROLL:${alpha_asm}",
 | 
				
			||||||
"linux-alpha+bwx-ccc","ccc:-fast -readonly_strings -DL_ENDIAN -DTERMIO::-D_REENTRANT:::SIXTY_FOUR_BIT_LONG RC4_CHAR RC4_CHUNK DES_INT DES_PTR DES_RISC1 DES_UNROLL:${alpha_asm}",
 | 
					"linux-alpha+bwx-ccc","ccc:-fast -readonly_strings -DL_ENDIAN -DTERMIO::-D_REENTRANT:::SIXTY_FOUR_BIT_LONG RC4_CHAR RC4_CHUNK DES_INT DES_PTR DES_RISC1 DES_UNROLL:${alpha_asm}",
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Android: linux-* but without -DTERMIO and pointers to headers and libs.
 | 
					 | 
				
			||||||
"android","gcc:-mandroid -I\$(ANDROID_DEV)/include -B\$(ANDROID_DEV)/lib -O3 -fomit-frame-pointer -Wall::-D_REENTRANT::-ldl:BN_LLONG RC4_CHAR RC4_CHUNK DES_INT DES_UNROLL BF_PTR:${no_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					 | 
				
			||||||
"android-x86","gcc:-mandroid -I\$(ANDROID_DEV)/include -B\$(ANDROID_DEV)/lib -O3 -fomit-frame-pointer -Wall::-D_REENTRANT::-ldl:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:".eval{my $asm=${x86_elf_asm};$asm=~s/:elf/:android/;$asm}.":dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					 | 
				
			||||||
"android-armv7","gcc:-march=armv7-a -mandroid -I\$(ANDROID_DEV)/include -B\$(ANDROID_DEV)/lib -O3 -fomit-frame-pointer -Wall::-D_REENTRANT::-ldl:BN_LLONG RC4_CHAR RC4_CHUNK DES_INT DES_UNROLL BF_PTR:${armv4_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#### *BSD [do see comment about ${BSDthreads} above!]
 | 
					#### *BSD [do see comment about ${BSDthreads} above!]
 | 
				
			||||||
"BSD-generic32","gcc:-DTERMIOS -O3 -fomit-frame-pointer -Wall::${BSDthreads}:::BN_LLONG RC2_CHAR RC4_INDEX DES_INT DES_UNROLL:${no_asm}:dlfcn:bsd-gcc-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"BSD-generic32","gcc:-DTERMIOS -O3 -fomit-frame-pointer -Wall::${BSDthreads}:::BN_LLONG RC2_CHAR RC4_INDEX DES_INT DES_UNROLL:${no_asm}:dlfcn:bsd-gcc-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
"BSD-x86",	"gcc:-DL_ENDIAN -DTERMIOS -O3 -fomit-frame-pointer -Wall::${BSDthreads}:::BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_asm}:a.out:dlfcn:bsd-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"BSD-x86",	"gcc:-DL_ENDIAN -DTERMIOS -O3 -fomit-frame-pointer -Wall::${BSDthreads}:::BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_asm}:a.out:dlfcn:bsd-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
@@ -416,7 +388,7 @@ my %table=(
 | 
				
			|||||||
# triggered by RIPEMD160 code.
 | 
					# triggered by RIPEMD160 code.
 | 
				
			||||||
"BSD-sparc64",	"gcc:-DB_ENDIAN -DTERMIOS -O3 -DMD32_REG_T=int -Wall::${BSDthreads}:::BN_LLONG RC2_CHAR RC4_CHUNK DES_INT DES_PTR DES_RISC2 BF_PTR:${sparcv9_asm}:dlfcn:bsd-gcc-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"BSD-sparc64",	"gcc:-DB_ENDIAN -DTERMIOS -O3 -DMD32_REG_T=int -Wall::${BSDthreads}:::BN_LLONG RC2_CHAR RC4_CHUNK DES_INT DES_PTR DES_RISC2 BF_PTR:${sparcv9_asm}:dlfcn:bsd-gcc-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
"BSD-ia64",	"gcc:-DL_ENDIAN -DTERMIOS -O3 -Wall::${BSDthreads}:::SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_UNROLL DES_INT:${ia64_asm}:dlfcn:bsd-gcc-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"BSD-ia64",	"gcc:-DL_ENDIAN -DTERMIOS -O3 -Wall::${BSDthreads}:::SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_UNROLL DES_INT:${ia64_asm}:dlfcn:bsd-gcc-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
"BSD-x86_64",	"gcc:-DL_ENDIAN -DTERMIOS -O3 -Wall::${BSDthreads}:::SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_INT DES_UNROLL:${x86_64_asm}:elf:dlfcn:bsd-gcc-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"BSD-x86_64",	"gcc:-DL_ENDIAN -DTERMIOS -O3 -DMD32_REG_T=int -Wall::${BSDthreads}:::SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_INT DES_UNROLL:${x86_64_asm}:elf:dlfcn:bsd-gcc-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
 | 
					
 | 
				
			||||||
"bsdi-elf-gcc",     "gcc:-DPERL5 -DL_ENDIAN -fomit-frame-pointer -O3 -march=i486 -Wall::(unknown)::-ldl:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}:dlfcn:bsd-gcc-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"bsdi-elf-gcc",     "gcc:-DPERL5 -DL_ENDIAN -fomit-frame-pointer -O3 -march=i486 -Wall::(unknown)::-ldl:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}:dlfcn:bsd-gcc-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -428,8 +400,7 @@ my %table=(
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
# QNX
 | 
					# QNX
 | 
				
			||||||
"qnx4",	"cc:-DL_ENDIAN -DTERMIO::(unknown):::${x86_gcc_des} ${x86_gcc_opts}:",
 | 
					"qnx4",	"cc:-DL_ENDIAN -DTERMIO::(unknown):::${x86_gcc_des} ${x86_gcc_opts}:",
 | 
				
			||||||
"QNX6",       "gcc:-DTERMIOS::::-lsocket::${no_asm}:dlfcn:bsd-gcc-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"qnx6",	"cc:-DL_ENDIAN -DTERMIOS::(unknown)::-lsocket:${x86_gcc_des} ${x86_gcc_opts}:",
 | 
				
			||||||
"QNX6-i386",  "gcc:-DL_ENDIAN -DTERMIOS -O2 -Wall::::-lsocket:${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}:dlfcn:bsd-gcc-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
# BeOS
 | 
					# BeOS
 | 
				
			||||||
"beos-x86-r5",   "gcc:-DL_ENDIAN -DTERMIOS -O3 -fomit-frame-pointer -mcpu=pentium -Wall::-D_REENTRANT:BEOS:-lbe -lnet:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}:beos:beos-shared:-fPIC -DPIC:-shared:.so",
 | 
					"beos-x86-r5",   "gcc:-DL_ENDIAN -DTERMIOS -O3 -fomit-frame-pointer -mcpu=pentium -Wall::-D_REENTRANT:BEOS:-lbe -lnet:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}:beos:beos-shared:-fPIC -DPIC:-shared:.so",
 | 
				
			||||||
@@ -513,22 +484,19 @@ my %table=(
 | 
				
			|||||||
# Visual C targets
 | 
					# Visual C targets
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
# Win64 targets, WIN64I denotes IA-64 and WIN64A - AMD64
 | 
					# Win64 targets, WIN64I denotes IA-64 and WIN64A - AMD64
 | 
				
			||||||
"VC-WIN64I","cl:-W3 -Gs0 -Gy -nologo -DOPENSSL_SYSNAME_WIN32 -DWIN32_LEAN_AND_MEAN -DL_ENDIAN -DUNICODE -D_UNICODE -D_CRT_SECURE_NO_DEPRECATE:::WIN64I::SIXTY_FOUR_BIT RC4_CHUNK_LL DES_INT EXPORT_VAR_AS_FN:ia64cpuid.o:ia64.o ia64-mont.o::aes_core.o aes_cbc.o aes-ia64.o::md5-ia64.o:sha1-ia64.o sha256-ia64.o sha512-ia64.o:::::::ghash-ia64.o::ias:win32",
 | 
					"VC-WIN64I","cl:-W3 -Gs0 -Gy -nologo -DOPENSSL_SYSNAME_WIN32 -DWIN32_LEAN_AND_MEAN -DL_ENDIAN -DUNICODE -D_UNICODE -D_CRT_SECURE_NO_DEPRECATE:::WIN64I::SIXTY_FOUR_BIT RC4_CHUNK_LL DES_INT EXPORT_VAR_AS_FN:ia64cpuid.o:ia64.o::aes_core.o aes_cbc.o aes-ia64.o::md5-ia64.o:sha1-ia64.o sha256-ia64.o sha512-ia64.o:::::::ias:win32",
 | 
				
			||||||
"VC-WIN64A","cl:-W3 -Gs0 -Gy -nologo -DOPENSSL_SYSNAME_WIN32 -DWIN32_LEAN_AND_MEAN -DL_ENDIAN -DUNICODE -D_UNICODE -D_CRT_SECURE_NO_DEPRECATE:::WIN64A::SIXTY_FOUR_BIT RC4_CHUNK_LL DES_INT EXPORT_VAR_AS_FN:".eval{my $asm=$x86_64_asm;$asm=~s/x86_64-gcc\.o/bn_asm.o/;$asm}.":auto:win32",
 | 
					"VC-WIN64A","cl:-W3 -Gs0 -Gy -nologo -DOPENSSL_SYSNAME_WIN32 -DWIN32_LEAN_AND_MEAN -DL_ENDIAN -DUNICODE -D_UNICODE -D_CRT_SECURE_NO_DEPRECATE:::WIN64A::SIXTY_FOUR_BIT RC4_CHUNK_LL DES_INT EXPORT_VAR_AS_FN:x86_64cpuid.o:bn_asm.o x86_64-mont.o::aes-x86_64.o::md5-x86_64.o:sha1-x86_64.o sha256-x86_64.o sha512-x86_64.o::rc4-x86_64.o:::wp-x86_64.o::ml64:win32",
 | 
				
			||||||
"debug-VC-WIN64I","cl:-W3 -Gs0 -Gy -Zi -nologo -DOPENSSL_SYSNAME_WIN32 -DWIN32_LEAN_AND_MEAN -DL_ENDIAN -DUNICODE -D_UNICODE -D_CRT_SECURE_NO_DEPRECATE:::WIN64I::SIXTY_FOUR_BIT RC4_CHUNK_LL DES_INT EXPORT_VAR_AS_FN:ia64cpuid.o:ia64.o::aes_core.o aes_cbc.o aes-ia64.o::md5-ia64.o:sha1-ia64.o sha256-ia64.o sha512-ia64.o:::::::ghash-ia64.o::ias:win32",
 | 
					 | 
				
			||||||
"debug-VC-WIN64A","cl:-W3 -Gs0 -Gy -Zi -nologo -DOPENSSL_SYSNAME_WIN32 -DWIN32_LEAN_AND_MEAN -DL_ENDIAN -DUNICODE -D_UNICODE -D_CRT_SECURE_NO_DEPRECATE:::WIN64A::SIXTY_FOUR_BIT RC4_CHUNK_LL DES_INT EXPORT_VAR_AS_FN:".eval{my $asm=$x86_64_asm;$asm=~s/x86_64-gcc\.o/bn_asm.o/;$asm}.":auto:win32",
 | 
					 | 
				
			||||||
# x86 Win32 target defaults to ANSI API, if you want UNICODE, complement
 | 
					# x86 Win32 target defaults to ANSI API, if you want UNICODE, complement
 | 
				
			||||||
# 'perl Configure VC-WIN32' with '-DUNICODE -D_UNICODE'
 | 
					# 'perl Configure VC-WIN32' with '-DUNICODE -D_UNICODE'
 | 
				
			||||||
"VC-WIN32","cl:-W3 -Gs0 -GF -Gy -nologo -DOPENSSL_SYSNAME_WIN32 -DWIN32_LEAN_AND_MEAN -DL_ENDIAN -D_CRT_SECURE_NO_DEPRECATE:::WIN32::BN_LLONG RC4_INDEX EXPORT_VAR_AS_FN ${x86_gcc_opts}:${x86_asm}:win32n:win32",
 | 
					"VC-WIN32","cl:-W3 -WX -Gs0 -GF -Gy -nologo -DOPENSSL_SYSNAME_WIN32 -DWIN32_LEAN_AND_MEAN -DL_ENDIAN -D_CRT_SECURE_NO_DEPRECATE:::WIN32::BN_LLONG RC4_INDEX EXPORT_VAR_AS_FN ${x86_gcc_opts}:${x86_asm}:win32n:win32",
 | 
				
			||||||
# Unified CE target
 | 
					# Unified CE target
 | 
				
			||||||
"debug-VC-WIN32","cl:-W3 -WX -Gs0 -GF -Gy -Zi -nologo -DOPENSSL_SYSNAME_WIN32 -DWIN32_LEAN_AND_MEAN -DL_ENDIAN -D_CRT_SECURE_NO_DEPRECATE:::WIN32::BN_LLONG RC4_INDEX EXPORT_VAR_AS_FN ${x86_gcc_opts}:${x86_asm}:win32n:win32",
 | 
					 | 
				
			||||||
"VC-CE","cl::::WINCE::BN_LLONG RC4_INDEX EXPORT_VAR_AS_FN ${x86_gcc_opts}:${no_asm}:win32",
 | 
					"VC-CE","cl::::WINCE::BN_LLONG RC4_INDEX EXPORT_VAR_AS_FN ${x86_gcc_opts}:${no_asm}:win32",
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Borland C++ 4.5
 | 
					# Borland C++ 4.5
 | 
				
			||||||
"BC-32","bcc32::::WIN32::BN_LLONG DES_PTR RC4_INDEX EXPORT_VAR_AS_FN:${no_asm}:win32",
 | 
					"BC-32","bcc32::::WIN32::BN_LLONG DES_PTR RC4_INDEX EXPORT_VAR_AS_FN:${no_asm}:win32",
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# MinGW
 | 
					# MinGW
 | 
				
			||||||
"mingw", "gcc:-mno-cygwin -DL_ENDIAN -DWIN32_LEAN_AND_MEAN -fomit-frame-pointer -O3 -march=i486 -Wall::-D_MT:MINGW32:-lws2_32 -lgdi32 -lcrypt32:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts} EXPORT_VAR_AS_FN:${x86_asm}:coff:win32:cygwin-shared:-D_WINDLL -DOPENSSL_USE_APPLINK:-mno-cygwin:.dll.a",
 | 
					"mingw", "gcc:-mno-cygwin -DL_ENDIAN -fomit-frame-pointer -O3 -march=i486 -Wall:::MINGW32:-lws2_32 -lgdi32:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts} EXPORT_VAR_AS_FN:${x86_asm}:coff:win32:cygwin-shared:-D_WINDLL -DOPENSSL_USE_APPLINK:-mno-cygwin:.dll.a",
 | 
				
			||||||
# As for OPENSSL_USE_APPLINK. Applink makes it possible to use .dll
 | 
					# As for OPENSSL_USE_APPLINK. Applink makes it possible to use .dll
 | 
				
			||||||
# compiled with one compiler with application compiled with another
 | 
					# compiled with one compiler with application compiled with another
 | 
				
			||||||
# compiler. It's possible to engage Applink support in mingw64 build,
 | 
					# compiler. It's possible to engage Applink support in mingw64 build,
 | 
				
			||||||
@@ -536,7 +504,7 @@ my %table=(
 | 
				
			|||||||
# handling, one can't seriously consider its binaries for using with
 | 
					# handling, one can't seriously consider its binaries for using with
 | 
				
			||||||
# non-mingw64 run-time environment. And as mingw64 is always consistent
 | 
					# non-mingw64 run-time environment. And as mingw64 is always consistent
 | 
				
			||||||
# with itself, Applink is never engaged and can as well be omitted.
 | 
					# with itself, Applink is never engaged and can as well be omitted.
 | 
				
			||||||
"mingw64", "gcc:-mno-cygwin -DL_ENDIAN -O3 -Wall -DWIN32_LEAN_AND_MEAN -DUNICODE -D_UNICODE::-D_MT:MINGW64:-lws2_32 -lgdi32 -lcrypt32:SIXTY_FOUR_BIT RC4_CHUNK_LL DES_INT EXPORT_VAR_AS_FN:${x86_64_asm}:mingw64:win32:cygwin-shared:-D_WINDLL:-mno-cygwin:.dll.a",
 | 
					"mingw64", "gcc:-mno-cygwin -DL_ENDIAN -O3 -Wall -DWIN32_LEAN_AND_MEAN -DUNICODE -D_UNICODE:::MINGW64:-lws2_32 -lgdi32:SIXTY_FOUR_BIT RC4_CHUNK_LL DES_INT EXPORT_VAR_AS_FN:${x86_64_asm}:mingw64:win32:cygwin-shared:-D_WINDLL:-mno-cygwin:.dll.a",
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# UWIN 
 | 
					# UWIN 
 | 
				
			||||||
"UWIN", "cc:-DTERMIOS -DL_ENDIAN -O -Wall:::UWIN::BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${no_asm}:win32",
 | 
					"UWIN", "cc:-DTERMIOS -DL_ENDIAN -O -Wall:::UWIN::BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${no_asm}:win32",
 | 
				
			||||||
@@ -572,14 +540,12 @@ my %table=(
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
##### MacOS X (a.k.a. Rhapsody or Darwin) setup
 | 
					##### MacOS X (a.k.a. Rhapsody or Darwin) setup
 | 
				
			||||||
"rhapsody-ppc-cc","cc:-O3 -DB_ENDIAN::(unknown):MACOSX_RHAPSODY::BN_LLONG RC4_CHAR RC4_CHUNK DES_UNROLL BF_PTR:${no_asm}::",
 | 
					"rhapsody-ppc-cc","cc:-O3 -DB_ENDIAN::(unknown):MACOSX_RHAPSODY::BN_LLONG RC4_CHAR RC4_CHUNK DES_UNROLL BF_PTR:${no_asm}::",
 | 
				
			||||||
"darwin-ppc-cc","cc:-arch ppc -O3 -DB_ENDIAN -Wa,-force_cpusubtype_ALL::-D_REENTRANT:MACOSX:-Wl,-search_paths_first%:BN_LLONG RC4_CHAR RC4_CHUNK DES_UNROLL BF_PTR:${ppc32_asm}:osx32:dlfcn:darwin-shared:-fPIC -fno-common:-arch ppc -dynamiclib:.\$(SHLIB_MAJOR).\$(SHLIB_MINOR).dylib",
 | 
					"darwin-ppc-cc","cc:-arch ppc -O3 -DB_ENDIAN::-D_REENTRANT:MACOSX:-Wl,-search_paths_first%:BN_LLONG RC4_CHAR RC4_CHUNK DES_UNROLL BF_PTR:${ppc32_asm}:osx32:dlfcn:darwin-shared:-fPIC -fno-common:-arch ppc -dynamiclib:.\$(SHLIB_MAJOR).\$(SHLIB_MINOR).dylib",
 | 
				
			||||||
"darwin64-ppc-cc","cc:-arch ppc64 -O3 -DB_ENDIAN::-D_REENTRANT:MACOSX:-Wl,-search_paths_first%:SIXTY_FOUR_BIT_LONG RC4_CHAR RC4_CHUNK DES_UNROLL BF_PTR:${ppc64_asm}:osx64:dlfcn:darwin-shared:-fPIC -fno-common:-arch ppc64 -dynamiclib:.\$(SHLIB_MAJOR).\$(SHLIB_MINOR).dylib",
 | 
					"darwin64-ppc-cc","cc:-arch ppc64 -O3 -DB_ENDIAN::-D_REENTRANT:MACOSX:-Wl,-search_paths_first%:SIXTY_FOUR_BIT_LONG RC4_CHAR RC4_CHUNK DES_UNROLL BF_PTR:${ppc64_asm}:osx64:dlfcn:darwin-shared:-fPIC -fno-common:-arch ppc64 -dynamiclib:.\$(SHLIB_MAJOR).\$(SHLIB_MINOR).dylib",
 | 
				
			||||||
"darwin-i386-cc","cc:-arch i386 -O3 -fomit-frame-pointer -DL_ENDIAN::-D_REENTRANT:MACOSX:-Wl,-search_paths_first%:BN_LLONG RC4_INT RC4_CHUNK DES_UNROLL BF_PTR:${x86_asm}:macosx:dlfcn:darwin-shared:-fPIC -fno-common:-arch i386 -dynamiclib:.\$(SHLIB_MAJOR).\$(SHLIB_MINOR).dylib",
 | 
					"darwin-i386-cc","cc:-arch i386 -O3 -fomit-frame-pointer -DL_ENDIAN::-D_REENTRANT:MACOSX:-Wl,-search_paths_first%:BN_LLONG RC4_INT RC4_CHUNK DES_UNROLL BF_PTR:${x86_asm}:macosx:dlfcn:darwin-shared:-fPIC -fno-common:-arch i386 -dynamiclib:.\$(SHLIB_MAJOR).\$(SHLIB_MINOR).dylib",
 | 
				
			||||||
"debug-darwin-i386-cc","cc:-arch i386 -g3 -DL_ENDIAN::-D_REENTRANT:MACOSX:-Wl,-search_paths_first%:BN_LLONG RC4_INT RC4_CHUNK DES_UNROLL BF_PTR:${x86_asm}:macosx:dlfcn:darwin-shared:-fPIC -fno-common:-arch i386 -dynamiclib:.\$(SHLIB_MAJOR).\$(SHLIB_MINOR).dylib",
 | 
					"debug-darwin-i386-cc","cc:-arch i386 -g3 -DL_ENDIAN::-D_REENTRANT:MACOSX:-Wl,-search_paths_first%:BN_LLONG RC4_INT RC4_CHUNK DES_UNROLL BF_PTR:${x86_asm}:macosx:dlfcn:darwin-shared:-fPIC -fno-common:-arch i386 -dynamiclib:.\$(SHLIB_MAJOR).\$(SHLIB_MINOR).dylib",
 | 
				
			||||||
"darwin64-x86_64-cc","cc:-arch x86_64 -O3 -DL_ENDIAN -Wall::-D_REENTRANT:MACOSX:-Wl,-search_paths_first%:SIXTY_FOUR_BIT_LONG RC4_CHAR RC4_CHUNK DES_INT DES_UNROLL:${x86_64_asm}:macosx:dlfcn:darwin-shared:-fPIC -fno-common:-arch x86_64 -dynamiclib:.\$(SHLIB_MAJOR).\$(SHLIB_MINOR).dylib",
 | 
					"darwin64-x86_64-cc","cc:-arch x86_64 -O3 -DL_ENDIAN -DMD32_REG_T=int -Wall::-D_REENTRANT:MACOSX:-Wl,-search_paths_first%:SIXTY_FOUR_BIT_LONG RC4_CHAR RC4_CHUNK BF_PTR2 DES_INT DES_UNROLL:${x86_64_asm}:macosx:dlfcn:darwin-shared:-fPIC -fno-common:-arch x86_64 -dynamiclib:.\$(SHLIB_MAJOR).\$(SHLIB_MINOR).dylib",
 | 
				
			||||||
"debug-darwin-ppc-cc","cc:-DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DCRYPTO_MDEBUG -DB_ENDIAN -g -Wall -O::-D_REENTRANT:MACOSX::BN_LLONG RC4_CHAR RC4_CHUNK DES_UNROLL BF_PTR:${ppc32_asm}:osx32:dlfcn:darwin-shared:-fPIC:-dynamiclib:.\$(SHLIB_MAJOR).\$(SHLIB_MINOR).dylib",
 | 
					"debug-darwin-ppc-cc","cc:-DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DCRYPTO_MDEBUG -DB_ENDIAN -g -Wall -O::-D_REENTRANT:MACOSX::BN_LLONG RC4_CHAR RC4_CHUNK DES_UNROLL BF_PTR:${ppc32_asm}:osx32:dlfcn:darwin-shared:-fPIC:-dynamiclib:.\$(SHLIB_MAJOR).\$(SHLIB_MINOR).dylib",
 | 
				
			||||||
# iPhoneOS/iOS
 | 
					 | 
				
			||||||
"iphoneos-cross","llvm-gcc:-O3 -isysroot \$(CROSS_TOP)/SDKs/\$(CROSS_SDK) -fomit-frame-pointer -fno-common::-D_REENTRANT:iOS:-Wl,-search_paths_first%:BN_LLONG RC4_CHAR RC4_CHUNK DES_UNROLL BF_PTR:${no_asm}:dlfcn:darwin-shared:-fPIC -fno-common:-dynamiclib:.\$(SHLIB_MAJOR).\$(SHLIB_MINOR).dylib",
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
##### A/UX
 | 
					##### A/UX
 | 
				
			||||||
"aux3-gcc","gcc:-O2 -DTERMIO::(unknown):AUX:-lbsd:RC4_CHAR RC4_CHUNK DES_UNROLL BF_PTR:::",
 | 
					"aux3-gcc","gcc:-O2 -DTERMIO::(unknown):AUX:-lbsd:RC4_CHAR RC4_CHUNK DES_UNROLL BF_PTR:::",
 | 
				
			||||||
@@ -594,28 +560,20 @@ my %table=(
 | 
				
			|||||||
"OS2-EMX", "gcc::::::::",
 | 
					"OS2-EMX", "gcc::::::::",
 | 
				
			||||||
 | 
					
 | 
				
			||||||
##### VxWorks for various targets
 | 
					##### VxWorks for various targets
 | 
				
			||||||
"vxworks-ppc60x","ccppc:-D_REENTRANT -mrtp -mhard-float -mstrict-align -fno-implicit-fp -DPPC32_fp60x -O2 -fstrength-reduce -fno-builtin -fno-strict-aliasing -Wall -DCPU=PPC32 -DTOOL_FAMILY=gnu -DTOOL=gnu -I\$(WIND_BASE)/target/usr/h -I\$(WIND_BASE)/target/usr/h/wrn/coreip:::VXWORKS:-Wl,--defsym,__wrs_rtp_base=0xe0000000 -L \$(WIND_BASE)/target/usr/lib/ppc/PPC32/common:::::",
 | 
					 | 
				
			||||||
"vxworks-ppcgen","ccppc:-D_REENTRANT -mrtp -msoft-float -mstrict-align -O1 -fno-builtin -fno-strict-aliasing -Wall -DCPU=PPC32 -DTOOL_FAMILY=gnu -DTOOL=gnu -I\$(WIND_BASE)/target/usr/h -I\$(WIND_BASE)/target/usr/h/wrn/coreip:::VXWORKS:-Wl,--defsym,__wrs_rtp_base=0xe0000000 -L \$(WIND_BASE)/target/usr/lib/ppc/PPC32/sfcommon:::::",
 | 
					 | 
				
			||||||
"vxworks-ppc405","ccppc:-g -msoft-float -mlongcall -DCPU=PPC405 -I\$(WIND_BASE)/target/h:::VXWORKS:-r:::::",
 | 
					"vxworks-ppc405","ccppc:-g -msoft-float -mlongcall -DCPU=PPC405 -I\$(WIND_BASE)/target/h:::VXWORKS:-r:::::",
 | 
				
			||||||
"vxworks-ppc750","ccppc:-ansi -nostdinc -DPPC750 -D_REENTRANT -fvolatile -fno-builtin -fno-for-scope -fsigned-char -Wall -msoft-float -mlongcall -DCPU=PPC604 -I\$(WIND_BASE)/target/h \$(DEBUG_FLAG):::VXWORKS:-r:::::",
 | 
					"vxworks-ppc750","ccppc:-ansi -nostdinc -DPPC750 -D_REENTRANT -fvolatile -fno-builtin -fno-for-scope -fsigned-char -Wall -msoft-float -mlongcall -DCPU=PPC604 -I\$(WIND_BASE)/target/h \$(DEBUG_FLAG):::VXWORKS:-r:::::",
 | 
				
			||||||
"vxworks-ppc750-debug","ccppc:-ansi -nostdinc -DPPC750 -D_REENTRANT -fvolatile -fno-builtin -fno-for-scope -fsigned-char -Wall -msoft-float -mlongcall -DCPU=PPC604 -I\$(WIND_BASE)/target/h -DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_CTX_DEBUG -DCRYPTO_MDEBUG -DPEDANTIC -DDEBUG_SAFESTACK -DDEBUG -g:::VXWORKS:-r:::::",
 | 
					"vxworks-ppc750-debug","ccppc:-ansi -nostdinc -DPPC750 -D_REENTRANT -fvolatile -fno-builtin -fno-for-scope -fsigned-char -Wall -msoft-float -mlongcall -DCPU=PPC604 -I\$(WIND_BASE)/target/h -DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_CTX_DEBUG -DCRYPTO_MDEBUG -DPEDANTIC -DDEBUG_SAFESTACK -DDEBUG -g:::VXWORKS:-r:::::",
 | 
				
			||||||
"vxworks-ppc860","ccppc:-nostdinc -msoft-float -DCPU=PPC860 -DNO_STRINGS_H -I\$(WIND_BASE)/target/h:::VXWORKS:-r:::::",
 | 
					"vxworks-ppc860","ccppc:-nostdinc -msoft-float -DCPU=PPC860 -DNO_STRINGS_H -I\$(WIND_BASE)/target/h:::VXWORKS:-r:::::",
 | 
				
			||||||
"vxworks-simlinux","ccpentium:-B\$(WIND_BASE)/host/\$(WIND_HOST_TYPE)/lib/gcc-lib/ -D_VSB_CONFIG_FILE=\"\$(WIND_BASE)/target/lib/h/config/vsbConfig.h\" -DL_ENDIAN -DCPU=SIMLINUX -DTOOL_FAMILY=gnu -DTOOL=gnu -fno-builtin -fno-defer-pop -DNO_STRINGS_H -I\$(WIND_BASE)/target/h -I\$(WIND_BASE)/target/h/wrn/coreip -DOPENSSL_NO_HW_PADLOCK:::VXWORKS:-r::${no_asm}::::::ranlibpentium:",
 | 
					"vxworks-mipsle","ccmips:-B\$(WIND_BASE)/host/\$(WIND_HOST_TYPE)/lib/gcc-lib/ -DL_ENDIAN -EL -Wl,-EL -mips2 -mno-branch-likely -G 0 -fno-builtin -msoft-float -DCPU=MIPS32 -DMIPSEL -DNO_STRINGS_H -I\$(WIND_BASE)/target/h:::VXWORKS:-r::${no_asm}::::::ranlibmips:",
 | 
				
			||||||
"vxworks-mips","ccmips:-mrtp -mips2 -O -G 0 -B\$(WIND_BASE)/host/\$(WIND_HOST_TYPE)/lib/gcc-lib/ -D_VSB_CONFIG_FILE=\"\$(WIND_BASE)/target/lib/h/config/vsbConfig.h\" -DCPU=MIPS32 -msoft-float -mno-branch-likely -DTOOL_FAMILY=gnu -DTOOL=gnu -fno-builtin -fno-defer-pop -DNO_STRINGS_H -I\$(WIND_BASE)/target/usr/h -I\$(WIND_BASE)/target/h/wrn/coreip::-D_REENTRANT:VXWORKS:-Wl,--defsym,__wrs_rtp_base=0xe0000000 -L \$(WIND_BASE)/target/usr/lib/mips/MIPSI32/sfcommon::${mips32_asm}:o32::::::ranlibmips:",
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
##### Compaq Non-Stop Kernel (Tandem)
 | 
					##### Compaq Non-Stop Kernel (Tandem)
 | 
				
			||||||
"tandem-c89","c89:-Ww -D__TANDEM -D_XOPEN_SOURCE -D_XOPEN_SOURCE_EXTENDED=1 -D_TANDEM_SOURCE -DB_ENDIAN::(unknown):::THIRTY_TWO_BIT:::",
 | 
					"tandem-c89","c89:-Ww -D__TANDEM -D_XOPEN_SOURCE -D_XOPEN_SOURCE_EXTENDED=1 -D_TANDEM_SOURCE -DB_ENDIAN::(unknown):::THIRTY_TWO_BIT:::",
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# uClinux
 | 
					 | 
				
			||||||
"uClinux-dist","$ENV{'CC'}:\$(CFLAGS)::-D_REENTRANT::\$(LDFLAGS) \$(LDLIBS):BN_LLONG:${no_asm}:$ENV{'LIBSSL_dlfcn'}:linux-shared:-fPIC:-shared:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):$ENV{'RANLIB'}::",
 | 
					 | 
				
			||||||
"uClinux-dist64","$ENV{'CC'}:\$(CFLAGS)::-D_REENTRANT::\$(LDFLAGS) \$(LDLIBS):SIXTY_FOUR_BIT_LONG:${no_asm}:$ENV{'LIBSSL_dlfcn'}:linux-shared:-fPIC:-shared:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):$ENV{'RANLIB'}::",
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
);
 | 
					);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
my @MK1MF_Builds=qw(VC-WIN64I VC-WIN64A
 | 
					my @MK1MF_Builds=qw(VC-WIN64I VC-WIN64A
 | 
				
			||||||
		    debug-VC-WIN64I debug-VC-WIN64A
 | 
							    VC-NT VC-CE VC-WIN32
 | 
				
			||||||
		    VC-NT VC-CE VC-WIN32 debug-VC-WIN32
 | 
							    BC-32 OS2-EMX
 | 
				
			||||||
		    BC-32 
 | 
					 | 
				
			||||||
		    netware-clib netware-clib-bsdsock
 | 
							    netware-clib netware-clib-bsdsock
 | 
				
			||||||
		    netware-libc netware-libc-bsdsock);
 | 
							    netware-libc netware-libc-bsdsock);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -640,8 +598,6 @@ my $idx_rmd160_obj = $idx++;
 | 
				
			|||||||
my $idx_rc5_obj = $idx++;
 | 
					my $idx_rc5_obj = $idx++;
 | 
				
			||||||
my $idx_wp_obj = $idx++;
 | 
					my $idx_wp_obj = $idx++;
 | 
				
			||||||
my $idx_cmll_obj = $idx++;
 | 
					my $idx_cmll_obj = $idx++;
 | 
				
			||||||
my $idx_modes_obj = $idx++;
 | 
					 | 
				
			||||||
my $idx_engines_obj = $idx++;
 | 
					 | 
				
			||||||
my $idx_perlasm_scheme = $idx++;
 | 
					my $idx_perlasm_scheme = $idx++;
 | 
				
			||||||
my $idx_dso_scheme = $idx++;
 | 
					my $idx_dso_scheme = $idx++;
 | 
				
			||||||
my $idx_shared_target = $idx++;
 | 
					my $idx_shared_target = $idx++;
 | 
				
			||||||
@@ -653,16 +609,10 @@ my $idx_arflags = $idx++;
 | 
				
			|||||||
my $idx_multilib = $idx++;
 | 
					my $idx_multilib = $idx++;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
my $prefix="";
 | 
					my $prefix="";
 | 
				
			||||||
my $libdir="";
 | 
					 | 
				
			||||||
my $openssldir="";
 | 
					my $openssldir="";
 | 
				
			||||||
my $exe_ext="";
 | 
					my $exe_ext="";
 | 
				
			||||||
my $install_prefix= "$ENV{'INSTALL_PREFIX'}";
 | 
					my $install_prefix="";
 | 
				
			||||||
my $cross_compile_prefix="";
 | 
					my $cross_compile_prefix="";
 | 
				
			||||||
my $fipslibdir="/usr/local/ssl/fips-2.0/lib/";
 | 
					 | 
				
			||||||
my $nofipscanistercheck=0;
 | 
					 | 
				
			||||||
my $fipscanisterinternal="n";
 | 
					 | 
				
			||||||
my $fipscanisteronly = 0;
 | 
					 | 
				
			||||||
my $baseaddr="0xFB00000";
 | 
					 | 
				
			||||||
my $no_threads=0;
 | 
					my $no_threads=0;
 | 
				
			||||||
my $threads=0;
 | 
					my $threads=0;
 | 
				
			||||||
my $no_shared=0; # but "no-shared" is default
 | 
					my $no_shared=0; # but "no-shared" is default
 | 
				
			||||||
@@ -697,42 +647,27 @@ my $cmll_enc="camellia.o cmll_misc.o cmll_cbc.o";
 | 
				
			|||||||
my $processor="";
 | 
					my $processor="";
 | 
				
			||||||
my $default_ranlib;
 | 
					my $default_ranlib;
 | 
				
			||||||
my $perl;
 | 
					my $perl;
 | 
				
			||||||
my $fips=0;
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# All of the following is disabled by default (RC5 was enabled before 0.9.8):
 | 
					# All of the following is disabled by default (RC5 was enabled before 0.9.8):
 | 
				
			||||||
 | 
					
 | 
				
			||||||
my %disabled = ( # "what"         => "comment" [or special keyword "experimental"]
 | 
					my %disabled = ( # "what"         => "comment" [or special keyword "experimental"]
 | 
				
			||||||
		 "ec_nistp_64_gcc_128" => "default",
 | 
					 | 
				
			||||||
		 "gmp"		  => "default",
 | 
							 "gmp"		  => "default",
 | 
				
			||||||
		 "jpake"          => "experimental",
 | 
					                 "jpake"          => "experimental",
 | 
				
			||||||
		 "md2"            => "default",
 | 
					                 "mdc2"           => "default",
 | 
				
			||||||
		 "rc5"            => "default",
 | 
					                 "rc5"            => "default",
 | 
				
			||||||
		 "rfc3779"	  => "default",
 | 
							 "rfc3779"	  => "default",
 | 
				
			||||||
		 "shared"         => "default",
 | 
					                 "shared"         => "default",
 | 
				
			||||||
		 "store"	  => "experimental",
 | 
							 "store"	  => "experimental",
 | 
				
			||||||
		 "zlib"           => "default",
 | 
					                 "zlib"           => "default",
 | 
				
			||||||
		 "zlib-dynamic"   => "default"
 | 
					                 "zlib-dynamic"   => "default"
 | 
				
			||||||
	       );
 | 
					               );
 | 
				
			||||||
my @experimental = ();
 | 
					my @experimental = ();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# If ssl directory missing assume truncated FIPS tarball
 | 
					 | 
				
			||||||
if (!-d "ssl")
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	print STDERR "Auto Configuring fipsonly\n";
 | 
					 | 
				
			||||||
	$fips = 1;
 | 
					 | 
				
			||||||
	$nofipscanistercheck = 1;
 | 
					 | 
				
			||||||
	$fipslibdir="";
 | 
					 | 
				
			||||||
	$fipscanisterinternal="y";
 | 
					 | 
				
			||||||
	$fipscanisteronly = 2;
 | 
					 | 
				
			||||||
	if (! -f "crypto/bn/bn_gf2m.c" )
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		$disabled{ec2m} = "forced";
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# This is what $depflags will look like with the above defaults
 | 
					# This is what $depflags will look like with the above defaults
 | 
				
			||||||
# (we need this to see if we should advise the user to run "make depend"):
 | 
					# (we need this to see if we should advise the user to run "make depend"):
 | 
				
			||||||
my $default_depflags = " -DOPENSSL_NO_EC_NISTP_64_GCC_128 -DOPENSSL_NO_GMP -DOPENSSL_NO_JPAKE -DOPENSSL_NO_MD2 -DOPENSSL_NO_RC5 -DOPENSSL_NO_RFC3779 -DOPENSSL_NO_STORE";
 | 
					my $default_depflags = " -DOPENSSL_NO_GMP -DOPENSSL_NO_JPAKE -DOPENSSL_NO_MDC2 -DOPENSSL_NO_RC5 -DOPENSSL_NO_RFC3779 -DOPENSSL_NO_STORE";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Explicit "no-..." options will be collected in %disabled along with the defaults.
 | 
					# Explicit "no-..." options will be collected in %disabled along with the defaults.
 | 
				
			||||||
# To remove something from %disabled, use "enable-foo" (unless it's experimental).
 | 
					# To remove something from %disabled, use "enable-foo" (unless it's experimental).
 | 
				
			||||||
@@ -830,10 +765,6 @@ PROCESS_ARGS:
 | 
				
			|||||||
			{
 | 
								{
 | 
				
			||||||
			exit(&test_sanity());
 | 
								exit(&test_sanity());
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		elsif (/^--strict-warnings/)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			$strict_warnings = 1;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		elsif (/^reconfigure/ || /^reconf/)
 | 
							elsif (/^reconfigure/ || /^reconf/)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (open(IN,"<$Makefile"))
 | 
								if (open(IN,"<$Makefile"))
 | 
				
			||||||
@@ -859,47 +790,12 @@ PROCESS_ARGS:
 | 
				
			|||||||
			}
 | 
								}
 | 
				
			||||||
		elsif (/^386$/)
 | 
							elsif (/^386$/)
 | 
				
			||||||
			{ $processor=386; }
 | 
								{ $processor=386; }
 | 
				
			||||||
		elsif (/^fips$/)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			$fips=1;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		elsif (/^rsaref$/)
 | 
							elsif (/^rsaref$/)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			# No RSAref support any more since it's not needed.
 | 
								# No RSAref support any more since it's not needed.
 | 
				
			||||||
			# The check for the option is there so scripts aren't
 | 
								# The check for the option is there so scripts aren't
 | 
				
			||||||
			# broken
 | 
								# broken
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		elsif (/^nofipscanistercheck$/)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			$fips = 1;
 | 
					 | 
				
			||||||
			$nofipscanistercheck = 1;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		elsif (/^fipscheck$/)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if ($fipscanisteronly != 2)
 | 
					 | 
				
			||||||
				{
 | 
					 | 
				
			||||||
				print STDERR <<"EOF";
 | 
					 | 
				
			||||||
ERROR: FIPS not autodetected. Not running from restricted tarball??
 | 
					 | 
				
			||||||
EOF
 | 
					 | 
				
			||||||
				exit(1);
 | 
					 | 
				
			||||||
				}
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		elsif (/^fipscanisteronly$/)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			$fips = 1;
 | 
					 | 
				
			||||||
			$nofipscanistercheck = 1;
 | 
					 | 
				
			||||||
			$fipslibdir="";
 | 
					 | 
				
			||||||
			$fipscanisterinternal="y";
 | 
					 | 
				
			||||||
			$fipscanisteronly = 1;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		elsif (/^fipscanisterbuild$/)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			$fips = 1;
 | 
					 | 
				
			||||||
			$nofipscanistercheck = 1;
 | 
					 | 
				
			||||||
			$fipslibdir="";
 | 
					 | 
				
			||||||
			$fipscanisterinternal="y";
 | 
					 | 
				
			||||||
			$fipscanisteronly = 1;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		elsif (/^[-+]/)
 | 
							elsif (/^[-+]/)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (/^-[lL](.*)$/ or /^-Wl,/)
 | 
								if (/^-[lL](.*)$/ or /^-Wl,/)
 | 
				
			||||||
@@ -908,17 +804,12 @@ EOF
 | 
				
			|||||||
				}
 | 
									}
 | 
				
			||||||
			elsif (/^-[^-]/ or /^\+/)
 | 
								elsif (/^-[^-]/ or /^\+/)
 | 
				
			||||||
				{
 | 
									{
 | 
				
			||||||
				$_ =~ s/%([0-9a-f]{1,2})/chr(hex($1))/gei;
 | 
					 | 
				
			||||||
				$flags.=$_." ";
 | 
									$flags.=$_." ";
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
			elsif (/^--prefix=(.*)$/)
 | 
								elsif (/^--prefix=(.*)$/)
 | 
				
			||||||
				{
 | 
									{
 | 
				
			||||||
				$prefix=$1;
 | 
									$prefix=$1;
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
			elsif (/^--libdir=(.*)$/)
 | 
					 | 
				
			||||||
				{
 | 
					 | 
				
			||||||
				$libdir=$1;
 | 
					 | 
				
			||||||
				}
 | 
					 | 
				
			||||||
			elsif (/^--openssldir=(.*)$/)
 | 
								elsif (/^--openssldir=(.*)$/)
 | 
				
			||||||
				{
 | 
									{
 | 
				
			||||||
				$openssldir=$1;
 | 
									$openssldir=$1;
 | 
				
			||||||
@@ -939,14 +830,6 @@ EOF
 | 
				
			|||||||
				{
 | 
									{
 | 
				
			||||||
				$withargs{"zlib-include"}="-I$1";
 | 
									$withargs{"zlib-include"}="-I$1";
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
			elsif (/^--with-fipslibdir=(.*)$/)
 | 
					 | 
				
			||||||
				{
 | 
					 | 
				
			||||||
				$fipslibdir="$1/";
 | 
					 | 
				
			||||||
				}
 | 
					 | 
				
			||||||
			elsif (/^--with-baseaddr=(.*)$/)
 | 
					 | 
				
			||||||
				{
 | 
					 | 
				
			||||||
				$baseaddr="$1";
 | 
					 | 
				
			||||||
				}
 | 
					 | 
				
			||||||
			elsif (/^--cross-compile-prefix=(.*)$/)
 | 
								elsif (/^--cross-compile-prefix=(.*)$/)
 | 
				
			||||||
				{
 | 
									{
 | 
				
			||||||
				$cross_compile_prefix=$1;
 | 
									$cross_compile_prefix=$1;
 | 
				
			||||||
@@ -1035,18 +918,6 @@ if (defined($disabled{"tls1"}))
 | 
				
			|||||||
	$disabled{"tlsext"} = "forced";
 | 
						$disabled{"tlsext"} = "forced";
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if (defined($disabled{"ec"}) || defined($disabled{"dsa"})
 | 
					 | 
				
			||||||
    || defined($disabled{"dh"}))
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	$disabled{"gost"} = "forced";
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# SRP requires TLSEXT
 | 
					 | 
				
			||||||
if (defined($disabled{"tlsext"}))
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	$disabled{"srp"} = "forced";
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
if ($target eq "TABLE") {
 | 
					if ($target eq "TABLE") {
 | 
				
			||||||
	foreach $target (sort keys %table) {
 | 
						foreach $target (sort keys %table) {
 | 
				
			||||||
		print_table_entry($target);
 | 
							print_table_entry($target);
 | 
				
			||||||
@@ -1070,10 +941,6 @@ print "Configuring for $target\n";
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
&usage if (!defined($table{$target}));
 | 
					&usage if (!defined($table{$target}));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if ($fips)
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	delete $disabled{"shared"} if ($disabled{"shared"} eq "default");
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
foreach (sort (keys %disabled))
 | 
					foreach (sort (keys %disabled))
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
@@ -1100,7 +967,7 @@ foreach (sort (keys %disabled))
 | 
				
			|||||||
	else
 | 
						else
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		my ($ALGO, $algo);
 | 
							my ($ALGO, $algo);
 | 
				
			||||||
		($ALGO = $algo = $_) =~ tr/[\-a-z]/[_A-Z]/;
 | 
							($ALGO = $algo = $_) =~ tr/[a-z]/[A-Z]/;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if (/^asm$/ || /^err$/ || /^hw$/ || /^hw-/)
 | 
							if (/^asm$/ || /^err$/ || /^hw$/ || /^hw-/)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
@@ -1131,7 +998,6 @@ foreach (sort (keys %disabled))
 | 
				
			|||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
my $exp_cflags = "";
 | 
					my $exp_cflags = "";
 | 
				
			||||||
 | 
					 | 
				
			||||||
foreach (sort @experimental)
 | 
					foreach (sort @experimental)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
	my $ALGO;
 | 
						my $ALGO;
 | 
				
			||||||
@@ -1147,36 +1013,12 @@ my $IsMK1MF=scalar grep /^$target$/,@MK1MF_Builds;
 | 
				
			|||||||
$exe_ext=".exe" if ($target eq "Cygwin" || $target eq "DJGPP" || $target =~ /^mingw/);
 | 
					$exe_ext=".exe" if ($target eq "Cygwin" || $target eq "DJGPP" || $target =~ /^mingw/);
 | 
				
			||||||
$exe_ext=".nlm" if ($target =~ /netware/);
 | 
					$exe_ext=".nlm" if ($target =~ /netware/);
 | 
				
			||||||
$exe_ext=".pm"  if ($target =~ /vos/);
 | 
					$exe_ext=".pm"  if ($target =~ /vos/);
 | 
				
			||||||
if ($openssldir eq "" and $prefix eq "")
 | 
					$openssldir="/usr/local/ssl" if ($openssldir eq "" and $prefix eq "");
 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	if ($fips)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		if (exists $ENV{FIPSDIR})
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			$openssldir="$ENV{FIPSDIR}";
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		else
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			$openssldir="/usr/local/ssl/fips-2.0";
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	else
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		$openssldir="/usr/local/ssl";
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
$prefix=$openssldir if $prefix eq "";
 | 
					$prefix=$openssldir if $prefix eq "";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
$default_ranlib= &which("ranlib") or $default_ranlib="true";
 | 
					$default_ranlib= &which("ranlib") or $default_ranlib="true";
 | 
				
			||||||
$perl=$ENV{'PERL'} or $perl=&which("perl5") or $perl=&which("perl")
 | 
					$perl=$ENV{'PERL'} or $perl=&which("perl5") or $perl=&which("perl")
 | 
				
			||||||
  or $perl="perl";
 | 
					  or $perl="perl";
 | 
				
			||||||
my $make = $ENV{'MAKE'} || "make";
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
my $fips_auth_key = $ENV{'FIPS_AUTH_KEY'};
 | 
					 | 
				
			||||||
my $fips_auth_officer = $ENV{'FIPS_AUTH_OFFICER'};
 | 
					 | 
				
			||||||
my $fips_auth_user = $ENV{'FIPS_AUTH_USER'};
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
$cross_compile_prefix=$ENV{'CROSS_COMPILE'} if $cross_compile_prefix eq "";
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
chop $openssldir if $openssldir =~ /\/$/;
 | 
					chop $openssldir if $openssldir =~ /\/$/;
 | 
				
			||||||
chop $prefix if $prefix =~ /.\/$/;
 | 
					chop $prefix if $prefix =~ /.\/$/;
 | 
				
			||||||
@@ -1212,27 +1054,16 @@ my $rmd160_obj = $fields[$idx_rmd160_obj];
 | 
				
			|||||||
my $rc5_obj = $fields[$idx_rc5_obj];
 | 
					my $rc5_obj = $fields[$idx_rc5_obj];
 | 
				
			||||||
my $wp_obj = $fields[$idx_wp_obj];
 | 
					my $wp_obj = $fields[$idx_wp_obj];
 | 
				
			||||||
my $cmll_obj = $fields[$idx_cmll_obj];
 | 
					my $cmll_obj = $fields[$idx_cmll_obj];
 | 
				
			||||||
my $modes_obj = $fields[$idx_modes_obj];
 | 
					 | 
				
			||||||
my $engines_obj = $fields[$idx_engines_obj];
 | 
					 | 
				
			||||||
my $perlasm_scheme = $fields[$idx_perlasm_scheme];
 | 
					my $perlasm_scheme = $fields[$idx_perlasm_scheme];
 | 
				
			||||||
my $dso_scheme = $fields[$idx_dso_scheme];
 | 
					my $dso_scheme = $fields[$idx_dso_scheme];
 | 
				
			||||||
my $shared_target = $fields[$idx_shared_target];
 | 
					my $shared_target = $fields[$idx_shared_target];
 | 
				
			||||||
my $shared_cflag = $fields[$idx_shared_cflag];
 | 
					my $shared_cflag = $fields[$idx_shared_cflag];
 | 
				
			||||||
my $shared_ldflag = $fields[$idx_shared_ldflag];
 | 
					my $shared_ldflag = $fields[$idx_shared_ldflag];
 | 
				
			||||||
my $shared_extension = $fields[$idx_shared_extension];
 | 
					my $shared_extension = $fields[$idx_shared_extension];
 | 
				
			||||||
my $ranlib = $ENV{'RANLIB'} || $fields[$idx_ranlib];
 | 
					my $ranlib = $fields[$idx_ranlib];
 | 
				
			||||||
my $ar = $ENV{'AR'} || "ar";
 | 
					 | 
				
			||||||
my $arflags = $fields[$idx_arflags];
 | 
					my $arflags = $fields[$idx_arflags];
 | 
				
			||||||
my $multilib = $fields[$idx_multilib];
 | 
					my $multilib = $fields[$idx_multilib];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# if $prefix/lib$multilib is not an existing directory, then
 | 
					 | 
				
			||||||
# assume that it's not searched by linker automatically, in
 | 
					 | 
				
			||||||
# which case adding $multilib suffix causes more grief than
 | 
					 | 
				
			||||||
# we're ready to tolerate, so don't...
 | 
					 | 
				
			||||||
$multilib="" if !-d "$prefix/lib$multilib";
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
$libdir="lib$multilib" if $libdir eq "";
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
$cflags = "$cflags$exp_cflags";
 | 
					$cflags = "$cflags$exp_cflags";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# '%' in $lflags is used to split flags to "pre-" and post-flags
 | 
					# '%' in $lflags is used to split flags to "pre-" and post-flags
 | 
				
			||||||
@@ -1240,12 +1071,6 @@ my ($prelflags,$postlflags)=split('%',$lflags);
 | 
				
			|||||||
if (defined($postlflags))	{ $lflags=$postlflags;	}
 | 
					if (defined($postlflags))	{ $lflags=$postlflags;	}
 | 
				
			||||||
else				{ $lflags=$prelflags; undef $prelflags;	}
 | 
					else				{ $lflags=$prelflags; undef $prelflags;	}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if ($target =~ /^mingw/ && `$cc --target-help 2>&1` !~ m/\-mno\-cygwin/m)
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	$cflags =~ s/\-mno\-cygwin\s*//;
 | 
					 | 
				
			||||||
	$shared_ldflag =~ s/\-mno\-cygwin\s*//;
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
my $no_shared_warn=0;
 | 
					my $no_shared_warn=0;
 | 
				
			||||||
my $no_user_cflags=0;
 | 
					my $no_user_cflags=0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -1374,13 +1199,7 @@ if ($no_asm)
 | 
				
			|||||||
	{
 | 
						{
 | 
				
			||||||
	$cpuid_obj=$bn_obj=
 | 
						$cpuid_obj=$bn_obj=
 | 
				
			||||||
	$des_obj=$aes_obj=$bf_obj=$cast_obj=$rc4_obj=$rc5_obj=$cmll_obj=
 | 
						$des_obj=$aes_obj=$bf_obj=$cast_obj=$rc4_obj=$rc5_obj=$cmll_obj=
 | 
				
			||||||
	$modes_obj=$sha1_obj=$md5_obj=$rmd160_obj=$wp_obj=$engines_obj="";
 | 
						$sha1_obj=$md5_obj=$rmd160_obj=$wp_obj="";
 | 
				
			||||||
	$cflags=~s/\-D[BL]_ENDIAN//		if ($fips);
 | 
					 | 
				
			||||||
	$thread_cflags=~s/\-D[BL]_ENDIAN//	if ($fips);
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
elsif (defined($disabled{ec2m}))
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	$bn_obj =~ s/\w+-gf2m.o//;
 | 
					 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if (!$no_shared)
 | 
					if (!$no_shared)
 | 
				
			||||||
@@ -1399,14 +1218,7 @@ if ($zlib)
 | 
				
			|||||||
	$cflags = "-DZLIB $cflags";
 | 
						$cflags = "-DZLIB $cflags";
 | 
				
			||||||
	if (defined($disabled{"zlib-dynamic"}))
 | 
						if (defined($disabled{"zlib-dynamic"}))
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		if (defined($withargs{"zlib-lib"}))
 | 
							$lflags = "$lflags -lz";
 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			$lflags = "$lflags -L" . $withargs{"zlib-lib"} . " -lz";
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		else
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			$lflags = "$lflags -lz";
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	else
 | 
						else
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
@@ -1418,7 +1230,7 @@ if ($zlib)
 | 
				
			|||||||
my $shared_mark = "";
 | 
					my $shared_mark = "";
 | 
				
			||||||
if ($shared_target eq "")
 | 
					if ($shared_target eq "")
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
	$no_shared_warn = 1 if !$no_shared && !$fips;
 | 
						$no_shared_warn = 1 if !$no_shared;
 | 
				
			||||||
	$no_shared = 1;
 | 
						$no_shared = 1;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
if (!$no_shared)
 | 
					if (!$no_shared)
 | 
				
			||||||
@@ -1444,7 +1256,7 @@ if (!$IsMK1MF)
 | 
				
			|||||||
		}
 | 
							}
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
$cpuid_obj.=" uplink.o uplink-x86.o" if ($cflags =~ /\-DOPENSSL_USE_APPLINK/);
 | 
					$cpuid_obj.=" uplink.o uplink-cof.o" if ($cflags =~ /\-DOPENSSL_USE_APPLINK/);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
# Platform fix-ups
 | 
					# Platform fix-ups
 | 
				
			||||||
@@ -1512,18 +1324,6 @@ $cflags.=" -DOPENSSL_BN_ASM_PART_WORDS" if ($bn_obj =~ /bn-586/);
 | 
				
			|||||||
$cflags.=" -DOPENSSL_IA32_SSE2" if (!$no_sse2 && $bn_obj =~ /86/);
 | 
					$cflags.=" -DOPENSSL_IA32_SSE2" if (!$no_sse2 && $bn_obj =~ /86/);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
$cflags.=" -DOPENSSL_BN_ASM_MONT" if ($bn_obj =~ /-mont/);
 | 
					$cflags.=" -DOPENSSL_BN_ASM_MONT" if ($bn_obj =~ /-mont/);
 | 
				
			||||||
$cflags.=" -DOPENSSL_BN_ASM_MONT5" if ($bn_obj =~ /-mont5/);
 | 
					 | 
				
			||||||
$cflags.=" -DOPENSSL_BN_ASM_GF2m" if ($bn_obj =~ /-gf2m/);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
if ($fips)
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	$openssl_other_defines.="#define OPENSSL_FIPS\n";
 | 
					 | 
				
			||||||
	if ($fipscanisterinternal eq "y")
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		$openssl_other_defines.="#define OPENSSL_FIPSCANISTER\n";
 | 
					 | 
				
			||||||
		$cflags = "-DOPENSSL_FIPSCANISTER $cflags";
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
$cpuid_obj="mem_clr.o"	unless ($cpuid_obj =~ /\.o$/);
 | 
					$cpuid_obj="mem_clr.o"	unless ($cpuid_obj =~ /\.o$/);
 | 
				
			||||||
$des_obj=$des_enc	unless ($des_obj =~ /\.o$/);
 | 
					$des_obj=$des_enc	unless ($des_obj =~ /\.o$/);
 | 
				
			||||||
@@ -1557,13 +1357,6 @@ if ($rmd160_obj =~ /\.o$/)
 | 
				
			|||||||
if ($aes_obj =~ /\.o$/)
 | 
					if ($aes_obj =~ /\.o$/)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
	$cflags.=" -DAES_ASM";
 | 
						$cflags.=" -DAES_ASM";
 | 
				
			||||||
	# aes_ctr.o is not a real file, only indication that assembler
 | 
					 | 
				
			||||||
	# module implements AES_ctr32_encrypt...
 | 
					 | 
				
			||||||
	$cflags.=" -DAES_CTR_ASM" if ($aes_obj =~ s/\s*aes_ctr\.o//);
 | 
					 | 
				
			||||||
	$aes_obj =~ s/\s*(vpaes|aesni)\-x86\.o//g if ($no_sse2);
 | 
					 | 
				
			||||||
	$aes_obj =~ s/\s*(vp|bs)aes-\w*\.o//g if ($fipscanisterinternal eq "y");
 | 
					 | 
				
			||||||
	$cflags.=" -DVPAES_ASM" if ($aes_obj =~ m/vpaes/);
 | 
					 | 
				
			||||||
	$cflags.=" -DBSAES_ASM" if ($aes_obj =~ m/bsaes/);
 | 
					 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
else	{
 | 
					else	{
 | 
				
			||||||
	$aes_obj=$aes_enc;
 | 
						$aes_obj=$aes_enc;
 | 
				
			||||||
@@ -1577,10 +1370,6 @@ else	{
 | 
				
			|||||||
	$wp_obj="wp_block.o";
 | 
						$wp_obj="wp_block.o";
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
$cmll_obj=$cmll_enc	unless ($cmll_obj =~ /.o$/);
 | 
					$cmll_obj=$cmll_enc	unless ($cmll_obj =~ /.o$/);
 | 
				
			||||||
if ($modes_obj =~ /ghash/)
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	$cflags.=" -DGHASH_ASM";
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
# "Stringify" the C flags string.  This permits it to be made part of a string
 | 
					# "Stringify" the C flags string.  This permits it to be made part of a string
 | 
				
			||||||
# and works as well on command lines.
 | 
					# and works as well on command lines.
 | 
				
			||||||
@@ -1618,45 +1407,11 @@ if ($shlib_version_number =~ /(^[0-9]*)\.([0-9\.]*)/)
 | 
				
			|||||||
	$shlib_minor=$2;
 | 
						$shlib_minor=$2;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if ($strict_warnings)
 | 
					open(IN,'<Makefile.org') || die "unable to read Makefile.org:$!\n";
 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	my $wopt;
 | 
					 | 
				
			||||||
	die "ERROR --strict-warnings requires gcc" unless ($cc =~ /gcc$/);
 | 
					 | 
				
			||||||
	foreach $wopt (split /\s+/, $gcc_devteam_warn)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		$cflags .= " $wopt" unless ($cflags =~ /$wopt/)
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
if ($fipscanisterinternal eq "y")
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	open(IN,"<fips/fips_auth.in") || die "can't open fips_auth.in";
 | 
					 | 
				
			||||||
	open(OUT,">fips/fips_auth.h") || die "can't open fips_auth.h";
 | 
					 | 
				
			||||||
	while(<IN>)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		s/FIPS_AUTH_KEY.*$/FIPS_AUTH_KEY $fips_auth_key/ if defined $fips_auth_key;
 | 
					 | 
				
			||||||
		s/FIPS_AUTH_CRYPTO_OFFICER.*$/FIPS_AUTH_CRYPTO_OFFICER $fips_auth_officer/ if defined $fips_auth_officer;
 | 
					 | 
				
			||||||
		s/FIPS_AUTH_CRYPTO_USER.*$/FIPS_AUTH_CRYPTO_USER $fips_auth_user/ if defined $fips_auth_user;
 | 
					 | 
				
			||||||
		print OUT $_;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	close IN;
 | 
					 | 
				
			||||||
	close OUT;
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
my $mforg = $fipscanisteronly ? "Makefile.fips" : "Makefile.org";
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
open(IN,"<$mforg") || die "unable to read $mforg:$!\n";
 | 
					 | 
				
			||||||
unlink("$Makefile.new") || die "unable to remove old $Makefile.new:$!\n" if -e "$Makefile.new";
 | 
					unlink("$Makefile.new") || die "unable to remove old $Makefile.new:$!\n" if -e "$Makefile.new";
 | 
				
			||||||
open(OUT,">$Makefile.new") || die "unable to create $Makefile.new:$!\n";
 | 
					open(OUT,">$Makefile.new") || die "unable to create $Makefile.new:$!\n";
 | 
				
			||||||
print OUT "### Generated automatically from $mforg by Configure.\n\n";
 | 
					print OUT "### Generated automatically from Makefile.org by Configure.\n\n";
 | 
				
			||||||
my $sdirs=0;
 | 
					my $sdirs=0;
 | 
				
			||||||
 | 
					 | 
				
			||||||
if ($fipscanisteronly)
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	$aes_obj =~ s/aesni-sha1-x86_64.o//;
 | 
					 | 
				
			||||||
	$bn_obj =~ s/modexp512-x86_64.o//;
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
while (<IN>)
 | 
					while (<IN>)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
	chomp;
 | 
						chomp;
 | 
				
			||||||
@@ -1669,9 +1424,7 @@ while (<IN>)
 | 
				
			|||||||
			}
 | 
								}
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	$sdirs = 0 unless /\\$/;
 | 
						$sdirs = 0 unless /\\$/;
 | 
				
			||||||
        s/fips // if (/^DIRS=/ && !$fips);
 | 
					 | 
				
			||||||
        s/engines // if (/^DIRS=/ && $disabled{"engine"});
 | 
					        s/engines // if (/^DIRS=/ && $disabled{"engine"});
 | 
				
			||||||
	s/ccgost// if (/^ENGDIRS=/ && $disabled{"gost"});
 | 
					 | 
				
			||||||
	s/^VERSION=.*/VERSION=$version/;
 | 
						s/^VERSION=.*/VERSION=$version/;
 | 
				
			||||||
	s/^MAJOR=.*/MAJOR=$major/;
 | 
						s/^MAJOR=.*/MAJOR=$major/;
 | 
				
			||||||
	s/^MINOR=.*/MINOR=$minor/;
 | 
						s/^MINOR=.*/MINOR=$minor/;
 | 
				
			||||||
@@ -1683,22 +1436,20 @@ while (<IN>)
 | 
				
			|||||||
	s/^INSTALLTOP=.*$/INSTALLTOP=$prefix/;
 | 
						s/^INSTALLTOP=.*$/INSTALLTOP=$prefix/;
 | 
				
			||||||
	s/^MULTILIB=.*$/MULTILIB=$multilib/;
 | 
						s/^MULTILIB=.*$/MULTILIB=$multilib/;
 | 
				
			||||||
	s/^OPENSSLDIR=.*$/OPENSSLDIR=$openssldir/;
 | 
						s/^OPENSSLDIR=.*$/OPENSSLDIR=$openssldir/;
 | 
				
			||||||
	s/^LIBDIR=.*$/LIBDIR=$libdir/;
 | 
					 | 
				
			||||||
	s/^INSTALL_PREFIX=.*$/INSTALL_PREFIX=$install_prefix/;
 | 
						s/^INSTALL_PREFIX=.*$/INSTALL_PREFIX=$install_prefix/;
 | 
				
			||||||
	s/^PLATFORM=.*$/PLATFORM=$target/;
 | 
						s/^PLATFORM=.*$/PLATFORM=$target/;
 | 
				
			||||||
	s/^OPTIONS=.*$/OPTIONS=$options/;
 | 
						s/^OPTIONS=.*$/OPTIONS=$options/;
 | 
				
			||||||
	s/^CONFIGURE_ARGS=.*$/CONFIGURE_ARGS=$argvstring/;
 | 
						s/^CONFIGURE_ARGS=.*$/CONFIGURE_ARGS=$argvstring/;
 | 
				
			||||||
	if ($cross_compile_prefix)
 | 
						if ($cross_compile_prefix)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		s/^CC=.*$/CROSS_COMPILE= $cross_compile_prefix\nCC= \$\(CROSS_COMPILE\)$cc/;
 | 
							s/^CC=.*$/CROSS_COMPILE_PREFIX= $cross_compile_prefix\nCC= \$\(CROSS_COMPILE_PREFIX\)$cc/;
 | 
				
			||||||
		s/^AR=\s*/AR= \$\(CROSS_COMPILE\)/;
 | 
							s/^AR=\s*/AR= \$\(CROSS_COMPILE_PREFIX\)/;
 | 
				
			||||||
		s/^NM=\s*/NM= \$\(CROSS_COMPILE\)/;
 | 
							s/^NM=\s*/NM= \$\(CROSS_COMPILE_PREFIX\)/;
 | 
				
			||||||
		s/^RANLIB=\s*/RANLIB= \$\(CROSS_COMPILE\)/;
 | 
							s/^RANLIB=\s*/RANLIB= \$\(CROSS_COMPILE_PREFIX\)/;
 | 
				
			||||||
		s/^MAKEDEPPROG=.*$/MAKEDEPPROG= \$\(CROSS_COMPILE\)$cc/ if $cc eq "gcc";
 | 
							s/^MAKEDEPPROG=.*$/MAKEDEPPROG= \$\(CROSS_COMPILE_PREFIX\)$cc/ if $cc eq "gcc";
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	else	{
 | 
						else	{
 | 
				
			||||||
		s/^CC=.*$/CC= $cc/;
 | 
							s/^CC=.*$/CC= $cc/;
 | 
				
			||||||
		s/^AR=\s*ar/AR= $ar/;
 | 
					 | 
				
			||||||
		s/^RANLIB=.*/RANLIB= $ranlib/;
 | 
							s/^RANLIB=.*/RANLIB= $ranlib/;
 | 
				
			||||||
		s/^MAKEDEPPROG=.*$/MAKEDEPPROG= $cc/ if $cc eq "gcc";
 | 
							s/^MAKEDEPPROG=.*$/MAKEDEPPROG= $cc/ if $cc eq "gcc";
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
@@ -1720,8 +1471,6 @@ while (<IN>)
 | 
				
			|||||||
	s/^RMD160_ASM_OBJ=.*$/RMD160_ASM_OBJ= $rmd160_obj/;
 | 
						s/^RMD160_ASM_OBJ=.*$/RMD160_ASM_OBJ= $rmd160_obj/;
 | 
				
			||||||
	s/^WP_ASM_OBJ=.*$/WP_ASM_OBJ= $wp_obj/;
 | 
						s/^WP_ASM_OBJ=.*$/WP_ASM_OBJ= $wp_obj/;
 | 
				
			||||||
	s/^CMLL_ENC=.*$/CMLL_ENC= $cmll_obj/;
 | 
						s/^CMLL_ENC=.*$/CMLL_ENC= $cmll_obj/;
 | 
				
			||||||
	s/^MODES_ASM_OBJ.=*$/MODES_ASM_OBJ= $modes_obj/;
 | 
					 | 
				
			||||||
	s/^ENGINES_ASM_OBJ.=*$/ENGINES_ASM_OBJ= $engines_obj/;
 | 
					 | 
				
			||||||
	s/^PERLASM_SCHEME=.*$/PERLASM_SCHEME= $perlasm_scheme/;
 | 
						s/^PERLASM_SCHEME=.*$/PERLASM_SCHEME= $perlasm_scheme/;
 | 
				
			||||||
	s/^PROCESSOR=.*/PROCESSOR= $processor/;
 | 
						s/^PROCESSOR=.*/PROCESSOR= $processor/;
 | 
				
			||||||
	s/^ARFLAGS=.*/ARFLAGS= $arflags/;
 | 
						s/^ARFLAGS=.*/ARFLAGS= $arflags/;
 | 
				
			||||||
@@ -1730,12 +1479,6 @@ while (<IN>)
 | 
				
			|||||||
	s/^LIBKRB5=.*/LIBKRB5=$withargs{"krb5-lib"}/;
 | 
						s/^LIBKRB5=.*/LIBKRB5=$withargs{"krb5-lib"}/;
 | 
				
			||||||
	s/^LIBZLIB=.*/LIBZLIB=$withargs{"zlib-lib"}/;
 | 
						s/^LIBZLIB=.*/LIBZLIB=$withargs{"zlib-lib"}/;
 | 
				
			||||||
	s/^ZLIB_INCLUDE=.*/ZLIB_INCLUDE=$withargs{"zlib-include"}/;
 | 
						s/^ZLIB_INCLUDE=.*/ZLIB_INCLUDE=$withargs{"zlib-include"}/;
 | 
				
			||||||
	s/^FIPSLIBDIR=.*/FIPSLIBDIR=$fipslibdir/;
 | 
					 | 
				
			||||||
	s/^FIPSCANLIB=.*/FIPSCANLIB=libcrypto/ if $fips;
 | 
					 | 
				
			||||||
	s/^SHARED_FIPS=.*/SHARED_FIPS=/;
 | 
					 | 
				
			||||||
	s/^SHLIBDIRS=.*/SHLIBDIRS= crypto ssl/;
 | 
					 | 
				
			||||||
	s/^FIPSCANISTERINTERNAL=.*/FIPSCANISTERINTERNAL=$fipscanisterinternal/;
 | 
					 | 
				
			||||||
	s/^BASEADDR=.*/BASEADDR=$baseaddr/;
 | 
					 | 
				
			||||||
	s/^SHLIB_TARGET=.*/SHLIB_TARGET=$shared_target/;
 | 
						s/^SHLIB_TARGET=.*/SHLIB_TARGET=$shared_target/;
 | 
				
			||||||
	s/^SHLIB_MARK=.*/SHLIB_MARK=$shared_mark/;
 | 
						s/^SHLIB_MARK=.*/SHLIB_MARK=$shared_mark/;
 | 
				
			||||||
	s/^SHARED_LIBS=.*/SHARED_LIBS=\$(SHARED_CRYPTO) \$(SHARED_SSL)/ if (!$no_shared);
 | 
						s/^SHARED_LIBS=.*/SHARED_LIBS=\$(SHARED_CRYPTO) \$(SHARED_SSL)/ if (!$no_shared);
 | 
				
			||||||
@@ -1758,10 +1501,6 @@ while (<IN>)
 | 
				
			|||||||
		s/^SHARED_LIBS_LINK_EXTS=.*/SHARED_LIBS_LINK_EXTS=.\$(SHLIB_MAJOR).dylib .dylib/;
 | 
							s/^SHARED_LIBS_LINK_EXTS=.*/SHARED_LIBS_LINK_EXTS=.\$(SHLIB_MAJOR).dylib .dylib/;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	s/^SHARED_LDFLAGS=.*/SHARED_LDFLAGS=$shared_ldflag/;
 | 
						s/^SHARED_LDFLAGS=.*/SHARED_LDFLAGS=$shared_ldflag/;
 | 
				
			||||||
	if ($fipscanisteronly && exists $disabled{"ec2m"})
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		next if (/ec2_/ || /bn_gf2m/);
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	print OUT $_."\n";
 | 
						print OUT $_."\n";
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
close(IN);
 | 
					close(IN);
 | 
				
			||||||
@@ -1783,9 +1522,7 @@ print "RC5_ENC       =$rc5_obj\n";
 | 
				
			|||||||
print "MD5_OBJ_ASM   =$md5_obj\n";
 | 
					print "MD5_OBJ_ASM   =$md5_obj\n";
 | 
				
			||||||
print "SHA1_OBJ_ASM  =$sha1_obj\n";
 | 
					print "SHA1_OBJ_ASM  =$sha1_obj\n";
 | 
				
			||||||
print "RMD160_OBJ_ASM=$rmd160_obj\n";
 | 
					print "RMD160_OBJ_ASM=$rmd160_obj\n";
 | 
				
			||||||
print "CMLL_ENC      =$cmll_obj\n";
 | 
					print "CMLL_ENC=     =$cmll_obj\n";
 | 
				
			||||||
print "MODES_OBJ     =$modes_obj\n";
 | 
					 | 
				
			||||||
print "ENGINES_OBJ   =$engines_obj\n";
 | 
					 | 
				
			||||||
print "PROCESSOR     =$processor\n";
 | 
					print "PROCESSOR     =$processor\n";
 | 
				
			||||||
print "RANLIB        =$ranlib\n";
 | 
					print "RANLIB        =$ranlib\n";
 | 
				
			||||||
print "ARFLAGS       =$arflags\n";
 | 
					print "ARFLAGS       =$arflags\n";
 | 
				
			||||||
@@ -1885,7 +1622,10 @@ while (<IN>)
 | 
				
			|||||||
		}
 | 
							}
 | 
				
			||||||
	elsif	(/^#define\s+ENGINESDIR/)
 | 
						elsif	(/^#define\s+ENGINESDIR/)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		my $foo = "$prefix/$libdir/engines";
 | 
							# $foo is to become "$prefix/lib$multilib/engines";
 | 
				
			||||||
 | 
							# as Makefile.org and engines/Makefile are adapted for
 | 
				
			||||||
 | 
							# $multilib suffix.
 | 
				
			||||||
 | 
							my $foo = "$prefix/lib/engines";
 | 
				
			||||||
		$foo =~ s/\\/\\\\/g;
 | 
							$foo =~ s/\\/\\\\/g;
 | 
				
			||||||
		print OUT "#define ENGINESDIR \"$foo\"\n";
 | 
							print OUT "#define ENGINESDIR \"$foo\"\n";
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
@@ -1993,24 +1733,22 @@ if($IsMK1MF) {
 | 
				
			|||||||
EOF
 | 
					EOF
 | 
				
			||||||
	close(OUT);
 | 
						close(OUT);
 | 
				
			||||||
} else {
 | 
					} else {
 | 
				
			||||||
	my $make_command = "$make PERL=\'$perl\'";
 | 
						my $make_command = "make PERL=\'$perl\'";
 | 
				
			||||||
	my $make_targets = "";
 | 
						my $make_targets = "";
 | 
				
			||||||
	$make_targets .= " links" if $symlink;
 | 
						$make_targets .= " links" if $symlink;
 | 
				
			||||||
	$make_targets .= " depend" if $depflags ne $default_depflags && $make_depend;
 | 
						$make_targets .= " depend" if $depflags ne $default_depflags && $make_depend;
 | 
				
			||||||
	$make_targets .= " gentests" if $symlink;
 | 
						$make_targets .= " gentests" if $symlink;
 | 
				
			||||||
	(system $make_command.$make_targets) == 0 or exit $?
 | 
						(system $make_command.$make_targets) == 0 or exit $?
 | 
				
			||||||
		if $make_targets ne "";
 | 
							if $make_targets ne "";
 | 
				
			||||||
	if ( $fipscanisteronly )
 | 
						if ( $perl =~ m@^/@) {
 | 
				
			||||||
		{}
 | 
						    &dofile("tools/c_rehash",$perl,'^#!/', '#!%s','^my \$dir;$', 'my $dir = "' . $openssldir . '";');
 | 
				
			||||||
	elsif ( $perl =~ m@^/@) {
 | 
					 | 
				
			||||||
	    &dofile("tools/c_rehash",$perl,'^#!/', '#!%s','^my \$dir;$', 'my $dir = "' . $openssldir . '";', '^my \$prefix;$', 'my $prefix = "' . $prefix . '";');
 | 
					 | 
				
			||||||
	    &dofile("apps/CA.pl",$perl,'^#!/', '#!%s');
 | 
						    &dofile("apps/CA.pl",$perl,'^#!/', '#!%s');
 | 
				
			||||||
	} else {
 | 
						} else {
 | 
				
			||||||
	    # No path for Perl known ...
 | 
						    # No path for Perl known ...
 | 
				
			||||||
	    &dofile("tools/c_rehash",'/usr/local/bin/perl','^#!/', '#!%s','^my \$dir;$', 'my $dir = "' . $openssldir . '";',  '^my \$prefix;$', 'my $prefix = "' . $prefix . '";');
 | 
						    &dofile("tools/c_rehash",'/usr/local/bin/perl','^#!/', '#!%s','^my \$dir;$', 'my $dir = "' . $openssldir . '";');
 | 
				
			||||||
	    &dofile("apps/CA.pl",'/usr/local/bin/perl','^#!/', '#!%s');
 | 
						    &dofile("apps/CA.pl",'/usr/local/bin/perl','^#!/', '#!%s');
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	if ($depflags ne $default_depflags && !$make_depend && !$fipscanisteronly) {
 | 
						if ($depflags ne $default_depflags && !$make_depend) {
 | 
				
			||||||
		print <<EOF;
 | 
							print <<EOF;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
Since you've disabled or enabled at least one algorithm, you need to do
 | 
					Since you've disabled or enabled at least one algorithm, you need to do
 | 
				
			||||||
@@ -2053,16 +1791,9 @@ BEGIN
 | 
				
			|||||||
    BEGIN
 | 
					    BEGIN
 | 
				
			||||||
	BLOCK "040904b0"
 | 
						BLOCK "040904b0"
 | 
				
			||||||
	BEGIN
 | 
						BEGIN
 | 
				
			||||||
#if defined(FIPS)
 | 
					 | 
				
			||||||
	    VALUE "Comments", "WARNING: TEST VERSION ONLY ***NOT*** FIPS 140-2 VALIDATED.\\0"
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	    // Required:	    
 | 
						    // Required:	    
 | 
				
			||||||
	    VALUE "CompanyName", "The OpenSSL Project, http://www.openssl.org/\\0"
 | 
						    VALUE "CompanyName", "The OpenSSL Project, http://www.openssl.org/\\0"
 | 
				
			||||||
#if defined(FIPS)
 | 
					 | 
				
			||||||
	    VALUE "FileDescription", "TEST UNVALIDATED FIPS140-2 DLL\\0"
 | 
					 | 
				
			||||||
#else
 | 
					 | 
				
			||||||
	    VALUE "FileDescription", "OpenSSL Shared Library\\0"
 | 
						    VALUE "FileDescription", "OpenSSL Shared Library\\0"
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	    VALUE "FileVersion", "$version\\0"
 | 
						    VALUE "FileVersion", "$version\\0"
 | 
				
			||||||
#if defined(CRYPTO)
 | 
					#if defined(CRYPTO)
 | 
				
			||||||
	    VALUE "InternalName", "libeay32\\0"
 | 
						    VALUE "InternalName", "libeay32\\0"
 | 
				
			||||||
@@ -2070,9 +1801,6 @@ BEGIN
 | 
				
			|||||||
#elif defined(SSL)
 | 
					#elif defined(SSL)
 | 
				
			||||||
	    VALUE "InternalName", "ssleay32\\0"
 | 
						    VALUE "InternalName", "ssleay32\\0"
 | 
				
			||||||
	    VALUE "OriginalFilename", "ssleay32.dll\\0"
 | 
						    VALUE "OriginalFilename", "ssleay32.dll\\0"
 | 
				
			||||||
#elif defined(FIPS)
 | 
					 | 
				
			||||||
	    VALUE "InternalName", "libosslfips\\0"
 | 
					 | 
				
			||||||
	    VALUE "OriginalFilename", "libosslfips.dll\\0"
 | 
					 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
	    VALUE "ProductName", "The OpenSSL Toolkit\\0"
 | 
						    VALUE "ProductName", "The OpenSSL Toolkit\\0"
 | 
				
			||||||
	    VALUE "ProductVersion", "$version\\0"
 | 
						    VALUE "ProductVersion", "$version\\0"
 | 
				
			||||||
@@ -2115,21 +1843,6 @@ libraries on this platform, they will at least look at it and try their best
 | 
				
			|||||||
(but please first make sure you have tried with a current version of OpenSSL).
 | 
					(but please first make sure you have tried with a current version of OpenSSL).
 | 
				
			||||||
EOF
 | 
					EOF
 | 
				
			||||||
 | 
					
 | 
				
			||||||
print <<\EOF if ($fipscanisterinternal eq "y");
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
WARNING: OpenSSL has been configured using unsupported option(s) to internally
 | 
					 | 
				
			||||||
generate a fipscanister.o object module for TESTING PURPOSES ONLY; that
 | 
					 | 
				
			||||||
compiled module is NOT FIPS 140-2 validated and CANNOT be used to replace the
 | 
					 | 
				
			||||||
OpenSSL FIPS Object Module as identified by the CMVP
 | 
					 | 
				
			||||||
(http://csrc.nist.gov/cryptval/) in any application requiring the use of FIPS
 | 
					 | 
				
			||||||
140-2 validated software. 
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
This is a test OpenSSL 2.0 FIPS module.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
See the file README.FIPS for details of how to build a test library.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
EOF
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
exit(0);
 | 
					exit(0);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
sub usage
 | 
					sub usage
 | 
				
			||||||
@@ -2205,8 +1918,7 @@ sub print_table_entry
 | 
				
			|||||||
	(my $cc,my $cflags,my $unistd,my $thread_cflag,my $sys_id,my $lflags,
 | 
						(my $cc,my $cflags,my $unistd,my $thread_cflag,my $sys_id,my $lflags,
 | 
				
			||||||
	my $bn_ops,my $cpuid_obj,my $bn_obj,my $des_obj,my $aes_obj, my $bf_obj,
 | 
						my $bn_ops,my $cpuid_obj,my $bn_obj,my $des_obj,my $aes_obj, my $bf_obj,
 | 
				
			||||||
	my $md5_obj,my $sha1_obj,my $cast_obj,my $rc4_obj,my $rmd160_obj,
 | 
						my $md5_obj,my $sha1_obj,my $cast_obj,my $rc4_obj,my $rmd160_obj,
 | 
				
			||||||
	my $rc5_obj,my $wp_obj,my $cmll_obj,my $modes_obj, my $engines_obj,
 | 
						my $rc5_obj,my $wp_obj,my $cmll_obj,my $perlasm_scheme,my $dso_scheme,my $shared_target,my $shared_cflag,
 | 
				
			||||||
	my $perlasm_scheme,my $dso_scheme,my $shared_target,my $shared_cflag,
 | 
					 | 
				
			||||||
	my $shared_ldflag,my $shared_extension,my $ranlib,my $arflags,my $multilib)=
 | 
						my $shared_ldflag,my $shared_extension,my $ranlib,my $arflags,my $multilib)=
 | 
				
			||||||
	split(/\s*:\s*/,$table{$target} . ":" x 30 , -1);
 | 
						split(/\s*:\s*/,$table{$target} . ":" x 30 , -1);
 | 
				
			||||||
			
 | 
								
 | 
				
			||||||
@@ -2233,8 +1945,6 @@ sub print_table_entry
 | 
				
			|||||||
\$rc5_obj      = $rc5_obj
 | 
					\$rc5_obj      = $rc5_obj
 | 
				
			||||||
\$wp_obj       = $wp_obj
 | 
					\$wp_obj       = $wp_obj
 | 
				
			||||||
\$cmll_obj     = $cmll_obj
 | 
					\$cmll_obj     = $cmll_obj
 | 
				
			||||||
\$modes_obj    = $modes_obj
 | 
					 | 
				
			||||||
\$engines_obj  = $engines_obj
 | 
					 | 
				
			||||||
\$perlasm_scheme = $perlasm_scheme
 | 
					\$perlasm_scheme = $perlasm_scheme
 | 
				
			||||||
\$dso_scheme   = $dso_scheme
 | 
					\$dso_scheme   = $dso_scheme
 | 
				
			||||||
\$shared_target= $shared_target
 | 
					\$shared_target= $shared_target
 | 
				
			||||||
@@ -2260,23 +1970,23 @@ sub test_sanity
 | 
				
			|||||||
		{
 | 
							{
 | 
				
			||||||
		@fields = split(/\s*:\s*/,$table{$target} . ":" x 30 , -1);
 | 
							@fields = split(/\s*:\s*/,$table{$target} . ":" x 30 , -1);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if ($fields[$idx_dso_scheme-1] =~ /^(beos|dl|dlfcn|win32|vms)$/)
 | 
							if ($fields[$idx_dso_scheme-1] =~ /^(dl|dlfcn|win32|vms)$/)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			$errorcnt++;
 | 
								$errorcnt++;
 | 
				
			||||||
			print STDERR "SANITY ERROR: '$target' has the dso_scheme [$idx_dso_scheme] values\n";
 | 
								print STDERR "SANITY ERROR: '$target' has the dso_scheme [$idx_dso_scheme] values\n";
 | 
				
			||||||
			print STDERR "              in the previous field\n";
 | 
								print STDERR "              in the previous field\n";
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		elsif ($fields[$idx_dso_scheme+1] =~ /^(beos|dl|dlfcn|win32|vms)$/)
 | 
							elsif ($fields[$idx_dso_scheme+1] =~ /^(dl|dlfcn|win32|vms)$/)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			$errorcnt++;
 | 
								$errorcnt++;
 | 
				
			||||||
			print STDERR "SANITY ERROR: '$target' has the dso_scheme [$idx_dso_scheme] values\n";
 | 
								print STDERR "SANITY ERROR: '$target' has the dso_scheme [$idx_dso_scheme] values\n";
 | 
				
			||||||
			print STDERR "              in the following field\n";
 | 
								print STDERR "              in the following field\n";
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		elsif ($fields[$idx_dso_scheme] !~ /^(beos|dl|dlfcn|win32|vms|)$/)
 | 
							elsif ($fields[$idx_dso_scheme] !~ /^(dl|dlfcn|win32|vms|)$/)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			$errorcnt++;
 | 
								$errorcnt++;
 | 
				
			||||||
			print STDERR "SANITY ERROR: '$target' has the dso_scheme [$idx_dso_scheme] field = ",$fields[$idx_dso_scheme],"\n";
 | 
								print STDERR "SANITY ERROR: '$target' has the dso_scheme [$idx_dso_scheme] field = ",$fields[$idx_dso_scheme],"\n";
 | 
				
			||||||
			print STDERR "              valid values are 'beos', 'dl', 'dlfcn', 'win32' and 'vms'\n";
 | 
								print STDERR "              valid values are 'dl', 'dlfcn', 'win32' and 'vms'\n";
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	print STDERR "No sanity errors detected!\n" if $errorcnt == 0;
 | 
						print STDERR "No sanity errors detected!\n" if $errorcnt == 0;
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										76
									
								
								FAQ
									
									
									
									
									
								
							
							
						
						
									
										76
									
								
								FAQ
									
									
									
									
									
								
							@@ -52,9 +52,6 @@ OpenSSL  -  Frequently Asked Questions
 | 
				
			|||||||
* Why does the OpenSSL test suite fail in sha512t on x86 CPU?
 | 
					* Why does the OpenSSL test suite fail in sha512t on x86 CPU?
 | 
				
			||||||
* Why does compiler fail to compile sha512.c?
 | 
					* Why does compiler fail to compile sha512.c?
 | 
				
			||||||
* Test suite still fails, what to do?
 | 
					* Test suite still fails, what to do?
 | 
				
			||||||
* I think I've found a bug, what should I do?
 | 
					 | 
				
			||||||
* I'm SURE I've found a bug, how do I report it?
 | 
					 | 
				
			||||||
* I've found a security issue, how do I report it?
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
[PROG] Questions about programming with OpenSSL
 | 
					[PROG] Questions about programming with OpenSSL
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -73,7 +70,6 @@ OpenSSL  -  Frequently Asked Questions
 | 
				
			|||||||
* I think I've detected a memory leak, is this a bug?
 | 
					* I think I've detected a memory leak, is this a bug?
 | 
				
			||||||
* Why does Valgrind complain about the use of uninitialized data?
 | 
					* Why does Valgrind complain about the use of uninitialized data?
 | 
				
			||||||
* Why doesn't a memory BIO work when a file does?
 | 
					* Why doesn't a memory BIO work when a file does?
 | 
				
			||||||
* Where are the declarations and implementations of d2i_X509() etc?
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
===============================================================================
 | 
					===============================================================================
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -82,7 +78,7 @@ OpenSSL  -  Frequently Asked Questions
 | 
				
			|||||||
* Which is the current version of OpenSSL?
 | 
					* Which is the current version of OpenSSL?
 | 
				
			||||||
 | 
					
 | 
				
			||||||
The current version is available from <URL: http://www.openssl.org>.
 | 
					The current version is available from <URL: http://www.openssl.org>.
 | 
				
			||||||
OpenSSL 1.0.0e was released on Sep 6th, 2011.
 | 
					OpenSSL 0.9.8k was released on Mar 25th, 2009.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
In addition to the current stable release, you can also access daily
 | 
					In addition to the current stable release, you can also access daily
 | 
				
			||||||
snapshots of the OpenSSL development version at <URL:
 | 
					snapshots of the OpenSSL development version at <URL:
 | 
				
			||||||
@@ -98,17 +94,14 @@ explains how to install this library.
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
OpenSSL includes a command line utility that can be used to perform a
 | 
					OpenSSL includes a command line utility that can be used to perform a
 | 
				
			||||||
variety of cryptographic functions.  It is described in the openssl(1)
 | 
					variety of cryptographic functions.  It is described in the openssl(1)
 | 
				
			||||||
manpage.  Documentation for developers is currently being written. Many
 | 
					manpage.  Documentation for developers is currently being written.  A
 | 
				
			||||||
manual pages are available; overviews over libcrypto and
 | 
					few manual pages already are available; overviews over libcrypto and
 | 
				
			||||||
libssl are given in the crypto(3) and ssl(3) manpages.
 | 
					libssl are given in the crypto(3) and ssl(3) manpages.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
The OpenSSL manpages are installed in /usr/local/ssl/man/ (or a
 | 
					The OpenSSL manpages are installed in /usr/local/ssl/man/ (or a
 | 
				
			||||||
different directory if you specified one as described in INSTALL).
 | 
					different directory if you specified one as described in INSTALL).
 | 
				
			||||||
In addition, you can read the most current versions at
 | 
					In addition, you can read the most current versions at
 | 
				
			||||||
<URL: http://www.openssl.org/docs/>. Note that the online documents refer
 | 
					<URL: http://www.openssl.org/docs/>.
 | 
				
			||||||
to the very latest development versions of OpenSSL and may include features
 | 
					 | 
				
			||||||
not present in released versions. If in doubt refer to the documentation
 | 
					 | 
				
			||||||
that came with the version of OpenSSL you are using.
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
For information on parts of libcrypto that are not yet documented, you
 | 
					For information on parts of libcrypto that are not yet documented, you
 | 
				
			||||||
might want to read Ariel Glenn's documentation on SSLeay 0.9, OpenSSL's
 | 
					might want to read Ariel Glenn's documentation on SSLeay 0.9, OpenSSL's
 | 
				
			||||||
@@ -134,7 +127,7 @@ OpenSSL.  Information on the OpenSSL mailing lists is available from
 | 
				
			|||||||
* Where can I get a compiled version of OpenSSL?
 | 
					* Where can I get a compiled version of OpenSSL?
 | 
				
			||||||
 | 
					
 | 
				
			||||||
You can finder pointers to binary distributions in
 | 
					You can finder pointers to binary distributions in
 | 
				
			||||||
<URL: http://www.openssl.org/related/binaries.html> .
 | 
					http://www.openssl.org/related/binaries.html .
 | 
				
			||||||
 | 
					
 | 
				
			||||||
Some applications that use OpenSSL are distributed in binary form.
 | 
					Some applications that use OpenSSL are distributed in binary form.
 | 
				
			||||||
When using such an application, you don't need to install OpenSSL
 | 
					When using such an application, you don't need to install OpenSSL
 | 
				
			||||||
@@ -466,7 +459,7 @@ administrators.
 | 
				
			|||||||
Other projects do have other policies so you can for example extract the CA
 | 
					Other projects do have other policies so you can for example extract the CA
 | 
				
			||||||
bundle used by Mozilla and/or modssl as described in this article:
 | 
					bundle used by Mozilla and/or modssl as described in this article:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  <URL: http://www.mail-archive.com/modssl-users@modssl.org/msg16980.html>
 | 
					  http://www.mail-archive.com/modssl-users@modssl.org/msg16980.html
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
[BUILD] =======================================================================
 | 
					[BUILD] =======================================================================
 | 
				
			||||||
@@ -508,7 +501,7 @@ when you run the test suite (using "make test").  The message returned is
 | 
				
			|||||||
"bc: 1 not implemented".
 | 
					"bc: 1 not implemented".
 | 
				
			||||||
 | 
					
 | 
				
			||||||
The best way to deal with this is to find another implementation of bc
 | 
					The best way to deal with this is to find another implementation of bc
 | 
				
			||||||
and compile/install it.  GNU bc (see <URL: http://www.gnu.org/software/software.html>
 | 
					and compile/install it.  GNU bc (see http://www.gnu.org/software/software.html
 | 
				
			||||||
for download instructions) can be safely used, for example.
 | 
					for download instructions) can be safely used, for example.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -519,7 +512,7 @@ that the OpenSSL bntest throws at it.  This gets triggered when you run the
 | 
				
			|||||||
test suite (using "make test").  The message returned is "bc: stack empty".
 | 
					test suite (using "make test").  The message returned is "bc: stack empty".
 | 
				
			||||||
 | 
					
 | 
				
			||||||
The best way to deal with this is to find another implementation of bc
 | 
					The best way to deal with this is to find another implementation of bc
 | 
				
			||||||
and compile/install it.  GNU bc (see <URL: http://www.gnu.org/software/software.html>
 | 
					and compile/install it.  GNU bc (see http://www.gnu.org/software/software.html
 | 
				
			||||||
for download instructions) can be safely used, for example.
 | 
					for download instructions) can be safely used, for example.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -712,46 +705,6 @@ never make sense, and tend to emerge when you least expect them. In order
 | 
				
			|||||||
to identify one, drop optimization level, e.g. by editing CFLAG line in
 | 
					to identify one, drop optimization level, e.g. by editing CFLAG line in
 | 
				
			||||||
top-level Makefile, recompile and re-run the test.
 | 
					top-level Makefile, recompile and re-run the test.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
* I think I've found a bug, what should I do?
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
If you are a new user then it is quite likely you haven't found a bug and
 | 
					 | 
				
			||||||
something is happening you aren't familiar with. Check this FAQ, the associated
 | 
					 | 
				
			||||||
documentation and the mailing lists for similar queries. If you are still
 | 
					 | 
				
			||||||
unsure whether it is a bug or not submit a query to the openssl-users mailing
 | 
					 | 
				
			||||||
list.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
* I'm SURE I've found a bug, how do I report it?
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
Bug reports with no security implications should be sent to the request
 | 
					 | 
				
			||||||
tracker. This can be done by mailing the report to <rt@openssl.org> (or its
 | 
					 | 
				
			||||||
alias <openssl-bugs@openssl.org>), please note that messages sent to the
 | 
					 | 
				
			||||||
request tracker also appear in the public openssl-dev mailing list.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
The report should be in plain text. Any patches should be sent as
 | 
					 | 
				
			||||||
plain text attachments because some mailers corrupt patches sent inline.
 | 
					 | 
				
			||||||
If your issue affects multiple versions of OpenSSL check any patches apply
 | 
					 | 
				
			||||||
cleanly and, if possible include patches to each affected version.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
The report should be given a meaningful subject line briefly summarising the
 | 
					 | 
				
			||||||
issue. Just "bug in OpenSSL" or "bug in OpenSSL 0.9.8n" is not very helpful.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
By sending reports to the request tracker the bug can then be given a priority
 | 
					 | 
				
			||||||
and assigned to the appropriate maintainer. The history of discussions can be
 | 
					 | 
				
			||||||
accessed and if the issue has been addressed or a reason why not. If patches
 | 
					 | 
				
			||||||
are only sent to openssl-dev they can be mislaid if a team member has to
 | 
					 | 
				
			||||||
wade through months of old messages to review the discussion.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
See also <URL: http://www.openssl.org/support/rt.html>
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
* I've found a security issue, how do I report it?
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
If you think your bug has security implications then please send it to
 | 
					 | 
				
			||||||
openssl-security@openssl.org if you don't get a prompt reply at least 
 | 
					 | 
				
			||||||
acknowledging receipt then resend or mail it directly to one of the
 | 
					 | 
				
			||||||
more active team members (e.g. Steve).
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
[PROG] ========================================================================
 | 
					[PROG] ========================================================================
 | 
				
			||||||
 | 
					
 | 
				
			||||||
* Is OpenSSL thread-safe?
 | 
					* Is OpenSSL thread-safe?
 | 
				
			||||||
@@ -765,7 +718,7 @@ file.
 | 
				
			|||||||
Multi-threaded applications must provide two callback functions to
 | 
					Multi-threaded applications must provide two callback functions to
 | 
				
			||||||
OpenSSL by calling CRYPTO_set_locking_callback() and
 | 
					OpenSSL by calling CRYPTO_set_locking_callback() and
 | 
				
			||||||
CRYPTO_set_id_callback(), for all versions of OpenSSL up to and
 | 
					CRYPTO_set_id_callback(), for all versions of OpenSSL up to and
 | 
				
			||||||
including 0.9.8[abc...]. As of version 1.0.0, CRYPTO_set_id_callback()
 | 
					including 0.9.8[abc...]. As of version 0.9.9, CRYPTO_set_id_callback()
 | 
				
			||||||
and associated APIs are deprecated by CRYPTO_THREADID_set_callback()
 | 
					and associated APIs are deprecated by CRYPTO_THREADID_set_callback()
 | 
				
			||||||
and friends. This is described in the threads(3) manpage.
 | 
					and friends. This is described in the threads(3) manpage.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -1011,15 +964,4 @@ is needed. This must be done by calling:
 | 
				
			|||||||
See the manual pages for more details.
 | 
					See the manual pages for more details.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
* Where are the declarations and implementations of d2i_X509() etc?
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
These are defined and implemented by macros of the form:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 DECLARE_ASN1_FUNCTIONS(X509) and IMPLEMENT_ASN1_FUNCTIONS(X509)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
The implementation passes an ASN1 "template" defining the structure into an
 | 
					 | 
				
			||||||
ASN1 interpreter using generalised functions such as ASN1_item_d2i().
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
===============================================================================
 | 
					===============================================================================
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										52
									
								
								INSTALL.VMS
									
									
									
									
									
								
							
							
						
						
									
										52
									
								
								INSTALL.VMS
									
									
									
									
									
								
							@@ -71,7 +71,7 @@ the top to understand how to use them.  However, if you want to
 | 
				
			|||||||
compile all you can get, the simplest is to use MAKEVMS.COM in the top
 | 
					compile all you can get, the simplest is to use MAKEVMS.COM in the top
 | 
				
			||||||
directory.  The syntax is the following:
 | 
					directory.  The syntax is the following:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  @MAKEVMS <option> <bits> <debug-p> [<compiler>]
 | 
					  @MAKEVMS <option> <rsaref-p> <debug-p> [<compiler>]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<option> must be one of the following:
 | 
					<option> must be one of the following:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -87,11 +87,24 @@ directory.  The syntax is the following:
 | 
				
			|||||||
      TEST      Just build the "[.xxx.EXE.TEST]" test programs for OpenSSL.
 | 
					      TEST      Just build the "[.xxx.EXE.TEST]" test programs for OpenSSL.
 | 
				
			||||||
      APPS      Just build the "[.xxx.EXE.APPS]" application programs for OpenSSL.
 | 
					      APPS      Just build the "[.xxx.EXE.APPS]" application programs for OpenSSL.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<bits> must be one of the following:
 | 
					<rsaref-p> must be one of the following:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      ""        compile using default pointer size
 | 
					      RSAREF    compile using the RSAREF Library
 | 
				
			||||||
      32        compile using 32 bit pointer size
 | 
					      NORSAREF  compile without using RSAREF
 | 
				
			||||||
      64        compile using 64 bit pointer size
 | 
					
 | 
				
			||||||
 | 
					Note 0: The RSAREF library IS NO LONGER NEEDED.  The RSA patent
 | 
				
			||||||
 | 
					        expires September 20, 2000, and RSA Security chose to make
 | 
				
			||||||
 | 
					        the algorithm public domain two weeks before that.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Note 1: If you still want to use RSAREF, the library is NOT INCLUDED
 | 
				
			||||||
 | 
					        and you have to download it.  RSA Security doesn't carry it
 | 
				
			||||||
 | 
					        any more, but there are a number of places where you can find
 | 
				
			||||||
 | 
					        it.  You have to get the ".tar-Z" file as the ".zip" file
 | 
				
			||||||
 | 
					        doesn't have the directory structure stored.  You have to
 | 
				
			||||||
 | 
					        extract the file into the [.RSAREF] directory as that is where
 | 
				
			||||||
 | 
					        the scripts will look for the files.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Note 2: I have never done this, so I've no idea if it works or not.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<debug-p> must be one of the following:
 | 
					<debug-p> must be one of the following:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -104,13 +117,12 @@ directory.  The syntax is the following:
 | 
				
			|||||||
      GNUC      For GNU C.
 | 
					      GNUC      For GNU C.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
You will find the crypto library in [.xxx.EXE.CRYPTO] (where xxx is VAX,
 | 
					You will find the crypto library in [.xxx.EXE.CRYPTO], called LIBCRYPTO.OLB,
 | 
				
			||||||
ALPHA or IA64), called SSL_LIBCRYPTO32.OLB or SSL_LIBCRYPTO.OLB depending
 | 
					where xxx is VAX or AXP.  You will find the SSL library in [.xxx.EXE.SSL],
 | 
				
			||||||
on how it was built.  You will find the SSL library in [.xxx.EXE.SSL],
 | 
					named LIBSSL.OLB, and you will find a bunch of useful programs in
 | 
				
			||||||
named SSL_LIBSSL32.OLB or SSL_LIBSSL.OLB, and you will find a bunch of
 | 
					[.xxx.EXE.APPS].  However, these shouldn't be used right off unless it's
 | 
				
			||||||
useful programs in [.xxx.EXE.APPS].  However, these shouldn't be used
 | 
					just to test them.  For production use, make sure you install first, see
 | 
				
			||||||
right off unless it's just to test them.  For production use, make sure
 | 
					Installation below.
 | 
				
			||||||
you install first, see Installation below.
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
Note 1: Some programs in this package require a TCP/IP library.
 | 
					Note 1: Some programs in this package require a TCP/IP library.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -158,14 +170,12 @@ Installation:
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
Installation is easy, just do the following:
 | 
					Installation is easy, just do the following:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  @INSTALL <root> <bits>
 | 
					  @INSTALL <root>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<root> is the directory in which everything will be installed,
 | 
					<root> is the directory in which everything will be installed,
 | 
				
			||||||
subdirectories, libraries, header files, programs and startup command
 | 
					subdirectories, libraries, header files, programs and startup command
 | 
				
			||||||
procedures.
 | 
					procedures.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<bits> works the same way as for MAKEVMS.COM
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
N.B.: INSTALL.COM builds a new directory structure, different from
 | 
					N.B.: INSTALL.COM builds a new directory structure, different from
 | 
				
			||||||
the directory tree where you have now build OpenSSL.
 | 
					the directory tree where you have now build OpenSSL.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -186,10 +196,6 @@ following command procedures:
 | 
				
			|||||||
        sets up the symbols to the applications.  Should be called
 | 
					        sets up the symbols to the applications.  Should be called
 | 
				
			||||||
        from for example SYS$MANAGER:SYLOGIN.COM 
 | 
					        from for example SYS$MANAGER:SYLOGIN.COM 
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  OPENSSL_UNDO.COM
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	deassigns the logical names created with OPENSSL_STARTUP.COM.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
The logical names that are set up are the following:
 | 
					The logical names that are set up are the following:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  SSLROOT       a dotted concealed logical name pointing at the
 | 
					  SSLROOT       a dotted concealed logical name pointing at the
 | 
				
			||||||
@@ -197,6 +203,7 @@ The logical names that are set up are the following:
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
  SSLCERTS      Initially an empty directory, this is the default
 | 
					  SSLCERTS      Initially an empty directory, this is the default
 | 
				
			||||||
		location for certificate files.
 | 
							location for certificate files.
 | 
				
			||||||
 | 
					  SSLMISC	Various scripts.
 | 
				
			||||||
  SSLPRIVATE	Initially an empty directory, this is the default
 | 
					  SSLPRIVATE	Initially an empty directory, this is the default
 | 
				
			||||||
		location for private key files.
 | 
							location for private key files.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -204,9 +211,8 @@ The logical names that are set up are the following:
 | 
				
			|||||||
		programs.
 | 
							programs.
 | 
				
			||||||
  SSLINCLUDE    Contains the header files needed if you want to
 | 
					  SSLINCLUDE    Contains the header files needed if you want to
 | 
				
			||||||
		compile programs with libcrypto or libssl.
 | 
							compile programs with libcrypto or libssl.
 | 
				
			||||||
  SSLLIB        Contains the OpenSSL library files themselves:
 | 
					  SSLLIB        Contains the OpenSSL library files (LIBCRYPTO.OLB
 | 
				
			||||||
  		- SSL_LIBCRYPTO32.OLB and SSL_LIBSSL32.OLB or
 | 
							and LIBSSL.OLB) themselves.
 | 
				
			||||||
		- SSL_LIBCRYPTO.OLB and SSL_LIBSSL.OLB
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
  OPENSSL	Same as SSLINCLUDE.  This is because the standard
 | 
					  OPENSSL	Same as SSLINCLUDE.  This is because the standard
 | 
				
			||||||
		way to include OpenSSL header files from version
 | 
							way to include OpenSSL header files from version
 | 
				
			||||||
@@ -290,4 +296,4 @@ have any ideas.
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
--
 | 
					--
 | 
				
			||||||
Richard Levitte <richard@levitte.org>
 | 
					Richard Levitte <richard@levitte.org>
 | 
				
			||||||
2000-02-27, 2011-03-18
 | 
					2000-02-27
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										43
									
								
								INSTALL.W32
									
									
									
									
									
								
							
							
						
						
									
										43
									
								
								INSTALL.W32
									
									
									
									
									
								
							@@ -27,7 +27,7 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
- Netwide Assembler, a.k.a. NASM, available from http://nasm.sourceforge.net/
 | 
					- Netwide Assembler, a.k.a. NASM, available from http://nasm.sourceforge.net/
 | 
				
			||||||
  is required if you intend to utilize assembler modules. Note that NASM
 | 
					  is required if you intend to utilize assembler modules. Note that NASM
 | 
				
			||||||
  is now the only supported assembler.
 | 
					  is the only supported assembler.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 If you are compiling from a tarball or a CVS snapshot then the Win32 files
 | 
					 If you are compiling from a tarball or a CVS snapshot then the Win32 files
 | 
				
			||||||
 may well be not up to date. This may mean that some "tweaking" is required to
 | 
					 may well be not up to date. This may mean that some "tweaking" is required to
 | 
				
			||||||
@@ -41,9 +41,9 @@
 | 
				
			|||||||
 C++, then you will need already mentioned Netwide Assembler binary,
 | 
					 C++, then you will need already mentioned Netwide Assembler binary,
 | 
				
			||||||
 nasmw.exe or nasm.exe, to be available on your %PATH%.
 | 
					 nasmw.exe or nasm.exe, to be available on your %PATH%.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 Firstly you should run Configure with platform VC-WIN32:
 | 
					 Firstly you should run Configure:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 > perl Configure VC-WIN32 --prefix=c:\some\openssl\dir
 | 
					 > perl Configure VC-WIN32 --prefix=c:/some/openssl/dir
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 Where the prefix argument specifies where OpenSSL will be installed to.
 | 
					 Where the prefix argument specifies where OpenSSL will be installed to.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -56,7 +56,6 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
 - If you don't want to use the assembly language files at all then run:
 | 
					 - If you don't want to use the assembly language files at all then run:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
   > perl Configure VC-WIN32 no-asm --prefix=c:/some/openssl/dir
 | 
					 | 
				
			||||||
   > ms\do_ms
 | 
					   > ms\do_ms
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 If you get errors about things not having numbers assigned then check the
 | 
					 If you get errors about things not having numbers assigned then check the
 | 
				
			||||||
@@ -81,13 +80,16 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
 There are various changes you can make to the Win32 compile
 | 
					 There are various changes you can make to the Win32 compile
 | 
				
			||||||
 environment. By default the library is not compiled with debugging
 | 
					 environment. By default the library is not compiled with debugging
 | 
				
			||||||
 symbols. If you use the platform debug-VC-WIN32 instead of VC-WIN32
 | 
					 symbols. If you add 'debug' to the mk1mf.pl lines in the do_* batch
 | 
				
			||||||
 then debugging symbols will be compiled in.
 | 
					 file then debugging symbols will be compiled in. Note that mk1mf.pl
 | 
				
			||||||
 | 
					 expects the platform to be the last argument on the command line, so
 | 
				
			||||||
 | 
					 'debug' must appear before that, as all other options.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 By default in 1.0.0 OpenSSL will compile builtin ENGINES into the
 | 
					
 | 
				
			||||||
 separate shared librariesy. If you specify the "enable-static-engine"
 | 
					 By default in 0.9.8 OpenSSL will compile builtin ENGINES into the
 | 
				
			||||||
 | 
					 libeay32.dll shared library. If you specify the "no-static-engine"
 | 
				
			||||||
 option on the command line to Configure the shared library build
 | 
					 option on the command line to Configure the shared library build
 | 
				
			||||||
 (ms\ntdll.mak) will compile the engines into libeay32.dll instead.
 | 
					 (ms\ntdll.mak) will compile the engines as separate DLLs.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 The default Win32 environment is to leave out any Windows NT specific
 | 
					 The default Win32 environment is to leave out any Windows NT specific
 | 
				
			||||||
 features.
 | 
					 features.
 | 
				
			||||||
@@ -100,6 +102,7 @@
 | 
				
			|||||||
 ms\nt.mak
 | 
					 ms\nt.mak
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 Borland C++ builder 5
 | 
					 Borland C++ builder 5
 | 
				
			||||||
 ---------------------
 | 
					 ---------------------
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -185,15 +188,6 @@
 | 
				
			|||||||
   required. Run the installers and do whatever magic they say it takes
 | 
					   required. Run the installers and do whatever magic they say it takes
 | 
				
			||||||
   to start MSYS bash shell with GNU tools on its PATH.
 | 
					   to start MSYS bash shell with GNU tools on its PATH.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
   N.B. Since source tar-ball can contain symbolic links, it's essential
 | 
					 | 
				
			||||||
   that you use accompanying MSYS tar to unpack the source. It will
 | 
					 | 
				
			||||||
   either handle them in one way or another or fail to extract them,
 | 
					 | 
				
			||||||
   which does the trick too. Latter means that you may safely ignore all
 | 
					 | 
				
			||||||
   "cannot create symlink" messages, as they will be "re-created" at
 | 
					 | 
				
			||||||
   configure stage by copying corresponding files. Alternative programs
 | 
					 | 
				
			||||||
   were observed to create empty files instead, which results in build
 | 
					 | 
				
			||||||
   failure.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 * Compile OpenSSL:
 | 
					 * Compile OpenSSL:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
   $ ./config
 | 
					   $ ./config
 | 
				
			||||||
@@ -306,18 +300,7 @@
 | 
				
			|||||||
 desktop, which is not available to service processes. The toolkit is
 | 
					 desktop, which is not available to service processes. The toolkit is
 | 
				
			||||||
 designed to detect in which context it's currently executed, GUI,
 | 
					 designed to detect in which context it's currently executed, GUI,
 | 
				
			||||||
 console app or service, and act accordingly, namely whether or not to
 | 
					 console app or service, and act accordingly, namely whether or not to
 | 
				
			||||||
 actually make GUI calls. Additionally those who wish to
 | 
					 actually make GUI calls.
 | 
				
			||||||
 /DELAYLOAD:GDI32.DLL and /DELAYLOAD:USER32.DLL and actually keep them
 | 
					 | 
				
			||||||
 off service process should consider implementing and exporting from
 | 
					 | 
				
			||||||
 .exe image in question own _OPENSSL_isservice not relying on USER32.DLL.
 | 
					 | 
				
			||||||
 E.g., on Windows Vista and later you could:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	__declspec(dllexport) __cdecl BOOL _OPENSSL_isservice(void)
 | 
					 | 
				
			||||||
	{   DWORD sess;
 | 
					 | 
				
			||||||
	    if (ProcessIdToSessionId(GetCurrentProcessId(),&sess))
 | 
					 | 
				
			||||||
	        return sess==0;
 | 
					 | 
				
			||||||
	    return FALSE;
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
 If you link with OpenSSL .DLLs, then you're expected to include into
 | 
					 If you link with OpenSSL .DLLs, then you're expected to include into
 | 
				
			||||||
 your application code small "shim" snippet, which provides glue between
 | 
					 your application code small "shim" snippet, which provides glue between
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										2
									
								
								LICENSE
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								LICENSE
									
									
									
									
									
								
							@@ -12,7 +12,7 @@
 | 
				
			|||||||
  ---------------
 | 
					  ---------------
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* ====================================================================
 | 
					/* ====================================================================
 | 
				
			||||||
 * Copyright (c) 1998-2011 The OpenSSL Project.  All rights reserved.
 | 
					 * Copyright (c) 1998-2008 The OpenSSL Project.  All rights reserved.
 | 
				
			||||||
 *
 | 
					 *
 | 
				
			||||||
 * Redistribution and use in source and binary forms, with or without
 | 
					 * Redistribution and use in source and binary forms, with or without
 | 
				
			||||||
 * modification, are permitted provided that the following conditions
 | 
					 * modification, are permitted provided that the following conditions
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										62
									
								
								MacOS/GUSI_Init.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										62
									
								
								MacOS/GUSI_Init.cpp
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,62 @@
 | 
				
			|||||||
 | 
					/**************** BEGIN GUSI CONFIGURATION ****************************
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * GUSI Configuration section generated by GUSI Configurator
 | 
				
			||||||
 | 
					 * last modified: Wed Jan  5 20:33:51 2000
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * This section will be overwritten by the next run of Configurator.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define GUSI_SOURCE
 | 
				
			||||||
 | 
					#include <GUSIConfig.h>
 | 
				
			||||||
 | 
					#include <sys/cdefs.h>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* Declarations of Socket Factories */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					__BEGIN_DECLS
 | 
				
			||||||
 | 
					void GUSIwithInetSockets();
 | 
				
			||||||
 | 
					void GUSIwithLocalSockets();
 | 
				
			||||||
 | 
					void GUSIwithMTInetSockets();
 | 
				
			||||||
 | 
					void GUSIwithMTTcpSockets();
 | 
				
			||||||
 | 
					void GUSIwithMTUdpSockets();
 | 
				
			||||||
 | 
					void GUSIwithOTInetSockets();
 | 
				
			||||||
 | 
					void GUSIwithOTTcpSockets();
 | 
				
			||||||
 | 
					void GUSIwithOTUdpSockets();
 | 
				
			||||||
 | 
					void GUSIwithPPCSockets();
 | 
				
			||||||
 | 
					void GUSISetupFactories();
 | 
				
			||||||
 | 
					__END_DECLS
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* Configure Socket Factories */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void GUSISetupFactories()
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					#ifdef GUSISetupFactories_BeginHook
 | 
				
			||||||
 | 
						GUSISetupFactories_BeginHook
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
						GUSIwithInetSockets();
 | 
				
			||||||
 | 
					#ifdef GUSISetupFactories_EndHook
 | 
				
			||||||
 | 
						GUSISetupFactories_EndHook
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* Declarations of File Devices */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					__BEGIN_DECLS
 | 
				
			||||||
 | 
					void GUSIwithDConSockets();
 | 
				
			||||||
 | 
					void GUSIwithNullSockets();
 | 
				
			||||||
 | 
					void GUSISetupDevices();
 | 
				
			||||||
 | 
					__END_DECLS
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* Configure File Devices */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void GUSISetupDevices()
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					#ifdef GUSISetupDevices_BeginHook
 | 
				
			||||||
 | 
						GUSISetupDevices_BeginHook
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
						GUSIwithNullSockets();
 | 
				
			||||||
 | 
					#ifdef GUSISetupDevices_EndHook
 | 
				
			||||||
 | 
						GUSISetupDevices_EndHook
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**************** END GUSI CONFIGURATION *************************/
 | 
				
			||||||
							
								
								
									
										2753
									
								
								MacOS/GetHTTPS.src/CPStringUtils.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2753
									
								
								MacOS/GetHTTPS.src/CPStringUtils.cpp
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										104
									
								
								MacOS/GetHTTPS.src/CPStringUtils.hpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										104
									
								
								MacOS/GetHTTPS.src/CPStringUtils.hpp
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,104 @@
 | 
				
			|||||||
 | 
					#pragma once
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef __cplusplus
 | 
				
			||||||
 | 
					extern "C" {
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void CopyPStrToCStr(const unsigned char *thePStr,char *theCStr,const int maxCStrLength);
 | 
				
			||||||
 | 
					void CopyPStrToPStr(const unsigned char *theSrcPStr,unsigned char *theDstPStr,const int maxDstStrLength);
 | 
				
			||||||
 | 
					void CopyCStrToCStr(const char *theSrcCStr,char *theDstCStr,const int maxDstStrLength);
 | 
				
			||||||
 | 
					void CopyCStrToPStr(const char *theSrcCStr,unsigned char *theDstPStr,const int maxDstStrLength);
 | 
				
			||||||
 | 
					void ConcatPStrToCStr(const unsigned char *thePStr,char *theCStr,const int maxCStrLength);
 | 
				
			||||||
 | 
					void ConcatPStrToPStr(const unsigned char *theSrcPStr,unsigned char *theDstPStr,const int maxDstStrLength);
 | 
				
			||||||
 | 
					void ConcatCStrToPStr(const char *theSrcCStr,unsigned char *theDstPStr,const int maxDstStrLength);
 | 
				
			||||||
 | 
					void ConcatCStrToCStr(const char *theSrcCStr,char *theDstCStr,const int maxCStrLength);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void ConcatCharToCStr(const char theChar,char *theDstCStr,const int maxCStrLength);
 | 
				
			||||||
 | 
					void ConcatCharToPStr(const char theChar,unsigned char *theDstPStr,const int maxPStrLength);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					int ComparePStrs(const unsigned char *theFirstPStr,const unsigned char *theSecondPStr,const Boolean ignoreCase = true);
 | 
				
			||||||
 | 
					int CompareCStrs(const char *theFirstCStr,const char *theSecondCStr,const Boolean ignoreCase = true);
 | 
				
			||||||
 | 
					int CompareCStrToPStr(const char *theCStr,const unsigned char *thePStr,const Boolean ignoreCase = true);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Boolean CStrsAreEqual(const char *theFirstCStr,const char *theSecondCStr,const Boolean ignoreCase = true);
 | 
				
			||||||
 | 
					Boolean PStrsAreEqual(const unsigned char *theFirstCStr,const unsigned char *theSecondCStr,const Boolean ignoreCase = true);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void CopyLongIntToCStr(const long theNum,char *theCStr,const int maxCStrLength,const int numDigits = -1);
 | 
				
			||||||
 | 
					void CopyUnsignedLongIntToCStr(const unsigned long theNum,char *theCStr,const int maxCStrLength);
 | 
				
			||||||
 | 
					void ConcatLongIntToCStr(const long theNum,char *theCStr,const int maxCStrLength,const int numDigits = -1);
 | 
				
			||||||
 | 
					void CopyCStrAndConcatLongIntToCStr(const char *theSrcCStr,const long theNum,char *theDstCStr,const int maxDstStrLength);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void CopyLongIntToPStr(const long theNum,unsigned char *thePStr,const int maxPStrLength,const int numDigits = -1);
 | 
				
			||||||
 | 
					void ConcatLongIntToPStr(const long theNum,unsigned char *thePStr,const int maxPStrLength,const int numDigits = -1);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					long CStrLength(const char *theCString);
 | 
				
			||||||
 | 
					long PStrLength(const unsigned char *thePString);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					OSErr CopyCStrToExistingHandle(const char *theCString,Handle theHandle);
 | 
				
			||||||
 | 
					OSErr CopyLongIntToExistingHandle(const long inTheLongInt,Handle theHandle);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					OSErr CopyCStrToNewHandle(const char *theCString,Handle *theHandle);
 | 
				
			||||||
 | 
					OSErr CopyPStrToNewHandle(const unsigned char *thePString,Handle *theHandle);
 | 
				
			||||||
 | 
					OSErr CopyLongIntToNewHandle(const long inTheLongInt,Handle *theHandle);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					OSErr AppendCStrToHandle(const char *theCString,Handle theHandle,long *currentLength = nil,long *maxLength = nil);
 | 
				
			||||||
 | 
					OSErr AppendCharsToHandle(const char *theChars,const int numChars,Handle theHandle,long *currentLength = nil,long *maxLength = nil);
 | 
				
			||||||
 | 
					OSErr AppendPStrToHandle(const unsigned char *thePString,Handle theHandle,long *currentLength = nil);
 | 
				
			||||||
 | 
					OSErr AppendLongIntToHandle(const long inTheLongInt,Handle theHandle,long *currentLength = nil);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void ZeroMem(void *theMemPtr,const unsigned long numBytes);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					char *FindCharInCStr(const char theChar,const char *theCString);
 | 
				
			||||||
 | 
					long FindCharOffsetInCStr(const char theChar,const char *theCString,const Boolean inIgnoreCase = false);
 | 
				
			||||||
 | 
					long FindCStrOffsetInCStr(const char *theCSubstring,const char *theCString,const Boolean inIgnoreCase = false);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void CopyCSubstrToCStr(const char *theSrcCStr,const int maxCharsToCopy,char *theDstCStr,const int maxDstStrLength);
 | 
				
			||||||
 | 
					void CopyCSubstrToPStr(const char *theSrcCStr,const int maxCharsToCopy,unsigned char *theDstPStr,const int maxDstStrLength);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void InsertCStrIntoCStr(const char *theSrcCStr,const int theInsertionOffset,char *theDstCStr,const int maxDstStrLength);
 | 
				
			||||||
 | 
					void InsertPStrIntoCStr(const unsigned char *theSrcPStr,const int theInsertionOffset,char *theDstCStr,const int maxDstStrLength);
 | 
				
			||||||
 | 
					OSErr InsertCStrIntoHandle(const char *theCString,Handle theHandle,const long inInsertOffset);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void CopyCStrAndInsertCStrIntoCStr(const char *theSrcCStr,const char *theInsertCStr,char *theDstCStr,const int maxDstStrLength);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void CopyCStrAndInsertCStrsLongIntsIntoCStr(const char *theSrcCStr,const char **theInsertCStrs,const long *theLongInts,char *theDstCStr,const int maxDstStrLength);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void CopyCStrAndInsert1LongIntIntoCStr(const char *theSrcCStr,const long theNum,char *theDstCStr,const int maxDstStrLength);
 | 
				
			||||||
 | 
					void CopyCStrAndInsert2LongIntsIntoCStr(const char *theSrcCStr,const long long1,const long long2,char *theDstCStr,const int maxDstStrLength);
 | 
				
			||||||
 | 
					void CopyCStrAndInsert3LongIntsIntoCStr(const char *theSrcCStr,const long long1,const long long2,const long long3,char *theDstCStr,const int maxDstStrLength);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void CopyCStrAndInsertCStrLongIntIntoCStr(const char *theSrcCStr,const char *theInsertCStr,const long theNum,char *theDstCStr,const int maxDstStrLength);
 | 
				
			||||||
 | 
					OSErr CopyCStrAndInsertCStrLongIntIntoHandle(const char *theSrcCStr,const char *theInsertCStr,const long theNum,Handle *theHandle);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					OSErr CopyIndexedWordToCStr(char *theSrcCStr,int whichWord,char *theDstCStr,int maxDstCStrLength);
 | 
				
			||||||
 | 
					OSErr CopyIndexedWordToNewHandle(char *theSrcCStr,int whichWord,Handle *outTheHandle);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					OSErr CopyIndexedLineToCStr(const char *theSrcCStr,int inWhichLine,int *lineEndIndex,Boolean *gotLastLine,char *theDstCStr,const int maxDstCStrLength);
 | 
				
			||||||
 | 
					OSErr CopyIndexedLineToNewHandle(const char *theSrcCStr,int inWhichLine,Handle *outNewHandle);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					OSErr ExtractIntFromCStr(const char *theSrcCStr,int *outInt,Boolean skipLeadingSpaces = true);
 | 
				
			||||||
 | 
					OSErr ExtractIntFromPStr(const unsigned char *theSrcPStr,int *outInt,Boolean skipLeadingSpaces = true);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void ConvertCStrToUpperCase(char *theSrcCStr);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					int CountOccurencesOfCharInCStr(const char inChar,const char *inSrcCStr);
 | 
				
			||||||
 | 
					int CountWordsInCStr(const char *inSrcCStr);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					OSErr CountDigits(const char *inCStr,int *outNumIntegerDigits,int *outNumFractDigits);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void ExtractCStrItemFromCStr(const char *inSrcCStr,const char inItemDelimiter,const int inItemNumber,Boolean *foundItem,char *outDstCharPtr,const int inDstCharPtrMaxLength,const Boolean inTreatMultipleDelimsAsSingleDelim = false);
 | 
				
			||||||
 | 
					OSErr ExtractCStrItemFromCStrIntoNewHandle(const char *inSrcCStr,const char inItemDelimiter,const int inItemNumber,Boolean *foundItem,Handle *outNewHandle,const Boolean inTreatMultipleDelimsAsSingleDelim = false);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					OSErr ExtractFloatFromCStr(const char *inCString,extended80 *outFloat);
 | 
				
			||||||
 | 
					OSErr CopyFloatToCStr(const extended80 *theFloat,char *theCStr,const int maxCStrLength,const int inMaxNumIntDigits = -1,const int inMaxNumFractDigits = -1);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void SkipWhiteSpace(char **ioSrcCharPtr,const Boolean inStopAtEOL = false);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef __cplusplus
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
@@ -1,8 +1,5 @@
 | 
				
			|||||||
/* Written by Stephen henson (steve@openssl.org) for the OpenSSL
 | 
					 | 
				
			||||||
 * project 2011.
 | 
					 | 
				
			||||||
 */
 | 
					 | 
				
			||||||
/* ====================================================================
 | 
					/* ====================================================================
 | 
				
			||||||
 * Copyright (c) 2011 The OpenSSL Project.  All rights reserved.
 | 
					 * Copyright (c) 1998-1999 The OpenSSL Project.  All rights reserved.
 | 
				
			||||||
 *
 | 
					 *
 | 
				
			||||||
 * Redistribution and use in source and binary forms, with or without
 | 
					 * Redistribution and use in source and binary forms, with or without
 | 
				
			||||||
 * modification, are permitted provided that the following conditions
 | 
					 * modification, are permitted provided that the following conditions
 | 
				
			||||||
@@ -54,30 +51,120 @@
 | 
				
			|||||||
 * Hudson (tjh@cryptsoft.com).
 | 
					 * Hudson (tjh@cryptsoft.com).
 | 
				
			||||||
 *
 | 
					 *
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
 | 
					 
 | 
				
			||||||
 | 
					 
 | 
				
			||||||
 | 
					 
 | 
				
			||||||
 | 
					 #include "ErrorHandling.hpp"
 | 
				
			||||||
 | 
					#include "CPStringUtils.hpp"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#include "cryptlib.h"
 | 
					#ifdef __EXCEPTIONS_ENABLED__
 | 
				
			||||||
#ifdef OPENSSL_FIPS
 | 
						#include "CMyException.hpp"
 | 
				
			||||||
#include <openssl/fips.h>
 | 
					 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
int FIPS_mode(void)
 | 
					
 | 
				
			||||||
 | 
					static char					gErrorMessageBuffer[512];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					char 						*gErrorMessage = gErrorMessageBuffer;
 | 
				
			||||||
 | 
					int							gErrorMessageMaxLength = sizeof(gErrorMessageBuffer);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void SetErrorMessage(const char *theErrorMessage)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						if (theErrorMessage != nil)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
#ifdef OPENSSL_FIPS
 | 
							CopyCStrToCStr(theErrorMessage,gErrorMessage,gErrorMessageMaxLength);
 | 
				
			||||||
	return FIPS_module_mode();
 | 
						}
 | 
				
			||||||
#else
 | 
					}
 | 
				
			||||||
	return 0;
 | 
					
 | 
				
			||||||
#endif
 | 
					
 | 
				
			||||||
 | 
					void SetErrorMessageAndAppendLongInt(const char *theErrorMessage,const long theLongInt)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						if (theErrorMessage != nil)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							CopyCStrAndConcatLongIntToCStr(theErrorMessage,theLongInt,gErrorMessage,gErrorMessageMaxLength);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void SetErrorMessageAndCStrAndLongInt(const char *theErrorMessage,const char * theCStr,const long theLongInt)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						if (theErrorMessage != nil)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							CopyCStrAndInsertCStrLongIntIntoCStr(theErrorMessage,theCStr,theLongInt,gErrorMessage,gErrorMessageMaxLength);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
int FIPS_mode_set(int r)
 | 
					}
 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
#ifdef OPENSSL_FIPS
 | 
					 | 
				
			||||||
	return FIPS_module_mode_set(r);
 | 
					 | 
				
			||||||
#else
 | 
					 | 
				
			||||||
	if (r == 0)
 | 
					 | 
				
			||||||
		return 1;
 | 
					 | 
				
			||||||
	CRYPTOerr(CRYPTO_F_FIPS_MODE_SET, CRYPTO_R_FIPS_MODE_NOT_SUPPORTED);
 | 
					 | 
				
			||||||
	return 0;
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void SetErrorMessageAndCStr(const char *theErrorMessage,const char * theCStr)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						if (theErrorMessage != nil)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							CopyCStrAndInsertCStrLongIntIntoCStr(theErrorMessage,theCStr,-1,gErrorMessage,gErrorMessageMaxLength);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void AppendCStrToErrorMessage(const char *theErrorMessage)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						if (theErrorMessage != nil)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							ConcatCStrToCStr(theErrorMessage,gErrorMessage,gErrorMessageMaxLength);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void AppendLongIntToErrorMessage(const long theLongInt)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						ConcatLongIntToCStr(theLongInt,gErrorMessage,gErrorMessageMaxLength);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					char *GetErrorMessage(void)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						return gErrorMessage;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					OSErr GetErrorMessageInNewHandle(Handle *inoutHandle)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					OSErr		errCode;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						errCode = CopyCStrToNewHandle(gErrorMessage,inoutHandle);
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						return(errCode);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					OSErr GetErrorMessageInExistingHandle(Handle inoutHandle)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					OSErr		errCode;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						errCode = CopyCStrToExistingHandle(gErrorMessage,inoutHandle);
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						return(errCode);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					OSErr AppendErrorMessageToHandle(Handle inoutHandle)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					OSErr		errCode;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						errCode = AppendCStrToHandle(gErrorMessage,inoutHandle,nil);
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						return(errCode);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef __EXCEPTIONS_ENABLED__
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void ThrowErrorMessageException(void)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						ThrowDescriptiveException(gErrorMessage);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
							
								
								
									
										147
									
								
								MacOS/GetHTTPS.src/ErrorHandling.hpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										147
									
								
								MacOS/GetHTTPS.src/ErrorHandling.hpp
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,147 @@
 | 
				
			|||||||
 | 
					#ifdef __cplusplus
 | 
				
			||||||
 | 
					extern "C" {
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifndef kGenericError
 | 
				
			||||||
 | 
						#define kGenericError		-1
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					extern char	*gErrorMessage;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void SetErrorMessage(const char *theErrorMessage);
 | 
				
			||||||
 | 
					void SetErrorMessageAndAppendLongInt(const char *theErrorMessage,const long theLongInt);
 | 
				
			||||||
 | 
					void SetErrorMessageAndCStrAndLongInt(const char *theErrorMessage,const char * theCStr,const long theLongInt);
 | 
				
			||||||
 | 
					void SetErrorMessageAndCStr(const char *theErrorMessage,const char * theCStr);
 | 
				
			||||||
 | 
					void AppendCStrToErrorMessage(const char *theErrorMessage);
 | 
				
			||||||
 | 
					void AppendLongIntToErrorMessage(const long theLongInt);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					char *GetErrorMessage(void);
 | 
				
			||||||
 | 
					OSErr GetErrorMessageInNewHandle(Handle *inoutHandle);
 | 
				
			||||||
 | 
					OSErr GetErrorMessageInExistingHandle(Handle inoutHandle);
 | 
				
			||||||
 | 
					OSErr AppendErrorMessageToHandle(Handle inoutHandle);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef __EXCEPTIONS_ENABLED__
 | 
				
			||||||
 | 
						void ThrowErrorMessageException(void);
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					//	A bunch of evil macros that would be unnecessary if I were always using C++ !
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define SetErrorMessageAndBailIfNil(theArg,theMessage)								\
 | 
				
			||||||
 | 
					{																					\
 | 
				
			||||||
 | 
						if (theArg == nil)																\
 | 
				
			||||||
 | 
						{																				\
 | 
				
			||||||
 | 
							SetErrorMessage(theMessage);												\
 | 
				
			||||||
 | 
							errCode = kGenericError;													\
 | 
				
			||||||
 | 
							goto EXITPOINT;																\
 | 
				
			||||||
 | 
						}																				\
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define SetErrorMessageAndBail(theMessage)											\
 | 
				
			||||||
 | 
					{																					\
 | 
				
			||||||
 | 
							SetErrorMessage(theMessage);												\
 | 
				
			||||||
 | 
							errCode = kGenericError;													\
 | 
				
			||||||
 | 
							goto EXITPOINT;																\
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define SetErrorMessageAndLongIntAndBail(theMessage,theLongInt)						\
 | 
				
			||||||
 | 
					{																					\
 | 
				
			||||||
 | 
							SetErrorMessageAndAppendLongInt(theMessage,theLongInt);						\
 | 
				
			||||||
 | 
							errCode = kGenericError;													\
 | 
				
			||||||
 | 
							goto EXITPOINT;																\
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define SetErrorMessageAndLongIntAndBailIfError(theErrCode,theMessage,theLongInt)	\
 | 
				
			||||||
 | 
					{																					\
 | 
				
			||||||
 | 
						if (theErrCode != noErr)														\
 | 
				
			||||||
 | 
						{																				\
 | 
				
			||||||
 | 
							SetErrorMessageAndAppendLongInt(theMessage,theLongInt);						\
 | 
				
			||||||
 | 
							errCode = theErrCode;														\
 | 
				
			||||||
 | 
							goto EXITPOINT;																\
 | 
				
			||||||
 | 
						}																				\
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define SetErrorMessageCStrLongIntAndBailIfError(theErrCode,theMessage,theCStr,theLongInt)	\
 | 
				
			||||||
 | 
					{																					\
 | 
				
			||||||
 | 
						if (theErrCode != noErr)														\
 | 
				
			||||||
 | 
						{																				\
 | 
				
			||||||
 | 
							SetErrorMessageAndCStrAndLongInt(theMessage,theCStr,theLongInt);			\
 | 
				
			||||||
 | 
							errCode = theErrCode;														\
 | 
				
			||||||
 | 
							goto EXITPOINT;																\
 | 
				
			||||||
 | 
						}																				\
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define SetErrorMessageAndCStrAndBail(theMessage,theCStr)							\
 | 
				
			||||||
 | 
					{																					\
 | 
				
			||||||
 | 
						SetErrorMessageAndCStr(theMessage,theCStr);										\
 | 
				
			||||||
 | 
						errCode = kGenericError;														\
 | 
				
			||||||
 | 
						goto EXITPOINT;																	\
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define SetErrorMessageAndBailIfError(theErrCode,theMessage)						\
 | 
				
			||||||
 | 
					{																					\
 | 
				
			||||||
 | 
						if (theErrCode != noErr)														\
 | 
				
			||||||
 | 
						{																				\
 | 
				
			||||||
 | 
							SetErrorMessage(theMessage);												\
 | 
				
			||||||
 | 
							errCode = theErrCode;														\
 | 
				
			||||||
 | 
							goto EXITPOINT;																\
 | 
				
			||||||
 | 
						}																				\
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define SetErrorMessageAndLongIntAndBailIfNil(theArg,theMessage,theLongInt)			\
 | 
				
			||||||
 | 
					{																					\
 | 
				
			||||||
 | 
						if (theArg == nil)																\
 | 
				
			||||||
 | 
						{																				\
 | 
				
			||||||
 | 
							SetErrorMessageAndAppendLongInt(theMessage,theLongInt);						\
 | 
				
			||||||
 | 
							errCode = kGenericError;													\
 | 
				
			||||||
 | 
							goto EXITPOINT;																\
 | 
				
			||||||
 | 
						}																				\
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define BailIfError(theErrCode)														\
 | 
				
			||||||
 | 
					{																					\
 | 
				
			||||||
 | 
						if ((theErrCode) != noErr)														\
 | 
				
			||||||
 | 
						{																				\
 | 
				
			||||||
 | 
							goto EXITPOINT;																\
 | 
				
			||||||
 | 
						}																				\
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define SetErrCodeAndBail(theErrCode)												\
 | 
				
			||||||
 | 
					{																					\
 | 
				
			||||||
 | 
						errCode = theErrCode;															\
 | 
				
			||||||
 | 
																										\
 | 
				
			||||||
 | 
						goto EXITPOINT;																	\
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define SetErrorCodeAndMessageAndBail(theErrCode,theMessage)						\
 | 
				
			||||||
 | 
					{																					\
 | 
				
			||||||
 | 
						SetErrorMessage(theMessage);													\
 | 
				
			||||||
 | 
						errCode = theErrCode;															\
 | 
				
			||||||
 | 
						goto EXITPOINT;																	\
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define BailNow()																	\
 | 
				
			||||||
 | 
					{																					\
 | 
				
			||||||
 | 
						errCode = kGenericError;														\
 | 
				
			||||||
 | 
						goto EXITPOINT;																	\
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef __cplusplus
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
							
								
								
									
										209
									
								
								MacOS/GetHTTPS.src/GetHTTPS.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										209
									
								
								MacOS/GetHTTPS.src/GetHTTPS.cpp
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,209 @@
 | 
				
			|||||||
 | 
					/*
 | 
				
			||||||
 | 
					 *	An demo illustrating how to retrieve a URI from a secure HTTP server.
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 *	Author: 	Roy Wood
 | 
				
			||||||
 | 
					 *	Date:		September 7, 1999
 | 
				
			||||||
 | 
					 *	Comments:	This relies heavily on my MacSockets library.
 | 
				
			||||||
 | 
					 *				This project is also set up so that it expects the OpenSSL source folder (0.9.4 as I write this)
 | 
				
			||||||
 | 
					 *				to live in a folder called "OpenSSL-0.9.4" in this project's parent folder.  For example:
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 *					Macintosh HD:
 | 
				
			||||||
 | 
					 *						Development:
 | 
				
			||||||
 | 
					 *							OpenSSL-0.9.4:
 | 
				
			||||||
 | 
					 *								(OpenSSL sources here)
 | 
				
			||||||
 | 
					 *							OpenSSL Example:
 | 
				
			||||||
 | 
					 *								(OpenSSL example junk here)
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 *				Also-- before attempting to compile this, make sure the aliases in "OpenSSL-0.9.4:include:openssl" 
 | 
				
			||||||
 | 
					 *				are installed!  Use the AppleScript applet in the "openssl-0.9.4" folder to do this!
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					/* modified to seed the PRNG */
 | 
				
			||||||
 | 
					/* modified to use CRandomizer for seeding */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					//	Include some funky libs I've developed over time
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "CPStringUtils.hpp"
 | 
				
			||||||
 | 
					#include "ErrorHandling.hpp"
 | 
				
			||||||
 | 
					#include "MacSocket.h"
 | 
				
			||||||
 | 
					#include "Randomizer.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					//	We use the OpenSSL implementation of SSL....
 | 
				
			||||||
 | 
					//	This was a lot of work to finally get going, though you wouldn't know it by the results!
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include <openssl/ssl.h>
 | 
				
			||||||
 | 
					#include <openssl/err.h>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include <timer.h>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					//	Let's try grabbing some data from here:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define kHTTPS_DNS		"www.apache-ssl.org"
 | 
				
			||||||
 | 
					#define kHTTPS_Port		443
 | 
				
			||||||
 | 
					#define kHTTPS_URI		"/"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					//	Forward-declare this
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					OSErr MyMacSocket_IdleWaitCallback(void *inUserRefPtr);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					//	My idle-wait callback.  Doesn't do much, does it?  Silly cooperative multitasking.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					OSErr MyMacSocket_IdleWaitCallback(void *inUserRefPtr)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					#pragma unused(inUserRefPtr)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					EventRecord		theEvent;
 | 
				
			||||||
 | 
						::EventAvail(everyEvent,&theEvent);
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						CRandomizer *randomizer = (CRandomizer*)inUserRefPtr;
 | 
				
			||||||
 | 
						if (randomizer)
 | 
				
			||||||
 | 
							randomizer->PeriodicAction();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						return(noErr);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					//	Finally!
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void main(void)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						OSErr				errCode;
 | 
				
			||||||
 | 
						int					theSocket = -1;
 | 
				
			||||||
 | 
						int					theTimeout = 30;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						SSL_CTX				*ssl_ctx = nil;
 | 
				
			||||||
 | 
						SSL					*ssl = nil;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						char				tempString[256];
 | 
				
			||||||
 | 
						UnsignedWide		microTickCount;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						CRandomizer randomizer;
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						printf("OpenSSL Demo by Roy Wood, roy@centricsystems.ca\n\n");
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						BailIfError(errCode = MacSocket_Startup());
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						//	Create a socket-like object
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						BailIfError(errCode = MacSocket_socket(&theSocket,false,theTimeout * 60,MyMacSocket_IdleWaitCallback,&randomizer));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						//	Set up the connect string and try to connect
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						CopyCStrAndInsertCStrLongIntIntoCStr("%s:%ld",kHTTPS_DNS,kHTTPS_Port,tempString,sizeof(tempString));
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						printf("Connecting to %s....\n",tempString);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						BailIfError(errCode = MacSocket_connect(theSocket,tempString));
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						//	Init SSL stuff
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						SSL_load_error_strings();
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						SSLeay_add_ssl_algorithms();
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						//	Pick the SSL method
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
					//	ssl_ctx = SSL_CTX_new(SSLv2_client_method());
 | 
				
			||||||
 | 
						ssl_ctx = SSL_CTX_new(SSLv23_client_method());
 | 
				
			||||||
 | 
					//	ssl_ctx = SSL_CTX_new(SSLv3_client_method());
 | 
				
			||||||
 | 
								
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						//	Create an SSL thingey and try to negotiate the connection
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						ssl = SSL_new(ssl_ctx);
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						SSL_set_fd(ssl,theSocket);
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						errCode = SSL_connect(ssl);
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						if (errCode < 0)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							SetErrorMessageAndLongIntAndBail("OpenSSL: Can't initiate SSL connection, SSL_connect() = ",errCode);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						//	Request the URI from the host
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						CopyCStrToCStr("GET ",tempString,sizeof(tempString));
 | 
				
			||||||
 | 
						ConcatCStrToCStr(kHTTPS_URI,tempString,sizeof(tempString));
 | 
				
			||||||
 | 
						ConcatCStrToCStr(" HTTP/1.0\r\n\r\n",tempString,sizeof(tempString));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						errCode = SSL_write(ssl,tempString,CStrLength(tempString));
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						if (errCode < 0)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							SetErrorMessageAndLongIntAndBail("OpenSSL: Error writing data via ssl, SSL_write() = ",errCode);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						for (;;)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
						char	tempString[256];
 | 
				
			||||||
 | 
						int		bytesRead;
 | 
				
			||||||
 | 
							
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							//	Read some bytes and dump them to the console
 | 
				
			||||||
 | 
							
 | 
				
			||||||
 | 
							bytesRead = SSL_read(ssl,tempString,sizeof(tempString) - 1);
 | 
				
			||||||
 | 
							
 | 
				
			||||||
 | 
							if (bytesRead == 0 && MacSocket_RemoteEndIsClosing(theSocket))
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								break;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							
 | 
				
			||||||
 | 
							else if (bytesRead < 0)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								SetErrorMessageAndLongIntAndBail("OpenSSL: Error reading data via ssl, SSL_read() = ",bytesRead);
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							
 | 
				
			||||||
 | 
							
 | 
				
			||||||
 | 
							tempString[bytesRead] = '\0';
 | 
				
			||||||
 | 
							
 | 
				
			||||||
 | 
							printf("%s", tempString);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						printf("\n\n\n");
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						//	All done!
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						errCode = noErr;
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
					EXITPOINT:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						//	Clean up and go home
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						if (theSocket >= 0)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							MacSocket_close(theSocket);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						if (ssl != nil)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							SSL_free(ssl);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						if (ssl_ctx != nil)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							SSL_CTX_free(ssl_ctx);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						if (errCode != noErr)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							printf("An error occurred:\n");
 | 
				
			||||||
 | 
							
 | 
				
			||||||
 | 
							printf("%s",GetErrorMessage());
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						MacSocket_Shutdown();
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
							
								
								
									
										1607
									
								
								MacOS/GetHTTPS.src/MacSocket.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1607
									
								
								MacOS/GetHTTPS.src/MacSocket.cpp
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										103
									
								
								MacOS/GetHTTPS.src/MacSocket.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										103
									
								
								MacOS/GetHTTPS.src/MacSocket.h
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,103 @@
 | 
				
			|||||||
 | 
					#pragma once
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef __cplusplus
 | 
				
			||||||
 | 
					extern "C" {
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					enum
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						kMacSocket_TimeoutErr = -2
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					//	Since MacSocket does busy waiting, I do a callback while waiting
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					typedef OSErr (*MacSocket_IdleWaitCallback)(void *);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					//	Call this before anything else!
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					OSErr MacSocket_Startup(void);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					//	Call this to cleanup before quitting
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					OSErr MacSocket_Shutdown(void);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					//	Call this to allocate a "socket" (reference number is returned in outSocketNum)
 | 
				
			||||||
 | 
					//	Note that inDoThreadSwitching is pretty much irrelevant right now, since I ignore it
 | 
				
			||||||
 | 
					//	The inTimeoutTicks parameter is applied during reads/writes of data
 | 
				
			||||||
 | 
					//	The inIdleWaitCallback parameter specifies a callback which is called during busy-waiting periods
 | 
				
			||||||
 | 
					//	The inUserRefPtr parameter is passed back to the idle-wait callback
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					OSErr MacSocket_socket(int *outSocketNum,const Boolean inDoThreadSwitching,const long inTimeoutTicks,MacSocket_IdleWaitCallback inIdleWaitCallback,void *inUserRefPtr);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					//	Call this to connect to an IP/DNS address
 | 
				
			||||||
 | 
					//	Note that inTargetAddressAndPort is in "IP:port" format-- e.g. 10.1.1.1:123
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					OSErr MacSocket_connect(const int inSocketNum,char *inTargetAddressAndPort);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					//	Call this to listen on a port
 | 
				
			||||||
 | 
					//	Since this a low-performance implementation, I allow a maximum of 1 (one!) incoming request when I listen
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					OSErr MacSocket_listen(const int inSocketNum,const int inPortNum);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					//	Call this to close a socket
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					OSErr MacSocket_close(const int inSocketNum);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					//	Call this to receive data on a socket
 | 
				
			||||||
 | 
					//	Most parameters' purpose are obvious-- except maybe "inBlock" which controls whether I wait for data or return immediately
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					int MacSocket_recv(const int inSocketNum,void *outBuff,int outBuffLength,const Boolean inBlock);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					//	Call this to send data on a socket
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					int MacSocket_send(const int inSocketNum,const void *inBuff,int inBuffLength);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					//	If zero bytes were read in a call to MacSocket_recv(), it may be that the remote end has done a half-close
 | 
				
			||||||
 | 
					//	This function will let you check whether that's true or not
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Boolean MacSocket_RemoteEndIsClosing(const int inSocketNum);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					//	Call this to see if the listen has completed after a call to MacSocket_listen()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Boolean MacSocket_ListenCompleted(const int inSocketNum);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					//	These really aren't very useful anymore
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Boolean MacSocket_LocalEndIsOpen(const int inSocketNum);
 | 
				
			||||||
 | 
					Boolean MacSocket_RemoteEndIsOpen(const int inSocketNum);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					//	You may wish to change the userRefPtr for a socket callback-- use this to do it
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void MacSocket_SetUserRefPtr(const int inSocketNum,void *inNewRefPtr);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					//	Call these to get the socket's IP:port descriptor
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void MacSocket_GetLocalIPAndPort(const int inSocketNum,char *outIPAndPort,const int inIPAndPortLength);
 | 
				
			||||||
 | 
					void MacSocket_GetRemoteIPAndPort(const int inSocketNum,char *outIPAndPort,const int inIPAndPortLength);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					//	Call this to get error info from a socket
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void MacSocket_GetSocketErrorInfo(const int inSocketNum,int *outSocketErrCode,char *outSocketErrString,const int inSocketErrStringMaxLength);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef __cplusplus
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
							
								
								
									
										4940
									
								
								MacOS/OpenSSL.mcp.hqx
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										4940
									
								
								MacOS/OpenSSL.mcp.hqx
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										476
									
								
								MacOS/Randomizer.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										476
									
								
								MacOS/Randomizer.cpp
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,476 @@
 | 
				
			|||||||
 | 
					/* 
 | 
				
			||||||
 | 
					------- Strong random data generation on a Macintosh (pre - OS X) ------
 | 
				
			||||||
 | 
							
 | 
				
			||||||
 | 
					--	GENERAL: We aim to generate unpredictable bits without explicit
 | 
				
			||||||
 | 
						user interaction. A general review of the problem may be found
 | 
				
			||||||
 | 
						in RFC 1750, "Randomness Recommendations for Security", and some
 | 
				
			||||||
 | 
						more discussion, of general and Mac-specific issues has appeared
 | 
				
			||||||
 | 
						in "Using and Creating Cryptographic- Quality Random Numbers" by
 | 
				
			||||||
 | 
						Jon Callas (www.merrymeet.com/jon/usingrandom.html).
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						The data and entropy estimates provided below are based on my
 | 
				
			||||||
 | 
						limited experimentation and estimates, rather than by any
 | 
				
			||||||
 | 
						rigorous study, and the entropy estimates tend to be optimistic.
 | 
				
			||||||
 | 
						They should not be considered absolute.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						Some of the information being collected may be correlated in
 | 
				
			||||||
 | 
						subtle ways. That includes mouse positions, timings, and disk
 | 
				
			||||||
 | 
						size measurements. Some obvious correlations will be eliminated
 | 
				
			||||||
 | 
						by the programmer, but other, weaker ones may remain. The
 | 
				
			||||||
 | 
						reliability of the code depends on such correlations being
 | 
				
			||||||
 | 
						poorly understood, both by us and by potential interceptors.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						This package has been planned to be used with OpenSSL, v. 0.9.5.
 | 
				
			||||||
 | 
						It requires the OpenSSL function RAND_add. 
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					--	OTHER WORK: Some source code and other details have been
 | 
				
			||||||
 | 
						published elsewhere, but I haven't found any to be satisfactory
 | 
				
			||||||
 | 
						for the Mac per se:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						* The Linux random number generator (by Theodore Ts'o, in
 | 
				
			||||||
 | 
						  drivers/char/random.c), is a carefully designed open-source
 | 
				
			||||||
 | 
						  crypto random number package. It collects data from a variety
 | 
				
			||||||
 | 
						  of sources, including mouse, keyboard and other interrupts.
 | 
				
			||||||
 | 
						  One nice feature is that it explicitly estimates the entropy
 | 
				
			||||||
 | 
						  of the data it collects. Some of its features (e.g. interrupt
 | 
				
			||||||
 | 
						  timing) cannot be reliably exported to the Mac without using
 | 
				
			||||||
 | 
						  undocumented APIs.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						* Truerand by Don P. Mitchell and Matt Blaze uses variations
 | 
				
			||||||
 | 
						  between different timing mechanisms on the same system. This
 | 
				
			||||||
 | 
						  has not been tested on the Mac, but requires preemptive
 | 
				
			||||||
 | 
						  multitasking, and is hardware-dependent, and can't be relied
 | 
				
			||||||
 | 
						  on to work well if only one oscillator is present.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						* Cryptlib's RNG for the Mac (RNDMAC.C by Peter Gutmann),
 | 
				
			||||||
 | 
						  gathers a lot of information about the machine and system
 | 
				
			||||||
 | 
						  environment. Unfortunately, much of it is constant from one
 | 
				
			||||||
 | 
						  startup to the next. In other words, the random seed could be
 | 
				
			||||||
 | 
						  the same from one day to the next. Some of the APIs are
 | 
				
			||||||
 | 
						  hardware-dependent, and not all are compatible with Carbon (OS
 | 
				
			||||||
 | 
						  X). Incidentally, the EGD library is based on the UNIX entropy
 | 
				
			||||||
 | 
						  gathering methods in cryptlib, and isn't suitable for MacOS
 | 
				
			||||||
 | 
						  either.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						* Mozilla (and perhaps earlier versions of Netscape) uses the
 | 
				
			||||||
 | 
						  time of day (in seconds) and an uninitialized local variable
 | 
				
			||||||
 | 
						  to seed the random number generator. The time of day is known
 | 
				
			||||||
 | 
						  to an outside interceptor (to within the accuracy of the
 | 
				
			||||||
 | 
						  system clock). The uninitialized variable could easily be
 | 
				
			||||||
 | 
						  identical between subsequent launches of an application, if it
 | 
				
			||||||
 | 
						  is reached through the same path.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						* OpenSSL provides the function RAND_screen(), by G. van
 | 
				
			||||||
 | 
						  Oosten, which hashes the contents of the screen to generate a
 | 
				
			||||||
 | 
						  seed. This is not useful for an extension or for an
 | 
				
			||||||
 | 
						  application which launches at startup time, since the screen
 | 
				
			||||||
 | 
						  is likely to look identical from one launch to the next. This
 | 
				
			||||||
 | 
						  method is also rather slow.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						* Using variations in disk drive seek times has been proposed
 | 
				
			||||||
 | 
						  (Davis, Ihaka and Fenstermacher, world.std.com/~dtd/;
 | 
				
			||||||
 | 
						  Jakobsson, Shriver, Hillyer and Juels,
 | 
				
			||||||
 | 
						  www.bell-labs.com/user/shriver/random.html). These variations
 | 
				
			||||||
 | 
						  appear to be due to air turbulence inside the disk drive
 | 
				
			||||||
 | 
						  mechanism, and are very strongly unpredictable. Unfortunately
 | 
				
			||||||
 | 
						  this technique is slow, and some implementations of it may be
 | 
				
			||||||
 | 
						  patented (see Shriver's page above.) It of course cannot be
 | 
				
			||||||
 | 
						  used with a RAM disk.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					--	TIMING: On the 601 PowerPC the time base register is guaranteed
 | 
				
			||||||
 | 
						to change at least once every 10 addi instructions, i.e. 10
 | 
				
			||||||
 | 
						cycles. On a 60 MHz machine (slowest PowerPC) this translates to
 | 
				
			||||||
 | 
						a resolution of 1/6 usec. Newer machines seem to be using a 10
 | 
				
			||||||
 | 
						cycle resolution as well.
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						For 68K Macs, the Microseconds() call may be used. See Develop
 | 
				
			||||||
 | 
						issue 29 on the Apple developer site
 | 
				
			||||||
 | 
						(developer.apple.com/dev/techsupport/develop/issue29/minow.html)
 | 
				
			||||||
 | 
						for information on its accuracy and resolution. The code below
 | 
				
			||||||
 | 
						has been tested only on PowerPC based machines.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						The time from machine startup to the launch of an application in
 | 
				
			||||||
 | 
						the startup folder has a variance of about 1.6 msec on a new G4
 | 
				
			||||||
 | 
						machine with a defragmented and optimized disk, most extensions
 | 
				
			||||||
 | 
						off and no icons on the desktop. This can be reasonably taken as
 | 
				
			||||||
 | 
						a lower bound on the variance. Most of this variation is likely
 | 
				
			||||||
 | 
						due to disk seek time variability. The distribution of startup
 | 
				
			||||||
 | 
						times is probably not entirely even or uncorrelated. This needs
 | 
				
			||||||
 | 
						to be investigated, but I am guessing that it not a majpor
 | 
				
			||||||
 | 
						problem. Entropy = log2 (1600/0.166) ~= 13 bits on a 60 MHz
 | 
				
			||||||
 | 
						machine, ~16 bits for a 450 MHz machine.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						User-launched application startup times will have a variance of
 | 
				
			||||||
 | 
						a second or more relative to machine startup time. Entropy >~22
 | 
				
			||||||
 | 
						bits.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						Machine startup time is available with a 1-second resolution. It
 | 
				
			||||||
 | 
						is predictable to no better a minute or two, in the case of
 | 
				
			||||||
 | 
						people who show up punctually to work at the same time and
 | 
				
			||||||
 | 
						immediately start their computer. Using the scheduled startup
 | 
				
			||||||
 | 
						feature (when available) will cause the machine to start up at
 | 
				
			||||||
 | 
						the same time every day, making the value predictable. Entropy
 | 
				
			||||||
 | 
						>~7 bits, or 0 bits with scheduled startup.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						The time of day is of course known to an outsider and thus has 0
 | 
				
			||||||
 | 
						entropy if the system clock is regularly calibrated.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					--	KEY TIMING: A  very fast typist (120 wpm) will have a typical
 | 
				
			||||||
 | 
						inter-key timing interval of 100 msec. We can assume a variance
 | 
				
			||||||
 | 
						of no less than 2 msec -- maybe. Do good typists have a constant
 | 
				
			||||||
 | 
						rhythm, like drummers? Since what we measure is not the
 | 
				
			||||||
 | 
						key-generated interrupt but the time at which the key event was
 | 
				
			||||||
 | 
						taken off the event queue, our resolution is roughly the time
 | 
				
			||||||
 | 
						between process switches, at best 1 tick (17 msec). I  therefore
 | 
				
			||||||
 | 
						consider this technique questionable and not very useful for
 | 
				
			||||||
 | 
						obtaining high entropy data on the Mac.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					--	MOUSE POSITION AND TIMING: The high bits of the mouse position
 | 
				
			||||||
 | 
						are far from arbitrary, since the mouse tends to stay in a few
 | 
				
			||||||
 | 
						limited areas of the screen. I am guessing that the position of
 | 
				
			||||||
 | 
						the mouse is arbitrary within a 6 pixel square. Since the mouse
 | 
				
			||||||
 | 
						stays still for long periods of time, it should be sampled only
 | 
				
			||||||
 | 
						after it was moved, to avoid correlated data. This gives an
 | 
				
			||||||
 | 
						entropy of log2(6*6) ~= 5 bits per measurement.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						The time during which the mouse stays still can vary from zero
 | 
				
			||||||
 | 
						to, say, 5 seconds (occasionally longer). If the still time is
 | 
				
			||||||
 | 
						measured by sampling the mouse during null events, and null
 | 
				
			||||||
 | 
						events are received once per tick, its resolution is 1/60th of a
 | 
				
			||||||
 | 
						second, giving an entropy of log2 (60*5) ~= 8 bits per
 | 
				
			||||||
 | 
						measurement. Since the distribution of still times is uneven,
 | 
				
			||||||
 | 
						this estimate is on the high side.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						For simplicity and compatibility across system versions, the
 | 
				
			||||||
 | 
						mouse is to be sampled explicitly (e.g. in the event loop),
 | 
				
			||||||
 | 
						rather than in a time manager task.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					--	STARTUP DISK TOTAL FILE SIZE: Varies typically by at least 20k
 | 
				
			||||||
 | 
						from one startup to the next, with 'minimal' computer use. Won't
 | 
				
			||||||
 | 
						vary at all if machine is started again immediately after
 | 
				
			||||||
 | 
						startup (unless virtual memory is on), but any application which
 | 
				
			||||||
 | 
						uses the web and caches information to disk is likely to cause
 | 
				
			||||||
 | 
						this much variation or more. The variation is probably not
 | 
				
			||||||
 | 
						random, but I don't know in what way. File sizes tend to be
 | 
				
			||||||
 | 
						divisible by 4 bytes since file format fields are often
 | 
				
			||||||
 | 
						long-aligned. Entropy > log2 (20000/4) ~= 12 bits.
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
					--	STARTUP DISK FIRST AVAILABLE ALLOCATION BLOCK: As the volume
 | 
				
			||||||
 | 
						gets fragmented this could be anywhere in principle. In a
 | 
				
			||||||
 | 
						perfectly unfragmented volume this will be strongly correlated
 | 
				
			||||||
 | 
						with the total file size on the disk. With more fragmentation
 | 
				
			||||||
 | 
						comes less certainty. I took the variation in this value to be
 | 
				
			||||||
 | 
						1/8 of the total file size on the volume.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					--	SYSTEM REQUIREMENTS: The code here requires System 7.0 and above
 | 
				
			||||||
 | 
						(for Gestalt and Microseconds calls). All the calls used are
 | 
				
			||||||
 | 
						Carbon-compatible.
 | 
				
			||||||
 | 
					*/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/*------------------------------ Includes ----------------------------*/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "Randomizer.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// Mac OS API
 | 
				
			||||||
 | 
					#include <Files.h>
 | 
				
			||||||
 | 
					#include <Folders.h>
 | 
				
			||||||
 | 
					#include <Events.h>
 | 
				
			||||||
 | 
					#include <Processes.h>
 | 
				
			||||||
 | 
					#include <Gestalt.h>
 | 
				
			||||||
 | 
					#include <Resources.h>
 | 
				
			||||||
 | 
					#include <LowMem.h>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// Standard C library
 | 
				
			||||||
 | 
					#include <stdlib.h>
 | 
				
			||||||
 | 
					#include <math.h>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/*---------------------- Function declarations -----------------------*/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// declared in OpenSSL/crypto/rand/rand.h
 | 
				
			||||||
 | 
					extern "C" void RAND_add (const void *buf, int num, double entropy);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					unsigned long GetPPCTimer (bool is601);	// Make it global if needed
 | 
				
			||||||
 | 
										// elsewhere
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/*---------------------------- Constants -----------------------------*/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define kMouseResolution 6		// Mouse position has to differ
 | 
				
			||||||
 | 
										// from the last one by this
 | 
				
			||||||
 | 
										// much to be entered
 | 
				
			||||||
 | 
					#define kMousePositionEntropy 5.16	// log2 (kMouseResolution**2)
 | 
				
			||||||
 | 
					#define kTypicalMouseIdleTicks 300.0	// I am guessing that a typical
 | 
				
			||||||
 | 
										// amount of time between mouse
 | 
				
			||||||
 | 
										// moves is 5 seconds
 | 
				
			||||||
 | 
					#define kVolumeBytesEntropy 12.0	// about log2 (20000/4),
 | 
				
			||||||
 | 
										// assuming a variation of 20K
 | 
				
			||||||
 | 
										// in total file size and
 | 
				
			||||||
 | 
										// long-aligned file formats.
 | 
				
			||||||
 | 
					#define kApplicationUpTimeEntropy 6.0	// Variance > 1 second, uptime
 | 
				
			||||||
 | 
										// in ticks  
 | 
				
			||||||
 | 
					#define kSysStartupEntropy 7.0		// Entropy for machine startup
 | 
				
			||||||
 | 
										// time
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/*------------------------ Function definitions ----------------------*/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					CRandomizer::CRandomizer (void)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						long	result;
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						mSupportsLargeVolumes =
 | 
				
			||||||
 | 
							(Gestalt(gestaltFSAttr, &result) == noErr) &&
 | 
				
			||||||
 | 
							((result & (1L << gestaltFSSupports2TBVols)) != 0);
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						if (Gestalt (gestaltNativeCPUtype, &result) != noErr)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							mIsPowerPC = false;
 | 
				
			||||||
 | 
							mIs601 = false;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						else
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							mIs601 = (result == gestaltCPU601);
 | 
				
			||||||
 | 
							mIsPowerPC = (result >= gestaltCPU601);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						mLastMouse.h = mLastMouse.v = -10;	// First mouse will
 | 
				
			||||||
 | 
											// always be recorded
 | 
				
			||||||
 | 
						mLastPeriodicTicks = TickCount();
 | 
				
			||||||
 | 
						GetTimeBaseResolution ();
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						// Add initial entropy
 | 
				
			||||||
 | 
						AddTimeSinceMachineStartup ();
 | 
				
			||||||
 | 
						AddAbsoluteSystemStartupTime ();
 | 
				
			||||||
 | 
						AddStartupVolumeInfo ();
 | 
				
			||||||
 | 
						AddFiller ();
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void CRandomizer::PeriodicAction (void)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						AddCurrentMouse ();
 | 
				
			||||||
 | 
						AddNow (0.0);	// Should have a better entropy estimate here
 | 
				
			||||||
 | 
						mLastPeriodicTicks = TickCount();
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/*------------------------- Private Methods --------------------------*/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void CRandomizer::AddCurrentMouse (void)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						Point mouseLoc;
 | 
				
			||||||
 | 
						unsigned long lastCheck;	// Ticks since mouse was last
 | 
				
			||||||
 | 
										// sampled
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if TARGET_API_MAC_CARBON
 | 
				
			||||||
 | 
						GetGlobalMouse (&mouseLoc);
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
						mouseLoc = LMGetMouseLocation();
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						if (labs (mLastMouse.h - mouseLoc.h) > kMouseResolution/2 &&
 | 
				
			||||||
 | 
						    labs (mLastMouse.v - mouseLoc.v) > kMouseResolution/2)
 | 
				
			||||||
 | 
							AddBytes (&mouseLoc, sizeof (mouseLoc),
 | 
				
			||||||
 | 
									kMousePositionEntropy);
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						if (mLastMouse.h == mouseLoc.h && mLastMouse.v == mouseLoc.v)
 | 
				
			||||||
 | 
							mMouseStill ++;
 | 
				
			||||||
 | 
						else
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							double entropy;
 | 
				
			||||||
 | 
							
 | 
				
			||||||
 | 
							// Mouse has moved. Add the number of measurements for
 | 
				
			||||||
 | 
							// which it's been still. If the resolution is too
 | 
				
			||||||
 | 
							// coarse, assume the entropy is 0.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							lastCheck = TickCount() - mLastPeriodicTicks;
 | 
				
			||||||
 | 
							if (lastCheck <= 0)
 | 
				
			||||||
 | 
								lastCheck = 1;
 | 
				
			||||||
 | 
							entropy = log2l
 | 
				
			||||||
 | 
								(kTypicalMouseIdleTicks/(double)lastCheck);
 | 
				
			||||||
 | 
							if (entropy < 0.0)
 | 
				
			||||||
 | 
								entropy = 0.0;
 | 
				
			||||||
 | 
							AddBytes (&mMouseStill, sizeof (mMouseStill), entropy);
 | 
				
			||||||
 | 
							mMouseStill = 0;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						mLastMouse = mouseLoc;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void CRandomizer::AddAbsoluteSystemStartupTime (void)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						unsigned long	now;		// Time in seconds since
 | 
				
			||||||
 | 
										// 1/1/1904
 | 
				
			||||||
 | 
						GetDateTime (&now);
 | 
				
			||||||
 | 
						now -= TickCount() / 60;	// Time in ticks since machine
 | 
				
			||||||
 | 
										// startup
 | 
				
			||||||
 | 
						AddBytes (&now, sizeof (now), kSysStartupEntropy);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void CRandomizer::AddTimeSinceMachineStartup (void)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						AddNow (1.5);			// Uncertainty in app startup
 | 
				
			||||||
 | 
										// time is > 1.5 msec (for
 | 
				
			||||||
 | 
										// automated app startup).
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void CRandomizer::AddAppRunningTime (void)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						ProcessSerialNumber PSN;
 | 
				
			||||||
 | 
						ProcessInfoRec		ProcessInfo;
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						ProcessInfo.processInfoLength = sizeof (ProcessInfoRec);
 | 
				
			||||||
 | 
						ProcessInfo.processName = nil;
 | 
				
			||||||
 | 
						ProcessInfo.processAppSpec = nil;
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						GetCurrentProcess (&PSN);
 | 
				
			||||||
 | 
						GetProcessInformation (&PSN, &ProcessInfo);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						// Now add the amount of time in ticks that the current process
 | 
				
			||||||
 | 
						// has been active
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						AddBytes (&ProcessInfo, sizeof (ProcessInfoRec),
 | 
				
			||||||
 | 
								kApplicationUpTimeEntropy);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void CRandomizer::AddStartupVolumeInfo (void)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						short			vRefNum;
 | 
				
			||||||
 | 
						long			dirID;
 | 
				
			||||||
 | 
						XVolumeParam	pb;
 | 
				
			||||||
 | 
						OSErr			err;
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						if (!mSupportsLargeVolumes)
 | 
				
			||||||
 | 
							return;
 | 
				
			||||||
 | 
							
 | 
				
			||||||
 | 
						FindFolder (kOnSystemDisk, kSystemFolderType, kDontCreateFolder,
 | 
				
			||||||
 | 
								&vRefNum, &dirID);
 | 
				
			||||||
 | 
						pb.ioVRefNum = vRefNum;
 | 
				
			||||||
 | 
						pb.ioCompletion = 0;
 | 
				
			||||||
 | 
						pb.ioNamePtr = 0;
 | 
				
			||||||
 | 
						pb.ioVolIndex = 0;
 | 
				
			||||||
 | 
						err = PBXGetVolInfoSync (&pb);
 | 
				
			||||||
 | 
						if (err != noErr)
 | 
				
			||||||
 | 
							return;
 | 
				
			||||||
 | 
							
 | 
				
			||||||
 | 
						// Base the entropy on the amount of space used on the disk and
 | 
				
			||||||
 | 
						// on the next available allocation block. A lot else might be
 | 
				
			||||||
 | 
						// unpredictable, so might as well toss the whole block in. See
 | 
				
			||||||
 | 
						// comments for entropy estimate justifications.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						AddBytes (&pb, sizeof (pb),
 | 
				
			||||||
 | 
							kVolumeBytesEntropy +
 | 
				
			||||||
 | 
							log2l (((pb.ioVTotalBytes.hi - pb.ioVFreeBytes.hi)
 | 
				
			||||||
 | 
									* 4294967296.0D +
 | 
				
			||||||
 | 
								(pb.ioVTotalBytes.lo - pb.ioVFreeBytes.lo))
 | 
				
			||||||
 | 
									/ pb.ioVAlBlkSiz - 3.0));
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/*
 | 
				
			||||||
 | 
						On a typical startup CRandomizer will come up with about 60
 | 
				
			||||||
 | 
						bits of good, unpredictable data. Assuming no more input will
 | 
				
			||||||
 | 
						be available, we'll need some more lower-quality data to give
 | 
				
			||||||
 | 
						OpenSSL the 128 bits of entropy it desires. AddFiller adds some
 | 
				
			||||||
 | 
						relatively predictable data into the soup.
 | 
				
			||||||
 | 
					*/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void CRandomizer::AddFiller (void)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						struct
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							ProcessSerialNumber psn;	// Front process serial
 | 
				
			||||||
 | 
											// number
 | 
				
			||||||
 | 
							RGBColor	hiliteRGBValue;	// User-selected
 | 
				
			||||||
 | 
											// highlight color
 | 
				
			||||||
 | 
							long		processCount;	// Number of active
 | 
				
			||||||
 | 
											// processes
 | 
				
			||||||
 | 
							long		cpuSpeed;	// Processor speed
 | 
				
			||||||
 | 
							long		totalMemory;	// Total logical memory
 | 
				
			||||||
 | 
											// (incl. virtual one)
 | 
				
			||||||
 | 
							long		systemVersion;	// OS version
 | 
				
			||||||
 | 
							short		resFile;	// Current resource file
 | 
				
			||||||
 | 
						} data;
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						GetNextProcess ((ProcessSerialNumber*) kNoProcess);
 | 
				
			||||||
 | 
						while (GetNextProcess (&data.psn) == noErr)
 | 
				
			||||||
 | 
							data.processCount++;
 | 
				
			||||||
 | 
						GetFrontProcess (&data.psn);
 | 
				
			||||||
 | 
						LMGetHiliteRGB (&data.hiliteRGBValue);
 | 
				
			||||||
 | 
						Gestalt (gestaltProcClkSpeed, &data.cpuSpeed);
 | 
				
			||||||
 | 
						Gestalt (gestaltLogicalRAMSize, &data.totalMemory);
 | 
				
			||||||
 | 
						Gestalt (gestaltSystemVersion, &data.systemVersion);
 | 
				
			||||||
 | 
						data.resFile = CurResFile ();
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						// Here we pretend to feed the PRNG completely random data. This
 | 
				
			||||||
 | 
						// is of course false, as much of the above data is predictable
 | 
				
			||||||
 | 
						// by an outsider. At this point we don't have any more
 | 
				
			||||||
 | 
						// randomness to add, but with OpenSSL we must have a 128 bit
 | 
				
			||||||
 | 
						// seed before we can start. We just add what we can, without a
 | 
				
			||||||
 | 
						// real entropy estimate, and hope for the best.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						AddBytes (&data, sizeof(data), 8.0 * sizeof(data));
 | 
				
			||||||
 | 
						AddCurrentMouse ();
 | 
				
			||||||
 | 
						AddNow (1.0);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					//-------------------  LOW LEVEL ---------------------
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void CRandomizer::AddBytes (void *data, long size, double entropy)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						RAND_add (data, size, entropy * 0.125);	// Convert entropy bits
 | 
				
			||||||
 | 
											// to bytes
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void CRandomizer::AddNow (double millisecondUncertainty)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						long time = SysTimer();
 | 
				
			||||||
 | 
						AddBytes (&time, sizeof (time), log2l (millisecondUncertainty *
 | 
				
			||||||
 | 
								mTimebaseTicksPerMillisec));
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					//----------------- TIMING SUPPORT ------------------
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void CRandomizer::GetTimeBaseResolution (void)
 | 
				
			||||||
 | 
					{	
 | 
				
			||||||
 | 
					#ifdef __powerc
 | 
				
			||||||
 | 
						long speed;
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						// gestaltProcClkSpeed available on System 7.5.2 and above
 | 
				
			||||||
 | 
						if (Gestalt (gestaltProcClkSpeed, &speed) != noErr)
 | 
				
			||||||
 | 
							// Only PowerPCs running pre-7.5.2 are 60-80 MHz
 | 
				
			||||||
 | 
							// machines.
 | 
				
			||||||
 | 
							mTimebaseTicksPerMillisec =  6000.0D;
 | 
				
			||||||
 | 
						// Assume 10 cycles per clock update, as in 601 spec. Seems true
 | 
				
			||||||
 | 
						// for later chips as well.
 | 
				
			||||||
 | 
						mTimebaseTicksPerMillisec = speed / 1.0e4D;
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
						// 68K VIA-based machines (see Develop Magazine no. 29)
 | 
				
			||||||
 | 
						mTimebaseTicksPerMillisec = 783.360D;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					unsigned long CRandomizer::SysTimer (void)	// returns the lower 32
 | 
				
			||||||
 | 
											// bit of the chip timer
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					#ifdef __powerc
 | 
				
			||||||
 | 
						return GetPPCTimer (mIs601);
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
						UnsignedWide usec;
 | 
				
			||||||
 | 
						Microseconds (&usec);
 | 
				
			||||||
 | 
						return usec.lo;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef __powerc
 | 
				
			||||||
 | 
					// The timebase is available through mfspr on 601, mftb on later chips.
 | 
				
			||||||
 | 
					// Motorola recommends that an 601 implementation map mftb to mfspr
 | 
				
			||||||
 | 
					// through an exception, but I haven't tested to see if MacOS actually
 | 
				
			||||||
 | 
					// does this. We only sample the lower 32 bits of the timer (i.e. a
 | 
				
			||||||
 | 
					// few minutes of resolution)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					asm unsigned long GetPPCTimer (register bool is601)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						cmplwi	is601, 0	// Check if 601
 | 
				
			||||||
 | 
						bne	_601		// if non-zero goto _601
 | 
				
			||||||
 | 
						mftb  	r3		// Available on 603 and later.
 | 
				
			||||||
 | 
						blr			// return with result in r3
 | 
				
			||||||
 | 
					_601:
 | 
				
			||||||
 | 
						mfspr r3, spr5  	// Available on 601 only.
 | 
				
			||||||
 | 
									// blr inserted automatically
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
							
								
								
									
										43
									
								
								MacOS/Randomizer.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										43
									
								
								MacOS/Randomizer.h
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,43 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
 | 
					//	Gathers unpredictable system data to be used for generating
 | 
				
			||||||
 | 
					//	random bits
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include <MacTypes.h>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					class CRandomizer
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					public:
 | 
				
			||||||
 | 
						CRandomizer (void);
 | 
				
			||||||
 | 
						void PeriodicAction (void);
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
					private:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						// Private calls
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						void		AddTimeSinceMachineStartup (void);
 | 
				
			||||||
 | 
						void		AddAbsoluteSystemStartupTime (void);
 | 
				
			||||||
 | 
						void		AddAppRunningTime (void);
 | 
				
			||||||
 | 
						void		AddStartupVolumeInfo (void);
 | 
				
			||||||
 | 
						void		AddFiller (void);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						void		AddCurrentMouse (void);
 | 
				
			||||||
 | 
						void		AddNow (double millisecondUncertainty);
 | 
				
			||||||
 | 
						void		AddBytes (void *data, long size, double entropy);
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						void		GetTimeBaseResolution (void);
 | 
				
			||||||
 | 
						unsigned long	SysTimer (void);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						// System Info	
 | 
				
			||||||
 | 
						bool		mSupportsLargeVolumes;
 | 
				
			||||||
 | 
						bool		mIsPowerPC;
 | 
				
			||||||
 | 
						bool		mIs601;
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						// Time info
 | 
				
			||||||
 | 
						double		mTimebaseTicksPerMillisec;
 | 
				
			||||||
 | 
						unsigned long	mLastPeriodicTicks;
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						// Mouse info
 | 
				
			||||||
 | 
						long		mSamplePeriod;
 | 
				
			||||||
 | 
						Point		mLastMouse;
 | 
				
			||||||
 | 
						long		mMouseStill;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
							
								
								
									
										18
									
								
								MacOS/TODO
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								MacOS/TODO
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,18 @@
 | 
				
			|||||||
 | 
					-------------------------------------------------------------------
 | 
				
			||||||
 | 
					Verify server certificate
 | 
				
			||||||
 | 
					-------------------------------------------------------------------
 | 
				
			||||||
 | 
					Currently omitted from the project:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						crypto/tmdiff.c
 | 
				
			||||||
 | 
						crypto/bio/bss_conn.c
 | 
				
			||||||
 | 
						crypto/bio/b_sock.c
 | 
				
			||||||
 | 
						crypto/bio/bss_acpt.c
 | 
				
			||||||
 | 
						crypto/bio/bss_log.h
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					-------------------------------------------------------------------
 | 
				
			||||||
 | 
					Build libraries to link with...
 | 
				
			||||||
 | 
					-------------------------------------------------------------------
 | 
				
			||||||
 | 
					Port openssl application.
 | 
				
			||||||
 | 
					-------------------------------------------------------------------
 | 
				
			||||||
 | 
					BN optimizations (currently PPC version is compiled with BN_LLONG)
 | 
				
			||||||
 | 
					-------------------------------------------------------------------
 | 
				
			||||||
							
								
								
									
										9
									
								
								MacOS/_MWERKS_GUSI_prefix.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								MacOS/_MWERKS_GUSI_prefix.h
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,9 @@
 | 
				
			|||||||
 | 
					#include <MacHeaders.h>
 | 
				
			||||||
 | 
					#define B_ENDIAN
 | 
				
			||||||
 | 
					#ifdef __POWERPC__
 | 
				
			||||||
 | 
					#pragma longlong on
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#if 1
 | 
				
			||||||
 | 
					#define MAC_OS_GUSI_SOURCE
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#define MONOLITH
 | 
				
			||||||
							
								
								
									
										9
									
								
								MacOS/_MWERKS_prefix.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								MacOS/_MWERKS_prefix.h
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,9 @@
 | 
				
			|||||||
 | 
					#include <MacHeaders.h>
 | 
				
			||||||
 | 
					#define B_ENDIAN
 | 
				
			||||||
 | 
					#ifdef __POWERPC__
 | 
				
			||||||
 | 
					#pragma longlong on
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#if 0
 | 
				
			||||||
 | 
					#define MAC_OS_GUSI_SOURCE
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#define MONOLITH
 | 
				
			||||||
							
								
								
									
										5
									
								
								MacOS/buildinf.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								MacOS/buildinf.h
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,5 @@
 | 
				
			|||||||
 | 
					#ifndef MK1MF_BUILD
 | 
				
			||||||
 | 
					#  define CFLAGS	"-DB_ENDIAN"
 | 
				
			||||||
 | 
					#  define PLATFORM	"macos"
 | 
				
			||||||
 | 
					#  define DATE		"Sun Feb 27 19:44:16 MET 2000"
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
							
								
								
									
										820
									
								
								MacOS/mklinks.as.hqx
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										820
									
								
								MacOS/mklinks.as.hqx
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,820 @@
 | 
				
			|||||||
 | 
					(This file must be converted with BinHex 4.0)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					:#QeVE'PZDh-ZBA-!39"36'&`E(3J!!!!!!!!!*LiI6m!!!!!!3!!!*G#!!#@3J!
 | 
				
			||||||
 | 
					!!AChFQPd!!!!K3)"!3m(Fh9`F'pbG!!!!)B#!3%$"(0eFQ8!!!#(!J-%"!3("3C
 | 
				
			||||||
 | 
					cGfPdBfJ!!!#)!J%"#39cH@jMD!!!!)N#"J%$!`-&"3-'FhPcG'9Y!!!!LJ)&"3)
 | 
				
			||||||
 | 
					%!J8("!-#!`4dB@*X!!!!L`))!3-$!`-$!`-$"(4PE'`!!!#-!J)"#38$G'KP!!!
 | 
				
			||||||
 | 
					!M3))(J)@!Ki#!J))!K)#!`)B!Kd%G'KPE3!!!)i#!J%&#`4dD'9j!!!!M`)#!J)
 | 
				
			||||||
 | 
					#$3TdD(*[G@GSEh9d!!!!N!!#!3%&"(4TCQB!!!#4!J%"!`4dD@eP!!!!NJ)"!JS
 | 
				
			||||||
 | 
					#!h4T!!!!'N!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!H!!!!!!!#!!!!!!
 | 
				
			||||||
 | 
					!!!!!!!!!!!!!rrrrr`!!!$3!!!!N!!!!!#"[!!5JAb"[!!5K++!M6R9$9'mJFR9
 | 
				
			||||||
 | 
					Z)(4SDA-JFf0bDA"d)'&`F'aTBf&dD@pZ,#"jEh8JEA9cG#"QDA*cG#"TER0dB@a
 | 
				
			||||||
 | 
					X)%&`F'aP8f0bDA"d,J!!!)C8D'Pc)(0MFQP`G#"MFQ9KG'9c)#iZ,fPZBfaeC'8
 | 
				
			||||||
 | 
					[Eh"PER0cE#"KEQ3JCQPXE(-JDA3JGfPdD#"ZC@0PFh0KFRNJB@aTBA0PFbi0$8P
 | 
				
			||||||
 | 
					d)'eTCfKd)(4KDf8JB5"hD'PXC5"dEb"MEfe`E'9dC5"cEb"`E'9KFf8JBQ8JF'&
 | 
				
			||||||
 | 
					dD@9ZG$SY+3!!!#S!!J!!!!!!$3!+!"!!!!!-!!!!!!!!!!!!63!0!!S!%!%!!!`
 | 
				
			||||||
 | 
					!!!!!!!!!!!!B!!!!+!!!!!!!!!!)!!!!)!#N2c`!!DR`!!!!l!!!!!&19[ri,`0
 | 
				
			||||||
 | 
					f!#m$-$bKVDG'*KmY52ri,`-`2+LITdBQ(b!ZrrLa`'FJ,`-J2'0`ER4"l[rm)NL
 | 
				
			||||||
 | 
					KV5+)*Kp+3'B)5Ulrr'F#GJ%3!bBZrr41ANje6PB!!#m-@Bm[2%j29%Nr2!#!U"m
 | 
				
			||||||
 | 
					SAb!-CJK`!cm!UFKJ+#m-UC)J9#!)d+J!'#&!!"JJ9#!)d+J!(#&!!"a9Mbm8)&q
 | 
				
			||||||
 | 
					JAMk!9%mSE[rm6Pj1G8j@!!![$%kkre4+!'FU@Bm[2'&`E(3[2(0MF(4`)DJU+&m
 | 
				
			||||||
 | 
					J$'F5@Bm[$#mm!!!!!A!!U#UTp&K26VVrG#KZrra1ANje!!!!('&`E(3!!!!"4P*
 | 
				
			||||||
 | 
					&4J!!!!!!J%P$6L-!!!!!!*B!!!!"!!!!!!G"8&"-!!!!!!!"!!!"!!!!!S!!!!4
 | 
				
			||||||
 | 
					!!!"i)!!!K"!!!3))!!)#"!!%"!)!#!J"!"!8!)!J)J"!3%%!)2#!J"#*!%!)KJ!
 | 
				
			||||||
 | 
					J")3!)!*!!"!")!!3!K!!%!3)!"!)"!!J%!)!3#!"!)"!!S%!J!5#!3!)4!)!#%J
 | 
				
			||||||
 | 
					%!!KB#!!%C"!!!m)J!!!"3!!!!)!!!!%!!!!$J!!!"m!!!(rJ!!$rm!!"rrJ!!rr
 | 
				
			||||||
 | 
					m!!IrrJ!2rrm!(rrrJ$rrrm"rrrrJrrrrm2rrrrMrrrrmrrrrrRrrrrmrrrrq(rr
 | 
				
			||||||
 | 
					rr!rrrrJ(rrr`!rrri!(rrm!$rrq!"rrr!!rrrJ!2rr`!$rri!!IRm!!$`q!!!!(
 | 
				
			||||||
 | 
					!!!!!J!!!!!)!!!!!!!!!!!m!!!!!!!!!!!!!!!!!!!$`m!!!!!!!!!!!!!!!!!!
 | 
				
			||||||
 | 
					2!!m!!!!!!!!!!!!!!!rrm!!!m!!!!!!!!!!!!!$`c0m!!!m!!!!!!!!!!!!2!!c
 | 
				
			||||||
 | 
					-m!!!m!!!!!!!!!!!m!$-cI!!!!m!!!!!!!!!$`!-c0m!!!!!m!!!!!!!!2!!c-h
 | 
				
			||||||
 | 
					`!!!!!!m!!!!!!!m!$-cIh`!!!!!!m!!!!!$`!-c0rGh`!!!!!!m!!!!2!!c-hph
 | 
				
			||||||
 | 
					-h`!!!!!!m!!!rrr-cIhF`-h`!!!!!!m!!2lFr0rGc!`-h`!!!!!!m!$pc-rph-$
 | 
				
			||||||
 | 
					!`-h`!!!!!!m!r-`2cF`-$!!-r3!!!!!!m!m!`-c!`-!!$0m!!!!!$-m!m!`-$!`
 | 
				
			||||||
 | 
					!!-cI!!!!!-c`!!m!`-$!!!`-h`!!!!c2!!!!m!`-!!$!c0m!!!$-m!!!!!m!`!!
 | 
				
			||||||
 | 
					-$-hm!!!-c`!!!!!!m!!!`-cIc!!!c2!!!!!!!!m!$!c0r-`!$-m!!!!!!!$pm-$
 | 
				
			||||||
 | 
					-hmc!!-c`!!!!!!!2hI`-cIc-!!c2!!!!!!!!rGc2c0r-`!$-m!!!!!!!!2h-cmh
 | 
				
			||||||
 | 
					mc!!-c`!!!!!!!!$mc!rIr-!!c2!!!!!!!!!!$m$2m!r-$-m!!!!!!!!!!!$rr`!
 | 
				
			||||||
 | 
					!r-c`!!!!!!!!!!!!!!!!!!r2!!!!!!!!!!!!!!!!!!!!m!!!!!!!!!!!!!"!!B!
 | 
				
			||||||
 | 
					13"%J)4"##18%Q)+3!%&!)5!L%%3BL#83*L!G3!#!!B!2`"rJ2r"rq2rmrrlrrhr
 | 
				
			||||||
 | 
					r2riIr"ri2r!ri"h!!)!!!!#!!!!!$r!!!!!!!2r`$`!!!!!2$!m!m!!!!2$!c`!
 | 
				
			||||||
 | 
					2!!!2$!c`!!$`!2r`cpm!!!m!rGrpc2!!!2$p$p`-c`!!$`m!`-$0m!$2!2!-$-h
 | 
				
			||||||
 | 
					`$2!!$`$-hm$2!!!2m-hm$2!!!2h2hm$2!!!!r-rm$2!!!!!2r`r2!!!!!!!!!2!
 | 
				
			||||||
 | 
					!!!!!!!#D8f0bDA"d)%&`F'aTBf&dD@pZ$3e8D'Pc)(0MFQP`G#"MFQ9KG'9c)#i
 | 
				
			||||||
 | 
					Z,fPZBfaeC'8[Eh"PER0cE#"KEQ3JCQPXE(-JDA3JGfPdD#"ZC@0PFh0KFRNJB@a
 | 
				
			||||||
 | 
					TBA0PFbi0$8Pd)'eTCfKd)(4KDf8JB5"hD'PXC5"dEb"MEfe`E'9dC5"cEb"`E'9
 | 
				
			||||||
 | 
					KFf8JBQ8JF'&dD@9ZG$SY+3!!!")!!J!!!!!!!!!!!!%!"J!'%iN!!!!+@1!!!b!
 | 
				
			||||||
 | 
					!!!-J!!!!!"3!+`!(!Cm#@!!V!!F"f!*B!!!!!3!!M`C'BA0N98&6)$%Z-6!a,M%
 | 
				
			||||||
 | 
					`$J!!!!32rrm!!3!#!!-"rrm!!!d!!3!"D`!!!!!!!!!%!J!%!!)!"3!'$3!&!!*
 | 
				
			||||||
 | 
					X!!)!!!U`!!IrrJd!"`!#6`!!!!!+X!!)!!N0!!J!!@X!!!!%#Um!#J)!#J!#!!X
 | 
				
			||||||
 | 
					!$!d!#`!#E!!#!!3!"2rprr`"rrd!!!(rr!!!!J!-!!)!$3!1$3!0!!*X!!%!"!!
 | 
				
			||||||
 | 
					%rrX!$`(rq`!!$!!2!&N!8b"(CA3JF'&dD#"dEb"dD'Pc)%&`F'aP8f0bDA"d)'&
 | 
				
			||||||
 | 
					`F'aPG$XJGA0P)'Pd)(4[)'C[FQdJG'KP)("KG'JJG'mJG'KP)'PZBfaeC'8JCQp
 | 
				
			||||||
 | 
					XC'9b!!)!!!)!$J!#!"!!%3d!%!!#E!!"!!3!"2rk!")"rrS!!!`!%J!Q!#!JB@j
 | 
				
			||||||
 | 
					N)(4SC5"[G'KPFL"bC@aPGQ&ZG#"QEfaNCA*c,J!#!!!#!"%!!J!6!"30!"-!!R-
 | 
				
			||||||
 | 
					!!!!%!"%!&3!@$3!9!!*M!!!!"!!1!"F!'!d!&`!#E!!&!!3!$!!CrrN0!"N!!Qi
 | 
				
			||||||
 | 
					!!!!%!!`!'J!E$3!D!!)d!!!!"3!-rrJ!(!Vrq!!%#Q0[BQS0!"`!!Q`!"3!'!!X
 | 
				
			||||||
 | 
					!(Irh$3!G!!0*!!)!"J!,rrB!([re#[rf!"JZC@&bFfCQC(*KE'Pc!!!!!!!!)!"
 | 
				
			||||||
 | 
					KCQ4b$3!H!!"Q!!!!"J!(![re!!!"rrF!!!d!'`!"E3!!!!3!"3!I$`!I!6J)ER9
 | 
				
			||||||
 | 
					XE!!!!!!!!Gq!rrm!!!!A"NCTEQ4PFJ!!(`*[Me!!ASfm!Qq,i!"HA[!!I&M!!!!
 | 
				
			||||||
 | 
					!!!!!'mi!!JN#!Qq-1!!!Kb%#Ei`J!!!!!%C14&*038e"3e-!!"%!B@aTF`!!!!!
 | 
				
			||||||
 | 
					!fJ!#!!!-6@&MD@jdEh0S)%K%!!!!!!!!!!!!!!!!!!!!XSA5h%*%!!!!!!!A"NC
 | 
				
			||||||
 | 
					TEQ4PFJ!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
 | 
				
			||||||
 | 
					!!!!!!!!!!!!!!!!!!!!!3rLc#@a!4Nj%8Ne"3e2rrrrr!!!!!!!!!!!!!!!!!!!
 | 
				
			||||||
 | 
					!!!!!!!e6HA0dC@dJ4QpXC'9b!!!"!!3!!!!A!!)!)8eKBfPZG'pcD#")4$T6HA0
 | 
				
			||||||
 | 
					dC@dJ4QpXC'9b1NCTEQ4PFJ$rr`!!!Irj!!!0!"J!!@d!!!!-!!hrp!Vrp!!%#Q0
 | 
				
			||||||
 | 
					dH(30!"B!!@m!!!!!!!$rm`[rm`!5-!!(G'KPF'&dD!!(G'KP8'&dD!)!&!!#!#!
 | 
				
			||||||
 | 
					!)3d!)!!#E!!#!")!%[rbrr%"rr)!!!(rm3!!!J!K!!)!)J!M$3!L!!*b!!!!%J!
 | 
				
			||||||
 | 
					A!#3!*3d!*!!#EJ!$!")!&3!Q!#F0!#B!!6%!!!!6!"Arm!Vrm!!%#R4iC'`0!#F
 | 
				
			||||||
 | 
					!!6%!!!!5!"2rl`Vrl`!%#Q&cBh)0!#8!!@m!!!!!!!$rlJ[rlJ!F-!!-G'KPEfa
 | 
				
			||||||
 | 
					NC'9XD@ec!!adD'92E'4%C@aTEA-#!#-!!J!S!#N0!#J!!R)!!!!B!"d!+J!V$3!
 | 
				
			||||||
 | 
					U!!&Y!!!!'!!C!#`-!#`!"`!"1J!#!!!0!#X!!Qi!!`!!!!!!,3!Z$3!Y!!%a!!!
 | 
				
			||||||
 | 
					!'J!Frqd+rqd!"!TdH'4X$3!Z!!%a!!!!'3!Drq`+rq`!"!TKFf0b!J!T!!)!,`!
 | 
				
			||||||
 | 
					`$3![!!*X!!)!(J!Hrq[rkJ(rk`!!!IrU!!!#!$!!!J!a!$)0!$%!!R)!!!!H!#X
 | 
				
			||||||
 | 
					!-`!d$3!c!!*X!!8!(J!T!$Ark3d!03!#EJ!!!"i!+3!f!$F0!$B!!cF"!!!I!#R
 | 
				
			||||||
 | 
					rk!!i!$N+rqJ!"!TMDA4Y$3!i!!&Y!!!!)`!PrqF$rqF!!3d!13!"E3!!!#B!+2r
 | 
				
			||||||
 | 
					Q!rrQrrd0!$F!!@m!!!!H!"rrj3[rj3!5-!!(G'KPF'&dD!!(G'KP8'&dD!(rk3!
 | 
				
			||||||
 | 
					!$3!d!!&[!!!!!!!!rq3,rq3!)$!!$R4SCA"bEfTPBh4`BA4S!!jdD'93FQpUC@0
 | 
				
			||||||
 | 
					d8'&dD!)!-J!#!$S!1`d!1J!#FJ!!!#`!1`!m!$d0!$`!!Q-!!!!X!$N!2J!r$3!
 | 
				
			||||||
 | 
					q!!*X!!8!,!!h!%$ri`d!3!!#EJ!!!#`!0`""!%)0!%%!!cF"!!!Y!$IriJ"$!%3
 | 
				
			||||||
 | 
					+rq)!"!TMDA4Y$3"$!!&Y!!!!-3!crq%$rq%!!3d!4!!"E3!!!$3!0[rJ!rrJrri
 | 
				
			||||||
 | 
					0!%)!!@m!!!!X!#hrh`[rh`!5-!!(G'KPF'&dD!!(G'KP8'&dD!(ri`!!$3!r!!&
 | 
				
			||||||
 | 
					Y!!!!0`!irpi+rpi!"!T849K8$3!p!!&[!!!!!!!!rpd,rpd!&M!!#A4SC@ePF'&
 | 
				
			||||||
 | 
					dD!!*G'KP6@93BA4S!J!l!!)!43"'$3"&!!*X!!)!2!!mrpcrf`(rh!!!!IrE!!!
 | 
				
			||||||
 | 
					#!%B!!J"(!%J0!%F!!R)!!!!m!%8!53"+$3"*!!*M!!!!2!""!%X!6!d!5`!#BJ!
 | 
				
			||||||
 | 
					!!$`!2`"0!%i0!%d!!@m!!!!m!$hrfJ[rfJ!J-!!1G'KPF(*[DQ9MG("KG'J!$R4
 | 
				
			||||||
 | 
					SC9"bEfTPBh43BA4S$3"1!!&Y!!!!23!q!%m-!%m!$3!(D@jME(9NC3!#!!!0!%`
 | 
				
			||||||
 | 
					!!@d!!!!r!%$rf3Vrf3!%#P4&@&30!%S!!@m!!!!!!!$rf![rf!!Q-!!4D@jME(9
 | 
				
			||||||
 | 
					NC@C[E'4PFR"KG'J!%@PZBfaeC'9'EfaNCA*3BA4S!J")!!)!8!"4$3"3!!*b!!!
 | 
				
			||||||
 | 
					!4J"9!&)!8`d!8J!#B`!!!%B!83"8!&80!&3!!Q)!!!"'!%m!9J"A$3"@!!*L!!!
 | 
				
			||||||
 | 
					!4J",!&J!@3d!@!!"E`!!!%B!4rrA#rrA!#!`!!jdD'9`FQpUC@0dF'&dD!!1G'K
 | 
				
			||||||
 | 
					P8(*[DQ9MG&"KG'J0!&N!!@d!!!"(!%S!@J`!@J!0!!GTEQ0XG@4P!!)!!!d!9`!
 | 
				
			||||||
 | 
					"E3!!!%X!6J"E$!"E!!d!"fp`C@jcFf`!!J!!$3"9!!&Y!!!!6`"3rpB+rpB!"!T
 | 
				
			||||||
 | 
					849K8$3"6!!&[!!!!!!!!rp8,rp8!0$!!''p`C@jcFfaTEQ0XG@4PCQpXC'9bF'&
 | 
				
			||||||
 | 
					dD!!BEh"PEP066%PZBfaeC'9'EfaNCA*3BA4S!J"4!!)!A!"G$3"F!!*b!!!!9J"
 | 
				
			||||||
 | 
					K!&i!A`d!AJ!#B`!!!&B!A3"J!'%0!'!!!Q)!!!"@!&X!BJ"M$3"L!!&[!!!!9J"
 | 
				
			||||||
 | 
					Arp3,rp3!)$!!$R4SCA"bEfTPBh4`BA4S!!jdD'93FQpUC@0d8'&dD!d!B`!"E3!
 | 
				
			||||||
 | 
					!!&F!@J"N$!"N!!`!"Q0bHA"dE`!#!!!0!'%!!@d!!!"E!&crd`Vrd`!%#P4&@&3
 | 
				
			||||||
 | 
					0!&m!!@m!!!!!!!$rdJ[rdJ!N-!!3Bh*jF(4[CQpXC'9bF'&dD!!3Bh*jF(4[4Qp
 | 
				
			||||||
 | 
					XC'9b8'&dD!)!A3!#!'8!CJd!C3!#FJ!!!')!E3"R!'J0!'F!!Q-!!!"L!'N!D3"
 | 
				
			||||||
 | 
					U$3"T!!*L!!!!BJ"R!'X!E!d!D`!"E`!!!')!Brr4#rr4!#!`!!jdD'9`FQpUC@0
 | 
				
			||||||
 | 
					dF'&dD!!1G'KP8(*[DQ9MG&"KG'J0!'`!!@d!!!"M!'B!E3`!E3!*!!0cFf`!!J!
 | 
				
			||||||
 | 
					!$3"U!!&Y!!!!C`"Srp!+rp!!"!T849K8$3"S!!&[!!!!!!!!rmm,rmm!(M!!$A0
 | 
				
			||||||
 | 
					cE'C[E'4PFR"KG'J!$A0cE%C[E'4PFP"KG'J#!'B!!J"Z!'m0!'i!!R)!!!"Z!(8
 | 
				
			||||||
 | 
					!F!"a$3"`!!*M!!!!EJ"a!()!F`d!FJ!"E`!!!'i!Err1#rr1!#!`!!jdD'9`FQp
 | 
				
			||||||
 | 
					UC@0dF'&dD!!1G'KP8(*[DQ9MG&"KG'J0!(-!!@d!!!"[!($rc3Vrc3!%#P4&@&3
 | 
				
			||||||
 | 
					0!(%!!@m!!!!!!!$rc![rc!!Q-!!4Eh"PER0cE'C[E'4PFR"KG'J!%@p`C@jcFfa
 | 
				
			||||||
 | 
					'EfaNCA*3BA4S!J"[!!)!G!"e$3"d!!*X!!)!GJ"frm[rbJ(rb`!!!Ir+!!!#!(8
 | 
				
			||||||
 | 
					!!J"f!(F0!(B!!R)!!!"f!(X!H!"j$3"i!!&[!!!!GJ"hrmN,rmN!($!!$(4SC@p
 | 
				
			||||||
 | 
					XC'4PE'PYF`!-G'KP6faN4'9XD@ec$3"j!!*Z!!-!!!!!!(S!H`d!HJ!"-3!!!(J
 | 
				
			||||||
 | 
					!H[r)#[r)!!3+G(KNE!d!H`!"-3!!!(F!H2r(#[r(!!3+BA0MFJ)!G`!#!(`!I3d
 | 
				
			||||||
 | 
					!I!!#E!!#!(`!I2r'rm8"rmB!!!(ra3!!!J"p!!)!IJ"r$3"q!!*X!!%!I!"mrm3
 | 
				
			||||||
 | 
					!J!(ra!!!$!#!!%!!1L"NC@aPG'8JEfaN)'PZBfaeC'8kEh"PER0cE#"QEfaNCA)
 | 
				
			||||||
 | 
					JB@jN)(*PBh*PBA4P)'Pd)'0XC@&ZE(N!!J!!!J"r!!)!J3##$3#"!!*X!!)!I!"
 | 
				
			||||||
 | 
					mrm2r`J(r``!!!Ir#!!!#!))!!J#$!)30!)-!!e%!!!"m!+8!K3#'!)F0!)8!!@X
 | 
				
			||||||
 | 
					!!!"r!*`!L!)!L!!#!)N!LJd!L3!$53!#!(m!N[r"!)[r`!Vr`3!B,QeTFf0cE'0
 | 
				
			||||||
 | 
					d+LSU+J!!!!!!!*!!!#SU+LS0!)X!!Qi!!!"r!)i!M!#0$3#-!!)d!!!!K`#1rlm
 | 
				
			||||||
 | 
					!MJVr[`!%#Q0QEf`0!)i!!@d!!!#+!)d!M``!M`!0!!G[F'9ZFh0X!!)!!!d!M3!
 | 
				
			||||||
 | 
					#0!!!!(m!Krqq!*!!#[qq!!3+BfC[E!d!N!!!!@m!!!#$!)Er[3[r[3!Q-!!4D@j
 | 
				
			||||||
 | 
					ME(9NC@C[E'4PFR"KG'J!%@PZBfaeC'9'EfaNCA*3BA4S![r!!!!#!)S!!J#4rl`
 | 
				
			||||||
 | 
					0!*%!!dN!!J#6!*crZ`#5rlS+rlX!'#jMEh*PC'9XEbSU+LS!!!!!!!#3!!!U+LS
 | 
				
			||||||
 | 
					U$3#5!!%a!!!!N`#BrlN+rlN!"!TcC@aP![qk!!!#rl`!!!d!KJ!$8J!!!!!!!2q
 | 
				
			||||||
 | 
					irlIrYJVrZ!!B,Q&cBh*PFR)J+LSU+J!!!!!!!*!!!#SU+LS"rlF!!!,rYJ!!$3#
 | 
				
			||||||
 | 
					(!!*X!!%!T!#Nrl8!N`(rY3!!$!#6!"-!$5"TCfj[FQ8JCA*bEh)!!J!!!J#%!!)
 | 
				
			||||||
 | 
					!P!#9$3#8!!*X!!)!TJ#Qrl6rX`(rY!!!!Iqc!!!#!*8!!J#@!*F0!*B!!dN!!J#
 | 
				
			||||||
 | 
					Q!,lrX[qa!*J+rl)!'#jMEh*PBh*PE#SU+LS!!!!!!!#3!!"ZG@aX!Iqa!!!'!*J
 | 
				
			||||||
 | 
					!!rq`!*N!QJVrX!!%#QY[Bf`0!*N!!@d!!!#U!+hrV`VrV`!%#Q0QEf`'!*S!!rq
 | 
				
			||||||
 | 
					Z!*[rV3VrVJ!%#QPZFfJ0!*X!!M3!!!#`!,MrV!#F#[qX!!3+BfC[E!d!R!!"E`!
 | 
				
			||||||
 | 
					!!,3!YrqV#rqV!#B`!"&TEQ0XG@4PCQpXC'9bF'&dD!!4D@jME(9NC8C[E'4PFP"
 | 
				
			||||||
 | 
					KG'J'rkd!!!)!P`!#!*d!RJd!R3!#FJ!!!,m!aJ#I!+!0!*m!!Q`"!!#r!-)!SIq
 | 
				
			||||||
 | 
					U$3#K!!%a!!!![`$#rkN+rkN!"!TbFfad!IqU!!!0!+!!!@m!!!!!!!$rU![rU!!
 | 
				
			||||||
 | 
					Z-!!9G'KPEQ9hCQpXC'9bFQ9QCA*PEQ0P!"9dD'91CAG'EfaNCA*5C@CPFQ9ZBf8
 | 
				
			||||||
 | 
					#!*i!!J#L!+-0!+)!!dN!!J$(!-lrT`#NrkB+rkF!'#jYDA0MFfaMG#SU+LS!!!!
 | 
				
			||||||
 | 
					!!!#3!!!U+LSU$3#N!!&[!!!!a`$+rk8,rk8!,M!!&A4SC@jPGfC[E'4PFR*PCQ9
 | 
				
			||||||
 | 
					bC@jMC3!9G'KP6Q9h4QpXC'9b8Q9QCA*PEQ0P![qQ!!!#!+-!!J#P!+B0!+8!!R)
 | 
				
			||||||
 | 
					!!!$2!0`!T`#S$3#R!!&Y!!!!c`$5!+N-!+N!$3!(Eh"PER0cE!!#!!!0!+J!!Qi
 | 
				
			||||||
 | 
					!!!!!!!!!UJ#V$3#U!!%a!!!!e`$Erk3+rk3!"!T`EQ&Y$3#V!!%a!!!!dJ$Ark-
 | 
				
			||||||
 | 
					+rk-!"!TcC@aP!J#Q!!)!V!#Y$3#X!!*X!!)!h3$Grk,rS3(rSJ!!!IqK!!!#!+d
 | 
				
			||||||
 | 
					!!J#Z!+m0!+i!!Q`!!3$G!0hrS!#`!IqJ!!!-!,!!(`!C)&0dBA*d)'eKDfPZCb"
 | 
				
			||||||
 | 
					dD'8JB@aTBA0PF`!#!!!#!+m!!J#a!,)0!,%!!dN!!J$G!3ArRrqH!,-+rjm!'#j
 | 
				
			||||||
 | 
					MEh*PBh*PE#SU+LS!!!!!!!#3!!"ZG@aX!IqH!!!'!,-!!rqG!,3!Y3VrR3!%#QY
 | 
				
			||||||
 | 
					[Bf`0!,3!!@d!!!$K!16rR!VrR!!%#Q&XD@%'!,8!!rqE!,B!Y`VrQ`!%#QPZFfJ
 | 
				
			||||||
 | 
					0!,B!!M3!!!$R!1rrQJ#i#[qD!!3+BfC[E!d!Z!!"E`!!!1X!l[qC#rqC!$3`!"K
 | 
				
			||||||
 | 
					[F'9ZFh0XD@jME(9NC@C[E'4PFR"KG'J!''p`C@j68da*EQ0XG@4P4QpXC'9b8'&
 | 
				
			||||||
 | 
					dD!B!Y`!$rjJ!ZIqA#[qB!!3+G'mJ)!d!Z3!#EJ!!!2)!r`#k!,X0!,S!!M3!!!$
 | 
				
			||||||
 | 
					i!2rrPJ#m#[q@!!3+CQPXC3d![!!"E3!!!2X!rJ#p$!#p!"-!$@p`C@jcFfaMEfj
 | 
				
			||||||
 | 
					Q,QJ!!J!!$3#l!!)d!!!!mJ$irj8![JVrP3!%#Q0QEf`0!,i!!@m!!!$f!2IrP![
 | 
				
			||||||
 | 
					rP!!@-!!*G'KPE@9`BA4S!!PdD'90C9"KG'J'rjF!!!)!XJ!#!,m!`!d![`!#E!!
 | 
				
			||||||
 | 
					#!3B""[q6rj)"rj-!!!(rNJ!!!J$!!!)!`3$#$3$"!!*b!!!""J%4!--!a!d!``!
 | 
				
			||||||
 | 
					#BJ!!!3B"$3$&!-B0!-8!!@m!!!%'!3RrN3[rN3!N-!!3Bh*jF(4[CQpXC'9bF'&
 | 
				
			||||||
 | 
					dD!!3Bh*jF(4[4QpXC'9b8'&dD!d!aJ!"E3!!!3N"$!$($!$(!!X!"6TKFfia!!)
 | 
				
			||||||
 | 
					!!!d!a!!"E`!!!!!!!2q3!![rN!!!&$!!#(4PEA"`BA4S!!KdC@e`8'&dD!)!`J!
 | 
				
			||||||
 | 
					#!-J!b3d!b!!$53!#!4)"22q2rii!bJVrM`!B,Q0[FQ9MFQ9X+LSU+J!!!!!!!*!
 | 
				
			||||||
 | 
					!!'jeE'`"rii!!!B!bJ!$rid!b`$-#[q0!!3+DfpME!d!b`!"E3!!!4B"'Iq-#[q
 | 
				
			||||||
 | 
					-!!3+B@aTB3B!c!!$riX!c3$1#[q,!!3+D@jcD!d!c3!#0!!!!4`"*2q+!-m+riS
 | 
				
			||||||
 | 
					!"!TMCQpX$3$2!!&[!!!")!%MriN,riN!0$!!''p`C@jcFfaTEQ0XG@4PCQpXC'9
 | 
				
			||||||
 | 
					bF'&dD!!BEh"PEP066%PZBfaeC'9'EfaNCA*3BA4S"J$1!!2rL!$3riF+riJ!"!T
 | 
				
			||||||
 | 
					dEb!J$3$3!!*Z!!!"*`%f!0%!dJd!d3!#0!!!!5m"0[q'!0-+riB!"!TQD@aP$3$
 | 
				
			||||||
 | 
					6!!&Y!!!"-J%e!03-!03!$!!'BA0Z-5jS!!)!!!d!dJ!#0!!!!5F",rq&!08+ri8
 | 
				
			||||||
 | 
					!"!TMCQpX$3$9!!&[!!!"+`%Zri3,ri3!&$!!#(4PEA"`BA4S!!KdC@e`8'&dD!E
 | 
				
			||||||
 | 
					rK`!!!J$*!!)!eJ$A$3$@!!0*!!)"23&Rri2rJJ$B#[q$!"JZBfpbC@0bC@`U+LS
 | 
				
			||||||
 | 
					U!!!!!!!!N!!!ER9XE!(rJJ!!"J$B!!2rJ3$C!0S+ri%!"!TVEf0X$3$C!!&Y!!!
 | 
				
			||||||
 | 
					"33&%ri!+ri!!"!TKE'PK"J$D!!2rI`$E!0`+rhm!"!TTER0S$3$E!!)d!!!"4`&
 | 
				
			||||||
 | 
					2rhi!h3VrIJ!%#Q0QEf`0!0d!!@m!!!&,!8lrI3[rI3!d-!!BEh"PER0cE'PZBfa
 | 
				
			||||||
 | 
					eC'9QEfaNCA*`BA4S!"K[F'9Z8e0-5@jME(9NC8C[E'4PFP"KG'J'!0`!!rpm!0l
 | 
				
			||||||
 | 
					rH`VrI!!%#R4[)#!0!0i!!Qi!!!&5!@%!h`$J$3$I!!)d!!!"@J&KrhS!i3VrHJ!
 | 
				
			||||||
 | 
					%#QCTE'80!1%!!@d!!!&G!@!!iJ`!iJ!3!!TKFfiaAfeKBbjS!!)!!!d!i!!#0!!
 | 
				
			||||||
 | 
					!!9)"@[pj!1-+rhN!"!TMCQpX$3$M!!&[!!!"9J&CrhJ,rhJ!&$!!#(4PEA"`BA4
 | 
				
			||||||
 | 
					S!!KdC@e`8'&dD!ErH`!!!J$A!!)!j!$P$3$N!!*X!!)"D!&SrhIrGJ(rG`!!!Ip
 | 
				
			||||||
 | 
					f!!!#!18!!J$Q!1F0!1B!!R)!!!&S!A-!k!$T$3$S!!*L!!!"D!&[!1S!k`d!kJ!
 | 
				
			||||||
 | 
					"E`!!!@J"Drpe#rpe!#3`!""MFRP`G'pQEfaNCA*`BA4S!""MFRP`G'p'EfaNCA*
 | 
				
			||||||
 | 
					3BA4S$3$V!!&Y!!!"D`&Z!1`-!1`!#J!%1Q*TE`!#!!!0!1N!!@m!!!!!!!$rG![
 | 
				
			||||||
 | 
					rG!!8-!!)G'9YF("KG'J!#(4PEA"3BA4S!J$R!!)!l3$Z$3$Y!!0*!!)"G!'Hrh2
 | 
				
			||||||
 | 
					rFJ$[#[pc!"JZBfpbC@0bC@`U+LSU!!!!!!!!N!!!ER9XE!(rFJ!!"J$[!!2rF3$
 | 
				
			||||||
 | 
					`!2%+rh%!"!TVEf0X$3$`!!&Y!!!"H!&lrh!+rh!!"!TKE'PK"J$a!!2rE`$b!2-
 | 
				
			||||||
 | 
					+rfm!"!TTER0S$3$b!!)d!!!"IJ''rfi!p!VrEJ!%#Q0QEf`0!23!!@m!!!'#!BA
 | 
				
			||||||
 | 
					rE3[rE3!d-!!BEh"PER0cE'PZBfaeC'9QEfaNCA*`BA4S!"K[F'9Z8e0-5@jME(9
 | 
				
			||||||
 | 
					NC8C[E'4PFP"KG'J'!2-!!rpX!2ArD`VrE!!%#R4[)#!0!28!!Qi!!!'*!CJ!pJ$
 | 
				
			||||||
 | 
					h$3$f!!)d!!!"N3'BrfS!q!VrDJ!%#QCTE'80!2J!!@d!!!'8!CF!q3`!q3!,!!9
 | 
				
			||||||
 | 
					LD@mZD!!#!!!0!2F!!M3!!!'*!C(rD3$k#[pT!!3+BfC[E!d!qJ!"E`!!!Bd"N!$
 | 
				
			||||||
 | 
					rD![rD!!8-!!)G'9YF("KG'J!#(4PEA"3BA4S"[pV!!!#!1i!!J$l!2`0!2X!!Q`
 | 
				
			||||||
 | 
					!!J'I!CrrCrpQ!IpR!!!"rfB!!!)!r!!#!2d!rJd!r3!#FJ!!!Cm"UJ$r!3!0!2m
 | 
				
			||||||
 | 
					!!Q)!!!'I!DB"!3%#$3%"!!&[!!!"R`'Lrf8,rf8!*$!!%'0bHA"dEfC[E'4PFR"
 | 
				
			||||||
 | 
					KG'J!%'0bHA"dEdC[E'4PFP"KG'J0!3)!!@d!!!'L!D8"!``"!`!*!!-kBQB!!J!
 | 
				
			||||||
 | 
					!$3%!!!&[!!!!!!!!rf3,rf3!&$!!#(4PEA"`BA4S!!KdC@e`8'&dD!)!rJ!#!33
 | 
				
			||||||
 | 
					""3d""!!$53!#!DX"eIpMrf)""JVrB`!B,Q0[FQ9MFQ9X+LSU+J!!!!!!!*!!!'j
 | 
				
			||||||
 | 
					eE'`"rf)!!!B""J!$rf%""`%)#[pK!!3+DfpME!d""`!"E3!!!Dm"X[pJ#[pJ!!3
 | 
				
			||||||
 | 
					+B@aTB3B"#!!$rem"#3%+#[pI!!3+D@jcD!d"#3!#0!!!!E8"[IpH!3X+rei!"!T
 | 
				
			||||||
 | 
					MCQpX$3%,!!&[!!!"Z3'mred,red!0$!!''p`C@jcFfaTEQ0XG@4PCQpXC'9bF'&
 | 
				
			||||||
 | 
					dD!!BEh"PEP066%PZBfaeC'9'EfaNCA*3BA4S"J%+!!2rA!%-reX+re`!"!TdEb!
 | 
				
			||||||
 | 
					J$3%-!!*Z!!!"`!(2!3d"$Jd"$3!#0!!!!FJ"crpD!3m+reS!"!TQD@aP$3%2!!&
 | 
				
			||||||
 | 
					Y!!!"b`(1!4!-!4!!%!!+BQa[GfCTFfJZD!!#!!!0!3i!!M3!!!(!!FMr@3%4#[p
 | 
				
			||||||
 | 
					C!!3+BfC[E!d"%3!"E`!!!F3"arpB#rpB!"3`!!KdC@e`F'&dD!!)G'9YF&"KG'J
 | 
				
			||||||
 | 
					'reX!!!)""3!#!4)"%`d"%J!#E!!#!GB"e[pAreB"reF!!!(r9J!!!J%6!!)"&!%
 | 
				
			||||||
 | 
					9$3%8!!*b!!!"eJ(K!4B"&`d"&J!#BJ!!!GB"h3%B!4N0!4J!!@m!!!(@!GRr93[
 | 
				
			||||||
 | 
					r93!N-!!3Bh*jF(4[CQpXC'9bF'&dD!!3Bh*jF(4[4QpXC'9b8'&dD!d"'3!"E3!
 | 
				
			||||||
 | 
					!!GN"h!%D$!%D!!N!!cTLEJ!#!!!0!4F!!@m!!!!!!!$r9![r9!!8-!!)G'9YF("
 | 
				
			||||||
 | 
					KG'J!#(4PEA"3BA4S!J%9!!)"'`%F$3%E!!0*!!)"iJ)-re2r8J%G#[p6!"JZBfp
 | 
				
			||||||
 | 
					bC@0bC@`U+LSU!!!!!!!!N!!!ER9XE!(r8J!!"J%G!!2r83%H!4m+re%!"!TVEf0
 | 
				
			||||||
 | 
					X$3%H!!&Y!!!"jJ(Tre!+re!!"!TKE'PK"J%I!!2r6`%J!5%+rdm!"!TTER0S$3%
 | 
				
			||||||
 | 
					J!!)d!!!"l!(drdi")JVr6J!%#Q0QEf`0!5)!!@m!!!(`!I2r63[r63!d-!!BEh"
 | 
				
			||||||
 | 
					PER0cE'PZBfaeC'9QEfaNCA*`BA4S!"K[F'9Z8e0-5@jME(9NC8C[E'4PFP"KG'J
 | 
				
			||||||
 | 
					'!5%!!rp-!52r5`Vr6!!%#R4[)#!0!5-!!Qi!!!(h!JB"*!%P$3%N!!)d!!!"r`)
 | 
				
			||||||
 | 
					'rdS"*JVr5J!%#QCTE'80!5B!!@d!!!)#!J8"*``"*`!+!!4LELjS!!)!!!d"*3!
 | 
				
			||||||
 | 
					#0!!!!IF"rrp*!5J+rdN!"!TMCQpX$3%S!!&[!!!"q`(qrdJ,rdJ!&$!!#(4PEA"
 | 
				
			||||||
 | 
					`BA4S!!KdC@e`8'&dD!Er5`!!!J%F!!)"+3%U$3%T!!*X!!)#$3)0rdIr4J(r4`!
 | 
				
			||||||
 | 
					!!Ip'!!!#!5S!!J%V!5`0!5X!!R)!!!)0!KJ",3%Z$3%Y!!*L!!!#$3)8!5m"-!d
 | 
				
			||||||
 | 
					",`!"E`!!!Jd#%2p&#rp&!#3`!""MFRP`G'pQEfaNCA*`BA4S!""MFRP`G'p'Efa
 | 
				
			||||||
 | 
					NCA*3BA4S$3%`!!&Y!!!#%!)6!6%-!6%!$3!(1Q*eCQCPFJ!#!!!0!5i!!@m!!!!
 | 
				
			||||||
 | 
					!!!$r4![r4!!8-!!)G'9YF("KG'J!#(4PEA"3BA4S!J%X!!)"-J%c$3%b!!0*!!)
 | 
				
			||||||
 | 
					#'3*$rd2r3J%d#[p$!"JZBfpbC@0bC@`U+LSU!!!!!!!!N!!!ER9XE!(r3J!!"J%
 | 
				
			||||||
 | 
					d!!2r33%e!6B+rd%!"!TVEf0X$3%e!!&Y!!!#(3)Jrd!+rd!!"!TKE'PK"J%f!!2
 | 
				
			||||||
 | 
					r2`%h!6J+rcm!"!TTER0S$3%h!!)d!!!#)`)Vrci"13Vr2J!%#Q0QEf`0!6N!!@m
 | 
				
			||||||
 | 
					!!!)R!LVr23[r23!d-!!BEh"PER0cE'PZBfaeC'9QEfaNCA*`BA4S!"K[F'9Z8e0
 | 
				
			||||||
 | 
					-5@jME(9NC8C[E'4PFP"KG'J'!6J!!rmm!6Vr1`Vr2!!%#R4[)#!0!6S!!Qi!!!)
 | 
				
			||||||
 | 
					Z!Md"1`%m$3%l!!)d!!!#0J)prcS"23Vr1J!%#QCTE'80!6d!!@d!!!)j!M`"2J`
 | 
				
			||||||
 | 
					"2J!1!!KLG@CQCA)ZD!!#!!!0!6`!!M3!!!)Z!MEr13%r#[mj!!3+BfC[E!d"2`!
 | 
				
			||||||
 | 
					"E`!!!M)#0Imi#rmi!"3`!!KdC@e`F'&dD!!)G'9YF&"KG'J'rcX!!!)"-`!#!8!
 | 
				
			||||||
 | 
					"33d"3!!#E!!#!N3#42mhrcB"rcF!!!(r0J!!!J&"!!)"3J&$$3&#!!*b!!!#4!*
 | 
				
			||||||
 | 
					2!83"43d"4!!#BJ!!!N3#5`&'!8F0!8B!!@m!!!*%!NIr03[r03!N-!!3Bh*jF(4
 | 
				
			||||||
 | 
					[CQpXC'9bF'&dD!!3Bh*jF(4[4QpXC'9b8'&dD!d"4`!"E3!!!NF#5J&)$!&)!!X
 | 
				
			||||||
 | 
					!"6TMBA0d!!)!!!d"43!"E`!!!!!!!2md#rmd!"3`!!KdC@e`F'&dD!!)G'9YF&"
 | 
				
			||||||
 | 
					KG'J#!8-!!J&*!8S0!8N!!dN!!J*3!RVr-rmb!8X+rc-!'#jMEh*PBh*PE#SU+LS
 | 
				
			||||||
 | 
					!!!!!!!#3!!"ZG@aX!Imb!!!'!8X!!rma!8`"63Vr-3!%#QY[Bf`0!8`!!@d!!!*
 | 
				
			||||||
 | 
					8!PIr-!Vr-!!%#Q&XD@%'!8d!!rm[!8i"6`Vr,`!%#QPZFfJ0!8i!!M3!!!*D!Q,
 | 
				
			||||||
 | 
					r,J&3#[mZ!!3+BfC[E!d"8!!"E`!!!Pi#BImY#rmY!$3`!"K[F'9ZFh0XD@jME(9
 | 
				
			||||||
 | 
					NC@C[E'4PFR"KG'J!''p`C@j68da*EQ0XG@4P4QpXC'9b8'&dD!B"6`!$rb`"8Im
 | 
				
			||||||
 | 
					V#[mX!!3+G'mJ)!d"83!#EJ!!!Q8#G!&5!9-0!9)!!M3!!!*Y!R6r+J&8#[mU!!3
 | 
				
			||||||
 | 
					+CQPXC3d"9!!"E3!!!R!#F`&9$!&9!!`!"Q0KFh3ZD!!#!!!0!9-!!M3!!!*P!Qh
 | 
				
			||||||
 | 
					r+3&@#[mT!!3+BfC[E!d"9J!"E`!!!QN#E2mS#rmS!"3`!!KdC@e`F'&dD!!)G'9
 | 
				
			||||||
 | 
					YF&"KG'J'rbX!!!)"5J!#!9F"@!d"9`!#E!!#!RX#HrmRrbB"rbF!!!(r*J!!!J&
 | 
				
			||||||
 | 
					B!!)"@3&D$3&C!!*b!!!#H`+'!9X"A!d"@`!#BJ!!!RX#JJ&G!9i0!9d!!@m!!!*
 | 
				
			||||||
 | 
					l!Rlr*3[r*3!N-!!3Bh*jF(4[CQpXC'9bF'&dD!!3Bh*jF(4[4QpXC'9b8'&dD!d
 | 
				
			||||||
 | 
					"AJ!"E3!!!Ri#J3&I$!&I!!X!"6TMEfe`!!)!!!d"A!!"E`!!!!!!!2mN#rmN!"3
 | 
				
			||||||
 | 
					`!!KdC@e`F'&dD!!)G'9YF&"KG'J#!9S!!J&J!@%0!@!!!dN!!J+(!V(r)rmL!@)
 | 
				
			||||||
 | 
					+rb-!'#jMEh*PBh*PE#SU+LS!!!!!!!#3!!"ZG@aX!ImL!!!'!@)!!rmK!@-"C!V
 | 
				
			||||||
 | 
					r)3!%#QY[Bf`0!@-!!@d!!!+,!Slr)!Vr)!!%#Q&XD@%'!@3!!rmI!@8"CJVr(`!
 | 
				
			||||||
 | 
					%#QPZFfJ0!@8!!M3!!!+4!TRr(J&R#[mH!!3+BfC[E!d"C`!"E`!!!T8#Q2mG#rm
 | 
				
			||||||
 | 
					G!$3`!"K[F'9ZFh0XD@jME(9NC@C[E'4PFR"KG'J!''p`C@j68da*EQ0XG@4P4Qp
 | 
				
			||||||
 | 
					XC'9b8'&dD!B"CJ!$ra`"D2mE#[mF!!3+G'mJ)!d"D!!#EJ!!!T`#U`&T!@S0!@N
 | 
				
			||||||
 | 
					!!M3!!!+N!U[r'J&V#[mD!!3+CQPXC3d"D`!"E3!!!UF#UJ&X$!&X!!`!"Q0[EA!
 | 
				
			||||||
 | 
					ZD!!#!!!0!@S!!M3!!!+F!U6r'3&Y#[mC!!3+BfC[E!d"E3!"E`!!!U!#SrmB#rm
 | 
				
			||||||
 | 
					B!"3`!!KdC@e`F'&dD!!)G'9YF&"KG'J'raX!!!)"B3!#!@i"E`d"EJ!#E!!#!V)
 | 
				
			||||||
 | 
					#X[mAraB"raF!!!(r&J!!!J&[!!)"F!&a$3&`!!*b!!!#XJ+p!A)"F`d"FJ!#BJ!
 | 
				
			||||||
 | 
					!!V)#Z3&d!A80!A3!!@m!!!+b!VAr&3[r&3!N-!!3Bh*jF(4[CQpXC'9bF'&dD!!
 | 
				
			||||||
 | 
					3Bh*jF(4[4QpXC'9b8'&dD!d"G3!"E3!!!V8#Z!&f$!&f!!X!"6TMEfjQ!!)!!!d
 | 
				
			||||||
 | 
					"F`!"E`!!!!!!!2m8#rm8!"3`!!KdC@e`F'&dD!!)G'9YF&"KG'J#!A%!!J&h!AJ
 | 
				
			||||||
 | 
					0!AF!!dN!!J+q!ZMr%rm5!AN+ra-!'#jMEh*PBh*PE#SU+LS!!!!!!!#3!!"ZG@a
 | 
				
			||||||
 | 
					X!Im5!!!'!AN!!rm4!AS"H`Vr%3!%#QY[Bf`0!AS!!@d!!!,#!XAr%!Vr%!!%#Q&
 | 
				
			||||||
 | 
					XD@%'!AX!!rm2!A`"I3Vr$`!%#QPZFfJ0!A`!!M3!!!,)!Y$r$J&q#[m1!!3+BfC
 | 
				
			||||||
 | 
					[E!d"IJ!"E`!!!X`#crm0#rm0!$3`!"K[F'9ZFh0XD@jME(9NC@C[E'4PFR"KG'J
 | 
				
			||||||
 | 
					!''p`C@j68da*EQ0XG@4P4QpXC'9b8'&dD!B"I3!$r``"Irm,#[m-!!3+G'mJ)!d
 | 
				
			||||||
 | 
					"I`!#EJ!!!Y-#iJ'!!B%0!B!!!M3!!!,E!Z,r#J'##[m+!!3+CQPXC3d"JJ!"E3!
 | 
				
			||||||
 | 
					!!Yi#i3'$$!'$!!`!"Q0[EQBZD!!#!!!0!B%!!M3!!!,6!Y[r#3'%#[m*!!3+BfC
 | 
				
			||||||
 | 
					[E!d"K!!"E`!!!YF#f[m)#rm)!"3`!!KdC@e`F'&dD!!)G'9YF&"KG'J'r`X!!!)
 | 
				
			||||||
 | 
					"H!!#!B8"KJd"K3!#E!!#!ZN#kIm(r`B"r`F!!!(r"J!!!J''!!)"K`')$3'(!!*
 | 
				
			||||||
 | 
					b!!!#k3,d!BN"LJd"L3!#BJ!!!ZN#m!',!B`0!BX!!@m!!!,T!Zcr"3[r"3!N-!!
 | 
				
			||||||
 | 
					3Bh*jF(4[CQpXC'9bF'&dD!!3Bh*jF(4[4QpXC'9b8'&dD!d"M!!"E3!!!Z`#l`'
 | 
				
			||||||
 | 
					0$!'0!!S!"$TNCA-!!J!!$3'+!!&[!!!!!!!!r`3,r`3!&$!!#(4PEA"`BA4S!!K
 | 
				
			||||||
 | 
					dC@e`8'&dD!)"L!!#!Bi"M`d"MJ!$53!#![8$(rm$r`)"N!!+r`-!'#jMEh*PBh*
 | 
				
			||||||
 | 
					PE#SU+LS!!!!!!!#3!!"ZG@aX!Im#!!!'!C!!!!2r!3'4!C)+r`%!"!TVEf0X$3'
 | 
				
			||||||
 | 
					4!!&Y!!!#q3,mr`!+r`!!"!TKE'PK"J'5!!2qr`'6!C3+r[m!"!TTER0S$3'6!!)
 | 
				
			||||||
 | 
					d!!!#r`-(r[i"P3VqrJ!%#Q0QEf`0!C8!!@m!!!-$!`Eqr3[qr3!d-!!BEh"PER0
 | 
				
			||||||
 | 
					cE'PZBfaeC'9QEfaNCA*`BA4S!"K[F'9Z8e0-5@jME(9NC8C[E'4PFP"KG'J'!C3
 | 
				
			||||||
 | 
					!!rlm!CEqq`Vqr!!%#R4[)#!0!CB!!Qi!!!-+!aN"P`'B$3'A!!)d!!!$%J-Cr[S
 | 
				
			||||||
 | 
					"Q3VqqJ!%#QCTE'80!CN!!@d!!!-9!aJ"QJ`"QJ!,!!9NCA-ZD!!#!!!0!CJ!!M3
 | 
				
			||||||
 | 
					!!!-+!a,qq3'E#[lj!!3+BfC[E!d"Q`!"E`!!!`i$%Ili#rli!"3`!!KdC@e`F'&
 | 
				
			||||||
 | 
					dD!!)G'9YF&"KG'J'r[X!!!)"M`!#!C`"R3d"R!!#E!!#!b!$)2lhr[B"r[F!!!(
 | 
				
			||||||
 | 
					qpJ!!!J'G!!)"RJ'I$3'H!!*b!!!$)!-V!D!"S3d"S!!#BJ!!!b!$*`'L!D-0!D)
 | 
				
			||||||
 | 
					!!@m!!!-J!b2qp3[qp3!N-!!3Bh*jF(4[CQpXC'9bF'&dD!!3Bh*jF(4[4QpXC'9
 | 
				
			||||||
 | 
					b8'&dD!d"S`!"E3!!!b-$*J'N$!'N!!N!!cTND!!#!!!0!D%!!@m!!!!!!!$qp![
 | 
				
			||||||
 | 
					qp!!8-!!)G'9YF("KG'J!#(4PEA"3BA4S!J'I!!)"T3'Q$3'P!!0*!!)$,!0@r[2
 | 
				
			||||||
 | 
					qmJ'R#[lc!"JZBfpbC@0bC@`U+LSU!!!!!!!!N!!!ER9XE!(qmJ!!"J'R!!2qm3'
 | 
				
			||||||
 | 
					S!DN+r[%!"!TVEf0X$3'S!!&Y!!!$-!-cr[!+r[!!"!TKE'PK"J'T!!2ql`'U!DX
 | 
				
			||||||
 | 
					+rZm!"!TTER0S$3'U!!)d!!!$0J-qrZi"V!VqlJ!%#Q0QEf`0!D`!!@m!!!-k!ch
 | 
				
			||||||
 | 
					ql3[ql3!d-!!BEh"PER0cE'PZBfaeC'9QEfaNCA*`BA4S!"K[F'9Z8e0-5@jME(9
 | 
				
			||||||
 | 
					NC8C[E'4PFP"KG'J'!DX!!rlX!Dhqk`Vql!!%#R4[)#!0!Dd!!Qi!!!0"!e!"VJ'
 | 
				
			||||||
 | 
					[$3'Z!!)d!!!$5303rZS"X!VqkJ!%#QCTE'80!E!!!@d!!!0-!dm"X3`"X3!+!!4
 | 
				
			||||||
 | 
					ND#jS!!)!!!d"V`!#0!!!!d%$5IlT!E)+rZN!"!TMCQpX$3'b!!&[!!!$430)rZJ
 | 
				
			||||||
 | 
					,rZJ!&$!!#(4PEA"`BA4S!!KdC@e`8'&dD!Eqk`!!!J'Q!!)"X`'d$3'c!!*X!!)
 | 
				
			||||||
 | 
					$9`0ArZIqjJ(qj`!!!IlQ!!!#!E3!!J'e!EB0!E8!!R)!!!0A!f)"Y`'i$3'h!!*
 | 
				
			||||||
 | 
					L!!!$9`0H!EN"ZJd"Z3!"E`!!!eF$@[lP#rlP!#3`!""MFRP`G'pQEfaNCA*`BA4
 | 
				
			||||||
 | 
					S!""MFRP`G'p'EfaNCA*3BA4S$3'k!!&Y!!!$@J0G!EX-!EX!#J!%1Q4cB3!#!!!
 | 
				
			||||||
 | 
					0!EJ!!@m!!!!!!!$qj![qj!!8-!!)G'9YF("KG'J!#(4PEA"3BA4S!J'f!!)"[!'
 | 
				
			||||||
 | 
					p$3'm!!0*!!)$B`10rZ2qiJ'q#[lM!"JZBfpbC@0bC@`U+LSU!!!!!!!!N!!!ER9
 | 
				
			||||||
 | 
					XE!(qiJ!!"J'q!!2qi3'r!F!+rZ%!"!TVEf0X$3'r!!&Y!!!$C`0UrZ!+rZ!!"!T
 | 
				
			||||||
 | 
					KE'PK"J(!!!2qh`("!F)+rYm!"!TTER0S$3("!!)d!!!$E30erYi"``VqhJ!%#Q0
 | 
				
			||||||
 | 
					QEf`0!F-!!@m!!!0a!h6qh3[qh3!d-!!BEh"PER0cE'PZBfaeC'9QEfaNCA*`BA4
 | 
				
			||||||
 | 
					S!"K[F'9Z8e0-5@jME(9NC8C[E'4PFP"KG'J'!F)!!rlF!F6qf`Vqh!!%#R4[)#!
 | 
				
			||||||
 | 
					0!F3!!Qi!!!0i!iF"a3('$3(&!!)d!!!$J!1(rYS"a`VqfJ!%#QCTE'80!FF!!@d
 | 
				
			||||||
 | 
					!!!1$!iB"b!`"b!!,!!9NFf%ZD!!#!!!0!FB!!M3!!!0i!i$qf3(*#[lC!!3+BfC
 | 
				
			||||||
 | 
					[E!d"b3!"E`!!!h`$IrlB#rlB!"3`!!KdC@e`F'&dD!!)G'9YF&"KG'J'rYX!!!)
 | 
				
			||||||
 | 
					"[3!#!FS"b`d"bJ!#E!!#!ii$M[lArYB"rYF!!!(qeJ!!!J(,!!)"c!(0$3(-!!*
 | 
				
			||||||
 | 
					b!!!$MJ1C!Fi"c`d"cJ!#BJ!!!ii$P3(3!G%0!G!!!@m!!!11!j(qe3[qe3!N-!!
 | 
				
			||||||
 | 
					3Bh*jF(4[CQpXC'9bF'&dD!!3Bh*jF(4[4QpXC'9b8'&dD!d"d3!"E3!!!j%$P!(
 | 
				
			||||||
 | 
					5$!(5!!S!"$TPFR)!!J!!$3(2!!&[!!!!!!!!rY3,rY3!&$!!#(4PEA"`BA4S!!K
 | 
				
			||||||
 | 
					dC@e`8'&dD!)"c3!#!G-"e!d"d`!$53!#!jS$a2l6rY)"e3Vqd`!B,Q0[FQ9MFQ9
 | 
				
			||||||
 | 
					X+LSU+J!!!!!!!*!!!'jeE'`"rY)!!!B"e3!$rY%"eJ(A#[l4!!3+DfpME!d"eJ!
 | 
				
			||||||
 | 
					"E3!!!ji$SIl3#[l3!!3+B@aTB3B"e`!$rXm"f!(C#[l2!!3+D@jcD!d"f!!#0!!
 | 
				
			||||||
 | 
					!!k3$V2l1!GS+rXi!"!TMCQpX$3(D!!&[!!!$U!1VrXd,rXd!0$!!''p`C@jcFfa
 | 
				
			||||||
 | 
					TEQ0XG@4PCQpXC'9bF'&dD!!BEh"PEP066%PZBfaeC'9'EfaNCA*3BA4S"J(C!!2
 | 
				
			||||||
 | 
					qc!(ErXX+rX`!"!TdEb!J$3(E!!*Z!!!$V`1q!G`"h3d"h!!#0!!!!lF$[[l+!Gi
 | 
				
			||||||
 | 
					+rXS!"!TQD@aP$3(H!!&Y!!!$ZJ1p!Gm-!Gm!#`!&CA*b,QJ!!J!!$3(G!!)d!!!
 | 
				
			||||||
 | 
					$V`1hrXN"i!Vqb3!%#Q0QEf`0!H!!!@m!!!1c!lEqb![qb!!8-!!)G'9YF("KG'J
 | 
				
			||||||
 | 
					!#(4PEA"3BA4S"[l,!!!#!G3!!J(K!H)0!H%!!Q`!!J2&!mAqarl'!Il(!!!"rXB
 | 
				
			||||||
 | 
					!!!)"iJ!#!H-"j!d"i`!#FJ!!!m8$d!(P!HB0!H8!!Q)!!!2&!m`"j`(S$3(R!!&
 | 
				
			||||||
 | 
					[!!!$a32)rX8,rX8!*$!!%'0bHA"dEfC[E'4PFR"KG'J!%'0bHA"dEdC[E'4PFP"
 | 
				
			||||||
 | 
					KG'J0!HJ!!@d!!!2)!mX"k3`"k3!+!!3kCAC`!!)!!!d"jJ!"E`!!!!!!!2l%#rl
 | 
				
			||||||
 | 
					%!"3`!!KdC@e`F'&dD!!)G'9YF&"KG'J#!H3!!J(U!HX0!HS!!dN!!J24!r[q`rl
 | 
				
			||||||
 | 
					#!H`+rX-!'#jMEh*PBh*PE#SU+LS!!!!!!!#3!!"ZG@aX!Il#!!!'!H`!!rl"!Hd
 | 
				
			||||||
 | 
					"lJVq`3!%#QY[Bf`0!Hd!!@d!!!29!pMq`!Vq`!!%#Q&XD@%'!Hi!!rkr!Hm"m!V
 | 
				
			||||||
 | 
					q[`!%#QPZFfJ0!Hm!!M3!!!2E!q2q[J(a#[kq!!3+BfC[E!d"m3!"E`!!!pm$i[k
 | 
				
			||||||
 | 
					p#rkp!$3`!"K[F'9ZFh0XD@jME(9NC@C[E'4PFR"KG'J!''p`C@j68da*EQ0XG@4
 | 
				
			||||||
 | 
					P4QpXC'9b8'&dD!B"m!!$rV`"m[kl#[km!!3+G'mJ)!d"mJ!#EJ!!!qB$p3(c!I3
 | 
				
			||||||
 | 
					0!I-!!M3!!!2Z!rAqZJ(e#[kk!!3+CQPXC3d"p3!"E3!!!r%$p!(f$!(f!!X!"@9
 | 
				
			||||||
 | 
					fF#jS!!)!!!d"p!!#0!!!!qB$l[kj!IF+rVN!"!TMCQpX$3(h!!&[!!!$kJ2YrVJ
 | 
				
			||||||
 | 
					,rVJ!&$!!#(4PEA"`BA4S!!KdC@e`8'&dD!EqZ`!!!J(V!!)"q!(j$3(i!!*X!!)
 | 
				
			||||||
 | 
					$r!2mrVIqYJ(qY`!!!Ikf!!!#!IN!!J(k!IX0!IS!!R)!!!2m"!F"r!(p$3(m!!*
 | 
				
			||||||
 | 
					L!!!$r!3$!Ii"r`d"rJ!"E`!!!r`$rrke#rke!#3`!""MFRP`G'pQEfaNCA*`BA4
 | 
				
			||||||
 | 
					S!""MFRP`G'p'EfaNCA*3BA4S$3(r!!&Y!!!$r`3#!J!-!J!!#`!&1QKYB@-!!J!
 | 
				
			||||||
 | 
					!$3(p!!&[!!!!!!!!rV3,rV3!&$!!#(4PEA"`BA4S!!KdC@e`8'&dD!)"q`!#!J%
 | 
				
			||||||
 | 
					#!Jd#!3!$53!#"!J%-[kcrV)#!`VqX`!B,Q0[FQ9MFQ9X+LSU+J!!!!!!!*!!!'j
 | 
				
			||||||
 | 
					eE'`"rV)!!!B#!`!$rV%#"!)&#[ka!!3+DfpME!d#"!!"E3!!"!`%$rk`#[k`!!3
 | 
				
			||||||
 | 
					+B@aTB3B#"3!$rUm#"J)(#[k[!!3+D@jcD!d#"J!#0!!!"")%'[kZ!JJ+rUi!"!T
 | 
				
			||||||
 | 
					MCQpX$3))!!&[!!!%&J3CrUd,rUd!0$!!''p`C@jcFfaTEQ0XG@4PCQpXC'9bF'&
 | 
				
			||||||
 | 
					dD!!BEh"PEP066%PZBfaeC'9'EfaNCA*3BA4S"J)(!!2qV!)*rUX+rU`!"!TdEb!
 | 
				
			||||||
 | 
					J$3)*!!*Z!!!%(33X!JS##`d##J!#0!!!"#8%,2kU!J`+rUS!"!TQD@aP$3)-!!&
 | 
				
			||||||
 | 
					Y!!!%+!3V!Jd-!Jd!$!!'D'eKBbjS!!)!!!d##`!#0!!!""d%*IkT!Ji+rUN!"!T
 | 
				
			||||||
 | 
					MCQpX$3)1!!&[!!!%)33NrUJ,rUJ!&$!!#(4PEA"`BA4S!!KdC@e`8'&dD!EqU`!
 | 
				
			||||||
 | 
					!!J)#!!)#$`)3$3)2!!*X!!)%-`3crUIqTJ(qT`!!!IkQ!!!#!K!!!J)4!K)0!K%
 | 
				
			||||||
 | 
					!!R)!!!3c"$i#%`)8$3)6!!*L!!!%-`3k!K8#&Jd#&3!"E`!!"$-%0[kP#rkP!#3
 | 
				
			||||||
 | 
					`!""MFRP`G'pQEfaNCA*`BA4S!""MFRP`G'p'EfaNCA*3BA4S$3)@!!&Y!!!%0J3
 | 
				
			||||||
 | 
					j!KF-!KF!#`!&1QPNC@%!!J!!$3)8!!&[!!!!!!!!rU3,rU3!&$!!#(4PEA"`BA4
 | 
				
			||||||
 | 
					S!!KdC@e`8'&dD!)#%J!#!KJ#'3d#'!!$53!#"$m%DIkMrU)#'JVqS`!B,Q0[FQ9
 | 
				
			||||||
 | 
					MFQ9X+LSU+J!!!!!!!*!!!'jeE'`"rU)!!!B#'J!$rU%#'`)F#[kK!!3+DfpME!d
 | 
				
			||||||
 | 
					#'`!"E3!!"%-%4[kJ#[kJ!!3+B@aTB3B#(!!$rTm#(3)H#[kI!!3+D@jcD!d#(3!
 | 
				
			||||||
 | 
					#0!!!"%N%8IkH!Km+rTi!"!TMCQpX$3)I!!&[!!!%6343rTd,rTd!0$!!''p`C@j
 | 
				
			||||||
 | 
					cFfaTEQ0XG@4PCQpXC'9bF'&dD!!BEh"PEP066%PZBfaeC'9'EfaNCA*3BA4S"J)
 | 
				
			||||||
 | 
					H!!2qR!)JrTX+rT`!"!TdEb!J$3)J!!*Z!!!%9!4M!L%#)Jd#)3!#0!!!"&`%Brk
 | 
				
			||||||
 | 
					D!L-+rTS!"!TQD@aP$3)M!!&Y!!!%A`4L!L3-!L3!$!!'D@4PB5jS!!)!!!d#)J!
 | 
				
			||||||
 | 
					#0!!!"&3%A2kC!L8+rTN!"!TMCQpX$3)P!!&[!!!%@!4ErTJ,rTJ!&$!!#(4PEA"
 | 
				
			||||||
 | 
					`BA4S!!KdC@e`8'&dD!EqQ`!!!J)C!!)#*J)R$3)Q!!*X!!)%DJ4UrTIqPJ(qP`!
 | 
				
			||||||
 | 
					!!Ik@!!!#!LF!!J)S!LN0!LJ!!R)!!!4U"(8#+J)V$3)U!!*L!!!%DJ4a!L`#,3d
 | 
				
			||||||
 | 
					#,!!"E`!!"'S%EIk9#rk9!#3`!""MFRP`G'pQEfaNCA*`BA4S!""MFRP`G'p'Efa
 | 
				
			||||||
 | 
					NCA*3BA4S$3)Y!!&Y!!!%E34`!Li-!Li!$!!'1QaSBA0S!!)!!!d#+`!"E`!!!!!
 | 
				
			||||||
 | 
					!!2k8#rk8!"3`!!KdC@e`F'&dD!!)G'9YF&"KG'J#!LN!!J)[!M!0!Lm!!dN!!J4
 | 
				
			||||||
 | 
					f"+$qNrk5!M%+rT-!'#jMEh*PBh*PE#SU+LS!!!!!!!#3!!"ZG@aX!Ik5!!!'!M%
 | 
				
			||||||
 | 
					!!rk4!M)#-`VqN3!%#QY[Bf`0!M)!!@d!!!4k"(hqN!!+rT!!!!3+B@aTB3B#-`!
 | 
				
			||||||
 | 
					$rSm#0!)e#[k2!!3+D@jcD!d#0!!#0!!!")!%L2k1!MB+rSi!"!TMCQpX$3)f!!&
 | 
				
			||||||
 | 
					[!!!%K!5(rSd,rSd!0$!!''p`C@jcFfaTEQ0XG@4PCQpXC'9bF'&dD!!BEh"PEP0
 | 
				
			||||||
 | 
					66%PZBfaeC'9'EfaNCA*3BA4S"J)e!!2qM!)hrSX+rS`!"!TdEb!J$3)h!!*Z!!!
 | 
				
			||||||
 | 
					%L`5D!MJ#13d#1!!#0!!!"*-%Q[k+!MS+rSS!"!TQD@aP$3)k!!&Y!!!%PJ5C!MX
 | 
				
			||||||
 | 
					-!MX!$3!(E'KKFfJZD!!#!!!0!MN!!M3!!!5,"*2qL3)m#[k*!!3+BfC[E!d#2!!
 | 
				
			||||||
 | 
					"E`!!")m%N[k)#rk)!"3`!!KdC@e`F'&dD!!)G'9YF&"KG'J'rSX!!!)#-!!#!Md
 | 
				
			||||||
 | 
					#2Jd#23!#E!!#"+%%SIk(rSB"rSF!!!(qKJ!!!J)q!!)#2`*!$3)r!!*b!!!%S35
 | 
				
			||||||
 | 
					X!N%#3Jd#33!#BJ!!"+%%U!*$!N30!N-!!@m!!!5K"+6qK3[qK3!N-!!3Bh*jF(4
 | 
				
			||||||
 | 
					[CQpXC'9bF'&dD!!3Bh*jF(4[4QpXC'9b8'&dD!d#4!!"E3!!"+3%T`*&$!*&!!S
 | 
				
			||||||
 | 
					!"$TYC$)!!J!!$3*#!!&[!!!!!!!!rS3,rS3!&$!!#(4PEA"`BA4S!!KdC@e`8'&
 | 
				
			||||||
 | 
					dD!)#3!!#!NB#4`d#4J!$53!#"+d%erk$rS)#5!VqJ`!B,Q0[FQ9MFQ9X+LSU+J!
 | 
				
			||||||
 | 
					!!!!!!*!!!'jeE'`"rS)!!!B#5!!$rS%#53*+#[k"!!3+DfpME!d#53!"E3!!",%
 | 
				
			||||||
 | 
					%Y2k!#[k!!!3+B@aTB3B#5J!$rRm#5`*-#[jr!!3+D@jcD!d#5`!#0!!!",F%[rj
 | 
				
			||||||
 | 
					q!Nd+rRi!"!TMCQpX$3*0!!&[!!!%Z`5qrRd,rRd!0$!!''p`C@jcFfaTEQ0XG@4
 | 
				
			||||||
 | 
					PCQpXC'9bF'&dD!!BEh"PEP066%PZBfaeC'9'EfaNCA*3BA4S"J*-!!2qI!*1rRX
 | 
				
			||||||
 | 
					+rR`!"!TdEb!J$3*1!!*Z!!!%`J64!Nm#8!d#6`!#0!!!"-S%dIjk!P%+rRS!"!T
 | 
				
			||||||
 | 
					QD@aP$3*4!!&Y!!!%c363!P)-!P)!#`!&E@3b,QJ!!J!!$3*3!!)d!!!%`J6+rRN
 | 
				
			||||||
 | 
					#8`VqH3!%#Q0QEf`0!P-!!@m!!!6'"-RqH![qH!!8-!!)G'9YF("KG'J!#(4PEA"
 | 
				
			||||||
 | 
					3BA4S"[jl!!!#!NF!!J*8!P80!P3!!Q`!!J6B"0MqGrjf!Ijh!!!"rRB!!!)#93!
 | 
				
			||||||
 | 
					#!PB#9`d#9J!#FJ!!"0J%i`*B!PN0!PJ!!Q)!!!6B"0m#@J*E$3*D!!&[!!!%f!6
 | 
				
			||||||
 | 
					ErR8,rR8!*$!!%'0bHA"dEfC[E'4PFR"KG'J!%'0bHA"dEdC[E'4PFP"KG'J0!PX
 | 
				
			||||||
 | 
					!!@d!!!6E"0i#A!`#A!!+!!3kE@3e!!)!!!d#@3!"E`!!!!!!!2jd#rjd!"3`!!K
 | 
				
			||||||
 | 
					dC@e`F'&dD!!)G'9YF&"KG'J#!PF!!J*G!Pi0!Pd!!dN!!J6N"3lqFrjb!Pm+rR-
 | 
				
			||||||
 | 
					!'#jMEh*PBh*PE#SU+LS!!!!!!!#3!!"ZG@aX!Ijb!!!'!Pm!!rja!Q!#B3VqF3!
 | 
				
			||||||
 | 
					%#QY[Bf`0!Q!!!@d!!!6S"1[qF!VqF!!%#Q&XD@%'!Q%!!rj[!Q)#B`VqE`!%#QP
 | 
				
			||||||
 | 
					ZFfJ0!Q)!!M3!!!6Z"2EqEJ*N#[jZ!!3+BfC[E!d#C!!"E`!!"2)%pIjY#rjY!$3
 | 
				
			||||||
 | 
					`!"K[F'9ZFh0XD@jME(9NC@C[E'4PFR"KG'J!''p`C@j68da*EQ0XG@4P4QpXC'9
 | 
				
			||||||
 | 
					b8'&dD!B#B`!$rQ`#CIjV#[jX!!3+G'mJ)!d#C3!#EJ!!"2N&#!*Q!QF0!QB!!M3
 | 
				
			||||||
 | 
					!!!8""3MqDJ*S#[jU!!3+CQPXC3d#D!!"E3!!"33&"`*T$!*T!!X!"@eN05jS!!)
 | 
				
			||||||
 | 
					!!!d#C`!#0!!!"2N&!IjT!QS+rQN!"!TMCQpX$3*U!!&[!!!%r38!rQJ,rQJ!&$!
 | 
				
			||||||
 | 
					!#(4PEA"`BA4S!!KdC@e`8'&dD!EqD`!!!J*H!!)#D`*X$3*V!!*X!!)&$`82rQI
 | 
				
			||||||
 | 
					qCJ(qC`!!!IjQ!!!#!Q`!!J*Y!Qi0!Qd!!R)!!!82"4S#E`*`$3*[!!*L!!!&$`8
 | 
				
			||||||
 | 
					@!R%#FJd#F3!"E`!!"3m&%[jP#rjP!#3`!""MFRP`G'pQEfaNCA*`BA4S!""MFRP
 | 
				
			||||||
 | 
					`G'p'EfaNCA*3BA4S$3*b!!&Y!!!&%J89!R--!R-!#`!&1QeNBc)!!J!!$3*`!!&
 | 
				
			||||||
 | 
					[!!!!!!!!rQ3,rQ3!&$!!#(4PEA"`BA4S!!KdC@e`8'&dD!)#EJ!#!R3#G3d#G!!
 | 
				
			||||||
 | 
					$53!#"4X&4IjMrQ)#GJVqB`!B,Q0[FQ9MFQ9X+LSU+J!!!!!!!*!!!'jeE'`"rQ)
 | 
				
			||||||
 | 
					!!!B#GJ!$rQ%#G`*i#[jK!!3+DfpME!d#G`!"E3!!"4m&)[jJ#[jJ!!3+B@aTB3B
 | 
				
			||||||
 | 
					#H!!$rPm#H3*k#[jI!!3+D@jcD!d#H3!#0!!!"58&,IjH!RX+rPi!"!TMCQpX$3*
 | 
				
			||||||
 | 
					l!!&[!!!&+38XrPd,rPd!0$!!''p`C@jcFfaTEQ0XG@4PCQpXC'9bF'&dD!!BEh"
 | 
				
			||||||
 | 
					PEP066%PZBfaeC'9'EfaNCA*3BA4S"J*k!!2qA!*mrPX+rP`!"!TdEb!J$3*m!!*
 | 
				
			||||||
 | 
					Z!!!&-!8r!Rd#IJd#I3!#0!!!"6J&2rjD!Rm+rPS!"!TQD@aP$3*r!!&Y!!!&1`8
 | 
				
			||||||
 | 
					q!S!-!S!!$!!'E@4M-LjS!!)!!!d#IJ!#0!!!"6!&12jC!S%+rPN!"!TMCQpX$3+
 | 
				
			||||||
 | 
					"!!&[!!!&0!8hrPJ,rPJ!&$!!#(4PEA"`BA4S!!KdC@e`8'&dD!Eq@`!!!J*e!!)
 | 
				
			||||||
 | 
					#JJ+$$3+#!!*X!!)&4J9'rPIq9J(q9`!!!Ij@!!!#!S-!!J+%!S80!S3!!R)!!!9
 | 
				
			||||||
 | 
					'"9%#KJ+($3+'!!*L!!!&4J90!SJ#L3d#L!!"E`!!"8B&5Ij9#rj9!#3`!""MFRP
 | 
				
			||||||
 | 
					`G'pQEfaNCA*`BA4S!""MFRP`G'p'EfaNCA*3BA4S$3+*!!&Y!!!&539-!SS-!SS
 | 
				
			||||||
 | 
					!$J!)1QpLDQ9MG(-!!J!!$3+(!!&[!!!!!!!!rP3,rP3!&$!!#(4PEA"`BA4S!!K
 | 
				
			||||||
 | 
					dC@e`8'&dD!)#K3!#!SX#M!d#L`!$53!#"9)&I2j6rP)#M3Vq8`!B,Q0[FQ9MFQ9
 | 
				
			||||||
 | 
					X+LSU+J!!!!!!!*!!!'jeE'`"rP)!!!B#M3!$rP%#MJ+2#[j4!!3+DfpME!d#MJ!
 | 
				
			||||||
 | 
					"E3!!"9B&@Ij3#[j3!!3+B@aTB3B#M`!$rNm#N!!#N3Vq6`!%#QPZFfJ0!T!!!!)
 | 
				
			||||||
 | 
					d!!!&A!9NrNi#NJVq6J!%#Q0QEf`0!T)!!@m!!!9J"@2q63[q63!d-!!BEh"PER0
 | 
				
			||||||
 | 
					cE'PZBfaeC'9QEfaNCA*`BA4S!"K[F'9Z8e0-5@jME(9NC8C[E'4PFP"KG'J'!T%
 | 
				
			||||||
 | 
					!!rj-!T2q5`Vq6!!%#R4[)#!0!T-!!Qi!!!9R"AB#P!+9$3+8!!)d!!!&E`9frNS
 | 
				
			||||||
 | 
					#PJVq5J!%#QCTE'80!TB!!@d!!!9b"A8#P``#P`!2!!P[BQTPBh4c,QJ!!J!!$3+
 | 
				
			||||||
 | 
					9!!)d!!!&C`9[rNN#Q!Vq53!%#Q0QEf`0!TJ!!@m!!!9V"@lq5![q5!!8-!!)G'9
 | 
				
			||||||
 | 
					YF("KG'J!#(4PEA"3BA4S"[j,!!!#!S`!!J+C!TS0!TN!!Q`!!J9p"Ahq4rj'!Ij
 | 
				
			||||||
 | 
					(!!!"rNB!!!)#QJ!#!TX#R!d#Q`!#FJ!!"Ad&L!+G!Ti0!Td!!Q)!!!9p"B3#R`+
 | 
				
			||||||
 | 
					J$3+I!!&[!!!&I3@!rN8,rN8!*$!!%'0bHA"dEfC[E'4PFR"KG'J!%'0bHA"dEdC
 | 
				
			||||||
 | 
					[E'4PFP"KG'J0!U!!!@d!!!@!"B-#S3`#S3!+!!3kF'9Y!!)!!!d#RJ!"E`!!!!!
 | 
				
			||||||
 | 
					!!2j%#rj%!"3`!!KdC@e`F'&dD!!)G'9YF&"KG'J#!T`!!J+L!U-0!U)!!dN!!J@
 | 
				
			||||||
 | 
					*"E2q3rj#!U3+rN-!'#jMEh*PBh*PE#SU+LS!!!!!!!#3!!"ZG@aX!Ij#!!!'!U3
 | 
				
			||||||
 | 
					!!rj"!U8#TJVq33!%#QY[Bf`0!U8!!@d!!!@0"C!!rN!+rN!!"!TKE'PK"J+Q!!2
 | 
				
			||||||
 | 
					q2`+R!UJ+rMm!"!TTER0S$3+R!!)d!!!&N`@ErMi#U3Vq2J!%#Q0QEf`0!UN!!@m
 | 
				
			||||||
 | 
					!!!@A"CVq23[q23!d-!!BEh"PER0cE'PZBfaeC'9QEfaNCA*`BA4S!"K[F'9Z8e0
 | 
				
			||||||
 | 
					-5@jME(9NC8C[E'4PFP"KG'J'!UJ!!rim!UVq1`Vq2!!%#R4[)#!0!US!!Qi!!!@
 | 
				
			||||||
 | 
					H"Dd#U`+X$3+V!!)d!!!&TJ@YrMS#V3Vq1J!%#QCTE'80!Ud!!@d!!!@T"D`#VJ`
 | 
				
			||||||
 | 
					#VJ!,!!9`C@dZD!!#!!!0!U`!!M3!!!@H"DEq13+[#[ij!!3+BfC[E!d#V`!"E`!
 | 
				
			||||||
 | 
					!"D)&TIii#rii!"3`!!KdC@e`F'&dD!!)G'9YF&"KG'J'rMX!!!)#S`!#!V!#X3d
 | 
				
			||||||
 | 
					#X!!$53!#"E3&h[ihrMB#XJVq0`!B,Q0[FQ9MFQ9X+LSU+J!!!!!!!*!!!'jeE'`
 | 
				
			||||||
 | 
					"rMB!!!B#XJ!$rM8#X`+d#[ie!!3+DfpME!d#X`!"E3!!"EJ&Zrid#[id!!3+B@a
 | 
				
			||||||
 | 
					TB3B#Y!!$rM-#Y3+f#[ic!!3+D@jcD!d#Y3!#0!!!"Ei&a[ib!VF+rM)!"!TMCQp
 | 
				
			||||||
 | 
					X$3+h!!&[!!!&`JA&rM%,rM%!0$!!''p`C@jcFfaTEQ0XG@4PCQpXC'9bF'&dD!!
 | 
				
			||||||
 | 
					BEh"PEP066%PZBfaeC'9'EfaNCA*3BA4S"J+f!!2q-!+irLm+rM!!"!TdEb!J$3+
 | 
				
			||||||
 | 
					i!!*Z!!!&b3AB!VN#ZJd#Z3!#0!!!"G%&f2iZ!VX+rLi!"!TQD@aP$3+l!!&Y!!!
 | 
				
			||||||
 | 
					&e!AA!V`-!V`!$!!'F'9Y-LjS!!)!!!d#ZJ!#0!!!"FN&dIiY!Vd+rLd!"!TMCQp
 | 
				
			||||||
 | 
					X$3+p!!&[!!!&c3A3rL`,rL`!&$!!#(4PEA"`BA4S!!KdC@e`8'&dD!Eq,`!!!J+
 | 
				
			||||||
 | 
					a!!)#[J+r$3+q!!*X!!)&h`AIrL[q+J(q+`!!!IiU!!!#!Vm!!J,!!X%0!X!!!R)
 | 
				
			||||||
 | 
					!!!AI"HS#`J,$$3,#!!*L!!!&h`AQ!X3#a3d#a!!"E`!!"Gm&i[iT#riT!#3`!""
 | 
				
			||||||
 | 
					MFRP`G'pQEfaNCA*`BA4S!""MFRP`G'p'EfaNCA*3BA4S$3,&!!&Y!!!&iJAP!XB
 | 
				
			||||||
 | 
					-!XB!$3!(1R"VBh-a-J!#!!!0!X-!!@m!!!!!!!$q+![q+!!8-!!)G'9YF("KG'J
 | 
				
			||||||
 | 
					!#(4PEA"3BA4S!J,"!!)#a`,)$3,(!!0*!!)&k`B9rLIq*J,*#[iR!"JZBfpbC@0
 | 
				
			||||||
 | 
					bC@`U+LSU!!!!!!!!N!!!ER9XE!(q*J!!"J,*!!2q*3,+!XX+rL8!"!TVEf0X$3,
 | 
				
			||||||
 | 
					+!!&Y!!!&l`AbrL3+rL3!"!TKE'PK"J,,!!2q)`,-!Xd+rL-!"!TTER0S$3,-!!)
 | 
				
			||||||
 | 
					d!!!&p3AprL)#cJVq)J!%#Q0QEf`0!Xi!!@m!!!Aj"Icq)3[q)3!d-!!BEh"PER0
 | 
				
			||||||
 | 
					cE'PZBfaeC'9QEfaNCA*`BA4S!"K[F'9Z8e0-5@jME(9NC8C[E'4PFP"KG'J'!Xd
 | 
				
			||||||
 | 
					!!riJ!Xrq(`Vq)!!%#R4[)#!0!Xm!!Qi!!!B!"Jm#d!,4$3,3!!)d!!!'#!B2rKi
 | 
				
			||||||
 | 
					#dJVq(J!%#QCTE'80!Y)!!@d!!!B,"Ji#d``#d`!1!!K`Df0c-6)ZD!!#!!!0!Y%
 | 
				
			||||||
 | 
					!!M3!!!B!"JMq(3,8#[iG!!3+BfC[E!d#e!!"E`!!"J3'"riF#riF!"3`!!KdC@e
 | 
				
			||||||
 | 
					`F'&dD!!)G'9YF&"KG'J'rKm!!!)#b!!#!Y8#eJd#e3!#E!!#"KB'&[iErKS"rKX
 | 
				
			||||||
 | 
					!!!(q'J!!!J,@!!)#e`,B$3,A!!*b!!!'&JBK!YN#fJd#f3!#BJ!!"KB'(3,E!Y`
 | 
				
			||||||
 | 
					0!YX!!@m!!!B@"KRq'3[q'3!N-!!3Bh*jF(4[CQpXC'9bF'&dD!!3Bh*jF(4[4Qp
 | 
				
			||||||
 | 
					XC'9b8'&dD!d#h!!"E3!!"KN'(!,G$!,G!!`!"MT`Df0c0`!#!!!0!YS!!@m!!!!
 | 
				
			||||||
 | 
					!!!$q'![q'!!8-!!)G'9YF("KG'J!#(4PEA"3BA4S!J,B!!)#hJ,I$3,H!!0*!!)
 | 
				
			||||||
 | 
					')JC-rKIq&J,J#[iA!"JZBfpbC@0bC@`U+LSU!!!!!!!!N!!!ER9XE!(q&J!!"J,
 | 
				
			||||||
 | 
					J!!2q&3,K!Z)+rK8!"!TVEf0X$3,K!!&Y!!!'*JBTrK3+rK3!"!TKE'PK"J,L!!2
 | 
				
			||||||
 | 
					q%`,M!Z3+rK-!"!TTER0S$3,M!!)d!!!',!BdrK)#j3Vq%J!%#Q0QEf`0!Z8!!@m
 | 
				
			||||||
 | 
					!!!B`"M2q%3[q%3!d-!!BEh"PER0cE'PZBfaeC'9QEfaNCA*`BA4S!"K[F'9Z8e0
 | 
				
			||||||
 | 
					-5@jME(9NC8C[E'4PFP"KG'J'!Z3!!ri3!ZEq$`Vq%!!%#R4[)#!0!ZB!!Qi!!!B
 | 
				
			||||||
 | 
					h"NB#j`,S$3,R!!)d!!!'2`C'rJi#k3Vq$J!%#QCTE'80!ZN!!@d!!!C#"N8#kJ`
 | 
				
			||||||
 | 
					#kJ!0!!G`Df0c0bjS!!)!!!d#k!!#0!!!"MF'2ri0!ZX+rJd!"!TMCQpX$3,V!!&
 | 
				
			||||||
 | 
					[!!!'1`BqrJ`,rJ`!&$!!#(4PEA"`BA4S!!KdC@e`8'&dD!Eq$`!!!J,I!!)#l!,
 | 
				
			||||||
 | 
					Y$3,X!!*X!!)'63C0rJ[q#J(q#`!!!Ii+!!!#!Zd!!J,Z!Zm0!Zi!!R)!!!C0"PJ
 | 
				
			||||||
 | 
					#m!,a$3,`!!*L!!!'63C8![)#m`d#mJ!"E`!!"Nd'82i*#ri*!#3`!""MFRP`G'p
 | 
				
			||||||
 | 
					QEfaNCA*`BA4S!""MFRP`G'p'EfaNCA*3BA4S$3,c!!&Y!!!'8!C6![3-![3!#`!
 | 
				
			||||||
 | 
					&1R*KEQ3!!J!!$3,a!!&[!!!!!!!!rJJ,rJJ!&$!!#(4PEA"`BA4S!!KdC@e`8'&
 | 
				
			||||||
 | 
					dD!)#l`!#![8#pJd#p3!$53!#"PN'Jri(rJB#p`Vq"`!B,Q0[FQ9MFQ9X+LSU+J!
 | 
				
			||||||
 | 
					!!!!!!*!!!'jeE'`"rJB!!!B#p`!$rJ8#q!,j#[i&!!3+DfpME!d#q!!"E3!!"Pd
 | 
				
			||||||
 | 
					'B2i%#[i%!!3+B@aTB3B#q3!$rJ-#qJ,l#[i$!!3+D@jcD!d#qJ!#0!!!"Q-'Dri
 | 
				
			||||||
 | 
					#![`+rJ)!"!TMCQpX$3,m!!&[!!!'C`CUrJ%,rJ%!0$!!''p`C@jcFfaTEQ0XG@4
 | 
				
			||||||
 | 
					PCQpXC'9bF'&dD!!BEh"PEP066%PZBfaeC'9'EfaNCA*3BA4S"J,l!!2q!!,prIm
 | 
				
			||||||
 | 
					+rJ!!"!TdEb!J$3,p!!*Z!!!'EJCp![i#r`d#rJ!#0!!!"RB'IIhq!`!+rIi!"!T
 | 
				
			||||||
 | 
					QD@aP$3-!!!&Y!!!'H3Cm!`%-!`%!$!!'FQ&ZC#jS!!)!!!d#r`!#0!!!"Qi'G[h
 | 
				
			||||||
 | 
					p!`)+rId!"!TMCQpX$3-#!!&[!!!'FJCerI`,rI`!&$!!#(4PEA"`BA4S!!KdC@e
 | 
				
			||||||
 | 
					`8'&dD!Epr`!!!J,f!!)$!`-%$3-$!!*X!!)'K!D%rI[pqJ(pq`!!!Ihk!!!#!`3
 | 
				
			||||||
 | 
					!!J-&!`B0!`8!!R)!!!D%"Sm$"`-)$3-(!!*L!!!'K!D,!`N$#Jd$#3!"E`!!"S3
 | 
				
			||||||
 | 
					'Krhj#rhj!#3`!""MFRP`G'pQEfaNCA*`BA4S!""MFRP`G'p'EfaNCA*3BA4S$3-
 | 
				
			||||||
 | 
					+!!&Y!!!'K`D+!`X-!`X!#J!%1R*M-J!#!!!0!`J!!@m!!!!!!!$pq![pq!!8-!!
 | 
				
			||||||
 | 
					)G'9YF("KG'J!#(4PEA"3BA4S!J-'!!)$$!-0$3--!!0*!!)'N!!'Z[hhrIB$$JV
 | 
				
			||||||
 | 
					pp`!B,Q0[FQ9MFQ9X+LSU+J!!!!!!!*!!!'jeE'`"rIB!!!B$$J!$rI8$$`-3#[h
 | 
				
			||||||
 | 
					e!!3+DfpME!d$$`!"E3!!"T3'Prhd#[hd!!3+B@aTB3B$%!!$rI-$%3-5#[hc!!3
 | 
				
			||||||
 | 
					+D@jcD!d$%3!#0!!!"TS'S[hb!a-+rI)!"!TMCQpX$3-6!!&[!!!'RJDKrI%,rI%
 | 
				
			||||||
 | 
					!0$!!''p`C@jcFfaTEQ0XG@4PCQpXC'9bF'&dD!!BEh"PEP066%PZBfaeC'9'Efa
 | 
				
			||||||
 | 
					NCA*3BA4S"J-5!!2pm!-8rHm+rI!!"!TdEb!J$3-8!!*Z!!!'T3Dd!a8$&Jd$&3!
 | 
				
			||||||
 | 
					#0!!!"Ud'Y2hZ!aF+rHi!"!TQD@aP$3-A!!&Y!!!'X!Dc!aJ-!aJ!#`!&FQ-b,QJ
 | 
				
			||||||
 | 
					!!J!!$3-@!!)d!!!'T3DYrHd$'3Vpl3!%#Q0QEf`0!aN!!@m!!!DT"Ucpl![pl!!
 | 
				
			||||||
 | 
					8-!!)G'9YF("KG'J!#(4PEA"3BA4S"[h[!!!#!`d!!J-D!aX0!aS!!Q`!!JDl"V[
 | 
				
			||||||
 | 
					pkrhU!IhV!!!"rHS!!!)$'`!#!a`$(3d$(!!#FJ!!"VX'aJ-H!am0!ai!!Q)!!!D
 | 
				
			||||||
 | 
					l"X)$)!-K$3-J!!&[!!!'Z`DqrHN,rHN!*$!!%'0bHA"dEfC[E'4PFR"KG'J!%'0
 | 
				
			||||||
 | 
					bHA"dEdC[E'4PFP"KG'J0!b%!!@d!!!Dq"X%$)J`$)J!+!!3kFQ-d!!)!!!d$(`!
 | 
				
			||||||
 | 
					"E`!!!!!!!2hS#rhS!"3`!!KdC@e`F'&dD!!)G'9YF&"KG'J#!ad!!J-M!b30!b-
 | 
				
			||||||
 | 
					!!dN!!JE("[(pjrhQ!b8+rHF!'#jMEh*PBh*PE#SU+LS!!!!!!!#3!!"ZG@aX!Ih
 | 
				
			||||||
 | 
					Q!!!'!b8!!rhP!bB$*`Vpj3!%#QY[Bf`0!bB!!@d!!!E,"Xlpj!Vpj!!%#Q&XD@%
 | 
				
			||||||
 | 
					'!bF!!rhM!bJ$+3Vpi`!%#QPZFfJ0!bJ!!M3!!!E4"YRpiJ-U#[hL!!3+BfC[E!d
 | 
				
			||||||
 | 
					$+J!"E`!!"Y8'f2hK#rhK!$3`!"K[F'9ZFh0XD@jME(9NC@C[E'4PFR"KG'J!''p
 | 
				
			||||||
 | 
					`C@j68da*EQ0XG@4P4QpXC'9b8'&dD!B$+3!$rH!$+rhI#[hJ!!3+G'mJ)!d$+`!
 | 
				
			||||||
 | 
					#EJ!!"Y`'k`-X!bd0!b`!!M3!!!EN"Z[phJ-Z#[hH!!3+CQPXC3d$,J!"E3!!"ZF
 | 
				
			||||||
 | 
					'kJ-[$!-[!!X!"A*M0#jS!!)!!!d$,3!#0!!!"Y`'j2hG!c!+rGd!"!TMCQpX$3-
 | 
				
			||||||
 | 
					`!!&[!!!'i!EMrG`,rG`!&$!!#(4PEA"`BA4S!!KdC@e`8'&dD!Eph`!!!J-N!!)
 | 
				
			||||||
 | 
					$-3-b$3-a!!*X!!)'mJEbrG[pfJ(pf`!!!IhD!!!#!c)!!J-c!c30!c-!!R)!!!E
 | 
				
			||||||
 | 
					b"[d$03-f$3-e!!*L!!!'mJEj!cF$1!d$0`!"E`!!"[)'pIhC#rhC!#3`!""MFRP
 | 
				
			||||||
 | 
					`G'pQEfaNCA*`BA4S!""MFRP`G'p'EfaNCA*3BA4S$3-i!!&Y!!!'p3Ei!cN-!cN
 | 
				
			||||||
 | 
					!#J!%1R*M03!#!!!0!cB!!@m!!!!!!!$pf![pf!!8-!!)G'9YF("KG'J!#(4PEA"
 | 
				
			||||||
 | 
					3BA4S!J-d!!)$1J-l$3-k!!0*!!)'rJFSrGIpeJ-m#[hA!"JZBfpbC@0bC@`U+LS
 | 
				
			||||||
 | 
					U!!!!!!!!N!!!ER9XE!(peJ!!"J-m!!2pe3-p!ci+rG8!"!TVEf0X$3-p!!&Y!!!
 | 
				
			||||||
 | 
					(!JF&rG3+rG3!"!TKE'PK"J-q!!2pd`-r!d!+rG-!"!TTER0S$3-r!!)d!!!(#!F
 | 
				
			||||||
 | 
					3rG)$33VpdJ!%#Q0QEf`0!d%!!@m!!!F-"`rpd3[pd3!d-!!BEh"PER0cE'PZBfa
 | 
				
			||||||
 | 
					eC'9QEfaNCA*`BA4S!"K[F'9Z8e0-5@jME(9NC8C[E'4PFP"KG'J'!d!!!rh3!d,
 | 
				
			||||||
 | 
					pc`Vpd!!%#R4[)#!0!d)!!Qi!!!F6"b)$3`0%$30$!!)d!!!('`FLrFi$43VpcJ!
 | 
				
			||||||
 | 
					%#QCTE'80!d8!!@d!!!FH"b%$4J`$4J!,!!9bBc8ZD!!#!!!0!d3!!M3!!!F6"a[
 | 
				
			||||||
 | 
					pc30(#[h0!!3+BfC[E!d$4`!"E`!!"aF('[h-#rh-!"3`!!KdC@e`F'&dD!!)G'9
 | 
				
			||||||
 | 
					YF&"KG'J'rFm!!!)$1`!#!dJ$53d$5!!#E!!#"bN(+Ih,rFS"rFX!!!(pbJ!!!J0
 | 
				
			||||||
 | 
					*!!)$5J0,$30+!!*b!!!(+3Fd!d`$63d$6!!#BJ!!"bN(-!01!dm0!di!!@m!!!F
 | 
				
			||||||
 | 
					T"bcpb3[pb3!N-!!3Bh*jF(4[CQpXC'9bF'&dD!!3Bh*jF(4[4QpXC'9b8'&dD!d
 | 
				
			||||||
 | 
					$6`!"E3!!"b`(,`03$!03!!d!"cTbDA"PE@3!!J!!$300!!&[!!!!!!!!rFJ,rFJ
 | 
				
			||||||
 | 
					!&$!!#(4PEA"`BA4S!!KdC@e`8'&dD!)$5`!#!e%$8Jd$83!$53!#"c8(Arh(rFB
 | 
				
			||||||
 | 
					$8`Vpa`!B,Q0[FQ9MFQ9X+LSU+J!!!!!!!*!!!'jeE'`"rFB!!!B$8`!$rF8$9!0
 | 
				
			||||||
 | 
					9#[h&!!3+DfpME!d$9!!"E3!!"cN(22h%#[h%!!3+B@aTB3B$93!$rF-$9J0A#[h
 | 
				
			||||||
 | 
					$!!3+D@jcD!d$9J!#0!!!"cm(4rh#!eJ+rF)!"!TMCQpX$30B!!&[!!!(3`G'rF%
 | 
				
			||||||
 | 
					,rF%!0$!!''p`C@jcFfaTEQ0XG@4PCQpXC'9bF'&dD!!BEh"PEP066%PZBfaeC'9
 | 
				
			||||||
 | 
					'EfaNCA*3BA4S"J0A!!2p`!0CrEm+rF!!"!TdEb!J$30C!!*Z!!!(5JGC!eS$@`d
 | 
				
			||||||
 | 
					$@J!#0!!!"e)(@Ifq!e`+rEi!"!TQD@aP$30F!!&Y!!!(93GB!ed-!ed!$J!)FQP
 | 
				
			||||||
 | 
					`C@eN,QJ!!J!!$30E!!)d!!!(5JG5rEd$AJVp[3!%#Q0QEf`0!ei!!@m!!!G1"e(
 | 
				
			||||||
 | 
					p[![p[!!8-!!)G'9YF("KG'J!#(4PEA"3BA4S"[fr!!!#!e)!!J0I!f!0!em!!Q`
 | 
				
			||||||
 | 
					!!JGJ"f$pZrfk!Ifl!!!"rES!!!)$B!!#!f%$BJd$B3!#FJ!!"f!(D`0M!f30!f-
 | 
				
			||||||
 | 
					!!Q)!!!GJ"fF$C30Q$30P!!&[!!!(B!GMrEN,rEN!*$!!%'0bHA"dEfC[E'4PFR"
 | 
				
			||||||
 | 
					KG'J!%'0bHA"dEdC[E'4PFP"KG'J0!fB!!@d!!!GM"fB$C``$C`!+!!3kFR0K!!)
 | 
				
			||||||
 | 
					!!!d$C!!"E`!!!!!!!2fi#rfi!"3`!!KdC@e`F'&dD!!)G'9YF&"KG'J#!f)!!J0
 | 
				
			||||||
 | 
					S!fN0!fJ!!dN!!JGX"jEpYrff!fS+rEF!'#jMEh*PBh*PE#SU+LS!!!!!!!#3!!"
 | 
				
			||||||
 | 
					ZG@aX!Iff!!!'!fS!!rfe!fX$E!VpY3!%#QY[Bf`0!fX!!@d!!!G`"h2pY!VpY!!
 | 
				
			||||||
 | 
					%#Q&XD@%'!f`!!rfc!fd$EJVpX`!%#QPZFfJ0!fd!!M3!!!Gf"hlpXJ0[#[fb!!3
 | 
				
			||||||
 | 
					+BfC[E!d$E`!"E`!!"hS(IIfa#rfa!$3`!"K[F'9ZFh0XD@jME(9NC@C[E'4PFR"
 | 
				
			||||||
 | 
					KG'J!''p`C@j68da*EQ0XG@4P4QpXC'9b8'&dD!B$EJ!$rE!$F2f[#[f`!!3+G'm
 | 
				
			||||||
 | 
					J)!d$F!!#EJ!!"i%(N!!$F30b$30a!!)d!!!(L3H3!2fZ!h-+rDi!"!TQD@aP$30
 | 
				
			||||||
 | 
					c!!&Y!!!(M!H2!h3-!h3!#`!&FR0K,QJ!!J!!$30b!!)d!!!(J3H*rDd$G3VpV3!
 | 
				
			||||||
 | 
					%#Q0QEf`0!h8!!@m!!!H&"iMpV![pV!!8-!!)G'9YF("KG'J!#(4PEA"3BA4S"[f
 | 
				
			||||||
 | 
					[!!!#!fN!!J0f!hF0!hB!!Q`!!JHA"jIpUrfU!IfV!!!"rDS!!!)$G`!#!hJ$H3d
 | 
				
			||||||
 | 
					$H!!#FJ!!"jF(SJ0k!hX0!hS!!Q)!!!HA"ji$I!0p$30m!!&[!!!(P`HDrDN,rDN
 | 
				
			||||||
 | 
					!*$!!%'0bHA"dEfC[E'4PFR"KG'J!%'0bHA"dEdC[E'4PFP"KG'J0!hd!!@d!!!H
 | 
				
			||||||
 | 
					D"jd$IJ`$IJ!-!!BkFh4KBfX!!J!!$30l!!&[!!!!!!!!rDJ,rDJ!&$!!#(4PEA"
 | 
				
			||||||
 | 
					`BA4S!!KdC@e`8'&dD!)$H3!#!hm$J!d$I`!$53!#"k-(cIfRrDB$J3VpT`!B,Q0
 | 
				
			||||||
 | 
					[FQ9MFQ9X+LSU+J!!!!!!!*!!!'jeE'`"rDB!!!B$J3!$rD8$JJ1$#[fP!!3+Dfp
 | 
				
			||||||
 | 
					ME!d$JJ!"E3!!"kF(U[fN#[fN!!3+B@aTB3B$J`!$rD-$K!1&#[fM!!3+D@jcD!d
 | 
				
			||||||
 | 
					$K!!#0!!!"kd(YIfL!iB+rD)!"!TMCQpX$31'!!&[!!!(X3HdrD%,rD%!0$!!''p
 | 
				
			||||||
 | 
					`C@jcFfaTEQ0XG@4PCQpXC'9bF'&dD!!BEh"PEP066%PZBfaeC'9'EfaNCA*3BA4
 | 
				
			||||||
 | 
					S"J1&!!2pS!1(rCm+rD!!"!TdEb!J$31(!!*Z!!!(Z!I(!iJ$L3d$L!!#0!!!"m!
 | 
				
			||||||
 | 
					(arfH!iS+rCi!"!TQD@aP$31+!!&Y!!!(``I'!iX-!iX!$3!(Fh4KBfXZD!!#!!!
 | 
				
			||||||
 | 
					0!iN!!M3!!!Hi"m$pR31-#[fG!!3+BfC[E!d$M!!"E`!!"l`([rfF#rfF!"3`!!K
 | 
				
			||||||
 | 
					dC@e`F'&dD!!)G'9YF&"KG'J'rCm!!!)$J!!#!id$MJd$M3!$53!#"mi(q2fErCS
 | 
				
			||||||
 | 
					$M`VpQ`!B,Q0[FQ9MFQ9X+LSU+J!!!!!!!*!!!'jeE'`"rCS!!!B$M`!$rCN$N!!
 | 
				
			||||||
 | 
					$N3VpQ3!%#QY[Bf`0!j!!!!&Y!!!(dJI9rCJ+rCJ!"!TKE'PK"J14!!2pP`15!j-
 | 
				
			||||||
 | 
					+rCF!"!TTER0S$315!!)d!!!(f!IJrCB$P!VpPJ!%#Q0QEf`0!j3!!@m!!!IF"pr
 | 
				
			||||||
 | 
					pP3[pP3!d-!!BEh"PER0cE'PZBfaeC'9QEfaNCA*`BA4S!"K[F'9Z8e0-5@jME(9
 | 
				
			||||||
 | 
					NC8C[E'4PFP"KG'J'!j-!!rf8!jApN`VpP!!%#R4[)#!0!j8!!Qi!!!IM"r)$PJ1
 | 
				
			||||||
 | 
					A$31@!!)d!!!(k`IbrC)$Q!VpNJ!%#QCTE'80!jJ!!@d!!!IZ"r%$Q3`$Q3!4!!Y
 | 
				
			||||||
 | 
					cB@CPFh4KBfXZD!!#!!!0!jF!!M3!!!IM"q[pN31D#[f4!!3+BfC[E!d$QJ!"E`!
 | 
				
			||||||
 | 
					!"qF(k[f3!![pN!!!&$!!#(4PEA"`BA4S!!KdC@e`8'&dD!EpN`!!!J11!!)$Q`1
 | 
				
			||||||
 | 
					F$31E!!*X!!)(q3IjrBrpMJ(pM`!!!If1!!!#!j`!!J1G!ji0!jd!!R)!!!Ij#!3
 | 
				
			||||||
 | 
					$R`1J$31I!!*L!!!(q3J!!k%$SJd$S3!"E`!!"rN(r2f0#rf0!#3`!""MFRP`G'p
 | 
				
			||||||
 | 
					QEfaNCA*`BA4S!""MFRP`G'p'EfaNCA*3BA4S$31L!!&Y!!!(r!Ir!k--!k-!#J!
 | 
				
			||||||
 | 
					%1R0SB3!#!!!0!k!!!@m!!!!!!!$pM![pM!!8-!!)G'9YF("KG'J!#(4PEA"3BA4
 | 
				
			||||||
 | 
					S!J1H!!)$T!1P$31N!!0*!!))"3J[rB[pLJ1Q#[f,!"JZBfpbC@0bC@`U+LSU!!!
 | 
				
			||||||
 | 
					!!!!!N!!!ER9XE!(pLJ!!"J1Q!!2pL31R!kJ+rBN!"!TVEf0X$31R!!&Y!!!)#3J
 | 
				
			||||||
 | 
					-rBJ+rBJ!"!TKE'PK"J1S!!2pK`1T!kS+rBF!"!TTER0S$31T!!)d!!!)$`JArBB
 | 
				
			||||||
 | 
					$U`VpKJ!%#Q0QEf`0!kX!!@m!!!J6#"EpK3[pK3!d-!!BEh"PER0cE'PZBfaeC'9
 | 
				
			||||||
 | 
					QEfaNCA*`BA4S!"K[F'9Z8e0-5@jME(9NC8C[E'4PFP"KG'J'!kS!!rf%!kcpJ`V
 | 
				
			||||||
 | 
					pK!!%#R4[)#!0!k`!!Qi!!!JD##N$V31Z$31Y!!)d!!!))JJTrB)$V`VpJJ!%#QC
 | 
				
			||||||
 | 
					TE'80!km!!@d!!!JP##J$X!`$X!!,!!9cD'%ZD!!#!!!0!ki!!M3!!!JD##,pJ31
 | 
				
			||||||
 | 
					a#[f"!!3+BfC[E!d$X3!"E`!!#"i))If!#rf!!"3`!!KdC@e`F'&dD!!)G'9YF&"
 | 
				
			||||||
 | 
					KG'J'rB-!!!)$T3!#!l)$X`d$XJ!#E!!##$!)-2errAi"rAm!!!(pIJ!!!J1c!!)
 | 
				
			||||||
 | 
					$Y!1e$31d!!*b!!!)-!Jl!lB$Y`d$YJ!#BJ!!#$!)0`1i!lN0!lJ!!@m!!!J`#$2
 | 
				
			||||||
 | 
					pI3[pI3!N-!!3Bh*jF(4[CQpXC'9bF'&dD!!3Bh*jF(4[4QpXC'9b8'&dD!d$Z3!
 | 
				
			||||||
 | 
					"E3!!#$-)0J1k$!1k!!d!"cTdH(4IC')!!J!!$31h!!&[!!!!!!!!rA`,rA`!&$!
 | 
				
			||||||
 | 
					!#(4PEA"`BA4S!!KdC@e`8'&dD!)$Y3!#!lX$[!d$Z`!$53!##$`)C[elrAS$[3V
 | 
				
			||||||
 | 
					pH`!B,Q0[FQ9MFQ9X+LSU+J!!!!!!!*!!!'jeE'`"rAS!!!B$[3!$rAN$[J1r#[e
 | 
				
			||||||
 | 
					j!!3+DfpME!d$[J!"E3!!#%!)3rei#[ei!!3+B@aTB3B$[`!$rAF$`!2"#[eh!!3
 | 
				
			||||||
 | 
					+D@jcD!d$`!!#0!!!#%B)6[ef!m)+rAB!"!TMCQpX$32#!!&[!!!)5JK0rA8,rA8
 | 
				
			||||||
 | 
					!0$!!''p`C@jcFfaTEQ0XG@4PCQpXC'9bF'&dD!!BEh"PEP066%PZBfaeC'9'Efa
 | 
				
			||||||
 | 
					NCA*3BA4S"J2"!!2pG!2$rA-+rA3!"!TdEb!J$32$!!*Z!!!)83KJ!m3$a3d$a!!
 | 
				
			||||||
 | 
					#0!!!#&N)B2eb!mB+rA)!"!TQD@aP$32'!!&Y!!!)A!KI!mF-!mF!$J!)G(KdAf4
 | 
				
			||||||
 | 
					L,QJ!!J!!$32&!!)d!!!)83KCrA%$b!VpF3!%#Q0QEf`0!mJ!!@m!!!K9#&MpF![
 | 
				
			||||||
 | 
					pF!!8-!!)G'9YF("KG'J!#(4PEA"3BA4S"[ec!!!#!l`!!J2*!mS0!mN!!Q`!!JK
 | 
				
			||||||
 | 
					R#'IpEreZ!Ie[!!!"r@i!!!)$bJ!#!mX$c!d$b`!#FJ!!#'F)FJ20!mi0!md!!Q)
 | 
				
			||||||
 | 
					!!!KR#'i$c`23$322!!&[!!!)C`KUr@d,r@d!*$!!%'0bHA"dEfC[E'4PFR"KG'J
 | 
				
			||||||
 | 
					!%'0bHA"dEdC[E'4PFP"KG'J0!p!!!@d!!!KU#'d$d3`$d3!,!!8kH$8`13!#!!!
 | 
				
			||||||
 | 
					0!mi!!@m!!!!!!!$pE![pE!!8-!!)G'9YF("KG'J!#(4PEA"3BA4S!J2-!!)$dJ2
 | 
				
			||||||
 | 
					6$325!!0*!!))F`LGr@[pDJ28#[eV!"JZBfpbC@0bC@`U+LSU!!!!!!!!N!!!ER9
 | 
				
			||||||
 | 
					XE!(pDJ!!"J28!!2pD329!pB+r@N!"!TVEf0X$329!!&Y!!!)G`Kkr@J+r@J!"!T
 | 
				
			||||||
 | 
					KE'PK"J2@!!2pC`2A!pJ+r@F!"!TTER0S$32A!!)d!!!)I3L&r@B$f3VpCJ!%#Q0
 | 
				
			||||||
 | 
					QEf`0!pN!!@m!!!L"#)6pC3[pC3!d-!!BEh"PER0cE'PZBfaeC'9QEfaNCA*`BA4
 | 
				
			||||||
 | 
					S!"K[F'9Z8e0-5@jME(9NC8C[E'4PFP"KG'J'!pJ!!reN!pVpB`VpC!!%#R4[)#!
 | 
				
			||||||
 | 
					0!pS!!Qi!!!L)#*F$f`2F$32E!!)d!!!)N!!)PreL!pd+r@)!"!TQD@aP$32G!!&
 | 
				
			||||||
 | 
					Y!!!)N`L@!pi-!pi!$!!'H$8`15jS!!)!!!d$h!!#0!!!#)J)N!$pB32I#[eK!!3
 | 
				
			||||||
 | 
					+BfC[E!d$h`!"E`!!#)`)MreJ#reJ!"3`!!KdC@e`F'&dD!!)G'9YF&"KG'J'r@-
 | 
				
			||||||
 | 
					!!!)$d`!#!q!$i3d$i!!$53!##*i)b2eIr9i$iJVpA`!B,Q0[FQ9MFQ9X+LSU+J!
 | 
				
			||||||
 | 
					!!!!!!*!!!'jeE'`"r9i!!!B$iJ!$r9d$i`2N#[eG!!3+DfpME!d$i`!"E3!!#+)
 | 
				
			||||||
 | 
					)TIeF#[eF!!3+B@aTB3B$j!!$r9X$j32Q#[eE!!3+D@jcD!d$j3!#0!!!#+J)X2e
 | 
				
			||||||
 | 
					D!qF+r9S!"!TMCQpX$32R!!&[!!!)V!L[r9N,r9N!0$!!''p`C@jcFfaTEQ0XG@4
 | 
				
			||||||
 | 
					PCQpXC'9bF'&dD!!BEh"PEP066%PZBfaeC'9'EfaNCA*3BA4S"J2Q!!2p@!2Sr9F
 | 
				
			||||||
 | 
					+r9J!"!TdEb!J$32S!!*Z!!!)X`M#!qN$kJd$k3!#0!!!#,X)`[e@!qX+r9B!"!T
 | 
				
			||||||
 | 
					QD@aP$32V!!&Y!!!)[JM"!q`-!q`!%!!+H$8`19pfCRNZD!!#!!!0!qS!!M3!!!L
 | 
				
			||||||
 | 
					c#,[p932Y#[e9!!3+BfC[E!d$l3!"E`!!#,F)Z[e8#re8!"3`!!KdC@e`F'&dD!!
 | 
				
			||||||
 | 
					)G'9YF&"KG'J'r9F!!!)$i3!#!qi$l`d$lJ!#E!!##-N)bIe6r9)"r9-!!!(p8J!
 | 
				
			||||||
 | 
					!!J2[!!)$m!2a$32`!!*b!!!)b3M8!r)$m`d$mJ!#BJ!!#-N)d!2d!r80!r3!!@m
 | 
				
			||||||
 | 
					!!!M*#-cp83[p83!N-!!3Bh*jF(4[CQpXC'9bF'&dD!!3Bh*jF(4[4QpXC'9b8'&
 | 
				
			||||||
 | 
					dD!d$p3!"E3!!#-`)c`2f$!2f!!d!"cTi06!jGM-!!J!!$32c!!&[!!!!!!!!r9!
 | 
				
			||||||
 | 
					,r9!!&$!!#(4PEA"`BA4S!!KdC@e`8'&dD!)$m3!#!rF$q!d$p`!$53!##08)rre
 | 
				
			||||||
 | 
					2r8i$q3Vp6`!B,Q0[FQ9MFQ9X+LSU+J!!!!!!!*!!!'jeE'`"r8i!!!B$q3!$r8d
 | 
				
			||||||
 | 
					$qJ2l#[e0!!3+DfpME!d$qJ!"E3!!#0N)h2e-#[e-!!3+B@aTB3B$q`!$r8X$r!2
 | 
				
			||||||
 | 
					p#[e,!!3+D@jcD!d$r!!#0!!!#0m)jre+!ri+r8S!"!TMCQpX$32q!!&[!!!)i`M
 | 
				
			||||||
 | 
					Qr8N,r8N!0$!!''p`C@jcFfaTEQ0XG@4PCQpXC'9bF'&dD!!BEh"PEP066%PZBfa
 | 
				
			||||||
 | 
					eC'9'EfaNCA*3BA4S"J2p!!2p5!2rr8F+r8J!"!TdEb!J$32r!!*Z!!!)kJMj"!!
 | 
				
			||||||
 | 
					%!3d%!!!#0!!!#2))qIe'"!)+r8B!"!TQD@aP$33#!!&Y!!!)p3Mi"!--"!-!$J!
 | 
				
			||||||
 | 
					)H$8`1ABc,QJ!!J!!$33"!!)d!!!)kJMbr88%"!Vp43!%#Q0QEf`0"!3!!@m!!!M
 | 
				
			||||||
 | 
					Z#2(p4![p4!!8-!!)G'9YF("KG'J!#(4PEA"3BA4S"[e(!!!#!rJ!!J3&"!B0"!8
 | 
				
			||||||
 | 
					!!Q`!!JN!#3$p3re#!Ie$!!!"r8)!!!)%"J!#"!F%#!d%"`!$53!##3!*+[e"r8!
 | 
				
			||||||
 | 
					%#3Vp33!B,Q0[FQ9MFQ9X+LSU+J!!!!!!!*!!!'jeE'`"r8!!!!B%#3!$r6m%#J3
 | 
				
			||||||
 | 
					,#[dr!!3+DfpME!d%#J!"E3!!#33*"rdq#[dq!!3+B@aTB3B%#`!$r6d%$!30#[d
 | 
				
			||||||
 | 
					p!!3+D@jcD!d%$!!#0!!!#3S*%[dm"!i+r6`!"!TMCQpX$331!!&[!!!*$JN4r6X
 | 
				
			||||||
 | 
					,r6X!0$!!''p`C@jcFfaTEQ0XG@4PCQpXC'9bF'&dD!!BEh"PEP066%PZBfaeC'9
 | 
				
			||||||
 | 
					'EfaNCA*3BA4S"J30!!2p1J32r6N+r6S!"!TdEb!J$332!!*Z!!!*&3NN""!%%3d
 | 
				
			||||||
 | 
					%%!!#0!!!#4d**2di"")+r6J!"!TQD@aP$335!!&Y!!!*)!NM""--""-!#`!&Fh0
 | 
				
			||||||
 | 
					X,QJ!!J!!$334!!)d!!!*&3NGr6F%&!Vp0`!%#Q0QEf`0""3!!@m!!!NC#4cp0J[
 | 
				
			||||||
 | 
					p0J!H-!!0Fh0XCQpXC'9bF'&dD!!0Fh0X4QpXC'9b8'&dD!Ep13!!!J3)!!)%&33
 | 
				
			||||||
 | 
					@$339!!0*!!)*+`P9r6Ap0!3A#[de!"JZBfpbC@0bC@`U+LSU!!!!!!!!N!!!ER9
 | 
				
			||||||
 | 
					XE!(p0!!!"J3A!!2p-`3B""N+r6-!"!TVEf0X$33B!!&Y!!!*,`Nbr6)+r6)!"!T
 | 
				
			||||||
 | 
					KE'PK"J3C!!2p-33D""X+r6%!"!TTER0S$33D!!)d!!!*03Npr6!%(!Vp-!!%#Q0
 | 
				
			||||||
 | 
					QEf`0""`!!@m!!!Nj#6cp,`[p,`!d-!!BEh"PER0cE'PZBfaeC'9QEfaNCA*`BA4
 | 
				
			||||||
 | 
					S!"K[F'9Z8e0-5@jME(9NC8C[E'4PFP"KG'J'""X!!rdZ""hp,3Vp,J!%#R4[)#!
 | 
				
			||||||
 | 
					0""d!!Qi!!!P!#8m%(J3I$33H!!)d!!!*5!P2r5`%)!Vp,!!%#QCTE'80"#!!!@d
 | 
				
			||||||
 | 
					!!!P,#8i%)3`%)3!-!!CcFf`b,QJ!!J!!$33I!!)d!!!*3!P)r5X%)JVp+`!%#Q0
 | 
				
			||||||
 | 
					QEf`0"#)!!@m!!!P%#8Ip+J[p+J!H-!!0Fh0XCQpXC'9bF'&dD!!0Fh0X4QpXC'9
 | 
				
			||||||
 | 
					b8'&dD!Ep,3!!!J3@!!)%)`3N$33M!!0*!!)*9JQ!r5Rp+!3P#[dT!"JZBfpbC@0
 | 
				
			||||||
 | 
					bC@`U+LSU!!!!!!!!N!!!ER9XE!(p+!!!"J3P!!2p*`3Q"#F+r5F!"!TVEf0X$33
 | 
				
			||||||
 | 
					Q!!&Y!!!*@JPGr5B+r5B!"!TKE'PK"J3R!!2p*33S"#N+r58!"!TTER0S$33S!!)
 | 
				
			||||||
 | 
					d!!!*B!PSr53%+JVp*!!%#Q0QEf`0"#S!!@m!!!PN#@Ip)`[p)`!d-!!BEh"PER0
 | 
				
			||||||
 | 
					cE'PZBfaeC'9QEfaNCA*`BA4S!"K[F'9Z8e0-5@jME(9NC8C[E'4PFP"KG'J'"#N
 | 
				
			||||||
 | 
					!!rdL"#[p)3Vp)J!%#R4[)#!0"#X!!Qi!!!PV#AS%,!3Y$33X!!)d!!!*F`Pkr5!
 | 
				
			||||||
 | 
					%,JVp)!!%#QCTE'80"#i!!@d!!!Pf#AN%,``%,`!0!!GcFf`b-bjS!!)!!!d%,3!
 | 
				
			||||||
 | 
					#0!!!#@X*FrdI"$!+r4m!"!TMCQpX$33`!!&[!!!*E`Pbr4i,r4i!(M!!$A0cE'C
 | 
				
			||||||
 | 
					[E'4PFR"KG'J!$A0cE%C[E'4PFP"KG'J'r5%!!!)%*!!#"$%%-Jd%-3!$53!##B%
 | 
				
			||||||
 | 
					*UrdGr4`%-`Vp(3!B,Q0[FQ9MFQ9X+LSU+J!!!!!!!*!!!'jeE'`"r4`!!!B%-`!
 | 
				
			||||||
 | 
					$r4X%0!3e#[dE!!3+DfpME!d%0!!"E3!!#B8*L2dD#[dD!!3+B@aTB3B%03!$r4N
 | 
				
			||||||
 | 
					%0J3h#[dC!!3+D@jcD!d%0J!#0!!!#BX*NrdB"$J+r4J!"!TMCQpX$33i!!&[!!!
 | 
				
			||||||
 | 
					*M`Q5r4F,r4F!0$!!''p`C@jcFfaTEQ0XG@4PCQpXC'9bF'&dD!!BEh"PEP066%P
 | 
				
			||||||
 | 
					ZBfaeC'9'EfaNCA*3BA4S"J3h!!2p&J3jr48+r4B!"!TdEb!J$33j!!*Z!!!*PJQ
 | 
				
			||||||
 | 
					P"$S%1`d%1J!#0!!!#Ci*TId8"$`+r43!"!TQD@aP$33m!!&Y!!!*S3QN"$d-"$d
 | 
				
			||||||
 | 
					!$!!'Fh0X-bjS!!)!!!d%1`!#0!!!#CB*R[d6"$i+r4-!"!TMCQpX$33q!!&[!!!
 | 
				
			||||||
 | 
					*QJQGr4),r4)!(M!!$A0cE'C[E'4PFR"KG'J!$A0cE%C[E'4PFP"KG'J'r48!!!)
 | 
				
			||||||
 | 
					%-J!#"$m%3!d%2`!$53!##D`*e[d4r4!%33Vp%3!B,Q0[FQ9MFQ9X+LSU+J!!!!!
 | 
				
			||||||
 | 
					!!*!!!'jeE'`"r4!!!!B%33!$r3m%3J4$#[d2!!3+DfpME!d%3J!"E3!!#E!*Xrd
 | 
				
			||||||
 | 
					1#[d1!!3+B@aTB3B%3`!$r3d%4!4&#[d0!!3+D@jcD!d%4!!#0!!!#EB*[[d-"%B
 | 
				
			||||||
 | 
					+r3`!"!TMCQpX$34'!!&[!!!*ZJQpr3X,r3X!0$!!''p`C@jcFfaTEQ0XG@4PCQp
 | 
				
			||||||
 | 
					XC'9bF'&dD!!BEh"PEP066%PZBfaeC'9'EfaNCA*3BA4S"J4&!!2p#J4(r3N+r3S
 | 
				
			||||||
 | 
					!"!TdEb!J$34(!!*Z!!!*`3R3"%J%53d%5!!#0!!!#FN*d2d)"%S+r3J!"!TQD@a
 | 
				
			||||||
 | 
					P$34+!!&Y!!!*c!R2"%X-"%X!$!!'G'ac-5jS!!)!!!d%53!#0!!!#F%*bId("%`
 | 
				
			||||||
 | 
					+r3F!"!TMCQpX$34-!!&[!!!*a3R)r3B,r3B!(M!!$A0cE'C[E'4PFR"KG'J!$A0
 | 
				
			||||||
 | 
					cE%C[E'4PFP"KG'J'r3N!!!)%3!!#"%d%6Jd%63!#E!!##GF*erd&r33"r38!!!(
 | 
				
			||||||
 | 
					p"!!!!J41!!)%6`43$342!!0*!!)*e`S"r32p!J44#[d$!"JZBfpbC@0bC@`U+LS
 | 
				
			||||||
 | 
					U!!!!!!!!N!!!ER9XE!(p!J!!"J44!!2p!345"&-+r3%!"!TVEf0X$345!!&Y!!!
 | 
				
			||||||
 | 
					*f`RHr3!+r3!!"!TKE'PK"J46!!2mr`48"&8+r2m!"!TTER0S$348!!)d!!!*i3R
 | 
				
			||||||
 | 
					Tr2i%9JVmrJ!%#Q0QEf`0"&B!!@m!!!RP#HMmr3[mr3!d-!!BEh"PER0cE'PZBfa
 | 
				
			||||||
 | 
					eC'9QEfaNCA*`BA4S!"K[F'9Z8e0-5@jME(9NC8C[E'4PFP"KG'J'"&8!!rcm"&I
 | 
				
			||||||
 | 
					mq`Vmr!!%#R4[)#!0"&F!!Qi!!!RX#IX%@!4C$34B!!)d!!!*p!Rlr2S%@JVmqJ!
 | 
				
			||||||
 | 
					%#QCTE'80"&S!!@d!!!Rh#IS%@``%@`!1!!KMFRP`G'mZD!!#!!!0"&N!!M3!!!R
 | 
				
			||||||
 | 
					X#I6mq34F#[cj!!3+BfC[E!d%A!!"E`!!#I!*mrci#rci!#3`!""MFRP`G'pQEfa
 | 
				
			||||||
 | 
					NCA*`BA4S!""MFRP`G'p'EfaNCA*3BA4S"[cl!!!#"&!!!J4G"&i0"&d!!Q`!!JS
 | 
				
			||||||
 | 
					##J,mprcf!Ich!!!"r2B!!!)%AJ!#"&m%B!d%A`!$53!##J)+,2cer23%B3Vmp3!
 | 
				
			||||||
 | 
					B,Q0[FQ9MFQ9X+LSU+J!!!!!!!*!!!'jeE'`"r23!!!B%B3!$r2-%BJ4M#[cc!!3
 | 
				
			||||||
 | 
					+DfpME!d%BJ!"E3!!#JB+#Icb#[cb!!3+B@aTB3B%B`!$r2%%C!4P#[ca!!3+D@j
 | 
				
			||||||
 | 
					cD!d%C!!#0!!!#J`+&2c`"'B+r2!!"!TMCQpX$34Q!!&[!!!+%!S6r1m,r1m!0$!
 | 
				
			||||||
 | 
					!''p`C@jcFfaTEQ0XG@4PCQpXC'9bF'&dD!!BEh"PEP066%PZBfaeC'9'EfaNCA*
 | 
				
			||||||
 | 
					3BA4S"J4P!!2mlJ4Rr1d+r1i!"!TdEb!J$34R!!*Z!!!+&`SQ"'J%D3d%D!!#0!!
 | 
				
			||||||
 | 
					!#Km+*[cX"'S+r1`!"!TQD@aP$34U!!&Y!!!+)JSP"'X-"'X!%!!+Eh"PER0cE(B
 | 
				
			||||||
 | 
					ZD!!#!!!0"'N!!M3!!!SA#Krmk`4X#[cV!!3+BfC[E!d%E!!"E`!!#KX+([cU#rc
 | 
				
			||||||
 | 
					U!#3`!""MFRP`G'pQEfaNCA*`BA4S!""MFRP`G'p'EfaNCA*3BA4S"[cY!!!#"'!
 | 
				
			||||||
 | 
					!!J4Y"'i0"'d!!dN!!JSY#PImkIcS"'m+r1N!'#jMEh*PBh*PE#SU+LS!!!!!!!#
 | 
				
			||||||
 | 
					3!!"ZG@aX!IcS!!!'"'m!!rcR"(!%F3Vmj`!%#QY[Bf`0"(!!!@d!!!Sa#M6mjJV
 | 
				
			||||||
 | 
					mjJ!%#Q&XD@%'"(%!!rcP"()%F`Vmj3!%#QPZFfJ0"()!!M3!!!Sh#Mrmj!4d#[c
 | 
				
			||||||
 | 
					N!!3+BfC[E!d%G!!"E`!!#MX+2[cM#rcM!$3`!"K[F'9ZFh0XD@jME(9NC@C[E'4
 | 
				
			||||||
 | 
					PFR"KG'J!''p`C@j68da*EQ0XG@4P4QpXC'9b8'&dD!B%F`!$r1)%GIcK#[cL!!3
 | 
				
			||||||
 | 
					+G'mJ)!d%G3!#EJ!!#N)+834f"(F0"(B!!M3!!!T+#P(mi!4i#[cJ!!3+CQPXC3d
 | 
				
			||||||
 | 
					%H!!"E3!!#Nd+8!4j$!4j!!i!#(4YC'PQCLjS!!)!!!d%G`!#0!!!#N)+5[cI"(S
 | 
				
			||||||
 | 
					+r0m!"!TMCQpX$34k!!&[!!!+4JT*r0i,r0i!*$!!%'0bHA"dEfC[E'4PFR"KG'J
 | 
				
			||||||
 | 
					!%'0bHA"dEdC[E'4PFP"KG'J'r1%!!!)%EJ!#"(X%I!d%H`!#E!!##PJ+@2cGr0`
 | 
				
			||||||
 | 
					"r0d!!!(mh!!!!J4m!!)%I34q$34p!!*X!!)+@!TBr0[mfJ(mf`!!!IcD!!!#"(i
 | 
				
			||||||
 | 
					!!J4r")!0"(m!!dN!!JTB#S,mfIcB")%+r0N!'#jMEh*PBh*PE#SU+LS!!!!!!!#
 | 
				
			||||||
 | 
					3!!"ZG@aX!IcB!!!'")%!!rcA"))%J`Vme`!%#QY[Bf`0"))!!@d!!!TF#PrmeJV
 | 
				
			||||||
 | 
					meJ!%#Q&XD@%'")-!!rc9")3%K3Vme3!%#QPZFfJ0")3!!M3!!!TL#QVme!5'#[c
 | 
				
			||||||
 | 
					8!!3+BfC[E!d%KJ!"E`!!#QB+DIc6#rc6!$3`!"K[F'9ZFh0XD@jME(9NC@C[E'4
 | 
				
			||||||
 | 
					PFR"KG'J!''p`C@j68da*EQ0XG@4P4QpXC'9b8'&dD!B%K3!$r0)%Krc4#[c5!!3
 | 
				
			||||||
 | 
					+G'mJ)!d%K`!#EJ!!#Qd+I!5)")N0")J!!M3!!!Te#Rcmd!5+#[c3!!3+CQPXC3d
 | 
				
			||||||
 | 
					%LJ!"E3!!#RJ+H`5,$!5,!!`!"Q9IEh-ZD!!#!!!0")N!!M3!!!TY#RAmc`5-#[c
 | 
				
			||||||
 | 
					2!!3+BfC[E!d%M!!"E`!!#R%+G2c1#rc1!#B`!"&[F'9ZFh0XCQpXC'9bF'&dD!!
 | 
				
			||||||
 | 
					4Eh"PER0cE%C[E'4PFP"KG'J'r0%!!!)%J!!#")d%MJd%M3!$53!##S-+VIc0r-`
 | 
				
			||||||
 | 
					%M`Vmc3!B,Q0[FQ9MFQ9X+LSU+J!!!!!!!*!!!'jeE'`"r-`!!!B%M`!$r-X%N!!
 | 
				
			||||||
 | 
					%N3Vmb`!%#QY[Bf`0"*!!!!&Y!!!+K`U+r-S+r-S!"!TKE'PK"J54!!2mb355"*-
 | 
				
			||||||
 | 
					+r-N!"!TTER0S$355!!)d!!!+M3U9r-J%P!Vmb!!%#Q0QEf`0"*3!!@m!!!U4#T6
 | 
				
			||||||
 | 
					ma`[ma`!d-!!BEh"PER0cE'PZBfaeC'9QEfaNCA*`BA4S!"K[F'9Z8e0-5@jME(9
 | 
				
			||||||
 | 
					NC8C[E'4PFP"KG'J'"*-!!rc'"*Ama3VmaJ!%#R4[)#!0"*8!!Qi!!!UB#UF%PJ5
 | 
				
			||||||
 | 
					A$35@!!)d!!!+S!URr-3%Q!Vma!!%#QCTE'80"*J!!@d!!!UM#UB%Q3`%Q3!0!!G
 | 
				
			||||||
 | 
					PAfpc-LjS!!)!!!d%P`!#0!!!#TJ+S2c$"*S+r--!"!TMCQpX$35D!!&[!!!+R!U
 | 
				
			||||||
 | 
					Ir-),r-)!*M!!%@p`C@jcFfaQEfaNCA*`BA4S!"&[F'9ZFh0X4QpXC'9b8'&dD!E
 | 
				
			||||||
 | 
					ma3!!!J51!!)%Qrc"$35E!!*X!!)+VJUZr-$m[`(m`!!!!Ibr!!!#r-%!!!d!#3!
 | 
				
			||||||
 | 
					"E3!!!!!!!3!I!Irq!!!#!!B!!J5F"*d0"*`!!Q`!!J!!!!$m[[bp!Ibq!!!"r,d
 | 
				
			||||||
 | 
					!!!)%R3!#"*i%R`d%RJ!#E!!##V%+b!5Jr,`0"+!!!dN!!JUa#XMmZ`5K"+)+r,X
 | 
				
			||||||
 | 
					!'#jcHA0[C'a[Cf&cDh)!!!!!!!!!!&4&@&30"+%!!@d!!!Ua#V3%S``%S`!'!!!
 | 
				
			||||||
 | 
					!!J!!"J5L!!2mZJ5N"+8+r,S!"!TLG'jc$35N!!&+!!!+Y`Um"+B#"+B!!J5Rr,N
 | 
				
			||||||
 | 
					0"+F!!@d!!!Uh#VS%U!`%U!!+!!4%EfjP!!)!!!,mZ3!!"J5P!!2mZ!5Tr,F+r,J
 | 
				
			||||||
 | 
					!"!TRDACe$35T!!&Y!!!+[`V#r,B$r,B!"3EmY`!!!Ibm!!!#"*m!!J5Ur,80"+S
 | 
				
			||||||
 | 
					!!Q`!!J!!!!$mY2bc!Ibd!!!"r,-!!!,mY3!!$J!#!!!2%!!$!",mXJ5V"+`%V35
 | 
				
			||||||
 | 
					Z"+m%X!5a",)%X`5d",8%YJ5hr,(mX2b[r+i"r,)!!"!%U`!3r+hmV2bVr+VmUIb
 | 
				
			||||||
 | 
					Sr+ImT[bPr+6mSrbLr+(mS2bIr*i+r+d!'#jKCACdEf&`F'jeE'`!!)!!!!#3!!!
 | 
				
			||||||
 | 
					U+LSU#rbX!")`!!GdD'9`BA4S!!GdD'93BA4S#rbV!"``!!adD'9[E'4NC@aTEA-
 | 
				
			||||||
 | 
					!$(4SC8pXC%4PE'PYF`[mUJ!J-!!1G'KPF(*[DQ9MG("KG'J!$R4SC9"bEfTPBh4
 | 
				
			||||||
 | 
					3BA4S#rbT!"B`!!PdD'9YCA"KG'J!#A4SC8eP8'&dD![mU!!Q-!!4D@jME(9NC@C
 | 
				
			||||||
 | 
					[E'4PFR"KG'J!%@PZBfaeC'9'EfaNCA*3BA4S#rbR!$3`!"K[F'9ZFh0XD@jME(9
 | 
				
			||||||
 | 
					NC@C[E'4PFR"KG'J!''p`C@j68da*EQ0XG@4P4QpXC'9b8'&dD![mTJ!N-!!3Bh*
 | 
				
			||||||
 | 
					jF(4[CQpXC'9bF'&dD!!3Bh*jF(4[4QpXC'9b8'&dD![mT3!H-!!0Fh0XCQpXC'9
 | 
				
			||||||
 | 
					bF'&dD!!0Fh0X4QpXC'9b8'&dD![mT!!Q-!!4Eh"PER0cE'C[E'4PFR"KG'J!%@p
 | 
				
			||||||
 | 
					`C@jcFfa'EfaNCA*3BA4S#rbM!#i`!"9dD'9ZCAGQEfaNCA*bC@CPFQ9ZBf8!&A4
 | 
				
			||||||
 | 
					SC8jPGdC[E'4PFP*PCQ9bC@jMC3[mSJ!8-!!)G'9YF("KG'J!#(4PEA"3BA4S!Ib
 | 
				
			||||||
 | 
					K!!!"r+!!!!(mR`!!!IbH!!!1"+`!"a$mR35ir*cmQ`5j",VmQJVmR3!B,Q&PGR4
 | 
				
			||||||
 | 
					[BA"`ER9XE!!!J!!!!*!!!#SU+LS0",J!!@X!!!!!#XJ%Z`)%Z`!#!!8%[!)%[!!
 | 
				
			||||||
 | 
					#"*lmQ3,mQ3!!!IbF!!!#r*X!!"!%Z3!!%!5k!)B!(rbBr*ImP[b9r*6mNrb5!#c
 | 
				
			||||||
 | 
					mNIb3!2b2r)lmMIb-!%rmL`"D!&[mLJ"Nr)N!EIb)r)ImKJ#2r)AmK2b$r),mJIb
 | 
				
			||||||
 | 
					!r(rmI[apr(cmH`#Tr(VmHIair(F![Iaf!-ImG3$8!1)!l!$j!3-"%!%D!5F"-3%
 | 
				
			||||||
 | 
					q!8J"93&I!@`"GJ'$!Bd"QJ'N!E%"Z`()!G)"h`(T!IB#!!)0!KF#*!)Z!MX#43*
 | 
				
			||||||
 | 
					5!P`#D3*c!S!#LJ+A!U%#VJ+m!XB#d`,G!ZS#p!-"!`X$'!-L!bm$130'!e!$A30
 | 
				
			||||||
 | 
					R!h3$IJ1,!jN$S`1`!lS$a`24!pi$l!2f"!-%%`3K"#m%234,"&X%D`4j")X%Q35
 | 
				
			||||||
 | 
					Mr(3%U2acr(,mF3VmQ!!%#Q0[BQS+r*F!'#jPBA*cCQCNFQ&XDA-!!!!!!!!J!'&
 | 
				
			||||||
 | 
					QC()+r*B!"!TMG(Kd#rb9!")`!!GdD'9`BA4S!!GdD'93BA4S#[b8!!3+BA0MFJV
 | 
				
			||||||
 | 
					mN`!%#R4iC'`,r*)!($!!$(4SC@pXC'4PE'PYF`!-G'KP6faN4'9XD@ec#[b4!!3
 | 
				
			||||||
 | 
					+BfPdE32mN!$rr3[mM`!J-!!1G'KPF(*[DQ9MG("KG'J!$R4SC9"bEfTPBh43BA4
 | 
				
			||||||
 | 
					S!rb1rri+r)d!"!T849K8#rb-!"B`!!PdD'9YCA"KG'J!#A4SC8eP8'&dD![mL`!
 | 
				
			||||||
 | 
					Q-!!4D@jME(9NC@C[E'4PFR"KG'J!%@PZBfaeC'9'EfaNCA*3BA4S#rb+!$3`!"K
 | 
				
			||||||
 | 
					[F'9ZFh0XD@jME(9NC@C[E'4PFR"KG'J!''p`C@j68da*EQ0XG@4P4QpXC'9b8'&
 | 
				
			||||||
 | 
					dD![mL3!N-!!3Bh*jF(4[CQpXC'9bF'&dD!!3Bh*jF(4[4QpXC'9b8'&dD![mL!!
 | 
				
			||||||
 | 
					H-!!0Fh0XCQpXC'9bF'&dD!!0Fh0X4QpXC'9b8'&dD![mK`!Q-!!4Eh"PER0cE'C
 | 
				
			||||||
 | 
					[E'4PFR"KG'J!%@p`C@jcFfa'EfaNCA*3BA4S#[b'!!3+BfC[E!VmK3!B,QeTFf0
 | 
				
			||||||
 | 
					cE'0d+LSU+J!!!!!!!*!!!#SU+LS+r)3!"!TcC@aP#[b$!"JZBfpbC@4PE'mU+LS
 | 
				
			||||||
 | 
					U!!!!!!!!N!!!+LSU+J(mJJ!!![b"!!!+r)!!"!TVEf0X#[ar!!3+D@jcD!2mIJ!
 | 
				
			||||||
 | 
					%#[ap!"JZBfpbC@0bC@`U+LSU!!!!!!!!N!!!ER9XE!VmI!!%#R*cE(3,r(X!,M!
 | 
				
			||||||
 | 
					!&A4SC@jPGfC[E'4PFR*PCQ9bC@jMC3!9G'KP6Q9h4QpXC'9b8Q9QCA*PEQ0P#[a
 | 
				
			||||||
 | 
					k!!3+F'jKE3VmH3!%#Q&XD@%+r(J!"!TdEb!J#[ah!!3+CQPXC32mGJ!'#rae!"3
 | 
				
			||||||
 | 
					`!!KdC@e`F'&dD!!)G'9YF&"KG'J+r(3!"!TLG'jc#[ac!!3+CfPfG32mFJ!&#[a
 | 
				
			||||||
 | 
					a!"JZFhPcEf4XEfGKFfYb!!!!!!!!!!"849K8%IbD#XRJ%JUYi1%TDJ`!!LrM*N9
 | 
				
			||||||
 | 
					4e%r&jLa&edrSaHBX4Nr%@qPF@eTVA&VU-NAE6m4Ek9aE@QYF@Z`bl5C&hNr,lbA
 | 
				
			||||||
 | 
					Y*N9J!""2bf%!%59K!")Pl5C&B!!66mYK!"3Pl5C&B!!96mYK!"BPl5C&B!!A6m[
 | 
				
			||||||
 | 
					Y*N9J!"K2amAQ,%C2&!!L+Q%!'9m!%#pK!"PK!"S[DJ`!'dmUB3!F,'S-!"eA!!K
 | 
				
			||||||
 | 
					B!"i!(fK2+Q%!)'%!'@%!)5TK!"PI!"![B3!L$!!M6em!*%9J!#92A`!PDJ`!'dp
 | 
				
			||||||
 | 
					K!#BUB3!F,'%!*ba'6bTK!#"K!#KK!#%UB3!CA`!6,f%!+5TK!"R1,f%!+Q%!+bp
 | 
				
			||||||
 | 
					K!#`-!#02A`!9B3!Y*89J!#j2+Q%!)'%!+'%!)5TK!"PI!"-[B3!T+Q%!'9m!,Lp
 | 
				
			||||||
 | 
					K!#TK!#m[B3!X$!!M6bTK!#"K!#KK!#%UB3!CA`!6,f%!+5TK!"PI!#i[B3!UB3!
 | 
				
			||||||
 | 
					`,f%!,!`!)dpI!"9K!$%P4@!!,NmUB3!JB3!SB3!K+Q%!'9m!%bpK!#NUB3!CA`!
 | 
				
			||||||
 | 
					Z,f%!+Q%!-LpK!#`-!#02A`!9B3!c*89J!#j2+Q%!)'%!+'%!)5TK!"PI!"-[B3!
 | 
				
			||||||
 | 
					T+Q%!'9m!,LpK!#TK!$3[B3!X$!!M6em!&@%!059&B!!Z6bTK!#"K!#KK!#%UB3!
 | 
				
			||||||
 | 
					CA`!6,f%!+5TK!"PI!#i[B3!UB3!f,f%!,!`!)dpI!"9K!$FP4@!!,NmUB3!JB3!
 | 
				
			||||||
 | 
					SB3!K+Q%!'9m!%bpK!#NUB3!CA`!Z,f%!+Q%!1#pK!#`-!#02A`!9B3!j*89J!#j
 | 
				
			||||||
 | 
					2+Q%!)'%!+'%!)5TK!"PI!"-[B3!T+Q%!'9m!,LpK!#TK!$S[B3!X$!!M6em!&@%
 | 
				
			||||||
 | 
					!1b9&B!!Z6bTK!#"K!#KK!#%UB3!CA`!6,f%!+5TK!"PI!#i[B3!UB3!m,f%!,!`
 | 
				
			||||||
 | 
					!)dpI!"9K!$dP4@!!,NmUB3!JB3!SB3!K+Q%!'9m!%bpK!#NUB3!CA`!Z,f%!+Q%
 | 
				
			||||||
 | 
					!2LpK!#`-!#02A`!9B3!r*89J!#j2+Q%!)'%!+'%!)5TK!"PI!"-[B3!T+Q%!'9m
 | 
				
			||||||
 | 
					!,LpK!#TK!%![B3!X$!!M6em!&@%!359&B!!Z6bTK!#"K!#KK!#%UB3!CA`!6,f%
 | 
				
			||||||
 | 
					!+5TK!"PI!#i[B3!UB3"#,f%!,!`!)dpI!"9K!%-P4@!!,NmUB3!JB3!SB3!K+Q%
 | 
				
			||||||
 | 
					!'9m!%bpK!#NUB3!CA`!Z,f%!+Q%!4#pK!#`-!#02A`!9B3"&*89J!#j2+Q%!)'%
 | 
				
			||||||
 | 
					!+'%!)5TK!"PI!"-[B3!T+Q%!'9m!,LpK!#TK!%B[B3!X$!!M6em!&@%!4b9&B!!
 | 
				
			||||||
 | 
					Z6bTK!#"K!#KK!#%UB3!CA`!6,f%!+5TK!"PI!#i[B3!UB3"),f%!,!`!)dpI!"9
 | 
				
			||||||
 | 
					K!%NP4@!!,NmUB3!JB3!SB3!K+Q%!'9m!%bpK!#NUB3!CA`!Z,f%!+Q%!5LpK!#`
 | 
				
			||||||
 | 
					-!#02A`!9B3",*89J!#j2+Q%!)'%!+'%!)5TK!"PI!"-[B3!T+Q%!'9m!,LpK!#T
 | 
				
			||||||
 | 
					K!%`[B3!X$!!M6em!&@%!659&B!!Z6bTK!#"K!#KK!#%UB3!CA`!6,f%!+5TK!"P
 | 
				
			||||||
 | 
					I!#i[B3!UB3"1,f%!,!`!)dpI!"9K!%mP4@!!,NmUB3!JB3!SB3!K+Q%!'9m!%bp
 | 
				
			||||||
 | 
					K!#NUB3!CA`!Z,f%!+Q%!8#pK!#`-!#02A`!9B3"4*89J!#j2+Q%!)'%!+'%!)5T
 | 
				
			||||||
 | 
					K!"PI!"-[B3!T+Q%!'9m!,LpK!#TK!&)[B3!X$!!M6em!&@%!8b9&B!!Z6bTK!#"
 | 
				
			||||||
 | 
					K!#KK!#%UB3!CA`!6,f%!+5TK!"PI!#i[B3!UB3"8,f%!,!`!)dpI!"9K!&8P4@!
 | 
				
			||||||
 | 
					!,NmUB3!JB3!SB3!K+Q%!'9m!%bpK!#NUB3!CA`!Z,f%!+Q%!9LpK!#`-!#02A`!
 | 
				
			||||||
 | 
					9B3"A*89J!#j2+Q%!)'%!+'%!)5TK!"PI!"-[B3!T+Q%!'9m!,LpK!#TK!&J[B3!
 | 
				
			||||||
 | 
					X$!!M6bTK!#"K!#KK!#%UB3!CA`!6,f%!+5TK!"PI!#i[B3!UB3"C,f%!,!`!)dp
 | 
				
			||||||
 | 
					I!"9K!&SP4@!!,NmUB3!JB3!SB3!K+Q%!'9m!%bpK!#NUB3!CA`!Z,f%!+Q%!@bp
 | 
				
			||||||
 | 
					K!#`-!#02A`!9B3"F*89J!#j2+Q%!)'%!+'%!)5TK!"PI!"-[B3!T+Q%!'9m!,Lp
 | 
				
			||||||
 | 
					K!#TK!&d[B3!X$!!M6em!&@%!AL9&B!!Z6bTK!#"K!#KK!#%UB3!CA`!6,f%!+5T
 | 
				
			||||||
 | 
					K!"PI!#i[B3!UB3"I,f%!,!`!)dpI!"9K!'!P4@!!,NmUB3!JB3!SB3!K+Q%!'9m
 | 
				
			||||||
 | 
					!%bpK!#NUB3!CA`!Z,f%!+Q%!B5pK!#`-!#02A`!9B3"L*89J!#j2+Q%!)'%!+'%
 | 
				
			||||||
 | 
					!)5TK!"PI!"-[B3!T+Q%!'9m!,LpK!#TK!'-[B3!X$!!M6em!&@%!C#9&B!!Z6bT
 | 
				
			||||||
 | 
					K!#"K!#KK!#%UB3!CA`!6,f%!+5TK!"PI!#i[B3!UB3"P,f%!,!`!)dpI!"9K!'B
 | 
				
			||||||
 | 
					P4@!!,NmUB3!JB3!SB3!K+Q%!'9m!%bpK!#NUB3!CA`!Z,f%!+Q%!CbpK!#`-!#0
 | 
				
			||||||
 | 
					2A`!9B3"S*89J!#j2+Q%!)'%!+'%!)5TK!"PI!"-[B3!T+Q%!'9m!,LpK!#TK!'N
 | 
				
			||||||
 | 
					[B3!X$!!M6em!&@%!DL9&B!!Z6bTK!#"K!#KK!#%UB3!CA`!6,f%!+5TK!"PI!#i
 | 
				
			||||||
 | 
					[B3!UB3"V,f%!,!`!)dmUB3!JB3!SB3!K+Q%!'9m!%bpK!#NUB3!CA`!Z,f%!+Q%
 | 
				
			||||||
 | 
					!E#pK!#`-!#02A`!9B3"Y*89J!#j2+Q%!)'%!+'%!)5TK!"PI!"-[B3!T+Q%!'9m
 | 
				
			||||||
 | 
					!,LpK!#TK!'i[B3!X$!!M6em!&@%!Eb9&B!!Z6bTK!#"K!#KK!#%UB3!CA`!6,f%
 | 
				
			||||||
 | 
					!+5TK!"PI!#i[B3!UB3"`,f%!,!`!)dpI!"9K!(%P4@!!,NmUB3!JB3!SB3!K+Q%
 | 
				
			||||||
 | 
					!'9m!%bpK!#NUB3!CA`!Z,f%!+Q%!FLpK!#`-!#02+Q%!)'%!+'%!)5TK!"PI!"-
 | 
				
			||||||
 | 
					[B3!T+Q%!'9m!,LpK!#TK!(-[B3!X$!!M6em!&@%!G#9&B!!Z6bTK!#"K!#KK!#%
 | 
				
			||||||
 | 
					UB3!CA`!6,f%!+5TK!"PI!#i[B3!UB3"e,f%!,!`!)dmUB3!JB3!SB3!K+Q%!'9m
 | 
				
			||||||
 | 
					!%bpK!#NUB3!CA`!A,f%!+Q%!GLpK!#`-!#02+Q%!)'%!+'%!)5TK!"PI!"-[B3!
 | 
				
			||||||
 | 
					T+Q%!'9m!&bpK!#TK!(F[B3!X$!!M6bTK!#"K!#KK!#%UB3!CA`!6,f%!+5TK!"P
 | 
				
			||||||
 | 
					I!"F[B3!UB3"i,f%!,!`!)dmUB3!JB3!SB3!K+Q%!'9m!%bpK!#NUB3!CA`!A,f%
 | 
				
			||||||
 | 
					!+Q%!H5pK!#`-!#02+Q%!)'%!+'%!)5TK!"PI!"-[B3!T+Q%!'9m!&bpK!#TK!(S
 | 
				
			||||||
 | 
					[B3!X$!!M6bTK!#"K!#KK!#%UB3!CA`!6,f%!+5TK!"PI!"8[B3!UB3"l,f%!,!`
 | 
				
			||||||
 | 
					!)dmUB3!JB3!SB3!K+Q%!'9m!%bpK!#NUB3!CA`!9,f%!+Q%!I#pK!#`-!#02+Q%
 | 
				
			||||||
 | 
					!)'%!+'%!)5TK!"PI!"-[B3!T+Q%!'9m!&5pK!#TK!(d[B3!X$!!M6bTK!#"K!#K
 | 
				
			||||||
 | 
					K!#%UB3!CA`!6,f%!+5TK!"PI!"J[B3!UB3"q,f%!,!`!)dmUB3!JB3!SB3!K+Q%
 | 
				
			||||||
 | 
					!'9m!%bpK!#NUB3!CA`!B,f%!+Q%!IbpK!#`-!#028&92B3#!B3#"B3##DhCK!)0
 | 
				
			||||||
 | 
					K!)4K!#)-!)82$!5Y!&%!5deKBfPZG'pcD#")4$T%CA0VG'p`)%C[E'4PFMT*EQ0
 | 
				
			||||||
 | 
					[E@PZCcT[F'9ZFh0X,90139!Y-6Nj16%b-6%k6@&M6e-kE@YXD@jVFbjKF`!#!!!
 | 
				
			||||||
 | 
					1"+i!!J6mF!5p!ra`!!%1",d!!3!%[J`%[J!'!!!!!J!!$J5[!!)%r'm%[`2mE`!
 | 
				
			||||||
 | 
					%$J5r!!3!"-!%`36#"---"-!!%J!-6@&MD@jdEh0S)%K%!!)!!!`%`3!8!!j%CA0
 | 
				
			||||||
 | 
					VG'p`)%C[E'4PFJ!#!!!-"-)!$J!)5@jMEfeTEQF!!J!!$!6$!"X!&@p`C@jcFf`
 | 
				
			||||||
 | 
					Y8dj"8#da16Nj-6)a-3!#!!!-",!!4J"!6@&MD@jdEh0S)%K%1N4PFfYdEh!J4Qp
 | 
				
			||||||
 | 
					XC'9b1NPZBfpYD@jR1Qp`C@jcFf`Y8dj"8#da16Nj-6)a-6T0B@028`!#!!!-",%
 | 
				
			||||||
 | 
					!5!"#6@&MD@jdEh0S)%K%1N4PFfYdEh!J4QpXC'9b1NPZBfpYD@jR1Qp`C@jcFf`
 | 
				
			||||||
 | 
					Y8dj"8#da16Nj-6)a-6TTEQ0XG@4P!!)!!!`%XJ"3!%T0B@0TER4[FfJJ5%3k4'9
 | 
				
			||||||
 | 
					cDh4[F#"'EfaNCA)k5@jMEfeTEQFkEh"PER0cE#e66N&3,6%j16Na-M%a1QPZBfa
 | 
				
			||||||
 | 
					eC'8kEh"PER0cE!!#!!!-",-!4`""6@&MD@jdEh0S)%K%1N4PFfYdEh!J4QpXC'9
 | 
				
			||||||
 | 
					b1NPZBfpYD@jR1Qp`C@jcFf`Y8dj"8#da16Nj-6)a-6TMFRP`G'm!!J!!$!5d!%3
 | 
				
			||||||
 | 
					!2NeKBfPZG'pcD#")4$T%CA0VG'p`)%C[E'4PFMT*EQ0[E@PZCcT[F'9ZFh0X,90
 | 
				
			||||||
 | 
					139!Y-6Nj16%b-6%kFh0X!!)!!!`%Y3"!!$T0B@0TER4[FfJJ5%3k4'9cDh4[F#"
 | 
				
			||||||
 | 
					'EfaNCA)k5@jMEfeTEQFkEh"PER0cE#e66N&3,6%j16Na-M%a!!)!!!i%YJ!"&!6
 | 
				
			||||||
 | 
					%$J6%!!-B"-AmEJ6'$J6&!!-B"-ImE36)$J6(!!-B"-RmE!6+$J6*!!-B!"rmD`6
 | 
				
			||||||
 | 
					,#[aV!!3+BfC[E!`%b`!1!!K*EQ0[E@PZC`!#!!!+r'`!"!TMCQpX$!6+!"X!&@p
 | 
				
			||||||
 | 
					`C@jcFf`Y8dj"8#da16Nj-6)a-3!#!!!+r'd!"!TMCQpX$!6)!!d!"fPZBfaeC'8
 | 
				
			||||||
 | 
					!!J!!#[aZ!!3+BfC[E!`%aJ!9!!peER4TG'aPC#"QEfaNCA)!!J!!$!5h!%i!5%e
 | 
				
			||||||
 | 
					KBfPZG'pcD#")4$T%CA0VG'p`)%C[E'4PFMT*EQ0[E@PZCcT[F'9ZFh0X,90139!
 | 
				
			||||||
 | 
					Y-6Nj16%b-6%kBh*jF(4[1RJe-$Pf-`!#!!!"r,%!!!(mX!!!!Ib[!!!"r+i!!'&
 | 
				
			||||||
 | 
					cBh)!!3!-qYlHV3!!!3!!!*G#!!#@3J!!!AB!!$-8-0J!!!!F!AB!$h0MFhS!!!#
 | 
				
			||||||
 | 
					#6Np853!!!)jcBh"d!!!!QP4&@&3!!3#QFh4jE!!!!,j$6d4&!!%!bN*14%`!!!$
 | 
				
			||||||
 | 
					LBA"XG!!!!1j'8N9'!!!!qNP$6L-!!!%'D@0X0!!!!4*TBh-M!!!"(QPMFc3!!!%
 | 
				
			||||||
 | 
					UD'CNFJ!!!6C659T&!!!"3PG3Eh-!!!&1!!$rr`!!!!!!!!!!!)$rre!!!"i!!!!
 | 
				
			||||||
 | 
					!!)$rr`!!"cJ#DH#m"'Mrr`!!!*S!!!!!%iRrr`!!"Pi!!!!!"'Mrr`!!!53!!!!
 | 
				
			||||||
 | 
					!!!$rrb!!!9)!!!!!!!(rra3!!@i#DG`%!)$rr`!!!Pi#DH"X!!$rr`!!!Ri!!!!
 | 
				
			||||||
 | 
					!!)$rr`!!!S-#DH"d!*Err`!!!Si!!!!!!*Err`!!!j)!!!!!!*Err`!!"CB#DH%
 | 
				
			||||||
 | 
					i!*Err`!!"GS#DH%dkF$rr`!!"[`!!!!!rrrrr`!!"a)!!!!!!)$rr`!!"b!!!!!
 | 
				
			||||||
 | 
					!*4S:
 | 
				
			||||||
							
								
								
									
										116
									
								
								MacOS/opensslconf.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										116
									
								
								MacOS/opensslconf.h
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,116 @@
 | 
				
			|||||||
 | 
					/* MacOS/opensslconf.h */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if !(defined(VMS) || defined(__VMS)) /* VMS uses logical names instead */
 | 
				
			||||||
 | 
					#if defined(HEADER_CRYPTLIB_H) && !defined(OPENSSLDIR)
 | 
				
			||||||
 | 
					#define OPENSSLDIR "/usr/local/ssl"
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if defined(HEADER_IDEA_H) && !defined(IDEA_INT)
 | 
				
			||||||
 | 
					#define IDEA_INT unsigned int
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if defined(HEADER_MD2_H) && !defined(MD2_INT)
 | 
				
			||||||
 | 
					#define MD2_INT unsigned int
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if defined(HEADER_RC2_H) && !defined(RC2_INT)
 | 
				
			||||||
 | 
					/* I need to put in a mod for the alpha - eay */
 | 
				
			||||||
 | 
					#define RC2_INT unsigned int
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if defined(HEADER_RC4_H)
 | 
				
			||||||
 | 
					#if !defined(RC4_INT)
 | 
				
			||||||
 | 
					/* using int types make the structure larger but make the code faster
 | 
				
			||||||
 | 
					 * on most boxes I have tested - up to %20 faster. */
 | 
				
			||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * I don't know what does "most" mean, but declaring "int" is a must on:
 | 
				
			||||||
 | 
					 * - Intel P6 because partial register stalls are very expensive;
 | 
				
			||||||
 | 
					 * - elder Alpha because it lacks byte load/store instructions;
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					#define RC4_INT unsigned char
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#if !defined(RC4_CHUNK)
 | 
				
			||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * This enables code handling data aligned at natural CPU word
 | 
				
			||||||
 | 
					 * boundary. See crypto/rc4/rc4_enc.c for further details.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					#define RC4_CHUNK unsigned long
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if defined(HEADER_DES_H) && !defined(DES_LONG)
 | 
				
			||||||
 | 
					/* If this is set to 'unsigned int' on a DEC Alpha, this gives about a
 | 
				
			||||||
 | 
					 * %20 speed up (longs are 8 bytes, int's are 4). */
 | 
				
			||||||
 | 
					#ifndef DES_LONG
 | 
				
			||||||
 | 
					#define DES_LONG unsigned long
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if defined(HEADER_BN_H) && !defined(CONFIG_HEADER_BN_H)
 | 
				
			||||||
 | 
					#define CONFIG_HEADER_BN_H
 | 
				
			||||||
 | 
					#if __option(longlong)
 | 
				
			||||||
 | 
					#  define BN_LLONG
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					#  undef BN_LLONG
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* Should we define BN_DIV2W here? */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* Only one for the following should be defined */
 | 
				
			||||||
 | 
					/* The prime number generation stuff may not work when
 | 
				
			||||||
 | 
					 * EIGHT_BIT but I don't care since I've only used this mode
 | 
				
			||||||
 | 
					 * for debuging the bignum libraries */
 | 
				
			||||||
 | 
					#undef SIXTY_FOUR_BIT_LONG
 | 
				
			||||||
 | 
					#undef SIXTY_FOUR_BIT
 | 
				
			||||||
 | 
					#define THIRTY_TWO_BIT
 | 
				
			||||||
 | 
					#undef SIXTEEN_BIT
 | 
				
			||||||
 | 
					#undef EIGHT_BIT
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if defined(HEADER_RC4_LOCL_H) && !defined(CONFIG_HEADER_RC4_LOCL_H)
 | 
				
			||||||
 | 
					#define CONFIG_HEADER_RC4_LOCL_H
 | 
				
			||||||
 | 
					/* if this is defined data[i] is used instead of *data, this is a %20
 | 
				
			||||||
 | 
					 * speedup on x86 */
 | 
				
			||||||
 | 
					#undef RC4_INDEX
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if defined(HEADER_BF_LOCL_H) && !defined(CONFIG_HEADER_BF_LOCL_H)
 | 
				
			||||||
 | 
					#define CONFIG_HEADER_BF_LOCL_H
 | 
				
			||||||
 | 
					#define BF_PTR
 | 
				
			||||||
 | 
					#endif /* HEADER_BF_LOCL_H */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if defined(HEADER_DES_LOCL_H) && !defined(CONFIG_HEADER_DES_LOCL_H)
 | 
				
			||||||
 | 
					#define CONFIG_HEADER_DES_LOCL_H
 | 
				
			||||||
 | 
					/* the following is tweaked from a config script, that is why it is a
 | 
				
			||||||
 | 
					 * protected undef/define */
 | 
				
			||||||
 | 
					#ifndef DES_PTR
 | 
				
			||||||
 | 
					#define DES_PTR
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* This helps C compiler generate the correct code for multiple functional
 | 
				
			||||||
 | 
					 * units.  It reduces register dependancies at the expense of 2 more
 | 
				
			||||||
 | 
					 * registers */
 | 
				
			||||||
 | 
					#ifndef DES_RISC1
 | 
				
			||||||
 | 
					#define DES_RISC1
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifndef DES_RISC2
 | 
				
			||||||
 | 
					#undef DES_RISC2
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if defined(DES_RISC1) && defined(DES_RISC2)
 | 
				
			||||||
 | 
					YOU SHOULD NOT HAVE BOTH DES_RISC1 AND DES_RISC2 DEFINED!!!!!
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* Unroll the inner loop, this sometimes helps, sometimes hinders.
 | 
				
			||||||
 | 
					 * Very mucy CPU dependant */
 | 
				
			||||||
 | 
					#ifndef DES_UNROLL
 | 
				
			||||||
 | 
					#define DES_UNROLL
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#endif /* HEADER_DES_LOCL_H */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifndef __POWERPC__
 | 
				
			||||||
 | 
					#define MD32_XARRAY
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
							
								
								
									
										638
									
								
								Makefile.fips
									
									
									
									
									
								
							
							
						
						
									
										638
									
								
								Makefile.fips
									
									
									
									
									
								
							@@ -1,638 +0,0 @@
 | 
				
			|||||||
##
 | 
					 | 
				
			||||||
## Makefile for OpenSSL: fipscanister.o only
 | 
					 | 
				
			||||||
##
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
VERSION=fips-2.0-test
 | 
					 | 
				
			||||||
MAJOR=
 | 
					 | 
				
			||||||
MINOR=
 | 
					 | 
				
			||||||
SHLIB_VERSION_NUMBER=
 | 
					 | 
				
			||||||
SHLIB_VERSION_HISTORY=
 | 
					 | 
				
			||||||
SHLIB_MAJOR=
 | 
					 | 
				
			||||||
SHLIB_MINOR=
 | 
					 | 
				
			||||||
SHLIB_EXT=
 | 
					 | 
				
			||||||
PLATFORM=dist
 | 
					 | 
				
			||||||
OPTIONS=
 | 
					 | 
				
			||||||
CONFIGURE_ARGS=
 | 
					 | 
				
			||||||
SHLIB_TARGET=
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# HERE indicates where this Makefile lives.  This can be used to indicate
 | 
					 | 
				
			||||||
# where sub-Makefiles are expected to be.  Currently has very limited usage,
 | 
					 | 
				
			||||||
# and should probably not be bothered with at all.
 | 
					 | 
				
			||||||
HERE=.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# INSTALL_PREFIX is for package builders so that they can configure
 | 
					 | 
				
			||||||
# for, say, /usr/ and yet have everything installed to /tmp/somedir/usr/.
 | 
					 | 
				
			||||||
# Normally it is left empty.
 | 
					 | 
				
			||||||
INSTALL_PREFIX=
 | 
					 | 
				
			||||||
INSTALLTOP=/usr/local/ssl
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# Do not edit this manually. Use Configure --openssldir=DIR do change this!
 | 
					 | 
				
			||||||
OPENSSLDIR=/usr/local/ssl
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# NO_IDEA - Define to build without the IDEA algorithm
 | 
					 | 
				
			||||||
# NO_RC4  - Define to build without the RC4 algorithm
 | 
					 | 
				
			||||||
# NO_RC2  - Define to build without the RC2 algorithm
 | 
					 | 
				
			||||||
# THREADS - Define when building with threads, you will probably also need any
 | 
					 | 
				
			||||||
#           system defines as well, i.e. _REENTERANT for Solaris 2.[34]
 | 
					 | 
				
			||||||
# TERMIO  - Define the termio terminal subsystem, needed if sgtty is missing.
 | 
					 | 
				
			||||||
# TERMIOS - Define the termios terminal subsystem, Silicon Graphics.
 | 
					 | 
				
			||||||
# LONGCRYPT - Define to use HPUX 10.x's long password modification to crypt(3).
 | 
					 | 
				
			||||||
# DEVRANDOM - Give this the value of the 'random device' if your OS supports
 | 
					 | 
				
			||||||
#           one.  32 bytes will be read from this when the random
 | 
					 | 
				
			||||||
#           number generator is initalised.
 | 
					 | 
				
			||||||
# SSL_FORBID_ENULL - define if you want the server to be not able to use the
 | 
					 | 
				
			||||||
#           NULL encryption ciphers.
 | 
					 | 
				
			||||||
#
 | 
					 | 
				
			||||||
# LOCK_DEBUG - turns on lots of lock debug output :-)
 | 
					 | 
				
			||||||
# REF_CHECK - turn on some xyz_free() assertions.
 | 
					 | 
				
			||||||
# REF_PRINT - prints some stuff on structure free.
 | 
					 | 
				
			||||||
# CRYPTO_MDEBUG - turns on my 'memory leak' detecting stuff
 | 
					 | 
				
			||||||
# MFUNC - Make all Malloc/Free/Realloc calls call
 | 
					 | 
				
			||||||
#       CRYPTO_malloc/CRYPTO_free/CRYPTO_realloc which can be setup to
 | 
					 | 
				
			||||||
#       call application defined callbacks via CRYPTO_set_mem_functions()
 | 
					 | 
				
			||||||
# MD5_ASM needs to be defined to use the x86 assembler for MD5
 | 
					 | 
				
			||||||
# SHA1_ASM needs to be defined to use the x86 assembler for SHA1
 | 
					 | 
				
			||||||
# RMD160_ASM needs to be defined to use the x86 assembler for RIPEMD160
 | 
					 | 
				
			||||||
# Do not define B_ENDIAN or L_ENDIAN if 'unsigned long' == 8.  It must
 | 
					 | 
				
			||||||
# equal 4.
 | 
					 | 
				
			||||||
# PKCS1_CHECK - pkcs1 tests.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
CC= cc
 | 
					 | 
				
			||||||
CFLAG= -O
 | 
					 | 
				
			||||||
DEPFLAG= 
 | 
					 | 
				
			||||||
PEX_LIBS= 
 | 
					 | 
				
			||||||
EX_LIBS= 
 | 
					 | 
				
			||||||
EXE_EXT= 
 | 
					 | 
				
			||||||
ARFLAGS=
 | 
					 | 
				
			||||||
AR=ar $(ARFLAGS) r
 | 
					 | 
				
			||||||
RANLIB= ranlib
 | 
					 | 
				
			||||||
NM= nm
 | 
					 | 
				
			||||||
PERL= perl
 | 
					 | 
				
			||||||
TAR= tar
 | 
					 | 
				
			||||||
TARFLAGS= --no-recursion
 | 
					 | 
				
			||||||
MAKEDEPPROG=makedepend
 | 
					 | 
				
			||||||
LIBDIR=lib
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# We let the C compiler driver to take care of .s files. This is done in
 | 
					 | 
				
			||||||
# order to be excused from maintaining a separate set of architecture
 | 
					 | 
				
			||||||
# dependent assembler flags. E.g. if you throw -mcpu=ultrasparc at SPARC
 | 
					 | 
				
			||||||
# gcc, then the driver will automatically translate it to -xarch=v8plus
 | 
					 | 
				
			||||||
# and pass it down to assembler.
 | 
					 | 
				
			||||||
#AS=$(CC) -c
 | 
					 | 
				
			||||||
ASFLAG=$(CFLAG)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# For x86 assembler: Set PROCESSOR to 386 if you want to support
 | 
					 | 
				
			||||||
# the 80386.
 | 
					 | 
				
			||||||
PROCESSOR=
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# CPUID module collects small commonly used assembler snippets
 | 
					 | 
				
			||||||
CPUID_OBJ= 
 | 
					 | 
				
			||||||
BN_ASM= bn_asm.o
 | 
					 | 
				
			||||||
DES_ENC= des_enc.o fcrypt_b.o
 | 
					 | 
				
			||||||
AES_ENC= aes_core.o aes_cbc.o
 | 
					 | 
				
			||||||
BF_ENC= bf_enc.o
 | 
					 | 
				
			||||||
CAST_ENC= c_enc.o
 | 
					 | 
				
			||||||
RC4_ENC= rc4_enc.o
 | 
					 | 
				
			||||||
RC5_ENC= rc5_enc.o
 | 
					 | 
				
			||||||
MD5_ASM_OBJ= 
 | 
					 | 
				
			||||||
SHA1_ASM_OBJ= 
 | 
					 | 
				
			||||||
RMD160_ASM_OBJ= 
 | 
					 | 
				
			||||||
WP_ASM_OBJ=
 | 
					 | 
				
			||||||
CMLL_ENC=
 | 
					 | 
				
			||||||
MODES_ASM_OBJ=
 | 
					 | 
				
			||||||
PERLASM_SCHEME=
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# KRB5 stuff
 | 
					 | 
				
			||||||
KRB5_INCLUDES=
 | 
					 | 
				
			||||||
LIBKRB5=
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# Zlib stuff
 | 
					 | 
				
			||||||
ZLIB_INCLUDE=
 | 
					 | 
				
			||||||
LIBZLIB=
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# This is the location of fipscanister.o and friends.
 | 
					 | 
				
			||||||
# The FIPS module build will place it $(INSTALLTOP)/lib
 | 
					 | 
				
			||||||
# but since $(INSTALLTOP) can only take the default value
 | 
					 | 
				
			||||||
# when the module is built it will be in /usr/local/ssl/lib
 | 
					 | 
				
			||||||
# $(INSTALLTOP) for this build may be different so hard
 | 
					 | 
				
			||||||
# code the path.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
FIPSLIBDIR=/usr/local/ssl/$(LIBDIR)/
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# This is set to "y" if fipscanister.o is compiled internally as
 | 
					 | 
				
			||||||
# opposed to coming from an external validated location.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
FIPSCANISTERINTERNAL=n
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# This is set if we only build fipscanister.o
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
FIPSCANISTERONLY=y
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# The location of the library which contains fipscanister.o
 | 
					 | 
				
			||||||
# normally it will be libcrypto unless fipsdso is set in which
 | 
					 | 
				
			||||||
# case it will be libfips. If not compiling in FIPS mode at all
 | 
					 | 
				
			||||||
# this is empty making it a useful test for a FIPS compile.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
FIPSCANLIB=
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# Shared library base address. Currently only used on Windows.
 | 
					 | 
				
			||||||
#
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
BASEADDR=
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
DIRS=   crypto fips test 
 | 
					 | 
				
			||||||
ENGDIRS= ccgost
 | 
					 | 
				
			||||||
SHLIBDIRS= crypto 
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# dirs in crypto to build
 | 
					 | 
				
			||||||
SDIRS=  \
 | 
					 | 
				
			||||||
	sha hmac des aes modes \
 | 
					 | 
				
			||||||
	bn ec rsa dsa ecdsa dh \
 | 
					 | 
				
			||||||
	buffer evp ecdh cmac
 | 
					 | 
				
			||||||
# keep in mind that the above list is adjusted by ./Configure
 | 
					 | 
				
			||||||
# according to no-xxx arguments...
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
LINKDIRS=  \
 | 
					 | 
				
			||||||
	objects sha hmac des aes modes \
 | 
					 | 
				
			||||||
	bn ec rsa dsa ecdh cmac ecdsa dh engine \
 | 
					 | 
				
			||||||
	buffer bio stack lhash rand err \
 | 
					 | 
				
			||||||
	evp asn1 ui
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# tests to perform.  "alltests" is a special word indicating that all tests
 | 
					 | 
				
			||||||
# should be performed.
 | 
					 | 
				
			||||||
TESTS = alltests
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
MAKEFILE= Makefile
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
MANDIR=$(OPENSSLDIR)/man
 | 
					 | 
				
			||||||
MAN1=1
 | 
					 | 
				
			||||||
MAN3=3
 | 
					 | 
				
			||||||
MANSUFFIX=
 | 
					 | 
				
			||||||
HTMLSUFFIX=html
 | 
					 | 
				
			||||||
HTMLDIR=$(OPENSSLDIR)/html
 | 
					 | 
				
			||||||
SHELL=/bin/sh
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
TOP=    .
 | 
					 | 
				
			||||||
ONEDIRS=out tmp
 | 
					 | 
				
			||||||
EDIRS=  times doc bugs util include certs ms shlib mt demos perl sf dep VMS
 | 
					 | 
				
			||||||
WDIRS=  windows
 | 
					 | 
				
			||||||
LIBS=   
 | 
					 | 
				
			||||||
SHARED_CRYPTO=libcrypto$(SHLIB_EXT)
 | 
					 | 
				
			||||||
SHARED_SSL=libssl$(SHLIB_EXT)
 | 
					 | 
				
			||||||
SHARED_LIBS=
 | 
					 | 
				
			||||||
SHARED_LIBS_LINK_EXTS=
 | 
					 | 
				
			||||||
SHARED_LDFLAGS=
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
GENERAL=        Makefile
 | 
					 | 
				
			||||||
BASENAME=       openssl
 | 
					 | 
				
			||||||
NAME=           $(BASENAME)-$(VERSION)
 | 
					 | 
				
			||||||
TARFILE=        openssl-fips-2.0-test.tar
 | 
					 | 
				
			||||||
WTARFILE=       $(NAME)-win.tar
 | 
					 | 
				
			||||||
EXHEADER=       e_os2.h
 | 
					 | 
				
			||||||
HEADER=         e_os.h
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
all: Makefile build_all openssl.pc libssl.pc libcrypto.pc
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# as we stick to -e, CLEARENV ensures that local variables in lower
 | 
					 | 
				
			||||||
# Makefiles remain local and variable. $${VAR+VAR} is tribute to Korn
 | 
					 | 
				
			||||||
# shell, which [annoyingly enough] terminates unset with error if VAR
 | 
					 | 
				
			||||||
# is not present:-( TOP= && unset TOP is tribute to HP-UX /bin/sh,
 | 
					 | 
				
			||||||
# which terminates unset with error if no variable was present:-(
 | 
					 | 
				
			||||||
CLEARENV=	TOP= && unset TOP $${LIB+LIB} $${LIBS+LIBS}	\
 | 
					 | 
				
			||||||
		$${INCLUDE+INCLUDE} $${INCLUDES+INCLUDES}	\
 | 
					 | 
				
			||||||
		$${DIR+DIR} $${DIRS+DIRS} $${SRC+SRC}		\
 | 
					 | 
				
			||||||
		$${LIBSRC+LIBSRC} $${LIBOBJ+LIBOBJ} $${ALL+ALL}	\
 | 
					 | 
				
			||||||
		$${EXHEADER+EXHEADER} $${HEADER+HEADER}		\
 | 
					 | 
				
			||||||
		$${GENERAL+GENERAL} $${CFLAGS+CFLAGS}		\
 | 
					 | 
				
			||||||
		$${ASFLAGS+ASFLAGS} $${AFLAGS+AFLAGS}		\
 | 
					 | 
				
			||||||
		$${LDCMD+LDCMD} $${LDFLAGS+LDFLAGS}		\
 | 
					 | 
				
			||||||
		$${SHAREDCMD+SHAREDCMD} $${SHAREDFLAGS+SHAREDFLAGS}	\
 | 
					 | 
				
			||||||
		$${SHARED_LIB+SHARED_LIB} $${LIBEXTRAS+LIBEXTRAS}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
BUILDENV=	PLATFORM='$(PLATFORM)' PROCESSOR='$(PROCESSOR)' \
 | 
					 | 
				
			||||||
		CC='$(CC)' CFLAG='$(CFLAG)' 			\
 | 
					 | 
				
			||||||
		ASFLAG='$(CFLAG) -c'			\
 | 
					 | 
				
			||||||
		AR='$(AR)' NM='$(NM)' RANLIB='$(RANLIB)'	\
 | 
					 | 
				
			||||||
		CROSS_COMPILE='$(CROSS_COMPILE)'	\
 | 
					 | 
				
			||||||
		PERL='$(PERL)' ENGDIRS='$(ENGDIRS)'		\
 | 
					 | 
				
			||||||
		SDIRS='$(SDIRS)' LIBRPATH='$(INSTALLTOP)/$(LIBDIR)'	\
 | 
					 | 
				
			||||||
		INSTALL_PREFIX='$(INSTALL_PREFIX)'		\
 | 
					 | 
				
			||||||
		INSTALLTOP='$(INSTALLTOP)' OPENSSLDIR='$(OPENSSLDIR)'	\
 | 
					 | 
				
			||||||
		LIBDIR='$(LIBDIR)'				\
 | 
					 | 
				
			||||||
		MAKEDEPEND='$$$${TOP}/util/domd $$$${TOP} -MD $(MAKEDEPPROG)' \
 | 
					 | 
				
			||||||
		DEPFLAG='-DOPENSSL_NO_DEPRECATED $(DEPFLAG)'	\
 | 
					 | 
				
			||||||
		MAKEDEPPROG='$(MAKEDEPPROG)'			\
 | 
					 | 
				
			||||||
		SHARED_LDFLAGS='$(SHARED_LDFLAGS)'		\
 | 
					 | 
				
			||||||
		KRB5_INCLUDES='$(KRB5_INCLUDES)' LIBKRB5='$(LIBKRB5)'	\
 | 
					 | 
				
			||||||
		ZLIB_INCLUDE='$(ZLIB_INCLUDE)' LIBZLIB='$(LIBZLIB)'	\
 | 
					 | 
				
			||||||
		EXE_EXT='$(EXE_EXT)' SHARED_LIBS='$(SHARED_LIBS)'	\
 | 
					 | 
				
			||||||
		SHLIB_EXT='$(SHLIB_EXT)' SHLIB_TARGET='$(SHLIB_TARGET)'	\
 | 
					 | 
				
			||||||
		PEX_LIBS='$(PEX_LIBS)' EX_LIBS='$(EX_LIBS)'	\
 | 
					 | 
				
			||||||
		CPUID_OBJ='$(CPUID_OBJ)'			\
 | 
					 | 
				
			||||||
		BN_ASM='$(BN_ASM)' DES_ENC='$(DES_ENC)' 	\
 | 
					 | 
				
			||||||
		AES_ENC='$(AES_ENC)' CMLL_ENC='$(CMLL_ENC)'	\
 | 
					 | 
				
			||||||
		BF_ENC='$(BF_ENC)' CAST_ENC='$(CAST_ENC)'	\
 | 
					 | 
				
			||||||
		RC4_ENC='$(RC4_ENC)' RC5_ENC='$(RC5_ENC)'	\
 | 
					 | 
				
			||||||
		SHA1_ASM_OBJ='$(SHA1_ASM_OBJ)'			\
 | 
					 | 
				
			||||||
		MD5_ASM_OBJ='$(MD5_ASM_OBJ)'			\
 | 
					 | 
				
			||||||
		RMD160_ASM_OBJ='$(RMD160_ASM_OBJ)'		\
 | 
					 | 
				
			||||||
		WP_ASM_OBJ='$(WP_ASM_OBJ)'			\
 | 
					 | 
				
			||||||
		MODES_ASM_OBJ='$(MODES_ASM_OBJ)'		\
 | 
					 | 
				
			||||||
		PERLASM_SCHEME='$(PERLASM_SCHEME)'		\
 | 
					 | 
				
			||||||
		FIPSLIBDIR='${FIPSLIBDIR}'			\
 | 
					 | 
				
			||||||
		FIPSCANLIB="$${FIPSCANLIB:-$(FIPSCANLIB)}"	\
 | 
					 | 
				
			||||||
		FIPSCANISTERINTERNAL='${FIPSCANISTERINTERNAL}'	\
 | 
					 | 
				
			||||||
		FIPSCANISTERONLY='${FIPSCANISTERONLY}'	\
 | 
					 | 
				
			||||||
		FIPS_EX_OBJ='${FIPS_EX_OBJ}'	\
 | 
					 | 
				
			||||||
		THIS=$${THIS:-$@} MAKEFILE=Makefile MAKEOVERRIDES=
 | 
					 | 
				
			||||||
# MAKEOVERRIDES= effectively "equalizes" GNU-ish and SysV-ish make flavors,
 | 
					 | 
				
			||||||
# which in turn eliminates ambiguities in variable treatment with -e.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# BUILD_CMD is a generic macro to build a given target in a given
 | 
					 | 
				
			||||||
# subdirectory.  The target must be given through the shell variable
 | 
					 | 
				
			||||||
# `target' and the subdirectory to build in must be given through `dir'.
 | 
					 | 
				
			||||||
# This macro shouldn't be used directly, use RECURSIVE_BUILD_CMD or
 | 
					 | 
				
			||||||
# BUILD_ONE_CMD instead.
 | 
					 | 
				
			||||||
#
 | 
					 | 
				
			||||||
# BUILD_ONE_CMD is a macro to build a given target in a given
 | 
					 | 
				
			||||||
# subdirectory if that subdirectory is part of $(DIRS).  It requires
 | 
					 | 
				
			||||||
# exactly the same shell variables as BUILD_CMD.
 | 
					 | 
				
			||||||
#
 | 
					 | 
				
			||||||
# RECURSIVE_BUILD_CMD is a macro to build a given target in all
 | 
					 | 
				
			||||||
# subdirectories defined in $(DIRS).  It requires that the target
 | 
					 | 
				
			||||||
# is given through the shell variable `target'.
 | 
					 | 
				
			||||||
BUILD_CMD=  if [ -d "$$dir" ]; then \
 | 
					 | 
				
			||||||
	    (	cd $$dir && echo "making $$target in $$dir..." && \
 | 
					 | 
				
			||||||
		$(CLEARENV) && $(MAKE) -e $(BUILDENV) TOP=.. DIR=$$dir $$target \
 | 
					 | 
				
			||||||
	    ) || exit 1; \
 | 
					 | 
				
			||||||
	    fi
 | 
					 | 
				
			||||||
RECURSIVE_BUILD_CMD=for dir in $(DIRS); do $(BUILD_CMD); done
 | 
					 | 
				
			||||||
BUILD_ONE_CMD=\
 | 
					 | 
				
			||||||
	if expr " $(DIRS) " : ".* $$dir " >/dev/null 2>&1; then \
 | 
					 | 
				
			||||||
		$(BUILD_CMD); \
 | 
					 | 
				
			||||||
	fi
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
reflect:
 | 
					 | 
				
			||||||
	@[ -n "$(THIS)" ] && $(CLEARENV) && $(MAKE) $(THIS) -e $(BUILDENV)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
FIPS_EX_OBJ= ../crypto/aes/aes_cfb.o \
 | 
					 | 
				
			||||||
	../crypto/aes/aes_ecb.o \
 | 
					 | 
				
			||||||
	../crypto/aes/aes_ofb.o \
 | 
					 | 
				
			||||||
	../crypto/bn/bn_add.o \
 | 
					 | 
				
			||||||
	../crypto/bn/bn_blind.o \
 | 
					 | 
				
			||||||
	../crypto/bn/bn_ctx.o \
 | 
					 | 
				
			||||||
	../crypto/bn/bn_div.o \
 | 
					 | 
				
			||||||
	../crypto/bn/bn_exp2.o \
 | 
					 | 
				
			||||||
	../crypto/bn/bn_exp.o \
 | 
					 | 
				
			||||||
	../crypto/bn/bn_gcd.o \
 | 
					 | 
				
			||||||
	../crypto/bn/bn_gf2m.o \
 | 
					 | 
				
			||||||
	../crypto/bn/bn_lib.o \
 | 
					 | 
				
			||||||
	../crypto/bn/bn_mod.o \
 | 
					 | 
				
			||||||
	../crypto/bn/bn_mont.o \
 | 
					 | 
				
			||||||
	../crypto/bn/bn_mul.o \
 | 
					 | 
				
			||||||
	../crypto/bn/bn_nist.o \
 | 
					 | 
				
			||||||
	../crypto/bn/bn_prime.o \
 | 
					 | 
				
			||||||
	../crypto/bn/bn_rand.o \
 | 
					 | 
				
			||||||
	../crypto/bn/bn_recp.o \
 | 
					 | 
				
			||||||
	../crypto/bn/bn_shift.o \
 | 
					 | 
				
			||||||
	../crypto/bn/bn_sqr.o \
 | 
					 | 
				
			||||||
	../crypto/bn/bn_word.o \
 | 
					 | 
				
			||||||
	../crypto/bn/bn_x931p.o \
 | 
					 | 
				
			||||||
	../crypto/buffer/buf_str.o \
 | 
					 | 
				
			||||||
	../crypto/cmac/cmac.o \
 | 
					 | 
				
			||||||
	../crypto/cryptlib.o \
 | 
					 | 
				
			||||||
	../crypto/des/cfb64ede.o \
 | 
					 | 
				
			||||||
	../crypto/des/cfb64enc.o \
 | 
					 | 
				
			||||||
	../crypto/des/cfb_enc.o \
 | 
					 | 
				
			||||||
	../crypto/des/ecb3_enc.o \
 | 
					 | 
				
			||||||
	../crypto/des/ofb64ede.o \
 | 
					 | 
				
			||||||
	../crypto/des/fcrypt.o \
 | 
					 | 
				
			||||||
	../crypto/des/set_key.o \
 | 
					 | 
				
			||||||
	../crypto/dh/dh_check.o \
 | 
					 | 
				
			||||||
	../crypto/dh/dh_gen.o \
 | 
					 | 
				
			||||||
	../crypto/dh/dh_key.o \
 | 
					 | 
				
			||||||
	../crypto/dsa/dsa_gen.o \
 | 
					 | 
				
			||||||
	../crypto/dsa/dsa_key.o \
 | 
					 | 
				
			||||||
	../crypto/dsa/dsa_ossl.o \
 | 
					 | 
				
			||||||
	../crypto/ec/ec_curve.o \
 | 
					 | 
				
			||||||
	../crypto/ec/ec_cvt.o \
 | 
					 | 
				
			||||||
	../crypto/ec/ec_key.o \
 | 
					 | 
				
			||||||
	../crypto/ec/ec_lib.o \
 | 
					 | 
				
			||||||
	../crypto/ec/ecp_mont.o \
 | 
					 | 
				
			||||||
	../crypto/ec/ec_mult.o \
 | 
					 | 
				
			||||||
	../crypto/ec/ecp_nist.o \
 | 
					 | 
				
			||||||
	../crypto/ec/ecp_smpl.o \
 | 
					 | 
				
			||||||
	../crypto/ec/ec2_mult.o \
 | 
					 | 
				
			||||||
	../crypto/ec/ec2_smpl.o \
 | 
					 | 
				
			||||||
	../crypto/ecdh/ech_key.o \
 | 
					 | 
				
			||||||
	../crypto/ecdh/ech_ossl.o \
 | 
					 | 
				
			||||||
	../crypto/ecdsa/ecs_ossl.o \
 | 
					 | 
				
			||||||
	../crypto/evp/e_aes.o \
 | 
					 | 
				
			||||||
	../crypto/evp/e_des3.o \
 | 
					 | 
				
			||||||
	../crypto/evp/e_null.o \
 | 
					 | 
				
			||||||
	../crypto/evp/m_sha1.o \
 | 
					 | 
				
			||||||
	../crypto/evp/m_dss1.o \
 | 
					 | 
				
			||||||
	../crypto/evp/m_dss.o \
 | 
					 | 
				
			||||||
	../crypto/evp/m_ecdsa.o \
 | 
					 | 
				
			||||||
	../crypto/hmac/hmac.o \
 | 
					 | 
				
			||||||
	../crypto/modes/cbc128.o \
 | 
					 | 
				
			||||||
	../crypto/modes/ccm128.o \
 | 
					 | 
				
			||||||
	../crypto/modes/cfb128.o \
 | 
					 | 
				
			||||||
	../crypto/modes/ctr128.o \
 | 
					 | 
				
			||||||
	../crypto/modes/gcm128.o \
 | 
					 | 
				
			||||||
	../crypto/modes/ofb128.o \
 | 
					 | 
				
			||||||
	../crypto/modes/xts128.o \
 | 
					 | 
				
			||||||
	../crypto/rsa/rsa_eay.o \
 | 
					 | 
				
			||||||
	../crypto/rsa/rsa_gen.o \
 | 
					 | 
				
			||||||
	../crypto/rsa/rsa_crpt.o \
 | 
					 | 
				
			||||||
	../crypto/rsa/rsa_none.o \
 | 
					 | 
				
			||||||
	../crypto/rsa/rsa_oaep.o \
 | 
					 | 
				
			||||||
	../crypto/rsa/rsa_pk1.o \
 | 
					 | 
				
			||||||
	../crypto/rsa/rsa_pss.o \
 | 
					 | 
				
			||||||
	../crypto/rsa/rsa_ssl.o \
 | 
					 | 
				
			||||||
	../crypto/rsa/rsa_x931.o \
 | 
					 | 
				
			||||||
	../crypto/rsa/rsa_x931g.o \
 | 
					 | 
				
			||||||
	../crypto/sha/sha1dgst.o \
 | 
					 | 
				
			||||||
	../crypto/sha/sha256.o \
 | 
					 | 
				
			||||||
	../crypto/sha/sha512.o \
 | 
					 | 
				
			||||||
	../crypto/thr_id.o \
 | 
					 | 
				
			||||||
	../crypto/uid.o
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
sub_all: build_all
 | 
					 | 
				
			||||||
build_all: build_libs
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
build_libs: build_crypto build_fips
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
build_fips:
 | 
					 | 
				
			||||||
	@dir=fips; target=all; [ -z "$(FIPSCANLIB)" ] || $(BUILD_ONE_CMD)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
build_crypto:
 | 
					 | 
				
			||||||
	if [ -n "$(FIPSCANLIB)" ]; then \
 | 
					 | 
				
			||||||
		EXCL_OBJ='$(AES_ENC) $(BN_ASM) $(DES_ENC) $(CPUID_OBJ) $(SHA1_ASM_OBJ) $(MODES_ASM_OBJ) $(FIPS_EX_OBJ)' ; export EXCL_OBJ ; \
 | 
					 | 
				
			||||||
		ARX='$(PERL) $${TOP}/util/arx.pl $(AR)' ; \
 | 
					 | 
				
			||||||
	else \
 | 
					 | 
				
			||||||
		ARX='${AR}' ; \
 | 
					 | 
				
			||||||
	fi ; export ARX ; \
 | 
					 | 
				
			||||||
	if [ $(FIPSCANISTERINTERNAL) = "y" ]; then \
 | 
					 | 
				
			||||||
		AS='$(PERL) $${TOP}/util/fipsas.pl $${TOP} $${<} $(CC)' ; \
 | 
					 | 
				
			||||||
	else \
 | 
					 | 
				
			||||||
		AS='$(CC) -c' ; \
 | 
					 | 
				
			||||||
	fi ; export AS ; \
 | 
					 | 
				
			||||||
		dir=crypto; target=fips; $(BUILD_ONE_CMD)
 | 
					 | 
				
			||||||
build_ssl:
 | 
					 | 
				
			||||||
	@dir=ssl; target=all; $(BUILD_ONE_CMD)
 | 
					 | 
				
			||||||
build_engines:
 | 
					 | 
				
			||||||
	@dir=engines; target=all; $(BUILD_ONE_CMD)
 | 
					 | 
				
			||||||
build_apps:
 | 
					 | 
				
			||||||
	@dir=apps; target=all; $(BUILD_ONE_CMD)
 | 
					 | 
				
			||||||
build_tests:
 | 
					 | 
				
			||||||
	@dir=test; target=fipsexe; $(BUILD_ONE_CMD)
 | 
					 | 
				
			||||||
build_algvs:
 | 
					 | 
				
			||||||
	@dir=test; target=fipsalgvs; $(BUILD_ONE_CMD)
 | 
					 | 
				
			||||||
build_tools:
 | 
					 | 
				
			||||||
	@dir=tools; target=all; $(BUILD_ONE_CMD)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
all_testapps: build_libs build_testapps
 | 
					 | 
				
			||||||
build_testapps:
 | 
					 | 
				
			||||||
	@dir=crypto; target=testapps; $(BUILD_ONE_CMD)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
libcrypto$(SHLIB_EXT): libcrypto.a build_fips
 | 
					 | 
				
			||||||
	@if [ "$(SHLIB_TARGET)" != "" ]; then \
 | 
					 | 
				
			||||||
		if [ "$(FIPSCANLIB)" = "libcrypto" ]; then \
 | 
					 | 
				
			||||||
			FIPSLD_CC="$(CC)"; CC=fips/fipsld; \
 | 
					 | 
				
			||||||
			export CC FIPSLD_CC; \
 | 
					 | 
				
			||||||
		fi; \
 | 
					 | 
				
			||||||
		$(MAKE) SHLIBDIRS=crypto build-shared; \
 | 
					 | 
				
			||||||
	else \
 | 
					 | 
				
			||||||
		echo "There's no support for shared libraries on this platform" >&2; \
 | 
					 | 
				
			||||||
		exit 1; \
 | 
					 | 
				
			||||||
	fi
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
libssl$(SHLIB_EXT): libcrypto$(SHLIB_EXT) libssl.a
 | 
					 | 
				
			||||||
	@if [ "$(SHLIB_TARGET)" != "" ]; then \
 | 
					 | 
				
			||||||
		$(MAKE) SHLIBDIRS=ssl SHLIBDEPS='-lcrypto' build-shared; \
 | 
					 | 
				
			||||||
	else \
 | 
					 | 
				
			||||||
		echo "There's no support for shared libraries on this platform" >&2; \
 | 
					 | 
				
			||||||
		exit 1; \
 | 
					 | 
				
			||||||
	fi
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
clean-shared:
 | 
					 | 
				
			||||||
	@set -e; for i in $(SHLIBDIRS); do \
 | 
					 | 
				
			||||||
		if [ -n "$(SHARED_LIBS_LINK_EXTS)" ]; then \
 | 
					 | 
				
			||||||
			tmp="$(SHARED_LIBS_LINK_EXTS)"; \
 | 
					 | 
				
			||||||
			for j in $${tmp:-x}; do \
 | 
					 | 
				
			||||||
				( set -x; rm -f lib$$i$$j ); \
 | 
					 | 
				
			||||||
			done; \
 | 
					 | 
				
			||||||
		fi; \
 | 
					 | 
				
			||||||
		( set -x; rm -f lib$$i$(SHLIB_EXT) ); \
 | 
					 | 
				
			||||||
		if [ "$(PLATFORM)" = "Cygwin" ]; then \
 | 
					 | 
				
			||||||
			( set -x; rm -f cyg$$i$(SHLIB_EXT) lib$$i$(SHLIB_EXT).a ); \
 | 
					 | 
				
			||||||
		fi; \
 | 
					 | 
				
			||||||
	done
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
link-shared:
 | 
					 | 
				
			||||||
	@ set -e; for i in $(SHLIBDIRS); do \
 | 
					 | 
				
			||||||
		$(MAKE) -f $(HERE)/Makefile.shared -e $(BUILDENV) \
 | 
					 | 
				
			||||||
			LIBNAME=$$i LIBVERSION=$(SHLIB_MAJOR).$(SHLIB_MINOR) \
 | 
					 | 
				
			||||||
			LIBCOMPATVERSIONS=";$(SHLIB_VERSION_HISTORY)" \
 | 
					 | 
				
			||||||
			symlink.$(SHLIB_TARGET); \
 | 
					 | 
				
			||||||
		libs="$$libs -l$$i"; \
 | 
					 | 
				
			||||||
	done
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
build-shared: do_$(SHLIB_TARGET) link-shared
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
do_$(SHLIB_TARGET):
 | 
					 | 
				
			||||||
	@ set -e; libs='-L. $(SHLIBDEPS)'; for i in $(SHLIBDIRS); do \
 | 
					 | 
				
			||||||
		if [ "$$i" = "ssl" -a -n "$(LIBKRB5)" ]; then \
 | 
					 | 
				
			||||||
			libs="$(LIBKRB5) $$libs"; \
 | 
					 | 
				
			||||||
		fi; \
 | 
					 | 
				
			||||||
		$(CLEARENV) && $(MAKE) -f Makefile.shared -e $(BUILDENV) \
 | 
					 | 
				
			||||||
			LIBNAME=$$i LIBVERSION=$(SHLIB_MAJOR).$(SHLIB_MINOR) \
 | 
					 | 
				
			||||||
			LIBCOMPATVERSIONS=";$(SHLIB_VERSION_HISTORY)" \
 | 
					 | 
				
			||||||
			LIBDEPS="$$libs $(EX_LIBS)" \
 | 
					 | 
				
			||||||
			link_a.$(SHLIB_TARGET); \
 | 
					 | 
				
			||||||
		libs="-l$$i $$libs"; \
 | 
					 | 
				
			||||||
	done
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
libcrypto.pc: Makefile
 | 
					 | 
				
			||||||
	@ ( echo 'prefix=$(INSTALLTOP)'; \
 | 
					 | 
				
			||||||
	    echo 'exec_prefix=$${prefix}'; \
 | 
					 | 
				
			||||||
	    echo 'libdir=$${exec_prefix}/$(LIBDIR)'; \
 | 
					 | 
				
			||||||
	    echo 'includedir=$${prefix}/include'; \
 | 
					 | 
				
			||||||
	    echo ''; \
 | 
					 | 
				
			||||||
	    echo 'Name: OpenSSL-libcrypto'; \
 | 
					 | 
				
			||||||
	    echo 'Description: OpenSSL cryptography library'; \
 | 
					 | 
				
			||||||
	    echo 'Version: '$(VERSION); \
 | 
					 | 
				
			||||||
	    echo 'Requires: '; \
 | 
					 | 
				
			||||||
	    echo 'Libs: -L$${libdir} -lcrypto $(EX_LIBS)'; \
 | 
					 | 
				
			||||||
	    echo 'Cflags: -I$${includedir} $(KRB5_INCLUDES)' ) > libcrypto.pc
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
libssl.pc: Makefile
 | 
					 | 
				
			||||||
	@ ( echo 'prefix=$(INSTALLTOP)'; \
 | 
					 | 
				
			||||||
	    echo 'exec_prefix=$${prefix}'; \
 | 
					 | 
				
			||||||
	    echo 'libdir=$${exec_prefix}/$(LIBDIR)'; \
 | 
					 | 
				
			||||||
	    echo 'includedir=$${prefix}/include'; \
 | 
					 | 
				
			||||||
	    echo ''; \
 | 
					 | 
				
			||||||
	    echo 'Name: OpenSSL'; \
 | 
					 | 
				
			||||||
	    echo 'Description: Secure Sockets Layer and cryptography libraries'; \
 | 
					 | 
				
			||||||
	    echo 'Version: '$(VERSION); \
 | 
					 | 
				
			||||||
	    echo 'Requires: '; \
 | 
					 | 
				
			||||||
	    echo 'Libs: -L$${libdir} -lssl -lcrypto $(EX_LIBS)'; \
 | 
					 | 
				
			||||||
	    echo 'Cflags: -I$${includedir} $(KRB5_INCLUDES)' ) > libssl.pc
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
openssl.pc: Makefile
 | 
					 | 
				
			||||||
	@ ( echo 'prefix=$(INSTALLTOP)'; \
 | 
					 | 
				
			||||||
	    echo 'exec_prefix=$${prefix}'; \
 | 
					 | 
				
			||||||
	    echo 'libdir=$${exec_prefix}/$(LIBDIR)'; \
 | 
					 | 
				
			||||||
	    echo 'includedir=$${prefix}/include'; \
 | 
					 | 
				
			||||||
	    echo ''; \
 | 
					 | 
				
			||||||
	    echo 'Name: OpenSSL'; \
 | 
					 | 
				
			||||||
	    echo 'Description: Secure Sockets Layer and cryptography libraries and tools'; \
 | 
					 | 
				
			||||||
	    echo 'Version: '$(VERSION); \
 | 
					 | 
				
			||||||
	    echo 'Requires: '; \
 | 
					 | 
				
			||||||
	    echo 'Libs: -L$${libdir} -lssl -lcrypto $(EX_LIBS)'; \
 | 
					 | 
				
			||||||
	    echo 'Cflags: -I$${includedir} $(KRB5_INCLUDES)' ) > openssl.pc
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
Makefile: Makefile.fips Configure config
 | 
					 | 
				
			||||||
	@echo "Makefile is older than Makefile.org, Configure or config."
 | 
					 | 
				
			||||||
	@echo "Reconfigure the source tree (via './config' or 'perl Configure'), please."
 | 
					 | 
				
			||||||
	@false
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
libclean:
 | 
					 | 
				
			||||||
	rm -f *.map *.so *.so.* *.dll engines/*.so engines/*.dll *.a engines/*.a */lib */*/lib
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
clean:	libclean
 | 
					 | 
				
			||||||
	rm -f shlib/*.o *.o core a.out fluff testlog make.log cctest cctest.c
 | 
					 | 
				
			||||||
	@set -e; target=clean; $(RECURSIVE_BUILD_CMD)
 | 
					 | 
				
			||||||
	rm -f $(LIBS)
 | 
					 | 
				
			||||||
	rm -f openssl.pc libssl.pc libcrypto.pc
 | 
					 | 
				
			||||||
	rm -f speed.* .pure
 | 
					 | 
				
			||||||
	rm -f $(TARFILE)
 | 
					 | 
				
			||||||
	@set -e; for i in $(ONEDIRS) ;\
 | 
					 | 
				
			||||||
	do \
 | 
					 | 
				
			||||||
	rm -fr $$i/*; \
 | 
					 | 
				
			||||||
	done
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
makefile.one: files
 | 
					 | 
				
			||||||
	$(PERL) util/mk1mf.pl >makefile.one; \
 | 
					 | 
				
			||||||
	sh util/do_ms.sh
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
files:
 | 
					 | 
				
			||||||
	$(PERL) $(TOP)/util/files.pl Makefile > $(TOP)/MINFO
 | 
					 | 
				
			||||||
	@set -e; target=files; $(RECURSIVE_BUILD_CMD)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
links:
 | 
					 | 
				
			||||||
	@$(PERL) $(TOP)/util/mkdir-p.pl include/openssl
 | 
					 | 
				
			||||||
	@$(PERL) $(TOP)/util/mklink.pl include/openssl $(EXHEADER)
 | 
					 | 
				
			||||||
	@set -e; dir=fips target=links; $(RECURSIVE_BUILD_CMD)
 | 
					 | 
				
			||||||
	@(cd crypto ; SDIRS='$(LINKDIRS)' $(MAKE) -e links)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
gentests:
 | 
					 | 
				
			||||||
	@(cd test && echo "generating dummy tests (if needed)..." && \
 | 
					 | 
				
			||||||
	$(CLEARENV) && $(MAKE) -e $(BUILDENV) TESTS='$(TESTS)' OPENSSL_DEBUG_MEMORY=on generate );
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
dclean:
 | 
					 | 
				
			||||||
	rm -rf *.bak include/openssl certs/.0
 | 
					 | 
				
			||||||
	@set -e; target=dclean; $(RECURSIVE_BUILD_CMD)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
test:   tests
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
tests:
 | 
					 | 
				
			||||||
	@echo "Not implemented in FIPS build" ; false
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
report:
 | 
					 | 
				
			||||||
	@$(PERL) util/selftest.pl
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
depend:
 | 
					 | 
				
			||||||
	@echo make depend not supported ; false
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
lint:
 | 
					 | 
				
			||||||
	@set -e; target=lint; $(RECURSIVE_BUILD_CMD)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
tags:
 | 
					 | 
				
			||||||
	rm -f TAGS
 | 
					 | 
				
			||||||
	find . -name '[^.]*.[ch]' | xargs etags -a
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
errors:
 | 
					 | 
				
			||||||
	$(PERL) util/mkerr.pl -recurse -write
 | 
					 | 
				
			||||||
	(cd engines; $(MAKE) PERL=$(PERL) errors)
 | 
					 | 
				
			||||||
	$(PERL) util/ck_errf.pl -strict */*.c */*/*.c
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
stacks:
 | 
					 | 
				
			||||||
	$(PERL) util/mkstack.pl -write
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
util/libeay.num::
 | 
					 | 
				
			||||||
	$(PERL) util/mkdef.pl crypto update
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
util/ssleay.num::
 | 
					 | 
				
			||||||
	$(PERL) util/mkdef.pl ssl update
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
crypto/objects/obj_dat.h: crypto/objects/obj_dat.pl crypto/objects/obj_mac.h
 | 
					 | 
				
			||||||
	$(PERL) crypto/objects/obj_dat.pl crypto/objects/obj_mac.h crypto/objects/obj_dat.h
 | 
					 | 
				
			||||||
crypto/objects/obj_mac.h: crypto/objects/objects.pl crypto/objects/objects.txt crypto/objects/obj_mac.num
 | 
					 | 
				
			||||||
	$(PERL) crypto/objects/objects.pl crypto/objects/objects.txt crypto/objects/obj_mac.num crypto/objects/obj_mac.h
 | 
					 | 
				
			||||||
crypto/objects/obj_xref.h: crypto/objects/objxref.pl crypto/objects/obj_xref.txt crypto/objects/obj_mac.num
 | 
					 | 
				
			||||||
	$(PERL) crypto/objects/objxref.pl crypto/objects/obj_mac.num crypto/objects/obj_xref.txt >crypto/objects/obj_xref.h
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
apps/openssl-vms.cnf: apps/openssl.cnf
 | 
					 | 
				
			||||||
	$(PERL) VMS/VMSify-conf.pl < apps/openssl.cnf > apps/openssl-vms.cnf
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
crypto/bn/bn_prime.h: crypto/bn/bn_prime.pl
 | 
					 | 
				
			||||||
	$(PERL) crypto/bn/bn_prime.pl >crypto/bn/bn_prime.h
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
TABLE: Configure
 | 
					 | 
				
			||||||
	(echo 'Output of `Configure TABLE'"':"; \
 | 
					 | 
				
			||||||
	$(PERL) Configure TABLE) > TABLE
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
update: errors stacks util/libeay.num util/ssleay.num crypto/objects/obj_dat.h crypto/objects/obj_xref.h apps/openssl-vms.cnf crypto/bn/bn_prime.h TABLE depend
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# Build distribution tar-file. As the list of files returned by "find" is
 | 
					 | 
				
			||||||
# pretty long, on several platforms a "too many arguments" error or similar
 | 
					 | 
				
			||||||
# would occur. Therefore the list of files is temporarily stored into a file
 | 
					 | 
				
			||||||
# and read directly, requiring GNU-Tar. Call "make TAR=gtar dist" if the normal
 | 
					 | 
				
			||||||
# tar does not support the --files-from option.
 | 
					 | 
				
			||||||
tar:
 | 
					 | 
				
			||||||
	find . -type d -print | xargs chmod 755
 | 
					 | 
				
			||||||
	find . -type f -print | xargs chmod a+r
 | 
					 | 
				
			||||||
	find . -type f -perm -0100 -print | xargs chmod a+x
 | 
					 | 
				
			||||||
	find * \! -path CVS/\* \! -path \*/CVS/\* \! -name CVS \! -name .cvsignore \! -name STATUS \! -name TABLE | $(BUILDENV) LINKDIRS='$(LINKDIRS)' $(PERL) util/fipsdist.pl | sort > ../$(TARFILE).list; \
 | 
					 | 
				
			||||||
	$(TAR) $(TARFLAGS) --files-from ../$(TARFILE).list -cvf - | \
 | 
					 | 
				
			||||||
	tardy --user_number=0  --user_name=openssl \
 | 
					 | 
				
			||||||
	      --group_number=0 --group_name=openssl \
 | 
					 | 
				
			||||||
	      --prefix=openssl-$(VERSION) - |\
 | 
					 | 
				
			||||||
	gzip --best >../$(TARFILE).gz; \
 | 
					 | 
				
			||||||
	rm -f ../$(TARFILE).list; \
 | 
					 | 
				
			||||||
	ls -l ../$(TARFILE).gz
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
tar-snap:
 | 
					 | 
				
			||||||
	@$(TAR) $(TARFLAGS) -cvf - \
 | 
					 | 
				
			||||||
		`find * \! -path CVS/\* \! -path \*/CVS/\* \! -name CVS \! -name .cvsignore \! -name STATUS \! -name TABLE \! -name '*.o' \! -name '*.a' \! -name '*.so' \! -name '*.so.*'  \! -name 'openssl' \! -name '*test' \! -name '.#*' \! -name '*~' | sort` |\
 | 
					 | 
				
			||||||
	tardy --user_number=0  --user_name=openssl \
 | 
					 | 
				
			||||||
	      --group_number=0 --group_name=openssl \
 | 
					 | 
				
			||||||
	      --prefix=openssl-$(VERSION) - > ../$(TARFILE);\
 | 
					 | 
				
			||||||
	ls -l ../$(TARFILE)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
dist:   
 | 
					 | 
				
			||||||
	$(PERL) Configure dist fipscanisteronly
 | 
					 | 
				
			||||||
	@$(MAKE) dist_pem_h
 | 
					 | 
				
			||||||
	@$(MAKE) SDIRS='$(SDIRS)' clean
 | 
					 | 
				
			||||||
	@$(MAKE) -f Makefile.fips TAR='$(TAR)' TARFLAGS='$(TARFLAGS)' tar
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
dist_pem_h:
 | 
					 | 
				
			||||||
	(cd crypto/pem; $(MAKE) -e $(BUILDENV) pem.h; $(MAKE) clean)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
install: all install_sw
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
install_sw:
 | 
					 | 
				
			||||||
	@$(PERL) $(TOP)/util/mkdir-p.pl $(INSTALL_PREFIX)$(INSTALLTOP)/bin \
 | 
					 | 
				
			||||||
		$(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR) \
 | 
					 | 
				
			||||||
		$(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl
 | 
					 | 
				
			||||||
	@set -e; headerlist="$(EXHEADER)"; for i in $$headerlist;\
 | 
					 | 
				
			||||||
	do \
 | 
					 | 
				
			||||||
	(cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$i; \
 | 
					 | 
				
			||||||
	chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$i ); \
 | 
					 | 
				
			||||||
	done;
 | 
					 | 
				
			||||||
	@set -e; target=install; $(RECURSIVE_BUILD_CMD)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# DO NOT DELETE THIS LINE -- make depend depends on it.
 | 
					 | 
				
			||||||
							
								
								
									
										232
									
								
								Makefile.org
									
									
									
									
									
								
							
							
						
						
									
										232
									
								
								Makefile.org
									
									
									
									
									
								
							@@ -71,14 +71,13 @@ PERL= perl
 | 
				
			|||||||
TAR= tar
 | 
					TAR= tar
 | 
				
			||||||
TARFLAGS= --no-recursion
 | 
					TARFLAGS= --no-recursion
 | 
				
			||||||
MAKEDEPPROG=makedepend
 | 
					MAKEDEPPROG=makedepend
 | 
				
			||||||
LIBDIR=lib
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
# We let the C compiler driver to take care of .s files. This is done in
 | 
					# We let the C compiler driver to take care of .s files. This is done in
 | 
				
			||||||
# order to be excused from maintaining a separate set of architecture
 | 
					# order to be excused from maintaining a separate set of architecture
 | 
				
			||||||
# dependent assembler flags. E.g. if you throw -mcpu=ultrasparc at SPARC
 | 
					# dependent assembler flags. E.g. if you throw -mcpu=ultrasparc at SPARC
 | 
				
			||||||
# gcc, then the driver will automatically translate it to -xarch=v8plus
 | 
					# gcc, then the driver will automatically translate it to -xarch=v8plus
 | 
				
			||||||
# and pass it down to assembler.
 | 
					# and pass it down to assembler.
 | 
				
			||||||
#AS=$(CC) -c
 | 
					AS=$(CC) -c
 | 
				
			||||||
ASFLAG=$(CFLAG)
 | 
					ASFLAG=$(CFLAG)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# For x86 assembler: Set PROCESSOR to 386 if you want to support
 | 
					# For x86 assembler: Set PROCESSOR to 386 if you want to support
 | 
				
			||||||
@@ -99,8 +98,6 @@ SHA1_ASM_OBJ=
 | 
				
			|||||||
RMD160_ASM_OBJ= 
 | 
					RMD160_ASM_OBJ= 
 | 
				
			||||||
WP_ASM_OBJ=
 | 
					WP_ASM_OBJ=
 | 
				
			||||||
CMLL_ENC=
 | 
					CMLL_ENC=
 | 
				
			||||||
MODES_ASM_OBJ=
 | 
					 | 
				
			||||||
ENGINES_ASM_OBJ=
 | 
					 | 
				
			||||||
PERLASM_SCHEME=
 | 
					PERLASM_SCHEME=
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# KRB5 stuff
 | 
					# KRB5 stuff
 | 
				
			||||||
@@ -111,34 +108,7 @@ LIBKRB5=
 | 
				
			|||||||
ZLIB_INCLUDE=
 | 
					ZLIB_INCLUDE=
 | 
				
			||||||
LIBZLIB=
 | 
					LIBZLIB=
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# This is the location of fipscanister.o and friends.
 | 
					DIRS=   crypto ssl engines apps test tools
 | 
				
			||||||
# The FIPS module build will place it $(INSTALLTOP)/lib
 | 
					 | 
				
			||||||
# but since $(INSTALLTOP) can only take the default value
 | 
					 | 
				
			||||||
# when the module is built it will be in /usr/local/ssl/lib
 | 
					 | 
				
			||||||
# $(INSTALLTOP) for this build may be different so hard
 | 
					 | 
				
			||||||
# code the path.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
FIPSLIBDIR=/usr/local/ssl/$(LIBDIR)/
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# This is set to "y" if fipscanister.o is compiled internally as
 | 
					 | 
				
			||||||
# opposed to coming from an external validated location.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
FIPSCANISTERINTERNAL=n
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# The location of the library which contains fipscanister.o
 | 
					 | 
				
			||||||
# normally it will be libcrypto unless fipsdso is set in which
 | 
					 | 
				
			||||||
# case it will be libfips. If not compiling in FIPS mode at all
 | 
					 | 
				
			||||||
# this is empty making it a useful test for a FIPS compile.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
FIPSCANLIB=
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# Shared library base address. Currently only used on Windows.
 | 
					 | 
				
			||||||
#
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
BASEADDR=
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
DIRS=   crypto fips ssl engines apps test tools
 | 
					 | 
				
			||||||
ENGDIRS= ccgost
 | 
					 | 
				
			||||||
SHLIBDIRS= crypto ssl
 | 
					SHLIBDIRS= crypto ssl
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# dirs in crypto to build
 | 
					# dirs in crypto to build
 | 
				
			||||||
@@ -149,7 +119,7 @@ SDIRS=  \
 | 
				
			|||||||
	bn ec rsa dsa ecdsa dh ecdh dso engine \
 | 
						bn ec rsa dsa ecdsa dh ecdh dso engine \
 | 
				
			||||||
	buffer bio stack lhash rand err \
 | 
						buffer bio stack lhash rand err \
 | 
				
			||||||
	evp asn1 pem x509 x509v3 conf txt_db pkcs7 pkcs12 comp ocsp ui krb5 \
 | 
						evp asn1 pem x509 x509v3 conf txt_db pkcs7 pkcs12 comp ocsp ui krb5 \
 | 
				
			||||||
	cms pqueue ts jpake srp store cmac
 | 
						cms pqueue ts jpake store
 | 
				
			||||||
# keep in mind that the above list is adjusted by ./Configure
 | 
					# keep in mind that the above list is adjusted by ./Configure
 | 
				
			||||||
# according to no-xxx arguments...
 | 
					# according to no-xxx arguments...
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -206,20 +176,18 @@ CLEARENV=	TOP= && unset TOP $${LIB+LIB} $${LIBS+LIBS}	\
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
BUILDENV=	PLATFORM='$(PLATFORM)' PROCESSOR='$(PROCESSOR)' \
 | 
					BUILDENV=	PLATFORM='$(PLATFORM)' PROCESSOR='$(PROCESSOR)' \
 | 
				
			||||||
		CC='$(CC)' CFLAG='$(CFLAG)' 			\
 | 
							CC='$(CC)' CFLAG='$(CFLAG)' 			\
 | 
				
			||||||
		ASFLAG='$(CFLAG) -c'			\
 | 
							AS='$(CC)' ASFLAG='$(CFLAG) -c'			\
 | 
				
			||||||
		AR='$(AR)' NM='$(NM)' RANLIB='$(RANLIB)'	\
 | 
							AR='$(AR)' NM='$(NM)' RANLIB='$(RANLIB)'	\
 | 
				
			||||||
		CROSS_COMPILE='$(CROSS_COMPILE)'	\
 | 
							CROSS_COMPILE_PREFIX='$(CROSS_COMPILE_PREFIX)'	\
 | 
				
			||||||
		PERL='$(PERL)' ENGDIRS='$(ENGDIRS)'		\
 | 
							PERL='$(PERL)'					\
 | 
				
			||||||
		SDIRS='$(SDIRS)' LIBRPATH='$(INSTALLTOP)/$(LIBDIR)'	\
 | 
							SDIRS='$(SDIRS)' LIBRPATH='$(INSTALLTOP)/lib'	\
 | 
				
			||||||
		INSTALL_PREFIX='$(INSTALL_PREFIX)'		\
 | 
							INSTALL_PREFIX='$(INSTALL_PREFIX)'		\
 | 
				
			||||||
		INSTALLTOP='$(INSTALLTOP)' OPENSSLDIR='$(OPENSSLDIR)'	\
 | 
							INSTALLTOP='$(INSTALLTOP)' OPENSSLDIR='$(OPENSSLDIR)'	\
 | 
				
			||||||
		LIBDIR='$(LIBDIR)'				\
 | 
					 | 
				
			||||||
		MAKEDEPEND='$$$${TOP}/util/domd $$$${TOP} -MD $(MAKEDEPPROG)' \
 | 
							MAKEDEPEND='$$$${TOP}/util/domd $$$${TOP} -MD $(MAKEDEPPROG)' \
 | 
				
			||||||
		DEPFLAG='-DOPENSSL_NO_DEPRECATED $(DEPFLAG)'	\
 | 
							DEPFLAG='-DOPENSSL_NO_DEPRECATED $(DEPFLAG)'	\
 | 
				
			||||||
		MAKEDEPPROG='$(MAKEDEPPROG)'			\
 | 
							MAKEDEPPROG='$(MAKEDEPPROG)'			\
 | 
				
			||||||
		SHARED_LDFLAGS='$(SHARED_LDFLAGS)'		\
 | 
							SHARED_LDFLAGS='$(SHARED_LDFLAGS)'		\
 | 
				
			||||||
		KRB5_INCLUDES='$(KRB5_INCLUDES)' LIBKRB5='$(LIBKRB5)'	\
 | 
							KRB5_INCLUDES='$(KRB5_INCLUDES)' LIBKRB5='$(LIBKRB5)'	\
 | 
				
			||||||
		ZLIB_INCLUDE='$(ZLIB_INCLUDE)' LIBZLIB='$(LIBZLIB)'	\
 | 
					 | 
				
			||||||
		EXE_EXT='$(EXE_EXT)' SHARED_LIBS='$(SHARED_LIBS)'	\
 | 
							EXE_EXT='$(EXE_EXT)' SHARED_LIBS='$(SHARED_LIBS)'	\
 | 
				
			||||||
		SHLIB_EXT='$(SHLIB_EXT)' SHLIB_TARGET='$(SHLIB_TARGET)'	\
 | 
							SHLIB_EXT='$(SHLIB_EXT)' SHLIB_TARGET='$(SHLIB_TARGET)'	\
 | 
				
			||||||
		PEX_LIBS='$(PEX_LIBS)' EX_LIBS='$(EX_LIBS)'	\
 | 
							PEX_LIBS='$(PEX_LIBS)' EX_LIBS='$(EX_LIBS)'	\
 | 
				
			||||||
@@ -232,13 +200,7 @@ BUILDENV=	PLATFORM='$(PLATFORM)' PROCESSOR='$(PROCESSOR)' \
 | 
				
			|||||||
		MD5_ASM_OBJ='$(MD5_ASM_OBJ)'			\
 | 
							MD5_ASM_OBJ='$(MD5_ASM_OBJ)'			\
 | 
				
			||||||
		RMD160_ASM_OBJ='$(RMD160_ASM_OBJ)'		\
 | 
							RMD160_ASM_OBJ='$(RMD160_ASM_OBJ)'		\
 | 
				
			||||||
		WP_ASM_OBJ='$(WP_ASM_OBJ)'			\
 | 
							WP_ASM_OBJ='$(WP_ASM_OBJ)'			\
 | 
				
			||||||
		MODES_ASM_OBJ='$(MODES_ASM_OBJ)'		\
 | 
					 | 
				
			||||||
		ENGINES_ASM_OBJ='$(ENGINES_ASM_OBJ)'		\
 | 
					 | 
				
			||||||
		PERLASM_SCHEME='$(PERLASM_SCHEME)'		\
 | 
							PERLASM_SCHEME='$(PERLASM_SCHEME)'		\
 | 
				
			||||||
		FIPSLIBDIR='${FIPSLIBDIR}'			\
 | 
					 | 
				
			||||||
		FIPSCANLIB="$${FIPSCANLIB:-$(FIPSCANLIB)}"	\
 | 
					 | 
				
			||||||
		FIPSCANISTERINTERNAL='${FIPSCANISTERINTERNAL}'	\
 | 
					 | 
				
			||||||
		FIPS_EX_OBJ='${FIPS_EX_OBJ}'	\
 | 
					 | 
				
			||||||
		THIS=$${THIS:-$@} MAKEFILE=Makefile MAKEOVERRIDES=
 | 
							THIS=$${THIS:-$@} MAKEFILE=Makefile MAKEOVERRIDES=
 | 
				
			||||||
# MAKEOVERRIDES= effectively "equalizes" GNU-ish and SysV-ish make flavors,
 | 
					# MAKEOVERRIDES= effectively "equalizes" GNU-ish and SysV-ish make flavors,
 | 
				
			||||||
# which in turn eliminates ambiguities in variable treatment with -e.
 | 
					# which in turn eliminates ambiguities in variable treatment with -e.
 | 
				
			||||||
@@ -270,114 +232,17 @@ BUILD_ONE_CMD=\
 | 
				
			|||||||
reflect:
 | 
					reflect:
 | 
				
			||||||
	@[ -n "$(THIS)" ] && $(CLEARENV) && $(MAKE) $(THIS) -e $(BUILDENV)
 | 
						@[ -n "$(THIS)" ] && $(CLEARENV) && $(MAKE) $(THIS) -e $(BUILDENV)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
FIPS_EX_OBJ= ../crypto/aes/aes_cfb.o \
 | 
					 | 
				
			||||||
	../crypto/aes/aes_ecb.o \
 | 
					 | 
				
			||||||
	../crypto/aes/aes_ofb.o \
 | 
					 | 
				
			||||||
	../crypto/bn/bn_add.o \
 | 
					 | 
				
			||||||
	../crypto/bn/bn_blind.o \
 | 
					 | 
				
			||||||
	../crypto/bn/bn_ctx.o \
 | 
					 | 
				
			||||||
	../crypto/bn/bn_div.o \
 | 
					 | 
				
			||||||
	../crypto/bn/bn_exp2.o \
 | 
					 | 
				
			||||||
	../crypto/bn/bn_exp.o \
 | 
					 | 
				
			||||||
	../crypto/bn/bn_gcd.o \
 | 
					 | 
				
			||||||
	../crypto/bn/bn_gf2m.o \
 | 
					 | 
				
			||||||
	../crypto/bn/bn_lib.o \
 | 
					 | 
				
			||||||
	../crypto/bn/bn_mod.o \
 | 
					 | 
				
			||||||
	../crypto/bn/bn_mont.o \
 | 
					 | 
				
			||||||
	../crypto/bn/bn_mul.o \
 | 
					 | 
				
			||||||
	../crypto/bn/bn_nist.o \
 | 
					 | 
				
			||||||
	../crypto/bn/bn_prime.o \
 | 
					 | 
				
			||||||
	../crypto/bn/bn_rand.o \
 | 
					 | 
				
			||||||
	../crypto/bn/bn_recp.o \
 | 
					 | 
				
			||||||
	../crypto/bn/bn_shift.o \
 | 
					 | 
				
			||||||
	../crypto/bn/bn_sqr.o \
 | 
					 | 
				
			||||||
	../crypto/bn/bn_word.o \
 | 
					 | 
				
			||||||
	../crypto/bn/bn_x931p.o \
 | 
					 | 
				
			||||||
	../crypto/buffer/buf_str.o \
 | 
					 | 
				
			||||||
	../crypto/cmac/cmac.o \
 | 
					 | 
				
			||||||
	../crypto/cryptlib.o \
 | 
					 | 
				
			||||||
	../crypto/des/cfb64ede.o \
 | 
					 | 
				
			||||||
	../crypto/des/cfb64enc.o \
 | 
					 | 
				
			||||||
	../crypto/des/cfb_enc.o \
 | 
					 | 
				
			||||||
	../crypto/des/ecb3_enc.o \
 | 
					 | 
				
			||||||
	../crypto/des/ofb64ede.o \
 | 
					 | 
				
			||||||
	../crypto/des/fcrypt.o \
 | 
					 | 
				
			||||||
	../crypto/des/set_key.o \
 | 
					 | 
				
			||||||
	../crypto/dh/dh_check.o \
 | 
					 | 
				
			||||||
	../crypto/dh/dh_gen.o \
 | 
					 | 
				
			||||||
	../crypto/dh/dh_key.o \
 | 
					 | 
				
			||||||
	../crypto/dsa/dsa_gen.o \
 | 
					 | 
				
			||||||
	../crypto/dsa/dsa_key.o \
 | 
					 | 
				
			||||||
	../crypto/dsa/dsa_ossl.o \
 | 
					 | 
				
			||||||
	../crypto/ec/ec_curve.o \
 | 
					 | 
				
			||||||
	../crypto/ec/ec_cvt.o \
 | 
					 | 
				
			||||||
	../crypto/ec/ec_key.o \
 | 
					 | 
				
			||||||
	../crypto/ec/ec_lib.o \
 | 
					 | 
				
			||||||
	../crypto/ec/ecp_mont.o \
 | 
					 | 
				
			||||||
	../crypto/ec/ec_mult.o \
 | 
					 | 
				
			||||||
	../crypto/ec/ecp_nist.o \
 | 
					 | 
				
			||||||
	../crypto/ec/ecp_smpl.o \
 | 
					 | 
				
			||||||
	../crypto/ec/ec2_mult.o \
 | 
					 | 
				
			||||||
	../crypto/ec/ec2_smpl.o \
 | 
					 | 
				
			||||||
	../crypto/ecdh/ech_key.o \
 | 
					 | 
				
			||||||
	../crypto/ecdh/ech_ossl.o \
 | 
					 | 
				
			||||||
	../crypto/ecdsa/ecs_ossl.o \
 | 
					 | 
				
			||||||
	../crypto/evp/e_aes.o \
 | 
					 | 
				
			||||||
	../crypto/evp/e_des3.o \
 | 
					 | 
				
			||||||
	../crypto/evp/e_null.o \
 | 
					 | 
				
			||||||
	../crypto/evp/m_sha1.o \
 | 
					 | 
				
			||||||
	../crypto/evp/m_dss1.o \
 | 
					 | 
				
			||||||
	../crypto/evp/m_dss.o \
 | 
					 | 
				
			||||||
	../crypto/evp/m_ecdsa.o \
 | 
					 | 
				
			||||||
	../crypto/hmac/hmac.o \
 | 
					 | 
				
			||||||
	../crypto/modes/cbc128.o \
 | 
					 | 
				
			||||||
	../crypto/modes/ccm128.o \
 | 
					 | 
				
			||||||
	../crypto/modes/cfb128.o \
 | 
					 | 
				
			||||||
	../crypto/modes/ctr128.o \
 | 
					 | 
				
			||||||
	../crypto/modes/gcm128.o \
 | 
					 | 
				
			||||||
	../crypto/modes/ofb128.o \
 | 
					 | 
				
			||||||
	../crypto/modes/xts128.o \
 | 
					 | 
				
			||||||
	../crypto/rsa/rsa_eay.o \
 | 
					 | 
				
			||||||
	../crypto/rsa/rsa_gen.o \
 | 
					 | 
				
			||||||
	../crypto/rsa/rsa_crpt.o \
 | 
					 | 
				
			||||||
	../crypto/rsa/rsa_none.o \
 | 
					 | 
				
			||||||
	../crypto/rsa/rsa_oaep.o \
 | 
					 | 
				
			||||||
	../crypto/rsa/rsa_pk1.o \
 | 
					 | 
				
			||||||
	../crypto/rsa/rsa_pss.o \
 | 
					 | 
				
			||||||
	../crypto/rsa/rsa_ssl.o \
 | 
					 | 
				
			||||||
	../crypto/rsa/rsa_x931.o \
 | 
					 | 
				
			||||||
	../crypto/rsa/rsa_x931g.o \
 | 
					 | 
				
			||||||
	../crypto/sha/sha1dgst.o \
 | 
					 | 
				
			||||||
	../crypto/sha/sha256.o \
 | 
					 | 
				
			||||||
	../crypto/sha/sha512.o \
 | 
					 | 
				
			||||||
	../crypto/thr_id.o \
 | 
					 | 
				
			||||||
	../crypto/uid.o
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
sub_all: build_all
 | 
					sub_all: build_all
 | 
				
			||||||
build_all: build_libs build_apps build_tests build_tools
 | 
					build_all: build_libs build_apps build_tests build_tools
 | 
				
			||||||
 | 
					
 | 
				
			||||||
build_libs: build_crypto build_fips build_ssl build_engines
 | 
					build_libs: build_crypto build_ssl build_engines
 | 
				
			||||||
 | 
					 | 
				
			||||||
build_fips:
 | 
					 | 
				
			||||||
	@dir=fips; target=all; [ -z "$(FIPSCANLIB)" ] || $(BUILD_ONE_CMD)
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
build_crypto:
 | 
					build_crypto:
 | 
				
			||||||
	if [ -n "$(FIPSCANLIB)" ]; then \
 | 
						@dir=crypto; target=all; $(BUILD_ONE_CMD)
 | 
				
			||||||
		EXCL_OBJ='$(AES_ENC) $(BN_ASM) $(DES_ENC) $(CPUID_OBJ) $(SHA1_ASM_OBJ) $(MODES_ASM_OBJ) $(FIPS_EX_OBJ)' ; export EXCL_OBJ ; \
 | 
					 | 
				
			||||||
		ARX='$(PERL) $${TOP}/util/arx.pl $(AR)' ; \
 | 
					 | 
				
			||||||
	else \
 | 
					 | 
				
			||||||
		ARX='${AR}' ; \
 | 
					 | 
				
			||||||
	fi ; export ARX ; \
 | 
					 | 
				
			||||||
	if [ $(FIPSCANISTERINTERNAL) = "y" ]; then \
 | 
					 | 
				
			||||||
		AS='$(PERL) $${TOP}/util/fipsas.pl $${TOP} $${<} $(CC) -c' ; \
 | 
					 | 
				
			||||||
	else \
 | 
					 | 
				
			||||||
		AS='$(CC) -c' ; \
 | 
					 | 
				
			||||||
	fi ; export AS ; \
 | 
					 | 
				
			||||||
		dir=crypto; target=all; $(BUILD_ONE_CMD)
 | 
					 | 
				
			||||||
build_ssl:
 | 
					build_ssl:
 | 
				
			||||||
	@dir=ssl; target=all; $(BUILD_ONE_CMD)
 | 
						@dir=ssl; target=all; $(BUILD_ONE_CMD)
 | 
				
			||||||
build_engines:
 | 
					build_engines:
 | 
				
			||||||
	@dir=engines; target=all; AS='$(CC) -c'; export AS; $(BUILD_ONE_CMD)
 | 
						@dir=engines; target=all; $(BUILD_ONE_CMD)
 | 
				
			||||||
build_apps:
 | 
					build_apps:
 | 
				
			||||||
	@dir=apps; target=all; $(BUILD_ONE_CMD)
 | 
						@dir=apps; target=all; $(BUILD_ONE_CMD)
 | 
				
			||||||
build_tests:
 | 
					build_tests:
 | 
				
			||||||
@@ -389,13 +254,9 @@ all_testapps: build_libs build_testapps
 | 
				
			|||||||
build_testapps:
 | 
					build_testapps:
 | 
				
			||||||
	@dir=crypto; target=testapps; $(BUILD_ONE_CMD)
 | 
						@dir=crypto; target=testapps; $(BUILD_ONE_CMD)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
libcrypto$(SHLIB_EXT): libcrypto.a build_fips
 | 
					libcrypto$(SHLIB_EXT): libcrypto.a
 | 
				
			||||||
	@if [ "$(SHLIB_TARGET)" != "" ]; then \
 | 
						@if [ "$(SHLIB_TARGET)" != "" ]; then \
 | 
				
			||||||
		if [ "$(FIPSCANLIB)" = "libcrypto" ]; then \
 | 
							$(MAKE) SHLIBDIRS=crypto build-shared; \
 | 
				
			||||||
			FIPSLD_CC="$(CC)"; CC=fips/fipsld; \
 | 
					 | 
				
			||||||
			export CC FIPSLD_CC; \
 | 
					 | 
				
			||||||
		fi; \
 | 
					 | 
				
			||||||
		$(MAKE) -e SHLIBDIRS=crypto build-shared; \
 | 
					 | 
				
			||||||
	else \
 | 
						else \
 | 
				
			||||||
		echo "There's no support for shared libraries on this platform" >&2; \
 | 
							echo "There's no support for shared libraries on this platform" >&2; \
 | 
				
			||||||
		exit 1; \
 | 
							exit 1; \
 | 
				
			||||||
@@ -436,7 +297,7 @@ build-shared: do_$(SHLIB_TARGET) link-shared
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
do_$(SHLIB_TARGET):
 | 
					do_$(SHLIB_TARGET):
 | 
				
			||||||
	@ set -e; libs='-L. $(SHLIBDEPS)'; for i in $(SHLIBDIRS); do \
 | 
						@ set -e; libs='-L. $(SHLIBDEPS)'; for i in $(SHLIBDIRS); do \
 | 
				
			||||||
		if [ "$$i" = "ssl" -a -n "$(LIBKRB5)" ]; then \
 | 
							if [ "$(SHLIBDIRS)" = "ssl" -a -n "$(LIBKRB5)" ]; then \
 | 
				
			||||||
			libs="$(LIBKRB5) $$libs"; \
 | 
								libs="$(LIBKRB5) $$libs"; \
 | 
				
			||||||
		fi; \
 | 
							fi; \
 | 
				
			||||||
		$(CLEARENV) && $(MAKE) -f Makefile.shared -e $(BUILDENV) \
 | 
							$(CLEARENV) && $(MAKE) -f Makefile.shared -e $(BUILDENV) \
 | 
				
			||||||
@@ -450,7 +311,7 @@ do_$(SHLIB_TARGET):
 | 
				
			|||||||
libcrypto.pc: Makefile
 | 
					libcrypto.pc: Makefile
 | 
				
			||||||
	@ ( echo 'prefix=$(INSTALLTOP)'; \
 | 
						@ ( echo 'prefix=$(INSTALLTOP)'; \
 | 
				
			||||||
	    echo 'exec_prefix=$${prefix}'; \
 | 
						    echo 'exec_prefix=$${prefix}'; \
 | 
				
			||||||
	    echo 'libdir=$${exec_prefix}/$(LIBDIR)'; \
 | 
						    echo 'libdir=$${exec_prefix}/lib'; \
 | 
				
			||||||
	    echo 'includedir=$${prefix}/include'; \
 | 
						    echo 'includedir=$${prefix}/include'; \
 | 
				
			||||||
	    echo ''; \
 | 
						    echo ''; \
 | 
				
			||||||
	    echo 'Name: OpenSSL-libcrypto'; \
 | 
						    echo 'Name: OpenSSL-libcrypto'; \
 | 
				
			||||||
@@ -463,7 +324,7 @@ libcrypto.pc: Makefile
 | 
				
			|||||||
libssl.pc: Makefile
 | 
					libssl.pc: Makefile
 | 
				
			||||||
	@ ( echo 'prefix=$(INSTALLTOP)'; \
 | 
						@ ( echo 'prefix=$(INSTALLTOP)'; \
 | 
				
			||||||
	    echo 'exec_prefix=$${prefix}'; \
 | 
						    echo 'exec_prefix=$${prefix}'; \
 | 
				
			||||||
	    echo 'libdir=$${exec_prefix}/$(LIBDIR)'; \
 | 
						    echo 'libdir=$${exec_prefix}/lib'; \
 | 
				
			||||||
	    echo 'includedir=$${prefix}/include'; \
 | 
						    echo 'includedir=$${prefix}/include'; \
 | 
				
			||||||
	    echo ''; \
 | 
						    echo ''; \
 | 
				
			||||||
	    echo 'Name: OpenSSL'; \
 | 
						    echo 'Name: OpenSSL'; \
 | 
				
			||||||
@@ -476,7 +337,7 @@ libssl.pc: Makefile
 | 
				
			|||||||
openssl.pc: Makefile
 | 
					openssl.pc: Makefile
 | 
				
			||||||
	@ ( echo 'prefix=$(INSTALLTOP)'; \
 | 
						@ ( echo 'prefix=$(INSTALLTOP)'; \
 | 
				
			||||||
	    echo 'exec_prefix=$${prefix}'; \
 | 
						    echo 'exec_prefix=$${prefix}'; \
 | 
				
			||||||
	    echo 'libdir=$${exec_prefix}/$(LIBDIR)'; \
 | 
						    echo 'libdir=$${exec_prefix}/lib'; \
 | 
				
			||||||
	    echo 'includedir=$${prefix}/include'; \
 | 
						    echo 'includedir=$${prefix}/include'; \
 | 
				
			||||||
	    echo ''; \
 | 
						    echo ''; \
 | 
				
			||||||
	    echo 'Name: OpenSSL'; \
 | 
						    echo 'Name: OpenSSL'; \
 | 
				
			||||||
@@ -518,9 +379,6 @@ links:
 | 
				
			|||||||
	@$(PERL) $(TOP)/util/mkdir-p.pl include/openssl
 | 
						@$(PERL) $(TOP)/util/mkdir-p.pl include/openssl
 | 
				
			||||||
	@$(PERL) $(TOP)/util/mklink.pl include/openssl $(EXHEADER)
 | 
						@$(PERL) $(TOP)/util/mklink.pl include/openssl $(EXHEADER)
 | 
				
			||||||
	@set -e; target=links; $(RECURSIVE_BUILD_CMD)
 | 
						@set -e; target=links; $(RECURSIVE_BUILD_CMD)
 | 
				
			||||||
	@if [ -z "$(FIPSCANLIB)" ]; then \
 | 
					 | 
				
			||||||
		set -e; target=links; dir=fips ; $(BUILD_CMD) ; \
 | 
					 | 
				
			||||||
	fi
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
gentests:
 | 
					gentests:
 | 
				
			||||||
	@(cd test && echo "generating dummy tests (if needed)..." && \
 | 
						@(cd test && echo "generating dummy tests (if needed)..." && \
 | 
				
			||||||
@@ -532,7 +390,7 @@ dclean:
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
rehash: rehash.time
 | 
					rehash: rehash.time
 | 
				
			||||||
rehash.time: certs apps
 | 
					rehash.time: certs apps
 | 
				
			||||||
	@if [ -z "$(CROSS_COMPILE)" ]; then \
 | 
						@if [ -z "$(CROSS_COMPILE_PREFIX)" ]; then \
 | 
				
			||||||
		(OPENSSL="`pwd`/util/opensslwrap.sh"; \
 | 
							(OPENSSL="`pwd`/util/opensslwrap.sh"; \
 | 
				
			||||||
		[ -x "apps/openssl.exe" ] && OPENSSL="apps/openssl.exe" || :; \
 | 
							[ -x "apps/openssl.exe" ] && OPENSSL="apps/openssl.exe" || :; \
 | 
				
			||||||
		OPENSSL_DEBUG_MEMORY=on; \
 | 
							OPENSSL_DEBUG_MEMORY=on; \
 | 
				
			||||||
@@ -545,8 +403,8 @@ test:   tests
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
tests: rehash
 | 
					tests: rehash
 | 
				
			||||||
	@(cd test && echo "testing..." && \
 | 
						@(cd test && echo "testing..." && \
 | 
				
			||||||
	$(CLEARENV) && $(MAKE) -e $(BUILDENV) TOP=.. TESTS='$(TESTS)' OPENSSL_DEBUG_MEMORY=on OPENSSL_CONF=../apps/openssl.cnf tests );
 | 
						$(CLEARENV) && $(MAKE) -e $(BUILDENV) TOP=.. TESTS='$(TESTS)' OPENSSL_DEBUG_MEMORY=on tests );
 | 
				
			||||||
	OPENSSL_CONF=apps/openssl.cnf util/opensslwrap.sh version -a
 | 
						util/opensslwrap.sh version -a
 | 
				
			||||||
 | 
					
 | 
				
			||||||
report:
 | 
					report:
 | 
				
			||||||
	@$(PERL) util/selftest.pl
 | 
						@$(PERL) util/selftest.pl
 | 
				
			||||||
@@ -564,7 +422,7 @@ tags:
 | 
				
			|||||||
errors:
 | 
					errors:
 | 
				
			||||||
	$(PERL) util/mkerr.pl -recurse -write
 | 
						$(PERL) util/mkerr.pl -recurse -write
 | 
				
			||||||
	(cd engines; $(MAKE) PERL=$(PERL) errors)
 | 
						(cd engines; $(MAKE) PERL=$(PERL) errors)
 | 
				
			||||||
	$(PERL) util/ck_errf.pl -strict */*.c */*/*.c
 | 
						$(PERL) util/ck_errf.pl */*.c */*/*.c
 | 
				
			||||||
 | 
					
 | 
				
			||||||
stacks:
 | 
					stacks:
 | 
				
			||||||
	$(PERL) util/mkstack.pl -write
 | 
						$(PERL) util/mkstack.pl -write
 | 
				
			||||||
@@ -634,9 +492,9 @@ install: all install_docs install_sw
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
install_sw:
 | 
					install_sw:
 | 
				
			||||||
	@$(PERL) $(TOP)/util/mkdir-p.pl $(INSTALL_PREFIX)$(INSTALLTOP)/bin \
 | 
						@$(PERL) $(TOP)/util/mkdir-p.pl $(INSTALL_PREFIX)$(INSTALLTOP)/bin \
 | 
				
			||||||
		$(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR) \
 | 
							$(INSTALL_PREFIX)$(INSTALLTOP)/lib \
 | 
				
			||||||
		$(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/engines \
 | 
							$(INSTALL_PREFIX)$(INSTALLTOP)/lib/engines \
 | 
				
			||||||
		$(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/pkgconfig \
 | 
							$(INSTALL_PREFIX)$(INSTALLTOP)/lib/pkgconfig \
 | 
				
			||||||
		$(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl \
 | 
							$(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl \
 | 
				
			||||||
		$(INSTALL_PREFIX)$(OPENSSLDIR)/misc \
 | 
							$(INSTALL_PREFIX)$(OPENSSLDIR)/misc \
 | 
				
			||||||
		$(INSTALL_PREFIX)$(OPENSSLDIR)/certs \
 | 
							$(INSTALL_PREFIX)$(OPENSSLDIR)/certs \
 | 
				
			||||||
@@ -647,14 +505,14 @@ install_sw:
 | 
				
			|||||||
	chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$i ); \
 | 
						chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$i ); \
 | 
				
			||||||
	done;
 | 
						done;
 | 
				
			||||||
	@set -e; target=install; $(RECURSIVE_BUILD_CMD)
 | 
						@set -e; target=install; $(RECURSIVE_BUILD_CMD)
 | 
				
			||||||
	@set -e; liblist="$(LIBS)"; for i in $$liblist ;\
 | 
						@set -e; for i in $(LIBS) ;\
 | 
				
			||||||
	do \
 | 
						do \
 | 
				
			||||||
		if [ -f "$$i" ]; then \
 | 
							if [ -f "$$i" ]; then \
 | 
				
			||||||
		(       echo installing $$i; \
 | 
							(       echo installing $$i; \
 | 
				
			||||||
			cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$i.new; \
 | 
								cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i.new; \
 | 
				
			||||||
			$(RANLIB) $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$i.new; \
 | 
								$(RANLIB) $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i.new; \
 | 
				
			||||||
			chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$i.new; \
 | 
								chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i.new; \
 | 
				
			||||||
			mv -f $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$i.new $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$i ); \
 | 
								mv -f $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i.new $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i ); \
 | 
				
			||||||
		fi; \
 | 
							fi; \
 | 
				
			||||||
	done;
 | 
						done;
 | 
				
			||||||
	@set -e; if [ -n "$(SHARED_LIBS)" ]; then \
 | 
						@set -e; if [ -n "$(SHARED_LIBS)" ]; then \
 | 
				
			||||||
@@ -664,17 +522,17 @@ install_sw:
 | 
				
			|||||||
			if [ -f "$$i" -o -f "$$i.a" ]; then \
 | 
								if [ -f "$$i" -o -f "$$i.a" ]; then \
 | 
				
			||||||
			(       echo installing $$i; \
 | 
								(       echo installing $$i; \
 | 
				
			||||||
				if [ "$(PLATFORM)" != "Cygwin" ]; then \
 | 
									if [ "$(PLATFORM)" != "Cygwin" ]; then \
 | 
				
			||||||
					cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$i.new; \
 | 
										cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i.new; \
 | 
				
			||||||
					chmod 555 $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$i.new; \
 | 
										chmod 555 $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i.new; \
 | 
				
			||||||
					mv -f $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$i.new $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$i; \
 | 
										mv -f $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i.new $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i; \
 | 
				
			||||||
				else \
 | 
									else \
 | 
				
			||||||
					c=`echo $$i | sed 's/^lib\(.*\)\.dll\.a/cyg\1-$(SHLIB_VERSION_NUMBER).dll/'`; \
 | 
										c=`echo $$i | sed 's/^lib\(.*\)\.dll\.a/cyg\1-$(SHLIB_VERSION_NUMBER).dll/'`; \
 | 
				
			||||||
					cp $$c $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$c.new; \
 | 
										cp $$c $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$c.new; \
 | 
				
			||||||
					chmod 755 $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$c.new; \
 | 
										chmod 755 $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$c.new; \
 | 
				
			||||||
					mv -f $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$c.new $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$c; \
 | 
										mv -f $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$c.new $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$c; \
 | 
				
			||||||
					cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$i.new; \
 | 
										cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i.new; \
 | 
				
			||||||
					chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$i.new; \
 | 
										chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i.new; \
 | 
				
			||||||
					mv -f $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$i.new $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$i; \
 | 
										mv -f $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i.new $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i; \
 | 
				
			||||||
				fi ); \
 | 
									fi ); \
 | 
				
			||||||
				if expr $(PLATFORM) : 'mingw' > /dev/null; then \
 | 
									if expr $(PLATFORM) : 'mingw' > /dev/null; then \
 | 
				
			||||||
				(	case $$i in \
 | 
									(	case $$i in \
 | 
				
			||||||
@@ -689,7 +547,7 @@ install_sw:
 | 
				
			|||||||
			fi; \
 | 
								fi; \
 | 
				
			||||||
		done; \
 | 
							done; \
 | 
				
			||||||
		(	here="`pwd`"; \
 | 
							(	here="`pwd`"; \
 | 
				
			||||||
			cd $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR); \
 | 
								cd $(INSTALL_PREFIX)$(INSTALLTOP)/lib; \
 | 
				
			||||||
			$(MAKE) -f $$here/Makefile HERE="$$here" link-shared ); \
 | 
								$(MAKE) -f $$here/Makefile HERE="$$here" link-shared ); \
 | 
				
			||||||
		if [ "$(INSTALLTOP)" != "/usr" ]; then \
 | 
							if [ "$(INSTALLTOP)" != "/usr" ]; then \
 | 
				
			||||||
			echo 'OpenSSL shared libraries have been installed in:'; \
 | 
								echo 'OpenSSL shared libraries have been installed in:'; \
 | 
				
			||||||
@@ -698,12 +556,12 @@ install_sw:
 | 
				
			|||||||
			sed -e '1,/^$$/d' doc/openssl-shared.txt; \
 | 
								sed -e '1,/^$$/d' doc/openssl-shared.txt; \
 | 
				
			||||||
		fi; \
 | 
							fi; \
 | 
				
			||||||
	fi
 | 
						fi
 | 
				
			||||||
	cp libcrypto.pc $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/pkgconfig
 | 
						cp libcrypto.pc $(INSTALL_PREFIX)$(INSTALLTOP)/lib/pkgconfig
 | 
				
			||||||
	chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/pkgconfig/libcrypto.pc
 | 
						chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/lib/pkgconfig/libcrypto.pc
 | 
				
			||||||
	cp libssl.pc $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/pkgconfig
 | 
						cp libssl.pc $(INSTALL_PREFIX)$(INSTALLTOP)/lib/pkgconfig
 | 
				
			||||||
	chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/pkgconfig/libssl.pc
 | 
						chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/lib/pkgconfig/libssl.pc
 | 
				
			||||||
	cp openssl.pc $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/pkgconfig
 | 
						cp openssl.pc $(INSTALL_PREFIX)$(INSTALLTOP)/lib/pkgconfig
 | 
				
			||||||
	chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/pkgconfig/openssl.pc
 | 
						chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/lib/pkgconfig/openssl.pc
 | 
				
			||||||
 | 
					
 | 
				
			||||||
install_html_docs:
 | 
					install_html_docs:
 | 
				
			||||||
	here="`pwd`"; \
 | 
						here="`pwd`"; \
 | 
				
			||||||
@@ -721,7 +579,7 @@ install_html_docs:
 | 
				
			|||||||
				grep -v $$filecase "^$$fn\$$" | \
 | 
									grep -v $$filecase "^$$fn\$$" | \
 | 
				
			||||||
				(cd $(INSTALL_PREFIX)$(HTMLDIR)/$$subdir; \
 | 
									(cd $(INSTALL_PREFIX)$(HTMLDIR)/$$subdir; \
 | 
				
			||||||
				 while read n; do \
 | 
									 while read n; do \
 | 
				
			||||||
					PLATFORM=$(PLATFORM) $$here/util/point.sh $$fn.$(HTMLSUFFIX) "$$n".$(HTMLSUFFIX); \
 | 
										$$here/util/point.sh $$fn.$(HTMLSUFFIX) "$$n".$(HTMLSUFFIX); \
 | 
				
			||||||
				 done); \
 | 
									 done); \
 | 
				
			||||||
		done; \
 | 
							done; \
 | 
				
			||||||
	done
 | 
						done
 | 
				
			||||||
@@ -732,7 +590,7 @@ install_docs:
 | 
				
			|||||||
		$(INSTALL_PREFIX)$(MANDIR)/man3 \
 | 
							$(INSTALL_PREFIX)$(MANDIR)/man3 \
 | 
				
			||||||
		$(INSTALL_PREFIX)$(MANDIR)/man5 \
 | 
							$(INSTALL_PREFIX)$(MANDIR)/man5 \
 | 
				
			||||||
		$(INSTALL_PREFIX)$(MANDIR)/man7
 | 
							$(INSTALL_PREFIX)$(MANDIR)/man7
 | 
				
			||||||
	@pod2man="`cd ./util; ./pod2mantest $(PERL)`"; \
 | 
						@pod2man="`cd util; ./pod2mantest $(PERL)`"; \
 | 
				
			||||||
	here="`pwd`"; \
 | 
						here="`pwd`"; \
 | 
				
			||||||
	filecase=; \
 | 
						filecase=; \
 | 
				
			||||||
	if [ "$(PLATFORM)" = "DJGPP" -o "$(PLATFORM)" = "Cygwin" -o "$(PLATFORM)" = "mingw" ]; then \
 | 
						if [ "$(PLATFORM)" = "DJGPP" -o "$(PLATFORM)" = "Cygwin" -o "$(PLATFORM)" = "mingw" ]; then \
 | 
				
			||||||
@@ -752,7 +610,7 @@ install_docs:
 | 
				
			|||||||
			(grep -v "[	]"; true) | \
 | 
								(grep -v "[	]"; true) | \
 | 
				
			||||||
			(cd $(INSTALL_PREFIX)$(MANDIR)/man$$sec/; \
 | 
								(cd $(INSTALL_PREFIX)$(MANDIR)/man$$sec/; \
 | 
				
			||||||
			 while read n; do \
 | 
								 while read n; do \
 | 
				
			||||||
				PLATFORM=$(PLATFORM) $$here/util/point.sh $$fn.$${sec}$(MANSUFFIX) "$$n".$${sec}$(MANSUFFIX); \
 | 
									$$here/util/point.sh $$fn.$${sec}$(MANSUFFIX) "$$n".$${sec}$(MANSUFFIX); \
 | 
				
			||||||
			 done); \
 | 
								 done); \
 | 
				
			||||||
	done; \
 | 
						done; \
 | 
				
			||||||
	set -e; for i in doc/crypto/*.pod doc/ssl/*.pod; do \
 | 
						set -e; for i in doc/crypto/*.pod doc/ssl/*.pod; do \
 | 
				
			||||||
@@ -769,7 +627,7 @@ install_docs:
 | 
				
			|||||||
			(grep -v "[	]"; true) | \
 | 
								(grep -v "[	]"; true) | \
 | 
				
			||||||
			(cd $(INSTALL_PREFIX)$(MANDIR)/man$$sec/; \
 | 
								(cd $(INSTALL_PREFIX)$(MANDIR)/man$$sec/; \
 | 
				
			||||||
			 while read n; do \
 | 
								 while read n; do \
 | 
				
			||||||
				PLATFORM=$(PLATFORM) $$here/util/point.sh $$fn.$${sec}$(MANSUFFIX) "$$n".$${sec}$(MANSUFFIX); \
 | 
									$$here/util/point.sh $$fn.$${sec}$(MANSUFFIX) "$$n".$${sec}$(MANSUFFIX); \
 | 
				
			||||||
			 done); \
 | 
								 done); \
 | 
				
			||||||
	done
 | 
						done
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -135,7 +135,7 @@ LINK_SO_A_VIA_O=	\
 | 
				
			|||||||
  ALL=$$ALLSYMSFLAGS; ALLSYMSFLAGS=; NOALLSYMSFLAGS=; \
 | 
					  ALL=$$ALLSYMSFLAGS; ALLSYMSFLAGS=; NOALLSYMSFLAGS=; \
 | 
				
			||||||
  ( $(SET_X); \
 | 
					  ( $(SET_X); \
 | 
				
			||||||
    ld $(LDFLAGS) -r -o lib$(LIBNAME).o $$ALL lib$(LIBNAME).a $(LIBEXTRAS) ); \
 | 
					    ld $(LDFLAGS) -r -o lib$(LIBNAME).o $$ALL lib$(LIBNAME).a $(LIBEXTRAS) ); \
 | 
				
			||||||
  $(LINK_SO) && rm -f lib$(LIBNAME).o
 | 
					  $(LINK_SO) && rm -f $(LIBNAME).o
 | 
				
			||||||
 | 
					
 | 
				
			||||||
LINK_SO_A_UNPACKED=	\
 | 
					LINK_SO_A_UNPACKED=	\
 | 
				
			||||||
  UNPACKDIR=link_tmp.$$$$; rm -rf $$UNPACKDIR; mkdir $$UNPACKDIR; \
 | 
					  UNPACKDIR=link_tmp.$$$$; rm -rf $$UNPACKDIR; mkdir $$UNPACKDIR; \
 | 
				
			||||||
@@ -207,29 +207,17 @@ link_app.bsd:
 | 
				
			|||||||
	fi; $(LINK_APP)
 | 
						fi; $(LINK_APP)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# For Darwin AKA Mac OS/X (dyld)
 | 
					# For Darwin AKA Mac OS/X (dyld)
 | 
				
			||||||
# Originally link_o.darwin produced .so, because it was hard-coded
 | 
					# link_o.darwin produces .so, because we let it use dso_dlfcn module,
 | 
				
			||||||
# in dso_dlfcn module. At later point dso_dlfcn switched to .dylib
 | 
					# which has .so extension hard-coded. One can argue that one should
 | 
				
			||||||
# extension in order to allow for run-time linking with vendor-
 | 
					# develop special dso module for MacOS X. At least manual encourages
 | 
				
			||||||
# supplied shared libraries such as libz, so that link_o.darwin had
 | 
					# to use native NSModule(3) API and refers to dlfcn as termporary hack.
 | 
				
			||||||
# to be harmonized with it. This caused minor controversy, because
 | 
					 | 
				
			||||||
# it was believed that dlopen can't be used to dynamically load
 | 
					 | 
				
			||||||
# .dylib-s, only so called bundle modules (ones linked with -bundle
 | 
					 | 
				
			||||||
# flag). The belief seems to be originating from pre-10.4 release,
 | 
					 | 
				
			||||||
# where dlfcn functionality was emulated by dlcompat add-on. In
 | 
					 | 
				
			||||||
# 10.4 dlopen was rewritten as native part of dyld and is documented
 | 
					 | 
				
			||||||
# to be capable of loading both dynamic libraries and bundles. In
 | 
					 | 
				
			||||||
# order to provide compatibility with pre-10.4 dlopen, modules are
 | 
					 | 
				
			||||||
# linked with -bundle flag, which makes .dylib extension misleading.
 | 
					 | 
				
			||||||
# It works, because dlopen is [and always was] extension-agnostic.
 | 
					 | 
				
			||||||
# Alternative to this heuristic approach is to develop specific
 | 
					 | 
				
			||||||
# MacOS X dso module relying on whichever "native" dyld interface.
 | 
					 | 
				
			||||||
link_o.darwin:
 | 
					link_o.darwin:
 | 
				
			||||||
	@ $(CALC_VERSIONS); \
 | 
						@ $(CALC_VERSIONS); \
 | 
				
			||||||
	SHLIB=lib$(LIBNAME); \
 | 
						SHLIB=lib$(LIBNAME); \
 | 
				
			||||||
	SHLIB_SUFFIX=.dylib; \
 | 
						SHLIB_SUFFIX=.so; \
 | 
				
			||||||
	ALLSYMSFLAGS='-all_load'; \
 | 
						ALLSYMSFLAGS='-all_load'; \
 | 
				
			||||||
	NOALLSYMSFLAGS=''; \
 | 
						NOALLSYMSFLAGS=''; \
 | 
				
			||||||
	SHAREDFLAGS="$(CFLAGS) `echo $(SHARED_LDFLAGS) | sed s/dynamiclib/bundle/`"; \
 | 
						SHAREDFLAGS="$(CFLAGS) $(SHARED_LDFLAGS)"; \
 | 
				
			||||||
	if [ -n "$(LIBVERSION)" ]; then \
 | 
						if [ -n "$(LIBVERSION)" ]; then \
 | 
				
			||||||
		SHAREDFLAGS="$$SHAREDFLAGS -current_version $(LIBVERSION)"; \
 | 
							SHAREDFLAGS="$$SHAREDFLAGS -current_version $(LIBVERSION)"; \
 | 
				
			||||||
	fi; \
 | 
						fi; \
 | 
				
			||||||
@@ -250,7 +238,7 @@ link_a.darwin:
 | 
				
			|||||||
	if [ -n "$$SHLIB_SOVER_NODOT" ]; then \
 | 
						if [ -n "$$SHLIB_SOVER_NODOT" ]; then \
 | 
				
			||||||
		SHAREDFLAGS="$$SHAREDFLAGS -compatibility_version $$SHLIB_SOVER_NODOT"; \
 | 
							SHAREDFLAGS="$$SHAREDFLAGS -compatibility_version $$SHLIB_SOVER_NODOT"; \
 | 
				
			||||||
	fi; \
 | 
						fi; \
 | 
				
			||||||
	SHAREDFLAGS="$$SHAREDFLAGS -install_name $(INSTALLTOP)/$(LIBDIR)/$$SHLIB$(SHLIB_EXT)"; \
 | 
						SHAREDFLAGS="$$SHAREDFLAGS -install_name $(INSTALLTOP)/lib/$$SHLIB$(SHLIB_EXT)"; \
 | 
				
			||||||
	$(LINK_SO_A)
 | 
						$(LINK_SO_A)
 | 
				
			||||||
link_app.darwin:	# is there run-path on darwin?
 | 
					link_app.darwin:	# is there run-path on darwin?
 | 
				
			||||||
	$(LINK_APP)
 | 
						$(LINK_APP)
 | 
				
			||||||
@@ -293,7 +281,7 @@ link_a.cygwin:
 | 
				
			|||||||
	fi; \
 | 
						fi; \
 | 
				
			||||||
	dll_name=$$SHLIB$$SHLIB_SOVER$$SHLIB_SUFFIX; \
 | 
						dll_name=$$SHLIB$$SHLIB_SOVER$$SHLIB_SUFFIX; \
 | 
				
			||||||
	$(PERL) util/mkrc.pl $$dll_name | \
 | 
						$(PERL) util/mkrc.pl $$dll_name | \
 | 
				
			||||||
		$(CROSS_COMPILE)windres -o rc.o; \
 | 
							$(CROSS_COMPILE_PREFIX)windres -o rc.o; \
 | 
				
			||||||
	extras="$$extras rc.o"; \
 | 
						extras="$$extras rc.o"; \
 | 
				
			||||||
	ALLSYMSFLAGS='-Wl,--whole-archive'; \
 | 
						ALLSYMSFLAGS='-Wl,--whole-archive'; \
 | 
				
			||||||
	NOALLSYMSFLAGS='-Wl,--no-whole-archive'; \
 | 
						NOALLSYMSFLAGS='-Wl,--no-whole-archive'; \
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										69
									
								
								NEWS
									
									
									
									
									
								
							
							
						
						
									
										69
									
								
								NEWS
									
									
									
									
									
								
							@@ -5,35 +5,13 @@
 | 
				
			|||||||
  This file gives a brief overview of the major changes between each OpenSSL
 | 
					  This file gives a brief overview of the major changes between each OpenSSL
 | 
				
			||||||
  release. For more details please read the CHANGES file.
 | 
					  release. For more details please read the CHANGES file.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  Major changes between OpenSSL 1.0.0c and OpenSSL 1.0.0d:
 | 
					  Major changes between OpenSSL 0.9.8k and OpenSSL 1.0:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      o Fix for security issue CVE-2011-0014
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  Major changes between OpenSSL 1.0.0b and OpenSSL 1.0.0c:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      o Fix for security issue CVE-2010-4180
 | 
					 | 
				
			||||||
      o Fix for CVE-2010-4252
 | 
					 | 
				
			||||||
      o Fix mishandling of absent EC point format extension.
 | 
					 | 
				
			||||||
      o Fix various platform compilation issues.
 | 
					 | 
				
			||||||
      o Corrected fix for security issue CVE-2010-3864.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  Major changes between OpenSSL 1.0.0a and OpenSSL 1.0.0b:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      o Fix for security issue CVE-2010-3864.
 | 
					 | 
				
			||||||
      o Fix for CVE-2010-2939
 | 
					 | 
				
			||||||
      o Fix WIN32 build system for GOST ENGINE.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  Major changes between OpenSSL 1.0.0 and OpenSSL 1.0.0a:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      o Fix for security issue CVE-2010-1633.
 | 
					 | 
				
			||||||
      o GOST MAC and CFB fixes.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  Major changes between OpenSSL 0.9.8n and OpenSSL 1.0.0:
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
      o RFC3280 path validation: sufficient to process PKITS tests.
 | 
					      o RFC3280 path validation: sufficient to process PKITS tests.
 | 
				
			||||||
      o Integrated support for PVK files and keyblobs.
 | 
					      o Integrated support for PVK files and keyblobs.
 | 
				
			||||||
      o Change default private key format to PKCS#8.
 | 
					      o Change default private key format to PKCS#8.
 | 
				
			||||||
      o CMS support: able to process all examples in RFC4134
 | 
					      o CMS support: able to process all examples in RFCXXXX
 | 
				
			||||||
      o Streaming ASN1 encode support for PKCS#7 and CMS.
 | 
					      o Streaming ASN1 encode support for PKCS#7 and CMS.
 | 
				
			||||||
      o Multiple signer and signer add support for PKCS#7 and CMS.
 | 
					      o Multiple signer and signer add support for PKCS#7 and CMS.
 | 
				
			||||||
      o ASN1 printing support.
 | 
					      o ASN1 printing support.
 | 
				
			||||||
@@ -49,49 +27,6 @@
 | 
				
			|||||||
      o ecdsa-with-SHA224/256/384/512 signature types.
 | 
					      o ecdsa-with-SHA224/256/384/512 signature types.
 | 
				
			||||||
      o dsa-with-SHA224 and dsa-with-SHA256 signature types.
 | 
					      o dsa-with-SHA224 and dsa-with-SHA256 signature types.
 | 
				
			||||||
      o Opaque PRF Input TLS extension support.
 | 
					      o Opaque PRF Input TLS extension support.
 | 
				
			||||||
      o Updated time routines to avoid OS limitations.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  Major changes between OpenSSL 0.9.8q and OpenSSL 0.9.8r:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      o Fix for security issue CVE-2011-0014
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  Major changes between OpenSSL 0.9.8p and OpenSSL 0.9.8q:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      o Fix for security issue CVE-2010-4180
 | 
					 | 
				
			||||||
      o Fix for CVE-2010-4252
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  Major changes between OpenSSL 0.9.8o and OpenSSL 0.9.8p:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      o Fix for security issue CVE-2010-3864.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  Major changes between OpenSSL 0.9.8n and OpenSSL 0.9.8o:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      o Fix for security issue CVE-2010-0742.
 | 
					 | 
				
			||||||
      o Various DTLS fixes.
 | 
					 | 
				
			||||||
      o Recognise SHA2 certificates if only SSL algorithms added.
 | 
					 | 
				
			||||||
      o Fix for no-rc4 compilation.
 | 
					 | 
				
			||||||
      o Chil ENGINE unload workaround.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  Major changes between OpenSSL 0.9.8m and OpenSSL 0.9.8n:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      o CFB cipher definition fixes.
 | 
					 | 
				
			||||||
      o Fix security issues CVE-2010-0740 and CVE-2010-0433.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  Major changes between OpenSSL 0.9.8l and OpenSSL 0.9.8m:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      o Cipher definition fixes.
 | 
					 | 
				
			||||||
      o Workaround for slow RAND_poll() on some WIN32 versions.
 | 
					 | 
				
			||||||
      o Remove MD2 from algorithm tables.
 | 
					 | 
				
			||||||
      o SPKAC handling fixes.
 | 
					 | 
				
			||||||
      o Support for RFC5746 TLS renegotiation extension.
 | 
					 | 
				
			||||||
      o Compression memory leak fixed.
 | 
					 | 
				
			||||||
      o Compression session resumption fixed.
 | 
					 | 
				
			||||||
      o Ticket and SNI coexistence fixes.
 | 
					 | 
				
			||||||
      o Many fixes to DTLS handling. 
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  Major changes between OpenSSL 0.9.8k and OpenSSL 0.9.8l:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      o Temporary work around for CVE-2009-3555: disable renegotiation.
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
  Major changes between OpenSSL 0.9.8j and OpenSSL 0.9.8k:
 | 
					  Major changes between OpenSSL 0.9.8j and OpenSSL 0.9.8k:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										4
									
								
								PROBLEMS
									
									
									
									
									
								
							
							
						
						
									
										4
									
								
								PROBLEMS
									
									
									
									
									
								
							@@ -36,9 +36,7 @@ may differ on your machine.
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
As long as Apple doesn't fix the problem with ld, this problem building
 | 
					As long as Apple doesn't fix the problem with ld, this problem building
 | 
				
			||||||
OpenSSL will remain as is. Well, the problem was addressed in 0.9.8f by
 | 
					OpenSSL will remain as is.
 | 
				
			||||||
passing -Wl,-search_paths_first, but it's unknown if the flag was
 | 
					 | 
				
			||||||
supported from the initial MacOS X release.
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
* Parallell make leads to errors
 | 
					* Parallell make leads to errors
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										27
									
								
								README
									
									
									
									
									
								
							
							
						
						
									
										27
									
								
								README
									
									
									
									
									
								
							@@ -1,7 +1,7 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
 OpenSSL 1.1.0-dev
 | 
					 OpenSSL 1.0.0-beta1 01 Apr 2009
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 Copyright (c) 1998-2011 The OpenSSL Project
 | 
					 Copyright (c) 1998-2008 The OpenSSL Project
 | 
				
			||||||
 Copyright (c) 1995-1998 Eric A. Young, Tim J. Hudson
 | 
					 Copyright (c) 1995-1998 Eric A. Young, Tim J. Hudson
 | 
				
			||||||
 All rights reserved.
 | 
					 All rights reserved.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -112,6 +112,8 @@
 | 
				
			|||||||
 should be contacted if that algorithm is to be used; their web page is
 | 
					 should be contacted if that algorithm is to be used; their web page is
 | 
				
			||||||
 http://www.ascom.ch/.
 | 
					 http://www.ascom.ch/.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 The MDC2 algorithm is patented by IBM.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 NTT and Mitsubishi have patents and pending patents on the Camellia
 | 
					 NTT and Mitsubishi have patents and pending patents on the Camellia
 | 
				
			||||||
 algorithm, but allow use at no charge without requiring an explicit
 | 
					 algorithm, but allow use at no charge without requiring an explicit
 | 
				
			||||||
 licensing agreement: http://info.isl.ntt.co.jp/crypt/eng/info/chiteki.html
 | 
					 licensing agreement: http://info.isl.ntt.co.jp/crypt/eng/info/chiteki.html
 | 
				
			||||||
@@ -137,9 +139,6 @@
 | 
				
			|||||||
 SUPPORT
 | 
					 SUPPORT
 | 
				
			||||||
 -------
 | 
					 -------
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 See the OpenSSL website www.openssl.org for details of how to obtain
 | 
					 | 
				
			||||||
 commercial technical support.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 If you have any problems with OpenSSL then please take the following steps
 | 
					 If you have any problems with OpenSSL then please take the following steps
 | 
				
			||||||
 first:
 | 
					 first:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -166,10 +165,6 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    openssl-bugs@openssl.org
 | 
					    openssl-bugs@openssl.org
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 Note that the request tracker should NOT be used for general assistance
 | 
					 | 
				
			||||||
 or support queries. Just because something doesn't work the way you expect
 | 
					 | 
				
			||||||
 does not mean it is necessarily a bug in OpenSSL.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 Note that mail to openssl-bugs@openssl.org is recorded in the publicly
 | 
					 Note that mail to openssl-bugs@openssl.org is recorded in the publicly
 | 
				
			||||||
 readable request tracker database and is forwarded to a public
 | 
					 readable request tracker database and is forwarded to a public
 | 
				
			||||||
 mailing list. Confidential mail may be sent to openssl-security@openssl.org
 | 
					 mailing list. Confidential mail may be sent to openssl-security@openssl.org
 | 
				
			||||||
@@ -180,22 +175,10 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
 Development is coordinated on the openssl-dev mailing list (see
 | 
					 Development is coordinated on the openssl-dev mailing list (see
 | 
				
			||||||
 http://www.openssl.org for information on subscribing). If you
 | 
					 http://www.openssl.org for information on subscribing). If you
 | 
				
			||||||
 would like to submit a patch, send it to openssl-bugs@openssl.org with
 | 
					 would like to submit a patch, send it to openssl-dev@openssl.org with
 | 
				
			||||||
 the string "[PATCH]" in the subject. Please be sure to include a
 | 
					 the string "[PATCH]" in the subject. Please be sure to include a
 | 
				
			||||||
 textual explanation of what your patch does.
 | 
					 textual explanation of what your patch does.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 If you are unsure as to whether a feature will be useful for the general
 | 
					 | 
				
			||||||
 OpenSSL community please discuss it on the openssl-dev mailing list first.
 | 
					 | 
				
			||||||
 Someone may be already working on the same thing or there may be a good
 | 
					 | 
				
			||||||
 reason as to why that feature isn't implemented.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 Patches should be as up to date as possible, preferably relative to the
 | 
					 | 
				
			||||||
 current CVS or the last snapshot. They should follow the coding style of
 | 
					 | 
				
			||||||
 OpenSSL and compile without warnings. Some of the core team developer targets
 | 
					 | 
				
			||||||
 can be used for testing purposes, (debug-steve64, debug-geoff etc). OpenSSL
 | 
					 | 
				
			||||||
 compiles on many varied platforms: try to ensure you only use portable
 | 
					 | 
				
			||||||
 features.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 Note: For legal reasons, contributions from the US can be accepted only
 | 
					 Note: For legal reasons, contributions from the US can be accepted only
 | 
				
			||||||
 if a TSU notification and a copy of the patch are sent to crypt@bis.doc.gov
 | 
					 if a TSU notification and a copy of the patch are sent to crypt@bis.doc.gov
 | 
				
			||||||
 (formerly BXA) with a copy to the ENC Encryption Request Coordinator;
 | 
					 (formerly BXA) with a copy to the ENC Encryption Request Coordinator;
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										61
									
								
								README.ECC
									
									
									
									
									
								
							
							
						
						
									
										61
									
								
								README.ECC
									
									
									
									
									
								
							@@ -1,61 +0,0 @@
 | 
				
			|||||||
NOTE: The OpenSSL Software Foundation has executed a sublicense agreement
 | 
					 | 
				
			||||||
entitled "Elliptic Curve Cryptography Patent License Agreement" with the
 | 
					 | 
				
			||||||
National Security Agency/ Central Security Service Commercial Solutions
 | 
					 | 
				
			||||||
Center (NCSC) dated 2010-11-04. That agreement permits implementation and
 | 
					 | 
				
			||||||
distribution of software containing features covered by any or all of the
 | 
					 | 
				
			||||||
following patents:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
1.) U.S. Pat. No. 5,761,305 entitled "Key Agreement and Transport Protocol 
 | 
					 | 
				
			||||||
    with Implicit Signatures" issued on June 2, 1998;
 | 
					 | 
				
			||||||
2.) Can. Pat. Appl. Ser. No. 2176972 entitled "Key Agreement and Transport 
 | 
					 | 
				
			||||||
    Protocol with Implicit Signature and Reduced Bandwidth" filed on May 
 | 
					 | 
				
			||||||
    16, 1996;
 | 
					 | 
				
			||||||
3.) U.S. Pat. No. 5,889,865 entitled "Key Agreement and Transport Protocol 
 | 
					 | 
				
			||||||
    with Implicit Signatures" issued on March 30, 1999;
 | 
					 | 
				
			||||||
4.) U.S. Pat. No. 5,896,455 entitled "Key Agreement and Transport Protocol 
 | 
					 | 
				
			||||||
    with Implicit Signatures" issued on April 20, 1999;
 | 
					 | 
				
			||||||
5.) U.S. Pat. No. 5,933,504 entitled "Strengthened Public Key Protocol" 
 | 
					 | 
				
			||||||
    issued on August 3, 1999;
 | 
					 | 
				
			||||||
6.) Can. Pat. Appl. Ser. No. 2176866 entitled "Strengthened Public Key 
 | 
					 | 
				
			||||||
    Protocol" filed on May 17, 1996;
 | 
					 | 
				
			||||||
7.) E.P. Pat. Appl. Ser. No. 96201322.3 entitled "Strengthened Public Key 
 | 
					 | 
				
			||||||
    Protocol" filed on May 17, 1996;
 | 
					 | 
				
			||||||
8.) U.S. Pat. No. 5,999,626 entitled "Digital Signatures on a Smartcard" 
 | 
					 | 
				
			||||||
    issued on December 7, 1999;
 | 
					 | 
				
			||||||
9.) Can. Pat. Appl. Ser. No. 2202566 entitled "Digital Signatures on a 
 | 
					 | 
				
			||||||
    Smartcard" filed on April 14, 1997;
 | 
					 | 
				
			||||||
10.) E.P. Pat. Appl. No. 97106114.8 entitled "Digital Signatures on a 
 | 
					 | 
				
			||||||
     Smartcard" filed on April 15, 1997;
 | 
					 | 
				
			||||||
11.) U.S Pat. No. 6,122,736 entitled "Key Agreement and Transport Protocol 
 | 
					 | 
				
			||||||
     with Implicit Signatures" issued on September 19, 2000;
 | 
					 | 
				
			||||||
12.) Can. Pat. Appl. Ser. No. 2174261 entitled "Key Agreement and Transport 
 | 
					 | 
				
			||||||
     Protocol with Implicit Signatures" filed on April 16, 1996;
 | 
					 | 
				
			||||||
13.) E.P. Pat. Appl. Ser. No. 96105920.1 entitled "Key Agreement and 
 | 
					 | 
				
			||||||
     Transport Protocol with Implicit Signatures" filed on April 16, 1996;
 | 
					 | 
				
			||||||
14.) U.S. Pat. No. 6,141,420 entitled "Elliptic Curve Encryption Systems" 
 | 
					 | 
				
			||||||
     issued on October 31, 2000;
 | 
					 | 
				
			||||||
15.) Can. Pat. Appl. Ser. No. 2155038 entitled "Elliptic Curve Encryption 
 | 
					 | 
				
			||||||
     Systems" filed on July 31, 1995;
 | 
					 | 
				
			||||||
16.) E.P. Pat. Appl. Ser. No. 95926348.4 entitled "Elliptic Curve Encryption 
 | 
					 | 
				
			||||||
     Systems" filed on July 31, 1995;
 | 
					 | 
				
			||||||
17.) U.S. Pat. No. 6,336,188 entitled "Authenticated Key Agreement" issued 
 | 
					 | 
				
			||||||
     on January 1, 2002;
 | 
					 | 
				
			||||||
18.) U.S. Pat. No. 6,487,661 entitled "Key Agreement and Transport Protocol" 
 | 
					 | 
				
			||||||
     issued on November 26, 2002;
 | 
					 | 
				
			||||||
19.) Can. Pat. Appl. Ser. No. 2174260 entitled "Key Agreement and Transport 
 | 
					 | 
				
			||||||
     Protocol" filed on April 16, 1996;
 | 
					 | 
				
			||||||
20.) E.P. Pat. Appl. Ser. No. 96105921.9 entitled "Key Agreement and 
 | 
					 | 
				
			||||||
     Transport Protocol" filed on April 21, 1996;
 | 
					 | 
				
			||||||
21.) U.S. Pat. No. 6,563,928 entitled "Strengthened Public Key Protocol" 
 | 
					 | 
				
			||||||
     issued on May 13, 2003;
 | 
					 | 
				
			||||||
22.) U.S. Pat. No. 6,618,483 entitled "Elliptic Curve Encryption Systems" 
 | 
					 | 
				
			||||||
     issued September 9, 2003;
 | 
					 | 
				
			||||||
23.) U.S. Pat. Appl. Ser. No. 09/434,247 entitled "Digital Signatures on a 
 | 
					 | 
				
			||||||
     Smartcard" filed on November 5, 1999;
 | 
					 | 
				
			||||||
24.) U.S. Pat. Appl. Ser. No. 09/558,256 entitled "Key Agreement and 
 | 
					 | 
				
			||||||
     Transport Protocol with Implicit Signatures" filed on April 25, 2000;
 | 
					 | 
				
			||||||
25.) U.S. Pat. Appl. Ser. No. 09/942,492 entitled "Digital Signatures on a 
 | 
					 | 
				
			||||||
     Smartcard" filed on August 29, 2001 and published on July 18, 2002; and,
 | 
					 | 
				
			||||||
26.) U.S. Pat. Appl. Ser. No. 10/185,735 entitled "Strengthened Public Key 
 | 
					 | 
				
			||||||
     Protocol" filed on July 1, 2000.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
							
								
								
									
										130
									
								
								README.FIPS
									
									
									
									
									
								
							
							
						
						
									
										130
									
								
								README.FIPS
									
									
									
									
									
								
							@@ -1,130 +0,0 @@
 | 
				
			|||||||
Preliminary status and build information for FIPS module v2.0 
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
NB: if you are cross compiling you now need to use the latest "incore" script
 | 
					 | 
				
			||||||
this can be found at util/incore in the tarballs.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
If you have any object files from a previous build do:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
make clean
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
To build the module do:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
./config fipscanisteronly
 | 
					 | 
				
			||||||
make
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
Build should complete without errors.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
Build test utilities:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
make build_tests
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
Run test suite:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
test/fips_test_suite
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
again should complete without errors.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
Run test vectors: 
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
1. Download an appropriate set of testvectors from www.openssl.org/docs/fips
 | 
					 | 
				
			||||||
   only the fips-2.0 testvector files are usable for complete tests.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
2. Extract the files to a suitable directory.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
3. Run the test vector perl script, for example:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
   cd fips
 | 
					 | 
				
			||||||
   perl fipsalgtest.pl --dir=/wherever/stuff/was/extracted
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
4. It should say "passed all tests" at the end. Report full details of any
 | 
					 | 
				
			||||||
   failures.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
If you wish to use the older 1.2.x testvectors (for example those from 2007)
 | 
					 | 
				
			||||||
you need the command line switch --disable-v2 to fipsalgtest.pl
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
Examine the external symbols in fips/fipscanister.o they should all begin
 | 
					 | 
				
			||||||
with FIPS or fips. One way to check with GNU nm is:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	nm -g --defined-only fips/fipscanister.o | grep -v -i fips
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
If you get *any* output at all from this test (i.e. symbols not starting with
 | 
					 | 
				
			||||||
fips or FIPS) please report it.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
Restricted tarball tests.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
The validated module will have its own tarball containing sufficient code to
 | 
					 | 
				
			||||||
build fipscanister.o and the associated algorithm tests. You can create a
 | 
					 | 
				
			||||||
similar tarball yourself for testing purposes using the commands below.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
Standard restricted tarball:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
make -f Makefile.fips dist
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
Prime field field only ECC tarball:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
make NOEC2M=1 -f Makefile.fips dist
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
Once you've created the tarball extract into a fresh directory and do:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
./config
 | 
					 | 
				
			||||||
make
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
You can then run the algorithm tests as above. This build automatically uses
 | 
					 | 
				
			||||||
fipscanisterbuild and no-ec2m as appropriate.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
FIPS capable OpenSSL test: WARNING PRELIMINARY INSTRUCTIONS, SUBJECT TO CHANGE.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
At least initially the test module and FIPS capable OpenSSL may change and
 | 
					 | 
				
			||||||
by out of sync. You are advised to check for any changes and pull the latest
 | 
					 | 
				
			||||||
source from CVS if you have problems. See anon CVS and rsync instructions at:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
http://www.openssl.org/source/repos.html
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
Make or download a restricted tarball from ftp://ftp.openssl.org/snapshot/
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
If required set the environment variable FIPSDIR to an appropriate location
 | 
					 | 
				
			||||||
to install the test module. If cross compiling set other environment
 | 
					 | 
				
			||||||
variables too.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
In this restricted tarball on a Linux or U*ix like system run:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
./config
 | 
					 | 
				
			||||||
make
 | 
					 | 
				
			||||||
make install
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
On Windows from a VC++ environment do:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
ms\do_fips
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
This will build and install the test module and some associated files.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
Now download the latest version of the OpenSSL 1.0.1 branch from either a
 | 
					 | 
				
			||||||
snapshot or preferably CVS. For Linux do:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
./config fips [other args]
 | 
					 | 
				
			||||||
make
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
For Windows:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
perl Configure VC-WIN32 fips [other args]
 | 
					 | 
				
			||||||
ms\do_nasm
 | 
					 | 
				
			||||||
nmake -f ms\ntdll.mak
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
(or ms\nt.mak for a static build).
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
Where [other args] can be any other arguments you use for an OpenSSL build
 | 
					 | 
				
			||||||
such as "shared" or "zlib".
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
This will build the fips capable OpenSSL and link it to the test module. You
 | 
					 | 
				
			||||||
can now try linking and testing applications against the FIPS capable OpenSSL.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
Please report any problems to either the openssl-dev mailing list or directly
 | 
					 | 
				
			||||||
to me steve@openssl.org . Check the mailing lists regularly to avoid duplicate
 | 
					 | 
				
			||||||
reports.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
Known issues:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
Code needs extensively reviewing to ensure it builds correctly on 
 | 
					 | 
				
			||||||
supported platforms and is compliant with FIPS 140-2.
 | 
					 | 
				
			||||||
The "FIPS capable OpenSSL" is still largely untested, it builds and runs
 | 
					 | 
				
			||||||
some simple tests OK on some systems but needs far more "real world" testing.
 | 
					 | 
				
			||||||
							
								
								
									
										20
									
								
								STATUS
									
									
									
									
									
								
							
							
						
						
									
										20
									
								
								STATUS
									
									
									
									
									
								
							@@ -1,26 +1,10 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
  OpenSSL STATUS                           Last modified at
 | 
					  OpenSSL STATUS                           Last modified at
 | 
				
			||||||
  ______________                           $Date: 2011/02/08 17:48:56 $
 | 
					  ______________                           $Date: 2009/04/01 08:47:27 $
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  DEVELOPMENT STATE
 | 
					  DEVELOPMENT STATE
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    o  OpenSSL 1.1.0:  Under development...
 | 
					    o  OpenSSL 1.0.0-beta1: Released on Aptil 1st, 2009
 | 
				
			||||||
    o  OpenSSL 1.0.1:  Under development...
 | 
					 | 
				
			||||||
    o  OpenSSL 1.0.0d: Released on February   8nd, 2011
 | 
					 | 
				
			||||||
    o  OpenSSL 1.0.0c: Released on December   2nd, 2010
 | 
					 | 
				
			||||||
    o  OpenSSL 1.0.0b: Released on November  16th, 2010
 | 
					 | 
				
			||||||
    o  OpenSSL 1.0.0a: Released on June      1st,  2010
 | 
					 | 
				
			||||||
    o  OpenSSL 1.0.0:  Released on March     29th, 2010
 | 
					 | 
				
			||||||
    o  OpenSSL 0.9.8r: Released on February   8nd, 2011
 | 
					 | 
				
			||||||
    o  OpenSSL 0.9.8q: Released on December   2nd, 2010
 | 
					 | 
				
			||||||
    o  OpenSSL 0.9.8p: Released on November  16th, 2010
 | 
					 | 
				
			||||||
    o  OpenSSL 0.9.8o: Released on June       1st, 2010
 | 
					 | 
				
			||||||
    o  OpenSSL 0.9.8n: Released on March     24th, 2010
 | 
					 | 
				
			||||||
    o  OpenSSL 0.9.8m: Released on February  25th, 2010
 | 
					 | 
				
			||||||
    o  OpenSSL 0.9.8l: Released on November   5th, 2009
 | 
					 | 
				
			||||||
    o  OpenSSL 0.9.8k: Released on March     25th, 2009
 | 
					 | 
				
			||||||
    o  OpenSSL 0.9.8j: Released on January    7th, 2009
 | 
					 | 
				
			||||||
    o  OpenSSL 0.9.8i: Released on September 15th, 2008
 | 
					 | 
				
			||||||
    o  OpenSSL 0.9.8h: Released on May       28th, 2008
 | 
					    o  OpenSSL 0.9.8h: Released on May       28th, 2008
 | 
				
			||||||
    o  OpenSSL 0.9.8g: Released on October   19th, 2007
 | 
					    o  OpenSSL 0.9.8g: Released on October   19th, 2007
 | 
				
			||||||
    o  OpenSSL 0.9.8f: Released on October   11th, 2007
 | 
					    o  OpenSSL 0.9.8f: Released on October   11th, 2007
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,67 +0,0 @@
 | 
				
			|||||||
$! install-vms.com -- Installs the files in a given directory tree
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$! Author: Richard Levitte <richard@levitte.org>
 | 
					 | 
				
			||||||
$! Time of creation: 23-MAY-1998 19:22
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$! P1	root of the directory tree
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$! Announce/identify.
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ proc = f$environment( "procedure")
 | 
					 | 
				
			||||||
$ write sys$output "@@@ "+ -
 | 
					 | 
				
			||||||
   f$parse( proc, , , "name")+ f$parse( proc, , , "type")
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ on error then goto tidy
 | 
					 | 
				
			||||||
$ on control_c then goto tidy
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ if p1 .eqs. ""
 | 
					 | 
				
			||||||
$ then
 | 
					 | 
				
			||||||
$   write sys$output "First argument missing."
 | 
					 | 
				
			||||||
$   write sys$output -
 | 
					 | 
				
			||||||
     "Should be the directory where you want things installed."
 | 
					 | 
				
			||||||
$   exit
 | 
					 | 
				
			||||||
$ endif
 | 
					 | 
				
			||||||
$
 | 
					 | 
				
			||||||
$ 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
 | 
					 | 
				
			||||||
$
 | 
					 | 
				
			||||||
$ root = f$parse( P1, "[]A.;0", , , "SYNTAX_ONLY, NO_CONCEAL")- "A.;0"
 | 
					 | 
				
			||||||
$ root_dev = f$parse( root, , , "device", "syntax_only")
 | 
					 | 
				
			||||||
$ root_dir = f$parse( root, , , "directory", "syntax_only") - -
 | 
					 | 
				
			||||||
   "[000000." - "][" - "[" - "]"
 | 
					 | 
				
			||||||
$ root = root_dev + "[" + root_dir
 | 
					 | 
				
			||||||
$
 | 
					 | 
				
			||||||
$ define /nolog wrk_sslroot 'root'.] /translation_attributes = concealed
 | 
					 | 
				
			||||||
$ define /nolog wrk_sslinclude wrk_sslroot:[include]
 | 
					 | 
				
			||||||
$
 | 
					 | 
				
			||||||
$ if f$parse( "wrk_sslroot:[000000]") .eqs. "" then -
 | 
					 | 
				
			||||||
   create /directory /log wrk_sslroot:[000000]
 | 
					 | 
				
			||||||
$ if f$parse( "wrk_sslinclude:") .eqs. "" then -
 | 
					 | 
				
			||||||
   create /directory /log wrk_sslinclude:
 | 
					 | 
				
			||||||
$ if f$parse( "wrk_sslroot:[vms]") .eqs. "" then -
 | 
					 | 
				
			||||||
   create /directory /log wrk_sslroot:[vms]
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ copy /log /protection = world:re openssl_startup.com wrk_sslroot:[vms]
 | 
					 | 
				
			||||||
$ copy /log /protection = world:re openssl_undo.com wrk_sslroot:[vms]
 | 
					 | 
				
			||||||
$ copy /log /protection = world:re openssl_utils.com wrk_sslroot:[vms]
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ tidy:
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ call deass wrk_sslroot
 | 
					 | 
				
			||||||
$ call deass wrk_sslinclude
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ exit
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ deass: subroutine
 | 
					 | 
				
			||||||
$ if (f$trnlnm( p1, "LNM$PROCESS") .nes. "")
 | 
					 | 
				
			||||||
$ then
 | 
					 | 
				
			||||||
$   deassign /process 'p1'
 | 
					 | 
				
			||||||
$ endif
 | 
					 | 
				
			||||||
$ endsubroutine
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
							
								
								
									
										72
									
								
								VMS/install.com
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										72
									
								
								VMS/install.com
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,72 @@
 | 
				
			|||||||
 | 
					$! INSTALL.COM -- Installs the files in a given directory tree
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$! Author: Richard Levitte <richard@levitte.org>
 | 
				
			||||||
 | 
					$! Time of creation: 23-MAY-1998 19:22
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$! P1	root of the directory tree
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$	IF P1 .EQS. ""
 | 
				
			||||||
 | 
					$	THEN
 | 
				
			||||||
 | 
					$	    WRITE SYS$OUTPUT "First argument missing."
 | 
				
			||||||
 | 
					$	    WRITE SYS$OUTPUT "Should be the directory where you want things installed."
 | 
				
			||||||
 | 
					$	    EXIT
 | 
				
			||||||
 | 
					$	ENDIF
 | 
				
			||||||
 | 
					$
 | 
				
			||||||
 | 
					$	ROOT = F$PARSE(P1,"[]A.;0",,,"SYNTAX_ONLY,NO_CONCEAL") - "A.;0"
 | 
				
			||||||
 | 
					$	ROOT_DEV = F$PARSE(ROOT,,,"DEVICE","SYNTAX_ONLY")
 | 
				
			||||||
 | 
					$	ROOT_DIR = F$PARSE(ROOT,,,"DIRECTORY","SYNTAX_ONLY") -
 | 
				
			||||||
 | 
							   - "[000000." - "][" - "[" - "]"
 | 
				
			||||||
 | 
					$	ROOT = ROOT_DEV + "[" + ROOT_DIR
 | 
				
			||||||
 | 
					$
 | 
				
			||||||
 | 
					$	DEFINE/NOLOG WRK_SSLROOT 'ROOT'.] /TRANS=CONC
 | 
				
			||||||
 | 
					$	DEFINE/NOLOG WRK_SSLVLIB WRK_SSLROOT:[VAX_LIB]
 | 
				
			||||||
 | 
					$	DEFINE/NOLOG WRK_SSLALIB WRK_SSLROOT:[ALPHA_LIB]
 | 
				
			||||||
 | 
					$	DEFINE/NOLOG WRK_SSLINCLUDE WRK_SSLROOT:[INCLUDE]
 | 
				
			||||||
 | 
					$	DEFINE/NOLOG WRK_SSLVEXE WRK_SSLROOT:[VAX_EXE]
 | 
				
			||||||
 | 
					$	DEFINE/NOLOG WRK_SSLAEXE WRK_SSLROOT:[ALPHA_EXE]
 | 
				
			||||||
 | 
					$	DEFINE/NOLOG WRK_SSLCERTS WRK_SSLROOT:[CERTS]
 | 
				
			||||||
 | 
					$	DEFINE/NOLOG WRK_SSLPRIVATE WRK_SSLROOT:[PRIVATE]
 | 
				
			||||||
 | 
					$
 | 
				
			||||||
 | 
					$	IF F$PARSE("WRK_SSLROOT:[000000]") .EQS. "" THEN -
 | 
				
			||||||
 | 
						   CREATE/DIR/LOG WRK_SSLROOT:[000000]
 | 
				
			||||||
 | 
					$	IF F$PARSE("WRK_SSLINCLUDE:") .EQS. "" THEN -
 | 
				
			||||||
 | 
						   CREATE/DIR/LOG WRK_SSLINCLUDE:
 | 
				
			||||||
 | 
					$	IF F$PARSE("WRK_SSLROOT:[VMS]") .EQS. "" THEN -
 | 
				
			||||||
 | 
						   CREATE/DIR/LOG WRK_SSLROOT:[VMS]
 | 
				
			||||||
 | 
					$
 | 
				
			||||||
 | 
					$	IF F$SEARCH("WRK_SSLINCLUDE:vms_idhacks.h") .NES. "" THEN -
 | 
				
			||||||
 | 
						   DELETE WRK_SSLINCLUDE:vms_idhacks.h;*
 | 
				
			||||||
 | 
					$
 | 
				
			||||||
 | 
					$	OPEN/WRITE SF WRK_SSLROOT:[VMS]OPENSSL_STARTUP.COM
 | 
				
			||||||
 | 
					$	WRITE SYS$OUTPUT "%OPEN-I-CREATED,  ",F$SEARCH("WRK_SSLROOT:[VMS]OPENSSL_STARTUP.COM")," created."
 | 
				
			||||||
 | 
					$	WRITE SF "$! Startup file for Openssl 0.9.2-RL 15-Mar-1999"
 | 
				
			||||||
 | 
					$	WRITE SF "$!"
 | 
				
			||||||
 | 
					$	WRITE SF "$! Do not edit this file, as it will be regenerated during next installation."
 | 
				
			||||||
 | 
					$	WRITE SF "$! Instead, add or change SSLROOT:[VMS]OPENSSL_SYSTARTUP.COM"
 | 
				
			||||||
 | 
					$	WRITE SF "$!"
 | 
				
			||||||
 | 
					$	WRITE SF "$! P1	a qualifier to DEFINE.  For example ""/SYSTEM"" to get the logical names"
 | 
				
			||||||
 | 
					$	WRITE SF "$!	defined in the system logical name table."
 | 
				
			||||||
 | 
					$	WRITE SF "$!"
 | 
				
			||||||
 | 
					$	WRITE SF "$	ARCH = ""VAX"""
 | 
				
			||||||
 | 
					$	WRITE SF "$	IF F$GETSYI(""CPU"") .GE. 128 THEN ARCH = ""ALPHA"""
 | 
				
			||||||
 | 
					$	WRITE SF "$	DEFINE/NOLOG'P1	SSLROOT		",ROOT,".] /TRANS=CONC"
 | 
				
			||||||
 | 
					$	WRITE SF "$	DEFINE/NOLOG'P1	SSLLIB		SSLROOT:['ARCH'_LIB]"
 | 
				
			||||||
 | 
					$	WRITE SF "$	DEFINE/NOLOG'P1	SSLINCLUDE	SSLROOT:[INCLUDE]"
 | 
				
			||||||
 | 
					$	WRITE SF "$	DEFINE/NOLOG'P1	SSLEXE		SSLROOT:['ARCH'_EXE]"
 | 
				
			||||||
 | 
					$	WRITE SF "$	DEFINE/NOLOG'P1	SSLCERTS	SSLROOT:[CERTS]"
 | 
				
			||||||
 | 
					$	WRITE SF "$	DEFINE/NOLOG'P1	SSLPRIVATE	SSLROOT:[PRIVATE]"
 | 
				
			||||||
 | 
					$	WRITE SF "$"
 | 
				
			||||||
 | 
					$	WRITE SF "$!	This is program can include <openssl/{foo}.h>"
 | 
				
			||||||
 | 
					$	WRITE SF "$	DEFINE/NOLOG'P1	OPENSSL		SSLINCLUDE:"
 | 
				
			||||||
 | 
					$	WRITE SF "$"
 | 
				
			||||||
 | 
					$	WRITE SF "$	IF F$SEARCH(""SSLROOT:[VMS]OPENSSL_SYSTARTUP.COM"") .NES."""" THEN -"
 | 
				
			||||||
 | 
					$	WRITE SF "	   @SSLROOT:[VMS]OPENSSL_SYSTARTUP.COM"
 | 
				
			||||||
 | 
					$	WRITE SF "$"
 | 
				
			||||||
 | 
					$	WRITE SF "$	EXIT"
 | 
				
			||||||
 | 
					$	CLOSE SF
 | 
				
			||||||
 | 
					$	SET FILE/PROT=WORLD:RE WRK_SSLROOT:[VMS]OPENSSL_STARTUP.COM
 | 
				
			||||||
 | 
					$
 | 
				
			||||||
 | 
					$	COPY OPENSSL_UTILS.COM WRK_SSLROOT:[VMS]/LOG
 | 
				
			||||||
 | 
					$	SET FILE/PROT=WORLD:RE WRK_SSLROOT:[VMS]OPENSSL_UTILS.COM
 | 
				
			||||||
 | 
					$
 | 
				
			||||||
 | 
					$	EXIT
 | 
				
			||||||
							
								
								
									
										250
									
								
								VMS/mkshared.com
									
									
									
									
									
								
							
							
						
						
									
										250
									
								
								VMS/mkshared.com
									
									
									
									
									
								
							@@ -1,164 +1,77 @@
 | 
				
			|||||||
$! MKSHARED.COM -- Create shareable images.
 | 
					$! MKSHARED.COM -- script to created shareable images on VMS
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$! P1: "64" for 64-bit pointers.
 | 
					$! No command line parameters.  This should be run at the start of the source
 | 
				
			||||||
 | 
					$! tree (the same directory where one finds INSTALL.VMS).
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$! P2: Zlib object library path (optional).
 | 
					$! Input:	[.UTIL]LIBEAY.NUM,[.AXP.EXE.CRYPTO]LIBCRYPTO.OLB
 | 
				
			||||||
$!
 | 
					$!		[.UTIL]SSLEAY.NUM,[.AXP.EXE.SSL]LIBSSL.OLB
 | 
				
			||||||
$! Input:	[.UTIL]LIBEAY.NUM,[.xxx.EXE.CRYPTO]SSL_LIBCRYPTO[32].OLB
 | 
					$! Output:	[.AXP.EXE.CRYPTO]LIBCRYPTO.OPT,.MAP,.EXE
 | 
				
			||||||
$!		[.UTIL]SSLEAY.NUM,[.xxx.EXE.SSL]SSL_LIBSSL[32].OLB
 | 
					$!		[.AXP.EXE.SSL]LIBSSL.OPT,.MAP,.EXE
 | 
				
			||||||
$! Output:	[.xxx.EXE.CRYPTO]SSL_LIBCRYPTO_SHR[32].OPT,.MAP,.EXE
 | 
					 | 
				
			||||||
$!		[.xxx.EXE.SSL]SSL_LIBSSL_SRH[32].OPT,.MAP,.EXE
 | 
					 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$! So far, tests have only been made on VMS for Alpha.  VAX will come in time.
 | 
					$! So far, tests have only been made on VMS for Alpha.  VAX will come in time.
 | 
				
			||||||
$! ===========================================================================
 | 
					$! ===========================================================================
 | 
				
			||||||
$!
 | 
					$
 | 
				
			||||||
$! Announce/identify.
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ proc = f$environment( "procedure")
 | 
					 | 
				
			||||||
$ write sys$output "@@@ "+ -
 | 
					 | 
				
			||||||
   f$parse( proc, , , "name")+ f$parse( proc, , , "type")
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$! Save the original default device:[directory].
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ def_orig = f$environment( "default")
 | 
					 | 
				
			||||||
$ on error then goto tidy
 | 
					 | 
				
			||||||
$ on control_c then goto tidy
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$! SET DEFAULT to the main kit directory.
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ proc = f$environment("procedure")
 | 
					 | 
				
			||||||
$ proc = f$parse( "A.;", proc)- "A.;"
 | 
					 | 
				
			||||||
$ set default 'proc'
 | 
					 | 
				
			||||||
$ set default [-]
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$! ----- Prepare info for processing: version number and file info
 | 
					$! ----- Prepare info for processing: version number and file info
 | 
				
			||||||
$ gosub read_version_info
 | 
					$ gosub read_version_info
 | 
				
			||||||
$ if libver .eqs. ""
 | 
					$ if libver .eqs. ""
 | 
				
			||||||
$ then
 | 
					$ then
 | 
				
			||||||
$   write sys$error "ERROR: Couldn't find any library version info..."
 | 
					$   write sys$error "ERROR: Couldn't find any library version info..."
 | 
				
			||||||
$   go to tidy:
 | 
					$   exit
 | 
				
			||||||
$ endif
 | 
					$ endif
 | 
				
			||||||
$
 | 
					$
 | 
				
			||||||
$ if (f$getsyi("cpu") .lt. 128)
 | 
					$ if f$getsyi("CPU") .ge. 128
 | 
				
			||||||
$ then
 | 
					$ then
 | 
				
			||||||
$   arch_vax = 1
 | 
					$   libid  = "Crypto"
 | 
				
			||||||
$   arch = "VAX"
 | 
					$   libnum = "[.UTIL]LIBEAY.NUM"
 | 
				
			||||||
 | 
					$   libdir = "[.AXP.EXE.CRYPTO]"
 | 
				
			||||||
 | 
					$   libolb = "''libdir'LIBCRYPTO.OLB"
 | 
				
			||||||
 | 
					$   libopt = "''libdir'LIBCRYPTO.OPT"
 | 
				
			||||||
 | 
					$   libmap = "''libdir'LIBCRYPTO.MAP"
 | 
				
			||||||
 | 
					$   libgoal= "''libdir'LIBCRYPTO.EXE"
 | 
				
			||||||
 | 
					$   libref = ""
 | 
				
			||||||
 | 
					$   gosub create_axp_shr
 | 
				
			||||||
 | 
					$   libid  = "SSL"
 | 
				
			||||||
 | 
					$   libnum = "[.UTIL]SSLEAY.NUM"
 | 
				
			||||||
 | 
					$   libdir = "[.AXP.EXE.SSL]"
 | 
				
			||||||
 | 
					$   libolb = "''libdir'LIBSSL.OLB"
 | 
				
			||||||
 | 
					$   libopt = "''libdir'LIBSSL.OPT"
 | 
				
			||||||
 | 
					$   libmap = "''libdir'LIBSSL.MAP"
 | 
				
			||||||
 | 
					$   libgoal= "''libdir'LIBSSL.EXE"
 | 
				
			||||||
 | 
					$   libref = "[.AXP.EXE.CRYPTO]LIBCRYPTO.EXE"
 | 
				
			||||||
 | 
					$   gosub create_axp_shr
 | 
				
			||||||
$ else
 | 
					$ else
 | 
				
			||||||
$   arch_vax = 0
 | 
					 | 
				
			||||||
$   arch = f$edit( f$getsyi( "ARCH_NAME"), "UPCASE")
 | 
					 | 
				
			||||||
$   if (arch .eqs. "") then arch = "UNK"
 | 
					 | 
				
			||||||
$ endif
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ archd = arch
 | 
					 | 
				
			||||||
$ lib32 = "32"
 | 
					 | 
				
			||||||
$ shr = "SHR32"
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ if (p1 .nes. "")
 | 
					 | 
				
			||||||
$ then
 | 
					 | 
				
			||||||
$   if (p1 .eqs. "64")
 | 
					 | 
				
			||||||
$   then
 | 
					 | 
				
			||||||
$     archd = arch+ "_64"
 | 
					 | 
				
			||||||
$     lib32 = ""
 | 
					 | 
				
			||||||
$     shr = "SHR"
 | 
					 | 
				
			||||||
$   else
 | 
					 | 
				
			||||||
$     if (p1 .nes. "32")
 | 
					 | 
				
			||||||
$     then
 | 
					 | 
				
			||||||
$       write sys$output "Second argument invalid."
 | 
					 | 
				
			||||||
$       write sys$output "It should be "32", "64", or nothing."
 | 
					 | 
				
			||||||
$       exit
 | 
					 | 
				
			||||||
$     endif
 | 
					 | 
				
			||||||
$   endif
 | 
					 | 
				
			||||||
$ endif
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ ZLIB = p2
 | 
					 | 
				
			||||||
$ zlib_lib = ""
 | 
					 | 
				
			||||||
$ if (ZLIB .nes. "")
 | 
					 | 
				
			||||||
$ then
 | 
					 | 
				
			||||||
$   file2 = f$parse( ZLIB, "libz.olb", , , "syntax_only")
 | 
					 | 
				
			||||||
$   if (f$search( file2) .eqs. "")
 | 
					 | 
				
			||||||
$   then
 | 
					 | 
				
			||||||
$     write sys$output ""
 | 
					 | 
				
			||||||
$     write sys$output "The Option ", ZLIB, " Is Invalid."
 | 
					 | 
				
			||||||
$     write sys$output "    Can't find library: ''file2'"
 | 
					 | 
				
			||||||
$     write sys$output ""
 | 
					 | 
				
			||||||
$     goto tidy
 | 
					 | 
				
			||||||
$   endif
 | 
					 | 
				
			||||||
$   zlib_lib = ", ''file2' /library"
 | 
					 | 
				
			||||||
$ endif
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ if (arch_vax)
 | 
					 | 
				
			||||||
$ then
 | 
					 | 
				
			||||||
$   libtit = "CRYPTO_TRANSFER_VECTOR"
 | 
					$   libtit = "CRYPTO_TRANSFER_VECTOR"
 | 
				
			||||||
$   libid  = "Crypto"
 | 
					$   libid  = "Crypto"
 | 
				
			||||||
$   libnum = "[.UTIL]LIBEAY.NUM"
 | 
					$   libnum = "[.UTIL]LIBEAY.NUM"
 | 
				
			||||||
$   libdir = "[.''ARCHD'.EXE.CRYPTO]"
 | 
					$   libdir = "[.VAX.EXE.CRYPTO]"
 | 
				
			||||||
$   libmar = "''libdir'SSL_LIBCRYPTO_''shr'.MAR"
 | 
					$   libmar = "''libdir'LIBCRYPTO.MAR"
 | 
				
			||||||
$   libolb = "''libdir'SSL_LIBCRYPTO''lib32'.OLB"
 | 
					$   libolb = "''libdir'LIBCRYPTO.OLB"
 | 
				
			||||||
$   libopt = "''libdir'SSL_LIBCRYPTO_''shr'.OPT"
 | 
					$   libopt = "''libdir'LIBCRYPTO.OPT"
 | 
				
			||||||
$   libobj = "''libdir'SSL_LIBCRYPTO_''shr'.OBJ"
 | 
					$   libobj = "''libdir'LIBCRYPTO.OBJ"
 | 
				
			||||||
$   libmap = "''libdir'SSL_LIBCRYPTO_''shr'.MAP"
 | 
					$   libmap = "''libdir'LIBCRYPTO.MAP"
 | 
				
			||||||
$   libgoal= "''libdir'SSL_LIBCRYPTO_''shr'.EXE"
 | 
					$   libgoal= "''libdir'LIBCRYPTO.EXE"
 | 
				
			||||||
$   libref = ""
 | 
					$   libref = ""
 | 
				
			||||||
$   libvec = "LIBCRYPTO"
 | 
					$   libvec = "LIBCRYPTO"
 | 
				
			||||||
$   if f$search( libolb) .nes. "" then gosub create_vax_shr
 | 
					$   gosub create_vax_shr
 | 
				
			||||||
$   libtit = "SSL_TRANSFER_VECTOR"
 | 
					$   libtit = "SSL_TRANSFER_VECTOR"
 | 
				
			||||||
$   libid  = "SSL"
 | 
					$   libid  = "SSL"
 | 
				
			||||||
$   libnum = "[.UTIL]SSLEAY.NUM"
 | 
					$   libnum = "[.UTIL]SSLEAY.NUM"
 | 
				
			||||||
$   libdir = "[.''ARCHD'.EXE.SSL]"
 | 
					$   libdir = "[.VAX.EXE.SSL]"
 | 
				
			||||||
$   libmar = "''libdir'SSL_LIBSSL_''shr'.MAR"
 | 
					$   libmar = "''libdir'LIBSSL.MAR"
 | 
				
			||||||
$   libolb = "''libdir'SSL_LIBSSL''lib32'.OLB"
 | 
					$   libolb = "''libdir'LIBSSL.OLB"
 | 
				
			||||||
$   libopt = "''libdir'SSL_LIBSSL_''shr'.OPT"
 | 
					$   libopt = "''libdir'LIBSSL.OPT"
 | 
				
			||||||
$   libobj = "''libdir'SSL_LIBSSL_''shr'.OBJ"
 | 
					$   libobj = "''libdir'LIBSSL.OBJ"
 | 
				
			||||||
$   libmap = "''libdir'SSL_LIBSSL_''shr'.MAP"
 | 
					$   libmap = "''libdir'LIBSSL.MAP"
 | 
				
			||||||
$   libgoal= "''libdir'SSL_LIBSSL_''shr'.EXE"
 | 
					$   libgoal= "''libdir'LIBSSL.EXE"
 | 
				
			||||||
$   libref = "[.''ARCHD'.EXE.CRYPTO]SSL_LIBCRYPTO_''shr'.EXE"
 | 
					$   libref = "[.VAX.EXE.CRYPTO]LIBCRYPTO.EXE"
 | 
				
			||||||
$   libvec = "LIBSSL"
 | 
					$   libvec = "LIBSSL"
 | 
				
			||||||
$   if f$search( libolb) .nes. "" then gosub create_vax_shr
 | 
					$   gosub create_vax_shr
 | 
				
			||||||
$ else
 | 
					 | 
				
			||||||
$   libid  = "Crypto"
 | 
					 | 
				
			||||||
$   libnum = "[.UTIL]LIBEAY.NUM"
 | 
					 | 
				
			||||||
$   libdir = "[.''ARCHD'.EXE.CRYPTO]"
 | 
					 | 
				
			||||||
$   libolb = "''libdir'SSL_LIBCRYPTO''lib32'.OLB"
 | 
					 | 
				
			||||||
$   libopt = "''libdir'SSL_LIBCRYPTO_''shr'.OPT"
 | 
					 | 
				
			||||||
$   libmap = "''libdir'SSL_LIBCRYPTO_''shr'.MAP"
 | 
					 | 
				
			||||||
$   libgoal= "''libdir'SSL_LIBCRYPTO_''shr'.EXE"
 | 
					 | 
				
			||||||
$   libref = ""
 | 
					 | 
				
			||||||
$   if f$search( libolb) .nes. "" then gosub create_nonvax_shr
 | 
					 | 
				
			||||||
$   libid  = "SSL"
 | 
					 | 
				
			||||||
$   libnum = "[.UTIL]SSLEAY.NUM"
 | 
					 | 
				
			||||||
$   libdir = "[.''ARCHD'.EXE.SSL]"
 | 
					 | 
				
			||||||
$   libolb = "''libdir'SSL_LIBSSL''lib32'.OLB"
 | 
					 | 
				
			||||||
$   libopt = "''libdir'SSL_LIBSSL_''shr'.OPT"
 | 
					 | 
				
			||||||
$   libmap = "''libdir'SSL_LIBSSL_''shr'.MAP"
 | 
					 | 
				
			||||||
$   libgoal= "''libdir'SSL_LIBSSL_''shr'.EXE"
 | 
					 | 
				
			||||||
$   libref = "[.''ARCHD'.EXE.CRYPTO]SSL_LIBCRYPTO_''shr'.EXE"
 | 
					 | 
				
			||||||
$   if f$search( libolb) .nes. "" then gosub create_nonvax_shr
 | 
					 | 
				
			||||||
$ endif
 | 
					$ endif
 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ tidy:
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$! Close any open files.
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ if (f$trnlnm( "libnum", "LNM$PROCESS", 0, "SUPERVISOR") .nes. "") then -
 | 
					 | 
				
			||||||
   close libnum
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ if (f$trnlnm( "mar", "LNM$PROCESS", 0, "SUPERVISOR") .nes. "") then -
 | 
					 | 
				
			||||||
   close mar
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ if (f$trnlnm( "opt", "LNM$PROCESS", 0, "SUPERVISOR") .nes. "") then -
 | 
					 | 
				
			||||||
   close opt
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ if (f$trnlnm( "vf", "LNM$PROCESS", 0, "SUPERVISOR") .nes. "") then -
 | 
					 | 
				
			||||||
   close vf
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$! Restore the original default device:[directory].
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ set default 'def_orig'
 | 
					 | 
				
			||||||
$ exit
 | 
					$ exit
 | 
				
			||||||
$
 | 
					$
 | 
				
			||||||
$! ----- Subroutines to build the shareable libraries
 | 
					$! ----- Soubroutines to actually build the shareable libraries
 | 
				
			||||||
$! For each supported architecture, there's a main shareable library
 | 
					$! The way things work, there's a main shareable library creator for each
 | 
				
			||||||
$! creator, which is called from the main code above.
 | 
					$! supported architecture, which is called from the main code above.
 | 
				
			||||||
$! The creator will define a number of variables to tell the next levels of
 | 
					$! The creator will define a number of variables to tell the next levels of
 | 
				
			||||||
$! subroutines what routines to use to write to the option files, call the
 | 
					$! subroutines what routines to use to write to the option files, call the
 | 
				
			||||||
$! main processor, read_func_num, and when that is done, it will write version
 | 
					$! main processor, read_func_num, and when that is done, it will write version
 | 
				
			||||||
@@ -184,29 +97,28 @@ $! read_func_num depends on the following variables from the creator:
 | 
				
			|||||||
$! libwriter	The name of the writer routine to call for each .num file line
 | 
					$! libwriter	The name of the writer routine to call for each .num file line
 | 
				
			||||||
$! -----
 | 
					$! -----
 | 
				
			||||||
$
 | 
					$
 | 
				
			||||||
$! ----- Subroutines for non-VAX
 | 
					$! ----- Subroutines for AXP
 | 
				
			||||||
$! -----
 | 
					$! -----
 | 
				
			||||||
$! The creator routine
 | 
					$! The creator routine
 | 
				
			||||||
$ create_nonvax_shr:
 | 
					$ create_axp_shr:
 | 
				
			||||||
$   open /write opt 'libopt'
 | 
					$   open/write opt 'libopt'
 | 
				
			||||||
$   write opt "identification=""",libid," ",libverstr,""""
 | 
					$   write opt "identification=""",libid," ",libverstr,""""
 | 
				
			||||||
$   write opt libolb, " /library"
 | 
					$   write opt libolb,"/lib"
 | 
				
			||||||
$   if libref .nes. "" then write opt libref,"/SHARE"
 | 
					$   if libref .nes. "" then write opt libref,"/SHARE"
 | 
				
			||||||
$   write opt "SYMBOL_VECTOR=(-"
 | 
					$   write opt "SYMBOL_VECTOR=(-"
 | 
				
			||||||
$   libfirstentry := true
 | 
					$   libfirstentry := true
 | 
				
			||||||
$   libwrch   := opt
 | 
					$   libwrch   := opt
 | 
				
			||||||
$   libwriter := write_nonvax_transfer_entry
 | 
					$   libwriter := write_axp_transfer_entry
 | 
				
			||||||
$   textcount = 0
 | 
					$   textcount = 0
 | 
				
			||||||
$   gosub read_func_num
 | 
					$   gosub read_func_num
 | 
				
			||||||
$   write opt ")"
 | 
					$   write opt ")"
 | 
				
			||||||
$   write opt "GSMATCH=",libvmatch,",",libver
 | 
					$   write opt "GSMATCH=",libvmatch,",",libver
 | 
				
			||||||
$   close opt
 | 
					$   close opt
 | 
				
			||||||
$   link /map = 'libmap' /full /share = 'libgoal' 'libopt' /options -
 | 
					$   link/map='libmap'/full/share='libgoal' 'libopt'/option
 | 
				
			||||||
     'zlib_lib'
 | 
					 | 
				
			||||||
$   return
 | 
					$   return
 | 
				
			||||||
$
 | 
					$
 | 
				
			||||||
$! The record writer routine
 | 
					$! The record writer routine
 | 
				
			||||||
$ write_nonvax_transfer_entry:
 | 
					$ write_axp_transfer_entry:
 | 
				
			||||||
$   if libentry .eqs. ".dummy" then return
 | 
					$   if libentry .eqs. ".dummy" then return
 | 
				
			||||||
$   if info_kind .eqs. "VARIABLE"
 | 
					$   if info_kind .eqs. "VARIABLE"
 | 
				
			||||||
$   then
 | 
					$   then
 | 
				
			||||||
@@ -232,11 +144,11 @@ $   libfirstentry := false
 | 
				
			|||||||
$   textcount = textcount + textcount_this
 | 
					$   textcount = textcount + textcount_this
 | 
				
			||||||
$   return
 | 
					$   return
 | 
				
			||||||
$
 | 
					$
 | 
				
			||||||
$! ----- Subroutines for VAX
 | 
					$! ----- Subroutines for AXP
 | 
				
			||||||
$! -----
 | 
					$! -----
 | 
				
			||||||
$! The creator routine
 | 
					$! The creator routine
 | 
				
			||||||
$ create_vax_shr:
 | 
					$ create_vax_shr:
 | 
				
			||||||
$   open /write mar 'libmar'
 | 
					$   open/write mar 'libmar'
 | 
				
			||||||
$   type sys$input:/out=mar:
 | 
					$   type sys$input:/out=mar:
 | 
				
			||||||
;
 | 
					;
 | 
				
			||||||
; Transfer vector for VAX shareable image
 | 
					; Transfer vector for VAX shareable image
 | 
				
			||||||
@@ -271,10 +183,10 @@ $!   libwriter := write_vax_vtransfer_entry
 | 
				
			|||||||
$!   gosub read_func_num
 | 
					$!   gosub read_func_num
 | 
				
			||||||
$   write mar "	.END"
 | 
					$   write mar "	.END"
 | 
				
			||||||
$   close mar
 | 
					$   close mar
 | 
				
			||||||
$   open /write opt 'libopt'
 | 
					$   open/write opt 'libopt'
 | 
				
			||||||
$   write opt "identification=""",libid," ",libverstr,""""
 | 
					$   write opt "identification=""",libid," ",libverstr,""""
 | 
				
			||||||
$   write opt libobj
 | 
					$   write opt libobj
 | 
				
			||||||
$   write opt libolb, " /library"
 | 
					$   write opt libolb,"/lib"
 | 
				
			||||||
$   if libref .nes. "" then write opt libref,"/SHARE"
 | 
					$   if libref .nes. "" then write opt libref,"/SHARE"
 | 
				
			||||||
$   type sys$input:/out=opt:
 | 
					$   type sys$input:/out=opt:
 | 
				
			||||||
!
 | 
					!
 | 
				
			||||||
@@ -293,8 +205,7 @@ $   libwriter := write_vax_psect_attr
 | 
				
			|||||||
$   gosub read_func_num
 | 
					$   gosub read_func_num
 | 
				
			||||||
$   close opt
 | 
					$   close opt
 | 
				
			||||||
$   macro/obj='libobj' 'libmar'
 | 
					$   macro/obj='libobj' 'libmar'
 | 
				
			||||||
$   link /map = 'libmap' /full /share = 'libgoal' 'libopt' /options -
 | 
					$   link/map='libmap'/full/share='libgoal' 'libopt'/option
 | 
				
			||||||
     'zlib_lib'
 | 
					 | 
				
			||||||
$   return
 | 
					$   return
 | 
				
			||||||
$
 | 
					$
 | 
				
			||||||
$! The record writer routine for VAX functions
 | 
					$! The record writer routine for VAX functions
 | 
				
			||||||
@@ -316,9 +227,9 @@ $   return
 | 
				
			|||||||
$
 | 
					$
 | 
				
			||||||
$! ----- Common subroutines
 | 
					$! ----- Common subroutines
 | 
				
			||||||
$! -----
 | 
					$! -----
 | 
				
			||||||
$! The .num file reader.  This one has great responsibility.
 | 
					$! The .num file reader.  This one has great responsability.
 | 
				
			||||||
$ read_func_num:
 | 
					$ read_func_num:
 | 
				
			||||||
$   open /read libnum 'libnum'
 | 
					$   open libnum 'libnum'
 | 
				
			||||||
$   goto read_nums
 | 
					$   goto read_nums
 | 
				
			||||||
$
 | 
					$
 | 
				
			||||||
$ read_nums:
 | 
					$ read_nums:
 | 
				
			||||||
@@ -326,46 +237,35 @@ $   libentrynum=0
 | 
				
			|||||||
$   liblastentry:=false
 | 
					$   liblastentry:=false
 | 
				
			||||||
$   entrycount=0
 | 
					$   entrycount=0
 | 
				
			||||||
$   loop:
 | 
					$   loop:
 | 
				
			||||||
$     read /end=loop_end /err=loop_end libnum line
 | 
					$     read/end=loop_end/err=loop_end libnum line
 | 
				
			||||||
$     lin = f$edit( line, "COMPRESS,TRIM")
 | 
					$     entrynum=f$int(f$element(1," ",f$edit(line,"COMPRESS,TRIM")))
 | 
				
			||||||
$!    Skip a "#" comment line.
 | 
					$     entryinfo=f$element(2," ",f$edit(line,"COMPRESS,TRIM"))
 | 
				
			||||||
$     if (f$extract( 0, 1, lin) .eqs. "#") then goto loop
 | 
					$     curentry=f$element(0," ",f$edit(line,"COMPRESS,TRIM"))
 | 
				
			||||||
$     entrynum = f$int(f$element( 1, " ", lin))
 | 
					$     info_exist=f$element(0,":",entryinfo)
 | 
				
			||||||
$     entryinfo = f$element( 2, " ", lin)
 | 
					$     info_platforms=","+f$element(1,":",entryinfo)+","
 | 
				
			||||||
$     curentry = f$element( 0, " ", lin)
 | 
					$     info_kind=f$element(2,":",entryinfo)
 | 
				
			||||||
$     info_exist = f$element( 0, ":", entryinfo)
 | 
					$     info_algorithms=","+f$element(3,":",entryinfo)+","
 | 
				
			||||||
$     info_platforms = ","+ f$element(1, ":", entryinfo)+ ","
 | 
					 | 
				
			||||||
$     info_kind = f$element( 2, ":", entryinfo)
 | 
					 | 
				
			||||||
$     info_algorithms = ","+ f$element( 3, ":", entryinfo)+ ","
 | 
					 | 
				
			||||||
$     if info_exist .eqs. "NOEXIST" then goto loop
 | 
					$     if info_exist .eqs. "NOEXIST" then goto loop
 | 
				
			||||||
$     truesum = 0
 | 
					$     truesum = 0
 | 
				
			||||||
$     falsesum = 0
 | 
					$     falsesum = 0
 | 
				
			||||||
$     negatives = 1
 | 
					$     negatives = 1
 | 
				
			||||||
$     plat_i = 0
 | 
					$     plat_i = 0
 | 
				
			||||||
$     loop1:
 | 
					$     loop1:
 | 
				
			||||||
$       plat_entry = f$element( plat_i, ",", info_platforms)
 | 
					$       plat_entry = f$element(plat_i,",",info_platforms)
 | 
				
			||||||
$       plat_i = plat_i + 1
 | 
					$       plat_i = plat_i + 1
 | 
				
			||||||
$       if plat_entry .eqs. "" then goto loop1
 | 
					$       if plat_entry .eqs. "" then goto loop1
 | 
				
			||||||
$       if plat_entry .nes. ","
 | 
					$       if plat_entry .nes. ","
 | 
				
			||||||
$       then
 | 
					$       then
 | 
				
			||||||
$         if f$extract(0,1,plat_entry) .nes. "!" then negatives = 0
 | 
					$         if f$extract(0,1,plat_entry) .nes. "!" then negatives = 0
 | 
				
			||||||
$         if (arch_vax)
 | 
					$         if f$getsyi("CPU") .lt. 128
 | 
				
			||||||
$         then
 | 
					$         then
 | 
				
			||||||
$           if plat_entry .eqs. "EXPORT_VAR_AS_FUNCTION" then -
 | 
					$           if plat_entry .eqs. "EXPORT_VAR_AS_FUNCTION" then -
 | 
				
			||||||
$             truesum = truesum + 1
 | 
					$             truesum = truesum + 1
 | 
				
			||||||
$           if plat_entry .eqs. "!EXPORT_VAR_AS_FUNCTION" then -
 | 
					$           if plat_entry .eqs. "!EXPORT_VAR_AS_FUNCTION" then -
 | 
				
			||||||
$             falsesum = falsesum + 1
 | 
					$             falsesum = falsesum + 1
 | 
				
			||||||
$         endif
 | 
					$         endif
 | 
				
			||||||
$!
 | 
					$         if plat_entry .eqs. "VMS" then truesum = truesum + 1
 | 
				
			||||||
$         if ((plat_entry .eqs. "VMS") .or. -
 | 
					$         if plat_entry .eqs. "!VMS" then falsesum = falsesum + 1
 | 
				
			||||||
            ((plat_entry .eqs. "ZLIB") .and. (ZLIB .nes. "")) .or. -
 | 
					 | 
				
			||||||
            (arch_vax .and. (plat_entry .eqs. "VMSVAX"))) then -
 | 
					 | 
				
			||||||
            truesum = truesum + 1
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$         if ((plat_entry .eqs. "!VMS") .or. -
 | 
					 | 
				
			||||||
            (arch_vax .and. (plat_entry .eqs. "!VMSVAX"))) then -
 | 
					 | 
				
			||||||
            falsesum = falsesum + 1
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$	  goto loop1
 | 
					$	  goto loop1
 | 
				
			||||||
$       endif
 | 
					$       endif
 | 
				
			||||||
$     endloop1:
 | 
					$     endloop1:
 | 
				
			||||||
@@ -428,7 +328,7 @@ $
 | 
				
			|||||||
$! The version number reader
 | 
					$! The version number reader
 | 
				
			||||||
$ read_version_info:
 | 
					$ read_version_info:
 | 
				
			||||||
$   libver = ""
 | 
					$   libver = ""
 | 
				
			||||||
$   open /read vf [.CRYPTO]OPENSSLV.H
 | 
					$   open/read vf [.CRYPTO]OPENSSLV.H
 | 
				
			||||||
$   loop_rvi:
 | 
					$   loop_rvi:
 | 
				
			||||||
$     read/err=endloop_rvi/end=endloop_rvi vf rvi_line
 | 
					$     read/err=endloop_rvi/end=endloop_rvi vf rvi_line
 | 
				
			||||||
$     if rvi_line - "SHLIB_VERSION_NUMBER """ .eqs. rvi_line then -
 | 
					$     if rvi_line - "SHLIB_VERSION_NUMBER """ .eqs. rvi_line then -
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,108 +0,0 @@
 | 
				
			|||||||
$!
 | 
					 | 
				
			||||||
$! Startup file for OpenSSL 1.x.
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$! 2011-03-05 SMS.
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$! This procedure must reside in the OpenSSL installation directory.
 | 
					 | 
				
			||||||
$! It will fail if it is copied to a different location.
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$! P1  qualifier(s) for DEFINE.  For example, "/SYSTEM" to get the
 | 
					 | 
				
			||||||
$!     logical names defined in the system logical name table.
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$! P2  "64", to use executables which were built with 64-bit pointers.
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$! Good (default) and bad status values.
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ status =    %x00010001 ! RMS$_NORMAL, normal successful completion.
 | 
					 | 
				
			||||||
$ rms_e_fnf = %x00018292 ! RMS$_FNF, file not found.
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$! Prepare for problems.
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ orig_dev_dir = f$environment( "DEFAULT")
 | 
					 | 
				
			||||||
$ on control_y then goto clean_up
 | 
					 | 
				
			||||||
$ on error then goto clean_up
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$! Determine hardware architecture.
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ if (f$getsyi( "cpu") .lt. 128)
 | 
					 | 
				
			||||||
$ then
 | 
					 | 
				
			||||||
$   arch_name = "VAX"
 | 
					 | 
				
			||||||
$ else
 | 
					 | 
				
			||||||
$   arch_name = f$edit( f$getsyi( "arch_name"), "upcase")
 | 
					 | 
				
			||||||
$   if (arch_name .eqs. "") then arch_name = "UNK"
 | 
					 | 
				
			||||||
$ endif
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ if (p2 .eqs. "64")
 | 
					 | 
				
			||||||
$ then
 | 
					 | 
				
			||||||
$   arch_name_exe = arch_name+ "_64"
 | 
					 | 
				
			||||||
$ else
 | 
					 | 
				
			||||||
$   arch_name_exe = arch_name
 | 
					 | 
				
			||||||
$ endif
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$! Derive the OpenSSL installation device:[directory] from the location
 | 
					 | 
				
			||||||
$! of this command procedure.
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ proc = f$environment( "procedure")
 | 
					 | 
				
			||||||
$ proc_dev_dir = f$parse( "A.;", proc, , , "no_conceal") - "A.;"
 | 
					 | 
				
			||||||
$ proc_dev = f$parse( proc_dev_dir, , , "device", "syntax_only")
 | 
					 | 
				
			||||||
$ proc_dir = f$parse( proc_dev_dir, , , "directory", "syntax_only") - -
 | 
					 | 
				
			||||||
   ".][000000"- "[000000."- "]["- "["- "]"
 | 
					 | 
				
			||||||
$ proc_dev_dir = proc_dev+ "["+ proc_dir+ "]"
 | 
					 | 
				
			||||||
$ set default 'proc_dev_dir'
 | 
					 | 
				
			||||||
$ set default [-]
 | 
					 | 
				
			||||||
$ ossl_dev_dir = f$environment( "default")
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$! Check existence of expected directories (to see if this procedure has
 | 
					 | 
				
			||||||
$! been moved away from its proper place).
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ if ((f$search( "certs.dir;1") .eqs. "") .or. -
 | 
					 | 
				
			||||||
   (f$search( "include.dir;1") .eqs. "") .or. -
 | 
					 | 
				
			||||||
   (f$search( "private.dir;1") .eqs. "") .or. -
 | 
					 | 
				
			||||||
   (f$search( "vms.dir;1") .eqs. ""))
 | 
					 | 
				
			||||||
$ then
 | 
					 | 
				
			||||||
$    write sys$output -
 | 
					 | 
				
			||||||
      "   Can't find expected common OpenSSL directories in:"
 | 
					 | 
				
			||||||
$    write sys$output "   ''ossl_dev_dir'"
 | 
					 | 
				
			||||||
$    status = rms_e_fnf
 | 
					 | 
				
			||||||
$    goto clean_up
 | 
					 | 
				
			||||||
$ endif
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ if ((f$search( "''arch_name_exe'_exe.dir;1") .eqs. "") .or. -
 | 
					 | 
				
			||||||
   (f$search( "''arch_name'_lib.dir;1") .eqs. ""))
 | 
					 | 
				
			||||||
$ then
 | 
					 | 
				
			||||||
$    write sys$output -
 | 
					 | 
				
			||||||
      "   Can't find expected architecture-specific OpenSSL directories in:"
 | 
					 | 
				
			||||||
$    write sys$output "   ''ossl_dev_dir'"
 | 
					 | 
				
			||||||
$    status = rms_e_fnf
 | 
					 | 
				
			||||||
$    goto clean_up
 | 
					 | 
				
			||||||
$ endif
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$! All seems well (enough).  Define the OpenSSL logical names.
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ ossl_root = ossl_dev_dir- "]"+ ".]"
 | 
					 | 
				
			||||||
$ define /translation_attributes = concealed /nolog'p1 SSLROOT 'ossl_root'
 | 
					 | 
				
			||||||
$ define /nolog 'p1' SSLCERTS     sslroot:[certs]
 | 
					 | 
				
			||||||
$ define /nolog 'p1' SSLINCLUDE   sslroot:[include]
 | 
					 | 
				
			||||||
$ define /nolog 'p1' SSLPRIVATE   sslroot:[private]
 | 
					 | 
				
			||||||
$ define /nolog 'p1' SSLEXE       sslroot:['arch_name_exe'_exe]
 | 
					 | 
				
			||||||
$ define /nolog 'p1' SSLLIB       sslroot:['arch_name'_lib]
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$! Defining OPENSSL lets a C program use "#include <openssl/{foo}.h>":
 | 
					 | 
				
			||||||
$ define /nolog 'p1' OPENSSL      SSLINCLUDE:
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$! Run a site-specific procedure, if it exists.
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ if f$search( "sslroot:[vms]openssl_systartup.com") .nes."" then -
 | 
					 | 
				
			||||||
   @ sslroot:[vms]openssl_systartup.com
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$! Restore the original default dev:[dir] (if known).
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ clean_up:
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ if (f$type( orig_dev_dir) .nes. "")
 | 
					 | 
				
			||||||
$ then
 | 
					 | 
				
			||||||
$    set default 'orig_dev_dir'
 | 
					 | 
				
			||||||
$ endif
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ EXIT 'status'
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
@@ -1,20 +0,0 @@
 | 
				
			|||||||
$!
 | 
					 | 
				
			||||||
$! Deassign OpenSSL logical names.
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ call deass "OPENSSL" "''p1'"
 | 
					 | 
				
			||||||
$ call deass "SSLCERTS" "''p1'"
 | 
					 | 
				
			||||||
$ call deass "SSLEXE" "''p1'"
 | 
					 | 
				
			||||||
$ call deass "SSLINCLUDE" "''p1'"
 | 
					 | 
				
			||||||
$ call deass "SSLLIB" "''p1'"
 | 
					 | 
				
			||||||
$ call deass "SSLPRIVATE" "''p1'"
 | 
					 | 
				
			||||||
$ call deass "SSLROOT" "''p1'"
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ exit
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$deass: subroutine
 | 
					 | 
				
			||||||
$ if (f$trnlnm( p1) .nes. "")
 | 
					 | 
				
			||||||
$ then
 | 
					 | 
				
			||||||
$    deassign 'p2' 'p1'
 | 
					 | 
				
			||||||
$ endif
 | 
					 | 
				
			||||||
$ endsubroutine
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
@@ -8,39 +8,31 @@ $!
 | 
				
			|||||||
$!
 | 
					$!
 | 
				
			||||||
$! Slightly modified by Richard Levitte <richard@levitte.org>
 | 
					$! Slightly modified by Richard Levitte <richard@levitte.org>
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$! Always define OPENSSL.  Others are optional (non-null P1).
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ OPENSSL  :== $SSLEXE:OPENSSL
 | 
					$ OPENSSL  :== $SSLEXE:OPENSSL
 | 
				
			||||||
$
 | 
					$ VERIFY   :== $SSLEXE:OPENSSL VERIFY
 | 
				
			||||||
$ IF (P1 .NES. "")
 | 
					$ ASN1PARSE:== $SSLEXE:OPENSSL ASN1PARS
 | 
				
			||||||
$ THEN
 | 
					$ REQ      :== $SSLEXE:OPENSSL REQ
 | 
				
			||||||
$     VERIFY   :== $SSLEXE:OPENSSL VERIFY
 | 
					$ DGST     :== $SSLEXE:OPENSSL DGST
 | 
				
			||||||
$     ASN1PARSE:== $SSLEXE:OPENSSL ASN1PARS
 | 
					$ DH       :== $SSLEXE:OPENSSL DH
 | 
				
			||||||
$! REQ could conflict with REQUEST.
 | 
					$ ENC      :== $SSLEXE:OPENSSL ENC
 | 
				
			||||||
$     OREQ     :== $SSLEXE:OPENSSL REQ
 | 
					$ GENDH    :== $SSLEXE:OPENSSL GENDH
 | 
				
			||||||
$     DGST     :== $SSLEXE:OPENSSL DGST
 | 
					$ ERRSTR   :== $SSLEXE:OPENSSL ERRSTR
 | 
				
			||||||
$     DH       :== $SSLEXE:OPENSSL DH
 | 
					$ CA       :== $SSLEXE:OPENSSL CA
 | 
				
			||||||
$     ENC      :== $SSLEXE:OPENSSL ENC
 | 
					$ CRL      :== $SSLEXE:OPENSSL CRL
 | 
				
			||||||
$     GENDH    :== $SSLEXE:OPENSSL GENDH
 | 
					$ RSA      :== $SSLEXE:OPENSSL RSA
 | 
				
			||||||
$     ERRSTR   :== $SSLEXE:OPENSSL ERRSTR
 | 
					$ DSA      :== $SSLEXE:OPENSSL DSA
 | 
				
			||||||
$     CA       :== $SSLEXE:OPENSSL CA
 | 
					$ DSAPARAM :== $SSLEXE:OPENSSL DSAPARAM
 | 
				
			||||||
$     CRL      :== $SSLEXE:OPENSSL CRL
 | 
					$ X509     :== $SSLEXE:OPENSSL X509
 | 
				
			||||||
$     RSA      :== $SSLEXE:OPENSSL RSA
 | 
					$ GENRSA   :== $SSLEXE:OPENSSL GENRSA
 | 
				
			||||||
$     DSA      :== $SSLEXE:OPENSSL DSA
 | 
					$ GENDSA   :== $SSLEXE:OPENSSL GENDSA
 | 
				
			||||||
$     DSAPARAM :== $SSLEXE:OPENSSL DSAPARAM
 | 
					$ S_SERVER :== $SSLEXE:OPENSSL S_SERVER
 | 
				
			||||||
$     X509     :== $SSLEXE:OPENSSL X509
 | 
					$ S_CLIENT :== $SSLEXE:OPENSSL S_CLIENT
 | 
				
			||||||
$     GENRSA   :== $SSLEXE:OPENSSL GENRSA
 | 
					$ SPEED    :== $SSLEXE:OPENSSL SPEED
 | 
				
			||||||
$     GENDSA   :== $SSLEXE:OPENSSL GENDSA
 | 
					$ S_TIME   :== $SSLEXE:OPENSSL S_TIME
 | 
				
			||||||
$     S_SERVER :== $SSLEXE:OPENSSL S_SERVER
 | 
					$ VERSION  :== $SSLEXE:OPENSSL VERSION
 | 
				
			||||||
$     S_CLIENT :== $SSLEXE:OPENSSL S_CLIENT
 | 
					$ PKCS7    :== $SSLEXE:OPENSSL PKCS7
 | 
				
			||||||
$     SPEED    :== $SSLEXE:OPENSSL SPEED
 | 
					$ CRL2PKCS7:== $SSLEXE:OPENSSL CRL2P7
 | 
				
			||||||
$     S_TIME   :== $SSLEXE:OPENSSL S_TIME
 | 
					$ SESS_ID  :== $SSLEXE:OPENSSL SESS_ID
 | 
				
			||||||
$     VERSION  :== $SSLEXE:OPENSSL VERSION
 | 
					$ CIPHERS  :== $SSLEXE:OPENSSL CIPHERS
 | 
				
			||||||
$     PKCS7    :== $SSLEXE:OPENSSL PKCS7
 | 
					$ NSEQ     :== $SSLEXE:OPENSSL NSEQ
 | 
				
			||||||
$     CRL2PKCS7:== $SSLEXE:OPENSSL CRL2P7
 | 
					$ PKCS12   :== $SSLEXE:OPENSSL PKCS12
 | 
				
			||||||
$     SESS_ID  :== $SSLEXE:OPENSSL SESS_ID
 | 
					 | 
				
			||||||
$     CIPHERS  :== $SSLEXE:OPENSSL CIPHERS
 | 
					 | 
				
			||||||
$     NSEQ     :== $SSLEXE:OPENSSL NSEQ
 | 
					 | 
				
			||||||
$     PKCS12   :== $SSLEXE:OPENSSL PKCS12
 | 
					 | 
				
			||||||
$ ENDIF
 | 
					 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										100
									
								
								apps/CA.com
									
									
									
									
									
								
							
							
						
						
									
										100
									
								
								apps/CA.com
									
									
									
									
									
								
							@@ -37,25 +37,14 @@ $ VERIFY = openssl + " verify"
 | 
				
			|||||||
$ X509   = openssl + " x509"
 | 
					$ X509   = openssl + " x509"
 | 
				
			||||||
$ PKCS12 = openssl + " pkcs12"
 | 
					$ PKCS12 = openssl + " pkcs12"
 | 
				
			||||||
$ echo   = "write sys$Output"
 | 
					$ echo   = "write sys$Output"
 | 
				
			||||||
$ RET = 1
 | 
					 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$! 2010-12-20 SMS.
 | 
					$ s = F$PARSE(F$ENVIRONMENT("DEFAULT"),"[]") - "].;"
 | 
				
			||||||
$! Use a concealed logical name to reduce command line lengths, to
 | 
					$ CATOP  := 's'.demoCA
 | 
				
			||||||
$! avoid DCL errors on VAX:
 | 
					$ CAKEY  := ]cakey.pem
 | 
				
			||||||
$!     %DCL-W-TKNOVF, command element is too long - shorten
 | 
					$ CACERT := ]cacert.pem
 | 
				
			||||||
$! (Path segments like "openssl-1_0_1-stable-SNAP-20101217" accumulate
 | 
					 | 
				
			||||||
$! quickly.)
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ CATOP = F$PARSE( F$ENVIRONMENT( "DEFAULT"), "[]")- "].;"+ ".demoCA.]"
 | 
					 | 
				
			||||||
$ define /translation_attributes = concealed CATOP 'CATOP'
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ on error then goto clean_up
 | 
					 | 
				
			||||||
$ on control_y then goto clean_up
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ CAKEY  = "CATOP:[private]cakey.pem"
 | 
					 | 
				
			||||||
$ CACERT = "CATOP:[000000]cacert.pem"
 | 
					 | 
				
			||||||
$
 | 
					$
 | 
				
			||||||
$ __INPUT := SYS$COMMAND
 | 
					$ __INPUT := SYS$COMMAND
 | 
				
			||||||
 | 
					$ RET = 1
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$ i = 1
 | 
					$ i = 1
 | 
				
			||||||
$opt_loop:
 | 
					$opt_loop:
 | 
				
			||||||
@@ -66,7 +55,7 @@ $
 | 
				
			|||||||
$ IF (prog_opt .EQS. "?" .OR. prog_opt .EQS. "-h" .OR. prog_opt .EQS. "-help") 
 | 
					$ IF (prog_opt .EQS. "?" .OR. prog_opt .EQS. "-h" .OR. prog_opt .EQS. "-help") 
 | 
				
			||||||
$ THEN
 | 
					$ THEN
 | 
				
			||||||
$   echo "usage: CA -newcert|-newreq|-newca|-sign|-verify" 
 | 
					$   echo "usage: CA -newcert|-newreq|-newca|-sign|-verify" 
 | 
				
			||||||
$   goto clean_up
 | 
					$   exit
 | 
				
			||||||
$ ENDIF
 | 
					$ ENDIF
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$ IF (prog_opt .EQS. "-input")
 | 
					$ IF (prog_opt .EQS. "-input")
 | 
				
			||||||
@@ -80,7 +69,7 @@ $!
 | 
				
			|||||||
$ IF (prog_opt .EQS. "-newcert")
 | 
					$ IF (prog_opt .EQS. "-newcert")
 | 
				
			||||||
$ THEN
 | 
					$ THEN
 | 
				
			||||||
$   ! Create a certificate.
 | 
					$   ! Create a certificate.
 | 
				
			||||||
$   DEFINE /USER_MODE SYS$INPUT '__INPUT'
 | 
					$   DEFINE/USER SYS$INPUT '__INPUT'
 | 
				
			||||||
$   REQ -new -x509 -keyout newreq.pem -out newreq.pem 'DAYS'
 | 
					$   REQ -new -x509 -keyout newreq.pem -out newreq.pem 'DAYS'
 | 
				
			||||||
$   RET=$STATUS
 | 
					$   RET=$STATUS
 | 
				
			||||||
$   echo "Certificate (and private key) is in newreq.pem"
 | 
					$   echo "Certificate (and private key) is in newreq.pem"
 | 
				
			||||||
@@ -90,7 +79,7 @@ $!
 | 
				
			|||||||
$ IF (prog_opt .EQS. "-newreq")
 | 
					$ IF (prog_opt .EQS. "-newreq")
 | 
				
			||||||
$ THEN
 | 
					$ THEN
 | 
				
			||||||
$   ! Create a certificate request
 | 
					$   ! Create a certificate request
 | 
				
			||||||
$   DEFINE /USER_MODE SYS$INPUT '__INPUT'
 | 
					$   DEFINE/USER SYS$INPUT '__INPUT'
 | 
				
			||||||
$   REQ -new -keyout newreq.pem -out newreq.pem 'DAYS'
 | 
					$   REQ -new -keyout newreq.pem -out newreq.pem 'DAYS'
 | 
				
			||||||
$   RET=$STATUS
 | 
					$   RET=$STATUS
 | 
				
			||||||
$   echo "Request (and private key) is in newreq.pem"
 | 
					$   echo "Request (and private key) is in newreq.pem"
 | 
				
			||||||
@@ -101,40 +90,41 @@ $ IF (prog_opt .EQS. "-newca")
 | 
				
			|||||||
$ THEN
 | 
					$ THEN
 | 
				
			||||||
$   ! If explicitly asked for or it doesn't exist then setup the directory
 | 
					$   ! If explicitly asked for or it doesn't exist then setup the directory
 | 
				
			||||||
$   ! structure that Eric likes to manage things.
 | 
					$   ! structure that Eric likes to manage things.
 | 
				
			||||||
$   IF F$SEARCH( "CATOP:[000000]serial.") .EQS. ""
 | 
					$   IF F$SEARCH(CATOP+"]serial.") .EQS. ""
 | 
				
			||||||
$   THEN
 | 
					$   THEN
 | 
				
			||||||
$     CREATE /DIRECTORY /PROTECTION=OWNER:RWED CATOP:[000000]
 | 
					$     CREATE /DIR /PROTECTION=OWNER:RWED 'CATOP']
 | 
				
			||||||
$     CREATE /DIRECTORY /PROTECTION=OWNER:RWED CATOP:[certs]
 | 
					$     CREATE /DIR /PROTECTION=OWNER:RWED 'CATOP'.certs]
 | 
				
			||||||
$     CREATE /DIRECTORY /PROTECTION=OWNER:RWED CATOP:[crl]
 | 
					$     CREATE /DIR /PROTECTION=OWNER:RWED 'CATOP'.crl]
 | 
				
			||||||
$     CREATE /DIRECTORY /PROTECTION=OWNER:RWED CATOP:[newcerts]
 | 
					$     CREATE /DIR /PROTECTION=OWNER:RWED 'CATOP'.newcerts]
 | 
				
			||||||
$     CREATE /DIRECTORY /PROTECTION=OWNER:RWED CATOP:[private]
 | 
					$     CREATE /DIR /PROTECTION=OWNER:RWED 'CATOP'.private]
 | 
				
			||||||
$
 | 
					$
 | 
				
			||||||
$     OPEN /WRITE ser_file CATOP:[000000]serial. 
 | 
					$     OPEN   /WRITE ser_file 'CATOP']serial. 
 | 
				
			||||||
$     WRITE ser_file "01"
 | 
					$     WRITE ser_file "01"
 | 
				
			||||||
$     CLOSE ser_file
 | 
					$     CLOSE ser_file
 | 
				
			||||||
$     APPEND /NEW_VERSION NL: CATOP:[000000]index.txt
 | 
					$     APPEND/NEW NL: 'CATOP']index.txt
 | 
				
			||||||
$
 | 
					$
 | 
				
			||||||
$     ! The following is to make sure access() doesn't get confused.  It
 | 
					$     ! The following is to make sure access() doesn't get confused.  It
 | 
				
			||||||
$     ! really needs one file in the directory to give correct answers...
 | 
					$     ! really needs one file in the directory to give correct answers...
 | 
				
			||||||
$     COPY NLA0: CATOP:[certs].;
 | 
					$     COPY NLA0: 'CATOP'.certs].;
 | 
				
			||||||
$     COPY NLA0: CATOP:[crl].;
 | 
					$     COPY NLA0: 'CATOP'.crl].;
 | 
				
			||||||
$     COPY NLA0: CATOP:[newcerts].;
 | 
					$     COPY NLA0: 'CATOP'.newcerts].;
 | 
				
			||||||
$     COPY NLA0: CATOP:[private].;
 | 
					$     COPY NLA0: 'CATOP'.private].;
 | 
				
			||||||
$   ENDIF
 | 
					$   ENDIF
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$   IF F$SEARCH( CAKEY) .EQS. ""
 | 
					$   IF F$SEARCH(CATOP+".private"+CAKEY) .EQS. ""
 | 
				
			||||||
$   THEN
 | 
					$   THEN
 | 
				
			||||||
$     READ '__INPUT' FILE -
 | 
					$     READ '__INPUT' FILE -
 | 
				
			||||||
       /PROMPT="CA certificate filename (or enter to create): "
 | 
						   /PROMT="CA certificate filename (or enter to create)"
 | 
				
			||||||
$     IF (FILE .NES. "") .AND. (F$SEARCH(FILE) .NES. "")
 | 
					$     IF F$SEARCH(FILE) .NES. ""
 | 
				
			||||||
$     THEN
 | 
					$     THEN
 | 
				
			||||||
$       COPY 'FILE' 'CAKEY'
 | 
					$       COPY 'FILE' 'CATOP'.private'CAKEY'
 | 
				
			||||||
$       RET=$STATUS
 | 
					$	RET=$STATUS
 | 
				
			||||||
$     ELSE
 | 
					$     ELSE
 | 
				
			||||||
$       echo "Making CA certificate ..."
 | 
					$       echo "Making CA certificate ..."
 | 
				
			||||||
$       DEFINE /USER_MODE SYS$INPUT '__INPUT'
 | 
					$       DEFINE/USER SYS$INPUT '__INPUT'
 | 
				
			||||||
$       REQ -new -x509 -keyout 'CAKEY' -out 'CACERT' 'DAYS'
 | 
					$       REQ -new -x509 -keyout 'CATOP'.private'CAKEY' -
 | 
				
			||||||
$       RET=$STATUS
 | 
							       -out 'CATOP''CACERT' 'DAYS'
 | 
				
			||||||
 | 
					$	RET=$STATUS
 | 
				
			||||||
$     ENDIF
 | 
					$     ENDIF
 | 
				
			||||||
$   ENDIF
 | 
					$   ENDIF
 | 
				
			||||||
$   GOTO opt_loop_continue
 | 
					$   GOTO opt_loop_continue
 | 
				
			||||||
@@ -145,16 +135,16 @@ $ THEN
 | 
				
			|||||||
$   i = i + 1
 | 
					$   i = i + 1
 | 
				
			||||||
$   cname = P'i'
 | 
					$   cname = P'i'
 | 
				
			||||||
$   IF cname .EQS. "" THEN cname = "My certificate"
 | 
					$   IF cname .EQS. "" THEN cname = "My certificate"
 | 
				
			||||||
$   PKCS12 -in newcert.pem -inkey newreq.pem -certfile 'CACERT' -
 | 
					$   PKCS12 -in newcert.pem -inkey newreq.pem -certfile 'CATOP''CACERT -
 | 
				
			||||||
     -out newcert.p12 -export -name "''cname'"
 | 
						   -out newcert.p12 -export -name "''cname'"
 | 
				
			||||||
$   RET=$STATUS
 | 
					$   RET=$STATUS
 | 
				
			||||||
$   goto clean_up
 | 
					$   exit RET
 | 
				
			||||||
$ ENDIF
 | 
					$ ENDIF
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$ IF (prog_opt .EQS. "-xsign")
 | 
					$ IF (prog_opt .EQS. "-xsign")
 | 
				
			||||||
$ THEN
 | 
					$ THEN
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$   DEFINE /USER_MODE SYS$INPUT '__INPUT'
 | 
					$   DEFINE/USER SYS$INPUT '__INPUT'
 | 
				
			||||||
$   CA -policy policy_anything -infiles newreq.pem
 | 
					$   CA -policy policy_anything -infiles newreq.pem
 | 
				
			||||||
$   RET=$STATUS
 | 
					$   RET=$STATUS
 | 
				
			||||||
$   GOTO opt_loop_continue
 | 
					$   GOTO opt_loop_continue
 | 
				
			||||||
@@ -163,7 +153,7 @@ $!
 | 
				
			|||||||
$ IF ((prog_opt .EQS. "-sign") .OR. (prog_opt .EQS. "-signreq"))
 | 
					$ IF ((prog_opt .EQS. "-sign") .OR. (prog_opt .EQS. "-signreq"))
 | 
				
			||||||
$ THEN
 | 
					$ THEN
 | 
				
			||||||
$!   
 | 
					$!   
 | 
				
			||||||
$   DEFINE /USER_MODE SYS$INPUT '__INPUT'
 | 
					$   DEFINE/USER SYS$INPUT '__INPUT'
 | 
				
			||||||
$   CA -policy policy_anything -out newcert.pem -infiles newreq.pem
 | 
					$   CA -policy policy_anything -out newcert.pem -infiles newreq.pem
 | 
				
			||||||
$   RET=$STATUS
 | 
					$   RET=$STATUS
 | 
				
			||||||
$   type newcert.pem
 | 
					$   type newcert.pem
 | 
				
			||||||
@@ -175,9 +165,9 @@ $ IF (prog_opt .EQS. "-signcert")
 | 
				
			|||||||
$  THEN
 | 
					$  THEN
 | 
				
			||||||
$!   
 | 
					$!   
 | 
				
			||||||
$   echo "Cert passphrase will be requested twice - bug?"
 | 
					$   echo "Cert passphrase will be requested twice - bug?"
 | 
				
			||||||
$   DEFINE /USER_MODE SYS$INPUT '__INPUT'
 | 
					$   DEFINE/USER SYS$INPUT '__INPUT'
 | 
				
			||||||
$   X509 -x509toreq -in newreq.pem -signkey newreq.pem -out tmp.pem
 | 
					$   X509 -x509toreq -in newreq.pem -signkey newreq.pem -out tmp.pem
 | 
				
			||||||
$   DEFINE /USER_MODE SYS$INPUT '__INPUT'
 | 
					$   DEFINE/USER SYS$INPUT '__INPUT'
 | 
				
			||||||
$   CA -policy policy_anything -out newcert.pem -infiles tmp.pem
 | 
					$   CA -policy policy_anything -out newcert.pem -infiles tmp.pem
 | 
				
			||||||
y
 | 
					y
 | 
				
			||||||
y
 | 
					y
 | 
				
			||||||
@@ -192,17 +182,17 @@ $!
 | 
				
			|||||||
$   i = i + 1
 | 
					$   i = i + 1
 | 
				
			||||||
$   IF (p'i' .EQS. "")
 | 
					$   IF (p'i' .EQS. "")
 | 
				
			||||||
$   THEN
 | 
					$   THEN
 | 
				
			||||||
$     DEFINE /USER_MODE SYS$INPUT '__INPUT'
 | 
					$     DEFINE/USER SYS$INPUT '__INPUT'
 | 
				
			||||||
$     VERIFY "-CAfile" 'CACERT' newcert.pem
 | 
					$     VERIFY "-CAfile" 'CATOP''CACERT' newcert.pem
 | 
				
			||||||
$   ELSE
 | 
					$   ELSE
 | 
				
			||||||
$     j = i
 | 
					$     j = i
 | 
				
			||||||
$    verify_opt_loop:
 | 
					$    verify_opt_loop:
 | 
				
			||||||
$     IF j .GT. 8 THEN GOTO verify_opt_loop_end
 | 
					$     IF j .GT. 8 THEN GOTO verify_opt_loop_end
 | 
				
			||||||
$     IF p'j' .NES. ""
 | 
					$     IF p'j' .NES. ""
 | 
				
			||||||
$     THEN 
 | 
					$     THEN 
 | 
				
			||||||
$       DEFINE /USER_MODE SYS$INPUT '__INPUT'
 | 
					$       DEFINE/USER SYS$INPUT '__INPUT'
 | 
				
			||||||
$       __tmp = p'j'
 | 
					$       __tmp = p'j'
 | 
				
			||||||
$       VERIFY "-CAfile" 'CACERT' '__tmp'
 | 
					$       VERIFY "-CAfile" 'CATOP''CACERT' '__tmp'
 | 
				
			||||||
$       tmp=$STATUS
 | 
					$       tmp=$STATUS
 | 
				
			||||||
$       IF tmp .NE. 0 THEN RET=tmp
 | 
					$       IF tmp .NE. 0 THEN RET=tmp
 | 
				
			||||||
$     ENDIF
 | 
					$     ENDIF
 | 
				
			||||||
@@ -218,8 +208,8 @@ $ IF (prog_opt .NES. "")
 | 
				
			|||||||
$ THEN
 | 
					$ THEN
 | 
				
			||||||
$!   
 | 
					$!   
 | 
				
			||||||
$   echo "Unknown argument ''prog_opt'"
 | 
					$   echo "Unknown argument ''prog_opt'"
 | 
				
			||||||
$   RET = 3
 | 
					$   
 | 
				
			||||||
$   goto clean_up
 | 
					$   EXIT 3
 | 
				
			||||||
$ ENDIF
 | 
					$ ENDIF
 | 
				
			||||||
$
 | 
					$
 | 
				
			||||||
$opt_loop_continue:
 | 
					$opt_loop_continue:
 | 
				
			||||||
@@ -227,10 +217,4 @@ $ i = i + 1
 | 
				
			|||||||
$ GOTO opt_loop
 | 
					$ GOTO opt_loop
 | 
				
			||||||
$
 | 
					$
 | 
				
			||||||
$opt_loop_end:
 | 
					$opt_loop_end:
 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$clean_up:
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ if f$trnlnm( "CATOP", "LNM$PROCESS") .nes. "" then -
 | 
					 | 
				
			||||||
   deassign /process CATOP
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ EXIT 'RET'
 | 
					$ EXIT 'RET'
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										121
									
								
								apps/CA.sh
									
									
									
									
									
								
							
							
						
						
									
										121
									
								
								apps/CA.sh
									
									
									
									
									
								
							@@ -5,10 +5,10 @@
 | 
				
			|||||||
#      things easier between now and when Eric is convinced to fix it :-)
 | 
					#      things easier between now and when Eric is convinced to fix it :-)
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
# CA -newca ... will setup the right stuff
 | 
					# CA -newca ... will setup the right stuff
 | 
				
			||||||
# CA -newreq ... will generate a certificate request
 | 
					# CA -newreq ... will generate a certificate request 
 | 
				
			||||||
# CA -sign ... will sign the generated request and output
 | 
					# CA -sign ... will sign the generated request and output 
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
# At the end of that grab newreq.pem and newcert.pem (one has the key
 | 
					# At the end of that grab newreq.pem and newcert.pem (one has the key 
 | 
				
			||||||
# and the other the certificate) and cat them together and that is what
 | 
					# and the other the certificate) and cat them together and that is what
 | 
				
			||||||
# you want/need ... I'll make even this a little cleaner later.
 | 
					# you want/need ... I'll make even this a little cleaner later.
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
@@ -16,8 +16,8 @@
 | 
				
			|||||||
# 12-Jan-96 tjh    Added more things ... including CA -signcert which
 | 
					# 12-Jan-96 tjh    Added more things ... including CA -signcert which
 | 
				
			||||||
#                  converts a certificate to a request and then signs it.
 | 
					#                  converts a certificate to a request and then signs it.
 | 
				
			||||||
# 10-Jan-96 eay    Fixed a few more bugs and added the SSLEAY_CONFIG
 | 
					# 10-Jan-96 eay    Fixed a few more bugs and added the SSLEAY_CONFIG
 | 
				
			||||||
#                  environment variable so this can be driven from
 | 
					#		   environment variable so this can be driven from
 | 
				
			||||||
#                  a script.
 | 
					#		   a script.
 | 
				
			||||||
# 25-Jul-96 eay    Cleaned up filenames some more.
 | 
					# 25-Jul-96 eay    Cleaned up filenames some more.
 | 
				
			||||||
# 11-Jun-96 eay    Fixed a few filename missmatches.
 | 
					# 11-Jun-96 eay    Fixed a few filename missmatches.
 | 
				
			||||||
# 03-May-96 eay    Modified to use 'ssleay cmd' instead of 'cmd'.
 | 
					# 03-May-96 eay    Modified to use 'ssleay cmd' instead of 'cmd'.
 | 
				
			||||||
@@ -29,87 +29,52 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
# default openssl.cnf file has setup as per the following
 | 
					# default openssl.cnf file has setup as per the following
 | 
				
			||||||
# demoCA ... where everything is stored
 | 
					# demoCA ... where everything is stored
 | 
				
			||||||
cp_pem() {
 | 
					 | 
				
			||||||
    infile=$1
 | 
					 | 
				
			||||||
    outfile=$2
 | 
					 | 
				
			||||||
    bound=$3
 | 
					 | 
				
			||||||
    flag=0
 | 
					 | 
				
			||||||
    exec <$infile;
 | 
					 | 
				
			||||||
    while read line; do
 | 
					 | 
				
			||||||
	if [ $flag -eq 1 ]; then
 | 
					 | 
				
			||||||
		echo $line|grep "^-----END.*$bound"  2>/dev/null 1>/dev/null
 | 
					 | 
				
			||||||
		if [ $? -eq 0 ] ; then
 | 
					 | 
				
			||||||
			echo $line >>$outfile
 | 
					 | 
				
			||||||
			break
 | 
					 | 
				
			||||||
		else
 | 
					 | 
				
			||||||
			echo $line >>$outfile
 | 
					 | 
				
			||||||
		fi
 | 
					 | 
				
			||||||
	fi
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	echo $line|grep "^-----BEGIN.*$bound"  2>/dev/null 1>/dev/null
 | 
					 | 
				
			||||||
	if [ $? -eq 0 ]; then
 | 
					 | 
				
			||||||
		echo $line >$outfile
 | 
					 | 
				
			||||||
		flag=1
 | 
					 | 
				
			||||||
	fi
 | 
					 | 
				
			||||||
    done
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
usage() {
 | 
					 | 
				
			||||||
 echo "usage: $0 -newcert|-newreq|-newreq-nodes|-newca|-sign|-verify" >&2
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
if [ -z "$OPENSSL" ]; then OPENSSL=openssl; fi
 | 
					if [ -z "$OPENSSL" ]; then OPENSSL=openssl; fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if [ -z "$DAYS" ] ; then DAYS="-days 365" ; fi	# 1 year
 | 
					DAYS="-days 365"	# 1 year
 | 
				
			||||||
CADAYS="-days 1095"	# 3 years
 | 
					CADAYS="-days 1095"	# 3 years
 | 
				
			||||||
REQ="$OPENSSL req $SSLEAY_CONFIG"
 | 
					REQ="$OPENSSL req $SSLEAY_CONFIG"
 | 
				
			||||||
CA="$OPENSSL ca $SSLEAY_CONFIG"
 | 
					CA="$OPENSSL ca $SSLEAY_CONFIG"
 | 
				
			||||||
VERIFY="$OPENSSL verify"
 | 
					VERIFY="$OPENSSL verify"
 | 
				
			||||||
X509="$OPENSSL x509"
 | 
					X509="$OPENSSL x509"
 | 
				
			||||||
PKCS12="openssl pkcs12"
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
if [ -z "$CATOP" ] ; then CATOP=./demoCA ; fi
 | 
					CATOP=./demoCA
 | 
				
			||||||
CAKEY=./cakey.pem
 | 
					CAKEY=./cakey.pem
 | 
				
			||||||
CAREQ=./careq.pem
 | 
					CAREQ=./careq.pem
 | 
				
			||||||
CACERT=./cacert.pem
 | 
					CACERT=./cacert.pem
 | 
				
			||||||
 | 
					
 | 
				
			||||||
RET=0
 | 
					for i
 | 
				
			||||||
 | 
					do
 | 
				
			||||||
while [ "$1" != "" ] ; do
 | 
					case $i in
 | 
				
			||||||
case $1 in
 | 
					 | 
				
			||||||
-\?|-h|-help)
 | 
					-\?|-h|-help)
 | 
				
			||||||
    usage
 | 
					    echo "usage: CA -newcert|-newreq|-newca|-sign|-verify" >&2
 | 
				
			||||||
    exit 0
 | 
					    exit 0
 | 
				
			||||||
    ;;
 | 
					    ;;
 | 
				
			||||||
-newcert)
 | 
					-newcert) 
 | 
				
			||||||
    # create a certificate
 | 
					    # create a certificate
 | 
				
			||||||
    $REQ -new -x509 -keyout newkey.pem -out newcert.pem $DAYS
 | 
					    $REQ -new -x509 -keyout newkey.pem -out newcert.pem $DAYS
 | 
				
			||||||
    RET=$?
 | 
					    RET=$?
 | 
				
			||||||
    echo "Certificate is in newcert.pem, private key is in newkey.pem"
 | 
					    echo "Certificate is in newcert.pem, private key is in newkey.pem"
 | 
				
			||||||
    ;;
 | 
					    ;;
 | 
				
			||||||
-newreq)
 | 
					-newreq) 
 | 
				
			||||||
    # create a certificate request
 | 
					    # create a certificate request
 | 
				
			||||||
    $REQ -new -keyout newkey.pem -out newreq.pem $DAYS
 | 
					    $REQ -new -keyout newkey.pem -out newreq.pem $DAYS
 | 
				
			||||||
    RET=$?
 | 
					    RET=$?
 | 
				
			||||||
    echo "Request is in newreq.pem, private key is in newkey.pem"
 | 
					    echo "Request is in newreq.pem, private key is in newkey.pem"
 | 
				
			||||||
    ;;
 | 
					    ;;
 | 
				
			||||||
-newreq-nodes) 
 | 
					-newca)     
 | 
				
			||||||
    # create a certificate request
 | 
					 | 
				
			||||||
    $REQ -new -nodes -keyout newreq.pem -out newreq.pem $DAYS
 | 
					 | 
				
			||||||
    RET=$?
 | 
					 | 
				
			||||||
    echo "Request (and private key) is in newreq.pem"
 | 
					 | 
				
			||||||
    ;;
 | 
					 | 
				
			||||||
-newca)
 | 
					 | 
				
			||||||
    # if explicitly asked for or it doesn't exist then setup the directory
 | 
					    # if explicitly asked for or it doesn't exist then setup the directory
 | 
				
			||||||
    # structure that Eric likes to manage things
 | 
					    # structure that Eric likes to manage things 
 | 
				
			||||||
    NEW="1"
 | 
					    NEW="1"
 | 
				
			||||||
    if [ "$NEW" -o ! -f ${CATOP}/serial ]; then
 | 
					    if [ "$NEW" -o ! -f ${CATOP}/serial ]; then
 | 
				
			||||||
	# create the directory hierarchy
 | 
						# create the directory hierarchy
 | 
				
			||||||
	mkdir -p ${CATOP}
 | 
						mkdir ${CATOP} 
 | 
				
			||||||
	mkdir -p ${CATOP}/certs
 | 
						mkdir ${CATOP}/certs 
 | 
				
			||||||
	mkdir -p ${CATOP}/crl
 | 
						mkdir ${CATOP}/crl 
 | 
				
			||||||
	mkdir -p ${CATOP}/newcerts
 | 
						mkdir ${CATOP}/newcerts
 | 
				
			||||||
	mkdir -p ${CATOP}/private
 | 
						mkdir ${CATOP}/private
 | 
				
			||||||
 | 
						echo "00" > ${CATOP}/serial
 | 
				
			||||||
	touch ${CATOP}/index.txt
 | 
						touch ${CATOP}/index.txt
 | 
				
			||||||
    fi
 | 
					    fi
 | 
				
			||||||
    if [ ! -f ${CATOP}/private/$CAKEY ]; then
 | 
					    if [ ! -f ${CATOP}/private/$CAKEY ]; then
 | 
				
			||||||
@@ -118,60 +83,37 @@ case $1 in
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	# ask user for existing CA certificate
 | 
						# ask user for existing CA certificate
 | 
				
			||||||
	if [ "$FILE" ]; then
 | 
						if [ "$FILE" ]; then
 | 
				
			||||||
	    cp_pem $FILE ${CATOP}/private/$CAKEY PRIVATE
 | 
						    cp $FILE ${CATOP}/private/$CAKEY
 | 
				
			||||||
	    cp_pem $FILE ${CATOP}/$CACERT CERTIFICATE
 | 
					 | 
				
			||||||
	    RET=$?
 | 
						    RET=$?
 | 
				
			||||||
	    if [ ! -f "${CATOP}/serial" ]; then
 | 
					 | 
				
			||||||
		$X509 -in ${CATOP}/$CACERT -noout -next_serial \
 | 
					 | 
				
			||||||
		      -out ${CATOP}/serial
 | 
					 | 
				
			||||||
	    fi
 | 
					 | 
				
			||||||
	else
 | 
						else
 | 
				
			||||||
	    echo "Making CA certificate ..."
 | 
						    echo "Making CA certificate ..."
 | 
				
			||||||
	    $REQ -new -keyout ${CATOP}/private/$CAKEY \
 | 
						    $REQ -new -keyout ${CATOP}/private/$CAKEY \
 | 
				
			||||||
			   -out ${CATOP}/$CAREQ
 | 
								   -out ${CATOP}/$CAREQ
 | 
				
			||||||
	    $CA -create_serial -out ${CATOP}/$CACERT $CADAYS -batch \
 | 
						    $CA -out ${CATOP}/$CACERT $CADAYS -batch \
 | 
				
			||||||
			   -keyfile ${CATOP}/private/$CAKEY -selfsign \
 | 
								   -keyfile ${CATOP}/private/$CAKEY -selfsign \
 | 
				
			||||||
			   -extensions v3_ca \
 | 
								   -infiles ${CATOP}/$CAREQ 
 | 
				
			||||||
			   -infiles ${CATOP}/$CAREQ
 | 
					 | 
				
			||||||
	    RET=$?
 | 
						    RET=$?
 | 
				
			||||||
	fi
 | 
						fi
 | 
				
			||||||
    fi
 | 
					    fi
 | 
				
			||||||
    ;;
 | 
					    ;;
 | 
				
			||||||
-xsign)
 | 
					-xsign)
 | 
				
			||||||
    $CA -policy policy_anything -infiles newreq.pem
 | 
					    $CA -policy policy_anything -infiles newreq.pem 
 | 
				
			||||||
    RET=$?
 | 
					    RET=$?
 | 
				
			||||||
    ;;
 | 
					    ;;
 | 
				
			||||||
-pkcs12)
 | 
					-sign|-signreq) 
 | 
				
			||||||
    if [ -z "$2" ] ; then
 | 
					 | 
				
			||||||
	CNAME="My Certificate"
 | 
					 | 
				
			||||||
    else
 | 
					 | 
				
			||||||
	CNAME="$2"
 | 
					 | 
				
			||||||
    fi
 | 
					 | 
				
			||||||
    $PKCS12 -in newcert.pem -inkey newreq.pem -certfile ${CATOP}/$CACERT \
 | 
					 | 
				
			||||||
	    -out newcert.p12 -export -name "$CNAME"
 | 
					 | 
				
			||||||
    RET=$?
 | 
					 | 
				
			||||||
    exit $RET
 | 
					 | 
				
			||||||
    ;;
 | 
					 | 
				
			||||||
-sign|-signreq)
 | 
					 | 
				
			||||||
    $CA -policy policy_anything -out newcert.pem -infiles newreq.pem
 | 
					    $CA -policy policy_anything -out newcert.pem -infiles newreq.pem
 | 
				
			||||||
    RET=$?
 | 
					    RET=$?
 | 
				
			||||||
    cat newcert.pem
 | 
					    cat newcert.pem
 | 
				
			||||||
    echo "Signed certificate is in newcert.pem"
 | 
					    echo "Signed certificate is in newcert.pem"
 | 
				
			||||||
    ;;
 | 
					    ;;
 | 
				
			||||||
-signCA)
 | 
					-signcert) 
 | 
				
			||||||
    $CA -policy policy_anything -out newcert.pem -extensions v3_ca -infiles newreq.pem
 | 
					 | 
				
			||||||
    RET=$?
 | 
					 | 
				
			||||||
    echo "Signed CA certificate is in newcert.pem"
 | 
					 | 
				
			||||||
    ;;
 | 
					 | 
				
			||||||
-signcert)
 | 
					 | 
				
			||||||
    echo "Cert passphrase will be requested twice - bug?"
 | 
					    echo "Cert passphrase will be requested twice - bug?"
 | 
				
			||||||
    $X509 -x509toreq -in newreq.pem -signkey newreq.pem -out tmp.pem
 | 
					    $X509 -x509toreq -in newreq.pem -signkey newreq.pem -out tmp.pem
 | 
				
			||||||
    $CA -policy policy_anything -out newcert.pem -infiles tmp.pem
 | 
					    $CA -policy policy_anything -out newcert.pem -infiles tmp.pem
 | 
				
			||||||
    RET=$?
 | 
					 | 
				
			||||||
    cat newcert.pem
 | 
					    cat newcert.pem
 | 
				
			||||||
    echo "Signed certificate is in newcert.pem"
 | 
					    echo "Signed certificate is in newcert.pem"
 | 
				
			||||||
    ;;
 | 
					    ;;
 | 
				
			||||||
-verify)
 | 
					-verify) 
 | 
				
			||||||
    shift
 | 
					    shift
 | 
				
			||||||
    if [ -z "$1" ]; then
 | 
					    if [ -z "$1" ]; then
 | 
				
			||||||
	    $VERIFY -CAfile $CATOP/$CACERT newcert.pem
 | 
						    $VERIFY -CAfile $CATOP/$CACERT newcert.pem
 | 
				
			||||||
@@ -185,14 +127,13 @@ case $1 in
 | 
				
			|||||||
	    fi
 | 
						    fi
 | 
				
			||||||
	done
 | 
						done
 | 
				
			||||||
    fi
 | 
					    fi
 | 
				
			||||||
    exit $RET
 | 
					    exit 0
 | 
				
			||||||
    ;;
 | 
					    ;;
 | 
				
			||||||
*)
 | 
					*)
 | 
				
			||||||
    echo "Unknown arg $i" >&2
 | 
					    echo "Unknown arg $i";
 | 
				
			||||||
    usage
 | 
					 | 
				
			||||||
    exit 1
 | 
					    exit 1
 | 
				
			||||||
    ;;
 | 
					    ;;
 | 
				
			||||||
esac
 | 
					esac
 | 
				
			||||||
shift
 | 
					 | 
				
			||||||
done
 | 
					done
 | 
				
			||||||
exit $RET
 | 
					exit $RET
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										116
									
								
								apps/Makefile
									
									
									
									
									
								
							
							
						
						
									
										116
									
								
								apps/Makefile
									
									
									
									
									
								
							@@ -39,7 +39,7 @@ E_EXE=	verify asn1pars req dgst dh dhparam enc passwd gendh errstr \
 | 
				
			|||||||
	ca crl rsa rsautl dsa dsaparam ec ecparam \
 | 
						ca crl rsa rsautl dsa dsaparam ec ecparam \
 | 
				
			||||||
	x509 genrsa gendsa genpkey s_server s_client speed \
 | 
						x509 genrsa gendsa genpkey s_server s_client speed \
 | 
				
			||||||
	s_time version pkcs7 cms crl2pkcs7 sess_id ciphers nseq pkcs12 \
 | 
						s_time version pkcs7 cms crl2pkcs7 sess_id ciphers nseq pkcs12 \
 | 
				
			||||||
	pkcs8 pkey pkeyparam pkeyutl spkac smime rand engine ocsp prime ts srp
 | 
						pkcs8 pkey pkeyparam pkeyutl spkac smime rand engine ocsp prime ts
 | 
				
			||||||
 | 
					
 | 
				
			||||||
PROGS= $(PROGRAM).c
 | 
					PROGS= $(PROGRAM).c
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -56,7 +56,7 @@ E_OBJ=	verify.o asn1pars.o req.o dgst.o dh.o dhparam.o enc.o passwd.o gendh.o er
 | 
				
			|||||||
	x509.o genrsa.o gendsa.o genpkey.o s_server.o s_client.o speed.o \
 | 
						x509.o genrsa.o gendsa.o genpkey.o s_server.o s_client.o speed.o \
 | 
				
			||||||
	s_time.o $(A_OBJ) $(S_OBJ) $(RAND_OBJ) version.o sess_id.o \
 | 
						s_time.o $(A_OBJ) $(S_OBJ) $(RAND_OBJ) version.o sess_id.o \
 | 
				
			||||||
	ciphers.o nseq.o pkcs12.o pkcs8.o pkey.o pkeyparam.o pkeyutl.o \
 | 
						ciphers.o nseq.o pkcs12.o pkcs8.o pkey.o pkeyparam.o pkeyutl.o \
 | 
				
			||||||
	spkac.o smime.o cms.o rand.o engine.o ocsp.o prime.o ts.o srp.o
 | 
						spkac.o smime.o cms.o rand.o engine.o ocsp.o prime.o ts.o
 | 
				
			||||||
 | 
					
 | 
				
			||||||
E_SRC=	verify.c asn1pars.c req.c dgst.c dh.c enc.c passwd.c gendh.c errstr.c ca.c \
 | 
					E_SRC=	verify.c asn1pars.c req.c dgst.c dh.c enc.c passwd.c gendh.c errstr.c ca.c \
 | 
				
			||||||
	pkcs7.c crl2p7.c crl.c \
 | 
						pkcs7.c crl2p7.c crl.c \
 | 
				
			||||||
@@ -64,7 +64,7 @@ E_SRC=	verify.c asn1pars.c req.c dgst.c dh.c enc.c passwd.c gendh.c errstr.c ca.
 | 
				
			|||||||
	x509.c genrsa.c gendsa.c genpkey.c s_server.c s_client.c speed.c \
 | 
						x509.c genrsa.c gendsa.c genpkey.c s_server.c s_client.c speed.c \
 | 
				
			||||||
	s_time.c $(A_SRC) $(S_SRC) $(RAND_SRC) version.c sess_id.c \
 | 
						s_time.c $(A_SRC) $(S_SRC) $(RAND_SRC) version.c sess_id.c \
 | 
				
			||||||
	ciphers.c nseq.c pkcs12.c pkcs8.c pkey.c pkeyparam.c pkeyutl.c \
 | 
						ciphers.c nseq.c pkcs12.c pkcs8.c pkey.c pkeyparam.c pkeyutl.c \
 | 
				
			||||||
	spkac.c smime.c cms.c rand.c engine.c ocsp.c prime.c ts.c srp.c
 | 
						spkac.c smime.c cms.c rand.c engine.c ocsp.c prime.c ts.c
 | 
				
			||||||
 | 
					
 | 
				
			||||||
SRC=$(E_SRC)
 | 
					SRC=$(E_SRC)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -789,14 +789,14 @@ s_cb.o: ../include/openssl/objects.h ../include/openssl/ocsp.h
 | 
				
			|||||||
s_cb.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
 | 
					s_cb.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
 | 
				
			||||||
s_cb.o: ../include/openssl/ossl_typ.h ../include/openssl/pem.h
 | 
					s_cb.o: ../include/openssl/ossl_typ.h ../include/openssl/pem.h
 | 
				
			||||||
s_cb.o: ../include/openssl/pem2.h ../include/openssl/pkcs7.h
 | 
					s_cb.o: ../include/openssl/pem2.h ../include/openssl/pkcs7.h
 | 
				
			||||||
s_cb.o: ../include/openssl/pqueue.h ../include/openssl/rand.h
 | 
					s_cb.o: ../include/openssl/pqueue.h ../include/openssl/safestack.h
 | 
				
			||||||
s_cb.o: ../include/openssl/safestack.h ../include/openssl/sha.h
 | 
					s_cb.o: ../include/openssl/sha.h ../include/openssl/ssl.h
 | 
				
			||||||
s_cb.o: ../include/openssl/ssl.h ../include/openssl/ssl2.h
 | 
					s_cb.o: ../include/openssl/ssl2.h ../include/openssl/ssl23.h
 | 
				
			||||||
s_cb.o: ../include/openssl/ssl23.h ../include/openssl/ssl3.h
 | 
					s_cb.o: ../include/openssl/ssl3.h ../include/openssl/stack.h
 | 
				
			||||||
s_cb.o: ../include/openssl/stack.h ../include/openssl/symhacks.h
 | 
					s_cb.o: ../include/openssl/symhacks.h ../include/openssl/tls1.h
 | 
				
			||||||
s_cb.o: ../include/openssl/tls1.h ../include/openssl/txt_db.h
 | 
					s_cb.o: ../include/openssl/txt_db.h ../include/openssl/x509.h
 | 
				
			||||||
s_cb.o: ../include/openssl/x509.h ../include/openssl/x509_vfy.h
 | 
					s_cb.o: ../include/openssl/x509_vfy.h ../include/openssl/x509v3.h apps.h
 | 
				
			||||||
s_cb.o: ../include/openssl/x509v3.h apps.h s_apps.h s_cb.c
 | 
					s_cb.o: s_apps.h s_cb.c
 | 
				
			||||||
s_client.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/bio.h
 | 
					s_client.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/bio.h
 | 
				
			||||||
s_client.o: ../include/openssl/bn.h ../include/openssl/buffer.h
 | 
					s_client.o: ../include/openssl/bn.h ../include/openssl/buffer.h
 | 
				
			||||||
s_client.o: ../include/openssl/comp.h ../include/openssl/conf.h
 | 
					s_client.o: ../include/openssl/comp.h ../include/openssl/conf.h
 | 
				
			||||||
@@ -812,13 +812,13 @@ s_client.o: ../include/openssl/opensslv.h ../include/openssl/ossl_typ.h
 | 
				
			|||||||
s_client.o: ../include/openssl/pem.h ../include/openssl/pem2.h
 | 
					s_client.o: ../include/openssl/pem.h ../include/openssl/pem2.h
 | 
				
			||||||
s_client.o: ../include/openssl/pkcs7.h ../include/openssl/pqueue.h
 | 
					s_client.o: ../include/openssl/pkcs7.h ../include/openssl/pqueue.h
 | 
				
			||||||
s_client.o: ../include/openssl/rand.h ../include/openssl/safestack.h
 | 
					s_client.o: ../include/openssl/rand.h ../include/openssl/safestack.h
 | 
				
			||||||
s_client.o: ../include/openssl/sha.h ../include/openssl/srp.h
 | 
					s_client.o: ../include/openssl/sha.h ../include/openssl/ssl.h
 | 
				
			||||||
s_client.o: ../include/openssl/ssl.h ../include/openssl/ssl2.h
 | 
					s_client.o: ../include/openssl/ssl2.h ../include/openssl/ssl23.h
 | 
				
			||||||
s_client.o: ../include/openssl/ssl23.h ../include/openssl/ssl3.h
 | 
					s_client.o: ../include/openssl/ssl3.h ../include/openssl/stack.h
 | 
				
			||||||
s_client.o: ../include/openssl/stack.h ../include/openssl/symhacks.h
 | 
					s_client.o: ../include/openssl/symhacks.h ../include/openssl/tls1.h
 | 
				
			||||||
s_client.o: ../include/openssl/tls1.h ../include/openssl/txt_db.h
 | 
					s_client.o: ../include/openssl/txt_db.h ../include/openssl/x509.h
 | 
				
			||||||
s_client.o: ../include/openssl/x509.h ../include/openssl/x509_vfy.h
 | 
					s_client.o: ../include/openssl/x509_vfy.h ../include/openssl/x509v3.h apps.h
 | 
				
			||||||
s_client.o: ../include/openssl/x509v3.h apps.h s_apps.h s_client.c timeouts.h
 | 
					s_client.o: s_apps.h s_client.c timeouts.h
 | 
				
			||||||
s_server.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/bio.h
 | 
					s_server.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/bio.h
 | 
				
			||||||
s_server.o: ../include/openssl/bn.h ../include/openssl/buffer.h
 | 
					s_server.o: ../include/openssl/bn.h ../include/openssl/buffer.h
 | 
				
			||||||
s_server.o: ../include/openssl/comp.h ../include/openssl/conf.h
 | 
					s_server.o: ../include/openssl/comp.h ../include/openssl/conf.h
 | 
				
			||||||
@@ -836,13 +836,13 @@ s_server.o: ../include/openssl/pem.h ../include/openssl/pem2.h
 | 
				
			|||||||
s_server.o: ../include/openssl/pkcs7.h ../include/openssl/pqueue.h
 | 
					s_server.o: ../include/openssl/pkcs7.h ../include/openssl/pqueue.h
 | 
				
			||||||
s_server.o: ../include/openssl/rand.h ../include/openssl/rsa.h
 | 
					s_server.o: ../include/openssl/rand.h ../include/openssl/rsa.h
 | 
				
			||||||
s_server.o: ../include/openssl/safestack.h ../include/openssl/sha.h
 | 
					s_server.o: ../include/openssl/safestack.h ../include/openssl/sha.h
 | 
				
			||||||
s_server.o: ../include/openssl/srp.h ../include/openssl/ssl.h
 | 
					s_server.o: ../include/openssl/ssl.h ../include/openssl/ssl2.h
 | 
				
			||||||
s_server.o: ../include/openssl/ssl2.h ../include/openssl/ssl23.h
 | 
					s_server.o: ../include/openssl/ssl23.h ../include/openssl/ssl3.h
 | 
				
			||||||
s_server.o: ../include/openssl/ssl3.h ../include/openssl/stack.h
 | 
					s_server.o: ../include/openssl/stack.h ../include/openssl/symhacks.h
 | 
				
			||||||
s_server.o: ../include/openssl/symhacks.h ../include/openssl/tls1.h
 | 
					s_server.o: ../include/openssl/tls1.h ../include/openssl/txt_db.h
 | 
				
			||||||
s_server.o: ../include/openssl/txt_db.h ../include/openssl/ui.h
 | 
					s_server.o: ../include/openssl/ui.h ../include/openssl/x509.h
 | 
				
			||||||
s_server.o: ../include/openssl/x509.h ../include/openssl/x509_vfy.h
 | 
					s_server.o: ../include/openssl/x509_vfy.h ../include/openssl/x509v3.h apps.h
 | 
				
			||||||
s_server.o: ../include/openssl/x509v3.h apps.h s_apps.h s_server.c timeouts.h
 | 
					s_server.o: s_apps.h s_server.c timeouts.h
 | 
				
			||||||
s_socket.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/bio.h
 | 
					s_socket.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/bio.h
 | 
				
			||||||
s_socket.o: ../include/openssl/buffer.h ../include/openssl/comp.h
 | 
					s_socket.o: ../include/openssl/buffer.h ../include/openssl/comp.h
 | 
				
			||||||
s_socket.o: ../include/openssl/conf.h ../include/openssl/crypto.h
 | 
					s_socket.o: ../include/openssl/conf.h ../include/openssl/crypto.h
 | 
				
			||||||
@@ -932,21 +932,21 @@ speed.o: ../include/openssl/ec.h ../include/openssl/ecdh.h
 | 
				
			|||||||
speed.o: ../include/openssl/ecdsa.h ../include/openssl/engine.h
 | 
					speed.o: ../include/openssl/ecdsa.h ../include/openssl/engine.h
 | 
				
			||||||
speed.o: ../include/openssl/err.h ../include/openssl/evp.h
 | 
					speed.o: ../include/openssl/err.h ../include/openssl/evp.h
 | 
				
			||||||
speed.o: ../include/openssl/hmac.h ../include/openssl/idea.h
 | 
					speed.o: ../include/openssl/hmac.h ../include/openssl/idea.h
 | 
				
			||||||
speed.o: ../include/openssl/lhash.h ../include/openssl/md4.h
 | 
					speed.o: ../include/openssl/lhash.h ../include/openssl/md2.h
 | 
				
			||||||
speed.o: ../include/openssl/md5.h ../include/openssl/mdc2.h
 | 
					speed.o: ../include/openssl/md4.h ../include/openssl/md5.h
 | 
				
			||||||
speed.o: ../include/openssl/modes.h ../include/openssl/obj_mac.h
 | 
					speed.o: ../include/openssl/obj_mac.h ../include/openssl/objects.h
 | 
				
			||||||
speed.o: ../include/openssl/objects.h ../include/openssl/ocsp.h
 | 
					speed.o: ../include/openssl/ocsp.h ../include/openssl/opensslconf.h
 | 
				
			||||||
speed.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
 | 
					speed.o: ../include/openssl/opensslv.h ../include/openssl/ossl_typ.h
 | 
				
			||||||
speed.o: ../include/openssl/ossl_typ.h ../include/openssl/pkcs7.h
 | 
					speed.o: ../include/openssl/pkcs7.h ../include/openssl/rand.h
 | 
				
			||||||
speed.o: ../include/openssl/rand.h ../include/openssl/rc2.h
 | 
					speed.o: ../include/openssl/rc2.h ../include/openssl/rc4.h
 | 
				
			||||||
speed.o: ../include/openssl/rc4.h ../include/openssl/ripemd.h
 | 
					speed.o: ../include/openssl/ripemd.h ../include/openssl/rsa.h
 | 
				
			||||||
speed.o: ../include/openssl/rsa.h ../include/openssl/safestack.h
 | 
					speed.o: ../include/openssl/safestack.h ../include/openssl/seed.h
 | 
				
			||||||
speed.o: ../include/openssl/seed.h ../include/openssl/sha.h
 | 
					speed.o: ../include/openssl/sha.h ../include/openssl/stack.h
 | 
				
			||||||
speed.o: ../include/openssl/stack.h ../include/openssl/symhacks.h
 | 
					speed.o: ../include/openssl/symhacks.h ../include/openssl/txt_db.h
 | 
				
			||||||
speed.o: ../include/openssl/txt_db.h ../include/openssl/ui.h
 | 
					speed.o: ../include/openssl/ui.h ../include/openssl/ui_compat.h
 | 
				
			||||||
speed.o: ../include/openssl/ui_compat.h ../include/openssl/whrlpool.h
 | 
					speed.o: ../include/openssl/whrlpool.h ../include/openssl/x509.h
 | 
				
			||||||
speed.o: ../include/openssl/x509.h ../include/openssl/x509_vfy.h
 | 
					speed.o: ../include/openssl/x509_vfy.h ../include/openssl/x509v3.h apps.h
 | 
				
			||||||
speed.o: ../include/openssl/x509v3.h apps.h speed.c testdsa.h testrsa.h
 | 
					speed.o: speed.c testdsa.h testrsa.h
 | 
				
			||||||
spkac.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/bio.h
 | 
					spkac.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/bio.h
 | 
				
			||||||
spkac.o: ../include/openssl/buffer.h ../include/openssl/conf.h
 | 
					spkac.o: ../include/openssl/buffer.h ../include/openssl/conf.h
 | 
				
			||||||
spkac.o: ../include/openssl/crypto.h ../include/openssl/e_os2.h
 | 
					spkac.o: ../include/openssl/crypto.h ../include/openssl/e_os2.h
 | 
				
			||||||
@@ -963,21 +963,6 @@ spkac.o: ../include/openssl/stack.h ../include/openssl/symhacks.h
 | 
				
			|||||||
spkac.o: ../include/openssl/txt_db.h ../include/openssl/x509.h
 | 
					spkac.o: ../include/openssl/txt_db.h ../include/openssl/x509.h
 | 
				
			||||||
spkac.o: ../include/openssl/x509_vfy.h ../include/openssl/x509v3.h apps.h
 | 
					spkac.o: ../include/openssl/x509_vfy.h ../include/openssl/x509v3.h apps.h
 | 
				
			||||||
spkac.o: spkac.c
 | 
					spkac.o: spkac.c
 | 
				
			||||||
srp.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/bio.h
 | 
					 | 
				
			||||||
srp.o: ../include/openssl/bn.h ../include/openssl/buffer.h
 | 
					 | 
				
			||||||
srp.o: ../include/openssl/conf.h ../include/openssl/crypto.h
 | 
					 | 
				
			||||||
srp.o: ../include/openssl/e_os2.h ../include/openssl/ec.h
 | 
					 | 
				
			||||||
srp.o: ../include/openssl/ecdh.h ../include/openssl/ecdsa.h
 | 
					 | 
				
			||||||
srp.o: ../include/openssl/engine.h ../include/openssl/err.h
 | 
					 | 
				
			||||||
srp.o: ../include/openssl/evp.h ../include/openssl/lhash.h
 | 
					 | 
				
			||||||
srp.o: ../include/openssl/obj_mac.h ../include/openssl/objects.h
 | 
					 | 
				
			||||||
srp.o: ../include/openssl/ocsp.h ../include/openssl/opensslconf.h
 | 
					 | 
				
			||||||
srp.o: ../include/openssl/opensslv.h ../include/openssl/ossl_typ.h
 | 
					 | 
				
			||||||
srp.o: ../include/openssl/pkcs7.h ../include/openssl/safestack.h
 | 
					 | 
				
			||||||
srp.o: ../include/openssl/sha.h ../include/openssl/srp.h
 | 
					 | 
				
			||||||
srp.o: ../include/openssl/stack.h ../include/openssl/symhacks.h
 | 
					 | 
				
			||||||
srp.o: ../include/openssl/txt_db.h ../include/openssl/x509.h
 | 
					 | 
				
			||||||
srp.o: ../include/openssl/x509_vfy.h ../include/openssl/x509v3.h apps.h srp.c
 | 
					 | 
				
			||||||
ts.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/bio.h
 | 
					ts.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/bio.h
 | 
				
			||||||
ts.o: ../include/openssl/bn.h ../include/openssl/buffer.h
 | 
					ts.o: ../include/openssl/bn.h ../include/openssl/buffer.h
 | 
				
			||||||
ts.o: ../include/openssl/conf.h ../include/openssl/crypto.h
 | 
					ts.o: ../include/openssl/conf.h ../include/openssl/crypto.h
 | 
				
			||||||
@@ -1020,16 +1005,17 @@ version.o: ../include/openssl/des_old.h ../include/openssl/e_os2.h
 | 
				
			|||||||
version.o: ../include/openssl/ec.h ../include/openssl/ecdh.h
 | 
					version.o: ../include/openssl/ec.h ../include/openssl/ecdh.h
 | 
				
			||||||
version.o: ../include/openssl/ecdsa.h ../include/openssl/engine.h
 | 
					version.o: ../include/openssl/ecdsa.h ../include/openssl/engine.h
 | 
				
			||||||
version.o: ../include/openssl/evp.h ../include/openssl/idea.h
 | 
					version.o: ../include/openssl/evp.h ../include/openssl/idea.h
 | 
				
			||||||
version.o: ../include/openssl/lhash.h ../include/openssl/obj_mac.h
 | 
					version.o: ../include/openssl/lhash.h ../include/openssl/md2.h
 | 
				
			||||||
version.o: ../include/openssl/objects.h ../include/openssl/ocsp.h
 | 
					version.o: ../include/openssl/obj_mac.h ../include/openssl/objects.h
 | 
				
			||||||
version.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
 | 
					version.o: ../include/openssl/ocsp.h ../include/openssl/opensslconf.h
 | 
				
			||||||
version.o: ../include/openssl/ossl_typ.h ../include/openssl/pkcs7.h
 | 
					version.o: ../include/openssl/opensslv.h ../include/openssl/ossl_typ.h
 | 
				
			||||||
version.o: ../include/openssl/rc4.h ../include/openssl/safestack.h
 | 
					version.o: ../include/openssl/pkcs7.h ../include/openssl/rc4.h
 | 
				
			||||||
version.o: ../include/openssl/sha.h ../include/openssl/stack.h
 | 
					version.o: ../include/openssl/safestack.h ../include/openssl/sha.h
 | 
				
			||||||
version.o: ../include/openssl/symhacks.h ../include/openssl/txt_db.h
 | 
					version.o: ../include/openssl/stack.h ../include/openssl/symhacks.h
 | 
				
			||||||
version.o: ../include/openssl/ui.h ../include/openssl/ui_compat.h
 | 
					version.o: ../include/openssl/txt_db.h ../include/openssl/ui.h
 | 
				
			||||||
version.o: ../include/openssl/x509.h ../include/openssl/x509_vfy.h
 | 
					version.o: ../include/openssl/ui_compat.h ../include/openssl/x509.h
 | 
				
			||||||
version.o: ../include/openssl/x509v3.h apps.h version.c
 | 
					version.o: ../include/openssl/x509_vfy.h ../include/openssl/x509v3.h apps.h
 | 
				
			||||||
 | 
					version.o: version.c
 | 
				
			||||||
x509.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/bio.h
 | 
					x509.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/bio.h
 | 
				
			||||||
x509.o: ../include/openssl/bn.h ../include/openssl/buffer.h
 | 
					x509.o: ../include/openssl/bn.h ../include/openssl/buffer.h
 | 
				
			||||||
x509.o: ../include/openssl/conf.h ../include/openssl/crypto.h
 | 
					x509.o: ../include/openssl/conf.h ../include/openssl/crypto.h
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										288
									
								
								apps/apps.c
									
									
									
									
									
								
							
							
						
						
									
										288
									
								
								apps/apps.c
									
									
									
									
									
								
							@@ -109,16 +109,14 @@
 | 
				
			|||||||
 *
 | 
					 *
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef _POSIX_C_SOURCE
 | 
					 | 
				
			||||||
#define _POSIX_C_SOURCE 2	/* On VMS, you need to define this to get
 | 
					#define _POSIX_C_SOURCE 2	/* On VMS, you need to define this to get
 | 
				
			||||||
				   the declaration of fileno().  The value
 | 
									   the declaration of fileno().  The value
 | 
				
			||||||
				   2 is to make sure no function defined
 | 
									   2 is to make sure no function defined
 | 
				
			||||||
				   in POSIX-2 is left undefined. */
 | 
									   in POSIX-2 is left undefined. */
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
#include <stdio.h>
 | 
					#include <stdio.h>
 | 
				
			||||||
#include <stdlib.h>
 | 
					#include <stdlib.h>
 | 
				
			||||||
#include <string.h>
 | 
					#include <string.h>
 | 
				
			||||||
#if !defined(OPENSSL_SYSNAME_WIN32) && !defined(NETWARE_CLIB)
 | 
					#ifndef OPENSSL_SYSNAME_WIN32
 | 
				
			||||||
#include <strings.h>
 | 
					#include <strings.h>
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
#include <sys/types.h>
 | 
					#include <sys/types.h>
 | 
				
			||||||
@@ -257,12 +255,17 @@ int args_from_file(char *file, int *argc, char **argv[])
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
int str2fmt(char *s)
 | 
					int str2fmt(char *s)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
	if (s == NULL)
 | 
					 | 
				
			||||||
		return FORMAT_UNDEF;
 | 
					 | 
				
			||||||
	if 	((*s == 'D') || (*s == 'd'))
 | 
						if 	((*s == 'D') || (*s == 'd'))
 | 
				
			||||||
		return(FORMAT_ASN1);
 | 
							return(FORMAT_ASN1);
 | 
				
			||||||
	else if ((*s == 'T') || (*s == 't'))
 | 
						else if ((*s == 'T') || (*s == 't'))
 | 
				
			||||||
		return(FORMAT_TEXT);
 | 
							return(FORMAT_TEXT);
 | 
				
			||||||
 | 
						else if ((*s == 'P') || (*s == 'p'))
 | 
				
			||||||
 | 
					 		{
 | 
				
			||||||
 | 
					 		if (s[1] == 'V' || s[1] == 'v')
 | 
				
			||||||
 | 
					 			return FORMAT_PVK;
 | 
				
			||||||
 | 
					 		else
 | 
				
			||||||
 | 
					  			return(FORMAT_PEM);
 | 
				
			||||||
 | 
					 		}
 | 
				
			||||||
  	else if ((*s == 'N') || (*s == 'n'))
 | 
					  	else if ((*s == 'N') || (*s == 'n'))
 | 
				
			||||||
  		return(FORMAT_NETSCAPE);
 | 
					  		return(FORMAT_NETSCAPE);
 | 
				
			||||||
  	else if ((*s == 'S') || (*s == 's'))
 | 
					  	else if ((*s == 'S') || (*s == 's'))
 | 
				
			||||||
@@ -275,13 +278,6 @@ int str2fmt(char *s)
 | 
				
			|||||||
		return(FORMAT_PKCS12);
 | 
							return(FORMAT_PKCS12);
 | 
				
			||||||
	else if ((*s == 'E') || (*s == 'e'))
 | 
						else if ((*s == 'E') || (*s == 'e'))
 | 
				
			||||||
		return(FORMAT_ENGINE);
 | 
							return(FORMAT_ENGINE);
 | 
				
			||||||
	else if ((*s == 'P') || (*s == 'p'))
 | 
					 | 
				
			||||||
 		{
 | 
					 | 
				
			||||||
 		if (s[1] == 'V' || s[1] == 'v')
 | 
					 | 
				
			||||||
 			return FORMAT_PVK;
 | 
					 | 
				
			||||||
 		else
 | 
					 | 
				
			||||||
  			return(FORMAT_PEM);
 | 
					 | 
				
			||||||
 		}
 | 
					 | 
				
			||||||
	else
 | 
						else
 | 
				
			||||||
		return(FORMAT_UNDEF);
 | 
							return(FORMAT_UNDEF);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
@@ -379,12 +375,13 @@ void program_name(char *in, char *out, int size)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
int chopup_args(ARGS *arg, char *buf, int *argc, char **argv[])
 | 
					int chopup_args(ARGS *arg, char *buf, int *argc, char **argv[])
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
	int num,i;
 | 
						int num,len,i;
 | 
				
			||||||
	char *p;
 | 
						char *p;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	*argc=0;
 | 
						*argc=0;
 | 
				
			||||||
	*argv=NULL;
 | 
						*argv=NULL;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						len=strlen(buf);
 | 
				
			||||||
	i=0;
 | 
						i=0;
 | 
				
			||||||
	if (arg->count == 0)
 | 
						if (arg->count == 0)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
@@ -798,9 +795,7 @@ X509 *load_cert(BIO *err, const char *file, int format,
 | 
				
			|||||||
	if (file == NULL)
 | 
						if (file == NULL)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
#ifdef _IONBF
 | 
					#ifdef _IONBF
 | 
				
			||||||
# ifndef OPENSSL_NO_SETVBUF_IONBF
 | 
					 | 
				
			||||||
		setvbuf(stdin, NULL, _IONBF, 0);
 | 
							setvbuf(stdin, NULL, _IONBF, 0);
 | 
				
			||||||
# endif /* ndef OPENSSL_NO_SETVBUF_IONBF */
 | 
					 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
		BIO_set_fp(cert,stdin,BIO_NOCLOSE);
 | 
							BIO_set_fp(cert,stdin,BIO_NOCLOSE);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
@@ -878,17 +873,10 @@ EVP_PKEY *load_key(BIO *err, const char *file, int format, int maybe_stdin,
 | 
				
			|||||||
	if (format == FORMAT_ENGINE)
 | 
						if (format == FORMAT_ENGINE)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		if (!e)
 | 
							if (!e)
 | 
				
			||||||
			BIO_printf(err,"no engine specified\n");
 | 
								BIO_printf(bio_err,"no engine specified\n");
 | 
				
			||||||
		else
 | 
							else
 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			pkey = ENGINE_load_private_key(e, file,
 | 
								pkey = ENGINE_load_private_key(e, file,
 | 
				
			||||||
				ui_method, &cb_data);
 | 
									ui_method, &cb_data);
 | 
				
			||||||
			if (!pkey) 
 | 
					 | 
				
			||||||
				{
 | 
					 | 
				
			||||||
				BIO_printf(err,"cannot load %s from engine\n",key_descrip);
 | 
					 | 
				
			||||||
				ERR_print_errors(err);
 | 
					 | 
				
			||||||
				}	
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		goto end;
 | 
							goto end;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
@@ -901,9 +889,7 @@ EVP_PKEY *load_key(BIO *err, const char *file, int format, int maybe_stdin,
 | 
				
			|||||||
	if (file == NULL && maybe_stdin)
 | 
						if (file == NULL && maybe_stdin)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
#ifdef _IONBF
 | 
					#ifdef _IONBF
 | 
				
			||||||
# ifndef OPENSSL_NO_SETVBUF_IONBF
 | 
					 | 
				
			||||||
		setvbuf(stdin, NULL, _IONBF, 0);
 | 
							setvbuf(stdin, NULL, _IONBF, 0);
 | 
				
			||||||
# endif /* ndef OPENSSL_NO_SETVBUF_IONBF */
 | 
					 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
		BIO_set_fp(key,stdin,BIO_NOCLOSE);
 | 
							BIO_set_fp(key,stdin,BIO_NOCLOSE);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
@@ -935,13 +921,11 @@ EVP_PKEY *load_key(BIO *err, const char *file, int format, int maybe_stdin,
 | 
				
			|||||||
				&pkey, NULL, NULL))
 | 
									&pkey, NULL, NULL))
 | 
				
			||||||
			goto end;
 | 
								goto end;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
#if !defined(OPENSSL_NO_RSA) && !defined(OPENSSL_NO_DSA) && !defined (OPENSSL_NO_RC4)
 | 
					 | 
				
			||||||
	else if (format == FORMAT_MSBLOB)
 | 
						else if (format == FORMAT_MSBLOB)
 | 
				
			||||||
		pkey = b2i_PrivateKey_bio(key);
 | 
							pkey = b2i_PrivateKey_bio(key);
 | 
				
			||||||
	else if (format == FORMAT_PVK)
 | 
						else if (format == FORMAT_PVK)
 | 
				
			||||||
		pkey = b2i_PVK_bio(key, (pem_password_cb *)password_callback,
 | 
							pkey = b2i_PVK_bio(key, (pem_password_cb *)password_callback,
 | 
				
			||||||
								&cb_data);
 | 
													&cb_data);
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	else
 | 
						else
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		BIO_printf(err,"bad input format specified for key file\n");
 | 
							BIO_printf(err,"bad input format specified for key file\n");
 | 
				
			||||||
@@ -949,11 +933,8 @@ EVP_PKEY *load_key(BIO *err, const char *file, int format, int maybe_stdin,
 | 
				
			|||||||
		}
 | 
							}
 | 
				
			||||||
 end:
 | 
					 end:
 | 
				
			||||||
	if (key != NULL) BIO_free(key);
 | 
						if (key != NULL) BIO_free(key);
 | 
				
			||||||
	if (pkey == NULL) 
 | 
						if (pkey == NULL)
 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		BIO_printf(err,"unable to load %s\n", key_descrip);
 | 
							BIO_printf(err,"unable to load %s\n", key_descrip);
 | 
				
			||||||
		ERR_print_errors(err);
 | 
					 | 
				
			||||||
		}	
 | 
					 | 
				
			||||||
	return(pkey);
 | 
						return(pkey);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -992,9 +973,7 @@ EVP_PKEY *load_pubkey(BIO *err, const char *file, int format, int maybe_stdin,
 | 
				
			|||||||
	if (file == NULL && maybe_stdin)
 | 
						if (file == NULL && maybe_stdin)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
#ifdef _IONBF
 | 
					#ifdef _IONBF
 | 
				
			||||||
# ifndef OPENSSL_NO_SETVBUF_IONBF
 | 
					 | 
				
			||||||
		setvbuf(stdin, NULL, _IONBF, 0);
 | 
							setvbuf(stdin, NULL, _IONBF, 0);
 | 
				
			||||||
# endif /* ndef OPENSSL_NO_SETVBUF_IONBF */
 | 
					 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
		BIO_set_fp(key,stdin,BIO_NOCLOSE);
 | 
							BIO_set_fp(key,stdin,BIO_NOCLOSE);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
@@ -1010,7 +989,6 @@ EVP_PKEY *load_pubkey(BIO *err, const char *file, int format, int maybe_stdin,
 | 
				
			|||||||
		{
 | 
							{
 | 
				
			||||||
		pkey=d2i_PUBKEY_bio(key, NULL);
 | 
							pkey=d2i_PUBKEY_bio(key, NULL);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
#ifndef OPENSSL_NO_RSA
 | 
					 | 
				
			||||||
	else if (format == FORMAT_ASN1RSA)
 | 
						else if (format == FORMAT_ASN1RSA)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		RSA *rsa;
 | 
							RSA *rsa;
 | 
				
			||||||
@@ -1040,7 +1018,7 @@ EVP_PKEY *load_pubkey(BIO *err, const char *file, int format, int maybe_stdin,
 | 
				
			|||||||
		else
 | 
							else
 | 
				
			||||||
			pkey = NULL;
 | 
								pkey = NULL;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
#endif
 | 
					
 | 
				
			||||||
	else if (format == FORMAT_PEM)
 | 
						else if (format == FORMAT_PEM)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		pkey=PEM_read_bio_PUBKEY(key,NULL,
 | 
							pkey=PEM_read_bio_PUBKEY(key,NULL,
 | 
				
			||||||
@@ -1050,10 +1028,8 @@ EVP_PKEY *load_pubkey(BIO *err, const char *file, int format, int maybe_stdin,
 | 
				
			|||||||
	else if (format == FORMAT_NETSCAPE || format == FORMAT_IISSGC)
 | 
						else if (format == FORMAT_NETSCAPE || format == FORMAT_IISSGC)
 | 
				
			||||||
		pkey = load_netscape_key(err, key, file, key_descrip, format);
 | 
							pkey = load_netscape_key(err, key, file, key_descrip, format);
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
#if !defined(OPENSSL_NO_RSA) && !defined(OPENSSL_NO_DSA)
 | 
					 | 
				
			||||||
	else if (format == FORMAT_MSBLOB)
 | 
						else if (format == FORMAT_MSBLOB)
 | 
				
			||||||
		pkey = b2i_PublicKey_bio(key);
 | 
							pkey = b2i_PublicKey_bio(key);
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	else
 | 
						else
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		BIO_printf(err,"bad input format specified for key file\n");
 | 
							BIO_printf(err,"bad input format specified for key file\n");
 | 
				
			||||||
@@ -1112,120 +1088,76 @@ error:
 | 
				
			|||||||
	}
 | 
						}
 | 
				
			||||||
#endif /* ndef OPENSSL_NO_RC4 */
 | 
					#endif /* ndef OPENSSL_NO_RC4 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static int load_certs_crls(BIO *err, const char *file, int format,
 | 
					STACK_OF(X509) *load_certs(BIO *err, const char *file, int format,
 | 
				
			||||||
	const char *pass, ENGINE *e, const char *desc,
 | 
						const char *pass, ENGINE *e, const char *cert_descrip)
 | 
				
			||||||
	STACK_OF(X509) **pcerts, STACK_OF(X509_CRL) **pcrls)
 | 
					 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
 | 
						BIO *certs;
 | 
				
			||||||
	int i;
 | 
						int i;
 | 
				
			||||||
	BIO *bio;
 | 
						STACK_OF(X509) *othercerts = NULL;
 | 
				
			||||||
	STACK_OF(X509_INFO) *xis = NULL;
 | 
						STACK_OF(X509_INFO) *allcerts = NULL;
 | 
				
			||||||
	X509_INFO *xi;
 | 
						X509_INFO *xi;
 | 
				
			||||||
	PW_CB_DATA cb_data;
 | 
						PW_CB_DATA cb_data;
 | 
				
			||||||
	int rv = 0;
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	cb_data.password = pass;
 | 
						cb_data.password = pass;
 | 
				
			||||||
	cb_data.prompt_info = file;
 | 
						cb_data.prompt_info = file;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (format != FORMAT_PEM)
 | 
						if((certs = BIO_new(BIO_s_file())) == NULL)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		BIO_printf(err,"bad input format specified for %s\n", desc);
 | 
							ERR_print_errors(err);
 | 
				
			||||||
		return 0;
 | 
							goto end;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (file == NULL)
 | 
						if (file == NULL)
 | 
				
			||||||
		bio = BIO_new_fp(stdin,BIO_NOCLOSE);
 | 
							BIO_set_fp(certs,stdin,BIO_NOCLOSE);
 | 
				
			||||||
	else
 | 
						else
 | 
				
			||||||
		bio = BIO_new_file(file, "r");
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if (bio == NULL)
 | 
					 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		BIO_printf(err, "Error opening %s %s\n",
 | 
							if (BIO_read_filename(certs,file) <= 0)
 | 
				
			||||||
				desc, file ? file : "stdin");
 | 
								{
 | 
				
			||||||
		ERR_print_errors(err);
 | 
								BIO_printf(err, "Error opening %s %s\n",
 | 
				
			||||||
		return 0;
 | 
									cert_descrip, file);
 | 
				
			||||||
 | 
								ERR_print_errors(err);
 | 
				
			||||||
 | 
								goto end;
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	xis = PEM_X509_INFO_read_bio(bio, NULL,
 | 
						if      (format == FORMAT_PEM)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
							othercerts = sk_X509_new_null();
 | 
				
			||||||
 | 
							if(!othercerts)
 | 
				
			||||||
 | 
								{
 | 
				
			||||||
 | 
								sk_X509_free(othercerts);
 | 
				
			||||||
 | 
								othercerts = NULL;
 | 
				
			||||||
 | 
								goto end;
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							allcerts = PEM_X509_INFO_read_bio(certs, NULL,
 | 
				
			||||||
				(pem_password_cb *)password_callback, &cb_data);
 | 
									(pem_password_cb *)password_callback, &cb_data);
 | 
				
			||||||
 | 
							for(i = 0; i < sk_X509_INFO_num(allcerts); i++)
 | 
				
			||||||
	BIO_free(bio);
 | 
								{
 | 
				
			||||||
 | 
								xi = sk_X509_INFO_value (allcerts, i);
 | 
				
			||||||
	if (pcerts)
 | 
								if (xi->x509)
 | 
				
			||||||
		{
 | 
									{
 | 
				
			||||||
		*pcerts = sk_X509_new_null();
 | 
									sk_X509_push(othercerts, xi->x509);
 | 
				
			||||||
		if (!*pcerts)
 | 
									xi->x509 = NULL;
 | 
				
			||||||
			goto end;
 | 
									}
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							goto end;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
						else	{
 | 
				
			||||||
	if (pcrls)
 | 
							BIO_printf(err,"bad input format specified for %s\n",
 | 
				
			||||||
		{
 | 
								cert_descrip);
 | 
				
			||||||
		*pcrls = sk_X509_CRL_new_null();
 | 
							goto end;
 | 
				
			||||||
		if (!*pcrls)
 | 
					 | 
				
			||||||
			goto end;
 | 
					 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					end:
 | 
				
			||||||
	for(i = 0; i < sk_X509_INFO_num(xis); i++)
 | 
						if (othercerts == NULL)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		xi = sk_X509_INFO_value (xis, i);
 | 
							BIO_printf(err,"unable to load certificates\n");
 | 
				
			||||||
		if (xi->x509 && pcerts)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if (!sk_X509_push(*pcerts, xi->x509))
 | 
					 | 
				
			||||||
				goto end;
 | 
					 | 
				
			||||||
			xi->x509 = NULL;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		if (xi->crl && pcrls)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if (!sk_X509_CRL_push(*pcrls, xi->crl))
 | 
					 | 
				
			||||||
				goto end;
 | 
					 | 
				
			||||||
			xi->crl = NULL;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if (pcerts && sk_X509_num(*pcerts) > 0)
 | 
					 | 
				
			||||||
		rv = 1;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if (pcrls && sk_X509_CRL_num(*pcrls) > 0)
 | 
					 | 
				
			||||||
		rv = 1;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	end:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if (xis)
 | 
					 | 
				
			||||||
		sk_X509_INFO_pop_free(xis, X509_INFO_free);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if (rv == 0)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		if (pcerts)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			sk_X509_pop_free(*pcerts, X509_free);
 | 
					 | 
				
			||||||
			*pcerts = NULL;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		if (pcrls)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			sk_X509_CRL_pop_free(*pcrls, X509_CRL_free);
 | 
					 | 
				
			||||||
			*pcrls = NULL;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		BIO_printf(err,"unable to load %s\n",
 | 
					 | 
				
			||||||
				pcerts ? "certificates" : "CRLs");
 | 
					 | 
				
			||||||
		ERR_print_errors(err);
 | 
							ERR_print_errors(err);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	return rv;
 | 
						if (allcerts) sk_X509_INFO_pop_free(allcerts, X509_INFO_free);
 | 
				
			||||||
 | 
						if (certs != NULL) BIO_free(certs);
 | 
				
			||||||
 | 
						return(othercerts);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
STACK_OF(X509) *load_certs(BIO *err, const char *file, int format,
 | 
					 | 
				
			||||||
	const char *pass, ENGINE *e, const char *desc)
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	STACK_OF(X509) *certs;
 | 
					 | 
				
			||||||
	load_certs_crls(err, file, format, pass, e, desc, &certs, NULL);
 | 
					 | 
				
			||||||
	return certs;
 | 
					 | 
				
			||||||
	}	
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
STACK_OF(X509_CRL) *load_crls(BIO *err, const char *file, int format,
 | 
					 | 
				
			||||||
	const char *pass, ENGINE *e, const char *desc)
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	STACK_OF(X509_CRL) *crls;
 | 
					 | 
				
			||||||
	load_certs_crls(err, file, format, pass, e, desc, NULL, &crls);
 | 
					 | 
				
			||||||
	return crls;
 | 
					 | 
				
			||||||
	}	
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define X509V3_EXT_UNKNOWN_MASK		(0xfL << 16)
 | 
					#define X509V3_EXT_UNKNOWN_MASK		(0xfL << 16)
 | 
				
			||||||
/* Return error for unknown extensions */
 | 
					/* Return error for unknown extensions */
 | 
				
			||||||
@@ -1549,7 +1481,7 @@ char *make_config_name()
 | 
				
			|||||||
	return p;
 | 
						return p;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static unsigned long index_serial_hash(const OPENSSL_CSTRING *a)
 | 
					static unsigned long index_serial_hash(const CSTRING *a)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
	const char *n;
 | 
						const char *n;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -1558,7 +1490,7 @@ static unsigned long index_serial_hash(const OPENSSL_CSTRING *a)
 | 
				
			|||||||
	return(lh_strhash(n));
 | 
						return(lh_strhash(n));
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static int index_serial_cmp(const OPENSSL_CSTRING *a, const OPENSSL_CSTRING *b)
 | 
					static int index_serial_cmp(const CSTRING *a, const CSTRING *b)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
	const char *aa,*bb;
 | 
						const char *aa,*bb;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -1570,16 +1502,16 @@ static int index_serial_cmp(const OPENSSL_CSTRING *a, const OPENSSL_CSTRING *b)
 | 
				
			|||||||
static int index_name_qual(char **a)
 | 
					static int index_name_qual(char **a)
 | 
				
			||||||
	{ return(a[0][0] == 'V'); }
 | 
						{ return(a[0][0] == 'V'); }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static unsigned long index_name_hash(const OPENSSL_CSTRING *a)
 | 
					static unsigned long index_name_hash(const CSTRING *a)
 | 
				
			||||||
	{ return(lh_strhash(a[DB_name])); }
 | 
						{ return(lh_strhash(a[DB_name])); }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
int index_name_cmp(const OPENSSL_CSTRING *a, const OPENSSL_CSTRING *b)
 | 
					int index_name_cmp(const CSTRING *a, const CSTRING *b)
 | 
				
			||||||
	{ return(strcmp(a[DB_name], b[DB_name])); }
 | 
						{ return(strcmp(a[DB_name], b[DB_name])); }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static IMPLEMENT_LHASH_HASH_FN(index_serial, OPENSSL_CSTRING)
 | 
					static IMPLEMENT_LHASH_HASH_FN(index_serial, CSTRING)
 | 
				
			||||||
static IMPLEMENT_LHASH_COMP_FN(index_serial, OPENSSL_CSTRING)
 | 
					static IMPLEMENT_LHASH_COMP_FN(index_serial, CSTRING)
 | 
				
			||||||
static IMPLEMENT_LHASH_HASH_FN(index_name, OPENSSL_CSTRING)
 | 
					static IMPLEMENT_LHASH_HASH_FN(index_name, CSTRING)
 | 
				
			||||||
static IMPLEMENT_LHASH_COMP_FN(index_name, OPENSSL_CSTRING)
 | 
					static IMPLEMENT_LHASH_COMP_FN(index_name, CSTRING)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#undef BSIZE
 | 
					#undef BSIZE
 | 
				
			||||||
#define BSIZE 256
 | 
					#define BSIZE 256
 | 
				
			||||||
@@ -2253,10 +2185,9 @@ int args_verify(char ***pargs, int *pargc,
 | 
				
			|||||||
	ASN1_OBJECT *otmp = NULL;
 | 
						ASN1_OBJECT *otmp = NULL;
 | 
				
			||||||
	unsigned long flags = 0;
 | 
						unsigned long flags = 0;
 | 
				
			||||||
	int i;
 | 
						int i;
 | 
				
			||||||
	int purpose = 0, depth = -1;
 | 
						int purpose = 0;
 | 
				
			||||||
	char **oldargs = *pargs;
 | 
						char **oldargs = *pargs;
 | 
				
			||||||
	char *arg = **pargs, *argn = (*pargs)[1];
 | 
						char *arg = **pargs, *argn = (*pargs)[1];
 | 
				
			||||||
	const X509_VERIFY_PARAM *vpm = NULL;
 | 
					 | 
				
			||||||
	if (!strcmp(arg, "-policy"))
 | 
						if (!strcmp(arg, "-policy"))
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		if (!argn)
 | 
							if (!argn)
 | 
				
			||||||
@@ -2294,36 +2225,6 @@ int args_verify(char ***pargs, int *pargc,
 | 
				
			|||||||
			}
 | 
								}
 | 
				
			||||||
		(*pargs)++;
 | 
							(*pargs)++;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	else if (strcmp(arg,"-verify_name") == 0)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		if (!argn)
 | 
					 | 
				
			||||||
			*badarg = 1;
 | 
					 | 
				
			||||||
		else
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			vpm = X509_VERIFY_PARAM_lookup(argn);
 | 
					 | 
				
			||||||
			if(!vpm)
 | 
					 | 
				
			||||||
				{
 | 
					 | 
				
			||||||
				BIO_printf(err, "unrecognized verify name\n");
 | 
					 | 
				
			||||||
				*badarg = 1;
 | 
					 | 
				
			||||||
				}
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		(*pargs)++;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	else if (strcmp(arg,"-verify_depth") == 0)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		if (!argn)
 | 
					 | 
				
			||||||
			*badarg = 1;
 | 
					 | 
				
			||||||
		else
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			depth = atoi(argn);
 | 
					 | 
				
			||||||
			if(depth < 0)
 | 
					 | 
				
			||||||
				{
 | 
					 | 
				
			||||||
				BIO_printf(err, "invalid depth\n");
 | 
					 | 
				
			||||||
				*badarg = 1;
 | 
					 | 
				
			||||||
				}
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		(*pargs)++;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	else if (!strcmp(arg, "-ignore_critical"))
 | 
						else if (!strcmp(arg, "-ignore_critical"))
 | 
				
			||||||
		flags |= X509_V_FLAG_IGNORE_CRITICAL;
 | 
							flags |= X509_V_FLAG_IGNORE_CRITICAL;
 | 
				
			||||||
	else if (!strcmp(arg, "-issuer_checks"))
 | 
						else if (!strcmp(arg, "-issuer_checks"))
 | 
				
			||||||
@@ -2348,10 +2249,6 @@ int args_verify(char ***pargs, int *pargc,
 | 
				
			|||||||
		flags |= X509_V_FLAG_USE_DELTAS;
 | 
							flags |= X509_V_FLAG_USE_DELTAS;
 | 
				
			||||||
	else if (!strcmp(arg, "-policy_print"))
 | 
						else if (!strcmp(arg, "-policy_print"))
 | 
				
			||||||
		flags |= X509_V_FLAG_NOTIFY_POLICY;
 | 
							flags |= X509_V_FLAG_NOTIFY_POLICY;
 | 
				
			||||||
	else if (!strcmp(arg, "-check_ss_sig"))
 | 
					 | 
				
			||||||
		flags |= X509_V_FLAG_CHECK_SS_SIGNATURE;
 | 
					 | 
				
			||||||
	else if (!strcmp(arg, "-trusted_first"))
 | 
					 | 
				
			||||||
		flags |= X509_V_FLAG_TRUSTED_FIRST;
 | 
					 | 
				
			||||||
	else
 | 
						else
 | 
				
			||||||
		return 0;
 | 
							return 0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -2369,9 +2266,6 @@ int args_verify(char ***pargs, int *pargc,
 | 
				
			|||||||
		goto end;
 | 
							goto end;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (vpm)
 | 
					 | 
				
			||||||
		X509_VERIFY_PARAM_set1(*pm, vpm);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if (otmp)
 | 
						if (otmp)
 | 
				
			||||||
		X509_VERIFY_PARAM_add0_policy(*pm, otmp);
 | 
							X509_VERIFY_PARAM_add0_policy(*pm, otmp);
 | 
				
			||||||
	if (flags)
 | 
						if (flags)
 | 
				
			||||||
@@ -2380,9 +2274,6 @@ int args_verify(char ***pargs, int *pargc,
 | 
				
			|||||||
	if (purpose)
 | 
						if (purpose)
 | 
				
			||||||
		X509_VERIFY_PARAM_set_purpose(*pm, purpose);
 | 
							X509_VERIFY_PARAM_set_purpose(*pm, purpose);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (depth >= 0)
 | 
					 | 
				
			||||||
		X509_VERIFY_PARAM_set_depth(*pm, depth);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	end:
 | 
						end:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	(*pargs)++;
 | 
						(*pargs)++;
 | 
				
			||||||
@@ -3039,46 +2930,3 @@ int raw_write_stdout(const void *buf,int siz)
 | 
				
			|||||||
int raw_write_stdout(const void *buf,int siz)
 | 
					int raw_write_stdout(const void *buf,int siz)
 | 
				
			||||||
	{	return write(fileno(stdout),buf,siz);	}
 | 
						{	return write(fileno(stdout),buf,siz);	}
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					 | 
				
			||||||
#if !defined(OPENSSL_NO_TLSEXT) && !defined(OPENSSL_NO_NEXTPROTONEG)
 | 
					 | 
				
			||||||
/* next_protos_parse parses a comma separated list of strings into a string
 | 
					 | 
				
			||||||
 * in a format suitable for passing to SSL_CTX_set_next_protos_advertised.
 | 
					 | 
				
			||||||
 *   outlen: (output) set to the length of the resulting buffer on success.
 | 
					 | 
				
			||||||
 *   in: a NUL termianted string like "abc,def,ghi"
 | 
					 | 
				
			||||||
 *
 | 
					 | 
				
			||||||
 *   returns: a malloced buffer or NULL on failure.
 | 
					 | 
				
			||||||
 */
 | 
					 | 
				
			||||||
unsigned char *next_protos_parse(unsigned short *outlen, const char *in)
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	size_t len;
 | 
					 | 
				
			||||||
	unsigned char *out;
 | 
					 | 
				
			||||||
	size_t i, start = 0;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	len = strlen(in);
 | 
					 | 
				
			||||||
	if (len >= 65535)
 | 
					 | 
				
			||||||
		return NULL;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	out = OPENSSL_malloc(strlen(in) + 1);
 | 
					 | 
				
			||||||
	if (!out)
 | 
					 | 
				
			||||||
		return NULL;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	for (i = 0; i <= len; ++i)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		if (i == len || in[i] == ',')
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if (i - start > 255)
 | 
					 | 
				
			||||||
				{
 | 
					 | 
				
			||||||
				OPENSSL_free(out);
 | 
					 | 
				
			||||||
				return NULL;
 | 
					 | 
				
			||||||
				}
 | 
					 | 
				
			||||||
			out[start] = i - start;
 | 
					 | 
				
			||||||
			start = i + 1;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		else
 | 
					 | 
				
			||||||
			out[i+1] = in[i];
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	*outlen = len + 1;
 | 
					 | 
				
			||||||
	return out;
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
#endif  /* !OPENSSL_NO_TLSEXT && !OPENSSL_NO_NEXTPROTONEG */
 | 
					 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										31
									
								
								apps/apps.h
									
									
									
									
									
								
							
							
						
						
									
										31
									
								
								apps/apps.h
									
									
									
									
									
								
							@@ -168,12 +168,6 @@ extern BIO *bio_err;
 | 
				
			|||||||
#define do_pipe_sig()
 | 
					#define do_pipe_sig()
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef OPENSSL_NO_COMP
 | 
					 | 
				
			||||||
#define zlib_cleanup() 
 | 
					 | 
				
			||||||
#else
 | 
					 | 
				
			||||||
#define zlib_cleanup() COMP_zlib_cleanup()
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#if defined(MONOLITH) && !defined(OPENSSL_C)
 | 
					#if defined(MONOLITH) && !defined(OPENSSL_C)
 | 
				
			||||||
#  define apps_startup() \
 | 
					#  define apps_startup() \
 | 
				
			||||||
		do_pipe_sig()
 | 
							do_pipe_sig()
 | 
				
			||||||
@@ -188,7 +182,7 @@ extern BIO *bio_err;
 | 
				
			|||||||
			do { CONF_modules_unload(1); destroy_ui_method(); \
 | 
								do { CONF_modules_unload(1); destroy_ui_method(); \
 | 
				
			||||||
			OBJ_cleanup(); EVP_cleanup(); ENGINE_cleanup(); \
 | 
								OBJ_cleanup(); EVP_cleanup(); ENGINE_cleanup(); \
 | 
				
			||||||
			CRYPTO_cleanup_all_ex_data(); ERR_remove_thread_state(NULL); \
 | 
								CRYPTO_cleanup_all_ex_data(); ERR_remove_thread_state(NULL); \
 | 
				
			||||||
			ERR_free_strings(); zlib_cleanup();} while(0)
 | 
								ERR_free_strings(); COMP_zlib_cleanup();} while(0)
 | 
				
			||||||
#  else
 | 
					#  else
 | 
				
			||||||
#    define apps_startup() \
 | 
					#    define apps_startup() \
 | 
				
			||||||
			do { do_pipe_sig(); CRYPTO_malloc_init(); \
 | 
								do { do_pipe_sig(); CRYPTO_malloc_init(); \
 | 
				
			||||||
@@ -198,7 +192,7 @@ extern BIO *bio_err;
 | 
				
			|||||||
			do { CONF_modules_unload(1); destroy_ui_method(); \
 | 
								do { CONF_modules_unload(1); destroy_ui_method(); \
 | 
				
			||||||
			OBJ_cleanup(); EVP_cleanup(); \
 | 
								OBJ_cleanup(); EVP_cleanup(); \
 | 
				
			||||||
			CRYPTO_cleanup_all_ex_data(); ERR_remove_thread_state(NULL); \
 | 
								CRYPTO_cleanup_all_ex_data(); ERR_remove_thread_state(NULL); \
 | 
				
			||||||
			ERR_free_strings(); zlib_cleanup(); } while(0)
 | 
								ERR_free_strings(); } while(0)
 | 
				
			||||||
#  endif
 | 
					#  endif
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -251,8 +245,6 @@ EVP_PKEY *load_pubkey(BIO *err, const char *file, int format, int maybe_stdin,
 | 
				
			|||||||
	const char *pass, ENGINE *e, const char *key_descrip);
 | 
						const char *pass, ENGINE *e, const char *key_descrip);
 | 
				
			||||||
STACK_OF(X509) *load_certs(BIO *err, const char *file, int format,
 | 
					STACK_OF(X509) *load_certs(BIO *err, const char *file, int format,
 | 
				
			||||||
	const char *pass, ENGINE *e, const char *cert_descrip);
 | 
						const char *pass, ENGINE *e, const char *cert_descrip);
 | 
				
			||||||
STACK_OF(X509_CRL) *load_crls(BIO *err, const char *file, int format,
 | 
					 | 
				
			||||||
	const char *pass, ENGINE *e, const char *cert_descrip);
 | 
					 | 
				
			||||||
X509_STORE *setup_verify(BIO *bp, char *CAfile, char *CApath);
 | 
					X509_STORE *setup_verify(BIO *bp, char *CAfile, char *CApath);
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					#ifndef OPENSSL_NO_ENGINE
 | 
				
			||||||
ENGINE *setup_engine(BIO *err, const char *engine, int debug);
 | 
					ENGINE *setup_engine(BIO *err, const char *engine, int debug);
 | 
				
			||||||
@@ -261,7 +253,6 @@ ENGINE *setup_engine(BIO *err, const char *engine, int debug);
 | 
				
			|||||||
#ifndef OPENSSL_NO_OCSP
 | 
					#ifndef OPENSSL_NO_OCSP
 | 
				
			||||||
OCSP_RESPONSE *process_responder(BIO *err, OCSP_REQUEST *req,
 | 
					OCSP_RESPONSE *process_responder(BIO *err, OCSP_REQUEST *req,
 | 
				
			||||||
			char *host, char *path, char *port, int use_ssl,
 | 
								char *host, char *path, char *port, int use_ssl,
 | 
				
			||||||
			STACK_OF(CONF_VALUE) *headers,
 | 
					 | 
				
			||||||
			int req_timeout);
 | 
								int req_timeout);
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -304,9 +295,9 @@ int save_index(const char *dbfile, const char *suffix, CA_DB *db);
 | 
				
			|||||||
int rotate_index(const char *dbfile, const char *new_suffix, const char *old_suffix);
 | 
					int rotate_index(const char *dbfile, const char *new_suffix, const char *old_suffix);
 | 
				
			||||||
void free_index(CA_DB *db);
 | 
					void free_index(CA_DB *db);
 | 
				
			||||||
#define index_name_cmp_noconst(a, b) \
 | 
					#define index_name_cmp_noconst(a, b) \
 | 
				
			||||||
	index_name_cmp((const OPENSSL_CSTRING *)CHECKED_PTR_OF(OPENSSL_STRING, a), \
 | 
						index_name_cmp((const CSTRING *)CHECKED_PTR_OF(STRING, a), \
 | 
				
			||||||
	(const OPENSSL_CSTRING *)CHECKED_PTR_OF(OPENSSL_STRING, b))
 | 
						(const CSTRING *)CHECKED_PTR_OF(STRING, b))
 | 
				
			||||||
int index_name_cmp(const OPENSSL_CSTRING *a, const OPENSSL_CSTRING *b);
 | 
					int index_name_cmp(const CSTRING *a, const CSTRING *b);
 | 
				
			||||||
int parse_yesno(const char *str, int def);
 | 
					int parse_yesno(const char *str, int def);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
X509_NAME *parse_name(char *str, long chtype, int multirdn);
 | 
					X509_NAME *parse_name(char *str, long chtype, int multirdn);
 | 
				
			||||||
@@ -317,12 +308,6 @@ int bio_to_mem(unsigned char **out, int maxlen, BIO *in);
 | 
				
			|||||||
int pkey_ctrl_string(EVP_PKEY_CTX *ctx, char *value);
 | 
					int pkey_ctrl_string(EVP_PKEY_CTX *ctx, char *value);
 | 
				
			||||||
int init_gen_str(BIO *err, EVP_PKEY_CTX **pctx,
 | 
					int init_gen_str(BIO *err, EVP_PKEY_CTX **pctx,
 | 
				
			||||||
			const char *algname, ENGINE *e, int do_param);
 | 
								const char *algname, ENGINE *e, int do_param);
 | 
				
			||||||
int do_X509_sign(BIO *err, X509 *x, EVP_PKEY *pkey, const EVP_MD *md,
 | 
					 | 
				
			||||||
			STACK_OF(OPENSSL_STRING) *sigopts);
 | 
					 | 
				
			||||||
int do_X509_REQ_sign(BIO *err, X509_REQ *x, EVP_PKEY *pkey, const EVP_MD *md,
 | 
					 | 
				
			||||||
			STACK_OF(OPENSSL_STRING) *sigopts);
 | 
					 | 
				
			||||||
int do_X509_CRL_sign(BIO *err, X509_CRL *x, EVP_PKEY *pkey, const EVP_MD *md,
 | 
					 | 
				
			||||||
			STACK_OF(OPENSSL_STRING) *sigopts);
 | 
					 | 
				
			||||||
#ifndef OPENSSL_NO_PSK
 | 
					#ifndef OPENSSL_NO_PSK
 | 
				
			||||||
extern char *psk_key;
 | 
					extern char *psk_key;
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
@@ -364,9 +349,3 @@ int raw_write_stdout(const void *,int);
 | 
				
			|||||||
#define TM_STOP		1
 | 
					#define TM_STOP		1
 | 
				
			||||||
double app_tminterval (int stop,int usertime);
 | 
					double app_tminterval (int stop,int usertime);
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					 | 
				
			||||||
#define OPENSSL_NO_SSL_INTERN
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifndef OPENSSL_NO_NEXTPROTONEG
 | 
					 | 
				
			||||||
unsigned char *next_protos_parse(unsigned short *outlen, const char *in);
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 
 | 
				
			|||||||
@@ -96,7 +96,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	unsigned char *tmpbuf;
 | 
						unsigned char *tmpbuf;
 | 
				
			||||||
	const unsigned char *ctmpbuf;
 | 
						const unsigned char *ctmpbuf;
 | 
				
			||||||
	BUF_MEM *buf=NULL;
 | 
						BUF_MEM *buf=NULL;
 | 
				
			||||||
	STACK_OF(OPENSSL_STRING) *osk=NULL;
 | 
						STACK_OF(STRING) *osk=NULL;
 | 
				
			||||||
	ASN1_TYPE *at=NULL;
 | 
						ASN1_TYPE *at=NULL;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	informat=FORMAT_PEM;
 | 
						informat=FORMAT_PEM;
 | 
				
			||||||
@@ -113,7 +113,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	prog=argv[0];
 | 
						prog=argv[0];
 | 
				
			||||||
	argc--;
 | 
						argc--;
 | 
				
			||||||
	argv++;
 | 
						argv++;
 | 
				
			||||||
	if ((osk=sk_OPENSSL_STRING_new_null()) == NULL)
 | 
						if ((osk=sk_STRING_new_null()) == NULL)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		BIO_printf(bio_err,"Memory allocation failure\n");
 | 
							BIO_printf(bio_err,"Memory allocation failure\n");
 | 
				
			||||||
		goto end;
 | 
							goto end;
 | 
				
			||||||
@@ -169,7 +169,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		else if (strcmp(*argv,"-strparse") == 0)
 | 
							else if (strcmp(*argv,"-strparse") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
			sk_OPENSSL_STRING_push(osk,*(++argv));
 | 
								sk_STRING_push(osk,*(++argv));
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else if (strcmp(*argv,"-genstr") == 0)
 | 
							else if (strcmp(*argv,"-genstr") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
@@ -302,18 +302,18 @@ bad:
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	/* If any structs to parse go through in sequence */
 | 
						/* If any structs to parse go through in sequence */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (sk_OPENSSL_STRING_num(osk))
 | 
						if (sk_STRING_num(osk))
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		tmpbuf=(unsigned char *)str;
 | 
							tmpbuf=(unsigned char *)str;
 | 
				
			||||||
		tmplen=num;
 | 
							tmplen=num;
 | 
				
			||||||
		for (i=0; i<sk_OPENSSL_STRING_num(osk); i++)
 | 
							for (i=0; i<sk_STRING_num(osk); i++)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			ASN1_TYPE *atmp;
 | 
								ASN1_TYPE *atmp;
 | 
				
			||||||
			int typ;
 | 
								int typ;
 | 
				
			||||||
			j=atoi(sk_OPENSSL_STRING_value(osk,i));
 | 
								j=atoi(sk_STRING_value(osk,i));
 | 
				
			||||||
			if (j == 0)
 | 
								if (j == 0)
 | 
				
			||||||
				{
 | 
									{
 | 
				
			||||||
				BIO_printf(bio_err,"'%s' is an invalid number\n",sk_OPENSSL_STRING_value(osk,i));
 | 
									BIO_printf(bio_err,"'%s' is an invalid number\n",sk_STRING_value(osk,i));
 | 
				
			||||||
				continue;
 | 
									continue;
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
			tmpbuf+=j;
 | 
								tmpbuf+=j;
 | 
				
			||||||
@@ -378,7 +378,7 @@ end:
 | 
				
			|||||||
		ERR_print_errors(bio_err);
 | 
							ERR_print_errors(bio_err);
 | 
				
			||||||
	if (buf != NULL) BUF_MEM_free(buf);
 | 
						if (buf != NULL) BUF_MEM_free(buf);
 | 
				
			||||||
	if (at != NULL) ASN1_TYPE_free(at);
 | 
						if (at != NULL) ASN1_TYPE_free(at);
 | 
				
			||||||
	if (osk != NULL) sk_OPENSSL_STRING_free(osk);
 | 
						if (osk != NULL) sk_STRING_free(osk);
 | 
				
			||||||
	OBJ_cleanup();
 | 
						OBJ_cleanup();
 | 
				
			||||||
	apps_shutdown();
 | 
						apps_shutdown();
 | 
				
			||||||
	OPENSSL_EXIT(ret);
 | 
						OPENSSL_EXIT(ret);
 | 
				
			||||||
@@ -408,7 +408,6 @@ static int do_generate(BIO *bio, char *genstr, char *genconf, BUF_MEM *buf)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	atyp = ASN1_generate_nconf(genstr, cnf);
 | 
						atyp = ASN1_generate_nconf(genstr, cnf);
 | 
				
			||||||
	NCONF_free(cnf);
 | 
						NCONF_free(cnf);
 | 
				
			||||||
	cnf = NULL;
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (!atyp)
 | 
						if (!atyp)
 | 
				
			||||||
		return -1;
 | 
							return -1;
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										144
									
								
								apps/ca.c
									
									
									
									
									
								
							
							
						
						
									
										144
									
								
								apps/ca.c
									
									
									
									
									
								
							@@ -197,30 +197,27 @@ extern int EF_ALIGNMENT;
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
static void lookup_fail(const char *name, const char *tag);
 | 
					static void lookup_fail(const char *name, const char *tag);
 | 
				
			||||||
static int certify(X509 **xret, char *infile,EVP_PKEY *pkey,X509 *x509,
 | 
					static int certify(X509 **xret, char *infile,EVP_PKEY *pkey,X509 *x509,
 | 
				
			||||||
		   const EVP_MD *dgst,STACK_OF(OPENSSL_STRING) *sigopts,
 | 
							   const EVP_MD *dgst,STACK_OF(CONF_VALUE) *policy,CA_DB *db,
 | 
				
			||||||
		   STACK_OF(CONF_VALUE) *policy,CA_DB *db,
 | 
					 | 
				
			||||||
		   BIGNUM *serial, char *subj,unsigned long chtype, int multirdn, int email_dn, char *startdate,
 | 
							   BIGNUM *serial, char *subj,unsigned long chtype, int multirdn, int email_dn, char *startdate,
 | 
				
			||||||
		   char *enddate, long days, int batch, char *ext_sect, CONF *conf,
 | 
							   char *enddate, long days, int batch, char *ext_sect, CONF *conf,
 | 
				
			||||||
		   int verbose, unsigned long certopt, unsigned long nameopt,
 | 
							   int verbose, unsigned long certopt, unsigned long nameopt,
 | 
				
			||||||
		   int default_op, int ext_copy, int selfsign);
 | 
							   int default_op, int ext_copy, int selfsign);
 | 
				
			||||||
static int certify_cert(X509 **xret, char *infile,EVP_PKEY *pkey,X509 *x509,
 | 
					static int certify_cert(X509 **xret, char *infile,EVP_PKEY *pkey,X509 *x509,
 | 
				
			||||||
			const EVP_MD *dgst,STACK_OF(OPENSSL_STRING) *sigopts,
 | 
								const EVP_MD *dgst,STACK_OF(CONF_VALUE) *policy,
 | 
				
			||||||
			STACK_OF(CONF_VALUE) *policy,
 | 
					 | 
				
			||||||
			CA_DB *db, BIGNUM *serial, char *subj,unsigned long chtype, int multirdn, int email_dn,
 | 
								CA_DB *db, BIGNUM *serial, char *subj,unsigned long chtype, int multirdn, int email_dn,
 | 
				
			||||||
			char *startdate, char *enddate, long days, int batch,
 | 
								char *startdate, char *enddate, long days, int batch,
 | 
				
			||||||
			char *ext_sect, CONF *conf,int verbose, unsigned long certopt,
 | 
								char *ext_sect, CONF *conf,int verbose, unsigned long certopt,
 | 
				
			||||||
			unsigned long nameopt, int default_op, int ext_copy,
 | 
								unsigned long nameopt, int default_op, int ext_copy,
 | 
				
			||||||
			ENGINE *e);
 | 
								ENGINE *e);
 | 
				
			||||||
static int certify_spkac(X509 **xret, char *infile,EVP_PKEY *pkey,X509 *x509,
 | 
					static int certify_spkac(X509 **xret, char *infile,EVP_PKEY *pkey,X509 *x509,
 | 
				
			||||||
			 const EVP_MD *dgst,STACK_OF(OPENSSL_STRING) *sigopts,
 | 
								 const EVP_MD *dgst,STACK_OF(CONF_VALUE) *policy,
 | 
				
			||||||
			 STACK_OF(CONF_VALUE) *policy,
 | 
					 | 
				
			||||||
			 CA_DB *db, BIGNUM *serial,char *subj,unsigned long chtype, int multirdn, int email_dn,
 | 
								 CA_DB *db, BIGNUM *serial,char *subj,unsigned long chtype, int multirdn, int email_dn,
 | 
				
			||||||
			 char *startdate, char *enddate, long days, char *ext_sect,
 | 
								 char *startdate, char *enddate, long days, char *ext_sect,
 | 
				
			||||||
			 CONF *conf, int verbose, unsigned long certopt, 
 | 
								 CONF *conf, int verbose, unsigned long certopt, 
 | 
				
			||||||
			 unsigned long nameopt, int default_op, int ext_copy);
 | 
								 unsigned long nameopt, int default_op, int ext_copy);
 | 
				
			||||||
 | 
					static int fix_data(int nid, int *type);
 | 
				
			||||||
static void write_new_certificate(BIO *bp, X509 *x, int output_der, int notext);
 | 
					static void write_new_certificate(BIO *bp, X509 *x, int output_der, int notext);
 | 
				
			||||||
static int do_body(X509 **xret, EVP_PKEY *pkey, X509 *x509, const EVP_MD *dgst,
 | 
					static int do_body(X509 **xret, EVP_PKEY *pkey, X509 *x509, const EVP_MD *dgst,
 | 
				
			||||||
	STACK_OF(OPENSSL_STRING) *sigopts,
 | 
					 | 
				
			||||||
	STACK_OF(CONF_VALUE) *policy, CA_DB *db, BIGNUM *serial,char *subj,unsigned long chtype, int multirdn,
 | 
						STACK_OF(CONF_VALUE) *policy, CA_DB *db, BIGNUM *serial,char *subj,unsigned long chtype, int multirdn,
 | 
				
			||||||
	int email_dn, char *startdate, char *enddate, long days, int batch,
 | 
						int email_dn, char *startdate, char *enddate, long days, int batch,
 | 
				
			||||||
       	int verbose, X509_REQ *req, char *ext_sect, CONF *conf,
 | 
					       	int verbose, X509_REQ *req, char *ext_sect, CONF *conf,
 | 
				
			||||||
@@ -315,7 +312,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	const EVP_MD *dgst=NULL;
 | 
						const EVP_MD *dgst=NULL;
 | 
				
			||||||
	STACK_OF(CONF_VALUE) *attribs=NULL;
 | 
						STACK_OF(CONF_VALUE) *attribs=NULL;
 | 
				
			||||||
	STACK_OF(X509) *cert_sk=NULL;
 | 
						STACK_OF(X509) *cert_sk=NULL;
 | 
				
			||||||
	STACK_OF(OPENSSL_STRING) *sigopts = NULL;
 | 
					 | 
				
			||||||
#undef BSIZE
 | 
					#undef BSIZE
 | 
				
			||||||
#define BSIZE 256
 | 
					#define BSIZE 256
 | 
				
			||||||
	MS_STATIC char buf[3][BSIZE];
 | 
						MS_STATIC char buf[3][BSIZE];
 | 
				
			||||||
@@ -440,15 +436,6 @@ EF_ALIGNMENT=0;
 | 
				
			|||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
			outdir= *(++argv);
 | 
								outdir= *(++argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else if (strcmp(*argv,"-sigopt") == 0)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if (--argc < 1)
 | 
					 | 
				
			||||||
				goto bad;
 | 
					 | 
				
			||||||
			if (!sigopts)
 | 
					 | 
				
			||||||
				sigopts = sk_OPENSSL_STRING_new_null();
 | 
					 | 
				
			||||||
			if (!sigopts || !sk_OPENSSL_STRING_push(sigopts, *(++argv)))
 | 
					 | 
				
			||||||
				goto bad;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-notext") == 0)
 | 
							else if (strcmp(*argv,"-notext") == 0)
 | 
				
			||||||
			notext=1;
 | 
								notext=1;
 | 
				
			||||||
		else if (strcmp(*argv,"-batch") == 0)
 | 
							else if (strcmp(*argv,"-batch") == 0)
 | 
				
			||||||
@@ -896,9 +883,9 @@ bad:
 | 
				
			|||||||
	if (db == NULL) goto err;
 | 
						if (db == NULL) goto err;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/* Lets check some fields */
 | 
						/* Lets check some fields */
 | 
				
			||||||
	for (i=0; i<sk_OPENSSL_PSTRING_num(db->db->data); i++)
 | 
						for (i=0; i<sk_PSTRING_num(db->db->data); i++)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		pp=sk_OPENSSL_PSTRING_value(db->db->data,i);
 | 
							pp=sk_PSTRING_value(db->db->data,i);
 | 
				
			||||||
		if ((pp[DB_type][0] != DB_TYPE_REV) &&
 | 
							if ((pp[DB_type][0] != DB_TYPE_REV) &&
 | 
				
			||||||
			(pp[DB_rev_date][0] != '\0'))
 | 
								(pp[DB_rev_date][0] != '\0'))
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
@@ -951,7 +938,7 @@ bad:
 | 
				
			|||||||
#endif
 | 
					#endif
 | 
				
			||||||
		TXT_DB_write(out,db->db);
 | 
							TXT_DB_write(out,db->db);
 | 
				
			||||||
		BIO_printf(bio_err,"%d entries loaded from the database\n",
 | 
							BIO_printf(bio_err,"%d entries loaded from the database\n",
 | 
				
			||||||
			   sk_OPENSSL_PSTRING_num(db->db->data));
 | 
								   sk_PSTRING_num(db->db->data));
 | 
				
			||||||
		BIO_printf(bio_err,"generating index\n");
 | 
							BIO_printf(bio_err,"generating index\n");
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	
 | 
						
 | 
				
			||||||
@@ -1184,9 +1171,8 @@ bad:
 | 
				
			|||||||
		if (spkac_file != NULL)
 | 
							if (spkac_file != NULL)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			total++;
 | 
								total++;
 | 
				
			||||||
			j=certify_spkac(&x,spkac_file,pkey,x509,dgst,sigopts,
 | 
								j=certify_spkac(&x,spkac_file,pkey,x509,dgst,attribs,db,
 | 
				
			||||||
				attribs,db, serial,subj,chtype,multirdn,
 | 
									serial,subj,chtype,multirdn,email_dn,startdate,enddate,days,extensions,
 | 
				
			||||||
				email_dn,startdate,enddate,days,extensions,
 | 
					 | 
				
			||||||
				conf,verbose,certopt,nameopt,default_op,ext_copy);
 | 
									conf,verbose,certopt,nameopt,default_op,ext_copy);
 | 
				
			||||||
			if (j < 0) goto err;
 | 
								if (j < 0) goto err;
 | 
				
			||||||
			if (j > 0)
 | 
								if (j > 0)
 | 
				
			||||||
@@ -1209,8 +1195,7 @@ bad:
 | 
				
			|||||||
		if (ss_cert_file != NULL)
 | 
							if (ss_cert_file != NULL)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			total++;
 | 
								total++;
 | 
				
			||||||
			j=certify_cert(&x,ss_cert_file,pkey,x509,dgst,sigopts,
 | 
								j=certify_cert(&x,ss_cert_file,pkey,x509,dgst,attribs,
 | 
				
			||||||
				attribs,
 | 
					 | 
				
			||||||
				db,serial,subj,chtype,multirdn,email_dn,startdate,enddate,days,batch,
 | 
									db,serial,subj,chtype,multirdn,email_dn,startdate,enddate,days,batch,
 | 
				
			||||||
				extensions,conf,verbose, certopt, nameopt,
 | 
									extensions,conf,verbose, certopt, nameopt,
 | 
				
			||||||
				default_op, ext_copy, e);
 | 
									default_op, ext_copy, e);
 | 
				
			||||||
@@ -1230,7 +1215,7 @@ bad:
 | 
				
			|||||||
		if (infile != NULL)
 | 
							if (infile != NULL)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			total++;
 | 
								total++;
 | 
				
			||||||
			j=certify(&x,infile,pkey,x509p,dgst,sigopts, attribs,db,
 | 
								j=certify(&x,infile,pkey,x509p,dgst,attribs,db,
 | 
				
			||||||
				serial,subj,chtype,multirdn,email_dn,startdate,enddate,days,batch,
 | 
									serial,subj,chtype,multirdn,email_dn,startdate,enddate,days,batch,
 | 
				
			||||||
				extensions,conf,verbose, certopt, nameopt,
 | 
									extensions,conf,verbose, certopt, nameopt,
 | 
				
			||||||
				default_op, ext_copy, selfsign);
 | 
									default_op, ext_copy, selfsign);
 | 
				
			||||||
@@ -1250,7 +1235,7 @@ bad:
 | 
				
			|||||||
		for (i=0; i<argc; i++)
 | 
							for (i=0; i<argc; i++)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			total++;
 | 
								total++;
 | 
				
			||||||
			j=certify(&x,argv[i],pkey,x509p,dgst,sigopts,attribs,db,
 | 
								j=certify(&x,argv[i],pkey,x509p,dgst,attribs,db,
 | 
				
			||||||
				serial,subj,chtype,multirdn,email_dn,startdate,enddate,days,batch,
 | 
									serial,subj,chtype,multirdn,email_dn,startdate,enddate,days,batch,
 | 
				
			||||||
				extensions,conf,verbose, certopt, nameopt,
 | 
									extensions,conf,verbose, certopt, nameopt,
 | 
				
			||||||
				default_op, ext_copy, selfsign);
 | 
									default_op, ext_copy, selfsign);
 | 
				
			||||||
@@ -1278,12 +1263,7 @@ bad:
 | 
				
			|||||||
				BIO_printf(bio_err,"\n%d out of %d certificate requests certified, commit? [y/n]",total_done,total);
 | 
									BIO_printf(bio_err,"\n%d out of %d certificate requests certified, commit? [y/n]",total_done,total);
 | 
				
			||||||
				(void)BIO_flush(bio_err);
 | 
									(void)BIO_flush(bio_err);
 | 
				
			||||||
				buf[0][0]='\0';
 | 
									buf[0][0]='\0';
 | 
				
			||||||
				if (!fgets(buf[0],10,stdin))
 | 
									fgets(buf[0],10,stdin);
 | 
				
			||||||
					{
 | 
					 | 
				
			||||||
					BIO_printf(bio_err,"CERTIFICATION CANCELED: I/O error\n"); 
 | 
					 | 
				
			||||||
					ret=0;
 | 
					 | 
				
			||||||
					goto err;
 | 
					 | 
				
			||||||
					}
 | 
					 | 
				
			||||||
				if ((buf[0][0] != 'y') && (buf[0][0] != 'Y'))
 | 
									if ((buf[0][0] != 'y') && (buf[0][0] != 'Y'))
 | 
				
			||||||
					{
 | 
										{
 | 
				
			||||||
					BIO_printf(bio_err,"CERTIFICATION CANCELED\n"); 
 | 
										BIO_printf(bio_err,"CERTIFICATION CANCELED\n"); 
 | 
				
			||||||
@@ -1408,7 +1388,6 @@ bad:
 | 
				
			|||||||
			if (!NCONF_get_number(conf,section,
 | 
								if (!NCONF_get_number(conf,section,
 | 
				
			||||||
				ENV_DEFAULT_CRL_HOURS, &crlhours))
 | 
									ENV_DEFAULT_CRL_HOURS, &crlhours))
 | 
				
			||||||
				crlhours = 0;
 | 
									crlhours = 0;
 | 
				
			||||||
			ERR_clear_error();
 | 
					 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		if ((crldays == 0) && (crlhours == 0) && (crlsec == 0))
 | 
							if ((crldays == 0) && (crlhours == 0) && (crlsec == 0))
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
@@ -1424,19 +1403,14 @@ bad:
 | 
				
			|||||||
		if (!tmptm) goto err;
 | 
							if (!tmptm) goto err;
 | 
				
			||||||
		X509_gmtime_adj(tmptm,0);
 | 
							X509_gmtime_adj(tmptm,0);
 | 
				
			||||||
		X509_CRL_set_lastUpdate(crl, tmptm);	
 | 
							X509_CRL_set_lastUpdate(crl, tmptm);	
 | 
				
			||||||
		if (!X509_time_adj_ex(tmptm, crldays, crlhours*60*60 + crlsec,
 | 
							X509_time_adj_ex(tmptm, crldays, crlhours*60*60 + crlsec, NULL);
 | 
				
			||||||
			NULL))
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			BIO_puts(bio_err, "error setting CRL nextUpdate\n");
 | 
					 | 
				
			||||||
			goto err;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		X509_CRL_set_nextUpdate(crl, tmptm);	
 | 
							X509_CRL_set_nextUpdate(crl, tmptm);	
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		ASN1_TIME_free(tmptm);
 | 
							ASN1_TIME_free(tmptm);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		for (i=0; i<sk_OPENSSL_PSTRING_num(db->db->data); i++)
 | 
							for (i=0; i<sk_PSTRING_num(db->db->data); i++)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			pp=sk_OPENSSL_PSTRING_value(db->db->data,i);
 | 
								pp=sk_PSTRING_value(db->db->data,i);
 | 
				
			||||||
			if (pp[DB_type][0] == DB_TYPE_REV)
 | 
								if (pp[DB_type][0] == DB_TYPE_REV)
 | 
				
			||||||
				{
 | 
									{
 | 
				
			||||||
				if ((r=X509_REVOKED_new()) == NULL) goto err;
 | 
									if ((r=X509_REVOKED_new()) == NULL) goto err;
 | 
				
			||||||
@@ -1500,7 +1474,7 @@ bad:
 | 
				
			|||||||
			crlnumber = NULL;
 | 
								crlnumber = NULL;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if (!do_X509_CRL_sign(bio_err,crl,pkey,dgst,sigopts)) goto err;
 | 
							if (!X509_CRL_sign(crl,pkey,dgst)) goto err;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		PEM_write_bio_X509_CRL(Sout,crl);
 | 
							PEM_write_bio_X509_CRL(Sout,crl);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -1554,8 +1528,6 @@ err:
 | 
				
			|||||||
	BN_free(serial);
 | 
						BN_free(serial);
 | 
				
			||||||
	BN_free(crlnumber);
 | 
						BN_free(crlnumber);
 | 
				
			||||||
	free_index(db);
 | 
						free_index(db);
 | 
				
			||||||
	if (sigopts)
 | 
					 | 
				
			||||||
		sk_OPENSSL_STRING_free(sigopts);
 | 
					 | 
				
			||||||
	EVP_PKEY_free(pkey);
 | 
						EVP_PKEY_free(pkey);
 | 
				
			||||||
	if (x509) X509_free(x509);
 | 
						if (x509) X509_free(x509);
 | 
				
			||||||
	X509_CRL_free(crl);
 | 
						X509_CRL_free(crl);
 | 
				
			||||||
@@ -1572,10 +1544,8 @@ static void lookup_fail(const char *name, const char *tag)
 | 
				
			|||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static int certify(X509 **xret, char *infile, EVP_PKEY *pkey, X509 *x509,
 | 
					static int certify(X509 **xret, char *infile, EVP_PKEY *pkey, X509 *x509,
 | 
				
			||||||
	     const EVP_MD *dgst, STACK_OF(OPENSSL_STRING) *sigopts,
 | 
						     const EVP_MD *dgst, STACK_OF(CONF_VALUE) *policy, CA_DB *db,
 | 
				
			||||||
	     STACK_OF(CONF_VALUE) *policy, CA_DB *db,
 | 
						     BIGNUM *serial, char *subj,unsigned long chtype, int multirdn, int email_dn, char *startdate, char *enddate,
 | 
				
			||||||
	     BIGNUM *serial, char *subj,unsigned long chtype, int multirdn,
 | 
					 | 
				
			||||||
	     int email_dn, char *startdate, char *enddate,
 | 
					 | 
				
			||||||
	     long days, int batch, char *ext_sect, CONF *lconf, int verbose,
 | 
						     long days, int batch, char *ext_sect, CONF *lconf, int verbose,
 | 
				
			||||||
	     unsigned long certopt, unsigned long nameopt, int default_op,
 | 
						     unsigned long certopt, unsigned long nameopt, int default_op,
 | 
				
			||||||
	     int ext_copy, int selfsign)
 | 
						     int ext_copy, int selfsign)
 | 
				
			||||||
@@ -1631,8 +1601,7 @@ static int certify(X509 **xret, char *infile, EVP_PKEY *pkey, X509 *x509,
 | 
				
			|||||||
	else
 | 
						else
 | 
				
			||||||
		BIO_printf(bio_err,"Signature ok\n");
 | 
							BIO_printf(bio_err,"Signature ok\n");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	ok=do_body(xret,pkey,x509,dgst,sigopts, policy,db,serial,subj,chtype,
 | 
						ok=do_body(xret,pkey,x509,dgst,policy,db,serial,subj,chtype,multirdn, email_dn,
 | 
				
			||||||
		multirdn, email_dn,
 | 
					 | 
				
			||||||
		startdate,enddate,days,batch,verbose,req,ext_sect,lconf,
 | 
							startdate,enddate,days,batch,verbose,req,ext_sect,lconf,
 | 
				
			||||||
		certopt, nameopt, default_op, ext_copy, selfsign);
 | 
							certopt, nameopt, default_op, ext_copy, selfsign);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -1643,8 +1612,7 @@ err:
 | 
				
			|||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static int certify_cert(X509 **xret, char *infile, EVP_PKEY *pkey, X509 *x509,
 | 
					static int certify_cert(X509 **xret, char *infile, EVP_PKEY *pkey, X509 *x509,
 | 
				
			||||||
	     const EVP_MD *dgst, STACK_OF(OPENSSL_STRING) *sigopts,
 | 
						     const EVP_MD *dgst, STACK_OF(CONF_VALUE) *policy, CA_DB *db,
 | 
				
			||||||
	     STACK_OF(CONF_VALUE) *policy, CA_DB *db,
 | 
					 | 
				
			||||||
	     BIGNUM *serial, char *subj, unsigned long chtype, int multirdn, int email_dn, char *startdate, char *enddate,
 | 
						     BIGNUM *serial, char *subj, unsigned long chtype, int multirdn, int email_dn, char *startdate, char *enddate,
 | 
				
			||||||
	     long days, int batch, char *ext_sect, CONF *lconf, int verbose,
 | 
						     long days, int batch, char *ext_sect, CONF *lconf, int verbose,
 | 
				
			||||||
	     unsigned long certopt, unsigned long nameopt, int default_op,
 | 
						     unsigned long certopt, unsigned long nameopt, int default_op,
 | 
				
			||||||
@@ -1687,7 +1655,7 @@ static int certify_cert(X509 **xret, char *infile, EVP_PKEY *pkey, X509 *x509,
 | 
				
			|||||||
	if ((rreq=X509_to_X509_REQ(req,NULL,EVP_md5())) == NULL)
 | 
						if ((rreq=X509_to_X509_REQ(req,NULL,EVP_md5())) == NULL)
 | 
				
			||||||
		goto err;
 | 
							goto err;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	ok=do_body(xret,pkey,x509,dgst,sigopts,policy,db,serial,subj,chtype,multirdn,email_dn,startdate,enddate,
 | 
						ok=do_body(xret,pkey,x509,dgst,policy,db,serial,subj,chtype,multirdn,email_dn,startdate,enddate,
 | 
				
			||||||
		days,batch,verbose,rreq,ext_sect,lconf, certopt, nameopt, default_op,
 | 
							days,batch,verbose,rreq,ext_sect,lconf, certopt, nameopt, default_op,
 | 
				
			||||||
		ext_copy, 0);
 | 
							ext_copy, 0);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -1698,8 +1666,7 @@ err:
 | 
				
			|||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static int do_body(X509 **xret, EVP_PKEY *pkey, X509 *x509, const EVP_MD *dgst,
 | 
					static int do_body(X509 **xret, EVP_PKEY *pkey, X509 *x509, const EVP_MD *dgst,
 | 
				
			||||||
	     STACK_OF(OPENSSL_STRING) *sigopts, STACK_OF(CONF_VALUE) *policy,
 | 
						     STACK_OF(CONF_VALUE) *policy, CA_DB *db, BIGNUM *serial, char *subj,
 | 
				
			||||||
             CA_DB *db, BIGNUM *serial, char *subj,
 | 
					 | 
				
			||||||
	     unsigned long chtype, int multirdn,
 | 
						     unsigned long chtype, int multirdn,
 | 
				
			||||||
	     int email_dn, char *startdate, char *enddate, long days, int batch,
 | 
						     int email_dn, char *startdate, char *enddate, long days, int batch,
 | 
				
			||||||
	     int verbose, X509_REQ *req, char *ext_sect, CONF *lconf,
 | 
						     int verbose, X509_REQ *req, char *ext_sect, CONF *lconf,
 | 
				
			||||||
@@ -1718,9 +1685,9 @@ static int do_body(X509 **xret, EVP_PKEY *pkey, X509 *x509, const EVP_MD *dgst,
 | 
				
			|||||||
	int ok= -1,i,j,last,nid;
 | 
						int ok= -1,i,j,last,nid;
 | 
				
			||||||
	const char *p;
 | 
						const char *p;
 | 
				
			||||||
	CONF_VALUE *cv;
 | 
						CONF_VALUE *cv;
 | 
				
			||||||
	OPENSSL_STRING row[DB_NUMBER];
 | 
						STRING row[DB_NUMBER];
 | 
				
			||||||
	OPENSSL_STRING *irow=NULL;
 | 
						STRING *irow=NULL;
 | 
				
			||||||
	OPENSSL_STRING *rrow=NULL;
 | 
						STRING *rrow=NULL;
 | 
				
			||||||
	char buf[25];
 | 
						char buf[25];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	tmptm=ASN1_UTCTIME_new();
 | 
						tmptm=ASN1_UTCTIME_new();
 | 
				
			||||||
@@ -1962,7 +1929,7 @@ again2:
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	if (db->attributes.unique_subject)
 | 
						if (db->attributes.unique_subject)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		OPENSSL_STRING *crow=row;
 | 
							STRING *crow=row;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		rrow=TXT_DB_get_by_index(db->db,DB_name,crow);
 | 
							rrow=TXT_DB_get_by_index(db->db,DB_name,crow);
 | 
				
			||||||
		if (rrow != NULL)
 | 
							if (rrow != NULL)
 | 
				
			||||||
@@ -2150,12 +2117,7 @@ again2:
 | 
				
			|||||||
		BIO_printf(bio_err,"Sign the certificate? [y/n]:");
 | 
							BIO_printf(bio_err,"Sign the certificate? [y/n]:");
 | 
				
			||||||
		(void)BIO_flush(bio_err);
 | 
							(void)BIO_flush(bio_err);
 | 
				
			||||||
		buf[0]='\0';
 | 
							buf[0]='\0';
 | 
				
			||||||
		if (!fgets(buf,sizeof(buf)-1,stdin))
 | 
							fgets(buf,sizeof(buf)-1,stdin);
 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			BIO_printf(bio_err,"CERTIFICATE WILL NOT BE CERTIFIED: I/O error\n");
 | 
					 | 
				
			||||||
			ok=0;
 | 
					 | 
				
			||||||
			goto err;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		if (!((buf[0] == 'y') || (buf[0] == 'Y')))
 | 
							if (!((buf[0] == 'y') || (buf[0] == 'Y')))
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			BIO_printf(bio_err,"CERTIFICATE WILL NOT BE CERTIFIED\n");
 | 
								BIO_printf(bio_err,"CERTIFICATE WILL NOT BE CERTIFIED\n");
 | 
				
			||||||
@@ -2170,7 +2132,7 @@ again2:
 | 
				
			|||||||
		EVP_PKEY_copy_parameters(pktmp,pkey);
 | 
							EVP_PKEY_copy_parameters(pktmp,pkey);
 | 
				
			||||||
	EVP_PKEY_free(pktmp);
 | 
						EVP_PKEY_free(pktmp);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (!do_X509_sign(bio_err, ret,pkey,dgst, sigopts))
 | 
						if (!X509_sign(ret,pkey,dgst))
 | 
				
			||||||
		goto err;
 | 
							goto err;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/* We now just add it to the database */
 | 
						/* We now just add it to the database */
 | 
				
			||||||
@@ -2264,8 +2226,7 @@ static void write_new_certificate(BIO *bp, X509 *x, int output_der, int notext)
 | 
				
			|||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static int certify_spkac(X509 **xret, char *infile, EVP_PKEY *pkey, X509 *x509,
 | 
					static int certify_spkac(X509 **xret, char *infile, EVP_PKEY *pkey, X509 *x509,
 | 
				
			||||||
	     const EVP_MD *dgst, STACK_OF(OPENSSL_STRING) *sigopts,
 | 
						     const EVP_MD *dgst, STACK_OF(CONF_VALUE) *policy, CA_DB *db,
 | 
				
			||||||
	     STACK_OF(CONF_VALUE) *policy, CA_DB *db,
 | 
					 | 
				
			||||||
	     BIGNUM *serial, char *subj,unsigned long chtype, int multirdn, int email_dn, char *startdate, char *enddate,
 | 
						     BIGNUM *serial, char *subj,unsigned long chtype, int multirdn, int email_dn, char *startdate, char *enddate,
 | 
				
			||||||
	     long days, char *ext_sect, CONF *lconf, int verbose, unsigned long certopt,
 | 
						     long days, char *ext_sect, CONF *lconf, int verbose, unsigned long certopt,
 | 
				
			||||||
	     unsigned long nameopt, int default_op, int ext_copy)
 | 
						     unsigned long nameopt, int default_op, int ext_copy)
 | 
				
			||||||
@@ -2358,9 +2319,25 @@ static int certify_spkac(X509 **xret, char *infile, EVP_PKEY *pkey, X509 *x509,
 | 
				
			|||||||
			continue;
 | 
								continue;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if (!X509_NAME_add_entry_by_NID(n, nid, chtype,
 | 
							/*
 | 
				
			||||||
				(unsigned char *)buf, -1, -1, 0))
 | 
							if ((nid == NID_pkcs9_emailAddress) && (email_dn == 0))
 | 
				
			||||||
 | 
								continue;
 | 
				
			||||||
 | 
							*/
 | 
				
			||||||
 | 
							
 | 
				
			||||||
 | 
							j=ASN1_PRINTABLE_type((unsigned char *)buf,-1);
 | 
				
			||||||
 | 
							if (fix_data(nid, &j) == 0)
 | 
				
			||||||
 | 
								{
 | 
				
			||||||
 | 
								BIO_printf(bio_err,
 | 
				
			||||||
 | 
									"invalid characters in string %s\n",buf);
 | 
				
			||||||
			goto err;
 | 
								goto err;
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							if ((ne=X509_NAME_ENTRY_create_by_NID(&ne,nid,j,
 | 
				
			||||||
 | 
								(unsigned char *)buf,
 | 
				
			||||||
 | 
								strlen(buf))) == NULL)
 | 
				
			||||||
 | 
								goto err;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							if (!X509_NAME_add_entry(n,ne,-1, 0)) goto err;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	if (spki == NULL)
 | 
						if (spki == NULL)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
@@ -2391,9 +2368,9 @@ static int certify_spkac(X509 **xret, char *infile, EVP_PKEY *pkey, X509 *x509,
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	X509_REQ_set_pubkey(req,pktmp);
 | 
						X509_REQ_set_pubkey(req,pktmp);
 | 
				
			||||||
	EVP_PKEY_free(pktmp);
 | 
						EVP_PKEY_free(pktmp);
 | 
				
			||||||
	ok=do_body(xret,pkey,x509,dgst,sigopts,policy,db,serial,subj,chtype,
 | 
						ok=do_body(xret,pkey,x509,dgst,policy,db,serial,subj,chtype,multirdn,email_dn,startdate,enddate,
 | 
				
			||||||
		   multirdn,email_dn,startdate,enddate, days,1,verbose,req,
 | 
							   days,1,verbose,req,ext_sect,lconf, certopt, nameopt, default_op,
 | 
				
			||||||
		   ext_sect,lconf, certopt, nameopt, default_op, ext_copy, 0);
 | 
								ext_copy, 0);
 | 
				
			||||||
err:
 | 
					err:
 | 
				
			||||||
	if (req != NULL) X509_REQ_free(req);
 | 
						if (req != NULL) X509_REQ_free(req);
 | 
				
			||||||
	if (parms != NULL) CONF_free(parms);
 | 
						if (parms != NULL) CONF_free(parms);
 | 
				
			||||||
@@ -2403,6 +2380,21 @@ err:
 | 
				
			|||||||
	return(ok);
 | 
						return(ok);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static int fix_data(int nid, int *type)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
						if (nid == NID_pkcs9_emailAddress)
 | 
				
			||||||
 | 
							*type=V_ASN1_IA5STRING;
 | 
				
			||||||
 | 
						if ((nid == NID_commonName) && (*type == V_ASN1_IA5STRING))
 | 
				
			||||||
 | 
							*type=V_ASN1_T61STRING;
 | 
				
			||||||
 | 
						if ((nid == NID_pkcs9_challengePassword) && (*type == V_ASN1_IA5STRING))
 | 
				
			||||||
 | 
							*type=V_ASN1_T61STRING;
 | 
				
			||||||
 | 
						if ((nid == NID_pkcs9_unstructuredName) && (*type == V_ASN1_T61STRING))
 | 
				
			||||||
 | 
							return(0);
 | 
				
			||||||
 | 
						if (nid == NID_pkcs9_unstructuredName)
 | 
				
			||||||
 | 
							*type=V_ASN1_IA5STRING;
 | 
				
			||||||
 | 
						return(1);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static int check_time_format(const char *str)
 | 
					static int check_time_format(const char *str)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
	return ASN1_TIME_set_string(NULL, str);
 | 
						return ASN1_TIME_set_string(NULL, str);
 | 
				
			||||||
@@ -2640,9 +2632,9 @@ static int do_updatedb (CA_DB *db)
 | 
				
			|||||||
	else
 | 
						else
 | 
				
			||||||
		a_y2k = 0;
 | 
							a_y2k = 0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	for (i = 0; i < sk_OPENSSL_PSTRING_num(db->db->data); i++)
 | 
						for (i = 0; i < sk_PSTRING_num(db->db->data); i++)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		rrow = sk_OPENSSL_PSTRING_value(db->db->data, i);
 | 
							rrow = sk_PSTRING_value(db->db->data, i);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if (rrow[DB_type][0] == 'V')
 | 
							if (rrow[DB_type][0] == 'V')
 | 
				
			||||||
		 	{
 | 
							 	{
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -196,7 +196,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			
 | 
								
 | 
				
			||||||
			if (Verbose)
 | 
								if (Verbose)
 | 
				
			||||||
				{
 | 
									{
 | 
				
			||||||
				unsigned long id = SSL_CIPHER_get_id(c);
 | 
									unsigned long id = c->id;
 | 
				
			||||||
				int id0 = (int)(id >> 24);
 | 
									int id0 = (int)(id >> 24);
 | 
				
			||||||
				int id1 = (int)((id >> 16) & 0xffL);
 | 
									int id1 = (int)((id >> 16) & 0xffL);
 | 
				
			||||||
				int id2 = (int)((id >> 8) & 0xffL);
 | 
									int id2 = (int)((id >> 8) & 0xffL);
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										105
									
								
								apps/cms.c
									
									
									
									
									
								
							
							
						
						
									
										105
									
								
								apps/cms.c
									
									
									
									
									
								
							@@ -71,9 +71,9 @@
 | 
				
			|||||||
static int save_certs(char *signerfile, STACK_OF(X509) *signers);
 | 
					static int save_certs(char *signerfile, STACK_OF(X509) *signers);
 | 
				
			||||||
static int cms_cb(int ok, X509_STORE_CTX *ctx);
 | 
					static int cms_cb(int ok, X509_STORE_CTX *ctx);
 | 
				
			||||||
static void receipt_request_print(BIO *out, CMS_ContentInfo *cms);
 | 
					static void receipt_request_print(BIO *out, CMS_ContentInfo *cms);
 | 
				
			||||||
static CMS_ReceiptRequest *make_receipt_request(STACK_OF(OPENSSL_STRING) *rr_to,
 | 
					static CMS_ReceiptRequest *make_receipt_request(STACK_OF(STRING) *rr_to,
 | 
				
			||||||
						int rr_allorfirst,
 | 
											int rr_allorfirst,
 | 
				
			||||||
					STACK_OF(OPENSSL_STRING) *rr_from);
 | 
											STACK_OF(STRING) *rr_from);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define SMIME_OP	0x10
 | 
					#define SMIME_OP	0x10
 | 
				
			||||||
#define SMIME_IP	0x20
 | 
					#define SMIME_IP	0x20
 | 
				
			||||||
@@ -108,7 +108,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	const char *inmode = "r", *outmode = "w";
 | 
						const char *inmode = "r", *outmode = "w";
 | 
				
			||||||
	char *infile = NULL, *outfile = NULL, *rctfile = NULL;
 | 
						char *infile = NULL, *outfile = NULL, *rctfile = NULL;
 | 
				
			||||||
	char *signerfile = NULL, *recipfile = NULL;
 | 
						char *signerfile = NULL, *recipfile = NULL;
 | 
				
			||||||
	STACK_OF(OPENSSL_STRING) *sksigners = NULL, *skkeys = NULL;
 | 
						STACK_OF(STRING) *sksigners = NULL, *skkeys = NULL;
 | 
				
			||||||
	char *certfile = NULL, *keyfile = NULL, *contfile=NULL;
 | 
						char *certfile = NULL, *keyfile = NULL, *contfile=NULL;
 | 
				
			||||||
	char *certsoutfile = NULL;
 | 
						char *certsoutfile = NULL;
 | 
				
			||||||
	const EVP_CIPHER *cipher = NULL;
 | 
						const EVP_CIPHER *cipher = NULL;
 | 
				
			||||||
@@ -122,7 +122,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	int flags = CMS_DETACHED, noout = 0, print = 0;
 | 
						int flags = CMS_DETACHED, noout = 0, print = 0;
 | 
				
			||||||
	int verify_retcode = 0;
 | 
						int verify_retcode = 0;
 | 
				
			||||||
	int rr_print = 0, rr_allorfirst = -1;
 | 
						int rr_print = 0, rr_allorfirst = -1;
 | 
				
			||||||
	STACK_OF(OPENSSL_STRING) *rr_to = NULL, *rr_from = NULL;
 | 
						STACK_OF(STRING) *rr_to = NULL, *rr_from = NULL;
 | 
				
			||||||
	CMS_ReceiptRequest *rr = NULL;
 | 
						CMS_ReceiptRequest *rr = NULL;
 | 
				
			||||||
	char *to = NULL, *from = NULL, *subject = NULL;
 | 
						char *to = NULL, *from = NULL, *subject = NULL;
 | 
				
			||||||
	char *CAfile = NULL, *CApath = NULL;
 | 
						char *CAfile = NULL, *CApath = NULL;
 | 
				
			||||||
@@ -136,7 +136,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	char *engine=NULL;
 | 
						char *engine=NULL;
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
	unsigned char *secret_key = NULL, *secret_keyid = NULL;
 | 
						unsigned char *secret_key = NULL, *secret_keyid = NULL;
 | 
				
			||||||
	unsigned char *pwri_pass = NULL, *pwri_tmp = NULL;
 | 
					 | 
				
			||||||
	size_t secret_keylen = 0, secret_keyidlen = 0;
 | 
						size_t secret_keylen = 0, secret_keyidlen = 0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	ASN1_OBJECT *econtent_type = NULL;
 | 
						ASN1_OBJECT *econtent_type = NULL;
 | 
				
			||||||
@@ -282,8 +281,8 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
				goto argerr;
 | 
									goto argerr;
 | 
				
			||||||
			args++;
 | 
								args++;
 | 
				
			||||||
			if (!rr_from)
 | 
								if (!rr_from)
 | 
				
			||||||
				rr_from = sk_OPENSSL_STRING_new_null();
 | 
									rr_from = sk_STRING_new_null();
 | 
				
			||||||
			sk_OPENSSL_STRING_push(rr_from, *args);
 | 
								sk_STRING_push(rr_from, *args);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else if (!strcmp(*args,"-receipt_request_to"))
 | 
							else if (!strcmp(*args,"-receipt_request_to"))
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
@@ -291,8 +290,8 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
				goto argerr;
 | 
									goto argerr;
 | 
				
			||||||
			args++;
 | 
								args++;
 | 
				
			||||||
			if (!rr_to)
 | 
								if (!rr_to)
 | 
				
			||||||
				rr_to = sk_OPENSSL_STRING_new_null();
 | 
									rr_to = sk_STRING_new_null();
 | 
				
			||||||
			sk_OPENSSL_STRING_push(rr_to, *args);
 | 
								sk_STRING_push(rr_to, *args);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else if (!strcmp (*args, "-print"))
 | 
							else if (!strcmp (*args, "-print"))
 | 
				
			||||||
				{
 | 
									{
 | 
				
			||||||
@@ -327,13 +326,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
				}
 | 
									}
 | 
				
			||||||
			secret_keyidlen = (size_t)ltmp;
 | 
								secret_keyidlen = (size_t)ltmp;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else if (!strcmp(*args,"-pwri_password"))
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if (!args[1])
 | 
					 | 
				
			||||||
				goto argerr;
 | 
					 | 
				
			||||||
			args++;
 | 
					 | 
				
			||||||
			pwri_pass = (unsigned char *)*args;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		else if (!strcmp(*args,"-econtent_type"))
 | 
							else if (!strcmp(*args,"-econtent_type"))
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (!args[1])
 | 
								if (!args[1])
 | 
				
			||||||
@@ -395,13 +387,13 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			if (signerfile)
 | 
								if (signerfile)
 | 
				
			||||||
				{
 | 
									{
 | 
				
			||||||
				if (!sksigners)
 | 
									if (!sksigners)
 | 
				
			||||||
					sksigners = sk_OPENSSL_STRING_new_null();
 | 
										sksigners = sk_STRING_new_null();
 | 
				
			||||||
				sk_OPENSSL_STRING_push(sksigners, signerfile);
 | 
									sk_STRING_push(sksigners, signerfile);
 | 
				
			||||||
				if (!keyfile)
 | 
									if (!keyfile)
 | 
				
			||||||
					keyfile = signerfile;
 | 
										keyfile = signerfile;
 | 
				
			||||||
				if (!skkeys)
 | 
									if (!skkeys)
 | 
				
			||||||
					skkeys = sk_OPENSSL_STRING_new_null();
 | 
										skkeys = sk_STRING_new_null();
 | 
				
			||||||
				sk_OPENSSL_STRING_push(skkeys, keyfile);
 | 
									sk_STRING_push(skkeys, keyfile);
 | 
				
			||||||
				keyfile = NULL;
 | 
									keyfile = NULL;
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
			signerfile = *++args;
 | 
								signerfile = *++args;
 | 
				
			||||||
@@ -443,12 +435,12 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
					goto argerr;
 | 
										goto argerr;
 | 
				
			||||||
					}
 | 
										}
 | 
				
			||||||
				if (!sksigners)
 | 
									if (!sksigners)
 | 
				
			||||||
					sksigners = sk_OPENSSL_STRING_new_null();
 | 
										sksigners = sk_STRING_new_null();
 | 
				
			||||||
				sk_OPENSSL_STRING_push(sksigners, signerfile);
 | 
									sk_STRING_push(sksigners, signerfile);
 | 
				
			||||||
				signerfile = NULL;
 | 
									signerfile = NULL;
 | 
				
			||||||
				if (!skkeys)
 | 
									if (!skkeys)
 | 
				
			||||||
					skkeys = sk_OPENSSL_STRING_new_null();
 | 
										skkeys = sk_STRING_new_null();
 | 
				
			||||||
				sk_OPENSSL_STRING_push(skkeys, keyfile);
 | 
									sk_STRING_push(skkeys, keyfile);
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
			keyfile = *++args;
 | 
								keyfile = *++args;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
@@ -547,13 +539,13 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		if (signerfile)
 | 
							if (signerfile)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (!sksigners)
 | 
								if (!sksigners)
 | 
				
			||||||
				sksigners = sk_OPENSSL_STRING_new_null();
 | 
									sksigners = sk_STRING_new_null();
 | 
				
			||||||
			sk_OPENSSL_STRING_push(sksigners, signerfile);
 | 
								sk_STRING_push(sksigners, signerfile);
 | 
				
			||||||
			if (!skkeys)
 | 
								if (!skkeys)
 | 
				
			||||||
				skkeys = sk_OPENSSL_STRING_new_null();
 | 
									skkeys = sk_STRING_new_null();
 | 
				
			||||||
			if (!keyfile)
 | 
								if (!keyfile)
 | 
				
			||||||
				keyfile = signerfile;
 | 
									keyfile = signerfile;
 | 
				
			||||||
			sk_OPENSSL_STRING_push(skkeys, keyfile);
 | 
								sk_STRING_push(skkeys, keyfile);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		if (!sksigners)
 | 
							if (!sksigners)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
@@ -567,7 +559,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	else if (operation == SMIME_DECRYPT)
 | 
						else if (operation == SMIME_DECRYPT)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		if (!recipfile && !keyfile && !secret_key && !pwri_pass)
 | 
							if (!recipfile && !keyfile && !secret_key)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			BIO_printf(bio_err, "No recipient certificate or key specified\n");
 | 
								BIO_printf(bio_err, "No recipient certificate or key specified\n");
 | 
				
			||||||
			badarg = 1;
 | 
								badarg = 1;
 | 
				
			||||||
@@ -575,7 +567,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		}
 | 
							}
 | 
				
			||||||
	else if (operation == SMIME_ENCRYPT)
 | 
						else if (operation == SMIME_ENCRYPT)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		if (!*args && !secret_key && !pwri_pass)
 | 
							if (!*args && !secret_key)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			BIO_printf(bio_err, "No recipient(s) certificate(s) specified\n");
 | 
								BIO_printf(bio_err, "No recipient(s) certificate(s) specified\n");
 | 
				
			||||||
			badarg = 1;
 | 
								badarg = 1;
 | 
				
			||||||
@@ -626,7 +618,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		BIO_printf (bio_err, "-certsout file certificate output file\n");
 | 
							BIO_printf (bio_err, "-certsout file certificate output file\n");
 | 
				
			||||||
		BIO_printf (bio_err, "-signer file   signer certificate file\n");
 | 
							BIO_printf (bio_err, "-signer file   signer certificate file\n");
 | 
				
			||||||
		BIO_printf (bio_err, "-recip  file   recipient certificate file for decryption\n");
 | 
							BIO_printf (bio_err, "-recip  file   recipient certificate file for decryption\n");
 | 
				
			||||||
		BIO_printf (bio_err, "-keyid        use subject key identifier\n");
 | 
							BIO_printf (bio_err, "-skeyid        use subject key identifier\n");
 | 
				
			||||||
		BIO_printf (bio_err, "-in file       input file\n");
 | 
							BIO_printf (bio_err, "-in file       input file\n");
 | 
				
			||||||
		BIO_printf (bio_err, "-inform arg    input format SMIME (default), PEM or DER\n");
 | 
							BIO_printf (bio_err, "-inform arg    input format SMIME (default), PEM or DER\n");
 | 
				
			||||||
		BIO_printf (bio_err, "-inkey file    input private key (if not signer or recipient)\n");
 | 
							BIO_printf (bio_err, "-inkey file    input private key (if not signer or recipient)\n");
 | 
				
			||||||
@@ -712,7 +704,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
		if (secret_key && !secret_keyid)
 | 
							if (secret_key && !secret_keyid)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			BIO_printf(bio_err, "No secret key id\n");
 | 
								BIO_printf(bio_err, "No sectre key id\n");
 | 
				
			||||||
			goto end;
 | 
								goto end;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -888,7 +880,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		{
 | 
							{
 | 
				
			||||||
		if (!(store = setup_verify(bio_err, CAfile, CApath)))
 | 
							if (!(store = setup_verify(bio_err, CAfile, CApath)))
 | 
				
			||||||
			goto end;
 | 
								goto end;
 | 
				
			||||||
		X509_STORE_set_verify_cb(store, cms_cb);
 | 
							X509_STORE_set_verify_cb_func(store, cms_cb);
 | 
				
			||||||
		if (vpm)
 | 
							if (vpm)
 | 
				
			||||||
			X509_STORE_set1_param(store, vpm);
 | 
								X509_STORE_set1_param(store, vpm);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
@@ -925,17 +917,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			secret_key = NULL;
 | 
								secret_key = NULL;
 | 
				
			||||||
			secret_keyid = NULL;
 | 
								secret_keyid = NULL;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		if (pwri_pass)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			pwri_tmp = (unsigned char *)BUF_strdup((char *)pwri_pass);
 | 
					 | 
				
			||||||
			if (!pwri_tmp)
 | 
					 | 
				
			||||||
				goto end;
 | 
					 | 
				
			||||||
			if (!CMS_add0_recipient_password(cms,
 | 
					 | 
				
			||||||
						-1, NID_undef, NID_undef,
 | 
					 | 
				
			||||||
						 pwri_tmp, -1, NULL))
 | 
					 | 
				
			||||||
				goto end;
 | 
					 | 
				
			||||||
			pwri_tmp = NULL;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		if (!(flags & CMS_STREAM))
 | 
							if (!(flags & CMS_STREAM))
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (!CMS_final(cms, in, NULL, flags))
 | 
								if (!CMS_final(cms, in, NULL, flags))
 | 
				
			||||||
@@ -999,11 +980,11 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			}
 | 
								}
 | 
				
			||||||
		else
 | 
							else
 | 
				
			||||||
			flags |= CMS_REUSE_DIGEST;
 | 
								flags |= CMS_REUSE_DIGEST;
 | 
				
			||||||
		for (i = 0; i < sk_OPENSSL_STRING_num(sksigners); i++)
 | 
							for (i = 0; i < sk_STRING_num(sksigners); i++)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			CMS_SignerInfo *si;
 | 
								CMS_SignerInfo *si;
 | 
				
			||||||
			signerfile = sk_OPENSSL_STRING_value(sksigners, i);
 | 
								signerfile = sk_STRING_value(sksigners, i);
 | 
				
			||||||
			keyfile = sk_OPENSSL_STRING_value(skkeys, i);
 | 
								keyfile = sk_STRING_value(skkeys, i);
 | 
				
			||||||
			signer = load_cert(bio_err, signerfile,FORMAT_PEM, NULL,
 | 
								signer = load_cert(bio_err, signerfile,FORMAT_PEM, NULL,
 | 
				
			||||||
					e, "signer certificate");
 | 
										e, "signer certificate");
 | 
				
			||||||
			if (!signer)
 | 
								if (!signer)
 | 
				
			||||||
@@ -1062,16 +1043,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
				}
 | 
									}
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if (pwri_pass)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if (!CMS_decrypt_set1_password(cms, pwri_pass, -1))
 | 
					 | 
				
			||||||
				{
 | 
					 | 
				
			||||||
				BIO_puts(bio_err,
 | 
					 | 
				
			||||||
					"Error decrypting CMS using password\n");
 | 
					 | 
				
			||||||
				goto end;
 | 
					 | 
				
			||||||
				}
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		if (!CMS_decrypt(cms, NULL, NULL, indata, out, flags))
 | 
							if (!CMS_decrypt(cms, NULL, NULL, indata, out, flags))
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			BIO_printf(bio_err, "Error decrypting CMS structure\n");
 | 
								BIO_printf(bio_err, "Error decrypting CMS structure\n");
 | 
				
			||||||
@@ -1189,23 +1160,21 @@ end:
 | 
				
			|||||||
	if (vpm)
 | 
						if (vpm)
 | 
				
			||||||
		X509_VERIFY_PARAM_free(vpm);
 | 
							X509_VERIFY_PARAM_free(vpm);
 | 
				
			||||||
	if (sksigners)
 | 
						if (sksigners)
 | 
				
			||||||
		sk_OPENSSL_STRING_free(sksigners);
 | 
							sk_STRING_free(sksigners);
 | 
				
			||||||
	if (skkeys)
 | 
						if (skkeys)
 | 
				
			||||||
		sk_OPENSSL_STRING_free(skkeys);
 | 
							sk_STRING_free(skkeys);
 | 
				
			||||||
	if (secret_key)
 | 
						if (secret_key)
 | 
				
			||||||
		OPENSSL_free(secret_key);
 | 
							OPENSSL_free(secret_key);
 | 
				
			||||||
	if (secret_keyid)
 | 
						if (secret_keyid)
 | 
				
			||||||
		OPENSSL_free(secret_keyid);
 | 
							OPENSSL_free(secret_keyid);
 | 
				
			||||||
	if (pwri_tmp)
 | 
					 | 
				
			||||||
		OPENSSL_free(pwri_tmp);
 | 
					 | 
				
			||||||
	if (econtent_type)
 | 
						if (econtent_type)
 | 
				
			||||||
		ASN1_OBJECT_free(econtent_type);
 | 
							ASN1_OBJECT_free(econtent_type);
 | 
				
			||||||
	if (rr)
 | 
						if (rr)
 | 
				
			||||||
		CMS_ReceiptRequest_free(rr);
 | 
							CMS_ReceiptRequest_free(rr);
 | 
				
			||||||
	if (rr_to)
 | 
						if (rr_to)
 | 
				
			||||||
		sk_OPENSSL_STRING_free(rr_to);
 | 
							sk_STRING_free(rr_to);
 | 
				
			||||||
	if (rr_from)
 | 
						if (rr_from)
 | 
				
			||||||
		sk_OPENSSL_STRING_free(rr_from);
 | 
							sk_STRING_free(rr_from);
 | 
				
			||||||
	X509_STORE_free(store);
 | 
						X509_STORE_free(store);
 | 
				
			||||||
	X509_free(cert);
 | 
						X509_free(cert);
 | 
				
			||||||
	X509_free(recip);
 | 
						X509_free(recip);
 | 
				
			||||||
@@ -1327,7 +1296,7 @@ static void receipt_request_print(BIO *out, CMS_ContentInfo *cms)
 | 
				
			|||||||
		}
 | 
							}
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static STACK_OF(GENERAL_NAMES) *make_names_stack(STACK_OF(OPENSSL_STRING) *ns)
 | 
					static STACK_OF(GENERAL_NAMES) *make_names_stack(STACK_OF(STRING) *ns)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
	int i;
 | 
						int i;
 | 
				
			||||||
	STACK_OF(GENERAL_NAMES) *ret;
 | 
						STACK_OF(GENERAL_NAMES) *ret;
 | 
				
			||||||
@@ -1336,9 +1305,9 @@ static STACK_OF(GENERAL_NAMES) *make_names_stack(STACK_OF(OPENSSL_STRING) *ns)
 | 
				
			|||||||
	ret = sk_GENERAL_NAMES_new_null();
 | 
						ret = sk_GENERAL_NAMES_new_null();
 | 
				
			||||||
	if (!ret)
 | 
						if (!ret)
 | 
				
			||||||
		goto err;
 | 
							goto err;
 | 
				
			||||||
	for (i = 0; i < sk_OPENSSL_STRING_num(ns); i++)
 | 
						for (i = 0; i < sk_STRING_num(ns); i++)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		char *str = sk_OPENSSL_STRING_value(ns, i);
 | 
							char *str = sk_STRING_value(ns, i);
 | 
				
			||||||
		gen = a2i_GENERAL_NAME(NULL, NULL, NULL, GEN_EMAIL, str, 0);
 | 
							gen = a2i_GENERAL_NAME(NULL, NULL, NULL, GEN_EMAIL, str, 0);
 | 
				
			||||||
		if (!gen)
 | 
							if (!gen)
 | 
				
			||||||
			goto err;
 | 
								goto err;
 | 
				
			||||||
@@ -1366,9 +1335,9 @@ static STACK_OF(GENERAL_NAMES) *make_names_stack(STACK_OF(OPENSSL_STRING) *ns)
 | 
				
			|||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static CMS_ReceiptRequest *make_receipt_request(STACK_OF(OPENSSL_STRING) *rr_to,
 | 
					static CMS_ReceiptRequest *make_receipt_request(STACK_OF(STRING) *rr_to,
 | 
				
			||||||
						int rr_allorfirst,
 | 
											int rr_allorfirst,
 | 
				
			||||||
						STACK_OF(OPENSSL_STRING) *rr_from)
 | 
											STACK_OF(STRING) *rr_from)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
	STACK_OF(GENERAL_NAMES) *rct_to, *rct_from;
 | 
						STACK_OF(GENERAL_NAMES) *rct_to, *rct_from;
 | 
				
			||||||
	CMS_ReceiptRequest *rr;
 | 
						CMS_ReceiptRequest *rr;
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -92,7 +92,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	PKCS7 *p7 = NULL;
 | 
						PKCS7 *p7 = NULL;
 | 
				
			||||||
	PKCS7_SIGNED *p7s = NULL;
 | 
						PKCS7_SIGNED *p7s = NULL;
 | 
				
			||||||
	X509_CRL *crl=NULL;
 | 
						X509_CRL *crl=NULL;
 | 
				
			||||||
	STACK_OF(OPENSSL_STRING) *certflst=NULL;
 | 
						STACK_OF(STRING) *certflst=NULL;
 | 
				
			||||||
	STACK_OF(X509_CRL) *crl_stack=NULL;
 | 
						STACK_OF(X509_CRL) *crl_stack=NULL;
 | 
				
			||||||
	STACK_OF(X509) *cert_stack=NULL;
 | 
						STACK_OF(X509) *cert_stack=NULL;
 | 
				
			||||||
	int ret=1,nocrl=0;
 | 
						int ret=1,nocrl=0;
 | 
				
			||||||
@@ -140,8 +140,8 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		else if (strcmp(*argv,"-certfile") == 0)
 | 
							else if (strcmp(*argv,"-certfile") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
			if(!certflst) certflst = sk_OPENSSL_STRING_new_null();
 | 
								if(!certflst) certflst = sk_STRING_new_null();
 | 
				
			||||||
			sk_OPENSSL_STRING_push(certflst,*(++argv));
 | 
								sk_STRING_push(certflst,*(++argv));
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else
 | 
							else
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
@@ -226,8 +226,8 @@ bad:
 | 
				
			|||||||
	if ((cert_stack=sk_X509_new_null()) == NULL) goto end;
 | 
						if ((cert_stack=sk_X509_new_null()) == NULL) goto end;
 | 
				
			||||||
	p7s->cert=cert_stack;
 | 
						p7s->cert=cert_stack;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if(certflst) for(i = 0; i < sk_OPENSSL_STRING_num(certflst); i++) {
 | 
						if(certflst) for(i = 0; i < sk_STRING_num(certflst); i++) {
 | 
				
			||||||
		certfile = sk_OPENSSL_STRING_value(certflst, i);
 | 
							certfile = sk_STRING_value(certflst, i);
 | 
				
			||||||
		if (add_certs_from_file(cert_stack,certfile) < 0)
 | 
							if (add_certs_from_file(cert_stack,certfile) < 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			BIO_printf(bio_err, "error loading certificates\n");
 | 
								BIO_printf(bio_err, "error loading certificates\n");
 | 
				
			||||||
@@ -236,7 +236,7 @@ bad:
 | 
				
			|||||||
			}
 | 
								}
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	sk_OPENSSL_STRING_free(certflst);
 | 
						sk_STRING_free(certflst);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (outfile == NULL)
 | 
						if (outfile == NULL)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,6 +0,0 @@
 | 
				
			|||||||
# This is a file that will be filled by the openssl srp routine.
 | 
					 | 
				
			||||||
# You can initialize the file with additional groups, these are
 | 
					 | 
				
			||||||
# records starting with a I followed by the g and N values and the id.
 | 
					 | 
				
			||||||
# The exact values ... you have to dig this out from the source of srp.c
 | 
					 | 
				
			||||||
# or srp_vfy.c
 | 
					 | 
				
			||||||
# The last value of an I is used as the default group for new users.  
 | 
					 | 
				
			||||||
@@ -1 +0,0 @@
 | 
				
			|||||||
unique_subject = yes
 | 
					 | 
				
			||||||
							
								
								
									
										116
									
								
								apps/dgst.c
									
									
									
									
									
								
							
							
						
						
									
										116
									
								
								apps/dgst.c
									
									
									
									
									
								
							@@ -79,31 +79,11 @@ int do_fp(BIO *out, unsigned char *buf, BIO *bp, int sep, int binout,
 | 
				
			|||||||
	  const char *sig_name, const char *md_name,
 | 
						  const char *sig_name, const char *md_name,
 | 
				
			||||||
	  const char *file,BIO *bmd);
 | 
						  const char *file,BIO *bmd);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static void list_md_fn(const EVP_MD *m,
 | 
					 | 
				
			||||||
			const char *from, const char *to, void *arg)
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	const char *mname;
 | 
					 | 
				
			||||||
	/* Skip aliases */
 | 
					 | 
				
			||||||
	if (!m)
 | 
					 | 
				
			||||||
		return;
 | 
					 | 
				
			||||||
	mname = OBJ_nid2ln(EVP_MD_type(m));
 | 
					 | 
				
			||||||
	/* Skip shortnames */
 | 
					 | 
				
			||||||
	if (strcmp(from, mname))
 | 
					 | 
				
			||||||
		return;
 | 
					 | 
				
			||||||
	/* Skip clones */
 | 
					 | 
				
			||||||
	if (EVP_MD_flags(m) & EVP_MD_FLAG_PKEY_DIGEST)
 | 
					 | 
				
			||||||
		return;
 | 
					 | 
				
			||||||
	if (strchr(mname, ' '))
 | 
					 | 
				
			||||||
		mname= EVP_MD_name(m);
 | 
					 | 
				
			||||||
	BIO_printf(arg, "-%-14s to use the %s message digest algorithm\n",
 | 
					 | 
				
			||||||
			mname, mname);
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
int MAIN(int, char **);
 | 
					int MAIN(int, char **);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
int MAIN(int argc, char **argv)
 | 
					int MAIN(int argc, char **argv)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
	ENGINE *e = NULL, *impl = NULL;
 | 
						ENGINE *e = NULL;
 | 
				
			||||||
	unsigned char *buf=NULL;
 | 
						unsigned char *buf=NULL;
 | 
				
			||||||
	int i,err=1;
 | 
						int i,err=1;
 | 
				
			||||||
	const EVP_MD *md=NULL,*m;
 | 
						const EVP_MD *md=NULL,*m;
 | 
				
			||||||
@@ -124,11 +104,10 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	char *passargin = NULL, *passin = NULL;
 | 
						char *passargin = NULL, *passin = NULL;
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					#ifndef OPENSSL_NO_ENGINE
 | 
				
			||||||
	char *engine=NULL;
 | 
						char *engine=NULL;
 | 
				
			||||||
	int engine_impl = 0;
 | 
					 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
	char *hmac_key=NULL;
 | 
						char *hmac_key=NULL;
 | 
				
			||||||
	char *mac_name=NULL;
 | 
						char *mac_name=NULL;
 | 
				
			||||||
	STACK_OF(OPENSSL_STRING) *sigopts = NULL, *macopts = NULL;
 | 
						STACK_OF(STRING) *sigopts = NULL, *macopts = NULL;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	apps_startup();
 | 
						apps_startup();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -156,8 +135,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		if ((*argv)[0] != '-') break;
 | 
							if ((*argv)[0] != '-') break;
 | 
				
			||||||
		if (strcmp(*argv,"-c") == 0)
 | 
							if (strcmp(*argv,"-c") == 0)
 | 
				
			||||||
			separator=1;
 | 
								separator=1;
 | 
				
			||||||
		else if (strcmp(*argv,"-r") == 0)
 | 
					 | 
				
			||||||
			separator=2;
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-rand") == 0)
 | 
							else if (strcmp(*argv,"-rand") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (--argc < 1) break;
 | 
								if (--argc < 1) break;
 | 
				
			||||||
@@ -209,8 +186,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			engine= *(++argv);
 | 
								engine= *(++argv);
 | 
				
			||||||
        		e = setup_engine(bio_err, engine, 0);
 | 
					        		e = setup_engine(bio_err, engine, 0);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else if (strcmp(*argv,"-engine_impl") == 0)
 | 
					 | 
				
			||||||
			engine_impl = 1;
 | 
					 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
		else if (strcmp(*argv,"-hex") == 0)
 | 
							else if (strcmp(*argv,"-hex") == 0)
 | 
				
			||||||
			out_bin = 0;
 | 
								out_bin = 0;
 | 
				
			||||||
@@ -218,8 +193,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			out_bin = 1;
 | 
								out_bin = 1;
 | 
				
			||||||
		else if (strcmp(*argv,"-d") == 0)
 | 
							else if (strcmp(*argv,"-d") == 0)
 | 
				
			||||||
			debug=1;
 | 
								debug=1;
 | 
				
			||||||
		else if (!strcmp(*argv,"-fips-fingerprint"))
 | 
					 | 
				
			||||||
			hmac_key = "etaonrishdlcupfm";
 | 
					 | 
				
			||||||
		else if (!strcmp(*argv,"-hmac"))
 | 
							else if (!strcmp(*argv,"-hmac"))
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (--argc < 1)
 | 
								if (--argc < 1)
 | 
				
			||||||
@@ -237,8 +210,8 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			if (--argc < 1)
 | 
								if (--argc < 1)
 | 
				
			||||||
				break;
 | 
									break;
 | 
				
			||||||
			if (!sigopts)
 | 
								if (!sigopts)
 | 
				
			||||||
				sigopts = sk_OPENSSL_STRING_new_null();
 | 
									sigopts = sk_STRING_new_null();
 | 
				
			||||||
			if (!sigopts || !sk_OPENSSL_STRING_push(sigopts, *(++argv)))
 | 
								if (!sigopts || !sk_STRING_push(sigopts, *(++argv)))
 | 
				
			||||||
				break;
 | 
									break;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else if (strcmp(*argv,"-macopt") == 0)
 | 
							else if (strcmp(*argv,"-macopt") == 0)
 | 
				
			||||||
@@ -246,8 +219,8 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			if (--argc < 1)
 | 
								if (--argc < 1)
 | 
				
			||||||
				break;
 | 
									break;
 | 
				
			||||||
			if (!macopts)
 | 
								if (!macopts)
 | 
				
			||||||
				macopts = sk_OPENSSL_STRING_new_null();
 | 
									macopts = sk_STRING_new_null();
 | 
				
			||||||
			if (!macopts || !sk_OPENSSL_STRING_push(macopts, *(++argv)))
 | 
								if (!macopts || !sk_STRING_push(macopts, *(++argv)))
 | 
				
			||||||
				break;
 | 
									break;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else if ((m=EVP_get_digestbyname(&((*argv)[1]))) != NULL)
 | 
							else if ((m=EVP_get_digestbyname(&((*argv)[1]))) != NULL)
 | 
				
			||||||
@@ -269,7 +242,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		BIO_printf(bio_err,"unknown option '%s'\n",*argv);
 | 
							BIO_printf(bio_err,"unknown option '%s'\n",*argv);
 | 
				
			||||||
		BIO_printf(bio_err,"options are\n");
 | 
							BIO_printf(bio_err,"options are\n");
 | 
				
			||||||
		BIO_printf(bio_err,"-c              to output the digest with separating colons\n");
 | 
							BIO_printf(bio_err,"-c              to output the digest with separating colons\n");
 | 
				
			||||||
		BIO_printf(bio_err,"-r              to output the digest in coreutils format\n");
 | 
					 | 
				
			||||||
		BIO_printf(bio_err,"-d              to output debug info\n");
 | 
							BIO_printf(bio_err,"-d              to output debug info\n");
 | 
				
			||||||
		BIO_printf(bio_err,"-hex            output as hex dump\n");
 | 
							BIO_printf(bio_err,"-hex            output as hex dump\n");
 | 
				
			||||||
		BIO_printf(bio_err,"-binary         output in binary form\n");
 | 
							BIO_printf(bio_err,"-binary         output in binary form\n");
 | 
				
			||||||
@@ -277,25 +249,46 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		BIO_printf(bio_err,"-verify file    verify a signature using public key in file\n");
 | 
							BIO_printf(bio_err,"-verify file    verify a signature using public key in file\n");
 | 
				
			||||||
		BIO_printf(bio_err,"-prverify file  verify a signature using private key in file\n");
 | 
							BIO_printf(bio_err,"-prverify file  verify a signature using private key in file\n");
 | 
				
			||||||
		BIO_printf(bio_err,"-keyform arg    key file format (PEM or ENGINE)\n");
 | 
							BIO_printf(bio_err,"-keyform arg    key file format (PEM or ENGINE)\n");
 | 
				
			||||||
		BIO_printf(bio_err,"-out filename   output to filename rather than stdout\n");
 | 
					 | 
				
			||||||
		BIO_printf(bio_err,"-signature file signature to verify\n");
 | 
							BIO_printf(bio_err,"-signature file signature to verify\n");
 | 
				
			||||||
		BIO_printf(bio_err,"-sigopt nm:v    signature parameter\n");
 | 
							BIO_printf(bio_err,"-sigopt nm:v    signature parameter\n");
 | 
				
			||||||
		BIO_printf(bio_err,"-hmac key       create hashed MAC with key\n");
 | 
							BIO_printf(bio_err,"-hmac key       create hashed MAC with key\n");
 | 
				
			||||||
		BIO_printf(bio_err,"-mac algorithm  create MAC (not neccessarily HMAC)\n"); 
 | 
					 | 
				
			||||||
		BIO_printf(bio_err,"-macopt nm:v    MAC algorithm parameters or key\n");
 | 
					 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					#ifndef OPENSSL_NO_ENGINE
 | 
				
			||||||
		BIO_printf(bio_err,"-engine e       use engine e, possibly a hardware device.\n");
 | 
							BIO_printf(bio_err,"-engine e       use engine e, possibly a hardware device.\n");
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		EVP_MD_do_all_sorted(list_md_fn, bio_err);
 | 
							BIO_printf(bio_err,"-%-14s to use the %s message digest algorithm (default)\n",
 | 
				
			||||||
 | 
								LN_md5,LN_md5);
 | 
				
			||||||
 | 
							BIO_printf(bio_err,"-%-14s to use the %s message digest algorithm\n",
 | 
				
			||||||
 | 
								LN_md4,LN_md4);
 | 
				
			||||||
 | 
							BIO_printf(bio_err,"-%-14s to use the %s message digest algorithm\n",
 | 
				
			||||||
 | 
								LN_md2,LN_md2);
 | 
				
			||||||
 | 
					#ifndef OPENSSL_NO_SHA
 | 
				
			||||||
 | 
							BIO_printf(bio_err,"-%-14s to use the %s message digest algorithm\n",
 | 
				
			||||||
 | 
								LN_sha1,LN_sha1);
 | 
				
			||||||
 | 
					#ifndef OPENSSL_NO_SHA256
 | 
				
			||||||
 | 
							BIO_printf(bio_err,"-%-14s to use the %s message digest algorithm\n",
 | 
				
			||||||
 | 
								LN_sha224,LN_sha224);
 | 
				
			||||||
 | 
							BIO_printf(bio_err,"-%-14s to use the %s message digest algorithm\n",
 | 
				
			||||||
 | 
								LN_sha256,LN_sha256);
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#ifndef OPENSSL_NO_SHA512
 | 
				
			||||||
 | 
							BIO_printf(bio_err,"-%-14s to use the %s message digest algorithm\n",
 | 
				
			||||||
 | 
								LN_sha384,LN_sha384);
 | 
				
			||||||
 | 
							BIO_printf(bio_err,"-%-14s to use the %s message digest algorithm\n",
 | 
				
			||||||
 | 
								LN_sha512,LN_sha512);
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
							BIO_printf(bio_err,"-%-14s to use the %s message digest algorithm\n",
 | 
				
			||||||
 | 
								LN_mdc2,LN_mdc2);
 | 
				
			||||||
 | 
							BIO_printf(bio_err,"-%-14s to use the %s message digest algorithm\n",
 | 
				
			||||||
 | 
								LN_ripemd160,LN_ripemd160);
 | 
				
			||||||
 | 
					#ifndef OPENSSL_NO_WHIRLPOOL
 | 
				
			||||||
 | 
							BIO_printf(bio_err,"-%-14s to use the %s message digest algorithm\n",
 | 
				
			||||||
 | 
								SN_whirlpool,SN_whirlpool);
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
		goto end;
 | 
							goto end;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
	if (engine_impl)
 | 
					 | 
				
			||||||
		impl = e;
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	in=BIO_new(BIO_s_file());
 | 
						in=BIO_new(BIO_s_file());
 | 
				
			||||||
	bmd=BIO_new(BIO_f_md());
 | 
						bmd=BIO_new(BIO_f_md());
 | 
				
			||||||
	if (debug)
 | 
						if (debug)
 | 
				
			||||||
@@ -373,14 +366,14 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		{
 | 
							{
 | 
				
			||||||
		EVP_PKEY_CTX *mac_ctx = NULL;
 | 
							EVP_PKEY_CTX *mac_ctx = NULL;
 | 
				
			||||||
		int r = 0;
 | 
							int r = 0;
 | 
				
			||||||
		if (!init_gen_str(bio_err, &mac_ctx, mac_name, impl, 0))
 | 
							if (!init_gen_str(bio_err, &mac_ctx, mac_name,e, 0))
 | 
				
			||||||
			goto mac_end;
 | 
								goto mac_end;
 | 
				
			||||||
		if (macopts)
 | 
							if (macopts)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			char *macopt;
 | 
								char *macopt;
 | 
				
			||||||
			for (i = 0; i < sk_OPENSSL_STRING_num(macopts); i++)
 | 
								for (i = 0; i < sk_STRING_num(macopts); i++)
 | 
				
			||||||
				{
 | 
									{
 | 
				
			||||||
				macopt = sk_OPENSSL_STRING_value(macopts, i);
 | 
									macopt = sk_STRING_value(macopts, i);
 | 
				
			||||||
				if (pkey_ctrl_string(mac_ctx, macopt) <= 0)
 | 
									if (pkey_ctrl_string(mac_ctx, macopt) <= 0)
 | 
				
			||||||
					{
 | 
										{
 | 
				
			||||||
					BIO_printf(bio_err,
 | 
										BIO_printf(bio_err,
 | 
				
			||||||
@@ -407,7 +400,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	if (hmac_key)
 | 
						if (hmac_key)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		sigkey = EVP_PKEY_new_mac_key(EVP_PKEY_HMAC, impl,
 | 
							sigkey = EVP_PKEY_new_mac_key(EVP_PKEY_HMAC, e,
 | 
				
			||||||
					(unsigned char *)hmac_key, -1);
 | 
										(unsigned char *)hmac_key, -1);
 | 
				
			||||||
		if (!sigkey)
 | 
							if (!sigkey)
 | 
				
			||||||
			goto end;
 | 
								goto end;
 | 
				
			||||||
@@ -425,9 +418,9 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			goto end;
 | 
								goto end;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		if (do_verify)
 | 
							if (do_verify)
 | 
				
			||||||
			r = EVP_DigestVerifyInit(mctx, &pctx, md, impl, sigkey);
 | 
								r = EVP_DigestVerifyInit(mctx, &pctx, md, e, sigkey);
 | 
				
			||||||
		else
 | 
							else
 | 
				
			||||||
			r = EVP_DigestSignInit(mctx, &pctx, md, impl, sigkey);
 | 
								r = EVP_DigestSignInit(mctx, &pctx, md, e, sigkey);
 | 
				
			||||||
		if (!r)
 | 
							if (!r)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			BIO_printf(bio_err, "Error setting context\n");
 | 
								BIO_printf(bio_err, "Error setting context\n");
 | 
				
			||||||
@@ -437,9 +430,9 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		if (sigopts)
 | 
							if (sigopts)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			char *sigopt;
 | 
								char *sigopt;
 | 
				
			||||||
			for (i = 0; i < sk_OPENSSL_STRING_num(sigopts); i++)
 | 
								for (i = 0; i < sk_STRING_num(sigopts); i++)
 | 
				
			||||||
				{
 | 
									{
 | 
				
			||||||
				sigopt = sk_OPENSSL_STRING_value(sigopts, i);
 | 
									sigopt = sk_STRING_value(sigopts, i);
 | 
				
			||||||
				if (pkey_ctrl_string(pctx, sigopt) <= 0)
 | 
									if (pkey_ctrl_string(pctx, sigopt) <= 0)
 | 
				
			||||||
					{
 | 
										{
 | 
				
			||||||
					BIO_printf(bio_err,
 | 
										BIO_printf(bio_err,
 | 
				
			||||||
@@ -454,16 +447,9 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	/* we use md as a filter, reading from 'in' */
 | 
						/* we use md as a filter, reading from 'in' */
 | 
				
			||||||
	else
 | 
						else
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		EVP_MD_CTX *mctx = NULL;
 | 
					 | 
				
			||||||
		if (!BIO_get_md_ctx(bmd, &mctx))
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			BIO_printf(bio_err, "Error getting context\n");
 | 
					 | 
				
			||||||
			ERR_print_errors(bio_err);
 | 
					 | 
				
			||||||
			goto end;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		if (md == NULL)
 | 
							if (md == NULL)
 | 
				
			||||||
			md = EVP_md5(); 
 | 
								md = EVP_md5(); 
 | 
				
			||||||
		if (!EVP_DigestInit_ex(mctx, md, impl))
 | 
							if (!BIO_set_md(bmd,md))
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			BIO_printf(bio_err, "Error setting digest %s\n", pname);
 | 
								BIO_printf(bio_err, "Error setting digest %s\n", pname);
 | 
				
			||||||
			ERR_print_errors(bio_err);
 | 
								ERR_print_errors(bio_err);
 | 
				
			||||||
@@ -551,9 +537,9 @@ end:
 | 
				
			|||||||
	BIO_free_all(out);
 | 
						BIO_free_all(out);
 | 
				
			||||||
	EVP_PKEY_free(sigkey);
 | 
						EVP_PKEY_free(sigkey);
 | 
				
			||||||
	if (sigopts)
 | 
						if (sigopts)
 | 
				
			||||||
		sk_OPENSSL_STRING_free(sigopts);
 | 
							sk_STRING_free(sigopts);
 | 
				
			||||||
	if (macopts)
 | 
						if (macopts)
 | 
				
			||||||
		sk_OPENSSL_STRING_free(macopts);
 | 
							sk_STRING_free(macopts);
 | 
				
			||||||
	if(sigbuf) OPENSSL_free(sigbuf);
 | 
						if(sigbuf) OPENSSL_free(sigbuf);
 | 
				
			||||||
	if (bmd != NULL) BIO_free(bmd);
 | 
						if (bmd != NULL) BIO_free(bmd);
 | 
				
			||||||
	apps_shutdown();
 | 
						apps_shutdown();
 | 
				
			||||||
@@ -614,7 +600,7 @@ int do_fp(BIO *out, unsigned char *buf, BIO *bp, int sep, int binout,
 | 
				
			|||||||
	else
 | 
						else
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		len=BIO_gets(bp,(char *)buf,BUFSIZE);
 | 
							len=BIO_gets(bp,(char *)buf,BUFSIZE);
 | 
				
			||||||
		if ((int)len <0)
 | 
							if (len <0) 
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			ERR_print_errors(bio_err);
 | 
								ERR_print_errors(bio_err);
 | 
				
			||||||
			return 1;
 | 
								return 1;
 | 
				
			||||||
@@ -622,12 +608,6 @@ int do_fp(BIO *out, unsigned char *buf, BIO *bp, int sep, int binout,
 | 
				
			|||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if(binout) BIO_write(out, buf, len);
 | 
						if(binout) BIO_write(out, buf, len);
 | 
				
			||||||
	else if (sep == 2)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		for (i=0; i<(int)len; i++)
 | 
					 | 
				
			||||||
			BIO_printf(out, "%02x",buf[i]);
 | 
					 | 
				
			||||||
		BIO_printf(out, " *%s\n", file);
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	else 
 | 
						else 
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		if (sig_name)
 | 
							if (sig_name)
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										11
									
								
								apps/dh.c
									
									
									
									
									
								
							
							
						
						
									
										11
									
								
								apps/dh.c
									
									
									
									
									
								
							@@ -88,6 +88,9 @@ int MAIN(int, char **);
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
int MAIN(int argc, char **argv)
 | 
					int MAIN(int argc, char **argv)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
 | 
					#ifndef OPENSSL_NO_ENGINE
 | 
				
			||||||
 | 
						ENGINE *e = NULL;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
	DH *dh=NULL;
 | 
						DH *dh=NULL;
 | 
				
			||||||
	int i,badops=0,text=0;
 | 
						int i,badops=0,text=0;
 | 
				
			||||||
	BIO *in=NULL,*out=NULL;
 | 
						BIO *in=NULL,*out=NULL;
 | 
				
			||||||
@@ -186,7 +189,7 @@ bad:
 | 
				
			|||||||
	ERR_load_crypto_strings();
 | 
						ERR_load_crypto_strings();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					#ifndef OPENSSL_NO_ENGINE
 | 
				
			||||||
        setup_engine(bio_err, engine, 0);
 | 
					        e = setup_engine(bio_err, engine, 0);
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	in=BIO_new(BIO_s_file());
 | 
						in=BIO_new(BIO_s_file());
 | 
				
			||||||
@@ -346,10 +349,4 @@ end:
 | 
				
			|||||||
	apps_shutdown();
 | 
						apps_shutdown();
 | 
				
			||||||
	OPENSSL_EXIT(ret);
 | 
						OPENSSL_EXIT(ret);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
#else /* !OPENSSL_NO_DH */
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# if PEDANTIC
 | 
					 | 
				
			||||||
static void *dummy=&dummy;
 | 
					 | 
				
			||||||
# endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -149,6 +149,9 @@ int MAIN(int, char **);
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
int MAIN(int argc, char **argv)
 | 
					int MAIN(int argc, char **argv)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
 | 
					#ifndef OPENSSL_NO_ENGINE
 | 
				
			||||||
 | 
						ENGINE *e = NULL;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
	DH *dh=NULL;
 | 
						DH *dh=NULL;
 | 
				
			||||||
	int i,badops=0,text=0;
 | 
						int i,badops=0,text=0;
 | 
				
			||||||
#ifndef OPENSSL_NO_DSA
 | 
					#ifndef OPENSSL_NO_DSA
 | 
				
			||||||
@@ -267,7 +270,7 @@ bad:
 | 
				
			|||||||
	ERR_load_crypto_strings();
 | 
						ERR_load_crypto_strings();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					#ifndef OPENSSL_NO_ENGINE
 | 
				
			||||||
        setup_engine(bio_err, engine, 0);
 | 
					        e = setup_engine(bio_err, engine, 0);
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (g && !num)
 | 
						if (g && !num)
 | 
				
			||||||
@@ -551,10 +554,4 @@ static int MS_CALLBACK dh_cb(int p, int n, BN_GENCB *cb)
 | 
				
			|||||||
	return 1;
 | 
						return 1;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#else /* !OPENSSL_NO_DH */
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# if PEDANTIC
 | 
					 | 
				
			||||||
static void *dummy=&dummy;
 | 
					 | 
				
			||||||
# endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										10
									
								
								apps/dsa.c
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								apps/dsa.c
									
									
									
									
									
								
							@@ -334,7 +334,6 @@ bad:
 | 
				
			|||||||
			i=PEM_write_bio_DSA_PUBKEY(out,dsa);
 | 
								i=PEM_write_bio_DSA_PUBKEY(out,dsa);
 | 
				
			||||||
		else i=PEM_write_bio_DSAPrivateKey(out,dsa,enc,
 | 
							else i=PEM_write_bio_DSAPrivateKey(out,dsa,enc,
 | 
				
			||||||
							NULL,0,NULL, passout);
 | 
												NULL,0,NULL, passout);
 | 
				
			||||||
#if !defined(OPENSSL_NO_RSA) && !defined(OPENSSL_NO_RC4)
 | 
					 | 
				
			||||||
	} else if (outformat == FORMAT_MSBLOB || outformat == FORMAT_PVK) {
 | 
						} else if (outformat == FORMAT_MSBLOB || outformat == FORMAT_PVK) {
 | 
				
			||||||
		EVP_PKEY *pk;
 | 
							EVP_PKEY *pk;
 | 
				
			||||||
		pk = EVP_PKEY_new();
 | 
							pk = EVP_PKEY_new();
 | 
				
			||||||
@@ -346,12 +345,11 @@ bad:
 | 
				
			|||||||
		else
 | 
							else
 | 
				
			||||||
			i = i2b_PrivateKey_bio(out, pk);
 | 
								i = i2b_PrivateKey_bio(out, pk);
 | 
				
			||||||
		EVP_PKEY_free(pk);
 | 
							EVP_PKEY_free(pk);
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	} else {
 | 
						} else {
 | 
				
			||||||
		BIO_printf(bio_err,"bad output format specified for outfile\n");
 | 
							BIO_printf(bio_err,"bad output format specified for outfile\n");
 | 
				
			||||||
		goto end;
 | 
							goto end;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	if (i <= 0)
 | 
						if (!i)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		BIO_printf(bio_err,"unable to write private key\n");
 | 
							BIO_printf(bio_err,"unable to write private key\n");
 | 
				
			||||||
		ERR_print_errors(bio_err);
 | 
							ERR_print_errors(bio_err);
 | 
				
			||||||
@@ -367,10 +365,4 @@ end:
 | 
				
			|||||||
	apps_shutdown();
 | 
						apps_shutdown();
 | 
				
			||||||
	OPENSSL_EXIT(ret);
 | 
						OPENSSL_EXIT(ret);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
#else /* !OPENSSL_NO_DSA */
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# if PEDANTIC
 | 
					 | 
				
			||||||
static void *dummy=&dummy;
 | 
					 | 
				
			||||||
# endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -111,6 +111,9 @@ int MAIN(int, char **);
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
int MAIN(int argc, char **argv)
 | 
					int MAIN(int argc, char **argv)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
 | 
					#ifndef OPENSSL_NO_ENGINE
 | 
				
			||||||
 | 
						ENGINE *e = NULL;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
	DSA *dsa=NULL;
 | 
						DSA *dsa=NULL;
 | 
				
			||||||
	int i,badops=0,text=0;
 | 
						int i,badops=0,text=0;
 | 
				
			||||||
	BIO *in=NULL,*out=NULL;
 | 
						BIO *in=NULL,*out=NULL;
 | 
				
			||||||
@@ -118,7 +121,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	char *infile,*outfile,*prog,*inrand=NULL;
 | 
						char *infile,*outfile,*prog,*inrand=NULL;
 | 
				
			||||||
	int numbits= -1,num,genkey=0;
 | 
						int numbits= -1,num,genkey=0;
 | 
				
			||||||
	int need_rand=0;
 | 
						int need_rand=0;
 | 
				
			||||||
	int non_fips_allow = 0;
 | 
					 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					#ifndef OPENSSL_NO_ENGINE
 | 
				
			||||||
	char *engine=NULL;
 | 
						char *engine=NULL;
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
@@ -196,8 +198,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			}
 | 
								}
 | 
				
			||||||
		else if (strcmp(*argv,"-noout") == 0)
 | 
							else if (strcmp(*argv,"-noout") == 0)
 | 
				
			||||||
			noout=1;
 | 
								noout=1;
 | 
				
			||||||
		else if (strcmp(*argv,"-non-fips-allow") == 0)
 | 
					 | 
				
			||||||
			non_fips_allow = 1;
 | 
					 | 
				
			||||||
		else if (sscanf(*argv,"%d",&num) == 1)
 | 
							else if (sscanf(*argv,"%d",&num) == 1)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			/* generate a key */
 | 
								/* generate a key */
 | 
				
			||||||
@@ -278,7 +278,7 @@ bad:
 | 
				
			|||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					#ifndef OPENSSL_NO_ENGINE
 | 
				
			||||||
        setup_engine(bio_err, engine, 0);
 | 
					        e = setup_engine(bio_err, engine, 0);
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (need_rand)
 | 
						if (need_rand)
 | 
				
			||||||
@@ -300,8 +300,6 @@ bad:
 | 
				
			|||||||
			BIO_printf(bio_err,"Error allocating DSA object\n");
 | 
								BIO_printf(bio_err,"Error allocating DSA object\n");
 | 
				
			||||||
			goto end;
 | 
								goto end;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		if (non_fips_allow)
 | 
					 | 
				
			||||||
			dsa->flags |= DSA_FLAG_NON_FIPS_ALLOW;
 | 
					 | 
				
			||||||
		BIO_printf(bio_err,"Generating DSA parameters, %d bit long prime\n",num);
 | 
							BIO_printf(bio_err,"Generating DSA parameters, %d bit long prime\n",num);
 | 
				
			||||||
	        BIO_printf(bio_err,"This could take some time\n");
 | 
						        BIO_printf(bio_err,"This could take some time\n");
 | 
				
			||||||
#ifdef GENCB_TEST
 | 
					#ifdef GENCB_TEST
 | 
				
			||||||
@@ -331,7 +329,6 @@ bad:
 | 
				
			|||||||
				goto end;
 | 
									goto end;
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
			ERR_print_errors(bio_err);
 | 
					 | 
				
			||||||
			BIO_printf(bio_err,"Error, DSA key generation failed\n");
 | 
								BIO_printf(bio_err,"Error, DSA key generation failed\n");
 | 
				
			||||||
			goto end;
 | 
								goto end;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
@@ -360,10 +357,12 @@ bad:
 | 
				
			|||||||
	if (C)
 | 
						if (C)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		unsigned char *data;
 | 
							unsigned char *data;
 | 
				
			||||||
		int l,len,bits_p;
 | 
							int l,len,bits_p,bits_q,bits_g;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		len=BN_num_bytes(dsa->p);
 | 
							len=BN_num_bytes(dsa->p);
 | 
				
			||||||
		bits_p=BN_num_bits(dsa->p);
 | 
							bits_p=BN_num_bits(dsa->p);
 | 
				
			||||||
 | 
							bits_q=BN_num_bits(dsa->q);
 | 
				
			||||||
 | 
							bits_g=BN_num_bits(dsa->g);
 | 
				
			||||||
		data=(unsigned char *)OPENSSL_malloc(len+20);
 | 
							data=(unsigned char *)OPENSSL_malloc(len+20);
 | 
				
			||||||
		if (data == NULL)
 | 
							if (data == NULL)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
@@ -435,21 +434,13 @@ bad:
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
		assert(need_rand);
 | 
							assert(need_rand);
 | 
				
			||||||
		if ((dsakey=DSAparams_dup(dsa)) == NULL) goto end;
 | 
							if ((dsakey=DSAparams_dup(dsa)) == NULL) goto end;
 | 
				
			||||||
		if (non_fips_allow)
 | 
							if (!DSA_generate_key(dsakey)) goto end;
 | 
				
			||||||
			dsakey->flags |= DSA_FLAG_NON_FIPS_ALLOW;
 | 
					 | 
				
			||||||
		if (!DSA_generate_key(dsakey))
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			ERR_print_errors(bio_err);
 | 
					 | 
				
			||||||
			DSA_free(dsakey);
 | 
					 | 
				
			||||||
			goto end;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		if 	(outformat == FORMAT_ASN1)
 | 
							if 	(outformat == FORMAT_ASN1)
 | 
				
			||||||
			i=i2d_DSAPrivateKey_bio(out,dsakey);
 | 
								i=i2d_DSAPrivateKey_bio(out,dsakey);
 | 
				
			||||||
		else if (outformat == FORMAT_PEM)
 | 
							else if (outformat == FORMAT_PEM)
 | 
				
			||||||
			i=PEM_write_bio_DSAPrivateKey(out,dsakey,NULL,NULL,0,NULL,NULL);
 | 
								i=PEM_write_bio_DSAPrivateKey(out,dsakey,NULL,NULL,0,NULL,NULL);
 | 
				
			||||||
		else	{
 | 
							else	{
 | 
				
			||||||
			BIO_printf(bio_err,"bad output format specified for outfile\n");
 | 
								BIO_printf(bio_err,"bad output format specified for outfile\n");
 | 
				
			||||||
			DSA_free(dsakey);
 | 
					 | 
				
			||||||
			goto end;
 | 
								goto end;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		DSA_free(dsakey);
 | 
							DSA_free(dsakey);
 | 
				
			||||||
@@ -484,10 +475,4 @@ static int MS_CALLBACK dsa_cb(int p, int n, BN_GENCB *cb)
 | 
				
			|||||||
#endif
 | 
					#endif
 | 
				
			||||||
	return 1;
 | 
						return 1;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
#else /* !OPENSSL_NO_DSA */
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# if PEDANTIC
 | 
					 | 
				
			||||||
static void *dummy=&dummy;
 | 
					 | 
				
			||||||
# endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										11
									
								
								apps/ec.c
									
									
									
									
									
								
							
							
						
						
									
										11
									
								
								apps/ec.c
									
									
									
									
									
								
							@@ -85,6 +85,9 @@ int MAIN(int, char **);
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
int MAIN(int argc, char **argv)
 | 
					int MAIN(int argc, char **argv)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
 | 
					#ifndef OPENSSL_NO_ENGINE
 | 
				
			||||||
 | 
						ENGINE 	*e = NULL;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
	int 	ret = 1;
 | 
						int 	ret = 1;
 | 
				
			||||||
	EC_KEY 	*eckey = NULL;
 | 
						EC_KEY 	*eckey = NULL;
 | 
				
			||||||
	const EC_GROUP *group;
 | 
						const EC_GROUP *group;
 | 
				
			||||||
@@ -251,7 +254,7 @@ bad:
 | 
				
			|||||||
	ERR_load_crypto_strings();
 | 
						ERR_load_crypto_strings();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					#ifndef OPENSSL_NO_ENGINE
 | 
				
			||||||
        setup_engine(bio_err, engine, 0);
 | 
					        e = setup_engine(bio_err, engine, 0);
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if(!app_passwd(bio_err, passargin, passargout, &passin, &passout)) 
 | 
						if(!app_passwd(bio_err, passargin, passargout, &passin, &passout)) 
 | 
				
			||||||
@@ -397,10 +400,4 @@ end:
 | 
				
			|||||||
	apps_shutdown();
 | 
						apps_shutdown();
 | 
				
			||||||
	OPENSSL_EXIT(ret);
 | 
						OPENSSL_EXIT(ret);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
#else /* !OPENSSL_NO_EC */
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# if PEDANTIC
 | 
					 | 
				
			||||||
static void *dummy=&dummy;
 | 
					 | 
				
			||||||
# endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -129,6 +129,9 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	char	*infile = NULL, *outfile = NULL, *prog;
 | 
						char	*infile = NULL, *outfile = NULL, *prog;
 | 
				
			||||||
	BIO 	*in = NULL, *out = NULL;
 | 
						BIO 	*in = NULL, *out = NULL;
 | 
				
			||||||
	int 	informat, outformat, noout = 0, C = 0, ret = 1;
 | 
						int 	informat, outformat, noout = 0, C = 0, ret = 1;
 | 
				
			||||||
 | 
					#ifndef OPENSSL_NO_ENGINE
 | 
				
			||||||
 | 
						ENGINE	*e = NULL;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
	char	*engine = NULL;
 | 
						char	*engine = NULL;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	BIGNUM	*ec_p = NULL, *ec_a = NULL, *ec_b = NULL,
 | 
						BIGNUM	*ec_p = NULL, *ec_a = NULL, *ec_b = NULL,
 | 
				
			||||||
@@ -337,7 +340,7 @@ bad:
 | 
				
			|||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					#ifndef OPENSSL_NO_ENGINE
 | 
				
			||||||
	setup_engine(bio_err, engine, 0);
 | 
						e = setup_engine(bio_err, engine, 0);
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (list_curves)
 | 
						if (list_curves)
 | 
				
			||||||
@@ -722,10 +725,4 @@ static int ecparam_print_var(BIO *out, BIGNUM *in, const char *var,
 | 
				
			|||||||
	BIO_printf(out, "\n\t};\n\n");
 | 
						BIO_printf(out, "\n\t};\n\n");
 | 
				
			||||||
	return 1;
 | 
						return 1;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
#else /* !OPENSSL_NO_EC */
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# if PEDANTIC
 | 
					 | 
				
			||||||
static void *dummy=&dummy;
 | 
					 | 
				
			||||||
# endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										16
									
								
								apps/enc.c
									
									
									
									
									
								
							
							
						
						
									
										16
									
								
								apps/enc.c
									
									
									
									
									
								
							@@ -101,6 +101,9 @@ int MAIN(int, char **);
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
int MAIN(int argc, char **argv)
 | 
					int MAIN(int argc, char **argv)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
 | 
					#ifndef OPENSSL_NO_ENGINE
 | 
				
			||||||
 | 
						ENGINE *e = NULL;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
	static const char magic[]="Salted__";
 | 
						static const char magic[]="Salted__";
 | 
				
			||||||
	char mbuf[sizeof magic-1];
 | 
						char mbuf[sizeof magic-1];
 | 
				
			||||||
	char *strbuf=NULL;
 | 
						char *strbuf=NULL;
 | 
				
			||||||
@@ -240,12 +243,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
				goto bad;
 | 
									goto bad;
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
			buf[0]='\0';
 | 
								buf[0]='\0';
 | 
				
			||||||
			if (!fgets(buf,sizeof buf,infile))
 | 
								fgets(buf,sizeof buf,infile);
 | 
				
			||||||
				{
 | 
					 | 
				
			||||||
				BIO_printf(bio_err,"unable to read key from '%s'\n",
 | 
					 | 
				
			||||||
					file);
 | 
					 | 
				
			||||||
				goto bad;
 | 
					 | 
				
			||||||
				}
 | 
					 | 
				
			||||||
			fclose(infile);
 | 
								fclose(infile);
 | 
				
			||||||
			i=strlen(buf);
 | 
								i=strlen(buf);
 | 
				
			||||||
			if ((i > 0) &&
 | 
								if ((i > 0) &&
 | 
				
			||||||
@@ -325,7 +323,7 @@ bad:
 | 
				
			|||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					#ifndef OPENSSL_NO_ENGINE
 | 
				
			||||||
        setup_engine(bio_err, engine, 0);
 | 
					        e = setup_engine(bio_err, engine, 0);
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (md && (dgst=EVP_get_digestbyname(md)) == NULL)
 | 
						if (md && (dgst=EVP_get_digestbyname(md)) == NULL)
 | 
				
			||||||
@@ -393,10 +391,8 @@ bad:
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	if (inf == NULL)
 | 
						if (inf == NULL)
 | 
				
			||||||
	        {
 | 
						        {
 | 
				
			||||||
#ifndef OPENSSL_NO_SETVBUF_IONBF
 | 
					 | 
				
			||||||
		if (bufsize != NULL)
 | 
							if (bufsize != NULL)
 | 
				
			||||||
			setvbuf(stdin, (char *)NULL, _IONBF, 0);
 | 
								setvbuf(stdin, (char *)NULL, _IONBF, 0);
 | 
				
			||||||
#endif /* ndef OPENSSL_NO_SETVBUF_IONBF */
 | 
					 | 
				
			||||||
		BIO_set_fp(in,stdin,BIO_NOCLOSE);
 | 
							BIO_set_fp(in,stdin,BIO_NOCLOSE);
 | 
				
			||||||
	        }
 | 
						        }
 | 
				
			||||||
	else
 | 
						else
 | 
				
			||||||
@@ -449,10 +445,8 @@ bad:
 | 
				
			|||||||
	if (outf == NULL)
 | 
						if (outf == NULL)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		BIO_set_fp(out,stdout,BIO_NOCLOSE);
 | 
							BIO_set_fp(out,stdout,BIO_NOCLOSE);
 | 
				
			||||||
#ifndef OPENSSL_NO_SETVBUF_IONBF
 | 
					 | 
				
			||||||
		if (bufsize != NULL)
 | 
							if (bufsize != NULL)
 | 
				
			||||||
			setvbuf(stdout, (char *)NULL, _IONBF, 0);
 | 
								setvbuf(stdout, (char *)NULL, _IONBF, 0);
 | 
				
			||||||
#endif /* ndef OPENSSL_NO_SETVBUF_IONBF */
 | 
					 | 
				
			||||||
#ifdef OPENSSL_SYS_VMS
 | 
					#ifdef OPENSSL_SYS_VMS
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		BIO *tmpbio = BIO_new(BIO_f_linebuffer());
 | 
							BIO *tmpbio = BIO_new(BIO_f_linebuffer());
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -200,7 +200,7 @@ static int util_verbose(ENGINE *e, int verbose, BIO *bio_out, const char *indent
 | 
				
			|||||||
	char *desc = NULL;
 | 
						char *desc = NULL;
 | 
				
			||||||
	int flags;
 | 
						int flags;
 | 
				
			||||||
	int xpos = 0;
 | 
						int xpos = 0;
 | 
				
			||||||
	STACK_OF(OPENSSL_STRING) *cmds = NULL;
 | 
						STACK_OF(STRING) *cmds = NULL;
 | 
				
			||||||
	if(!ENGINE_ctrl(e, ENGINE_CTRL_HAS_CTRL_FUNCTION, 0, NULL, NULL) ||
 | 
						if(!ENGINE_ctrl(e, ENGINE_CTRL_HAS_CTRL_FUNCTION, 0, NULL, NULL) ||
 | 
				
			||||||
			((num = ENGINE_ctrl(e, ENGINE_CTRL_GET_FIRST_CMD_TYPE,
 | 
								((num = ENGINE_ctrl(e, ENGINE_CTRL_GET_FIRST_CMD_TYPE,
 | 
				
			||||||
					0, NULL, NULL)) <= 0))
 | 
										0, NULL, NULL)) <= 0))
 | 
				
			||||||
@@ -211,7 +211,7 @@ static int util_verbose(ENGINE *e, int verbose, BIO *bio_out, const char *indent
 | 
				
			|||||||
		return 1;
 | 
							return 1;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	cmds = sk_OPENSSL_STRING_new_null();
 | 
						cmds = sk_STRING_new_null();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if(!cmds)
 | 
						if(!cmds)
 | 
				
			||||||
		goto err;
 | 
							goto err;
 | 
				
			||||||
@@ -284,16 +284,16 @@ static int util_verbose(ENGINE *e, int verbose, BIO *bio_out, const char *indent
 | 
				
			|||||||
		BIO_printf(bio_out, "\n");
 | 
							BIO_printf(bio_out, "\n");
 | 
				
			||||||
	ret = 1;
 | 
						ret = 1;
 | 
				
			||||||
err:
 | 
					err:
 | 
				
			||||||
	if(cmds) sk_OPENSSL_STRING_pop_free(cmds, identity);
 | 
						if(cmds) sk_STRING_pop_free(cmds, identity);
 | 
				
			||||||
	if(name) OPENSSL_free(name);
 | 
						if(name) OPENSSL_free(name);
 | 
				
			||||||
	if(desc) OPENSSL_free(desc);
 | 
						if(desc) OPENSSL_free(desc);
 | 
				
			||||||
	return ret;
 | 
						return ret;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static void util_do_cmds(ENGINE *e, STACK_OF(OPENSSL_STRING) *cmds,
 | 
					static void util_do_cmds(ENGINE *e, STACK_OF(STRING) *cmds, BIO *bio_out,
 | 
				
			||||||
			BIO *bio_out, const char *indent)
 | 
								 const char *indent)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
	int loop, res, num = sk_OPENSSL_STRING_num(cmds);
 | 
						int loop, res, num = sk_STRING_num(cmds);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if(num < 0)
 | 
						if(num < 0)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
@@ -304,7 +304,7 @@ static void util_do_cmds(ENGINE *e, STACK_OF(OPENSSL_STRING) *cmds,
 | 
				
			|||||||
		{
 | 
							{
 | 
				
			||||||
		char buf[256];
 | 
							char buf[256];
 | 
				
			||||||
		const char *cmd, *arg;
 | 
							const char *cmd, *arg;
 | 
				
			||||||
		cmd = sk_OPENSSL_STRING_value(cmds, loop);
 | 
							cmd = sk_STRING_value(cmds, loop);
 | 
				
			||||||
		res = 1; /* assume success */
 | 
							res = 1; /* assume success */
 | 
				
			||||||
		/* Check if this command has no ":arg" */
 | 
							/* Check if this command has no ":arg" */
 | 
				
			||||||
		if((arg = strstr(cmd, ":")) == NULL)
 | 
							if((arg = strstr(cmd, ":")) == NULL)
 | 
				
			||||||
@@ -344,9 +344,9 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	const char **pp;
 | 
						const char **pp;
 | 
				
			||||||
	int verbose=0, list_cap=0, test_avail=0, test_avail_noise = 0;
 | 
						int verbose=0, list_cap=0, test_avail=0, test_avail_noise = 0;
 | 
				
			||||||
	ENGINE *e;
 | 
						ENGINE *e;
 | 
				
			||||||
	STACK_OF(OPENSSL_STRING) *engines = sk_OPENSSL_STRING_new_null();
 | 
						STACK_OF(STRING) *engines = sk_STRING_new_null();
 | 
				
			||||||
	STACK_OF(OPENSSL_STRING) *pre_cmds = sk_OPENSSL_STRING_new_null();
 | 
						STACK_OF(STRING) *pre_cmds = sk_STRING_new_null();
 | 
				
			||||||
	STACK_OF(OPENSSL_STRING) *post_cmds = sk_OPENSSL_STRING_new_null();
 | 
						STACK_OF(STRING) *post_cmds = sk_STRING_new_null();
 | 
				
			||||||
	int badops=1;
 | 
						int badops=1;
 | 
				
			||||||
	BIO *bio_out=NULL;
 | 
						BIO *bio_out=NULL;
 | 
				
			||||||
	const char *indent = "     ";
 | 
						const char *indent = "     ";
 | 
				
			||||||
@@ -393,20 +393,20 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			argc--; argv++;
 | 
								argc--; argv++;
 | 
				
			||||||
			if (argc == 0)
 | 
								if (argc == 0)
 | 
				
			||||||
				goto skip_arg_loop;
 | 
									goto skip_arg_loop;
 | 
				
			||||||
			sk_OPENSSL_STRING_push(pre_cmds,*argv);
 | 
								sk_STRING_push(pre_cmds,*argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else if (strcmp(*argv,"-post") == 0)
 | 
							else if (strcmp(*argv,"-post") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			argc--; argv++;
 | 
								argc--; argv++;
 | 
				
			||||||
			if (argc == 0)
 | 
								if (argc == 0)
 | 
				
			||||||
				goto skip_arg_loop;
 | 
									goto skip_arg_loop;
 | 
				
			||||||
			sk_OPENSSL_STRING_push(post_cmds,*argv);
 | 
								sk_STRING_push(post_cmds,*argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else if ((strncmp(*argv,"-h",2) == 0) ||
 | 
							else if ((strncmp(*argv,"-h",2) == 0) ||
 | 
				
			||||||
				(strcmp(*argv,"-?") == 0))
 | 
									(strcmp(*argv,"-?") == 0))
 | 
				
			||||||
			goto skip_arg_loop;
 | 
								goto skip_arg_loop;
 | 
				
			||||||
		else
 | 
							else
 | 
				
			||||||
			sk_OPENSSL_STRING_push(engines,*argv);
 | 
								sk_STRING_push(engines,*argv);
 | 
				
			||||||
		argc--;
 | 
							argc--;
 | 
				
			||||||
		argv++;
 | 
							argv++;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
@@ -421,17 +421,17 @@ skip_arg_loop:
 | 
				
			|||||||
		goto end;
 | 
							goto end;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (sk_OPENSSL_STRING_num(engines) == 0)
 | 
						if (sk_STRING_num(engines) == 0)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		for(e = ENGINE_get_first(); e != NULL; e = ENGINE_get_next(e))
 | 
							for(e = ENGINE_get_first(); e != NULL; e = ENGINE_get_next(e))
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			sk_OPENSSL_STRING_push(engines,(char *)ENGINE_get_id(e));
 | 
								sk_STRING_push(engines,(char *)ENGINE_get_id(e));
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	for (i=0; i<sk_OPENSSL_STRING_num(engines); i++)
 | 
						for (i=0; i<sk_STRING_num(engines); i++)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		const char *id = sk_OPENSSL_STRING_value(engines,i);
 | 
							const char *id = sk_STRING_value(engines,i);
 | 
				
			||||||
		if ((e = ENGINE_by_id(id)) != NULL)
 | 
							if ((e = ENGINE_by_id(id)) != NULL)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			const char *name = ENGINE_get_name(e);
 | 
								const char *name = ENGINE_get_name(e);
 | 
				
			||||||
@@ -533,9 +533,9 @@ skip_pmeths:
 | 
				
			|||||||
end:
 | 
					end:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	ERR_print_errors(bio_err);
 | 
						ERR_print_errors(bio_err);
 | 
				
			||||||
	sk_OPENSSL_STRING_pop_free(engines, identity);
 | 
						sk_STRING_pop_free(engines, identity);
 | 
				
			||||||
	sk_OPENSSL_STRING_pop_free(pre_cmds, identity);
 | 
						sk_STRING_pop_free(pre_cmds, identity);
 | 
				
			||||||
	sk_OPENSSL_STRING_pop_free(post_cmds, identity);
 | 
						sk_STRING_pop_free(post_cmds, identity);
 | 
				
			||||||
	if (bio_out != NULL) BIO_free_all(bio_out);
 | 
						if (bio_out != NULL) BIO_free_all(bio_out);
 | 
				
			||||||
	apps_shutdown();
 | 
						apps_shutdown();
 | 
				
			||||||
	OPENSSL_EXIT(ret);
 | 
						OPENSSL_EXIT(ret);
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										11
									
								
								apps/gendh.c
									
									
									
									
									
								
							
							
						
						
									
										11
									
								
								apps/gendh.c
									
									
									
									
									
								
							@@ -89,6 +89,9 @@ int MAIN(int, char **);
 | 
				
			|||||||
int MAIN(int argc, char **argv)
 | 
					int MAIN(int argc, char **argv)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
	BN_GENCB cb;
 | 
						BN_GENCB cb;
 | 
				
			||||||
 | 
					#ifndef OPENSSL_NO_ENGINE
 | 
				
			||||||
 | 
						ENGINE *e = NULL;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
	DH *dh=NULL;
 | 
						DH *dh=NULL;
 | 
				
			||||||
	int ret=1,num=DEFBITS;
 | 
						int ret=1,num=DEFBITS;
 | 
				
			||||||
	int g=2;
 | 
						int g=2;
 | 
				
			||||||
@@ -160,7 +163,7 @@ bad:
 | 
				
			|||||||
		}
 | 
							}
 | 
				
			||||||
		
 | 
							
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					#ifndef OPENSSL_NO_ENGINE
 | 
				
			||||||
        setup_engine(bio_err, engine, 0);
 | 
					        e = setup_engine(bio_err, engine, 0);
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	out=BIO_new(BIO_s_file());
 | 
						out=BIO_new(BIO_s_file());
 | 
				
			||||||
@@ -232,10 +235,4 @@ static int MS_CALLBACK dh_cb(int p, int n, BN_GENCB *cb)
 | 
				
			|||||||
#endif
 | 
					#endif
 | 
				
			||||||
	return 1;
 | 
						return 1;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
#else /* !OPENSSL_NO_DH */
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# if PEDANTIC
 | 
					 | 
				
			||||||
static void *dummy=&dummy;
 | 
					 | 
				
			||||||
# endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -78,6 +78,9 @@ int MAIN(int, char **);
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
int MAIN(int argc, char **argv)
 | 
					int MAIN(int argc, char **argv)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
 | 
					#ifndef OPENSSL_NO_ENGINE
 | 
				
			||||||
 | 
						ENGINE *e = NULL;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
	DSA *dsa=NULL;
 | 
						DSA *dsa=NULL;
 | 
				
			||||||
	int ret=1;
 | 
						int ret=1;
 | 
				
			||||||
	char *outfile=NULL;
 | 
						char *outfile=NULL;
 | 
				
			||||||
@@ -203,7 +206,7 @@ bad:
 | 
				
			|||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					#ifndef OPENSSL_NO_ENGINE
 | 
				
			||||||
        setup_engine(bio_err, engine, 0);
 | 
					        e = setup_engine(bio_err, engine, 0);
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if(!app_passwd(bio_err, NULL, passargout, NULL, &passout)) {
 | 
						if(!app_passwd(bio_err, NULL, passargout, NULL, &passout)) {
 | 
				
			||||||
@@ -276,10 +279,4 @@ end:
 | 
				
			|||||||
	apps_shutdown();
 | 
						apps_shutdown();
 | 
				
			||||||
	OPENSSL_EXIT(ret);
 | 
						OPENSSL_EXIT(ret);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
#else /* !OPENSSL_NO_DSA */
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# if PEDANTIC
 | 
					 | 
				
			||||||
static void *dummy=&dummy;
 | 
					 | 
				
			||||||
# endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -93,7 +93,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	ENGINE *e = NULL;
 | 
						ENGINE *e = NULL;
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
	int ret=1;
 | 
						int ret=1;
 | 
				
			||||||
	int non_fips_allow = 0;
 | 
					 | 
				
			||||||
	int i,num=DEFBITS;
 | 
						int i,num=DEFBITS;
 | 
				
			||||||
	long l;
 | 
						long l;
 | 
				
			||||||
	const EVP_CIPHER *enc=NULL;
 | 
						const EVP_CIPHER *enc=NULL;
 | 
				
			||||||
@@ -106,9 +105,9 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	char *inrand=NULL;
 | 
						char *inrand=NULL;
 | 
				
			||||||
	BIO *out=NULL;
 | 
						BIO *out=NULL;
 | 
				
			||||||
	BIGNUM *bn = BN_new();
 | 
						BIGNUM *bn = BN_new();
 | 
				
			||||||
	RSA *rsa = NULL;
 | 
						RSA *rsa = RSA_new();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if(!bn) goto err;
 | 
						if(!bn || !rsa) goto err;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	apps_startup();
 | 
						apps_startup();
 | 
				
			||||||
	BN_GENCB_set(&cb, genrsa_cb, bio_err);
 | 
						BN_GENCB_set(&cb, genrsa_cb, bio_err);
 | 
				
			||||||
@@ -186,8 +185,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
			passargout= *(++argv);
 | 
								passargout= *(++argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else if (strcmp(*argv,"-non-fips-allow") == 0)
 | 
					 | 
				
			||||||
			non_fips_allow = 1;
 | 
					 | 
				
			||||||
		else
 | 
							else
 | 
				
			||||||
			break;
 | 
								break;
 | 
				
			||||||
		argv++;
 | 
							argv++;
 | 
				
			||||||
@@ -268,16 +265,6 @@ bad:
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	BIO_printf(bio_err,"Generating RSA private key, %d bit long modulus\n",
 | 
						BIO_printf(bio_err,"Generating RSA private key, %d bit long modulus\n",
 | 
				
			||||||
		num);
 | 
							num);
 | 
				
			||||||
#ifdef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
	rsa = RSA_new();
 | 
					 | 
				
			||||||
#else
 | 
					 | 
				
			||||||
	rsa = RSA_new_method(e);
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	if (!rsa)
 | 
					 | 
				
			||||||
		goto err;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if (non_fips_allow)
 | 
					 | 
				
			||||||
		rsa->flags |= RSA_FLAG_NON_FIPS_ALLOW;
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if(!BN_set_word(bn, f4) || !RSA_generate_key_ex(rsa, num, bn, &cb))
 | 
						if(!BN_set_word(bn, f4) || !RSA_generate_key_ex(rsa, num, bn, &cb))
 | 
				
			||||||
		goto err;
 | 
							goto err;
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,107 +0,0 @@
 | 
				
			|||||||
$! INSTALL.COM -- Installs the files in a given directory tree
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$! Author: Richard Levitte <richard@levitte.org>
 | 
					 | 
				
			||||||
$! Time of creation: 22-MAY-1998 10:13
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$! P1  root of the directory tree
 | 
					 | 
				
			||||||
$! P2  "64" for 64-bit pointers.
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$! Announce/identify.
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ proc = f$environment( "procedure")
 | 
					 | 
				
			||||||
$ write sys$output "@@@ "+ -
 | 
					 | 
				
			||||||
   f$parse( proc, , , "name")+ f$parse( proc, , , "type")
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ on error then goto tidy
 | 
					 | 
				
			||||||
$ on control_c then goto tidy
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ if (p1 .eqs. "")
 | 
					 | 
				
			||||||
$ then
 | 
					 | 
				
			||||||
$   write sys$output "First argument missing."
 | 
					 | 
				
			||||||
$   write sys$output -
 | 
					 | 
				
			||||||
     "It should be the directory where you want things installed."
 | 
					 | 
				
			||||||
$   exit
 | 
					 | 
				
			||||||
$ endif
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ 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
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ archd = arch
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ if (p2 .nes. "")
 | 
					 | 
				
			||||||
$ then
 | 
					 | 
				
			||||||
$   if (p2 .eqs. "64")
 | 
					 | 
				
			||||||
$   then
 | 
					 | 
				
			||||||
$     archd = arch+ "_64"
 | 
					 | 
				
			||||||
$   else
 | 
					 | 
				
			||||||
$     if (p2 .nes. "32")
 | 
					 | 
				
			||||||
$     then
 | 
					 | 
				
			||||||
$       write sys$output "Second argument invalid."
 | 
					 | 
				
			||||||
$       write sys$output "It should be "32", "64", or nothing."
 | 
					 | 
				
			||||||
$       exit
 | 
					 | 
				
			||||||
$     endif
 | 
					 | 
				
			||||||
$   endif
 | 
					 | 
				
			||||||
$ endif
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ root = f$parse( p1, "[]A.;0", , , "syntax_only, no_conceal") - "A.;0"
 | 
					 | 
				
			||||||
$ root_dev = f$parse(root,,,"device","syntax_only")
 | 
					 | 
				
			||||||
$ root_dir = f$parse(root,,,"directory","syntax_only") - -
 | 
					 | 
				
			||||||
   "[000000." - "][" - "[" - "]"
 | 
					 | 
				
			||||||
$ root = root_dev + "[" + root_dir
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ define /nolog wrk_sslroot 'root'.] /trans=conc
 | 
					 | 
				
			||||||
$ define /nolog wrk_sslxexe wrk_sslroot:['archd'_exe]
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ if f$parse("wrk_sslroot:[000000]") .eqs. "" then -
 | 
					 | 
				
			||||||
   create /directory /log wrk_sslroot:[000000]
 | 
					 | 
				
			||||||
$ if f$parse("wrk_sslxexe:") .eqs. "" then -
 | 
					 | 
				
			||||||
   create /directory /log wrk_sslxexe:
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ exe := openssl
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ exe_dir := [-.'archd'.exe.apps]
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$! Executables.
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ i = 0
 | 
					 | 
				
			||||||
$ loop_exe:
 | 
					 | 
				
			||||||
$   e = f$edit(f$element( i, ",", exe), "trim")
 | 
					 | 
				
			||||||
$   i = i + 1
 | 
					 | 
				
			||||||
$   if e .eqs. "," then goto loop_exe_end
 | 
					 | 
				
			||||||
$   set noon
 | 
					 | 
				
			||||||
$   file = exe_dir+ e+ ".exe"
 | 
					 | 
				
			||||||
$   if f$search( file) .nes. ""
 | 
					 | 
				
			||||||
$   then
 | 
					 | 
				
			||||||
$     copy /protection = w:re 'file' wrk_sslxexe: /log
 | 
					 | 
				
			||||||
$   endif
 | 
					 | 
				
			||||||
$   set on
 | 
					 | 
				
			||||||
$ goto loop_exe
 | 
					 | 
				
			||||||
$ loop_exe_end:
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$! Miscellaneous.
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ set noon
 | 
					 | 
				
			||||||
$ copy /protection = w:re ca.com wrk_sslxexe:ca.com /log
 | 
					 | 
				
			||||||
$ copy /protection = w:re openssl-vms.cnf wrk_sslroot:[000000]openssl.cnf /log
 | 
					 | 
				
			||||||
$ set on
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ tidy:
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ call deass wrk_sslroot
 | 
					 | 
				
			||||||
$ call deass wrk_sslxexe
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ exit
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ deass: subroutine
 | 
					 | 
				
			||||||
$ if (f$trnlnm( p1, "LNM$PROCESS") .nes. "")
 | 
					 | 
				
			||||||
$ then
 | 
					 | 
				
			||||||
$   deassign /process 'p1'
 | 
					 | 
				
			||||||
$ endif
 | 
					 | 
				
			||||||
$ endsubroutine
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
							
								
								
									
										69
									
								
								apps/install.com
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										69
									
								
								apps/install.com
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,69 @@
 | 
				
			|||||||
 | 
					$! INSTALL.COM -- Installs the files in a given directory tree
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$! Author: Richard Levitte <richard@levitte.org>
 | 
				
			||||||
 | 
					$! Time of creation: 22-MAY-1998 10:13
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$! P1	root of the directory tree
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$	IF P1 .EQS. ""
 | 
				
			||||||
 | 
					$	THEN
 | 
				
			||||||
 | 
					$	    WRITE SYS$OUTPUT "First argument missing."
 | 
				
			||||||
 | 
					$	    WRITE SYS$OUTPUT "Should be the directory where you want things installed."
 | 
				
			||||||
 | 
					$	    EXIT
 | 
				
			||||||
 | 
					$	ENDIF
 | 
				
			||||||
 | 
					$
 | 
				
			||||||
 | 
					$	ROOT = F$PARSE(P1,"[]A.;0",,,"SYNTAX_ONLY,NO_CONCEAL") - "A.;0"
 | 
				
			||||||
 | 
					$	ROOT_DEV = F$PARSE(ROOT,,,"DEVICE","SYNTAX_ONLY")
 | 
				
			||||||
 | 
					$	ROOT_DIR = F$PARSE(ROOT,,,"DIRECTORY","SYNTAX_ONLY") -
 | 
				
			||||||
 | 
							   - "[000000." - "][" - "[" - "]"
 | 
				
			||||||
 | 
					$	ROOT = ROOT_DEV + "[" + ROOT_DIR
 | 
				
			||||||
 | 
					$
 | 
				
			||||||
 | 
					$	DEFINE/NOLOG WRK_SSLROOT 'ROOT'.] /TRANS=CONC
 | 
				
			||||||
 | 
					$	DEFINE/NOLOG WRK_SSLVEXE WRK_SSLROOT:[VAX_EXE]
 | 
				
			||||||
 | 
					$	DEFINE/NOLOG WRK_SSLAEXE WRK_SSLROOT:[ALPHA_EXE]
 | 
				
			||||||
 | 
					$	DEFINE/NOLOG WRK_SSLLIB WRK_SSLROOT:[LIB]
 | 
				
			||||||
 | 
					$
 | 
				
			||||||
 | 
					$	IF F$PARSE("WRK_SSLROOT:[000000]") .EQS. "" THEN -
 | 
				
			||||||
 | 
						   CREATE/DIR/LOG WRK_SSLROOT:[000000]
 | 
				
			||||||
 | 
					$	IF F$PARSE("WRK_SSLVEXE:") .EQS. "" THEN -
 | 
				
			||||||
 | 
						   CREATE/DIR/LOG WRK_SSLVEXE:
 | 
				
			||||||
 | 
					$	IF F$PARSE("WRK_SSLAEXE:") .EQS. "" THEN -
 | 
				
			||||||
 | 
						   CREATE/DIR/LOG WRK_SSLAEXE:
 | 
				
			||||||
 | 
					$	IF F$PARSE("WRK_SSLLIB:") .EQS. "" THEN -
 | 
				
			||||||
 | 
						   CREATE/DIR/LOG WRK_SSLLIB:
 | 
				
			||||||
 | 
					$
 | 
				
			||||||
 | 
					$	EXE := openssl
 | 
				
			||||||
 | 
					$
 | 
				
			||||||
 | 
					$	VEXE_DIR := [-.VAX.EXE.APPS]
 | 
				
			||||||
 | 
					$	AEXE_DIR := [-.AXP.EXE.APPS]
 | 
				
			||||||
 | 
					$
 | 
				
			||||||
 | 
					$	I = 0
 | 
				
			||||||
 | 
					$ LOOP_EXE: 
 | 
				
			||||||
 | 
					$	E = F$EDIT(F$ELEMENT(I, ",", EXE),"TRIM")
 | 
				
			||||||
 | 
					$	I = I + 1
 | 
				
			||||||
 | 
					$	IF E .EQS. "," THEN GOTO LOOP_EXE_END
 | 
				
			||||||
 | 
					$	SET NOON
 | 
				
			||||||
 | 
					$	IF F$SEARCH(VEXE_DIR+E+".EXE") .NES. ""
 | 
				
			||||||
 | 
					$	THEN
 | 
				
			||||||
 | 
					$	  COPY 'VEXE_DIR''E'.EXE WRK_SSLVEXE:'E'.EXE/log
 | 
				
			||||||
 | 
					$	  SET FILE/PROT=W:RE WRK_SSLVEXE:'E'.EXE
 | 
				
			||||||
 | 
					$	ENDIF
 | 
				
			||||||
 | 
					$	IF F$SEARCH(AEXE_DIR+E+".EXE") .NES. ""
 | 
				
			||||||
 | 
					$	THEN
 | 
				
			||||||
 | 
					$	  COPY 'AEXE_DIR''E'.EXE WRK_SSLAEXE:'E'.EXE/log
 | 
				
			||||||
 | 
					$	  SET FILE/PROT=W:RE WRK_SSLAEXE:'E'.EXE
 | 
				
			||||||
 | 
					$	ENDIF
 | 
				
			||||||
 | 
					$	SET ON
 | 
				
			||||||
 | 
					$	GOTO LOOP_EXE
 | 
				
			||||||
 | 
					$ LOOP_EXE_END:
 | 
				
			||||||
 | 
					$
 | 
				
			||||||
 | 
					$	SET NOON
 | 
				
			||||||
 | 
					$	COPY CA.COM WRK_SSLAEXE:CA.COM/LOG
 | 
				
			||||||
 | 
					$	SET FILE/PROT=W:RE WRK_SSLAEXE:CA.COM
 | 
				
			||||||
 | 
					$	COPY CA.COM WRK_SSLVEXE:CA.COM/LOG
 | 
				
			||||||
 | 
					$	SET FILE/PROT=W:RE WRK_SSLVEXE:CA.COM
 | 
				
			||||||
 | 
					$	COPY OPENSSL-VMS.CNF WRK_SSLROOT:[000000]OPENSSL.CNF/LOG
 | 
				
			||||||
 | 
					$	SET FILE/PROT=W:R WRK_SSLROOT:[000000]OPENSSL.CNF
 | 
				
			||||||
 | 
					$	SET ON
 | 
				
			||||||
 | 
					$
 | 
				
			||||||
 | 
					$	EXIT
 | 
				
			||||||
@@ -6,12 +6,11 @@ $!               A-Com Computing, Inc.
 | 
				
			|||||||
$!               byer@mail.all-net.net
 | 
					$!               byer@mail.all-net.net
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!  Changes by Richard Levitte <richard@levitte.org>
 | 
					$!  Changes by Richard Levitte <richard@levitte.org>
 | 
				
			||||||
$!             Zoltan Arpadffy <zoli@polarhome.com>   
 | 
					 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!  This command files compiles and creates all the various different
 | 
					$!  This command files compiles and creates all the various different
 | 
				
			||||||
$!  "application" programs for the different types of encryption for OpenSSL.
 | 
					$!  "application" programs for the different types of encryption for OpenSSL.
 | 
				
			||||||
$!  The EXE's are placed in the directory [.xxx.EXE.APPS] where "xxx" denotes
 | 
					$!  The EXE's are placed in the directory [.xxx.EXE.APPS] where "xxx" denotes
 | 
				
			||||||
$!  ALPHA, IA64 or VAX, depending on your machine architecture.
 | 
					$!  either AXP or VAX depending on your machine architecture.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!  It was written so it would try to determine what "C" compiler to
 | 
					$!  It was written so it would try to determine what "C" compiler to
 | 
				
			||||||
$!  use or you can specify which "C" compiler to use.
 | 
					$!  use or you can specify which "C" compiler to use.
 | 
				
			||||||
@@ -25,7 +24,7 @@ $!	   VAXC	 For VAX C.
 | 
				
			|||||||
$!	   DECC	 For DEC C.
 | 
					$!	   DECC	 For DEC C.
 | 
				
			||||||
$!	   GNUC	 For GNU C.
 | 
					$!	   GNUC	 For GNU C.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!  If you don't specify a compiler, it will try to determine which
 | 
					$!  If you don't speficy a compiler, it will try to determine which
 | 
				
			||||||
$!  "C" compiler to use.
 | 
					$!  "C" compiler to use.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!  P3, if defined, sets a TCP/IP library to use, through one of the following
 | 
					$!  P3, if defined, sets a TCP/IP library to use, through one of the following
 | 
				
			||||||
@@ -39,63 +38,33 @@ $!  P4, if defined, sets a compiler thread NOT needed on OpenVMS 7.1 (and up)
 | 
				
			|||||||
$!
 | 
					$!
 | 
				
			||||||
$!  P5, if defined, sets a choice of programs to compile.
 | 
					$!  P5, if defined, sets a choice of programs to compile.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!  P6, if defined, specifies the C pointer size.  Ignored on VAX.
 | 
					 | 
				
			||||||
$!      ("64=ARGV" gives more efficient code with HP C V7.3 or newer.)
 | 
					 | 
				
			||||||
$!      Supported values are:
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$!      ""       Compile with default (/NOPOINTER_SIZE)
 | 
					 | 
				
			||||||
$!      32       Compile with /POINTER_SIZE=32 (SHORT)
 | 
					 | 
				
			||||||
$!      64       Compile with /POINTER_SIZE=64[=ARGV] (LONG[=ARGV])
 | 
					 | 
				
			||||||
$!               (Automatically select ARGV if compiler supports it.)
 | 
					 | 
				
			||||||
$!      64=      Compile with /POINTER_SIZE=64 (LONG).
 | 
					 | 
				
			||||||
$!      64=ARGV  Compile with /POINTER_SIZE=64=ARGV (LONG=ARGV).
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$!  P7, if defined, specifies a directory where ZLIB files (zlib.h,
 | 
					 | 
				
			||||||
$!  libz.olb) may be found.  Optionally, a non-default object library
 | 
					 | 
				
			||||||
$!  name may be included ("dev:[dir]libz_64.olb", for example).
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$! Announce/identify.
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ proc = f$environment( "procedure")
 | 
					 | 
				
			||||||
$ write sys$output "@@@ "+ -
 | 
					 | 
				
			||||||
   f$parse( proc, , , "name")+ f$parse( proc, , , "type")
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ on control_c then goto exit
 | 
					 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$! Define A TCP/IP Library That We Will Need To Link To.
 | 
					$! Define A TCP/IP Library That We Will Need To Link To.
 | 
				
			||||||
$! (That Is, If We Need To Link To One.)
 | 
					$! (That Is, If We Need To Link To One.)
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$ TCPIP_LIB = ""
 | 
					$ TCPIP_LIB = ""
 | 
				
			||||||
$ ZLIB_LIB = ""
 | 
					 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$! Check What Architecture We Are Using.
 | 
					$! Check What Architecture We Are Using.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$ IF (F$GETSYI("CPU").LT.128)
 | 
					$ IF (F$GETSYI("CPU").GE.128)
 | 
				
			||||||
$ THEN
 | 
					$ THEN
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!  The Architecture Is VAX.
 | 
					$!  The Architecture Is AXP.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$   ARCH = "VAX"
 | 
					$   ARCH := AXP
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$! Else...
 | 
					$! Else...
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$ ELSE
 | 
					$ ELSE
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!  The Architecture Is Alpha, IA64 or whatever comes in the future.
 | 
					$!  The Architecture Is VAX.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$   ARCH = F$EDIT( F$GETSYI( "ARCH_NAME"), "UPCASE")
 | 
					$   ARCH := VAX
 | 
				
			||||||
$   IF (ARCH .EQS. "") THEN ARCH = "UNK"
 | 
					 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$! End The Architecture Check.
 | 
					$! End The Architecture Check.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$ ENDIF
 | 
					$ ENDIF
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$ ARCHD = ARCH
 | 
					 | 
				
			||||||
$ LIB32 = "32"
 | 
					 | 
				
			||||||
$ OPT_FILE = ""
 | 
					 | 
				
			||||||
$ POINTER_SIZE = ""
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$! Define what programs should be compiled
 | 
					$! Define what programs should be compiled
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$ PROGRAMS := OPENSSL
 | 
					$ PROGRAMS := OPENSSL
 | 
				
			||||||
@@ -104,40 +73,25 @@ $! Check To Make Sure We Have Valid Command Line Parameters.
 | 
				
			|||||||
$!
 | 
					$!
 | 
				
			||||||
$ GOSUB CHECK_OPTIONS
 | 
					$ GOSUB CHECK_OPTIONS
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$! Define The CRYPTO Library.
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ CRYPTO_LIB := SYS$DISK:[-.'ARCHD'.EXE.CRYPTO]SSL_LIBCRYPTO'LIB32'.OLB
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$! Define The SSL Library.
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ SSL_LIB := SYS$DISK:[-.'ARCHD'.EXE.SSL]SSL_LIBSSL'LIB32'.OLB
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$! Define The OBJ and EXE Directories.
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ OBJ_DIR := SYS$DISK:[-.'ARCHD'.OBJ.APPS]
 | 
					 | 
				
			||||||
$ EXE_DIR := SYS$DISK:[-.'ARCHD'.EXE.APPS]
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$! Specify the destination directory in any /MAP option.
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ if (LINKMAP .eqs. "MAP")
 | 
					 | 
				
			||||||
$ then
 | 
					 | 
				
			||||||
$   LINKMAP = LINKMAP+ "=''EXE_DIR'"
 | 
					 | 
				
			||||||
$ endif
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$! Add the location prefix to the linker options file name.
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ if (OPT_FILE .nes. "")
 | 
					 | 
				
			||||||
$ then
 | 
					 | 
				
			||||||
$   OPT_FILE = EXE_DIR+ OPT_FILE
 | 
					 | 
				
			||||||
$ endif
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$! Initialise logical names and such
 | 
					$! Initialise logical names and such
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$ GOSUB INITIALISE
 | 
					$ GOSUB INITIALISE
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$! Tell The User What Kind of Machine We Run On.
 | 
					$! Tell The User What Kind of Machine We Run On.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$ WRITE SYS$OUTPUT "Host system architecture: ''ARCHD'"
 | 
					$ WRITE SYS$OUTPUT "Compiling On A ",ARCH," Machine."
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$! Define The CRYPTO Library.
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$ CRYPTO_LIB := SYS$DISK:[-.'ARCH'.EXE.CRYPTO]LIBCRYPTO.OLB
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$! Define The SSL Library.
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$ SSL_LIB := SYS$DISK:[-.'ARCH'.EXE.SSL]LIBSSL.OLB
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$! Define The OBJ Directory.
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$ OBJ_DIR := SYS$DISK:[-.'ARCH'.OBJ.APPS]
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$! Check To See If The OBJ Directory Exists.
 | 
					$! Check To See If The OBJ Directory Exists.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
@@ -152,6 +106,10 @@ $! End The OBJ Directory Check.
 | 
				
			|||||||
$!
 | 
					$!
 | 
				
			||||||
$ ENDIF
 | 
					$ ENDIF
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
 | 
					$! Define The EXE Directory.
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$ EXE_DIR := SYS$DISK:[-.'ARCH'.EXE.APPS]
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
$! Check To See If The EXE Directory Exists.
 | 
					$! Check To See If The EXE Directory Exists.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$ IF (F$PARSE(EXE_DIR).EQS."")
 | 
					$ IF (F$PARSE(EXE_DIR).EQS."")
 | 
				
			||||||
@@ -174,9 +132,6 @@ $!
 | 
				
			|||||||
$ GOSUB CHECK_OPT_FILE
 | 
					$ GOSUB CHECK_OPT_FILE
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$! Define The Application Files.
 | 
					$! Define The Application Files.
 | 
				
			||||||
$! NOTE: Some might think this list ugly.  However, it's made this way to
 | 
					 | 
				
			||||||
$! reflect the E_OBJ variable in Makefile as closely as possible, thereby
 | 
					 | 
				
			||||||
$! making it fairly easy to verify that the lists are the same.
 | 
					 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$ LIB_OPENSSL = "VERIFY,ASN1PARS,REQ,DGST,DH,DHPARAM,ENC,PASSWD,GENDH,ERRSTR,"+-
 | 
					$ LIB_OPENSSL = "VERIFY,ASN1PARS,REQ,DGST,DH,DHPARAM,ENC,PASSWD,GENDH,ERRSTR,"+-
 | 
				
			||||||
	     	"CA,PKCS7,CRL2P7,CRL,"+-
 | 
						     	"CA,PKCS7,CRL2P7,CRL,"+-
 | 
				
			||||||
@@ -184,17 +139,14 @@ $ LIB_OPENSSL = "VERIFY,ASN1PARS,REQ,DGST,DH,DHPARAM,ENC,PASSWD,GENDH,ERRSTR,"+-
 | 
				
			|||||||
	      	"X509,GENRSA,GENDSA,GENPKEY,S_SERVER,S_CLIENT,SPEED,"+-
 | 
						      	"X509,GENRSA,GENDSA,GENPKEY,S_SERVER,S_CLIENT,SPEED,"+-
 | 
				
			||||||
	      	"S_TIME,APPS,S_CB,S_SOCKET,APP_RAND,VERSION,SESS_ID,"+-
 | 
						      	"S_TIME,APPS,S_CB,S_SOCKET,APP_RAND,VERSION,SESS_ID,"+-
 | 
				
			||||||
	      	"CIPHERS,NSEQ,PKCS12,PKCS8,PKEY,PKEYPARAM,PKEYUTL,"+ -
 | 
						      	"CIPHERS,NSEQ,PKCS12,PKCS8,PKEY,PKEYPARAM,PKEYUTL,"+ -
 | 
				
			||||||
	      	"SPKAC,SMIME,CMS,RAND,ENGINE,OCSP,PRIME,TS,SRP"
 | 
						      	"SPKAC,SMIME,CMS,RAND,ENGINE,OCSP,PRIME,TS"
 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ LIB_OPENSSL = LIB_OPENSSL+ ",VMS_DECC_INIT"
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ TCPIP_PROGRAMS = ",,"
 | 
					$ TCPIP_PROGRAMS = ",,"
 | 
				
			||||||
$ IF COMPILER .EQS. "VAXC" THEN -
 | 
					$ IF COMPILER .EQS. "VAXC" THEN -
 | 
				
			||||||
     TCPIP_PROGRAMS = ",OPENSSL,"
 | 
					     TCPIP_PROGRAMS = ",OPENSSL,"
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$! Setup exceptional compilations
 | 
					$! Setup exceptional compilations
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$ COMPILEWITH_CC2 = ",S_SOCKET,S_SERVER,S_CLIENT,"
 | 
					$ COMPILEWITH_CC2 = ",S_SERVER,S_CLIENT,"
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$ PHASE := LIB
 | 
					$ PHASE := LIB
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
@@ -212,10 +164,6 @@ $!  Make The Application File Name
 | 
				
			|||||||
$!
 | 
					$!
 | 
				
			||||||
$ CURRENT_APP = F$EDIT(F$ELEMENT(APP_COUNTER,",",PROGRAMS),"TRIM")
 | 
					$ CURRENT_APP = F$EDIT(F$ELEMENT(APP_COUNTER,",",PROGRAMS),"TRIM")
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!  Create The Executable File Name.
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$   EXE_FILE = EXE_DIR + CURRENT_APP + ".EXE"
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$!  Check To See If We Are At The End Of The File List.
 | 
					$!  Check To See If We Are At The End Of The File List.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$ IF (CURRENT_APP.EQS.",")
 | 
					$ IF (CURRENT_APP.EQS.",")
 | 
				
			||||||
@@ -245,7 +193,7 @@ $   LIB_COUNTER = -1
 | 
				
			|||||||
$!
 | 
					$!
 | 
				
			||||||
$!  Create a .OPT file for the object files
 | 
					$!  Create a .OPT file for the object files
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$   OPEN /WRITE OBJECTS 'EXE_DIR''CURRENT_APP'.OPT
 | 
					$   OPEN/WRITE OBJECTS 'EXE_DIR''CURRENT_APP'.OPT
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!  Top Of The File Loop.
 | 
					$!  Top Of The File Loop.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
@@ -279,6 +227,10 @@ $!
 | 
				
			|||||||
$!  Create The Object File Name.
 | 
					$!  Create The Object File Name.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$   OBJECT_FILE = OBJ_DIR + FILE_NAME + ".OBJ"
 | 
					$   OBJECT_FILE = OBJ_DIR + FILE_NAME + ".OBJ"
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$!  Create The Executable File Name.
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$   EXE_FILE = EXE_DIR + FILE_NAME + ".EXE"
 | 
				
			||||||
$   ON WARNING THEN GOTO NEXT_LIB
 | 
					$   ON WARNING THEN GOTO NEXT_LIB
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!  Check To See If The File We Want To Compile Actually Exists.
 | 
					$!  Check To See If The File We Want To Compile Actually Exists.
 | 
				
			||||||
@@ -332,18 +284,34 @@ $   GOTO NEXT_APP
 | 
				
			|||||||
$ ENDIF
 | 
					$ ENDIF
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$! Link The Program.
 | 
					$! Link The Program.
 | 
				
			||||||
 | 
					$! Check To See If We Are To Link With A Specific TCP/IP Library.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$ ON WARNING THEN GOTO NEXT_APP
 | 
					$ ON WARNING THEN GOTO NEXT_APP
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
 | 
					$ IF (TCPIP_LIB.NES."")
 | 
				
			||||||
 | 
					$ THEN
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
$! Don't Link With The RSAREF Routines And TCP/IP Library.
 | 
					$! Don't Link With The RSAREF Routines And TCP/IP Library.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$ LINK /'DEBUGGER' /'LINKMAP' /'TRACEBACK' /EXE='EXE_FILE' -
 | 
					$   LINK/'DEBUGGER'/'TRACEBACK' /EXE='EXE_FILE' -
 | 
				
			||||||
  'EXE_DIR''CURRENT_APP'.OPT /OPTIONS, -
 | 
						'EXE_DIR''CURRENT_APP'.OPT/OPTION, -
 | 
				
			||||||
  'SSL_LIB' /LIBRARY, -
 | 
					        'SSL_LIB'/LIBRARY,'CRYPTO_LIB'/LIBRARY, -
 | 
				
			||||||
  'CRYPTO_LIB' /LIBRARY -
 | 
					        'TCPIP_LIB','OPT_FILE'/OPTION
 | 
				
			||||||
  'TCPIP_LIB' -
 | 
					$!
 | 
				
			||||||
  'ZLIB_LIB' -
 | 
					$! Else...
 | 
				
			||||||
  ,'OPT_FILE' /OPTIONS
 | 
					$!
 | 
				
			||||||
 | 
					$ ELSE
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$! Don't Link With The RSAREF Routines And Link With A TCP/IP Library.
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$   LINK/'DEBUGGER'/'TRACEBACK' /EXE='EXE_FILE' -
 | 
				
			||||||
 | 
						'EXE_DIR''CURRENT_APP'.OPT/OPTION, -
 | 
				
			||||||
 | 
					        'SSL_LIB'/LIBRARY,'CRYPTO_LIB'/LIBRARY, -
 | 
				
			||||||
 | 
					        'OPT_FILE'/OPTION
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$! End The TCP/IP Library Check.
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$ ENDIF
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$! Go Back And Do It Again.
 | 
					$! Go Back And Do It Again.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
@@ -378,7 +346,7 @@ $!
 | 
				
			|||||||
$     CREATE 'OPT_FILE'
 | 
					$     CREATE 'OPT_FILE'
 | 
				
			||||||
$DECK
 | 
					$DECK
 | 
				
			||||||
!
 | 
					!
 | 
				
			||||||
! Default System Options File To Link Against 
 | 
					! Default System Options File To Link Agianst 
 | 
				
			||||||
! The Sharable VAX C Runtime Library.
 | 
					! The Sharable VAX C Runtime Library.
 | 
				
			||||||
!
 | 
					!
 | 
				
			||||||
SYS$SHARE:VAXCRTL.EXE/SHARE
 | 
					SYS$SHARE:VAXCRTL.EXE/SHARE
 | 
				
			||||||
@@ -407,7 +375,7 @@ $!
 | 
				
			|||||||
$     CREATE 'OPT_FILE'
 | 
					$     CREATE 'OPT_FILE'
 | 
				
			||||||
$DECK
 | 
					$DECK
 | 
				
			||||||
!
 | 
					!
 | 
				
			||||||
! Default System Options File To Link Against 
 | 
					! Default System Options File To Link Agianst 
 | 
				
			||||||
! The Sharable C Runtime Library.
 | 
					! The Sharable C Runtime Library.
 | 
				
			||||||
!
 | 
					!
 | 
				
			||||||
GNU_CC:[000000]GCCLIB/LIBRARY
 | 
					GNU_CC:[000000]GCCLIB/LIBRARY
 | 
				
			||||||
@@ -442,7 +410,7 @@ $!
 | 
				
			|||||||
$       CREATE 'OPT_FILE'
 | 
					$       CREATE 'OPT_FILE'
 | 
				
			||||||
$DECK
 | 
					$DECK
 | 
				
			||||||
!
 | 
					!
 | 
				
			||||||
! Default System Options File To Link Against 
 | 
					! Default System Options File To Link Agianst 
 | 
				
			||||||
! The Sharable DEC C Runtime Library.
 | 
					! The Sharable DEC C Runtime Library.
 | 
				
			||||||
!
 | 
					!
 | 
				
			||||||
SYS$SHARE:DECC$SHR.EXE/SHARE
 | 
					SYS$SHARE:DECC$SHR.EXE/SHARE
 | 
				
			||||||
@@ -452,19 +420,19 @@ $!    Else...
 | 
				
			|||||||
$!
 | 
					$!
 | 
				
			||||||
$     ELSE
 | 
					$     ELSE
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!      Create The non-VAX Linker Option File.
 | 
					$!      Create The AXP Linker Option File.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$       CREATE 'OPT_FILE'
 | 
					$       CREATE 'OPT_FILE'
 | 
				
			||||||
$DECK
 | 
					$DECK
 | 
				
			||||||
!
 | 
					!
 | 
				
			||||||
! Default System Options File For non-VAX To Link Against 
 | 
					! Default System Options File For AXP To Link Agianst 
 | 
				
			||||||
! The Sharable C Runtime Library.
 | 
					! The Sharable C Runtime Library.
 | 
				
			||||||
!
 | 
					!
 | 
				
			||||||
SYS$SHARE:CMA$OPEN_LIB_SHR/SHARE
 | 
					SYS$SHARE:CMA$OPEN_LIB_SHR/SHARE
 | 
				
			||||||
SYS$SHARE:CMA$OPEN_RTL/SHARE
 | 
					SYS$SHARE:CMA$OPEN_RTL/SHARE
 | 
				
			||||||
$EOD
 | 
					$EOD
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!    End The DEC C Option File Check.
 | 
					$!    End The VAX/AXP DEC C Option File Check.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$     ENDIF
 | 
					$     ENDIF
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
@@ -541,15 +509,14 @@ $!
 | 
				
			|||||||
$ IF (P1.EQS."NODEBUG")
 | 
					$ IF (P1.EQS."NODEBUG")
 | 
				
			||||||
$ THEN
 | 
					$ THEN
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!  P1 Is NODEBUG, So Compile Without Debugger Information.
 | 
					$!   P1 Is NODEBUG, So Compile Without Debugger Information.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$   DEBUGGER  = "NODEBUG"
 | 
					$    DEBUGGER  = "NODEBUG"
 | 
				
			||||||
$   LINKMAP = "NOMAP"
 | 
					$    TRACEBACK = "NOTRACEBACK" 
 | 
				
			||||||
$   TRACEBACK = "NOTRACEBACK" 
 | 
					$    GCC_OPTIMIZE = "OPTIMIZE"
 | 
				
			||||||
$   GCC_OPTIMIZE = "OPTIMIZE"
 | 
					$    CC_OPTIMIZE = "OPTIMIZE"
 | 
				
			||||||
$   CC_OPTIMIZE = "OPTIMIZE"
 | 
					$    WRITE SYS$OUTPUT "No Debugger Information Will Be Produced During Compile."
 | 
				
			||||||
$   WRITE SYS$OUTPUT "No Debugger Information Will Be Produced During Compile."
 | 
					$    WRITE SYS$OUTPUT "Compiling With Compiler Optimization."
 | 
				
			||||||
$   WRITE SYS$OUTPUT "Compiling With Compiler Optimization."
 | 
					 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$! Else...
 | 
					$! Else...
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
@@ -563,7 +530,6 @@ $!
 | 
				
			|||||||
$!    Compile With Debugger Information.
 | 
					$!    Compile With Debugger Information.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$     DEBUGGER  = "DEBUG"
 | 
					$     DEBUGGER  = "DEBUG"
 | 
				
			||||||
$     LINKMAP = "MAP"
 | 
					 | 
				
			||||||
$     TRACEBACK = "TRACEBACK"
 | 
					$     TRACEBACK = "TRACEBACK"
 | 
				
			||||||
$     GCC_OPTIMIZE = "NOOPTIMIZE"
 | 
					$     GCC_OPTIMIZE = "NOOPTIMIZE"
 | 
				
			||||||
$     CC_OPTIMIZE = "NOOPTIMIZE"
 | 
					$     CC_OPTIMIZE = "NOOPTIMIZE"
 | 
				
			||||||
@@ -571,7 +537,7 @@ $     WRITE SYS$OUTPUT "Debugger Information Will Be Produced During Compile."
 | 
				
			|||||||
$     WRITE SYS$OUTPUT "Compiling Without Compiler Optimization."
 | 
					$     WRITE SYS$OUTPUT "Compiling Without Compiler Optimization."
 | 
				
			||||||
$   ELSE
 | 
					$   ELSE
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!    Tell The User Entered An Invalid Option.
 | 
					$!    Tell The User Entered An Invalid Option..
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$     WRITE SYS$OUTPUT ""
 | 
					$     WRITE SYS$OUTPUT ""
 | 
				
			||||||
$     WRITE SYS$OUTPUT "The Option ",P1," Is Invalid.  The Valid Options Are:"
 | 
					$     WRITE SYS$OUTPUT "The Option ",P1," Is Invalid.  The Valid Options Are:"
 | 
				
			||||||
@@ -584,7 +550,7 @@ $!    Time To EXIT.
 | 
				
			|||||||
$!
 | 
					$!
 | 
				
			||||||
$     EXIT
 | 
					$     EXIT
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!  End The Valid Argument Check.
 | 
					$!  End The Valid Arguement Check.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$   ENDIF
 | 
					$   ENDIF
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
@@ -592,87 +558,6 @@ $! End The P1 Check.
 | 
				
			|||||||
$!
 | 
					$!
 | 
				
			||||||
$ ENDIF
 | 
					$ ENDIF
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$! Check P6 (POINTER_SIZE).
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ IF (P6 .NES. "") .AND. (ARCH .NES. "VAX")
 | 
					 | 
				
			||||||
$ THEN
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$   IF (P6 .EQS. "32")
 | 
					 | 
				
			||||||
$   THEN
 | 
					 | 
				
			||||||
$     POINTER_SIZE = " /POINTER_SIZE=32"
 | 
					 | 
				
			||||||
$   ELSE
 | 
					 | 
				
			||||||
$     POINTER_SIZE = F$EDIT( P6, "COLLAPSE, UPCASE")
 | 
					 | 
				
			||||||
$     IF ((POINTER_SIZE .EQS. "64") .OR. -
 | 
					 | 
				
			||||||
       (POINTER_SIZE .EQS. "64=") .OR. -
 | 
					 | 
				
			||||||
       (POINTER_SIZE .EQS. "64=ARGV"))
 | 
					 | 
				
			||||||
$     THEN
 | 
					 | 
				
			||||||
$       ARCHD = ARCH+ "_64"
 | 
					 | 
				
			||||||
$       LIB32 = ""
 | 
					 | 
				
			||||||
$       IF (F$EXTRACT( 2, 1, POINTER_SIZE) .EQS. "=")
 | 
					 | 
				
			||||||
$       THEN
 | 
					 | 
				
			||||||
$!        Explicit user choice: "64" or "64=ARGV".
 | 
					 | 
				
			||||||
$         IF (POINTER_SIZE .EQS. "64=") THEN POINTER_SIZE = "64"
 | 
					 | 
				
			||||||
$       ELSE
 | 
					 | 
				
			||||||
$         SET NOON
 | 
					 | 
				
			||||||
$         DEFINE /USER_MODE SYS$OUTPUT NL:
 | 
					 | 
				
			||||||
$         DEFINE /USER_MODE SYS$ERROR NL:
 | 
					 | 
				
			||||||
$         CC /NOLIST /NOOBJECT /POINTER_SIZE=64=ARGV NL:
 | 
					 | 
				
			||||||
$         IF ($STATUS .AND. %X0FFF0000) .EQ. %X00030000
 | 
					 | 
				
			||||||
$         THEN
 | 
					 | 
				
			||||||
$           ! If we got here, it means DCL complained like this:
 | 
					 | 
				
			||||||
$           ! %DCL-W-NOVALU, value not allowed - remove value specification
 | 
					 | 
				
			||||||
$           !  \64=\
 | 
					 | 
				
			||||||
$           !
 | 
					 | 
				
			||||||
$           ! If the compiler was run, logicals defined in /USER would
 | 
					 | 
				
			||||||
$           ! have been deassigned automatically.  However, when DCL
 | 
					 | 
				
			||||||
$           ! complains, they aren't, so we do it here (it might be
 | 
					 | 
				
			||||||
$           ! unnecessary, but just in case there will be another error
 | 
					 | 
				
			||||||
$           ! message further on that we don't want to miss)
 | 
					 | 
				
			||||||
$           DEASSIGN /USER_MODE SYS$ERROR
 | 
					 | 
				
			||||||
$           DEASSIGN /USER_MODE SYS$OUTPUT
 | 
					 | 
				
			||||||
$         ELSE
 | 
					 | 
				
			||||||
$           POINTER_SIZE = POINTER_SIZE + "=ARGV"
 | 
					 | 
				
			||||||
$         ENDIF
 | 
					 | 
				
			||||||
$         SET ON
 | 
					 | 
				
			||||||
$       ENDIF
 | 
					 | 
				
			||||||
$       POINTER_SIZE = " /POINTER_SIZE=''POINTER_SIZE'"
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$     ELSE
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$!      Tell The User Entered An Invalid Option.
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$       WRITE SYS$OUTPUT ""
 | 
					 | 
				
			||||||
$       WRITE SYS$OUTPUT "The Option ", P6, -
 | 
					 | 
				
			||||||
         " Is Invalid.  The Valid Options Are:"
 | 
					 | 
				
			||||||
$       WRITE SYS$OUTPUT ""
 | 
					 | 
				
			||||||
$       WRITE SYS$OUTPUT -
 | 
					 | 
				
			||||||
         "    """"  :  Compile with default (short) pointers."
 | 
					 | 
				
			||||||
$       WRITE SYS$OUTPUT -
 | 
					 | 
				
			||||||
         "    32  :  Compile with 32-bit (short) pointers."
 | 
					 | 
				
			||||||
$       WRITE SYS$OUTPUT -
 | 
					 | 
				
			||||||
         "    64       :  Compile with 64-bit (long) pointers (auto ARGV)."
 | 
					 | 
				
			||||||
$       WRITE SYS$OUTPUT -
 | 
					 | 
				
			||||||
         "    64=      :  Compile with 64-bit (long) pointers (no ARGV)."
 | 
					 | 
				
			||||||
$       WRITE SYS$OUTPUT -
 | 
					 | 
				
			||||||
         "    64=ARGV  :  Compile with 64-bit (long) pointers (ARGV)."
 | 
					 | 
				
			||||||
$       WRITE SYS$OUTPUT ""
 | 
					 | 
				
			||||||
$! 
 | 
					 | 
				
			||||||
$!      Time To EXIT.
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$       EXIT
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$     ENDIF
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$   ENDIF
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$! End The P6 (POINTER_SIZE) Check.
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ ENDIF
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$! Set basic C compiler /INCLUDE directories.
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ CC_INCLUDES = "SYS$DISK:[-],SYS$DISK:[-.CRYPTO]"
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$! Check To See If P2 Is Blank.
 | 
					$! Check To See If P2 Is Blank.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$ IF (P2.EQS."")
 | 
					$ IF (P2.EQS."")
 | 
				
			||||||
@@ -696,7 +581,7 @@ $   ELSE
 | 
				
			|||||||
$!
 | 
					$!
 | 
				
			||||||
$!  Check To See If We Have VAXC Or DECC.
 | 
					$!  Check To See If We Have VAXC Or DECC.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$     IF (ARCH.NES."VAX").OR.(F$TRNLNM("DECC$CC_DEFAULT").NES."")
 | 
					$     IF (ARCH.EQS."AXP").OR.(F$TRNLNM("DECC$CC_DEFAULT").NES."")
 | 
				
			||||||
$     THEN 
 | 
					$     THEN 
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!      Looks Like DECC, Set To Use DECC.
 | 
					$!      Looks Like DECC, Set To Use DECC.
 | 
				
			||||||
@@ -773,64 +658,11 @@ $ CCDEFS = "MONOLITH"
 | 
				
			|||||||
$ IF F$TYPE(USER_CCDEFS) .NES. "" THEN CCDEFS = CCDEFS + "," + USER_CCDEFS
 | 
					$ IF F$TYPE(USER_CCDEFS) .NES. "" THEN CCDEFS = CCDEFS + "," + USER_CCDEFS
 | 
				
			||||||
$ CCEXTRAFLAGS = ""
 | 
					$ CCEXTRAFLAGS = ""
 | 
				
			||||||
$ IF F$TYPE(USER_CCFLAGS) .NES. "" THEN CCEXTRAFLAGS = USER_CCFLAGS
 | 
					$ IF F$TYPE(USER_CCFLAGS) .NES. "" THEN CCEXTRAFLAGS = USER_CCFLAGS
 | 
				
			||||||
$ CCDISABLEWARNINGS = "" !!! "LONGLONGTYPE,LONGLONGSUFX,FOUNDCR"
 | 
					$ CCDISABLEWARNINGS = "LONGLONGTYPE,LONGLONGSUFX,FOUNDCR"
 | 
				
			||||||
$ IF F$TYPE(USER_CCDISABLEWARNINGS) .NES. "" THEN -
 | 
					$ IF F$TYPE(USER_CCDISABLEWARNINGS) .NES. "" THEN -
 | 
				
			||||||
	CCDISABLEWARNINGS = CCDISABLEWARNINGS + "," + USER_CCDISABLEWARNINGS
 | 
						CCDISABLEWARNINGS = CCDISABLEWARNINGS + "," + USER_CCDISABLEWARNINGS
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$! Check To See If We Have A ZLIB Option.
 | 
					$!  Check To See If The User Entered A Valid Paramter.
 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ ZLIB = P7
 | 
					 | 
				
			||||||
$ IF (ZLIB .NES. "")
 | 
					 | 
				
			||||||
$ THEN
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$!  Check for expected ZLIB files.
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$   err = 0
 | 
					 | 
				
			||||||
$   file1 = f$parse( "zlib.h", ZLIB, , , "SYNTAX_ONLY")
 | 
					 | 
				
			||||||
$   if (f$search( file1) .eqs. "")
 | 
					 | 
				
			||||||
$   then
 | 
					 | 
				
			||||||
$     WRITE SYS$OUTPUT ""
 | 
					 | 
				
			||||||
$     WRITE SYS$OUTPUT "The Option ", ZLIB, " Is Invalid."
 | 
					 | 
				
			||||||
$     WRITE SYS$OUTPUT "    Can't find header: ''file1'"
 | 
					 | 
				
			||||||
$     err = 1
 | 
					 | 
				
			||||||
$   endif
 | 
					 | 
				
			||||||
$   file1 = f$parse( "A.;", ZLIB)- "A.;"
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$   file2 = f$parse( ZLIB, "libz.olb", , , "SYNTAX_ONLY")
 | 
					 | 
				
			||||||
$   if (f$search( file2) .eqs. "")
 | 
					 | 
				
			||||||
$   then
 | 
					 | 
				
			||||||
$     if (err .eq. 0)
 | 
					 | 
				
			||||||
$     then
 | 
					 | 
				
			||||||
$       WRITE SYS$OUTPUT ""
 | 
					 | 
				
			||||||
$       WRITE SYS$OUTPUT "The Option ", ZLIB, " Is Invalid."
 | 
					 | 
				
			||||||
$     endif
 | 
					 | 
				
			||||||
$     WRITE SYS$OUTPUT "    Can't find library: ''file2'"
 | 
					 | 
				
			||||||
$     WRITE SYS$OUTPUT ""
 | 
					 | 
				
			||||||
$     err = err+ 2
 | 
					 | 
				
			||||||
$   endif
 | 
					 | 
				
			||||||
$   if (err .eq. 1)
 | 
					 | 
				
			||||||
$   then
 | 
					 | 
				
			||||||
$     WRITE SYS$OUTPUT ""
 | 
					 | 
				
			||||||
$   endif
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$   if (err .ne. 0)
 | 
					 | 
				
			||||||
$   then
 | 
					 | 
				
			||||||
$     EXIT
 | 
					 | 
				
			||||||
$   endif
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$   CCDEFS = """ZLIB=1"", "+ CCDEFS
 | 
					 | 
				
			||||||
$   CC_INCLUDES = CC_INCLUDES+ ", "+ file1
 | 
					 | 
				
			||||||
$   ZLIB_LIB = ", ''file2' /library"
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$!  Print info
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$   WRITE SYS$OUTPUT "ZLIB library spec: ", file2
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$! End The ZLIB Check.
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ ENDIF
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$!  Check To See If The User Entered A Valid Parameter.
 | 
					 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$ IF (P2.EQS."VAXC").OR.(P2.EQS."DECC").OR.(P2.EQS."GNUC")
 | 
					$ IF (P2.EQS."VAXC").OR.(P2.EQS."DECC").OR.(P2.EQS."GNUC")
 | 
				
			||||||
$ THEN
 | 
					$ THEN
 | 
				
			||||||
@@ -853,13 +685,13 @@ $!
 | 
				
			|||||||
$     CC = "CC"
 | 
					$     CC = "CC"
 | 
				
			||||||
$     IF ARCH.EQS."VAX" .AND. F$TRNLNM("DECC$CC_DEFAULT").NES."/DECC" -
 | 
					$     IF ARCH.EQS."VAX" .AND. F$TRNLNM("DECC$CC_DEFAULT").NES."/DECC" -
 | 
				
			||||||
	 THEN CC = "CC/DECC"
 | 
						 THEN CC = "CC/DECC"
 | 
				
			||||||
$     CC = CC + " /''CC_OPTIMIZE' /''DEBUGGER' /STANDARD=RELAXED"+ -
 | 
					$     CC = CC + "/''CC_OPTIMIZE'/''DEBUGGER'/STANDARD=ANSI89" + -
 | 
				
			||||||
       "''POINTER_SIZE' /NOLIST /PREFIX=ALL" + -
 | 
					           "/NOLIST/PREFIX=ALL" + -
 | 
				
			||||||
       " /INCLUDE=(''CC_INCLUDES') " + CCEXTRAFLAGS
 | 
						   "/INCLUDE=(SYS$DISK:[-],SYS$DISK:[-.CRYPTO])" + CCEXTRAFLAGS
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!    Define The Linker Options File Name.
 | 
					$!    Define The Linker Options File Name.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$     OPT_FILE = "VAX_DECC_OPTIONS.OPT"
 | 
					$     OPT_FILE = "SYS$DISK:[]VAX_DECC_OPTIONS.OPT"
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!  End DECC Check.
 | 
					$!  End DECC Check.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
@@ -880,14 +712,14 @@ $!
 | 
				
			|||||||
$!    Compile Using VAXC.
 | 
					$!    Compile Using VAXC.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$     CC = "CC"
 | 
					$     CC = "CC"
 | 
				
			||||||
$     IF ARCH.NES."VAX"
 | 
					$     IF ARCH.EQS."AXP"
 | 
				
			||||||
$     THEN
 | 
					$     THEN
 | 
				
			||||||
$	WRITE SYS$OUTPUT "There is no VAX C on ''ARCH'!"
 | 
					$	WRITE SYS$OUTPUT "There is no VAX C on Alpha!"
 | 
				
			||||||
$	EXIT
 | 
					$	EXIT
 | 
				
			||||||
$     ENDIF
 | 
					$     ENDIF
 | 
				
			||||||
$     IF F$TRNLNM("DECC$CC_DEFAULT").EQS."/DECC" THEN CC = "CC/VAXC"
 | 
					$     IF F$TRNLNM("DECC$CC_DEFAULT").EQS."/DECC" THEN CC = "CC/VAXC"
 | 
				
			||||||
$     CC = CC + "/''CC_OPTIMIZE'/''DEBUGGER'/NOLIST" + -
 | 
					$     CC = CC + "/''CC_OPTIMIZE'/''DEBUGGER'/NOLIST" + -
 | 
				
			||||||
	   "/INCLUDE=(''CC_INCLUDES')" + CCEXTRAFLAGS
 | 
						   "/INCLUDE=(SYS$DISK:[-],SYS$DISK:[-.CRYPTO])" + CCEXTRAFLAGS
 | 
				
			||||||
$     CCDEFS = CCDEFS + ",""VAXC"""
 | 
					$     CCDEFS = CCDEFS + ",""VAXC"""
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!    Define <sys> As SYS$COMMON:[SYSLIB]
 | 
					$!    Define <sys> As SYS$COMMON:[SYSLIB]
 | 
				
			||||||
@@ -896,7 +728,7 @@ $     DEFINE/NOLOG SYS SYS$COMMON:[SYSLIB]
 | 
				
			|||||||
$!
 | 
					$!
 | 
				
			||||||
$!    Define The Linker Options File Name.
 | 
					$!    Define The Linker Options File Name.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$     OPT_FILE = "VAX_VAXC_OPTIONS.OPT"
 | 
					$     OPT_FILE = "SYS$DISK:[]VAX_VAXC_OPTIONS.OPT"
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!  End VAXC Check
 | 
					$!  End VAXC Check
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
@@ -919,11 +751,11 @@ $!    Use GNU C...
 | 
				
			|||||||
$!
 | 
					$!
 | 
				
			||||||
$     IF F$TYPE(GCC) .EQS. "" THEN GCC := GCC
 | 
					$     IF F$TYPE(GCC) .EQS. "" THEN GCC := GCC
 | 
				
			||||||
$     CC = GCC+"/NOCASE_HACK/''GCC_OPTIMIZE'/''DEBUGGER'/NOLIST" + -
 | 
					$     CC = GCC+"/NOCASE_HACK/''GCC_OPTIMIZE'/''DEBUGGER'/NOLIST" + -
 | 
				
			||||||
	   "/INCLUDE=(''CC_INCLUDES')" + CCEXTRAFLAGS
 | 
						   "/INCLUDE=(SYS$DISK:[-],SYS$DISK:[-.CRYPTO])" + CCEXTRAFLAGS
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!    Define The Linker Options File Name.
 | 
					$!    Define The Linker Options File Name.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$     OPT_FILE = "VAX_GNUC_OPTIONS.OPT"
 | 
					$     OPT_FILE = "SYS$DISK:[]VAX_GNUC_OPTIONS.OPT"
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!  End The GNU C Check.
 | 
					$!  End The GNU C Check.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
@@ -933,7 +765,7 @@ $!  Set up default defines
 | 
				
			|||||||
$!
 | 
					$!
 | 
				
			||||||
$   CCDEFS = """FLAT_INC=1""," + CCDEFS
 | 
					$   CCDEFS = """FLAT_INC=1""," + CCDEFS
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!  Else The User Entered An Invalid Argument.
 | 
					$!  Else The User Entered An Invalid Arguement.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$ ELSE
 | 
					$ ELSE
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
@@ -965,7 +797,7 @@ $   THEN
 | 
				
			|||||||
$!
 | 
					$!
 | 
				
			||||||
$!    Set the library to use SOCKETSHR
 | 
					$!    Set the library to use SOCKETSHR
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$     TCPIP_LIB = ",SYS$DISK:[-.VMS]SOCKETSHR_SHR.OPT /OPTIONS"
 | 
					$     TCPIP_LIB = "SYS$DISK:[-.VMS]SOCKETSHR_SHR.OPT/OPT"
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!    Done with SOCKETSHR
 | 
					$!    Done with SOCKETSHR
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
@@ -991,13 +823,13 @@ $   THEN
 | 
				
			|||||||
$!
 | 
					$!
 | 
				
			||||||
$!    Set the library to use UCX.
 | 
					$!    Set the library to use UCX.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$     TCPIP_LIB = ",SYS$DISK:[-.VMS]UCX_SHR_DECC.OPT /OPTIONS"
 | 
					$     TCPIP_LIB = "SYS$DISK:[-.VMS]UCX_SHR_DECC.OPT/OPT"
 | 
				
			||||||
$     IF F$TRNLNM("UCX$IPC_SHR") .NES. ""
 | 
					$     IF F$TRNLNM("UCX$IPC_SHR") .NES. ""
 | 
				
			||||||
$     THEN
 | 
					$     THEN
 | 
				
			||||||
$       TCPIP_LIB = ",SYS$DISK:[-.VMS]UCX_SHR_DECC_LOG.OPT /OPTIONS"
 | 
					$       TCPIP_LIB = "SYS$DISK:[-.VMS]UCX_SHR_DECC_LOG.OPT/OPT"
 | 
				
			||||||
$     ELSE
 | 
					$     ELSE
 | 
				
			||||||
$       IF COMPILER .NES. "DECC" .AND. ARCH .EQS. "VAX" THEN -
 | 
					$       IF COMPILER .NES. "DECC" .AND. ARCH .EQS. "VAX" THEN -
 | 
				
			||||||
	  TCPIP_LIB = ",SYS$DISK:[-.VMS]UCX_SHR_VAXC.OPT /OPTIONS"
 | 
						  TCPIP_LIB = "SYS$DISK:[-.VMS]UCX_SHR_VAXC.OPT/OPT"
 | 
				
			||||||
$     ENDIF
 | 
					$     ENDIF
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!    Done with UCX
 | 
					$!    Done with UCX
 | 
				
			||||||
@@ -1011,7 +843,7 @@ $   THEN
 | 
				
			|||||||
$!
 | 
					$!
 | 
				
			||||||
$!    Set the library to use TCPIP.
 | 
					$!    Set the library to use TCPIP.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$     TCPIP_LIB = ",SYS$DISK:[-.VMS]TCPIP_SHR_DECC.OPT /OPTIONS"
 | 
					$     TCPIP_LIB = "SYS$DISK:[-.VMS]TCPIP_SHR_DECC.OPT/OPT"
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!    Done with TCPIP
 | 
					$!    Done with TCPIP
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
@@ -1036,9 +868,9 @@ $   CCDEFS = CCDEFS + ",TCPIP_TYPE_''P3'"
 | 
				
			|||||||
$!
 | 
					$!
 | 
				
			||||||
$!  Print info
 | 
					$!  Print info
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$   WRITE SYS$OUTPUT "TCP/IP library spec: ", TCPIP_LIB- ","
 | 
					$   WRITE SYS$OUTPUT "TCP/IP library spec: ", TCPIP_LIB
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!  Else The User Entered An Invalid Argument.
 | 
					$!  Else The User Entered An Invalid Arguement.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$ ELSE
 | 
					$ ELSE
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
@@ -1066,13 +898,13 @@ $ IF COMPILER .EQS. "DECC"
 | 
				
			|||||||
$ THEN
 | 
					$ THEN
 | 
				
			||||||
$   IF CCDISABLEWARNINGS .NES. ""
 | 
					$   IF CCDISABLEWARNINGS .NES. ""
 | 
				
			||||||
$   THEN
 | 
					$   THEN
 | 
				
			||||||
$     CCDISABLEWARNINGS = " /WARNING=(DISABLE=(" + CCDISABLEWARNINGS + "))"
 | 
					$     CCDISABLEWARNINGS = "/WARNING=(DISABLE=(" + CCDISABLEWARNINGS + "))"
 | 
				
			||||||
$   ENDIF
 | 
					$   ENDIF
 | 
				
			||||||
$ ELSE
 | 
					$ ELSE
 | 
				
			||||||
$   CCDISABLEWARNINGS = ""
 | 
					$   CCDISABLEWARNINGS = ""
 | 
				
			||||||
$ ENDIF
 | 
					$ ENDIF
 | 
				
			||||||
$ CC2 = CC + " /DEFINE=(" + CCDEFS + ",_POSIX_C_SOURCE)" + CCDISABLEWARNINGS
 | 
					$ CC2 = CC + "/DEFINE=(" + CCDEFS + ",_POSIX_C_SOURCE)" + CCDISABLEWARNINGS
 | 
				
			||||||
$ CC = CC + " /DEFINE=(" + CCDEFS + ")" + CCDISABLEWARNINGS
 | 
					$ CC = CC + "/DEFINE=(" + CCDEFS + ")" + CCDISABLEWARNINGS
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$! Show user the result
 | 
					$! Show user the result
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
@@ -1138,7 +970,7 @@ $ __INCLUDE = __TOP + "INCLUDE.OPENSSL]"
 | 
				
			|||||||
$!
 | 
					$!
 | 
				
			||||||
$! Set up the logical name OPENSSL to point at the include directory
 | 
					$! Set up the logical name OPENSSL to point at the include directory
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$ DEFINE OPENSSL /NOLOG '__INCLUDE'
 | 
					$ DEFINE OPENSSL/NOLOG '__INCLUDE'
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$! Done
 | 
					$! Done
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
@@ -1146,24 +978,15 @@ $ RETURN
 | 
				
			|||||||
$!
 | 
					$!
 | 
				
			||||||
$ CLEANUP:
 | 
					$ CLEANUP:
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$! Restore the saved logical name OPENSSL, if it had a value.
 | 
					$! Restore the logical name OPENSSL if it had a value
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$ if (f$type( __SAVE_OPENSSL) .nes. "")
 | 
					$ IF __SAVE_OPENSSL .EQS. ""
 | 
				
			||||||
$ then
 | 
					$ THEN
 | 
				
			||||||
$   IF __SAVE_OPENSSL .EQS. ""
 | 
					$   DEASSIGN OPENSSL
 | 
				
			||||||
$   THEN
 | 
					$ ELSE
 | 
				
			||||||
$     DEASSIGN OPENSSL
 | 
					$   DEFINE/NOLOG OPENSSL '__SAVE_OPENSSL'
 | 
				
			||||||
$   ELSE
 | 
					$ ENDIF
 | 
				
			||||||
$     DEFINE /NOLOG OPENSSL '__SAVE_OPENSSL'
 | 
					 | 
				
			||||||
$   ENDIF
 | 
					 | 
				
			||||||
$ endif
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$! Close any open files.
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$ if (f$trnlnm( "objects", "LNM$PROCESS", 0, "SUPERVISOR") .nes. "") then -
 | 
					 | 
				
			||||||
   close objects
 | 
					 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$! Done
 | 
					$! Done
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$ RETURN
 | 
					$ RETURN
 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										66
									
								
								apps/ocsp.c
									
									
									
									
									
								
							
							
						
						
									
										66
									
								
								apps/ocsp.c
									
									
									
									
									
								
							@@ -62,8 +62,6 @@
 | 
				
			|||||||
				   on OpenVMS */
 | 
									   on OpenVMS */
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define USE_SOCKETS
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#include <stdio.h>
 | 
					#include <stdio.h>
 | 
				
			||||||
#include <stdlib.h>
 | 
					#include <stdlib.h>
 | 
				
			||||||
#include <string.h>
 | 
					#include <string.h>
 | 
				
			||||||
@@ -75,7 +73,6 @@
 | 
				
			|||||||
#include <openssl/ssl.h>
 | 
					#include <openssl/ssl.h>
 | 
				
			||||||
#include <openssl/evp.h>
 | 
					#include <openssl/evp.h>
 | 
				
			||||||
#include <openssl/bn.h>
 | 
					#include <openssl/bn.h>
 | 
				
			||||||
#include <openssl/x509v3.h>
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
#if defined(NETWARE_CLIB)
 | 
					#if defined(NETWARE_CLIB)
 | 
				
			||||||
#  ifdef NETWARE_BSDSOCK
 | 
					#  ifdef NETWARE_BSDSOCK
 | 
				
			||||||
@@ -100,7 +97,7 @@ static int add_ocsp_cert(OCSP_REQUEST **req, X509 *cert, const EVP_MD *cert_id_m
 | 
				
			|||||||
static int add_ocsp_serial(OCSP_REQUEST **req, char *serial, const EVP_MD * cert_id_md, X509 *issuer,
 | 
					static int add_ocsp_serial(OCSP_REQUEST **req, char *serial, const EVP_MD * cert_id_md, X509 *issuer,
 | 
				
			||||||
				STACK_OF(OCSP_CERTID) *ids);
 | 
									STACK_OF(OCSP_CERTID) *ids);
 | 
				
			||||||
static int print_ocsp_summary(BIO *out, OCSP_BASICRESP *bs, OCSP_REQUEST *req,
 | 
					static int print_ocsp_summary(BIO *out, OCSP_BASICRESP *bs, OCSP_REQUEST *req,
 | 
				
			||||||
			      STACK_OF(OPENSSL_STRING) *names,
 | 
								      STACK_OF(STRING) *names,
 | 
				
			||||||
			      STACK_OF(OCSP_CERTID) *ids, long nsec,
 | 
								      STACK_OF(OCSP_CERTID) *ids, long nsec,
 | 
				
			||||||
			      long maxage);
 | 
								      long maxage);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -114,7 +111,6 @@ static BIO *init_responder(char *port);
 | 
				
			|||||||
static int do_responder(OCSP_REQUEST **preq, BIO **pcbio, BIO *acbio, char *port);
 | 
					static int do_responder(OCSP_REQUEST **preq, BIO **pcbio, BIO *acbio, char *port);
 | 
				
			||||||
static int send_ocsp_response(BIO *cbio, OCSP_RESPONSE *resp);
 | 
					static int send_ocsp_response(BIO *cbio, OCSP_RESPONSE *resp);
 | 
				
			||||||
static OCSP_RESPONSE *query_responder(BIO *err, BIO *cbio, char *path,
 | 
					static OCSP_RESPONSE *query_responder(BIO *err, BIO *cbio, char *path,
 | 
				
			||||||
				STACK_OF(CONF_VALUE) *headers,
 | 
					 | 
				
			||||||
				OCSP_REQUEST *req, int req_timeout);
 | 
									OCSP_REQUEST *req, int req_timeout);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#undef PROG
 | 
					#undef PROG
 | 
				
			||||||
@@ -133,7 +129,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	char *rsignfile = NULL, *rkeyfile = NULL;
 | 
						char *rsignfile = NULL, *rkeyfile = NULL;
 | 
				
			||||||
	char *outfile = NULL;
 | 
						char *outfile = NULL;
 | 
				
			||||||
	int add_nonce = 1, noverify = 0, use_ssl = -1;
 | 
						int add_nonce = 1, noverify = 0, use_ssl = -1;
 | 
				
			||||||
	STACK_OF(CONF_VALUE) *headers = NULL;
 | 
					 | 
				
			||||||
	OCSP_REQUEST *req = NULL;
 | 
						OCSP_REQUEST *req = NULL;
 | 
				
			||||||
	OCSP_RESPONSE *resp = NULL;
 | 
						OCSP_RESPONSE *resp = NULL;
 | 
				
			||||||
	OCSP_BASICRESP *bs = NULL;
 | 
						OCSP_BASICRESP *bs = NULL;
 | 
				
			||||||
@@ -156,7 +151,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	int badarg = 0;
 | 
						int badarg = 0;
 | 
				
			||||||
	int i;
 | 
						int i;
 | 
				
			||||||
	int ignore_err = 0;
 | 
						int ignore_err = 0;
 | 
				
			||||||
	STACK_OF(OPENSSL_STRING) *reqnames = NULL;
 | 
						STACK_OF(STRING) *reqnames = NULL;
 | 
				
			||||||
	STACK_OF(OCSP_CERTID) *ids = NULL;
 | 
						STACK_OF(OCSP_CERTID) *ids = NULL;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	X509 *rca_cert = NULL;
 | 
						X509 *rca_cert = NULL;
 | 
				
			||||||
@@ -173,7 +168,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	SSL_load_error_strings();
 | 
						SSL_load_error_strings();
 | 
				
			||||||
	OpenSSL_add_ssl_algorithms();
 | 
						OpenSSL_add_ssl_algorithms();
 | 
				
			||||||
	args = argv + 1;
 | 
						args = argv + 1;
 | 
				
			||||||
	reqnames = sk_OPENSSL_STRING_new_null();
 | 
						reqnames = sk_STRING_new_null();
 | 
				
			||||||
	ids = sk_OCSP_CERTID_new_null();
 | 
						ids = sk_OCSP_CERTID_new_null();
 | 
				
			||||||
	while (!badarg && *args && *args[0] == '-')
 | 
						while (!badarg && *args && *args[0] == '-')
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
@@ -233,16 +228,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
				}
 | 
									}
 | 
				
			||||||
			else badarg = 1;
 | 
								else badarg = 1;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else if (!strcmp(*args, "-header"))
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if (args[1] && args[2])
 | 
					 | 
				
			||||||
				{
 | 
					 | 
				
			||||||
				if (!X509V3_add_value(args[1], args[2], &headers))
 | 
					 | 
				
			||||||
					goto end;
 | 
					 | 
				
			||||||
				args += 2;
 | 
					 | 
				
			||||||
				}
 | 
					 | 
				
			||||||
			else badarg = 1;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		else if (!strcmp(*args, "-ignore_err"))
 | 
							else if (!strcmp(*args, "-ignore_err"))
 | 
				
			||||||
			ignore_err = 1;
 | 
								ignore_err = 1;
 | 
				
			||||||
		else if (!strcmp(*args, "-noverify"))
 | 
							else if (!strcmp(*args, "-noverify"))
 | 
				
			||||||
@@ -445,7 +430,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
				if (!cert_id_md) cert_id_md = EVP_sha1();
 | 
									if (!cert_id_md) cert_id_md = EVP_sha1();
 | 
				
			||||||
				if(!add_ocsp_cert(&req, cert, cert_id_md, issuer, ids))
 | 
									if(!add_ocsp_cert(&req, cert, cert_id_md, issuer, ids))
 | 
				
			||||||
					goto end;
 | 
										goto end;
 | 
				
			||||||
				if(!sk_OPENSSL_STRING_push(reqnames, *args))
 | 
									if(!sk_STRING_push(reqnames, *args))
 | 
				
			||||||
					goto end;
 | 
										goto end;
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
			else badarg = 1;
 | 
								else badarg = 1;
 | 
				
			||||||
@@ -458,7 +443,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
				if (!cert_id_md) cert_id_md = EVP_sha1();
 | 
									if (!cert_id_md) cert_id_md = EVP_sha1();
 | 
				
			||||||
				if(!add_ocsp_serial(&req, *args, cert_id_md, issuer, ids))
 | 
									if(!add_ocsp_serial(&req, *args, cert_id_md, issuer, ids))
 | 
				
			||||||
					goto end;
 | 
										goto end;
 | 
				
			||||||
				if(!sk_OPENSSL_STRING_push(reqnames, *args))
 | 
									if(!sk_STRING_push(reqnames, *args))
 | 
				
			||||||
					goto end;
 | 
										goto end;
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
			else badarg = 1;
 | 
								else badarg = 1;
 | 
				
			||||||
@@ -769,7 +754,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		{
 | 
							{
 | 
				
			||||||
#ifndef OPENSSL_NO_SOCK
 | 
					#ifndef OPENSSL_NO_SOCK
 | 
				
			||||||
		resp = process_responder(bio_err, req, host, path,
 | 
							resp = process_responder(bio_err, req, host, path,
 | 
				
			||||||
					port, use_ssl, headers, req_timeout);
 | 
											port, use_ssl, req_timeout);
 | 
				
			||||||
		if (!resp)
 | 
							if (!resp)
 | 
				
			||||||
			goto end;
 | 
								goto end;
 | 
				
			||||||
#else
 | 
					#else
 | 
				
			||||||
@@ -914,11 +899,10 @@ end:
 | 
				
			|||||||
	OCSP_REQUEST_free(req);
 | 
						OCSP_REQUEST_free(req);
 | 
				
			||||||
	OCSP_RESPONSE_free(resp);
 | 
						OCSP_RESPONSE_free(resp);
 | 
				
			||||||
	OCSP_BASICRESP_free(bs);
 | 
						OCSP_BASICRESP_free(bs);
 | 
				
			||||||
	sk_OPENSSL_STRING_free(reqnames);
 | 
						sk_STRING_free(reqnames);
 | 
				
			||||||
	sk_OCSP_CERTID_free(ids);
 | 
						sk_OCSP_CERTID_free(ids);
 | 
				
			||||||
	sk_X509_pop_free(sign_other, X509_free);
 | 
						sk_X509_pop_free(sign_other, X509_free);
 | 
				
			||||||
	sk_X509_pop_free(verify_other, X509_free);
 | 
						sk_X509_pop_free(verify_other, X509_free);
 | 
				
			||||||
	sk_CONF_VALUE_pop_free(headers, X509V3_conf_free);
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (use_ssl != -1)
 | 
						if (use_ssl != -1)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
@@ -985,7 +969,7 @@ static int add_ocsp_serial(OCSP_REQUEST **req, char *serial,const EVP_MD *cert_i
 | 
				
			|||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static int print_ocsp_summary(BIO *out, OCSP_BASICRESP *bs, OCSP_REQUEST *req,
 | 
					static int print_ocsp_summary(BIO *out, OCSP_BASICRESP *bs, OCSP_REQUEST *req,
 | 
				
			||||||
			      STACK_OF(OPENSSL_STRING) *names,
 | 
								      STACK_OF(STRING) *names,
 | 
				
			||||||
			      STACK_OF(OCSP_CERTID) *ids, long nsec,
 | 
								      STACK_OF(OCSP_CERTID) *ids, long nsec,
 | 
				
			||||||
			      long maxage)
 | 
								      long maxage)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
@@ -997,13 +981,13 @@ static int print_ocsp_summary(BIO *out, OCSP_BASICRESP *bs, OCSP_REQUEST *req,
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	ASN1_GENERALIZEDTIME *rev, *thisupd, *nextupd;
 | 
						ASN1_GENERALIZEDTIME *rev, *thisupd, *nextupd;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (!bs || !req || !sk_OPENSSL_STRING_num(names) || !sk_OCSP_CERTID_num(ids))
 | 
						if (!bs || !req || !sk_STRING_num(names) || !sk_OCSP_CERTID_num(ids))
 | 
				
			||||||
		return 1;
 | 
							return 1;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	for (i = 0; i < sk_OCSP_CERTID_num(ids); i++)
 | 
						for (i = 0; i < sk_OCSP_CERTID_num(ids); i++)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		id = sk_OCSP_CERTID_value(ids, i);
 | 
							id = sk_OCSP_CERTID_value(ids, i);
 | 
				
			||||||
		name = sk_OPENSSL_STRING_value(names, i);
 | 
							name = sk_STRING_value(names, i);
 | 
				
			||||||
		BIO_printf(out, "%s: ", name);
 | 
							BIO_printf(out, "%s: ", name);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if(!OCSP_resp_find_status(bs, id, &status, &reason,
 | 
							if(!OCSP_resp_find_status(bs, id, &status, &reason,
 | 
				
			||||||
@@ -1274,12 +1258,10 @@ static int send_ocsp_response(BIO *cbio, OCSP_RESPONSE *resp)
 | 
				
			|||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static OCSP_RESPONSE *query_responder(BIO *err, BIO *cbio, char *path,
 | 
					static OCSP_RESPONSE *query_responder(BIO *err, BIO *cbio, char *path,
 | 
				
			||||||
				STACK_OF(CONF_VALUE) *headers,
 | 
					 | 
				
			||||||
				OCSP_REQUEST *req, int req_timeout)
 | 
									OCSP_REQUEST *req, int req_timeout)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
	int fd;
 | 
						int fd;
 | 
				
			||||||
	int rv;
 | 
						int rv;
 | 
				
			||||||
	int i;
 | 
					 | 
				
			||||||
	OCSP_REQ_CTX *ctx = NULL;
 | 
						OCSP_REQ_CTX *ctx = NULL;
 | 
				
			||||||
	OCSP_RESPONSE *rsp = NULL;
 | 
						OCSP_RESPONSE *rsp = NULL;
 | 
				
			||||||
	fd_set confds;
 | 
						fd_set confds;
 | 
				
			||||||
@@ -1296,13 +1278,16 @@ static OCSP_RESPONSE *query_responder(BIO *err, BIO *cbio, char *path,
 | 
				
			|||||||
		return NULL;
 | 
							return NULL;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if (req_timeout == -1)
 | 
				
			||||||
 | 
							return OCSP_sendreq_bio(cbio, path, req);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (BIO_get_fd(cbio, &fd) <= 0)
 | 
						if (BIO_get_fd(cbio, &fd) <= 0)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		BIO_puts(err, "Can't get connection fd\n");
 | 
							BIO_puts(err, "Can't get connection fd\n");
 | 
				
			||||||
		goto err;
 | 
							goto err;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (req_timeout != -1 && rv <= 0)
 | 
						if (rv <= 0)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		FD_ZERO(&confds);
 | 
							FD_ZERO(&confds);
 | 
				
			||||||
		openssl_fdset(fd, &confds);
 | 
							openssl_fdset(fd, &confds);
 | 
				
			||||||
@@ -1317,27 +1302,15 @@ static OCSP_RESPONSE *query_responder(BIO *err, BIO *cbio, char *path,
 | 
				
			|||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	ctx = OCSP_sendreq_new(cbio, path, NULL, -1);
 | 
						ctx = OCSP_sendreq_new(cbio, path, req, -1);
 | 
				
			||||||
	if (!ctx)
 | 
						if (!ctx)
 | 
				
			||||||
		return NULL;
 | 
							return NULL;
 | 
				
			||||||
 | 
					 | 
				
			||||||
	for (i = 0; i < sk_CONF_VALUE_num(headers); i++)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		CONF_VALUE *hdr = sk_CONF_VALUE_value(headers, i);
 | 
					 | 
				
			||||||
		if (!OCSP_REQ_CTX_add1_header(ctx, hdr->name, hdr->value))
 | 
					 | 
				
			||||||
			goto err;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if (!OCSP_REQ_CTX_set1_req(ctx, req))
 | 
					 | 
				
			||||||
		goto err;
 | 
					 | 
				
			||||||
	
 | 
						
 | 
				
			||||||
	for (;;)
 | 
						for (;;)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		rv = OCSP_sendreq_nbio(&rsp, ctx);
 | 
							rv = OCSP_sendreq_nbio(&rsp, ctx);
 | 
				
			||||||
		if (rv != -1)
 | 
							if (rv != -1)
 | 
				
			||||||
			break;
 | 
								break;
 | 
				
			||||||
		if (req_timeout == -1)
 | 
					 | 
				
			||||||
			continue;
 | 
					 | 
				
			||||||
		FD_ZERO(&confds);
 | 
							FD_ZERO(&confds);
 | 
				
			||||||
		openssl_fdset(fd, &confds);
 | 
							openssl_fdset(fd, &confds);
 | 
				
			||||||
		tv.tv_usec = 0;
 | 
							tv.tv_usec = 0;
 | 
				
			||||||
@@ -1361,7 +1334,7 @@ static OCSP_RESPONSE *query_responder(BIO *err, BIO *cbio, char *path,
 | 
				
			|||||||
			BIO_puts(err, "Select error\n");
 | 
								BIO_puts(err, "Select error\n");
 | 
				
			||||||
			break;
 | 
								break;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
 | 
								
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	err:
 | 
						err:
 | 
				
			||||||
	if (ctx)
 | 
						if (ctx)
 | 
				
			||||||
@@ -1372,7 +1345,6 @@ static OCSP_RESPONSE *query_responder(BIO *err, BIO *cbio, char *path,
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
OCSP_RESPONSE *process_responder(BIO *err, OCSP_REQUEST *req,
 | 
					OCSP_RESPONSE *process_responder(BIO *err, OCSP_REQUEST *req,
 | 
				
			||||||
			char *host, char *path, char *port, int use_ssl,
 | 
								char *host, char *path, char *port, int use_ssl,
 | 
				
			||||||
			STACK_OF(CONF_VALUE) *headers,
 | 
					 | 
				
			||||||
			int req_timeout)
 | 
								int req_timeout)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
	BIO *cbio = NULL;
 | 
						BIO *cbio = NULL;
 | 
				
			||||||
@@ -1407,14 +1379,14 @@ OCSP_RESPONSE *process_responder(BIO *err, OCSP_REQUEST *req,
 | 
				
			|||||||
		sbio = BIO_new_ssl(ctx, 1);
 | 
							sbio = BIO_new_ssl(ctx, 1);
 | 
				
			||||||
		cbio = BIO_push(sbio, cbio);
 | 
							cbio = BIO_push(sbio, cbio);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	resp = query_responder(err, cbio, path, headers, req, req_timeout);
 | 
						resp = query_responder(err, cbio, path, req, req_timeout);
 | 
				
			||||||
	if (!resp)
 | 
						if (!resp)
 | 
				
			||||||
		BIO_printf(bio_err, "Error querying OCSP responsder\n");
 | 
							BIO_printf(bio_err, "Error querying OCSP responsder\n");
 | 
				
			||||||
	end:
 | 
						end:
 | 
				
			||||||
	if (cbio)
 | 
					 | 
				
			||||||
		BIO_free_all(cbio);
 | 
					 | 
				
			||||||
	if (ctx)
 | 
						if (ctx)
 | 
				
			||||||
		SSL_CTX_free(ctx);
 | 
							SSL_CTX_free(ctx);
 | 
				
			||||||
 | 
						if (cbio)
 | 
				
			||||||
 | 
							BIO_free_all(cbio);
 | 
				
			||||||
	return resp;
 | 
						return resp;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -231,7 +231,7 @@ keyUsage = nonRepudiation, digitalSignature, keyEncipherment
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
subjectKeyIdentifier=hash
 | 
					subjectKeyIdentifier=hash
 | 
				
			||||||
 | 
					
 | 
				
			||||||
authorityKeyIdentifier=keyid:always,issuer
 | 
					authorityKeyIdentifier=keyid:always,issuer:always
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# This is what PKIX recommends but some broken software chokes on critical
 | 
					# This is what PKIX recommends but some broken software chokes on critical
 | 
				
			||||||
# extensions.
 | 
					# extensions.
 | 
				
			||||||
@@ -264,7 +264,7 @@ basicConstraints = CA:true
 | 
				
			|||||||
# Only issuerAltName and authorityKeyIdentifier make any sense in a CRL.
 | 
					# Only issuerAltName and authorityKeyIdentifier make any sense in a CRL.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# issuerAltName=issuer:copy
 | 
					# issuerAltName=issuer:copy
 | 
				
			||||||
authorityKeyIdentifier=keyid:always
 | 
					authorityKeyIdentifier=keyid:always,issuer:always
 | 
				
			||||||
 | 
					
 | 
				
			||||||
[ proxy_cert_ext ]
 | 
					[ proxy_cert_ext ]
 | 
				
			||||||
# These extensions should be added when creating a proxy certificate
 | 
					# These extensions should be added when creating a proxy certificate
 | 
				
			||||||
@@ -297,7 +297,7 @@ nsComment			= "OpenSSL Generated Certificate"
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
# PKIX recommendations harmless if included in all certificates.
 | 
					# PKIX recommendations harmless if included in all certificates.
 | 
				
			||||||
subjectKeyIdentifier=hash
 | 
					subjectKeyIdentifier=hash
 | 
				
			||||||
authorityKeyIdentifier=keyid,issuer
 | 
					authorityKeyIdentifier=keyid,issuer:always
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# This stuff is for subjectAltName and issuerAltname.
 | 
					# This stuff is for subjectAltName and issuerAltname.
 | 
				
			||||||
# Import the email address.
 | 
					# Import the email address.
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -129,9 +129,6 @@
 | 
				
			|||||||
#include "progs.h"
 | 
					#include "progs.h"
 | 
				
			||||||
#include "s_apps.h"
 | 
					#include "s_apps.h"
 | 
				
			||||||
#include <openssl/err.h>
 | 
					#include <openssl/err.h>
 | 
				
			||||||
#ifdef OPENSSL_FIPS
 | 
					 | 
				
			||||||
#include <openssl/fips.h>
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* The LHASH callbacks ("hash" & "cmp") have been replaced by functions with the
 | 
					/* The LHASH callbacks ("hash" & "cmp") have been replaced by functions with the
 | 
				
			||||||
 * base prototypes (we cast each variable inside the function to the required
 | 
					 * base prototypes (we cast each variable inside the function to the required
 | 
				
			||||||
@@ -215,13 +212,8 @@ static void lock_dbg_cb(int mode, int type, const char *file, int line)
 | 
				
			|||||||
		}
 | 
							}
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#if defined( OPENSSL_SYS_VMS) && (__INITIAL_POINTER_SIZE == 64)
 | 
					 | 
				
			||||||
# define ARGV _Argv
 | 
					 | 
				
			||||||
#else
 | 
					 | 
				
			||||||
# define ARGV Argv
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
int main(int Argc, char *ARGV[])
 | 
					int main(int Argc, char *Argv[])
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
	ARGS arg;
 | 
						ARGS arg;
 | 
				
			||||||
#define PROG_NAME_SIZE	39
 | 
					#define PROG_NAME_SIZE	39
 | 
				
			||||||
@@ -235,55 +227,7 @@ int main(int Argc, char *ARGV[])
 | 
				
			|||||||
	char **argv,*p;
 | 
						char **argv,*p;
 | 
				
			||||||
	LHASH_OF(FUNCTION) *prog=NULL;
 | 
						LHASH_OF(FUNCTION) *prog=NULL;
 | 
				
			||||||
	long errline;
 | 
						long errline;
 | 
				
			||||||
 | 
					 
 | 
				
			||||||
#if defined( OPENSSL_SYS_VMS) && (__INITIAL_POINTER_SIZE == 64)
 | 
					 | 
				
			||||||
	/* 2011-03-22 SMS.
 | 
					 | 
				
			||||||
	 * If we have 32-bit pointers everywhere, then we're safe, and
 | 
					 | 
				
			||||||
	 * we bypass this mess, as on non-VMS systems.  (See ARGV,
 | 
					 | 
				
			||||||
	 * above.)
 | 
					 | 
				
			||||||
	 * Problem 1: Compaq/HP C before V7.3 always used 32-bit
 | 
					 | 
				
			||||||
	 * pointers for argv[].
 | 
					 | 
				
			||||||
	 * Fix 1: For a 32-bit argv[], when we're using 64-bit pointers
 | 
					 | 
				
			||||||
	 * everywhere else, we always allocate and use a 64-bit
 | 
					 | 
				
			||||||
	 * duplicate of argv[].
 | 
					 | 
				
			||||||
	 * Problem 2: Compaq/HP C V7.3 (Alpha, IA64) before ECO1 failed
 | 
					 | 
				
			||||||
	 * to NULL-terminate a 64-bit argv[].  (As this was written, the
 | 
					 | 
				
			||||||
	 * compiler ECO was available only on IA64.)
 | 
					 | 
				
			||||||
	 * Fix 2: Unless advised not to (VMS_TRUST_ARGV), we test a
 | 
					 | 
				
			||||||
	 * 64-bit argv[argc] for NULL, and, if necessary, use a
 | 
					 | 
				
			||||||
	 * (properly) NULL-terminated (64-bit) duplicate of argv[].
 | 
					 | 
				
			||||||
	 * The same code is used in either case to duplicate argv[].
 | 
					 | 
				
			||||||
	 * Some of these decisions could be handled in preprocessing,
 | 
					 | 
				
			||||||
	 * but the code tends to get even uglier, and the penalty for
 | 
					 | 
				
			||||||
	 * deciding at compile- or run-time is tiny.
 | 
					 | 
				
			||||||
	 */
 | 
					 | 
				
			||||||
	char **Argv = NULL;
 | 
					 | 
				
			||||||
	int free_Argv = 0;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if ((sizeof( _Argv) < 8)        /* 32-bit argv[]. */
 | 
					 | 
				
			||||||
# if !defined( VMS_TRUST_ARGV)
 | 
					 | 
				
			||||||
	 || (_Argv[ Argc] != NULL)      /* Untrusted argv[argc] not NULL. */
 | 
					 | 
				
			||||||
# endif
 | 
					 | 
				
			||||||
		)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		int i;
 | 
					 | 
				
			||||||
		Argv = OPENSSL_malloc( (Argc+ 1)* sizeof( char *));
 | 
					 | 
				
			||||||
		if (Argv == NULL)
 | 
					 | 
				
			||||||
			{ ret = -1; goto end; }
 | 
					 | 
				
			||||||
		for(i = 0; i < Argc; i++)
 | 
					 | 
				
			||||||
			Argv[i] = _Argv[i];
 | 
					 | 
				
			||||||
		Argv[ Argc] = NULL;     /* Certain NULL termination. */
 | 
					 | 
				
			||||||
		free_Argv = 1;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	else
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		/* Use the known-good 32-bit argv[] (which needs the
 | 
					 | 
				
			||||||
		 * type cast to satisfy the compiler), or the trusted or
 | 
					 | 
				
			||||||
		 * tested-good 64-bit argv[] as-is. */
 | 
					 | 
				
			||||||
		Argv = (char **)_Argv;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
#endif /* defined( OPENSSL_SYS_VMS) && (__INITIAL_POINTER_SIZE == 64) */
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	arg.data=NULL;
 | 
						arg.data=NULL;
 | 
				
			||||||
	arg.count=0;
 | 
						arg.count=0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -313,19 +257,6 @@ int main(int Argc, char *ARGV[])
 | 
				
			|||||||
		CRYPTO_set_locking_callback(lock_dbg_cb);
 | 
							CRYPTO_set_locking_callback(lock_dbg_cb);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if(getenv("OPENSSL_FIPS")) {
 | 
					 | 
				
			||||||
#ifdef OPENSSL_FIPS
 | 
					 | 
				
			||||||
		if (!FIPS_mode_set(1)) {
 | 
					 | 
				
			||||||
			ERR_load_crypto_strings();
 | 
					 | 
				
			||||||
			ERR_print_errors(BIO_new_fp(stderr,BIO_NOCLOSE));
 | 
					 | 
				
			||||||
			EXIT(1);
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
#else
 | 
					 | 
				
			||||||
		fprintf(stderr, "FIPS mode not supported.\n");
 | 
					 | 
				
			||||||
		EXIT(1);
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	apps_startup();
 | 
						apps_startup();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/* Lets load up our environment a little */
 | 
						/* Lets load up our environment a little */
 | 
				
			||||||
@@ -399,8 +330,7 @@ int main(int Argc, char *ARGV[])
 | 
				
			|||||||
			else	prompt="OpenSSL> ";
 | 
								else	prompt="OpenSSL> ";
 | 
				
			||||||
			fputs(prompt,stdout);
 | 
								fputs(prompt,stdout);
 | 
				
			||||||
			fflush(stdout);
 | 
								fflush(stdout);
 | 
				
			||||||
			if (!fgets(p,n,stdin))
 | 
								fgets(p,n,stdin);
 | 
				
			||||||
				goto end;
 | 
					 | 
				
			||||||
			if (p[0] == '\0') goto end;
 | 
								if (p[0] == '\0') goto end;
 | 
				
			||||||
			i=strlen(p);
 | 
								i=strlen(p);
 | 
				
			||||||
			if (i <= 1) break;
 | 
								if (i <= 1) break;
 | 
				
			||||||
@@ -442,13 +372,6 @@ end:
 | 
				
			|||||||
		BIO_free(bio_err);
 | 
							BIO_free(bio_err);
 | 
				
			||||||
		bio_err=NULL;
 | 
							bio_err=NULL;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
#if defined( OPENSSL_SYS_VMS) && (__INITIAL_POINTER_SIZE == 64)
 | 
					 | 
				
			||||||
	/* Free any duplicate Argv[] storage. */
 | 
					 | 
				
			||||||
	if (free_Argv)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		OPENSSL_free(Argv);
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	OPENSSL_EXIT(ret);
 | 
						OPENSSL_EXIT(ret);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -231,7 +231,7 @@ keyUsage = nonRepudiation, digitalSignature, keyEncipherment
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
subjectKeyIdentifier=hash
 | 
					subjectKeyIdentifier=hash
 | 
				
			||||||
 | 
					
 | 
				
			||||||
authorityKeyIdentifier=keyid:always,issuer
 | 
					authorityKeyIdentifier=keyid:always,issuer:always
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# This is what PKIX recommends but some broken software chokes on critical
 | 
					# This is what PKIX recommends but some broken software chokes on critical
 | 
				
			||||||
# extensions.
 | 
					# extensions.
 | 
				
			||||||
@@ -264,7 +264,7 @@ basicConstraints = CA:true
 | 
				
			|||||||
# Only issuerAltName and authorityKeyIdentifier make any sense in a CRL.
 | 
					# Only issuerAltName and authorityKeyIdentifier make any sense in a CRL.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# issuerAltName=issuer:copy
 | 
					# issuerAltName=issuer:copy
 | 
				
			||||||
authorityKeyIdentifier=keyid:always
 | 
					authorityKeyIdentifier=keyid:always,issuer:always
 | 
				
			||||||
 | 
					
 | 
				
			||||||
[ proxy_cert_ext ]
 | 
					[ proxy_cert_ext ]
 | 
				
			||||||
# These extensions should be added when creating a proxy certificate
 | 
					# These extensions should be added when creating a proxy certificate
 | 
				
			||||||
@@ -297,7 +297,7 @@ nsComment			= "OpenSSL Generated Certificate"
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
# PKIX recommendations harmless if included in all certificates.
 | 
					# PKIX recommendations harmless if included in all certificates.
 | 
				
			||||||
subjectKeyIdentifier=hash
 | 
					subjectKeyIdentifier=hash
 | 
				
			||||||
authorityKeyIdentifier=keyid,issuer
 | 
					authorityKeyIdentifier=keyid,issuer:always
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# This stuff is for subjectAltName and issuerAltname.
 | 
					# This stuff is for subjectAltName and issuerAltname.
 | 
				
			||||||
# Import the email address.
 | 
					# Import the email address.
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -117,7 +117,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
    int ret = 1;
 | 
					    int ret = 1;
 | 
				
			||||||
    int macver = 1;
 | 
					    int macver = 1;
 | 
				
			||||||
    int noprompt = 0;
 | 
					    int noprompt = 0;
 | 
				
			||||||
    STACK_OF(OPENSSL_STRING) *canames = NULL;
 | 
					    STACK_OF(STRING) *canames = NULL;
 | 
				
			||||||
    char *cpass = NULL, *mpass = NULL;
 | 
					    char *cpass = NULL, *mpass = NULL;
 | 
				
			||||||
    char *passargin = NULL, *passargout = NULL, *passarg = NULL;
 | 
					    char *passargin = NULL, *passargout = NULL, *passarg = NULL;
 | 
				
			||||||
    char *passin = NULL, *passout = NULL;
 | 
					    char *passin = NULL, *passout = NULL;
 | 
				
			||||||
@@ -222,8 +222,8 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		} else if (!strcmp (*args, "-caname")) {
 | 
							} else if (!strcmp (*args, "-caname")) {
 | 
				
			||||||
		    if (args[1]) {
 | 
							    if (args[1]) {
 | 
				
			||||||
			args++;	
 | 
								args++;	
 | 
				
			||||||
			if (!canames) canames = sk_OPENSSL_STRING_new_null();
 | 
								if (!canames) canames = sk_STRING_new_null();
 | 
				
			||||||
			sk_OPENSSL_STRING_push(canames, *args);
 | 
								sk_STRING_push(canames, *args);
 | 
				
			||||||
		    } else badarg = 1;
 | 
							    } else badarg = 1;
 | 
				
			||||||
		} else if (!strcmp (*args, "-in")) {
 | 
							} else if (!strcmp (*args, "-in")) {
 | 
				
			||||||
		    if (args[1]) {
 | 
							    if (args[1]) {
 | 
				
			||||||
@@ -549,9 +549,9 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	/* Add any CA names */
 | 
						/* Add any CA names */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	for (i = 0; i < sk_OPENSSL_STRING_num(canames); i++)
 | 
						for (i = 0; i < sk_STRING_num(canames); i++)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		catmp = (unsigned char *)sk_OPENSSL_STRING_value(canames, i);
 | 
							catmp = (unsigned char *)sk_STRING_value(canames, i);
 | 
				
			||||||
		X509_alias_set1(sk_X509_value(certs, i), catmp, -1);
 | 
							X509_alias_set1(sk_X509_value(certs, i), catmp, -1);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -647,7 +647,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    if (!twopass) BUF_strlcpy(macpass, pass, sizeof macpass);
 | 
					    if (!twopass) BUF_strlcpy(macpass, pass, sizeof macpass);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    if ((options & INFO) && p12->mac) BIO_printf (bio_err, "MAC Iteration %ld\n", p12->mac->iter ? ASN1_INTEGER_get (p12->mac->iter) : 1);
 | 
					    if (options & INFO) BIO_printf (bio_err, "MAC Iteration %ld\n", p12->mac->iter ? ASN1_INTEGER_get (p12->mac->iter) : 1);
 | 
				
			||||||
    if(macver) {
 | 
					    if(macver) {
 | 
				
			||||||
#ifdef CRYPTO_MDEBUG
 | 
					#ifdef CRYPTO_MDEBUG
 | 
				
			||||||
    CRYPTO_push_info("verify MAC");
 | 
					    CRYPTO_push_info("verify MAC");
 | 
				
			||||||
@@ -687,7 +687,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
#endif
 | 
					#endif
 | 
				
			||||||
    BIO_free(in);
 | 
					    BIO_free(in);
 | 
				
			||||||
    BIO_free_all(out);
 | 
					    BIO_free_all(out);
 | 
				
			||||||
    if (canames) sk_OPENSSL_STRING_free(canames);
 | 
					    if (canames) sk_STRING_free(canames);
 | 
				
			||||||
    if(passin) OPENSSL_free(passin);
 | 
					    if(passin) OPENSSL_free(passin);
 | 
				
			||||||
    if(passout) OPENSSL_free(passout);
 | 
					    if(passout) OPENSSL_free(passout);
 | 
				
			||||||
    apps_shutdown();
 | 
					    apps_shutdown();
 | 
				
			||||||
@@ -923,7 +923,7 @@ int print_attribs (BIO *out, STACK_OF(X509_ATTRIBUTE) *attrlst,const char *name)
 | 
				
			|||||||
			av = sk_ASN1_TYPE_value(attr->value.set, 0);
 | 
								av = sk_ASN1_TYPE_value(attr->value.set, 0);
 | 
				
			||||||
			switch(av->type) {
 | 
								switch(av->type) {
 | 
				
			||||||
				case V_ASN1_BMPSTRING:
 | 
									case V_ASN1_BMPSTRING:
 | 
				
			||||||
        			value = OPENSSL_uni2asc(av->value.bmpstring->data,
 | 
					        			value = uni2asc(av->value.bmpstring->data,
 | 
				
			||||||
                                	       av->value.bmpstring->length);
 | 
					                                	       av->value.bmpstring->length);
 | 
				
			||||||
				BIO_printf(out, "%s\n", value);
 | 
									BIO_printf(out, "%s\n", value);
 | 
				
			||||||
				OPENSSL_free(value);
 | 
									OPENSSL_free(value);
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -82,6 +82,9 @@ int MAIN(int, char **);
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
int MAIN(int argc, char **argv)
 | 
					int MAIN(int argc, char **argv)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
 | 
					#ifndef OPENSSL_NO_ENGINE
 | 
				
			||||||
 | 
						ENGINE *e = NULL;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
	PKCS7 *p7=NULL;
 | 
						PKCS7 *p7=NULL;
 | 
				
			||||||
	int i,badops=0;
 | 
						int i,badops=0;
 | 
				
			||||||
	BIO *in=NULL,*out=NULL;
 | 
						BIO *in=NULL,*out=NULL;
 | 
				
			||||||
@@ -179,7 +182,7 @@ bad:
 | 
				
			|||||||
	ERR_load_crypto_strings();
 | 
						ERR_load_crypto_strings();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					#ifndef OPENSSL_NO_ENGINE
 | 
				
			||||||
        setup_engine(bio_err, engine, 0);
 | 
					        e = setup_engine(bio_err, engine, 0);
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	in=BIO_new(BIO_s_file());
 | 
						in=BIO_new(BIO_s_file());
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -275,6 +275,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		}
 | 
							}
 | 
				
			||||||
	if (topk8)
 | 
						if (topk8)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
 | 
							BIO_free(in); /* Not needed in this section */
 | 
				
			||||||
		pkey = load_key(bio_err, infile, informat, 1,
 | 
							pkey = load_key(bio_err, infile, informat, 1,
 | 
				
			||||||
			passin, e, "key");
 | 
								passin, e, "key");
 | 
				
			||||||
		if (!pkey)
 | 
							if (!pkey)
 | 
				
			||||||
@@ -403,10 +404,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			BIO_printf(bio_err, "DSA public key include in PrivateKey\n");
 | 
								BIO_printf(bio_err, "DSA public key include in PrivateKey\n");
 | 
				
			||||||
			break;
 | 
								break;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
			case PKCS8_NEG_PRIVKEY:
 | 
					 | 
				
			||||||
			BIO_printf(bio_err, "DSA private key value is negative\n");
 | 
					 | 
				
			||||||
			break;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
			default:
 | 
								default:
 | 
				
			||||||
			BIO_printf(bio_err, "Unknown broken type\n");
 | 
								BIO_printf(bio_err, "Unknown broken type\n");
 | 
				
			||||||
			break;
 | 
								break;
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -74,6 +74,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	EVP_PKEY *pkey=NULL;
 | 
						EVP_PKEY *pkey=NULL;
 | 
				
			||||||
	int badarg = 0;
 | 
						int badarg = 0;
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					#ifndef OPENSSL_NO_ENGINE
 | 
				
			||||||
 | 
						ENGINE *e = NULL;
 | 
				
			||||||
	char *engine=NULL;
 | 
						char *engine=NULL;
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
	int ret = 1;
 | 
						int ret = 1;
 | 
				
			||||||
@@ -140,7 +141,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					#ifndef OPENSSL_NO_ENGINE
 | 
				
			||||||
        setup_engine(bio_err, engine, 0);
 | 
					        e = setup_engine(bio_err, engine, 0);
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (infile)
 | 
						if (infile)
 | 
				
			||||||
@@ -178,7 +179,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	pkey = PEM_read_bio_Parameters(in, NULL);
 | 
						pkey = PEM_read_bio_Parameters(in, NULL);
 | 
				
			||||||
	if (!pkey)
 | 
						if (!pkey)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		BIO_printf(bio_err, "Error reading parameters\n");
 | 
							BIO_printf(bio_err, "Error reading paramters\n");
 | 
				
			||||||
		ERR_print_errors(bio_err);
 | 
							ERR_print_errors(bio_err);
 | 
				
			||||||
		goto end;
 | 
							goto end;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -119,17 +119,17 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		if (!strcmp(*argv,"-in"))
 | 
							if (!strcmp(*argv,"-in"))
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (--argc < 1) badarg = 1;
 | 
								if (--argc < 1) badarg = 1;
 | 
				
			||||||
                        else infile= *(++argv);
 | 
					                        infile= *(++argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else if (!strcmp(*argv,"-out"))
 | 
							else if (!strcmp(*argv,"-out"))
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (--argc < 1) badarg = 1;
 | 
								if (--argc < 1) badarg = 1;
 | 
				
			||||||
			else outfile= *(++argv);
 | 
								outfile= *(++argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else if (!strcmp(*argv,"-sigfile"))
 | 
							else if (!strcmp(*argv,"-sigfile"))
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (--argc < 1) badarg = 1;
 | 
								if (--argc < 1) badarg = 1;
 | 
				
			||||||
			else sigfile= *(++argv);
 | 
								sigfile= *(++argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else if(!strcmp(*argv, "-inkey"))
 | 
							else if(!strcmp(*argv, "-inkey"))
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
@@ -159,17 +159,17 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		else if (!strcmp(*argv,"-passin"))
 | 
							else if (!strcmp(*argv,"-passin"))
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (--argc < 1) badarg = 1;
 | 
								if (--argc < 1) badarg = 1;
 | 
				
			||||||
			else passargin= *(++argv);
 | 
								passargin= *(++argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else if (strcmp(*argv,"-peerform") == 0)
 | 
							else if (strcmp(*argv,"-peerform") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (--argc < 1) badarg = 1;
 | 
								if (--argc < 1) badarg = 1;
 | 
				
			||||||
			else peerform=str2fmt(*(++argv));
 | 
								peerform=str2fmt(*(++argv));
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else if (strcmp(*argv,"-keyform") == 0)
 | 
							else if (strcmp(*argv,"-keyform") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (--argc < 1) badarg = 1;
 | 
								if (--argc < 1) badarg = 1;
 | 
				
			||||||
			else keyform=str2fmt(*(++argv));
 | 
								keyform=str2fmt(*(++argv));
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					#ifndef OPENSSL_NO_ENGINE
 | 
				
			||||||
		else if(!strcmp(*argv, "-engine"))
 | 
							else if(!strcmp(*argv, "-engine"))
 | 
				
			||||||
@@ -390,7 +390,7 @@ static void usage()
 | 
				
			|||||||
	BIO_printf(bio_err, "Usage: pkeyutl [options]\n");
 | 
						BIO_printf(bio_err, "Usage: pkeyutl [options]\n");
 | 
				
			||||||
	BIO_printf(bio_err, "-in file        input file\n");
 | 
						BIO_printf(bio_err, "-in file        input file\n");
 | 
				
			||||||
	BIO_printf(bio_err, "-out file       output file\n");
 | 
						BIO_printf(bio_err, "-out file       output file\n");
 | 
				
			||||||
	BIO_printf(bio_err, "-sigfile file signature file (verify operation only)\n");
 | 
						BIO_printf(bio_err, "-signature file signature file (verify operation only)\n");
 | 
				
			||||||
	BIO_printf(bio_err, "-inkey file     input key\n");
 | 
						BIO_printf(bio_err, "-inkey file     input key\n");
 | 
				
			||||||
	BIO_printf(bio_err, "-keyform arg    private key format - default PEM\n");
 | 
						BIO_printf(bio_err, "-keyform arg    private key format - default PEM\n");
 | 
				
			||||||
	BIO_printf(bio_err, "-pubin          input is a public key\n");
 | 
						BIO_printf(bio_err, "-pubin          input is a public key\n");
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,16 +1,18 @@
 | 
				
			|||||||
-----BEGIN PRIVATE KEY-----
 | 
					-----BEGIN RSA PRIVATE KEY-----
 | 
				
			||||||
MIICdgIBADANBgkqhkiG9w0BAQEFAASCAmAwggJcAgEAAoGBAMo7DFNMqywUA1O/
 | 
					Proc-Type: 4,ENCRYPTED
 | 
				
			||||||
qvWqCOm6rGrUAcR+dKsSXw6y2qiKO7APDDyotc0b4Mxwqjga98npex2RBIwUoCGJ
 | 
					DEK-Info: DES-EDE3-CBC,BA26229A1653B7FF
 | 
				
			||||||
iEmMXo/a8RbXVUZ+ZwcAX7PC+XeXVC5qoajaBBkd2MvYmib/2PqnNrgvhHsUL5dO
 | 
					
 | 
				
			||||||
xhC7cRqxLM/g45k3Yyw+nGa+WkTdAgMBAAECgYBMBT5w4dVG0I8foGFnz+9hzWab
 | 
					6nhWG8PKhTPO/s3ZvjUa6226NlKdvPDZFsNXOOoSUs9ejxpb/aj5huhs6qRYzsz9
 | 
				
			||||||
Ee9IKjE5TcKmB93ilXQyjrWO5+zPmbc7ou6aAKk9IaPCTY1kCyzW7pho7Xdt+RFq
 | 
					Year47uaAZYhGD0vAagnNiBnYmjWEpN9G/wQxG7pgZThK1ZxDi63qn8aQ8UjuGHo
 | 
				
			||||||
TgVXGZZfqtixO7f2/5oqZAkd00eOn9ZrhBpVMu4yXbbDvhDyFe4/oy0HGDjRUhxa
 | 
					F6RpnnBQIAnWTWqr/Qsybtc5EoNkrj/Cpx0OfbSr6gZsFBCxwX1R1hT3/mhJ45f3
 | 
				
			||||||
Lf6ZlBuTherxm4eFkQJBAPBQwRs9UtqaMAQlagA9pV5UsQjV1WT4IxDURMPfXgCd
 | 
					XMofY32Vdfx9/vtw1O7HmlHXQnXaqnbd9/nn1EpvFJG9+UjPoW7gV4jCOLuR4deE
 | 
				
			||||||
ETNkB6pP0SmxQm5xhv9N2HY1UtoWpug9s0OU5IJB15sCQQDXbfbjiujNbuOxCFNw
 | 
					jS8hm+cpkwXmFtk3VGjT9tQXPpMv3JpYfBqgGQoMAJ5Toq0DWcHi6Wg08PsD8lgy
 | 
				
			||||||
68JZaCFVdNovyOWORkpenQLNEjVkmTCS9OayK09ADEYtsdpUGKeF+2EYBNkFr5px
 | 
					vmTioPsRg+JGkJkJ8GnusgLpQdlQJbjzd7wGE6ElUFLfOxLo8bLlRHoriHNdWYhh
 | 
				
			||||||
CajnAkBMYI4PNz1HBuwt1SpMa0tMoMQnV7bbwVV7usskKbC5pzHZUHhzM6z5gEHp
 | 
					JjY0LyeTkovcmWxVjImc6ZyBz5Ly4t0BYf1gq3OkjsV91Q1taBxnhiavfizqMCAf
 | 
				
			||||||
0iEisT4Ty7zKXZqsgzefSgoaMAzzAkEAoCIaUhtwXzwdPfvNYnOs3J6doJMimECB
 | 
					PPB3sLQnlXG77TOXkNxpqbZfEYrVZW2Nsqqdn8s07Uj4IMONZyq2odYKWFPMJBiM
 | 
				
			||||||
+lbfcyLM8TimvadtRt+KGEg/OYGmLNM2UiqdY+duzdbUpvhYGcwvYwJAQvaoi9z2
 | 
					POYwXjMAOcmFMTHYsVlhcUJuV6LOuipw/FEbTtPH/MYMxLe4zx65dYo1rb4iLKLS
 | 
				
			||||||
CkiwSs/PFrLaNlfLJmXRsUBzmiWYoh6+IQJJorEXz7ewI72ee9RBO4s746cgUFwH
 | 
					gMtB0o/Wl4Xno3ZXh1ucicYnV2J7NpVcjVq+3SFiCRu2SrSkZHZ23EPS13Ec6fcz
 | 
				
			||||||
Ri+qO+HhZFUBqQ==
 | 
					8X/YGA2vTJ8MAOozAzQUwHQYvLk7bIoQVekqDq4p0AZQbhdspHpArCk0Ifqqzg/v
 | 
				
			||||||
-----END PRIVATE KEY-----
 | 
					Uyky/zZiQYanzDenTSRVI/8wac3olxpU8QvbySxYqmbkgq6bTpXJfYFQfnAttEsC
 | 
				
			||||||
 | 
					dA4S5UFgyOPZluxCAM4yaJF3Ft6neutNwftuJQMbgCUi9vYg2tGdSw==
 | 
				
			||||||
 | 
					-----END RSA PRIVATE KEY-----
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -44,7 +44,6 @@ extern int smime_main(int argc,char *argv[]);
 | 
				
			|||||||
extern int rand_main(int argc,char *argv[]);
 | 
					extern int rand_main(int argc,char *argv[]);
 | 
				
			||||||
extern int engine_main(int argc,char *argv[]);
 | 
					extern int engine_main(int argc,char *argv[]);
 | 
				
			||||||
extern int ocsp_main(int argc,char *argv[]);
 | 
					extern int ocsp_main(int argc,char *argv[]);
 | 
				
			||||||
extern int srp_main(int argc,char *argv[]);
 | 
					 | 
				
			||||||
extern int prime_main(int argc,char *argv[]);
 | 
					extern int prime_main(int argc,char *argv[]);
 | 
				
			||||||
extern int ts_main(int argc,char *argv[]);
 | 
					extern int ts_main(int argc,char *argv[]);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -143,12 +142,7 @@ FUNCTION functions[] = {
 | 
				
			|||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					#ifndef OPENSSL_NO_ENGINE
 | 
				
			||||||
	{FUNC_TYPE_GENERAL,"engine",engine_main},
 | 
						{FUNC_TYPE_GENERAL,"engine",engine_main},
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
#ifndef OPENSSL_NO_OCSP
 | 
					 | 
				
			||||||
	{FUNC_TYPE_GENERAL,"ocsp",ocsp_main},
 | 
						{FUNC_TYPE_GENERAL,"ocsp",ocsp_main},
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
#ifndef OPENSSL_NO_SRP
 | 
					 | 
				
			||||||
	{FUNC_TYPE_GENERAL,"srp",srp_main},
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	{FUNC_TYPE_GENERAL,"prime",prime_main},
 | 
						{FUNC_TYPE_GENERAL,"prime",prime_main},
 | 
				
			||||||
	{FUNC_TYPE_GENERAL,"ts",ts_main},
 | 
						{FUNC_TYPE_GENERAL,"ts",ts_main},
 | 
				
			||||||
#ifndef OPENSSL_NO_MD2
 | 
					#ifndef OPENSSL_NO_MD2
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -22,7 +22,6 @@ typedef struct {
 | 
				
			|||||||
	const char *name;
 | 
						const char *name;
 | 
				
			||||||
	int (*func)(int argc,char *argv[]);
 | 
						int (*func)(int argc,char *argv[]);
 | 
				
			||||||
	} FUNCTION;
 | 
						} FUNCTION;
 | 
				
			||||||
DECLARE_LHASH_OF(FUNCTION);
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
FUNCTION functions[] = {
 | 
					FUNCTION functions[] = {
 | 
				
			||||||
EOF
 | 
					EOF
 | 
				
			||||||
@@ -49,8 +48,6 @@ foreach (@ARGV)
 | 
				
			|||||||
		{ print "#if !defined(OPENSSL_NO_DES) && !defined(OPENSSL_NO_SHA1)\n${str}#endif\n"; }
 | 
							{ print "#if !defined(OPENSSL_NO_DES) && !defined(OPENSSL_NO_SHA1)\n${str}#endif\n"; }
 | 
				
			||||||
	elsif ( ($_ =~ /^cms$/))
 | 
						elsif ( ($_ =~ /^cms$/))
 | 
				
			||||||
		{ print "#ifndef OPENSSL_NO_CMS\n${str}#endif\n"; }
 | 
							{ print "#ifndef OPENSSL_NO_CMS\n${str}#endif\n"; }
 | 
				
			||||||
	elsif ( ($_ =~ /^ocsp$/))
 | 
					 | 
				
			||||||
		{ print "#ifndef OPENSSL_NO_OCSP\n${str}#endif\n"; }
 | 
					 | 
				
			||||||
	else
 | 
						else
 | 
				
			||||||
		{ print $str; }
 | 
							{ print $str; }
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -77,6 +77,9 @@ int MAIN(int, char **);
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
int MAIN(int argc, char **argv)
 | 
					int MAIN(int argc, char **argv)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
 | 
					#ifndef OPENSSL_NO_ENGINE
 | 
				
			||||||
 | 
						ENGINE *e = NULL;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
	int i, r, ret = 1;
 | 
						int i, r, ret = 1;
 | 
				
			||||||
	int badopt;
 | 
						int badopt;
 | 
				
			||||||
	char *outfile = NULL;
 | 
						char *outfile = NULL;
 | 
				
			||||||
@@ -175,7 +178,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					#ifndef OPENSSL_NO_ENGINE
 | 
				
			||||||
        setup_engine(bio_err, engine, 0);
 | 
					        e = setup_engine(bio_err, engine, 0);
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	app_RAND_load_file(NULL, bio_err, (inrand != NULL));
 | 
						app_RAND_load_file(NULL, bio_err, (inrand != NULL));
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										121
									
								
								apps/req.c
									
									
									
									
									
								
							
							
						
						
									
										121
									
								
								apps/req.c
									
									
									
									
									
								
							@@ -165,7 +165,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	EVP_PKEY_CTX *genctx = NULL;
 | 
						EVP_PKEY_CTX *genctx = NULL;
 | 
				
			||||||
	const char *keyalg = NULL;
 | 
						const char *keyalg = NULL;
 | 
				
			||||||
	char *keyalgstr = NULL;
 | 
						char *keyalgstr = NULL;
 | 
				
			||||||
	STACK_OF(OPENSSL_STRING) *pkeyopts = NULL, *sigopts = NULL;
 | 
						STACK_OF(STRING) *pkeyopts = NULL;
 | 
				
			||||||
	EVP_PKEY *pkey=NULL;
 | 
						EVP_PKEY *pkey=NULL;
 | 
				
			||||||
	int i=0,badops=0,newreq=0,verbose=0,pkey_type=-1;
 | 
						int i=0,badops=0,newreq=0,verbose=0,pkey_type=-1;
 | 
				
			||||||
	long newkey = -1;
 | 
						long newkey = -1;
 | 
				
			||||||
@@ -306,17 +306,8 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			if (--argc < 1)
 | 
								if (--argc < 1)
 | 
				
			||||||
				goto bad;
 | 
									goto bad;
 | 
				
			||||||
			if (!pkeyopts)
 | 
								if (!pkeyopts)
 | 
				
			||||||
				pkeyopts = sk_OPENSSL_STRING_new_null();
 | 
									pkeyopts = sk_STRING_new_null();
 | 
				
			||||||
			if (!pkeyopts || !sk_OPENSSL_STRING_push(pkeyopts, *(++argv)))
 | 
								if (!pkeyopts || !sk_STRING_push(pkeyopts, *(++argv)))
 | 
				
			||||||
				goto bad;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-sigopt") == 0)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if (--argc < 1)
 | 
					 | 
				
			||||||
				goto bad;
 | 
					 | 
				
			||||||
			if (!sigopts)
 | 
					 | 
				
			||||||
				sigopts = sk_OPENSSL_STRING_new_null();
 | 
					 | 
				
			||||||
			if (!sigopts || !sk_OPENSSL_STRING_push(sigopts, *(++argv)))
 | 
					 | 
				
			||||||
				goto bad;
 | 
									goto bad;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else if (strcmp(*argv,"-batch") == 0)
 | 
							else if (strcmp(*argv,"-batch") == 0)
 | 
				
			||||||
@@ -374,6 +365,11 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			serial = s2i_ASN1_INTEGER(NULL, *(++argv));
 | 
								serial = s2i_ASN1_INTEGER(NULL, *(++argv));
 | 
				
			||||||
			if (!serial) goto bad;
 | 
								if (!serial) goto bad;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
 | 
							else if ((md_alg=EVP_get_digestbyname(&((*argv)[1]))) != NULL)
 | 
				
			||||||
 | 
								{
 | 
				
			||||||
 | 
								/* ok */
 | 
				
			||||||
 | 
								digest=md_alg;
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
		else if (strcmp(*argv,"-extensions") == 0)
 | 
							else if (strcmp(*argv,"-extensions") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
@@ -384,11 +380,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
			req_exts = *(++argv);
 | 
								req_exts = *(++argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else if ((md_alg=EVP_get_digestbyname(&((*argv)[1]))) != NULL)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			/* ok */
 | 
					 | 
				
			||||||
			digest=md_alg;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		else
 | 
							else
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			BIO_printf(bio_err,"unknown option %s\n",*argv);
 | 
								BIO_printf(bio_err,"unknown option %s\n",*argv);
 | 
				
			||||||
@@ -676,9 +667,9 @@ bad:
 | 
				
			|||||||
		if (pkeyopts)
 | 
							if (pkeyopts)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			char *genopt;
 | 
								char *genopt;
 | 
				
			||||||
			for (i = 0; i < sk_OPENSSL_STRING_num(pkeyopts); i++)
 | 
								for (i = 0; i < sk_STRING_num(pkeyopts); i++)
 | 
				
			||||||
				{
 | 
									{
 | 
				
			||||||
				genopt = sk_OPENSSL_STRING_value(pkeyopts, i);
 | 
									genopt = sk_STRING_value(pkeyopts, i);
 | 
				
			||||||
				if (pkey_ctrl_string(genctx, genopt) <= 0)
 | 
									if (pkey_ctrl_string(genctx, genopt) <= 0)
 | 
				
			||||||
					{
 | 
										{
 | 
				
			||||||
					BIO_printf(bio_err,
 | 
										BIO_printf(bio_err,
 | 
				
			||||||
@@ -867,9 +858,8 @@ loop:
 | 
				
			|||||||
					extensions);
 | 
										extensions);
 | 
				
			||||||
				goto end;
 | 
									goto end;
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
 | 
								
 | 
				
			||||||
			i=do_X509_sign(bio_err, x509ss, pkey, digest, sigopts);
 | 
								if (!(i=X509_sign(x509ss,pkey,digest)))
 | 
				
			||||||
			if (!i)
 | 
					 | 
				
			||||||
				{
 | 
									{
 | 
				
			||||||
				ERR_print_errors(bio_err);
 | 
									ERR_print_errors(bio_err);
 | 
				
			||||||
				goto end;
 | 
									goto end;
 | 
				
			||||||
@@ -893,8 +883,7 @@ loop:
 | 
				
			|||||||
					req_exts);
 | 
										req_exts);
 | 
				
			||||||
				goto end;
 | 
									goto end;
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
			i=do_X509_REQ_sign(bio_err, req, pkey, digest, sigopts);
 | 
								if (!(i=X509_REQ_sign(req,pkey,digest)))
 | 
				
			||||||
			if (!i)
 | 
					 | 
				
			||||||
				{
 | 
									{
 | 
				
			||||||
				ERR_print_errors(bio_err);
 | 
									ERR_print_errors(bio_err);
 | 
				
			||||||
				goto end;
 | 
									goto end;
 | 
				
			||||||
@@ -1094,9 +1083,7 @@ end:
 | 
				
			|||||||
	if (genctx)
 | 
						if (genctx)
 | 
				
			||||||
		EVP_PKEY_CTX_free(genctx);
 | 
							EVP_PKEY_CTX_free(genctx);
 | 
				
			||||||
	if (pkeyopts)
 | 
						if (pkeyopts)
 | 
				
			||||||
		sk_OPENSSL_STRING_free(pkeyopts);
 | 
							sk_STRING_free(pkeyopts);
 | 
				
			||||||
	if (sigopts)
 | 
					 | 
				
			||||||
		sk_OPENSSL_STRING_free(sigopts);
 | 
					 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					#ifndef OPENSSL_NO_ENGINE
 | 
				
			||||||
	if (gen_eng)
 | 
						if (gen_eng)
 | 
				
			||||||
		ENGINE_free(gen_eng);
 | 
							ENGINE_free(gen_eng);
 | 
				
			||||||
@@ -1349,17 +1336,11 @@ start2:			for (;;)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
				BIO_snprintf(buf,sizeof buf,"%s_min",type);
 | 
									BIO_snprintf(buf,sizeof buf,"%s_min",type);
 | 
				
			||||||
				if (!NCONF_get_number(req_conf,attr_sect,buf, &n_min))
 | 
									if (!NCONF_get_number(req_conf,attr_sect,buf, &n_min))
 | 
				
			||||||
					{
 | 
					 | 
				
			||||||
					ERR_clear_error();
 | 
					 | 
				
			||||||
					n_min = -1;
 | 
										n_min = -1;
 | 
				
			||||||
					}
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
				BIO_snprintf(buf,sizeof buf,"%s_max",type);
 | 
									BIO_snprintf(buf,sizeof buf,"%s_max",type);
 | 
				
			||||||
				if (!NCONF_get_number(req_conf,attr_sect,buf, &n_max))
 | 
									if (!NCONF_get_number(req_conf,attr_sect,buf, &n_max))
 | 
				
			||||||
					{
 | 
					 | 
				
			||||||
					ERR_clear_error();
 | 
					 | 
				
			||||||
					n_max = -1;
 | 
										n_max = -1;
 | 
				
			||||||
					}
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
				if (!add_attribute_object(req,
 | 
									if (!add_attribute_object(req,
 | 
				
			||||||
					v->value,def,value,nid,n_min,n_max, chtype))
 | 
										v->value,def,value,nid,n_min,n_max, chtype))
 | 
				
			||||||
@@ -1460,8 +1441,7 @@ start:
 | 
				
			|||||||
		buf[0]='\0';
 | 
							buf[0]='\0';
 | 
				
			||||||
		if (!batch)
 | 
							if (!batch)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (!fgets(buf,sizeof buf,stdin))
 | 
								fgets(buf,sizeof buf,stdin);
 | 
				
			||||||
				return 0;
 | 
					 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else
 | 
							else
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
@@ -1519,8 +1499,7 @@ start:
 | 
				
			|||||||
		buf[0]='\0';
 | 
							buf[0]='\0';
 | 
				
			||||||
		if (!batch)
 | 
							if (!batch)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (!fgets(buf,sizeof buf,stdin))
 | 
								fgets(buf,sizeof buf,stdin);
 | 
				
			||||||
				return 0;
 | 
					 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else
 | 
							else
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
@@ -1736,7 +1715,7 @@ static EVP_PKEY_CTX *set_keygen_ctx(BIO *err, const char *gstr, int *pkey_type,
 | 
				
			|||||||
		ERR_print_errors(err);
 | 
							ERR_print_errors(err);
 | 
				
			||||||
		return NULL;
 | 
							return NULL;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
#ifndef OPENSSL_NO_RSA
 | 
					
 | 
				
			||||||
	if ((*pkey_type == EVP_PKEY_RSA) && (keylen != -1))
 | 
						if ((*pkey_type == EVP_PKEY_RSA) && (keylen != -1))
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		if (EVP_PKEY_CTX_set_rsa_keygen_bits(gctx, keylen) <= 0)
 | 
							if (EVP_PKEY_CTX_set_rsa_keygen_bits(gctx, keylen) <= 0)
 | 
				
			||||||
@@ -1747,7 +1726,6 @@ static EVP_PKEY_CTX *set_keygen_ctx(BIO *err, const char *gstr, int *pkey_type,
 | 
				
			|||||||
			return NULL;
 | 
								return NULL;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	return gctx;
 | 
						return gctx;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
@@ -1769,68 +1747,3 @@ static int genpkey_cb(EVP_PKEY_CTX *ctx)
 | 
				
			|||||||
#endif
 | 
					#endif
 | 
				
			||||||
	return 1;
 | 
						return 1;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					 | 
				
			||||||
static int do_sign_init(BIO *err, EVP_MD_CTX *ctx, EVP_PKEY *pkey,
 | 
					 | 
				
			||||||
			const EVP_MD *md, STACK_OF(OPENSSL_STRING) *sigopts)
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	EVP_PKEY_CTX *pkctx = NULL;
 | 
					 | 
				
			||||||
	int i;
 | 
					 | 
				
			||||||
	EVP_MD_CTX_init(ctx);
 | 
					 | 
				
			||||||
	if (!EVP_DigestSignInit(ctx, &pkctx, md, NULL, pkey))
 | 
					 | 
				
			||||||
		return 0;
 | 
					 | 
				
			||||||
	for (i = 0; i < sk_OPENSSL_STRING_num(sigopts); i++)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		char *sigopt = sk_OPENSSL_STRING_value(sigopts, i);
 | 
					 | 
				
			||||||
		if (pkey_ctrl_string(pkctx, sigopt) <= 0)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			BIO_printf(err, "parameter error \"%s\"\n", sigopt);
 | 
					 | 
				
			||||||
			ERR_print_errors(bio_err);
 | 
					 | 
				
			||||||
			return 0;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	return 1;
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
int do_X509_sign(BIO *err, X509 *x, EVP_PKEY *pkey, const EVP_MD *md,
 | 
					 | 
				
			||||||
			STACK_OF(OPENSSL_STRING) *sigopts)
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	int rv;
 | 
					 | 
				
			||||||
	EVP_MD_CTX mctx;
 | 
					 | 
				
			||||||
	EVP_MD_CTX_init(&mctx);
 | 
					 | 
				
			||||||
	rv = do_sign_init(err, &mctx, pkey, md, sigopts);
 | 
					 | 
				
			||||||
	if (rv > 0)
 | 
					 | 
				
			||||||
		rv = X509_sign_ctx(x, &mctx);
 | 
					 | 
				
			||||||
	EVP_MD_CTX_cleanup(&mctx);
 | 
					 | 
				
			||||||
	return rv > 0 ? 1 : 0;
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
int do_X509_REQ_sign(BIO *err, X509_REQ *x, EVP_PKEY *pkey, const EVP_MD *md,
 | 
					 | 
				
			||||||
			STACK_OF(OPENSSL_STRING) *sigopts)
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	int rv;
 | 
					 | 
				
			||||||
	EVP_MD_CTX mctx;
 | 
					 | 
				
			||||||
	EVP_MD_CTX_init(&mctx);
 | 
					 | 
				
			||||||
	rv = do_sign_init(err, &mctx, pkey, md, sigopts);
 | 
					 | 
				
			||||||
	if (rv > 0)
 | 
					 | 
				
			||||||
		rv = X509_REQ_sign_ctx(x, &mctx);
 | 
					 | 
				
			||||||
	EVP_MD_CTX_cleanup(&mctx);
 | 
					 | 
				
			||||||
	return rv > 0 ? 1 : 0;
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
		
 | 
					 | 
				
			||||||
	
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
int do_X509_CRL_sign(BIO *err, X509_CRL *x, EVP_PKEY *pkey, const EVP_MD *md,
 | 
					 | 
				
			||||||
			STACK_OF(OPENSSL_STRING) *sigopts)
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	int rv;
 | 
					 | 
				
			||||||
	EVP_MD_CTX mctx;
 | 
					 | 
				
			||||||
	EVP_MD_CTX_init(&mctx);
 | 
					 | 
				
			||||||
	rv = do_sign_init(err, &mctx, pkey, md, sigopts);
 | 
					 | 
				
			||||||
	if (rv > 0)
 | 
					 | 
				
			||||||
		rv = X509_CRL_sign_ctx(x, &mctx);
 | 
					 | 
				
			||||||
	EVP_MD_CTX_cleanup(&mctx);
 | 
					 | 
				
			||||||
	return rv > 0 ? 1 : 0;
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
		
 | 
					 | 
				
			||||||
	
 | 
					 | 
				
			||||||
 
 | 
				
			|||||||
@@ -409,7 +409,6 @@ bad:
 | 
				
			|||||||
			}
 | 
								}
 | 
				
			||||||
		else i=PEM_write_bio_RSAPrivateKey(out,rsa,
 | 
							else i=PEM_write_bio_RSAPrivateKey(out,rsa,
 | 
				
			||||||
						enc,NULL,0,NULL,passout);
 | 
											enc,NULL,0,NULL,passout);
 | 
				
			||||||
#if !defined(OPENSSL_NO_DSA) && !defined(OPENSSL_NO_RC4)
 | 
					 | 
				
			||||||
	} else if (outformat == FORMAT_MSBLOB || outformat == FORMAT_PVK) {
 | 
						} else if (outformat == FORMAT_MSBLOB || outformat == FORMAT_PVK) {
 | 
				
			||||||
		EVP_PKEY *pk;
 | 
							EVP_PKEY *pk;
 | 
				
			||||||
		pk = EVP_PKEY_new();
 | 
							pk = EVP_PKEY_new();
 | 
				
			||||||
@@ -421,12 +420,11 @@ bad:
 | 
				
			|||||||
		else
 | 
							else
 | 
				
			||||||
			i = i2b_PrivateKey_bio(out, pk);
 | 
								i = i2b_PrivateKey_bio(out, pk);
 | 
				
			||||||
		EVP_PKEY_free(pk);
 | 
							EVP_PKEY_free(pk);
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	} else	{
 | 
						} else	{
 | 
				
			||||||
		BIO_printf(bio_err,"bad output format specified for outfile\n");
 | 
							BIO_printf(bio_err,"bad output format specified for outfile\n");
 | 
				
			||||||
		goto end;
 | 
							goto end;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	if (i <= 0)
 | 
						if (!i)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		BIO_printf(bio_err,"unable to write key\n");
 | 
							BIO_printf(bio_err,"unable to write key\n");
 | 
				
			||||||
		ERR_print_errors(bio_err);
 | 
							ERR_print_errors(bio_err);
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -342,10 +342,4 @@ static void usage()
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#else /* !OPENSSL_NO_RSA */
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# if PEDANTIC
 | 
					 | 
				
			||||||
static void *dummy=&dummy;
 | 
					 | 
				
			||||||
# endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -171,6 +171,3 @@ void MS_CALLBACK tlsext_cb(SSL *s, int client_server, int type,
 | 
				
			|||||||
					unsigned char *data, int len,
 | 
										unsigned char *data, int len,
 | 
				
			||||||
					void *arg);
 | 
										void *arg);
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					 | 
				
			||||||
int MS_CALLBACK generate_cookie_callback(SSL *ssl, unsigned char *cookie, unsigned int *cookie_len);
 | 
					 | 
				
			||||||
int MS_CALLBACK verify_cookie_callback(SSL *ssl, unsigned char *cookie, unsigned int cookie_len);
 | 
					 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										229
									
								
								apps/s_cb.c
									
									
									
									
									
								
							
							
						
						
									
										229
									
								
								apps/s_cb.c
									
									
									
									
									
								
							@@ -117,21 +117,17 @@
 | 
				
			|||||||
#undef NON_MAIN
 | 
					#undef NON_MAIN
 | 
				
			||||||
#undef USE_SOCKETS
 | 
					#undef USE_SOCKETS
 | 
				
			||||||
#include <openssl/err.h>
 | 
					#include <openssl/err.h>
 | 
				
			||||||
#include <openssl/rand.h>
 | 
					 | 
				
			||||||
#include <openssl/x509.h>
 | 
					#include <openssl/x509.h>
 | 
				
			||||||
#include <openssl/ssl.h>
 | 
					#include <openssl/ssl.h>
 | 
				
			||||||
#include "s_apps.h"
 | 
					#include "s_apps.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define	COOKIE_SECRET_LENGTH	16
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
int verify_depth=0;
 | 
					int verify_depth=0;
 | 
				
			||||||
int verify_error=X509_V_OK;
 | 
					int verify_error=X509_V_OK;
 | 
				
			||||||
int verify_return_error=0;
 | 
					int verify_return_error=0;
 | 
				
			||||||
unsigned char cookie_secret[COOKIE_SECRET_LENGTH];
 | 
					 | 
				
			||||||
int cookie_initialized=0;
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
int MS_CALLBACK verify_callback(int ok, X509_STORE_CTX *ctx)
 | 
					int MS_CALLBACK verify_callback(int ok, X509_STORE_CTX *ctx)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
 | 
						char buf[256];
 | 
				
			||||||
	X509 *err_cert;
 | 
						X509 *err_cert;
 | 
				
			||||||
	int err,depth;
 | 
						int err,depth;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -139,15 +135,8 @@ int MS_CALLBACK verify_callback(int ok, X509_STORE_CTX *ctx)
 | 
				
			|||||||
	err=	X509_STORE_CTX_get_error(ctx);
 | 
						err=	X509_STORE_CTX_get_error(ctx);
 | 
				
			||||||
	depth=	X509_STORE_CTX_get_error_depth(ctx);
 | 
						depth=	X509_STORE_CTX_get_error_depth(ctx);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	BIO_printf(bio_err,"depth=%d ",depth);
 | 
						X509_NAME_oneline(X509_get_subject_name(err_cert),buf,sizeof buf);
 | 
				
			||||||
	if (err_cert)
 | 
						BIO_printf(bio_err,"depth=%d %s\n",depth,buf);
 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		X509_NAME_print_ex(bio_err, X509_get_subject_name(err_cert),
 | 
					 | 
				
			||||||
					0, XN_FLAG_ONELINE);
 | 
					 | 
				
			||||||
		BIO_puts(bio_err, "\n");
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	else
 | 
					 | 
				
			||||||
		BIO_puts(bio_err, "<no cert>\n");
 | 
					 | 
				
			||||||
	if (!ok)
 | 
						if (!ok)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		BIO_printf(bio_err,"verify error:num=%d:%s\n",err,
 | 
							BIO_printf(bio_err,"verify error:num=%d:%s\n",err,
 | 
				
			||||||
@@ -164,33 +153,25 @@ int MS_CALLBACK verify_callback(int ok, X509_STORE_CTX *ctx)
 | 
				
			|||||||
			verify_error=X509_V_ERR_CERT_CHAIN_TOO_LONG;
 | 
								verify_error=X509_V_ERR_CERT_CHAIN_TOO_LONG;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	switch (err)
 | 
						switch (ctx->error)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
	case X509_V_ERR_UNABLE_TO_GET_ISSUER_CERT:
 | 
						case X509_V_ERR_UNABLE_TO_GET_ISSUER_CERT:
 | 
				
			||||||
		BIO_puts(bio_err,"issuer= ");
 | 
							X509_NAME_oneline(X509_get_issuer_name(ctx->current_cert),buf,sizeof buf);
 | 
				
			||||||
		X509_NAME_print_ex(bio_err, X509_get_issuer_name(err_cert),
 | 
							BIO_printf(bio_err,"issuer= %s\n",buf);
 | 
				
			||||||
					0, XN_FLAG_ONELINE);
 | 
					 | 
				
			||||||
		BIO_puts(bio_err, "\n");
 | 
					 | 
				
			||||||
		break;
 | 
							break;
 | 
				
			||||||
	case X509_V_ERR_CERT_NOT_YET_VALID:
 | 
						case X509_V_ERR_CERT_NOT_YET_VALID:
 | 
				
			||||||
	case X509_V_ERR_ERROR_IN_CERT_NOT_BEFORE_FIELD:
 | 
						case X509_V_ERR_ERROR_IN_CERT_NOT_BEFORE_FIELD:
 | 
				
			||||||
		BIO_printf(bio_err,"notBefore=");
 | 
							BIO_printf(bio_err,"notBefore=");
 | 
				
			||||||
		ASN1_TIME_print(bio_err,X509_get_notBefore(err_cert));
 | 
							ASN1_TIME_print(bio_err,X509_get_notBefore(ctx->current_cert));
 | 
				
			||||||
		BIO_printf(bio_err,"\n");
 | 
							BIO_printf(bio_err,"\n");
 | 
				
			||||||
		break;
 | 
							break;
 | 
				
			||||||
	case X509_V_ERR_CERT_HAS_EXPIRED:
 | 
						case X509_V_ERR_CERT_HAS_EXPIRED:
 | 
				
			||||||
	case X509_V_ERR_ERROR_IN_CERT_NOT_AFTER_FIELD:
 | 
						case X509_V_ERR_ERROR_IN_CERT_NOT_AFTER_FIELD:
 | 
				
			||||||
		BIO_printf(bio_err,"notAfter=");
 | 
							BIO_printf(bio_err,"notAfter=");
 | 
				
			||||||
		ASN1_TIME_print(bio_err,X509_get_notAfter(err_cert));
 | 
							ASN1_TIME_print(bio_err,X509_get_notAfter(ctx->current_cert));
 | 
				
			||||||
		BIO_printf(bio_err,"\n");
 | 
							BIO_printf(bio_err,"\n");
 | 
				
			||||||
		break;
 | 
							break;
 | 
				
			||||||
	case X509_V_ERR_NO_EXPLICIT_POLICY:
 | 
					 | 
				
			||||||
		policies_print(bio_err, ctx);
 | 
					 | 
				
			||||||
		break;
 | 
					 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	if (err == X509_V_OK && ok == 2)
 | 
					 | 
				
			||||||
		policies_print(bio_err, ctx);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	BIO_printf(bio_err,"verify return:%d\n",ok);
 | 
						BIO_printf(bio_err,"verify return:%d\n",ok);
 | 
				
			||||||
	return(ok);
 | 
						return(ok);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
@@ -357,15 +338,6 @@ void MS_CALLBACK msg_cb(int write_p, int version, int content_type, const void *
 | 
				
			|||||||
	case TLS1_VERSION:
 | 
						case TLS1_VERSION:
 | 
				
			||||||
		str_version = "TLS 1.0 ";
 | 
							str_version = "TLS 1.0 ";
 | 
				
			||||||
		break;
 | 
							break;
 | 
				
			||||||
	case TLS1_1_VERSION:
 | 
					 | 
				
			||||||
		str_version = "TLS 1.1 ";
 | 
					 | 
				
			||||||
		break;
 | 
					 | 
				
			||||||
	case DTLS1_VERSION:
 | 
					 | 
				
			||||||
		str_version = "DTLS 1.0 ";
 | 
					 | 
				
			||||||
		break;
 | 
					 | 
				
			||||||
	case DTLS1_BAD_VER:
 | 
					 | 
				
			||||||
		str_version = "DTLS 1.0 (bad) ";
 | 
					 | 
				
			||||||
		break;
 | 
					 | 
				
			||||||
	default:
 | 
						default:
 | 
				
			||||||
		str_version = "???";
 | 
							str_version = "???";
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
@@ -431,10 +403,7 @@ void MS_CALLBACK msg_cb(int write_p, int version, int content_type, const void *
 | 
				
			|||||||
			}
 | 
								}
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (version == SSL3_VERSION ||
 | 
						if (version == SSL3_VERSION || version == TLS1_VERSION)
 | 
				
			||||||
	    version == TLS1_VERSION ||
 | 
					 | 
				
			||||||
	    version == DTLS1_VERSION ||
 | 
					 | 
				
			||||||
	    version == DTLS1_BAD_VER)
 | 
					 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		switch (content_type)
 | 
							switch (content_type)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
@@ -573,9 +542,6 @@ void MS_CALLBACK msg_cb(int write_p, int version, int content_type, const void *
 | 
				
			|||||||
				case 2:
 | 
									case 2:
 | 
				
			||||||
					str_details1 = ", ServerHello";
 | 
										str_details1 = ", ServerHello";
 | 
				
			||||||
					break;
 | 
										break;
 | 
				
			||||||
				case 3:
 | 
					 | 
				
			||||||
					str_details1 = ", HelloVerifyRequest";
 | 
					 | 
				
			||||||
					break;
 | 
					 | 
				
			||||||
				case 11:
 | 
									case 11:
 | 
				
			||||||
					str_details1 = ", Certificate";
 | 
										str_details1 = ", Certificate";
 | 
				
			||||||
					break;
 | 
										break;
 | 
				
			||||||
@@ -672,14 +638,6 @@ void MS_CALLBACK tlsext_cb(SSL *s, int client_server, int type,
 | 
				
			|||||||
		extname = "server ticket";
 | 
							extname = "server ticket";
 | 
				
			||||||
		break;
 | 
							break;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		case TLSEXT_TYPE_renegotiate:
 | 
					 | 
				
			||||||
		extname = "renegotiate";
 | 
					 | 
				
			||||||
		break;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		case TLSEXT_TYPE_signature_algorithms:
 | 
					 | 
				
			||||||
		extname = "signature algorithms";
 | 
					 | 
				
			||||||
		break;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifdef TLSEXT_TYPE_opaque_prf_input
 | 
					#ifdef TLSEXT_TYPE_opaque_prf_input
 | 
				
			||||||
		case TLSEXT_TYPE_opaque_prf_input:
 | 
							case TLSEXT_TYPE_opaque_prf_input:
 | 
				
			||||||
		extname = "opaque PRF input";
 | 
							extname = "opaque PRF input";
 | 
				
			||||||
@@ -698,172 +656,3 @@ void MS_CALLBACK tlsext_cb(SSL *s, int client_server, int type,
 | 
				
			|||||||
	BIO_dump(bio, (char *)data, len);
 | 
						BIO_dump(bio, (char *)data, len);
 | 
				
			||||||
	(void)BIO_flush(bio);
 | 
						(void)BIO_flush(bio);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					 | 
				
			||||||
int MS_CALLBACK generate_cookie_callback(SSL *ssl, unsigned char *cookie, unsigned int *cookie_len)
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	unsigned char *buffer, result[EVP_MAX_MD_SIZE];
 | 
					 | 
				
			||||||
	unsigned int length, resultlength;
 | 
					 | 
				
			||||||
	union {
 | 
					 | 
				
			||||||
		struct sockaddr sa;
 | 
					 | 
				
			||||||
		struct sockaddr_in s4;
 | 
					 | 
				
			||||||
#if OPENSSL_USE_IPV6
 | 
					 | 
				
			||||||
		struct sockaddr_in6 s6;
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	} peer;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	/* Initialize a random secret */
 | 
					 | 
				
			||||||
	if (!cookie_initialized)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		if (!RAND_bytes(cookie_secret, COOKIE_SECRET_LENGTH))
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			BIO_printf(bio_err,"error setting random cookie secret\n");
 | 
					 | 
				
			||||||
			return 0;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		cookie_initialized = 1;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	/* Read peer information */
 | 
					 | 
				
			||||||
	(void)BIO_dgram_get_peer(SSL_get_rbio(ssl), &peer);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	/* Create buffer with peer's address and port */
 | 
					 | 
				
			||||||
	length = 0;
 | 
					 | 
				
			||||||
	switch (peer.sa.sa_family)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
	case AF_INET:
 | 
					 | 
				
			||||||
		length += sizeof(struct in_addr);
 | 
					 | 
				
			||||||
		length += sizeof(peer.s4.sin_port);
 | 
					 | 
				
			||||||
		break;
 | 
					 | 
				
			||||||
#if OPENSSL_USE_IPV6
 | 
					 | 
				
			||||||
	case AF_INET6:
 | 
					 | 
				
			||||||
		length += sizeof(struct in6_addr);
 | 
					 | 
				
			||||||
		length += sizeof(peer.s6.sin6_port);
 | 
					 | 
				
			||||||
		break;
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	default:
 | 
					 | 
				
			||||||
		OPENSSL_assert(0);
 | 
					 | 
				
			||||||
		break;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	buffer = OPENSSL_malloc(length);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if (buffer == NULL)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		BIO_printf(bio_err,"out of memory\n");
 | 
					 | 
				
			||||||
		return 0;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	switch (peer.sa.sa_family)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
	case AF_INET:
 | 
					 | 
				
			||||||
		memcpy(buffer,
 | 
					 | 
				
			||||||
		       &peer.s4.sin_port,
 | 
					 | 
				
			||||||
		       sizeof(peer.s4.sin_port));
 | 
					 | 
				
			||||||
		memcpy(buffer + sizeof(peer.s4.sin_port),
 | 
					 | 
				
			||||||
		       &peer.s4.sin_addr,
 | 
					 | 
				
			||||||
		       sizeof(struct in_addr));
 | 
					 | 
				
			||||||
		break;
 | 
					 | 
				
			||||||
#if OPENSSL_USE_IPV6
 | 
					 | 
				
			||||||
	case AF_INET6:
 | 
					 | 
				
			||||||
		memcpy(buffer,
 | 
					 | 
				
			||||||
		       &peer.s6.sin6_port,
 | 
					 | 
				
			||||||
		       sizeof(peer.s6.sin6_port));
 | 
					 | 
				
			||||||
		memcpy(buffer + sizeof(peer.s6.sin6_port),
 | 
					 | 
				
			||||||
		       &peer.s6.sin6_addr,
 | 
					 | 
				
			||||||
		       sizeof(struct in6_addr));
 | 
					 | 
				
			||||||
		break;
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	default:
 | 
					 | 
				
			||||||
		OPENSSL_assert(0);
 | 
					 | 
				
			||||||
		break;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	/* Calculate HMAC of buffer using the secret */
 | 
					 | 
				
			||||||
	HMAC(EVP_sha1(), cookie_secret, COOKIE_SECRET_LENGTH,
 | 
					 | 
				
			||||||
	     buffer, length, result, &resultlength);
 | 
					 | 
				
			||||||
	OPENSSL_free(buffer);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	memcpy(cookie, result, resultlength);
 | 
					 | 
				
			||||||
	*cookie_len = resultlength;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	return 1;
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
int MS_CALLBACK verify_cookie_callback(SSL *ssl, unsigned char *cookie, unsigned int cookie_len)
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	unsigned char *buffer, result[EVP_MAX_MD_SIZE];
 | 
					 | 
				
			||||||
	unsigned int length, resultlength;
 | 
					 | 
				
			||||||
	union {
 | 
					 | 
				
			||||||
		struct sockaddr sa;
 | 
					 | 
				
			||||||
		struct sockaddr_in s4;
 | 
					 | 
				
			||||||
#if OPENSSL_USE_IPV6
 | 
					 | 
				
			||||||
		struct sockaddr_in6 s6;
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	} peer;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	/* If secret isn't initialized yet, the cookie can't be valid */
 | 
					 | 
				
			||||||
	if (!cookie_initialized)
 | 
					 | 
				
			||||||
		return 0;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	/* Read peer information */
 | 
					 | 
				
			||||||
	(void)BIO_dgram_get_peer(SSL_get_rbio(ssl), &peer);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	/* Create buffer with peer's address and port */
 | 
					 | 
				
			||||||
	length = 0;
 | 
					 | 
				
			||||||
	switch (peer.sa.sa_family)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
	case AF_INET:
 | 
					 | 
				
			||||||
		length += sizeof(struct in_addr);
 | 
					 | 
				
			||||||
		length += sizeof(peer.s4.sin_port);
 | 
					 | 
				
			||||||
		break;
 | 
					 | 
				
			||||||
#if OPENSSL_USE_IPV6
 | 
					 | 
				
			||||||
	case AF_INET6:
 | 
					 | 
				
			||||||
		length += sizeof(struct in6_addr);
 | 
					 | 
				
			||||||
		length += sizeof(peer.s6.sin6_port);
 | 
					 | 
				
			||||||
		break;
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	default:
 | 
					 | 
				
			||||||
		OPENSSL_assert(0);
 | 
					 | 
				
			||||||
		break;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	buffer = OPENSSL_malloc(length);
 | 
					 | 
				
			||||||
	
 | 
					 | 
				
			||||||
	if (buffer == NULL)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		BIO_printf(bio_err,"out of memory\n");
 | 
					 | 
				
			||||||
		return 0;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	switch (peer.sa.sa_family)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
	case AF_INET:
 | 
					 | 
				
			||||||
		memcpy(buffer,
 | 
					 | 
				
			||||||
		       &peer.s4.sin_port,
 | 
					 | 
				
			||||||
		       sizeof(peer.s4.sin_port));
 | 
					 | 
				
			||||||
		memcpy(buffer + sizeof(peer.s4.sin_port),
 | 
					 | 
				
			||||||
		       &peer.s4.sin_addr,
 | 
					 | 
				
			||||||
		       sizeof(struct in_addr));
 | 
					 | 
				
			||||||
		break;
 | 
					 | 
				
			||||||
#if OPENSSL_USE_IPV6
 | 
					 | 
				
			||||||
	case AF_INET6:
 | 
					 | 
				
			||||||
		memcpy(buffer,
 | 
					 | 
				
			||||||
		       &peer.s6.sin6_port,
 | 
					 | 
				
			||||||
		       sizeof(peer.s6.sin6_port));
 | 
					 | 
				
			||||||
		memcpy(buffer + sizeof(peer.s6.sin6_port),
 | 
					 | 
				
			||||||
		       &peer.s6.sin6_addr,
 | 
					 | 
				
			||||||
		       sizeof(struct in6_addr));
 | 
					 | 
				
			||||||
		break;
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	default:
 | 
					 | 
				
			||||||
		OPENSSL_assert(0);
 | 
					 | 
				
			||||||
		break;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	/* Calculate HMAC of buffer using the secret */
 | 
					 | 
				
			||||||
	HMAC(EVP_sha1(), cookie_secret, COOKIE_SECRET_LENGTH,
 | 
					 | 
				
			||||||
	     buffer, length, result, &resultlength);
 | 
					 | 
				
			||||||
	OPENSSL_free(buffer);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if (cookie_len == resultlength && memcmp(result, cookie, resultlength) == 0)
 | 
					 | 
				
			||||||
		return 1;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	return 0;
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										358
									
								
								apps/s_client.c
									
									
									
									
									
								
							
							
						
						
									
										358
									
								
								apps/s_client.c
									
									
									
									
									
								
							@@ -163,9 +163,6 @@ typedef unsigned int u_int;
 | 
				
			|||||||
#include <openssl/rand.h>
 | 
					#include <openssl/rand.h>
 | 
				
			||||||
#include <openssl/ocsp.h>
 | 
					#include <openssl/ocsp.h>
 | 
				
			||||||
#include <openssl/bn.h>
 | 
					#include <openssl/bn.h>
 | 
				
			||||||
#ifndef OPENSSL_NO_SRP
 | 
					 | 
				
			||||||
#include <openssl/srp.h>
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
#include "s_apps.h"
 | 
					#include "s_apps.h"
 | 
				
			||||||
#include "timeouts.h"
 | 
					#include "timeouts.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -318,22 +315,13 @@ static void sc_usage(void)
 | 
				
			|||||||
# ifndef OPENSSL_NO_JPAKE
 | 
					# ifndef OPENSSL_NO_JPAKE
 | 
				
			||||||
	BIO_printf(bio_err," -jpake arg    - JPAKE secret to use\n");
 | 
						BIO_printf(bio_err," -jpake arg    - JPAKE secret to use\n");
 | 
				
			||||||
# endif
 | 
					# endif
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
#ifndef OPENSSL_NO_SRP
 | 
					 | 
				
			||||||
	BIO_printf(bio_err," -srpuser user     - SRP authentification for 'user'\n");
 | 
					 | 
				
			||||||
	BIO_printf(bio_err," -srppass arg      - password for 'user'\n");
 | 
					 | 
				
			||||||
	BIO_printf(bio_err," -srp_lateuser     - SRP username into second ClientHello message\n");
 | 
					 | 
				
			||||||
	BIO_printf(bio_err," -srp_moregroups   - Tolerate other than the known g N values.\n");
 | 
					 | 
				
			||||||
	BIO_printf(bio_err," -srp_strength int - minimal mength in bits for N (default %d).\n",SRP_MINIMAL_N);
 | 
					 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
	BIO_printf(bio_err," -ssl2         - just use SSLv2\n");
 | 
						BIO_printf(bio_err," -ssl2         - just use SSLv2\n");
 | 
				
			||||||
	BIO_printf(bio_err," -ssl3         - just use SSLv3\n");
 | 
						BIO_printf(bio_err," -ssl3         - just use SSLv3\n");
 | 
				
			||||||
	BIO_printf(bio_err," -tls1_2       - just use TLSv1.2\n");
 | 
					 | 
				
			||||||
	BIO_printf(bio_err," -tls1_1       - just use TLSv1.1\n");
 | 
					 | 
				
			||||||
	BIO_printf(bio_err," -tls1         - just use TLSv1\n");
 | 
						BIO_printf(bio_err," -tls1         - just use TLSv1\n");
 | 
				
			||||||
	BIO_printf(bio_err," -dtls1        - just use DTLSv1\n");    
 | 
						BIO_printf(bio_err," -dtls1        - just use DTLSv1\n");    
 | 
				
			||||||
	BIO_printf(bio_err," -mtu          - set the link layer MTU\n");
 | 
						BIO_printf(bio_err," -mtu          - set the MTU\n");
 | 
				
			||||||
	BIO_printf(bio_err," -no_tls1_2/-no_tls1_1/-no_tls1/-no_ssl3/-no_ssl2 - turn off that protocol\n");
 | 
						BIO_printf(bio_err," -no_tls1/-no_ssl3/-no_ssl2 - turn off that protocol\n");
 | 
				
			||||||
	BIO_printf(bio_err," -bugs         - Switch on all SSL implementation bug workarounds\n");
 | 
						BIO_printf(bio_err," -bugs         - Switch on all SSL implementation bug workarounds\n");
 | 
				
			||||||
	BIO_printf(bio_err," -serverpref   - Use server's cipher preferences (only SSLv2)\n");
 | 
						BIO_printf(bio_err," -serverpref   - Use server's cipher preferences (only SSLv2)\n");
 | 
				
			||||||
	BIO_printf(bio_err," -cipher       - preferred cipher to use, use the 'openssl ciphers'\n");
 | 
						BIO_printf(bio_err," -cipher       - preferred cipher to use, use the 'openssl ciphers'\n");
 | 
				
			||||||
@@ -354,11 +342,7 @@ static void sc_usage(void)
 | 
				
			|||||||
	BIO_printf(bio_err," -tlsextdebug      - hex dump of all TLS extensions received\n");
 | 
						BIO_printf(bio_err," -tlsextdebug      - hex dump of all TLS extensions received\n");
 | 
				
			||||||
	BIO_printf(bio_err," -status           - request certificate status from server\n");
 | 
						BIO_printf(bio_err," -status           - request certificate status from server\n");
 | 
				
			||||||
	BIO_printf(bio_err," -no_ticket        - disable use of RFC4507bis session tickets\n");
 | 
						BIO_printf(bio_err," -no_ticket        - disable use of RFC4507bis session tickets\n");
 | 
				
			||||||
# ifndef OPENSSL_NO_NEXTPROTONEG
 | 
					 | 
				
			||||||
	BIO_printf(bio_err," -nextprotoneg arg - enable NPN extension, considering named protocols supported (comma-separated list)\n");
 | 
					 | 
				
			||||||
# endif
 | 
					 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
	BIO_printf(bio_err," -legacy_renegotiation - enable use of legacy renegotiation (dangerous)\n");
 | 
					 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef OPENSSL_NO_TLSEXT
 | 
					#ifndef OPENSSL_NO_TLSEXT
 | 
				
			||||||
@@ -381,146 +365,6 @@ static int MS_CALLBACK ssl_servername_cb(SSL *s, int *ad, void *arg)
 | 
				
			|||||||
	
 | 
						
 | 
				
			||||||
	return SSL_TLSEXT_ERR_OK;
 | 
						return SSL_TLSEXT_ERR_OK;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifndef OPENSSL_NO_SRP
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
/* This is a context that we pass to all callbacks */
 | 
					 | 
				
			||||||
typedef struct srp_arg_st
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	char *srppassin;
 | 
					 | 
				
			||||||
	char *srplogin;
 | 
					 | 
				
			||||||
	int msg;   /* copy from c_msg */
 | 
					 | 
				
			||||||
	int debug; /* copy from c_debug */
 | 
					 | 
				
			||||||
	int amp;   /* allow more groups */
 | 
					 | 
				
			||||||
	int strength /* minimal size for N */ ;
 | 
					 | 
				
			||||||
	} SRP_ARG;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#define SRP_NUMBER_ITERATIONS_FOR_PRIME 64
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
static int SRP_Verify_N_and_g(const BIGNUM *N, const BIGNUM *g)
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	BN_CTX *bn_ctx = BN_CTX_new();
 | 
					 | 
				
			||||||
	BIGNUM *p = BN_new();
 | 
					 | 
				
			||||||
	BIGNUM *r = BN_new();
 | 
					 | 
				
			||||||
	int ret =
 | 
					 | 
				
			||||||
		g != NULL && N != NULL && bn_ctx != NULL && BN_is_odd(N) &&
 | 
					 | 
				
			||||||
		BN_is_prime_ex(N,SRP_NUMBER_ITERATIONS_FOR_PRIME,bn_ctx,NULL) &&
 | 
					 | 
				
			||||||
		p != NULL && BN_rshift1(p, N) &&
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		/* p = (N-1)/2 */
 | 
					 | 
				
			||||||
		BN_is_prime_ex(p,SRP_NUMBER_ITERATIONS_FOR_PRIME,bn_ctx,NULL) &&
 | 
					 | 
				
			||||||
		r != NULL &&
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		/* verify g^((N-1)/2) == -1 (mod N) */
 | 
					 | 
				
			||||||
		BN_mod_exp(r, g, p, N, bn_ctx) &&
 | 
					 | 
				
			||||||
		BN_add_word(r, 1) &&
 | 
					 | 
				
			||||||
		BN_cmp(r, N) == 0;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if(r)
 | 
					 | 
				
			||||||
		BN_free(r);
 | 
					 | 
				
			||||||
	if(p)
 | 
					 | 
				
			||||||
		BN_free(p);
 | 
					 | 
				
			||||||
	if(bn_ctx)
 | 
					 | 
				
			||||||
		BN_CTX_free(bn_ctx);
 | 
					 | 
				
			||||||
	return ret;
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
static int MS_CALLBACK ssl_srp_verify_param_cb(SSL *s, void *arg)
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	SRP_ARG *srp_arg = (SRP_ARG *)arg;
 | 
					 | 
				
			||||||
	BIGNUM *N = NULL, *g = NULL;
 | 
					 | 
				
			||||||
	if (!(N = SSL_get_srp_N(s)) || !(g = SSL_get_srp_g(s)))
 | 
					 | 
				
			||||||
		return 0;
 | 
					 | 
				
			||||||
	if (srp_arg->debug || srp_arg->msg || srp_arg->amp == 1)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
    		BIO_printf(bio_err, "SRP parameters:\n"); 
 | 
					 | 
				
			||||||
		BIO_printf(bio_err,"\tN="); BN_print(bio_err,N);
 | 
					 | 
				
			||||||
		BIO_printf(bio_err,"\n\tg="); BN_print(bio_err,g);
 | 
					 | 
				
			||||||
		BIO_printf(bio_err,"\n");
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if (SRP_check_known_gN_param(g,N))
 | 
					 | 
				
			||||||
		return 1;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if (srp_arg->amp == 1)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		if (srp_arg->debug)
 | 
					 | 
				
			||||||
			BIO_printf(bio_err, "SRP param N and g are not known params, going to check deeper.\n");
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
/* The srp_moregroups must be used with caution, testing primes costs time. 
 | 
					 | 
				
			||||||
   Implementors should rather add the value to the known ones.
 | 
					 | 
				
			||||||
   The minimal size has already been tested.
 | 
					 | 
				
			||||||
*/
 | 
					 | 
				
			||||||
		if (BN_num_bits(g) <= BN_BITS && SRP_Verify_N_and_g(N,g))
 | 
					 | 
				
			||||||
			return 1;
 | 
					 | 
				
			||||||
		}	
 | 
					 | 
				
			||||||
	BIO_printf(bio_err, "SRP param N and g rejected.\n");
 | 
					 | 
				
			||||||
	return 0;
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#define PWD_STRLEN 1024
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
static char * MS_CALLBACK ssl_give_srp_client_pwd_cb(SSL *s, void *arg)
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	SRP_ARG *srp_arg = (SRP_ARG *)arg;
 | 
					 | 
				
			||||||
	char *pass = (char *)OPENSSL_malloc(PWD_STRLEN+1);
 | 
					 | 
				
			||||||
	PW_CB_DATA cb_tmp;
 | 
					 | 
				
			||||||
	int l;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	cb_tmp.password = (char *)srp_arg->srppassin;
 | 
					 | 
				
			||||||
	cb_tmp.prompt_info = "SRP user";
 | 
					 | 
				
			||||||
	if ((l = password_callback(pass, PWD_STRLEN, 0, &cb_tmp))<0)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		BIO_printf (bio_err, "Can't read Password\n");
 | 
					 | 
				
			||||||
		OPENSSL_free(pass);
 | 
					 | 
				
			||||||
		return NULL;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	*(pass+l)= '\0';
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	return pass;
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
static char * MS_CALLBACK missing_srp_username_callback(SSL *s, void *arg)
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	SRP_ARG *srp_arg = (SRP_ARG *)arg;
 | 
					 | 
				
			||||||
	return BUF_strdup(srp_arg->srplogin);
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# ifndef OPENSSL_NO_NEXTPROTONEG
 | 
					 | 
				
			||||||
/* This the context that we pass to next_proto_cb */
 | 
					 | 
				
			||||||
typedef struct tlsextnextprotoctx_st {
 | 
					 | 
				
			||||||
	unsigned char *data;
 | 
					 | 
				
			||||||
	unsigned short len;
 | 
					 | 
				
			||||||
	int status;
 | 
					 | 
				
			||||||
} tlsextnextprotoctx;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
static tlsextnextprotoctx next_proto;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
static int next_proto_cb(SSL *s, unsigned char **out, unsigned char *outlen, const unsigned char *in, unsigned int inlen, void *arg)
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	tlsextnextprotoctx *ctx = arg;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if (!c_quiet)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		/* We can assume that |in| is syntactically valid. */
 | 
					 | 
				
			||||||
		unsigned i;
 | 
					 | 
				
			||||||
		BIO_printf(bio_c_out, "Protocols advertised by server: ");
 | 
					 | 
				
			||||||
		for (i = 0; i < inlen; )
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if (i)
 | 
					 | 
				
			||||||
				BIO_write(bio_c_out, ", ", 2);
 | 
					 | 
				
			||||||
			BIO_write(bio_c_out, &in[i + 1], in[i]);
 | 
					 | 
				
			||||||
			i += in[i] + 1;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		BIO_write(bio_c_out, "\n", 1);
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	ctx->status = SSL_select_next_proto(out, outlen, in, inlen, ctx->data, ctx->len);
 | 
					 | 
				
			||||||
	return SSL_TLSEXT_ERR_OK;
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
# endif  /* ndef OPENSSL_NO_NEXTPROTONEG */
 | 
					 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
enum
 | 
					enum
 | 
				
			||||||
@@ -537,11 +381,9 @@ int MAIN(int, char **);
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
int MAIN(int argc, char **argv)
 | 
					int MAIN(int argc, char **argv)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
	unsigned int off=0, clr=0;
 | 
						int off=0;
 | 
				
			||||||
	SSL *con=NULL;
 | 
						SSL *con=NULL;
 | 
				
			||||||
#ifndef OPENSSL_NO_KRB5
 | 
						X509_STORE *store = NULL;
 | 
				
			||||||
	KSSL_CTX *kctx;
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	int s,k,width,state=0;
 | 
						int s,k,width,state=0;
 | 
				
			||||||
	char *cbuf=NULL,*sbuf=NULL,*mbuf=NULL;
 | 
						char *cbuf=NULL,*sbuf=NULL,*mbuf=NULL;
 | 
				
			||||||
	int cbuf_len,cbuf_off;
 | 
						int cbuf_len,cbuf_off;
 | 
				
			||||||
@@ -562,15 +404,12 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	SSL_CTX *ctx=NULL;
 | 
						SSL_CTX *ctx=NULL;
 | 
				
			||||||
	int ret=1,in_init=1,i,nbio_test=0;
 | 
						int ret=1,in_init=1,i,nbio_test=0;
 | 
				
			||||||
	int starttls_proto = PROTO_OFF;
 | 
						int starttls_proto = PROTO_OFF;
 | 
				
			||||||
	int prexit = 0;
 | 
						int prexit = 0, vflags = 0;
 | 
				
			||||||
	X509_VERIFY_PARAM *vpm = NULL;
 | 
					 | 
				
			||||||
	int badarg = 0;
 | 
					 | 
				
			||||||
	const SSL_METHOD *meth=NULL;
 | 
						const SSL_METHOD *meth=NULL;
 | 
				
			||||||
	int socket_type=SOCK_STREAM;
 | 
						int socket_type=SOCK_STREAM;
 | 
				
			||||||
	BIO *sbio;
 | 
						BIO *sbio;
 | 
				
			||||||
	char *inrand=NULL;
 | 
						char *inrand=NULL;
 | 
				
			||||||
	int mbuf_len=0;
 | 
						int mbuf_len=0;
 | 
				
			||||||
	struct timeval timeout, *timeoutp;
 | 
					 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					#ifndef OPENSSL_NO_ENGINE
 | 
				
			||||||
	char *engine_id=NULL;
 | 
						char *engine_id=NULL;
 | 
				
			||||||
	char *ssl_client_engine_id=NULL;
 | 
						char *ssl_client_engine_id=NULL;
 | 
				
			||||||
@@ -587,9 +426,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	char *servername = NULL; 
 | 
						char *servername = NULL; 
 | 
				
			||||||
        tlsextctx tlsextcbp = 
 | 
					        tlsextctx tlsextcbp = 
 | 
				
			||||||
        {NULL,0};
 | 
					        {NULL,0};
 | 
				
			||||||
# ifndef OPENSSL_NO_NEXTPROTONEG
 | 
					 | 
				
			||||||
	const char *next_proto_neg_in = NULL;
 | 
					 | 
				
			||||||
# endif
 | 
					 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
	char *sess_in = NULL;
 | 
						char *sess_in = NULL;
 | 
				
			||||||
	char *sess_out = NULL;
 | 
						char *sess_out = NULL;
 | 
				
			||||||
@@ -600,11 +436,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
#ifndef OPENSSL_NO_JPAKE
 | 
					#ifndef OPENSSL_NO_JPAKE
 | 
				
			||||||
	char *jpake_secret = NULL;
 | 
						char *jpake_secret = NULL;
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
#ifndef OPENSSL_NO_SRP
 | 
					 | 
				
			||||||
	char * srppass = NULL;
 | 
					 | 
				
			||||||
	int srp_lateuser = 0;
 | 
					 | 
				
			||||||
	SRP_ARG srp_arg = {NULL,NULL,0,0,0,1024};
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
#if !defined(OPENSSL_NO_SSL2) && !defined(OPENSSL_NO_SSL3)
 | 
					#if !defined(OPENSSL_NO_SSL2) && !defined(OPENSSL_NO_SSL3)
 | 
				
			||||||
	meth=SSLv23_client_method();
 | 
						meth=SSLv23_client_method();
 | 
				
			||||||
@@ -690,12 +521,10 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
			cert_format = str2fmt(*(++argv));
 | 
								cert_format = str2fmt(*(++argv));
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else if (args_verify(&argv, &argc, &badarg, bio_err, &vpm))
 | 
							else if	(strcmp(*argv,"-crl_check") == 0)
 | 
				
			||||||
			{
 | 
								vflags |= X509_V_FLAG_CRL_CHECK;
 | 
				
			||||||
			if (badarg)
 | 
							else if	(strcmp(*argv,"-crl_check_all") == 0)
 | 
				
			||||||
				goto bad;
 | 
								vflags |= X509_V_FLAG_CRL_CHECK|X509_V_FLAG_CRL_CHECK_ALL;
 | 
				
			||||||
			continue;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-verify_return_error") == 0)
 | 
							else if (strcmp(*argv,"-verify_return_error") == 0)
 | 
				
			||||||
			verify_return_error = 1;
 | 
								verify_return_error = 1;
 | 
				
			||||||
		else if	(strcmp(*argv,"-prexit") == 0)
 | 
							else if	(strcmp(*argv,"-prexit") == 0)
 | 
				
			||||||
@@ -754,37 +583,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
                                }
 | 
					                                }
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
#ifndef OPENSSL_NO_SRP
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-srpuser") == 0)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
					 | 
				
			||||||
			srp_arg.srplogin= *(++argv);
 | 
					 | 
				
			||||||
			meth=TLSv1_client_method();
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-srppass") == 0)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
					 | 
				
			||||||
			srppass= *(++argv);
 | 
					 | 
				
			||||||
			meth=TLSv1_client_method();
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-srp_strength") == 0)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
					 | 
				
			||||||
			srp_arg.strength=atoi(*(++argv));
 | 
					 | 
				
			||||||
			BIO_printf(bio_err,"SRP minimal length for N is %d\n",srp_arg.strength);
 | 
					 | 
				
			||||||
			meth=TLSv1_client_method();
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-srp_lateuser") == 0)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			srp_lateuser= 1;
 | 
					 | 
				
			||||||
			meth=TLSv1_client_method();
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		else if	(strcmp(*argv,"-srp_moregroups") == 0)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			srp_arg.amp=1;
 | 
					 | 
				
			||||||
			meth=TLSv1_client_method();
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
#ifndef OPENSSL_NO_SSL2
 | 
					#ifndef OPENSSL_NO_SSL2
 | 
				
			||||||
		else if	(strcmp(*argv,"-ssl2") == 0)
 | 
							else if	(strcmp(*argv,"-ssl2") == 0)
 | 
				
			||||||
			meth=SSLv2_client_method();
 | 
								meth=SSLv2_client_method();
 | 
				
			||||||
@@ -794,10 +592,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			meth=SSLv3_client_method();
 | 
								meth=SSLv3_client_method();
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
#ifndef OPENSSL_NO_TLS1
 | 
					#ifndef OPENSSL_NO_TLS1
 | 
				
			||||||
		else if	(strcmp(*argv,"-tls1_2") == 0)
 | 
					 | 
				
			||||||
			meth=TLSv1_2_client_method();
 | 
					 | 
				
			||||||
		else if	(strcmp(*argv,"-tls1_1") == 0)
 | 
					 | 
				
			||||||
			meth=TLSv1_1_client_method();
 | 
					 | 
				
			||||||
		else if	(strcmp(*argv,"-tls1") == 0)
 | 
							else if	(strcmp(*argv,"-tls1") == 0)
 | 
				
			||||||
			meth=TLSv1_client_method();
 | 
								meth=TLSv1_client_method();
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
@@ -846,10 +640,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
			CAfile= *(++argv);
 | 
								CAfile= *(++argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else if (strcmp(*argv,"-no_tls1_2") == 0)
 | 
					 | 
				
			||||||
			off|=SSL_OP_NO_TLSv1_2;
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-no_tls1_1") == 0)
 | 
					 | 
				
			||||||
			off|=SSL_OP_NO_TLSv1_1;
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-no_tls1") == 0)
 | 
							else if (strcmp(*argv,"-no_tls1") == 0)
 | 
				
			||||||
			off|=SSL_OP_NO_TLSv1;
 | 
								off|=SSL_OP_NO_TLSv1;
 | 
				
			||||||
		else if (strcmp(*argv,"-no_ssl3") == 0)
 | 
							else if (strcmp(*argv,"-no_ssl3") == 0)
 | 
				
			||||||
@@ -861,22 +651,9 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
#ifndef OPENSSL_NO_TLSEXT
 | 
					#ifndef OPENSSL_NO_TLSEXT
 | 
				
			||||||
		else if	(strcmp(*argv,"-no_ticket") == 0)
 | 
							else if	(strcmp(*argv,"-no_ticket") == 0)
 | 
				
			||||||
			{ off|=SSL_OP_NO_TICKET; }
 | 
								{ off|=SSL_OP_NO_TICKET; }
 | 
				
			||||||
# ifndef OPENSSL_NO_NEXTPROTONEG
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-nextprotoneg") == 0)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
					 | 
				
			||||||
			next_proto_neg_in = *(++argv);
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
# endif
 | 
					 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
		else if (strcmp(*argv,"-serverpref") == 0)
 | 
							else if (strcmp(*argv,"-serverpref") == 0)
 | 
				
			||||||
			off|=SSL_OP_CIPHER_SERVER_PREFERENCE;
 | 
								off|=SSL_OP_CIPHER_SERVER_PREFERENCE;
 | 
				
			||||||
		else if (strcmp(*argv,"-legacy_renegotiation") == 0)
 | 
					 | 
				
			||||||
			off|=SSL_OP_ALLOW_UNSAFE_LEGACY_RENEGOTIATION;
 | 
					 | 
				
			||||||
		else if	(strcmp(*argv,"-legacy_server_connect") == 0)
 | 
					 | 
				
			||||||
			{ off|=SSL_OP_LEGACY_SERVER_CONNECT; }
 | 
					 | 
				
			||||||
		else if	(strcmp(*argv,"-no_legacy_server_connect") == 0)
 | 
					 | 
				
			||||||
			{ clr|=SSL_OP_LEGACY_SERVER_CONNECT; }
 | 
					 | 
				
			||||||
		else if	(strcmp(*argv,"-cipher") == 0)
 | 
							else if	(strcmp(*argv,"-cipher") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
@@ -974,21 +751,6 @@ bad:
 | 
				
			|||||||
	OpenSSL_add_ssl_algorithms();
 | 
						OpenSSL_add_ssl_algorithms();
 | 
				
			||||||
	SSL_load_error_strings();
 | 
						SSL_load_error_strings();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#if !defined(OPENSSL_NO_TLSEXT) && !defined(OPENSSL_NO_NEXTPROTONEG)
 | 
					 | 
				
			||||||
	next_proto.status = -1;
 | 
					 | 
				
			||||||
	if (next_proto_neg_in)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		next_proto.data = next_protos_parse(&next_proto.len, next_proto_neg_in);
 | 
					 | 
				
			||||||
		if (next_proto.data == NULL)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			BIO_printf(bio_err, "Error parsing -nextprotoneg argument\n");
 | 
					 | 
				
			||||||
			goto end;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	else
 | 
					 | 
				
			||||||
		next_proto.data = NULL;
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					#ifndef OPENSSL_NO_ENGINE
 | 
				
			||||||
        e = setup_engine(bio_err, engine_id, 1);
 | 
					        e = setup_engine(bio_err, engine_id, 1);
 | 
				
			||||||
	if (ssl_client_engine_id)
 | 
						if (ssl_client_engine_id)
 | 
				
			||||||
@@ -1062,14 +824,6 @@ bad:
 | 
				
			|||||||
			}
 | 
								}
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef OPENSSL_NO_SRP
 | 
					 | 
				
			||||||
	if(!app_passwd(bio_err, srppass, NULL, &srp_arg.srppassin, NULL))
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		BIO_printf(bio_err, "Error getting password\n");
 | 
					 | 
				
			||||||
		goto end;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	ctx=SSL_CTX_new(meth);
 | 
						ctx=SSL_CTX_new(meth);
 | 
				
			||||||
	if (ctx == NULL)
 | 
						if (ctx == NULL)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
@@ -1077,9 +831,6 @@ bad:
 | 
				
			|||||||
		goto end;
 | 
							goto end;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (vpm)
 | 
					 | 
				
			||||||
		SSL_CTX_set1_param(ctx, vpm);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					#ifndef OPENSSL_NO_ENGINE
 | 
				
			||||||
	if (ssl_client_engine)
 | 
						if (ssl_client_engine)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
@@ -1110,19 +861,11 @@ bad:
 | 
				
			|||||||
		SSL_CTX_set_options(ctx,SSL_OP_ALL|off);
 | 
							SSL_CTX_set_options(ctx,SSL_OP_ALL|off);
 | 
				
			||||||
	else
 | 
						else
 | 
				
			||||||
		SSL_CTX_set_options(ctx,off);
 | 
							SSL_CTX_set_options(ctx,off);
 | 
				
			||||||
 | 
					 | 
				
			||||||
	if (clr)
 | 
					 | 
				
			||||||
		SSL_CTX_clear_options(ctx, clr);
 | 
					 | 
				
			||||||
	/* DTLS: partial reads end up discarding unread UDP bytes :-( 
 | 
						/* DTLS: partial reads end up discarding unread UDP bytes :-( 
 | 
				
			||||||
	 * Setting read ahead solves this problem.
 | 
						 * Setting read ahead solves this problem.
 | 
				
			||||||
	 */
 | 
						 */
 | 
				
			||||||
	if (socket_type == SOCK_DGRAM) SSL_CTX_set_read_ahead(ctx, 1);
 | 
						if (socket_type == SOCK_DGRAM) SSL_CTX_set_read_ahead(ctx, 1);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#if !defined(OPENSSL_NO_TLSEXT) && !defined(OPENSSL_NO_NEXTPROTONEG)
 | 
					 | 
				
			||||||
	if (next_proto.data)
 | 
					 | 
				
			||||||
		SSL_CTX_set_next_proto_select_cb(ctx, next_proto_cb, &next_proto);
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if (state) SSL_CTX_set_info_callback(ctx,apps_ssl_info_callback);
 | 
						if (state) SSL_CTX_set_info_callback(ctx,apps_ssl_info_callback);
 | 
				
			||||||
	if (cipher != NULL)
 | 
						if (cipher != NULL)
 | 
				
			||||||
		if(!SSL_CTX_set_cipher_list(ctx,cipher)) {
 | 
							if(!SSL_CTX_set_cipher_list(ctx,cipher)) {
 | 
				
			||||||
@@ -1147,6 +890,8 @@ bad:
 | 
				
			|||||||
		/* goto end; */
 | 
							/* goto end; */
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						store = SSL_CTX_get_cert_store(ctx);
 | 
				
			||||||
 | 
						X509_STORE_set_flags(store, vflags);
 | 
				
			||||||
#ifndef OPENSSL_NO_TLSEXT
 | 
					#ifndef OPENSSL_NO_TLSEXT
 | 
				
			||||||
	if (servername != NULL)
 | 
						if (servername != NULL)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
@@ -1154,26 +899,6 @@ bad:
 | 
				
			|||||||
		SSL_CTX_set_tlsext_servername_callback(ctx, ssl_servername_cb);
 | 
							SSL_CTX_set_tlsext_servername_callback(ctx, ssl_servername_cb);
 | 
				
			||||||
		SSL_CTX_set_tlsext_servername_arg(ctx, &tlsextcbp);
 | 
							SSL_CTX_set_tlsext_servername_arg(ctx, &tlsextcbp);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
#ifndef OPENSSL_NO_SRP
 | 
					 | 
				
			||||||
        if (srp_arg.srplogin)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		if (srp_lateuser) 
 | 
					 | 
				
			||||||
			SSL_CTX_set_srp_missing_srp_username_callback(ctx,missing_srp_username_callback);
 | 
					 | 
				
			||||||
		else if (!SSL_CTX_set_srp_username(ctx, srp_arg.srplogin))
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			BIO_printf(bio_err,"Unable to set SRP username\n");
 | 
					 | 
				
			||||||
			goto end;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		srp_arg.msg = c_msg;
 | 
					 | 
				
			||||||
		srp_arg.debug = c_debug ;
 | 
					 | 
				
			||||||
		SSL_CTX_set_srp_cb_arg(ctx,&srp_arg);
 | 
					 | 
				
			||||||
		SSL_CTX_set_srp_client_pwd_callback(ctx, ssl_give_srp_client_pwd_cb);
 | 
					 | 
				
			||||||
		SSL_CTX_set_srp_strength(ctx, srp_arg.strength);
 | 
					 | 
				
			||||||
		if (c_msg || c_debug || srp_arg.amp == 0)
 | 
					 | 
				
			||||||
			SSL_CTX_set_srp_verify_param_callback(ctx, ssl_srp_verify_param_cb);
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	con=SSL_new(ctx);
 | 
						con=SSL_new(ctx);
 | 
				
			||||||
@@ -1212,10 +937,9 @@ bad:
 | 
				
			|||||||
		}
 | 
							}
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
#ifndef OPENSSL_NO_KRB5
 | 
					#ifndef OPENSSL_NO_KRB5
 | 
				
			||||||
	if (con  &&  (kctx = kssl_ctx_new()) != NULL)
 | 
						if (con  &&  (con->kssl_ctx = kssl_ctx_new()) != NULL)
 | 
				
			||||||
                {
 | 
					                {
 | 
				
			||||||
		SSL_set0_kssl_ctx(con, kctx);
 | 
					                kssl_ctx_setstring(con->kssl_ctx, KSSL_SERVER, host);
 | 
				
			||||||
                kssl_ctx_setstring(kctx, KSSL_SERVER, host);
 | 
					 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
#endif	/* OPENSSL_NO_KRB5  */
 | 
					#endif	/* OPENSSL_NO_KRB5  */
 | 
				
			||||||
/*	SSL_set_cipher_list(con,"RC4-MD5"); */
 | 
					/*	SSL_set_cipher_list(con,"RC4-MD5"); */
 | 
				
			||||||
@@ -1247,10 +971,11 @@ re_start:
 | 
				
			|||||||
			}
 | 
								}
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
#endif                                              
 | 
					#endif                                              
 | 
				
			||||||
	if (c_Pause & 0x01) SSL_set_debug(con, 1);
 | 
						if (c_Pause & 0x01) con->debug=1;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if ( SSL_version(con) == DTLS1_VERSION)
 | 
						if ( SSL_version(con) == DTLS1_VERSION)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
 | 
							struct timeval timeout;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		sbio=BIO_new_dgram(s,BIO_NOCLOSE);
 | 
							sbio=BIO_new_dgram(s,BIO_NOCLOSE);
 | 
				
			||||||
		if (getsockname(s, &peer, (void *)&peerlen) < 0)
 | 
							if (getsockname(s, &peer, (void *)&peerlen) < 0)
 | 
				
			||||||
@@ -1274,10 +999,10 @@ re_start:
 | 
				
			|||||||
			BIO_ctrl(sbio, BIO_CTRL_DGRAM_SET_SEND_TIMEOUT, 0, &timeout);
 | 
								BIO_ctrl(sbio, BIO_CTRL_DGRAM_SET_SEND_TIMEOUT, 0, &timeout);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if (socket_mtu > 28)
 | 
							if (socket_mtu > 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			SSL_set_options(con, SSL_OP_NO_QUERY_MTU);
 | 
								SSL_set_options(con, SSL_OP_NO_QUERY_MTU);
 | 
				
			||||||
			SSL_set_mtu(con, socket_mtu - 28);
 | 
								SSL_set_mtu(con, socket_mtu);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else
 | 
							else
 | 
				
			||||||
			/* want to do MTU discovery */
 | 
								/* want to do MTU discovery */
 | 
				
			||||||
@@ -1296,7 +1021,7 @@ re_start:
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	if (c_debug)
 | 
						if (c_debug)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		SSL_set_debug(con, 1);
 | 
							con->debug=1;
 | 
				
			||||||
		BIO_set_callback(sbio,bio_dump_callback);
 | 
							BIO_set_callback(sbio,bio_dump_callback);
 | 
				
			||||||
		BIO_set_callback_arg(sbio,(char *)bio_c_out);
 | 
							BIO_set_callback_arg(sbio,(char *)bio_c_out);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
@@ -1467,12 +1192,6 @@ SSL_set_tlsext_status_ids(con, ids);
 | 
				
			|||||||
		FD_ZERO(&readfds);
 | 
							FD_ZERO(&readfds);
 | 
				
			||||||
		FD_ZERO(&writefds);
 | 
							FD_ZERO(&writefds);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if ((SSL_version(con) == DTLS1_VERSION) &&
 | 
					 | 
				
			||||||
			DTLSv1_get_timeout(con, &timeout))
 | 
					 | 
				
			||||||
			timeoutp = &timeout;
 | 
					 | 
				
			||||||
		else
 | 
					 | 
				
			||||||
			timeoutp = NULL;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		if (SSL_in_init(con) && !SSL_total_renegotiations(con))
 | 
							if (SSL_in_init(con) && !SSL_total_renegotiations(con))
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			in_init=1;
 | 
								in_init=1;
 | 
				
			||||||
@@ -1577,7 +1296,7 @@ SSL_set_tlsext_status_ids(con, ids);
 | 
				
			|||||||
					if(!i && (!((_kbhit()) || (WAIT_OBJECT_0 == WaitForSingleObject(GetStdHandle(STD_INPUT_HANDLE), 0))) || !read_tty) ) continue;
 | 
										if(!i && (!((_kbhit()) || (WAIT_OBJECT_0 == WaitForSingleObject(GetStdHandle(STD_INPUT_HANDLE), 0))) || !read_tty) ) continue;
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
				} else 	i=select(width,(void *)&readfds,(void *)&writefds,
 | 
									} else 	i=select(width,(void *)&readfds,(void *)&writefds,
 | 
				
			||||||
					 NULL,timeoutp);
 | 
										 NULL,NULL);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
#elif defined(OPENSSL_SYS_NETWARE)
 | 
					#elif defined(OPENSSL_SYS_NETWARE)
 | 
				
			||||||
			if(!write_tty) {
 | 
								if(!write_tty) {
 | 
				
			||||||
@@ -1587,7 +1306,7 @@ SSL_set_tlsext_status_ids(con, ids);
 | 
				
			|||||||
					i=select(width,(void *)&readfds,(void *)&writefds,
 | 
										i=select(width,(void *)&readfds,(void *)&writefds,
 | 
				
			||||||
						NULL,&tv);
 | 
											NULL,&tv);
 | 
				
			||||||
				} else 	i=select(width,(void *)&readfds,(void *)&writefds,
 | 
									} else 	i=select(width,(void *)&readfds,(void *)&writefds,
 | 
				
			||||||
					NULL,timeoutp);
 | 
										NULL,NULL);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
#elif defined(OPENSSL_SYS_BEOS_R5)
 | 
					#elif defined(OPENSSL_SYS_BEOS_R5)
 | 
				
			||||||
			/* Under BeOS-R5 the situation is similar to DOS */
 | 
								/* Under BeOS-R5 the situation is similar to DOS */
 | 
				
			||||||
@@ -1605,12 +1324,12 @@ SSL_set_tlsext_status_ids(con, ids);
 | 
				
			|||||||
					if (!i && (stdin_set != 1 || !read_tty))
 | 
										if (!i && (stdin_set != 1 || !read_tty))
 | 
				
			||||||
						continue;
 | 
											continue;
 | 
				
			||||||
				} else 	i=select(width,(void *)&readfds,(void *)&writefds,
 | 
									} else 	i=select(width,(void *)&readfds,(void *)&writefds,
 | 
				
			||||||
					 NULL,timeoutp);
 | 
										 NULL,NULL);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
			(void)fcntl(fileno(stdin), F_SETFL, 0);
 | 
								(void)fcntl(fileno(stdin), F_SETFL, 0);
 | 
				
			||||||
#else
 | 
					#else
 | 
				
			||||||
			i=select(width,(void *)&readfds,(void *)&writefds,
 | 
								i=select(width,(void *)&readfds,(void *)&writefds,
 | 
				
			||||||
				 NULL,timeoutp);
 | 
									 NULL,NULL);
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
			if ( i < 0)
 | 
								if ( i < 0)
 | 
				
			||||||
				{
 | 
									{
 | 
				
			||||||
@@ -1621,11 +1340,6 @@ SSL_set_tlsext_status_ids(con, ids);
 | 
				
			|||||||
				}
 | 
									}
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if ((SSL_version(con) == DTLS1_VERSION) && DTLSv1_handle_timeout(con) > 0)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			BIO_printf(bio_err,"TIMEOUT occured\n");
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		if (!ssl_pending && FD_ISSET(SSL_get_fd(con),&writefds))
 | 
							if (!ssl_pending && FD_ISSET(SSL_get_fd(con),&writefds))
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			k=SSL_write(con,&(cbuf[cbuf_off]),
 | 
								k=SSL_write(con,&(cbuf[cbuf_off]),
 | 
				
			||||||
@@ -1981,7 +1695,7 @@ static void print_stuff(BIO *bio, SSL *s, int full)
 | 
				
			|||||||
			BIO_number_read(SSL_get_rbio(s)),
 | 
								BIO_number_read(SSL_get_rbio(s)),
 | 
				
			||||||
			BIO_number_written(SSL_get_wbio(s)));
 | 
								BIO_number_written(SSL_get_wbio(s)));
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	BIO_printf(bio,(SSL_cache_hit(s)?"---\nReused, ":"---\nNew, "));
 | 
						BIO_printf(bio,((s->hit)?"---\nReused, ":"---\nNew, "));
 | 
				
			||||||
	c=SSL_get_current_cipher(s);
 | 
						c=SSL_get_current_cipher(s);
 | 
				
			||||||
	BIO_printf(bio,"%s, Cipher is %s\n",
 | 
						BIO_printf(bio,"%s, Cipher is %s\n",
 | 
				
			||||||
		SSL_CIPHER_get_version(c),
 | 
							SSL_CIPHER_get_version(c),
 | 
				
			||||||
@@ -1993,8 +1707,6 @@ static void print_stuff(BIO *bio, SSL *s, int full)
 | 
				
			|||||||
							 EVP_PKEY_bits(pktmp));
 | 
												 EVP_PKEY_bits(pktmp));
 | 
				
			||||||
		EVP_PKEY_free(pktmp);
 | 
							EVP_PKEY_free(pktmp);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	BIO_printf(bio, "Secure Renegotiation IS%s supported\n",
 | 
					 | 
				
			||||||
			SSL_get_secure_renegotiation_support(s) ? "" : " NOT");
 | 
					 | 
				
			||||||
#ifndef OPENSSL_NO_COMP
 | 
					#ifndef OPENSSL_NO_COMP
 | 
				
			||||||
	comp=SSL_get_current_compression(s);
 | 
						comp=SSL_get_current_compression(s);
 | 
				
			||||||
	expansion=SSL_get_current_expansion(s);
 | 
						expansion=SSL_get_current_expansion(s);
 | 
				
			||||||
@@ -2003,30 +1715,6 @@ static void print_stuff(BIO *bio, SSL *s, int full)
 | 
				
			|||||||
	BIO_printf(bio,"Expansion: %s\n",
 | 
						BIO_printf(bio,"Expansion: %s\n",
 | 
				
			||||||
		expansion ? SSL_COMP_get_name(expansion) : "NONE");
 | 
							expansion ? SSL_COMP_get_name(expansion) : "NONE");
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					 | 
				
			||||||
#if !defined(OPENSSL_NO_TLSEXT) && !defined(OPENSSL_NO_NEXTPROTONEG)
 | 
					 | 
				
			||||||
	if (next_proto.status != -1) {
 | 
					 | 
				
			||||||
		const unsigned char *proto;
 | 
					 | 
				
			||||||
		unsigned int proto_len;
 | 
					 | 
				
			||||||
		SSL_get0_next_proto_negotiated(s, &proto, &proto_len);
 | 
					 | 
				
			||||||
		BIO_printf(bio, "Next protocol: (%d) ", next_proto.status);
 | 
					 | 
				
			||||||
		BIO_write(bio, proto, proto_len);
 | 
					 | 
				
			||||||
		BIO_write(bio, "\n", 1);
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifdef SSL_DEBUG
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	/* Print out local port of connection: useful for debugging */
 | 
					 | 
				
			||||||
	int sock;
 | 
					 | 
				
			||||||
	struct sockaddr_in ladd;
 | 
					 | 
				
			||||||
	socklen_t ladd_size = sizeof(ladd);
 | 
					 | 
				
			||||||
	sock = SSL_get_fd(s);
 | 
					 | 
				
			||||||
	getsockname(sock, (struct sockaddr *)&ladd, &ladd_size);
 | 
					 | 
				
			||||||
	BIO_printf(bio_c_out, "LOCAL PORT is %u\n", ntohs(ladd.sin_port));
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	SSL_SESSION_print(bio,SSL_get_session(s));
 | 
						SSL_SESSION_print(bio,SSL_get_session(s));
 | 
				
			||||||
	BIO_printf(bio,"---\n");
 | 
						BIO_printf(bio,"---\n");
 | 
				
			||||||
	if (peer != NULL)
 | 
						if (peer != NULL)
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										457
									
								
								apps/s_server.c
									
									
									
									
									
								
							
							
						
						
									
										457
									
								
								apps/s_server.c
									
									
									
									
									
								
							@@ -186,9 +186,6 @@ typedef unsigned int u_int;
 | 
				
			|||||||
#ifndef OPENSSL_NO_RSA
 | 
					#ifndef OPENSSL_NO_RSA
 | 
				
			||||||
#include <openssl/rsa.h>
 | 
					#include <openssl/rsa.h>
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
#ifndef OPENSSL_NO_SRP
 | 
					 | 
				
			||||||
#include <openssl/srp.h>
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
#include "s_apps.h"
 | 
					#include "s_apps.h"
 | 
				
			||||||
#include "timeouts.h"
 | 
					#include "timeouts.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -204,7 +201,6 @@ typedef unsigned int u_int;
 | 
				
			|||||||
#ifndef OPENSSL_NO_RSA
 | 
					#ifndef OPENSSL_NO_RSA
 | 
				
			||||||
static RSA MS_CALLBACK *tmp_rsa_cb(SSL *s, int is_export, int keylength);
 | 
					static RSA MS_CALLBACK *tmp_rsa_cb(SSL *s, int is_export, int keylength);
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
static int not_resumable_sess_cb(SSL *s, int is_forward_secure);
 | 
					 | 
				
			||||||
static int sv_body(char *hostname, int s, unsigned char *context);
 | 
					static int sv_body(char *hostname, int s, unsigned char *context);
 | 
				
			||||||
static int www_body(char *hostname, int s, unsigned char *context);
 | 
					static int www_body(char *hostname, int s, unsigned char *context);
 | 
				
			||||||
static void close_accept_socket(void );
 | 
					static void close_accept_socket(void );
 | 
				
			||||||
@@ -213,8 +209,6 @@ static int init_ssl_connection(SSL *s);
 | 
				
			|||||||
static void print_stats(BIO *bp,SSL_CTX *ctx);
 | 
					static void print_stats(BIO *bp,SSL_CTX *ctx);
 | 
				
			||||||
static int generate_session_id(const SSL *ssl, unsigned char *id,
 | 
					static int generate_session_id(const SSL *ssl, unsigned char *id,
 | 
				
			||||||
				unsigned int *id_len);
 | 
									unsigned int *id_len);
 | 
				
			||||||
static void init_session_cache_ctx(SSL_CTX *sctx);
 | 
					 | 
				
			||||||
static void free_sessions(void);
 | 
					 | 
				
			||||||
#ifndef OPENSSL_NO_DH
 | 
					#ifndef OPENSSL_NO_DH
 | 
				
			||||||
static DH *load_dh_param(const char *dhfile);
 | 
					static DH *load_dh_param(const char *dhfile);
 | 
				
			||||||
static DH *get_dh512(void);
 | 
					static DH *get_dh512(void);
 | 
				
			||||||
@@ -293,7 +287,6 @@ static int s_tlsextdebug=0;
 | 
				
			|||||||
static int s_tlsextstatus=0;
 | 
					static int s_tlsextstatus=0;
 | 
				
			||||||
static int cert_status_cb(SSL *s, void *arg);
 | 
					static int cert_status_cb(SSL *s, void *arg);
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
static int no_resume_ephemeral = 0;
 | 
					 | 
				
			||||||
static int s_msg=0;
 | 
					static int s_msg=0;
 | 
				
			||||||
static int s_quiet=0;
 | 
					static int s_quiet=0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -305,9 +298,7 @@ static const char *session_id_prefix=NULL;
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
static int enable_timeouts = 0;
 | 
					static int enable_timeouts = 0;
 | 
				
			||||||
static long socket_mtu;
 | 
					static long socket_mtu;
 | 
				
			||||||
#ifndef OPENSSL_NO_DTLS1
 | 
					 | 
				
			||||||
static int cert_chain = 0;
 | 
					static int cert_chain = 0;
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef OPENSSL_NO_PSK
 | 
					#ifndef OPENSSL_NO_PSK
 | 
				
			||||||
static char *psk_identity="Client_identity";
 | 
					static char *psk_identity="Client_identity";
 | 
				
			||||||
@@ -376,40 +367,6 @@ static unsigned int psk_server_cb(SSL *ssl, const char *identity,
 | 
				
			|||||||
        }
 | 
					        }
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef OPENSSL_NO_SRP
 | 
					 | 
				
			||||||
/* This is a context that we pass to callbacks */
 | 
					 | 
				
			||||||
typedef struct srpsrvparm_st
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	int verbose;
 | 
					 | 
				
			||||||
	char *login;
 | 
					 | 
				
			||||||
	SRP_VBASE *vb;
 | 
					 | 
				
			||||||
	} srpsrvparm;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
static int MS_CALLBACK ssl_srp_server_param_cb(SSL *s, int *ad, void *arg)
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	srpsrvparm *p = arg;
 | 
					 | 
				
			||||||
	SRP_user_pwd *user;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	p->login = BUF_strdup(SSL_get_srp_username(s));
 | 
					 | 
				
			||||||
	BIO_printf(bio_err, "SRP username = \"%s\"\n", p->login);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	user = SRP_VBASE_get_by_user(p->vb, p->login);	
 | 
					 | 
				
			||||||
	if (user == NULL)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		BIO_printf(bio_err, "User %s doesn't exist\n", p->login);
 | 
					 | 
				
			||||||
		return SSL3_AL_FATAL;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	if (SSL_set_srp_server_param(s, user->N, user->g, user->s, user->v,
 | 
					 | 
				
			||||||
				     user->info) < 0)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		*ad = SSL_AD_INTERNAL_ERROR;
 | 
					 | 
				
			||||||
		return SSL3_AL_FATAL;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	return SSL_ERROR_NONE;
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifdef MONOLITH
 | 
					#ifdef MONOLITH
 | 
				
			||||||
static void s_server_init(void)
 | 
					static void s_server_init(void)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
@@ -496,32 +453,23 @@ static void sv_usage(void)
 | 
				
			|||||||
# ifndef OPENSSL_NO_JPAKE
 | 
					# ifndef OPENSSL_NO_JPAKE
 | 
				
			||||||
	BIO_printf(bio_err," -jpake arg    - JPAKE secret to use\n");
 | 
						BIO_printf(bio_err," -jpake arg    - JPAKE secret to use\n");
 | 
				
			||||||
# endif
 | 
					# endif
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
#ifndef OPENSSL_NO_SRP
 | 
					 | 
				
			||||||
	BIO_printf(bio_err," -srpvfile file      - The verifier file for SRP\n");
 | 
					 | 
				
			||||||
	BIO_printf(bio_err," -srpuserseed string - A seed string for a default user salt.\n");
 | 
					 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
	BIO_printf(bio_err," -ssl2         - Just talk SSLv2\n");
 | 
						BIO_printf(bio_err," -ssl2         - Just talk SSLv2\n");
 | 
				
			||||||
	BIO_printf(bio_err," -ssl3         - Just talk SSLv3\n");
 | 
						BIO_printf(bio_err," -ssl3         - Just talk SSLv3\n");
 | 
				
			||||||
	BIO_printf(bio_err," -tls1_2       - Just talk TLSv1.2\n");
 | 
					 | 
				
			||||||
	BIO_printf(bio_err," -tls1_1       - Just talk TLSv1.1\n");
 | 
					 | 
				
			||||||
	BIO_printf(bio_err," -tls1         - Just talk TLSv1\n");
 | 
						BIO_printf(bio_err," -tls1         - Just talk TLSv1\n");
 | 
				
			||||||
	BIO_printf(bio_err," -dtls1        - Just talk DTLSv1\n");
 | 
						BIO_printf(bio_err," -dtls1        - Just talk DTLSv1\n");
 | 
				
			||||||
	BIO_printf(bio_err," -timeout      - Enable timeouts\n");
 | 
						BIO_printf(bio_err," -timeout      - Enable timeouts\n");
 | 
				
			||||||
	BIO_printf(bio_err," -mtu          - Set link layer MTU\n");
 | 
						BIO_printf(bio_err," -mtu          - Set MTU\n");
 | 
				
			||||||
	BIO_printf(bio_err," -chain        - Read a certificate chain\n");
 | 
						BIO_printf(bio_err," -chain        - Read a certificate chain\n");
 | 
				
			||||||
	BIO_printf(bio_err," -no_ssl2      - Just disable SSLv2\n");
 | 
						BIO_printf(bio_err," -no_ssl2      - Just disable SSLv2\n");
 | 
				
			||||||
	BIO_printf(bio_err," -no_ssl3      - Just disable SSLv3\n");
 | 
						BIO_printf(bio_err," -no_ssl3      - Just disable SSLv3\n");
 | 
				
			||||||
	BIO_printf(bio_err," -no_tls1      - Just disable TLSv1\n");
 | 
						BIO_printf(bio_err," -no_tls1      - Just disable TLSv1\n");
 | 
				
			||||||
	BIO_printf(bio_err," -no_tls1_1    - Just disable TLSv1.1\n");
 | 
					 | 
				
			||||||
	BIO_printf(bio_err," -no_tls1_2    - Just disable TLSv1.2\n");
 | 
					 | 
				
			||||||
#ifndef OPENSSL_NO_DH
 | 
					#ifndef OPENSSL_NO_DH
 | 
				
			||||||
	BIO_printf(bio_err," -no_dhe       - Disable ephemeral DH\n");
 | 
						BIO_printf(bio_err," -no_dhe       - Disable ephemeral DH\n");
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
#ifndef OPENSSL_NO_ECDH
 | 
					#ifndef OPENSSL_NO_ECDH
 | 
				
			||||||
	BIO_printf(bio_err," -no_ecdhe     - Disable ephemeral ECDH\n");
 | 
						BIO_printf(bio_err," -no_ecdhe     - Disable ephemeral ECDH\n");
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
	BIO_printf(bio_err, "-no_resume_ephemeral - Disable caching and tickets if ephemeral (EC)DH is used\n");
 | 
					 | 
				
			||||||
	BIO_printf(bio_err," -bugs         - Turn on SSL bug compatibility\n");
 | 
						BIO_printf(bio_err," -bugs         - Turn on SSL bug compatibility\n");
 | 
				
			||||||
	BIO_printf(bio_err," -www          - Respond to a 'GET /' with a status page\n");
 | 
						BIO_printf(bio_err," -www          - Respond to a 'GET /' with a status page\n");
 | 
				
			||||||
	BIO_printf(bio_err," -WWW          - Respond to a 'GET /<path> HTTP/1.0' with file ./<path>\n");
 | 
						BIO_printf(bio_err," -WWW          - Respond to a 'GET /<path> HTTP/1.0' with file ./<path>\n");
 | 
				
			||||||
@@ -541,10 +489,6 @@ static void sv_usage(void)
 | 
				
			|||||||
	BIO_printf(bio_err,"                 not specified (default is %s)\n",TEST_CERT2);
 | 
						BIO_printf(bio_err,"                 not specified (default is %s)\n",TEST_CERT2);
 | 
				
			||||||
	BIO_printf(bio_err," -tlsextdebug  - hex dump of all TLS extensions received\n");
 | 
						BIO_printf(bio_err," -tlsextdebug  - hex dump of all TLS extensions received\n");
 | 
				
			||||||
	BIO_printf(bio_err," -no_ticket    - disable use of RFC4507bis session tickets\n");
 | 
						BIO_printf(bio_err," -no_ticket    - disable use of RFC4507bis session tickets\n");
 | 
				
			||||||
	BIO_printf(bio_err," -legacy_renegotiation - enable use of legacy renegotiation (dangerous)\n");
 | 
					 | 
				
			||||||
# ifndef OPENSSL_NO_NEXTPROTONEG
 | 
					 | 
				
			||||||
	BIO_printf(bio_err," -nextprotoneg arg - set the advertised protocols for the NPN extension (comma-separated list)\n");
 | 
					 | 
				
			||||||
# endif
 | 
					 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -727,7 +671,7 @@ static int MS_CALLBACK ssl_servername_cb(SSL *s, int *ad, void *arg)
 | 
				
			|||||||
			return p->extension_error;
 | 
								return p->extension_error;
 | 
				
			||||||
		if (ctx2)
 | 
							if (ctx2)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			BIO_printf(p->biodebug,"Switching server context.\n");
 | 
								BIO_printf(p->biodebug,"Swiching server context.\n");
 | 
				
			||||||
			SSL_set_SSL_CTX(s,ctx2);
 | 
								SSL_set_SSL_CTX(s,ctx2);
 | 
				
			||||||
			}     
 | 
								}     
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
@@ -766,7 +710,7 @@ static int cert_status_cb(SSL *s, void *arg)
 | 
				
			|||||||
	int use_ssl;
 | 
						int use_ssl;
 | 
				
			||||||
	unsigned char *rspder = NULL;
 | 
						unsigned char *rspder = NULL;
 | 
				
			||||||
	int rspderlen;
 | 
						int rspderlen;
 | 
				
			||||||
	STACK_OF(OPENSSL_STRING) *aia = NULL;
 | 
						STACK_OF(STRING) *aia = NULL;
 | 
				
			||||||
	X509 *x = NULL;
 | 
						X509 *x = NULL;
 | 
				
			||||||
	X509_STORE_CTX inctx;
 | 
						X509_STORE_CTX inctx;
 | 
				
			||||||
	X509_OBJECT obj;
 | 
						X509_OBJECT obj;
 | 
				
			||||||
@@ -788,7 +732,7 @@ BIO_printf(err, "cert_status: received %d ids\n", sk_OCSP_RESPID_num(ids));
 | 
				
			|||||||
	aia = X509_get1_ocsp(x);
 | 
						aia = X509_get1_ocsp(x);
 | 
				
			||||||
	if (aia)
 | 
						if (aia)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		if (!OCSP_parse_url(sk_OPENSSL_STRING_value(aia, 0),
 | 
							if (!OCSP_parse_url(sk_STRING_value(aia, 0),
 | 
				
			||||||
			&host, &port, &path, &use_ssl))
 | 
								&host, &port, &path, &use_ssl))
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			BIO_puts(err, "cert_status: can't parse AIA URL\n");
 | 
								BIO_puts(err, "cert_status: can't parse AIA URL\n");
 | 
				
			||||||
@@ -796,7 +740,7 @@ BIO_printf(err, "cert_status: received %d ids\n", sk_OCSP_RESPID_num(ids));
 | 
				
			|||||||
			}
 | 
								}
 | 
				
			||||||
		if (srctx->verbose)
 | 
							if (srctx->verbose)
 | 
				
			||||||
			BIO_printf(err, "cert_status: AIA URL: %s\n",
 | 
								BIO_printf(err, "cert_status: AIA URL: %s\n",
 | 
				
			||||||
					sk_OPENSSL_STRING_value(aia, 0));
 | 
										sk_STRING_value(aia, 0));
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	else
 | 
						else
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
@@ -841,7 +785,7 @@ BIO_printf(err, "cert_status: received %d ids\n", sk_OCSP_RESPID_num(ids));
 | 
				
			|||||||
		if (!OCSP_REQUEST_add_ext(req, ext, -1))
 | 
							if (!OCSP_REQUEST_add_ext(req, ext, -1))
 | 
				
			||||||
			goto err;
 | 
								goto err;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	resp = process_responder(err, req, host, path, port, use_ssl, NULL,
 | 
						resp = process_responder(err, req, host, path, port, use_ssl,
 | 
				
			||||||
					srctx->timeout);
 | 
										srctx->timeout);
 | 
				
			||||||
	if (!resp)
 | 
						if (!resp)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
@@ -879,32 +823,8 @@ BIO_printf(err, "cert_status: received %d ids\n", sk_OCSP_RESPID_num(ids));
 | 
				
			|||||||
	ret = SSL_TLSEXT_ERR_ALERT_FATAL;
 | 
						ret = SSL_TLSEXT_ERR_ALERT_FATAL;
 | 
				
			||||||
	goto done;
 | 
						goto done;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					 | 
				
			||||||
# ifndef OPENSSL_NO_NEXTPROTONEG
 | 
					 | 
				
			||||||
/* This is the context that we pass to next_proto_cb */
 | 
					 | 
				
			||||||
typedef struct tlsextnextprotoctx_st {
 | 
					 | 
				
			||||||
	unsigned char *data;
 | 
					 | 
				
			||||||
	unsigned int len;
 | 
					 | 
				
			||||||
} tlsextnextprotoctx;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
static int next_proto_cb(SSL *s, const unsigned char **data, unsigned int *len, void *arg)
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	tlsextnextprotoctx *next_proto = arg;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	*data = next_proto->data;
 | 
					 | 
				
			||||||
	*len = next_proto->len;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	return SSL_TLSEXT_ERR_OK;
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
# endif  /* ndef OPENSSL_NO_NPN */
 | 
					 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static int not_resumable_sess_cb(SSL *s, int is_forward_secure)
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	/* disable resumption for sessions with forward secure ciphers */
 | 
					 | 
				
			||||||
	return is_forward_secure;
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
int MAIN(int, char **);
 | 
					int MAIN(int, char **);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef OPENSSL_NO_JPAKE
 | 
					#ifndef OPENSSL_NO_JPAKE
 | 
				
			||||||
@@ -913,8 +833,8 @@ static char *jpake_secret = NULL;
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
int MAIN(int argc, char *argv[])
 | 
					int MAIN(int argc, char *argv[])
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
	X509_VERIFY_PARAM *vpm = NULL;
 | 
						X509_STORE *store = NULL;
 | 
				
			||||||
	int badarg = 0;
 | 
						int vflags = 0;
 | 
				
			||||||
	short port=PORT;
 | 
						short port=PORT;
 | 
				
			||||||
	char *CApath=NULL,*CAfile=NULL;
 | 
						char *CApath=NULL,*CAfile=NULL;
 | 
				
			||||||
	unsigned char *context = NULL;
 | 
						unsigned char *context = NULL;
 | 
				
			||||||
@@ -937,37 +857,23 @@ int MAIN(int argc, char *argv[])
 | 
				
			|||||||
	int s_dcert_format = FORMAT_PEM, s_dkey_format = FORMAT_PEM;
 | 
						int s_dcert_format = FORMAT_PEM, s_dkey_format = FORMAT_PEM;
 | 
				
			||||||
	X509 *s_cert = NULL, *s_dcert = NULL;
 | 
						X509 *s_cert = NULL, *s_dcert = NULL;
 | 
				
			||||||
	EVP_PKEY *s_key = NULL, *s_dkey = NULL;
 | 
						EVP_PKEY *s_key = NULL, *s_dkey = NULL;
 | 
				
			||||||
	int no_cache = 0, ext_cache = 0;
 | 
					 | 
				
			||||||
#ifndef OPENSSL_NO_TLSEXT
 | 
					#ifndef OPENSSL_NO_TLSEXT
 | 
				
			||||||
	EVP_PKEY *s_key2 = NULL;
 | 
						EVP_PKEY *s_key2 = NULL;
 | 
				
			||||||
	X509 *s_cert2 = NULL;
 | 
						X509 *s_cert2 = NULL;
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
#ifndef OPENSSL_NO_TLSEXT
 | 
					#ifndef OPENSSL_NO_TLSEXT
 | 
				
			||||||
        tlsextctx tlsextcbp = {NULL, NULL, SSL_TLSEXT_ERR_ALERT_WARNING};
 | 
					        tlsextctx tlsextcbp = {NULL, NULL, SSL_TLSEXT_ERR_ALERT_WARNING};
 | 
				
			||||||
# ifndef OPENSSL_NO_NEXTPROTONEG
 | 
					 | 
				
			||||||
	const char *next_proto_neg_in = NULL;
 | 
					 | 
				
			||||||
	tlsextnextprotoctx next_proto;
 | 
					 | 
				
			||||||
# endif
 | 
					 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
#ifndef OPENSSL_NO_PSK
 | 
					#ifndef OPENSSL_NO_PSK
 | 
				
			||||||
	/* by default do not send a PSK identity hint */
 | 
						/* by default do not send a PSK identity hint */
 | 
				
			||||||
	static char *psk_identity_hint=NULL;
 | 
						static char *psk_identity_hint=NULL;
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
#ifndef OPENSSL_NO_SRP
 | 
					 | 
				
			||||||
	char *srpuserseed = NULL;
 | 
					 | 
				
			||||||
	char *srp_verifier_file = NULL;
 | 
					 | 
				
			||||||
	srpsrvparm p;
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
#if !defined(OPENSSL_NO_SSL2) && !defined(OPENSSL_NO_SSL3)
 | 
					#if !defined(OPENSSL_NO_SSL2) && !defined(OPENSSL_NO_SSL3)
 | 
				
			||||||
	meth=SSLv23_server_method();
 | 
						meth=SSLv23_server_method();
 | 
				
			||||||
#elif !defined(OPENSSL_NO_SSL3)
 | 
					#elif !defined(OPENSSL_NO_SSL3)
 | 
				
			||||||
	meth=SSLv3_server_method();
 | 
						meth=SSLv3_server_method();
 | 
				
			||||||
#elif !defined(OPENSSL_NO_SSL2)
 | 
					#elif !defined(OPENSSL_NO_SSL2)
 | 
				
			||||||
	meth=SSLv2_server_method();
 | 
						meth=SSLv2_server_method();
 | 
				
			||||||
#elif !defined(OPENSSL_NO_TLS1)
 | 
					 | 
				
			||||||
	meth=TLSv1_server_method();
 | 
					 | 
				
			||||||
#else
 | 
					 | 
				
			||||||
  /*  #error no SSL version enabled */
 | 
					 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	local_argc=argc;
 | 
						local_argc=argc;
 | 
				
			||||||
@@ -1093,22 +999,18 @@ int MAIN(int argc, char *argv[])
 | 
				
			|||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
			CApath= *(++argv);
 | 
								CApath= *(++argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else if (strcmp(*argv,"-no_cache") == 0)
 | 
							else if (strcmp(*argv,"-crl_check") == 0)
 | 
				
			||||||
			no_cache = 1;
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-ext_cache") == 0)
 | 
					 | 
				
			||||||
			ext_cache = 1;
 | 
					 | 
				
			||||||
		else if (args_verify(&argv, &argc, &badarg, bio_err, &vpm))
 | 
					 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (badarg)
 | 
								vflags |= X509_V_FLAG_CRL_CHECK;
 | 
				
			||||||
				goto bad;
 | 
								}
 | 
				
			||||||
			continue;
 | 
							else if (strcmp(*argv,"-crl_check_all") == 0)
 | 
				
			||||||
 | 
								{
 | 
				
			||||||
 | 
								vflags |= X509_V_FLAG_CRL_CHECK|X509_V_FLAG_CRL_CHECK_ALL;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else if (strcmp(*argv,"-verify_return_error") == 0)
 | 
							else if (strcmp(*argv,"-verify_return_error") == 0)
 | 
				
			||||||
			verify_return_error = 1;
 | 
								verify_return_error = 1;
 | 
				
			||||||
		else if	(strcmp(*argv,"-serverpref") == 0)
 | 
							else if	(strcmp(*argv,"-serverpref") == 0)
 | 
				
			||||||
			{ off|=SSL_OP_CIPHER_SERVER_PREFERENCE; }
 | 
								{ off|=SSL_OP_CIPHER_SERVER_PREFERENCE; }
 | 
				
			||||||
		else if (strcmp(*argv,"-legacy_renegotiation") == 0)
 | 
					 | 
				
			||||||
			off|=SSL_OP_ALLOW_UNSAFE_LEGACY_RENEGOTIATION;
 | 
					 | 
				
			||||||
		else if	(strcmp(*argv,"-cipher") == 0)
 | 
							else if	(strcmp(*argv,"-cipher") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
@@ -1181,8 +1083,6 @@ int MAIN(int argc, char *argv[])
 | 
				
			|||||||
			{ no_dhe=1; }
 | 
								{ no_dhe=1; }
 | 
				
			||||||
		else if	(strcmp(*argv,"-no_ecdhe") == 0)
 | 
							else if	(strcmp(*argv,"-no_ecdhe") == 0)
 | 
				
			||||||
			{ no_ecdhe=1; }
 | 
								{ no_ecdhe=1; }
 | 
				
			||||||
		else if (strcmp(*argv,"-no_resume_ephemeral") == 0)
 | 
					 | 
				
			||||||
			{ no_resume_ephemeral = 1; }
 | 
					 | 
				
			||||||
#ifndef OPENSSL_NO_PSK
 | 
					#ifndef OPENSSL_NO_PSK
 | 
				
			||||||
                else if (strcmp(*argv,"-psk_hint") == 0)
 | 
					                else if (strcmp(*argv,"-psk_hint") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
@@ -1203,20 +1103,6 @@ int MAIN(int argc, char *argv[])
 | 
				
			|||||||
				goto bad;
 | 
									goto bad;
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
#ifndef OPENSSL_NO_SRP
 | 
					 | 
				
			||||||
		else if (strcmp(*argv, "-srpvfile") == 0)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
					 | 
				
			||||||
			srp_verifier_file = *(++argv);
 | 
					 | 
				
			||||||
			meth = TLSv1_server_method();
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		else if (strcmp(*argv, "-srpuserseed") == 0)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
					 | 
				
			||||||
			srpuserseed = *(++argv);
 | 
					 | 
				
			||||||
			meth = TLSv1_server_method();
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
		else if	(strcmp(*argv,"-www") == 0)
 | 
							else if	(strcmp(*argv,"-www") == 0)
 | 
				
			||||||
			{ www=1; }
 | 
								{ www=1; }
 | 
				
			||||||
@@ -1228,10 +1114,6 @@ int MAIN(int argc, char *argv[])
 | 
				
			|||||||
			{ off|=SSL_OP_NO_SSLv2; }
 | 
								{ off|=SSL_OP_NO_SSLv2; }
 | 
				
			||||||
		else if	(strcmp(*argv,"-no_ssl3") == 0)
 | 
							else if	(strcmp(*argv,"-no_ssl3") == 0)
 | 
				
			||||||
			{ off|=SSL_OP_NO_SSLv3; }
 | 
								{ off|=SSL_OP_NO_SSLv3; }
 | 
				
			||||||
		else if	(strcmp(*argv,"-no_tls1_2") == 0)
 | 
					 | 
				
			||||||
			{ off|=SSL_OP_NO_TLSv1_2; }
 | 
					 | 
				
			||||||
		else if	(strcmp(*argv,"-no_tls1_1") == 0)
 | 
					 | 
				
			||||||
			{ off|=SSL_OP_NO_TLSv1_1; }
 | 
					 | 
				
			||||||
		else if	(strcmp(*argv,"-no_tls1") == 0)
 | 
							else if	(strcmp(*argv,"-no_tls1") == 0)
 | 
				
			||||||
			{ off|=SSL_OP_NO_TLSv1; }
 | 
								{ off|=SSL_OP_NO_TLSv1; }
 | 
				
			||||||
		else if	(strcmp(*argv,"-no_comp") == 0)
 | 
							else if	(strcmp(*argv,"-no_comp") == 0)
 | 
				
			||||||
@@ -1249,14 +1131,8 @@ int MAIN(int argc, char *argv[])
 | 
				
			|||||||
			{ meth=SSLv3_server_method(); }
 | 
								{ meth=SSLv3_server_method(); }
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
#ifndef OPENSSL_NO_TLS1
 | 
					#ifndef OPENSSL_NO_TLS1
 | 
				
			||||||
		else if	(strcmp(*argv,"-tls1_2") == 0)
 | 
					 | 
				
			||||||
			{ meth=TLSv1_2_server_method(); }
 | 
					 | 
				
			||||||
		else if	(strcmp(*argv,"-tls1_1") == 0)
 | 
					 | 
				
			||||||
			{ meth=TLSv1_1_server_method(); }
 | 
					 | 
				
			||||||
		else if	(strcmp(*argv,"-tls1") == 0)
 | 
							else if	(strcmp(*argv,"-tls1") == 0)
 | 
				
			||||||
			{ meth=TLSv1_server_method(); }
 | 
								{ meth=TLSv1_server_method(); }
 | 
				
			||||||
		else if	(strcmp(*argv,"-tls1_1") == 0)
 | 
					 | 
				
			||||||
			{ meth=TLSv1_1_server_method(); }
 | 
					 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
#ifndef OPENSSL_NO_DTLS1
 | 
					#ifndef OPENSSL_NO_DTLS1
 | 
				
			||||||
		else if	(strcmp(*argv,"-dtls1") == 0)
 | 
							else if	(strcmp(*argv,"-dtls1") == 0)
 | 
				
			||||||
@@ -1309,13 +1185,7 @@ int MAIN(int argc, char *argv[])
 | 
				
			|||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
			s_key_file2= *(++argv);
 | 
								s_key_file2= *(++argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
# ifndef OPENSSL_NO_NEXTPROTONEG
 | 
								
 | 
				
			||||||
		else if	(strcmp(*argv,"-nextprotoneg") == 0)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
					 | 
				
			||||||
			next_proto_neg_in = *(++argv);
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
# endif
 | 
					 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
#if !defined(OPENSSL_NO_JPAKE) && !defined(OPENSSL_NO_PSK)
 | 
					#if !defined(OPENSSL_NO_JPAKE) && !defined(OPENSSL_NO_PSK)
 | 
				
			||||||
		else if (strcmp(*argv,"-jpake") == 0)
 | 
							else if (strcmp(*argv,"-jpake") == 0)
 | 
				
			||||||
@@ -1420,21 +1290,6 @@ bad:
 | 
				
			|||||||
				goto end;
 | 
									goto end;
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
# ifndef OPENSSL_NO_NEXTPROTONEG
 | 
					 | 
				
			||||||
		if (next_proto_neg_in)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			unsigned short len;
 | 
					 | 
				
			||||||
			next_proto.data = next_protos_parse(&len,
 | 
					 | 
				
			||||||
				next_proto_neg_in);
 | 
					 | 
				
			||||||
			if (next_proto.data == NULL)
 | 
					 | 
				
			||||||
				goto end;
 | 
					 | 
				
			||||||
			next_proto.len = len;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		else
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			next_proto.data = NULL;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
# endif
 | 
					 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -1533,12 +1388,8 @@ bad:
 | 
				
			|||||||
	if (socket_type == SOCK_DGRAM) SSL_CTX_set_read_ahead(ctx, 1);
 | 
						if (socket_type == SOCK_DGRAM) SSL_CTX_set_read_ahead(ctx, 1);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (state) SSL_CTX_set_info_callback(ctx,apps_ssl_info_callback);
 | 
						if (state) SSL_CTX_set_info_callback(ctx,apps_ssl_info_callback);
 | 
				
			||||||
	if (no_cache)
 | 
					
 | 
				
			||||||
		SSL_CTX_set_session_cache_mode(ctx, SSL_SESS_CACHE_OFF);
 | 
						SSL_CTX_sess_set_cache_size(ctx,128);
 | 
				
			||||||
	else if (ext_cache)
 | 
					 | 
				
			||||||
		init_session_cache_ctx(ctx);
 | 
					 | 
				
			||||||
	else
 | 
					 | 
				
			||||||
		SSL_CTX_sess_set_cache_size(ctx,128);
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
#if 0
 | 
					#if 0
 | 
				
			||||||
	if (cipher == NULL) cipher=getenv("SSL_CIPHER");
 | 
						if (cipher == NULL) cipher=getenv("SSL_CIPHER");
 | 
				
			||||||
@@ -1559,8 +1410,8 @@ bad:
 | 
				
			|||||||
		ERR_print_errors(bio_err);
 | 
							ERR_print_errors(bio_err);
 | 
				
			||||||
		/* goto end; */
 | 
							/* goto end; */
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	if (vpm)
 | 
						store = SSL_CTX_get_cert_store(ctx);
 | 
				
			||||||
		SSL_CTX_set1_param(ctx, vpm);
 | 
						X509_STORE_set_flags(store, vflags);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef OPENSSL_NO_TLSEXT
 | 
					#ifndef OPENSSL_NO_TLSEXT
 | 
				
			||||||
	if (s_cert2)
 | 
						if (s_cert2)
 | 
				
			||||||
@@ -1604,26 +1455,16 @@ bad:
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
		if (state) SSL_CTX_set_info_callback(ctx2,apps_ssl_info_callback);
 | 
							if (state) SSL_CTX_set_info_callback(ctx2,apps_ssl_info_callback);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if (no_cache)
 | 
							SSL_CTX_sess_set_cache_size(ctx2,128);
 | 
				
			||||||
			SSL_CTX_set_session_cache_mode(ctx2,SSL_SESS_CACHE_OFF);
 | 
					 | 
				
			||||||
		else if (ext_cache)
 | 
					 | 
				
			||||||
			init_session_cache_ctx(ctx2);
 | 
					 | 
				
			||||||
		else
 | 
					 | 
				
			||||||
			SSL_CTX_sess_set_cache_size(ctx2,128);
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if ((!SSL_CTX_load_verify_locations(ctx2,CAfile,CApath)) ||
 | 
							if ((!SSL_CTX_load_verify_locations(ctx2,CAfile,CApath)) ||
 | 
				
			||||||
			(!SSL_CTX_set_default_verify_paths(ctx2)))
 | 
								(!SSL_CTX_set_default_verify_paths(ctx2)))
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			ERR_print_errors(bio_err);
 | 
								ERR_print_errors(bio_err);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		if (vpm)
 | 
							store = SSL_CTX_get_cert_store(ctx2);
 | 
				
			||||||
			SSL_CTX_set1_param(ctx2, vpm);
 | 
							X509_STORE_set_flags(store, vflags);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					 | 
				
			||||||
# ifndef OPENSSL_NO_NEXTPROTONEG
 | 
					 | 
				
			||||||
	if (next_proto.data)
 | 
					 | 
				
			||||||
		SSL_CTX_set_next_protos_advertised_cb(ctx, next_proto_cb, &next_proto);
 | 
					 | 
				
			||||||
# endif
 | 
					 | 
				
			||||||
#endif 
 | 
					#endif 
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef OPENSSL_NO_DH
 | 
					#ifndef OPENSSL_NO_DH
 | 
				
			||||||
@@ -1772,15 +1613,6 @@ bad:
 | 
				
			|||||||
#endif
 | 
					#endif
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (no_resume_ephemeral)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		SSL_CTX_set_not_resumable_session_callback(ctx, not_resumable_sess_cb);
 | 
					 | 
				
			||||||
#ifndef OPENSSL_NO_TLSEXT
 | 
					 | 
				
			||||||
		if (ctx2)
 | 
					 | 
				
			||||||
			SSL_CTX_set_not_resumable_session_callback(ctx2, not_resumable_sess_cb);
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifndef OPENSSL_NO_PSK
 | 
					#ifndef OPENSSL_NO_PSK
 | 
				
			||||||
#ifdef OPENSSL_NO_JPAKE
 | 
					#ifdef OPENSSL_NO_JPAKE
 | 
				
			||||||
	if (psk_key != NULL)
 | 
						if (psk_key != NULL)
 | 
				
			||||||
@@ -1822,10 +1654,6 @@ bad:
 | 
				
			|||||||
	SSL_CTX_set_session_id_context(ctx,(void*)&s_server_session_id_context,
 | 
						SSL_CTX_set_session_id_context(ctx,(void*)&s_server_session_id_context,
 | 
				
			||||||
		sizeof s_server_session_id_context);
 | 
							sizeof s_server_session_id_context);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/* Set DTLS cookie generation and verification callbacks */
 | 
					 | 
				
			||||||
	SSL_CTX_set_cookie_generate_cb(ctx, generate_cookie_callback);
 | 
					 | 
				
			||||||
	SSL_CTX_set_cookie_verify_cb(ctx, verify_cookie_callback);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifndef OPENSSL_NO_TLSEXT
 | 
					#ifndef OPENSSL_NO_TLSEXT
 | 
				
			||||||
	if (ctx2)
 | 
						if (ctx2)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
@@ -1841,23 +1669,6 @@ bad:
 | 
				
			|||||||
		}
 | 
							}
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef OPENSSL_NO_SRP
 | 
					 | 
				
			||||||
	if (srp_verifier_file != NULL)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		p.vb = SRP_VBASE_new(srpuserseed);
 | 
					 | 
				
			||||||
		if ((ret = SRP_VBASE_init(p.vb, srp_verifier_file)) != SRP_NO_ERROR)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			BIO_printf(bio_err,
 | 
					 | 
				
			||||||
					   "Cannot initialize SRP verifier file \"%s\":ret=%d\n",
 | 
					 | 
				
			||||||
					   srp_verifier_file,ret);
 | 
					 | 
				
			||||||
				goto end;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		SSL_CTX_set_verify(ctx, SSL_VERIFY_NONE,verify_callback);
 | 
					 | 
				
			||||||
		SSL_CTX_set_srp_cb_arg(ctx, &p);  			
 | 
					 | 
				
			||||||
		SSL_CTX_set_srp_username_callback(ctx, ssl_srp_server_param_cb);
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	else
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	if (CAfile != NULL)
 | 
						if (CAfile != NULL)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		SSL_CTX_set_client_CA_list(ctx,SSL_load_client_CA_file(CAfile));
 | 
							SSL_CTX_set_client_CA_list(ctx,SSL_load_client_CA_file(CAfile));
 | 
				
			||||||
@@ -1889,7 +1700,6 @@ end:
 | 
				
			|||||||
		OPENSSL_free(pass);
 | 
							OPENSSL_free(pass);
 | 
				
			||||||
	if (dpass)
 | 
						if (dpass)
 | 
				
			||||||
		OPENSSL_free(dpass);
 | 
							OPENSSL_free(dpass);
 | 
				
			||||||
	free_sessions();
 | 
					 | 
				
			||||||
#ifndef OPENSSL_NO_TLSEXT
 | 
					#ifndef OPENSSL_NO_TLSEXT
 | 
				
			||||||
	if (ctx2 != NULL) SSL_CTX_free(ctx2);
 | 
						if (ctx2 != NULL) SSL_CTX_free(ctx2);
 | 
				
			||||||
	if (s_cert2)
 | 
						if (s_cert2)
 | 
				
			||||||
@@ -1940,14 +1750,8 @@ static int sv_body(char *hostname, int s, unsigned char *context)
 | 
				
			|||||||
	unsigned long l;
 | 
						unsigned long l;
 | 
				
			||||||
	SSL *con=NULL;
 | 
						SSL *con=NULL;
 | 
				
			||||||
	BIO *sbio;
 | 
						BIO *sbio;
 | 
				
			||||||
#ifndef OPENSSL_NO_KRB5
 | 
					 | 
				
			||||||
	KSSL_CTX *kctx;
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	struct timeval timeout;
 | 
					 | 
				
			||||||
#if defined(OPENSSL_SYS_WINDOWS) || defined(OPENSSL_SYS_MSDOS) || defined(OPENSSL_SYS_NETWARE) || defined(OPENSSL_SYS_BEOS_R5)
 | 
					#if defined(OPENSSL_SYS_WINDOWS) || defined(OPENSSL_SYS_MSDOS) || defined(OPENSSL_SYS_NETWARE) || defined(OPENSSL_SYS_BEOS_R5)
 | 
				
			||||||
	struct timeval tv;
 | 
						struct timeval tv;
 | 
				
			||||||
#else
 | 
					 | 
				
			||||||
	struct timeval *timeoutp;
 | 
					 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if ((buf=OPENSSL_malloc(bufsize)) == NULL)
 | 
						if ((buf=OPENSSL_malloc(bufsize)) == NULL)
 | 
				
			||||||
@@ -1983,11 +1787,12 @@ static int sv_body(char *hostname, int s, unsigned char *context)
 | 
				
			|||||||
		}
 | 
							}
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
#ifndef OPENSSL_NO_KRB5
 | 
					#ifndef OPENSSL_NO_KRB5
 | 
				
			||||||
		if ((kctx = kssl_ctx_new()) != NULL)
 | 
							if ((con->kssl_ctx = kssl_ctx_new()) != NULL)
 | 
				
			||||||
                        {
 | 
					                        {
 | 
				
			||||||
			SSL_set0_kssl_ctx(con, kctx);
 | 
					                        kssl_ctx_setstring(con->kssl_ctx, KSSL_SERVICE,
 | 
				
			||||||
                        kssl_ctx_setstring(kctx, KSSL_SERVICE, KRB5SVC);
 | 
													KRB5SVC);
 | 
				
			||||||
                        kssl_ctx_setstring(kctx, KSSL_KEYTAB, KRB5KEYTAB);
 | 
					                        kssl_ctx_setstring(con->kssl_ctx, KSSL_KEYTAB,
 | 
				
			||||||
 | 
													KRB5KEYTAB);
 | 
				
			||||||
                        }
 | 
					                        }
 | 
				
			||||||
#endif	/* OPENSSL_NO_KRB5 */
 | 
					#endif	/* OPENSSL_NO_KRB5 */
 | 
				
			||||||
		if(context)
 | 
							if(context)
 | 
				
			||||||
@@ -2003,6 +1808,7 @@ static int sv_body(char *hostname, int s, unsigned char *context)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	if (SSL_version(con) == DTLS1_VERSION)
 | 
						if (SSL_version(con) == DTLS1_VERSION)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
 | 
							struct timeval timeout;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		sbio=BIO_new_dgram(s,BIO_NOCLOSE);
 | 
							sbio=BIO_new_dgram(s,BIO_NOCLOSE);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -2017,10 +1823,10 @@ static int sv_body(char *hostname, int s, unsigned char *context)
 | 
				
			|||||||
			BIO_ctrl(sbio, BIO_CTRL_DGRAM_SET_SEND_TIMEOUT, 0, &timeout);
 | 
								BIO_ctrl(sbio, BIO_CTRL_DGRAM_SET_SEND_TIMEOUT, 0, &timeout);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if (socket_mtu > 28)
 | 
							if (socket_mtu > 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			SSL_set_options(con, SSL_OP_NO_QUERY_MTU);
 | 
								SSL_set_options(con, SSL_OP_NO_QUERY_MTU);
 | 
				
			||||||
			SSL_set_mtu(con, socket_mtu - 28);
 | 
								SSL_set_mtu(con, socket_mtu);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else
 | 
							else
 | 
				
			||||||
			/* want to do MTU discovery */
 | 
								/* want to do MTU discovery */
 | 
				
			||||||
@@ -2050,7 +1856,7 @@ static int sv_body(char *hostname, int s, unsigned char *context)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	if (s_debug)
 | 
						if (s_debug)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		SSL_set_debug(con, 1);
 | 
							con->debug=1;
 | 
				
			||||||
		BIO_set_callback(SSL_get_rbio(con),bio_dump_callback);
 | 
							BIO_set_callback(SSL_get_rbio(con),bio_dump_callback);
 | 
				
			||||||
		BIO_set_callback_arg(SSL_get_rbio(con),(char *)bio_s_out);
 | 
							BIO_set_callback_arg(SSL_get_rbio(con),(char *)bio_s_out);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
@@ -2113,19 +1919,7 @@ static int sv_body(char *hostname, int s, unsigned char *context)
 | 
				
			|||||||
				read_from_terminal = 1;
 | 
									read_from_terminal = 1;
 | 
				
			||||||
			(void)fcntl(fileno(stdin), F_SETFL, 0);
 | 
								(void)fcntl(fileno(stdin), F_SETFL, 0);
 | 
				
			||||||
#else
 | 
					#else
 | 
				
			||||||
			if ((SSL_version(con) == DTLS1_VERSION) &&
 | 
								i=select(width,(void *)&readfds,NULL,NULL,NULL);
 | 
				
			||||||
				DTLSv1_get_timeout(con, &timeout))
 | 
					 | 
				
			||||||
				timeoutp = &timeout;
 | 
					 | 
				
			||||||
			else
 | 
					 | 
				
			||||||
				timeoutp = NULL;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
			i=select(width,(void *)&readfds,NULL,NULL,timeoutp);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
			if ((SSL_version(con) == DTLS1_VERSION) && DTLSv1_handle_timeout(con) > 0)
 | 
					 | 
				
			||||||
				{
 | 
					 | 
				
			||||||
				BIO_printf(bio_err,"TIMEOUT occured\n");
 | 
					 | 
				
			||||||
				}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
			if (i <= 0) continue;
 | 
								if (i <= 0) continue;
 | 
				
			||||||
			if (FD_ISSET(fileno(stdin),&readfds))
 | 
								if (FD_ISSET(fileno(stdin),&readfds))
 | 
				
			||||||
				read_from_terminal = 1;
 | 
									read_from_terminal = 1;
 | 
				
			||||||
@@ -2336,13 +2130,6 @@ static int init_ssl_connection(SSL *con)
 | 
				
			|||||||
	X509 *peer;
 | 
						X509 *peer;
 | 
				
			||||||
	long verify_error;
 | 
						long verify_error;
 | 
				
			||||||
	MS_STATIC char buf[BUFSIZ];
 | 
						MS_STATIC char buf[BUFSIZ];
 | 
				
			||||||
#if !defined(OPENSSL_NO_TLSEXT) && !defined(OPENSSL_NO_NEXTPROTONEG)
 | 
					 | 
				
			||||||
	const unsigned char *next_proto_neg;
 | 
					 | 
				
			||||||
	unsigned next_proto_neg_len;
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
#ifndef OPENSSL_NO_KRB5
 | 
					 | 
				
			||||||
	char *client_princ;
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if ((i=SSL_accept(con)) <= 0)
 | 
						if ((i=SSL_accept(con)) <= 0)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
@@ -2382,29 +2169,17 @@ static int init_ssl_connection(SSL *con)
 | 
				
			|||||||
		BIO_printf(bio_s_out,"Shared ciphers:%s\n",buf);
 | 
							BIO_printf(bio_s_out,"Shared ciphers:%s\n",buf);
 | 
				
			||||||
	str=SSL_CIPHER_get_name(SSL_get_current_cipher(con));
 | 
						str=SSL_CIPHER_get_name(SSL_get_current_cipher(con));
 | 
				
			||||||
	BIO_printf(bio_s_out,"CIPHER is %s\n",(str != NULL)?str:"(NONE)");
 | 
						BIO_printf(bio_s_out,"CIPHER is %s\n",(str != NULL)?str:"(NONE)");
 | 
				
			||||||
#if !defined(OPENSSL_NO_TLSEXT) && !defined(OPENSSL_NO_NEXTPROTONEG)
 | 
						if (con->hit) BIO_printf(bio_s_out,"Reused session-id\n");
 | 
				
			||||||
	SSL_get0_next_proto_negotiated(con, &next_proto_neg, &next_proto_neg_len);
 | 
					 | 
				
			||||||
	if (next_proto_neg)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		BIO_printf(bio_s_out,"NEXTPROTO is ");
 | 
					 | 
				
			||||||
		BIO_write(bio_s_out, next_proto_neg, next_proto_neg_len);
 | 
					 | 
				
			||||||
		BIO_printf(bio_s_out, "\n");
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	if (SSL_cache_hit(con)) BIO_printf(bio_s_out,"Reused session-id\n");
 | 
					 | 
				
			||||||
	if (SSL_ctrl(con,SSL_CTRL_GET_FLAGS,0,NULL) &
 | 
						if (SSL_ctrl(con,SSL_CTRL_GET_FLAGS,0,NULL) &
 | 
				
			||||||
		TLS1_FLAGS_TLS_PADDING_BUG)
 | 
							TLS1_FLAGS_TLS_PADDING_BUG)
 | 
				
			||||||
		BIO_printf(bio_s_out,"Peer has incorrect TLSv1 block padding\n");
 | 
							BIO_printf(bio_s_out,"Peer has incorrect TLSv1 block padding\n");
 | 
				
			||||||
#ifndef OPENSSL_NO_KRB5
 | 
					#ifndef OPENSSL_NO_KRB5
 | 
				
			||||||
	client_princ = kssl_ctx_get0_client_princ(SSL_get0_kssl_ctx(con));
 | 
						if (con->kssl_ctx->client_princ != NULL)
 | 
				
			||||||
	if (client_princ != NULL)
 | 
					 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		BIO_printf(bio_s_out,"Kerberos peer principal is %s\n",
 | 
							BIO_printf(bio_s_out,"Kerberos peer principal is %s\n",
 | 
				
			||||||
								client_princ);
 | 
								con->kssl_ctx->client_princ);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
#endif /* OPENSSL_NO_KRB5 */
 | 
					#endif /* OPENSSL_NO_KRB5 */
 | 
				
			||||||
	BIO_printf(bio_s_out, "Secure Renegotiation IS%s supported\n",
 | 
					 | 
				
			||||||
		      SSL_get_secure_renegotiation_support(con) ? "" : " NOT");
 | 
					 | 
				
			||||||
	return(1);
 | 
						return(1);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -2448,13 +2223,11 @@ static int www_body(char *hostname, int s, unsigned char *context)
 | 
				
			|||||||
	{
 | 
						{
 | 
				
			||||||
	char *buf=NULL;
 | 
						char *buf=NULL;
 | 
				
			||||||
	int ret=1;
 | 
						int ret=1;
 | 
				
			||||||
	int i,j,k,dot;
 | 
						int i,j,k,blank,dot;
 | 
				
			||||||
	SSL *con;
 | 
						SSL *con;
 | 
				
			||||||
	const SSL_CIPHER *c;
 | 
						const SSL_CIPHER *c;
 | 
				
			||||||
	BIO *io,*ssl_bio,*sbio;
 | 
						BIO *io,*ssl_bio,*sbio;
 | 
				
			||||||
#ifndef OPENSSL_NO_KRB5
 | 
						long total_bytes;
 | 
				
			||||||
	KSSL_CTX *kctx;
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	buf=OPENSSL_malloc(bufsize);
 | 
						buf=OPENSSL_malloc(bufsize);
 | 
				
			||||||
	if (buf == NULL) return(0);
 | 
						if (buf == NULL) return(0);
 | 
				
			||||||
@@ -2486,10 +2259,10 @@ static int www_body(char *hostname, int s, unsigned char *context)
 | 
				
			|||||||
			}
 | 
								}
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
#ifndef OPENSSL_NO_KRB5
 | 
					#ifndef OPENSSL_NO_KRB5
 | 
				
			||||||
	if ((kctx = kssl_ctx_new()) != NULL)
 | 
						if ((con->kssl_ctx = kssl_ctx_new()) != NULL)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		kssl_ctx_setstring(kctx, KSSL_SERVICE, KRB5SVC);
 | 
							kssl_ctx_setstring(con->kssl_ctx, KSSL_SERVICE, KRB5SVC);
 | 
				
			||||||
		kssl_ctx_setstring(kctx, KSSL_KEYTAB, KRB5KEYTAB);
 | 
							kssl_ctx_setstring(con->kssl_ctx, KSSL_KEYTAB, KRB5KEYTAB);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
#endif	/* OPENSSL_NO_KRB5 */
 | 
					#endif	/* OPENSSL_NO_KRB5 */
 | 
				
			||||||
	if(context) SSL_set_session_id_context(con, context,
 | 
						if(context) SSL_set_session_id_context(con, context,
 | 
				
			||||||
@@ -2505,6 +2278,7 @@ static int www_body(char *hostname, int s, unsigned char *context)
 | 
				
			|||||||
		}
 | 
							}
 | 
				
			||||||
	SSL_set_bio(con,sbio,sbio);
 | 
						SSL_set_bio(con,sbio,sbio);
 | 
				
			||||||
	SSL_set_accept_state(con);
 | 
						SSL_set_accept_state(con);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/* SSL_set_fd(con,s); */
 | 
						/* SSL_set_fd(con,s); */
 | 
				
			||||||
	BIO_set_ssl(ssl_bio,con,BIO_CLOSE);
 | 
						BIO_set_ssl(ssl_bio,con,BIO_CLOSE);
 | 
				
			||||||
	BIO_push(io,ssl_bio);
 | 
						BIO_push(io,ssl_bio);
 | 
				
			||||||
@@ -2514,7 +2288,7 @@ static int www_body(char *hostname, int s, unsigned char *context)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	if (s_debug)
 | 
						if (s_debug)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		SSL_set_debug(con, 1);
 | 
							con->debug=1;
 | 
				
			||||||
		BIO_set_callback(SSL_get_rbio(con),bio_dump_callback);
 | 
							BIO_set_callback(SSL_get_rbio(con),bio_dump_callback);
 | 
				
			||||||
		BIO_set_callback_arg(SSL_get_rbio(con),(char *)bio_s_out);
 | 
							BIO_set_callback_arg(SSL_get_rbio(con),(char *)bio_s_out);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
@@ -2524,6 +2298,7 @@ static int www_body(char *hostname, int s, unsigned char *context)
 | 
				
			|||||||
		SSL_set_msg_callback_arg(con, bio_s_out);
 | 
							SSL_set_msg_callback_arg(con, bio_s_out);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						blank=0;
 | 
				
			||||||
	for (;;)
 | 
						for (;;)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		if (hack)
 | 
							if (hack)
 | 
				
			||||||
@@ -2585,32 +2360,6 @@ static int www_body(char *hostname, int s, unsigned char *context)
 | 
				
			|||||||
			STACK_OF(SSL_CIPHER) *sk;
 | 
								STACK_OF(SSL_CIPHER) *sk;
 | 
				
			||||||
			static const char *space="                          ";
 | 
								static const char *space="                          ";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if (www == 1 && strncmp("GET /reneg", buf, 10) == 0)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if (strncmp("GET /renegcert", buf, 14) == 0)
 | 
					 | 
				
			||||||
				SSL_set_verify(con,
 | 
					 | 
				
			||||||
				SSL_VERIFY_PEER|SSL_VERIFY_CLIENT_ONCE,NULL);
 | 
					 | 
				
			||||||
			i=SSL_renegotiate(con);
 | 
					 | 
				
			||||||
			BIO_printf(bio_s_out, "SSL_renegotiate -> %d\n",i);
 | 
					 | 
				
			||||||
			i=SSL_do_handshake(con);
 | 
					 | 
				
			||||||
			if (i <= 0)
 | 
					 | 
				
			||||||
				{
 | 
					 | 
				
			||||||
				BIO_printf(bio_s_out, "SSL_do_handshake() Retval %d\n", SSL_get_error(con, i));
 | 
					 | 
				
			||||||
				ERR_print_errors(bio_err);
 | 
					 | 
				
			||||||
				goto err;
 | 
					 | 
				
			||||||
				}
 | 
					 | 
				
			||||||
			/* EVIL HACK! */
 | 
					 | 
				
			||||||
			SSL_set_state(con, SSL_ST_ACCEPT);
 | 
					 | 
				
			||||||
			i=SSL_do_handshake(con);
 | 
					 | 
				
			||||||
			BIO_printf(bio_s_out, "SSL_do_handshake -> %d\n",i);
 | 
					 | 
				
			||||||
			if (i <= 0)
 | 
					 | 
				
			||||||
				{
 | 
					 | 
				
			||||||
				BIO_printf(bio_s_out, "SSL_do_handshake() Retval %d\n", SSL_get_error(con, i));
 | 
					 | 
				
			||||||
				ERR_print_errors(bio_err);
 | 
					 | 
				
			||||||
				goto err;
 | 
					 | 
				
			||||||
				}
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
			BIO_puts(io,"HTTP/1.0 200 ok\r\nContent-type: text/html\r\n\r\n");
 | 
								BIO_puts(io,"HTTP/1.0 200 ok\r\nContent-type: text/html\r\n\r\n");
 | 
				
			||||||
			BIO_puts(io,"<HTML><BODY BGCOLOR=\"#ffffff\">\n");
 | 
								BIO_puts(io,"<HTML><BODY BGCOLOR=\"#ffffff\">\n");
 | 
				
			||||||
			BIO_puts(io,"<pre>\n");
 | 
								BIO_puts(io,"<pre>\n");
 | 
				
			||||||
@@ -2623,11 +2372,6 @@ static int www_body(char *hostname, int s, unsigned char *context)
 | 
				
			|||||||
				}
 | 
									}
 | 
				
			||||||
			BIO_puts(io,"\n");
 | 
								BIO_puts(io,"\n");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
			BIO_printf(io,
 | 
					 | 
				
			||||||
				"Secure Renegotiation IS%s supported\n",
 | 
					 | 
				
			||||||
		      		SSL_get_secure_renegotiation_support(con) ?
 | 
					 | 
				
			||||||
							"" : " NOT");
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
			/* The following is evil and should not really
 | 
								/* The following is evil and should not really
 | 
				
			||||||
			 * be done */
 | 
								 * be done */
 | 
				
			||||||
			BIO_printf(io,"Ciphers supported in s_server binary\n");
 | 
								BIO_printf(io,"Ciphers supported in s_server binary\n");
 | 
				
			||||||
@@ -2666,7 +2410,7 @@ static int www_body(char *hostname, int s, unsigned char *context)
 | 
				
			|||||||
					}
 | 
										}
 | 
				
			||||||
				BIO_puts(io,"\n");
 | 
									BIO_puts(io,"\n");
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
			BIO_printf(io,(SSL_cache_hit(con)
 | 
								BIO_printf(io,((con->hit)
 | 
				
			||||||
				?"---\nReused, "
 | 
									?"---\nReused, "
 | 
				
			||||||
				:"---\nNew, "));
 | 
									:"---\nNew, "));
 | 
				
			||||||
			c=SSL_get_current_cipher(con);
 | 
								c=SSL_get_current_cipher(con);
 | 
				
			||||||
@@ -2784,6 +2528,7 @@ static int www_body(char *hostname, int s, unsigned char *context)
 | 
				
			|||||||
                                        BIO_puts(io,"HTTP/1.0 200 ok\r\nContent-type: text/plain\r\n\r\n");
 | 
					                                        BIO_puts(io,"HTTP/1.0 200 ok\r\nContent-type: text/plain\r\n\r\n");
 | 
				
			||||||
                                }
 | 
					                                }
 | 
				
			||||||
			/* send the file */
 | 
								/* send the file */
 | 
				
			||||||
 | 
								total_bytes=0;
 | 
				
			||||||
			for (;;)
 | 
								for (;;)
 | 
				
			||||||
				{
 | 
									{
 | 
				
			||||||
				i=BIO_read(file,buf,bufsize);
 | 
									i=BIO_read(file,buf,bufsize);
 | 
				
			||||||
@@ -2913,115 +2658,3 @@ static int generate_session_id(const SSL *ssl, unsigned char *id,
 | 
				
			|||||||
		return 0;
 | 
							return 0;
 | 
				
			||||||
	return 1;
 | 
						return 1;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					 | 
				
			||||||
/* By default s_server uses an in-memory cache which caches SSL_SESSION
 | 
					 | 
				
			||||||
 * structures without any serialisation. This hides some bugs which only
 | 
					 | 
				
			||||||
 * become apparent in deployed servers. By implementing a basic external
 | 
					 | 
				
			||||||
 * session cache some issues can be debugged using s_server.
 | 
					 | 
				
			||||||
 */
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
typedef struct simple_ssl_session_st
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	unsigned char *id;
 | 
					 | 
				
			||||||
	unsigned int idlen;
 | 
					 | 
				
			||||||
	unsigned char *der;
 | 
					 | 
				
			||||||
	int derlen;
 | 
					 | 
				
			||||||
	struct simple_ssl_session_st *next;
 | 
					 | 
				
			||||||
	} simple_ssl_session;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
static simple_ssl_session *first = NULL;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
static int add_session(SSL *ssl, SSL_SESSION *session)
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	simple_ssl_session *sess;
 | 
					 | 
				
			||||||
	unsigned char *p;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	sess = OPENSSL_malloc(sizeof(simple_ssl_session));
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	sess->idlen = SSL_SESSION_get_id_len(session);
 | 
					 | 
				
			||||||
	sess->derlen = i2d_SSL_SESSION(session, NULL);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	sess->id = BUF_memdup(SSL_SESSION_get0_id(session), sess->idlen);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	sess->der = OPENSSL_malloc(sess->derlen);
 | 
					 | 
				
			||||||
	p = sess->der;
 | 
					 | 
				
			||||||
	i2d_SSL_SESSION(session, &p);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	sess->next = first;
 | 
					 | 
				
			||||||
	first = sess;
 | 
					 | 
				
			||||||
	BIO_printf(bio_err, "New session added to external cache\n");
 | 
					 | 
				
			||||||
	return 0;
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
static SSL_SESSION *get_session(SSL *ssl, unsigned char *id, int idlen,
 | 
					 | 
				
			||||||
					int *do_copy)
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	simple_ssl_session *sess;
 | 
					 | 
				
			||||||
	*do_copy = 0;
 | 
					 | 
				
			||||||
	for (sess = first; sess; sess = sess->next)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		if (idlen == (int)sess->idlen && !memcmp(sess->id, id, idlen))
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			const unsigned char *p = sess->der;
 | 
					 | 
				
			||||||
			BIO_printf(bio_err, "Lookup session: cache hit\n");
 | 
					 | 
				
			||||||
			return d2i_SSL_SESSION(NULL, &p, sess->derlen);
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	BIO_printf(bio_err, "Lookup session: cache miss\n");
 | 
					 | 
				
			||||||
	return NULL;
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
static void del_session(SSL_CTX *sctx, SSL_SESSION *session)
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	simple_ssl_session *sess, *prev = NULL;
 | 
					 | 
				
			||||||
	const unsigned char *id = SSL_SESSION_get0_id(session);
 | 
					 | 
				
			||||||
	unsigned int idlen = SSL_SESSION_get_id_len(session);
 | 
					 | 
				
			||||||
	for (sess = first; sess; sess = sess->next)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		if (idlen == sess->idlen && !memcmp(sess->id, id, idlen))
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if(prev)
 | 
					 | 
				
			||||||
				prev->next = sess->next;
 | 
					 | 
				
			||||||
			else
 | 
					 | 
				
			||||||
				first = sess->next;
 | 
					 | 
				
			||||||
			OPENSSL_free(sess->id);
 | 
					 | 
				
			||||||
			OPENSSL_free(sess->der);
 | 
					 | 
				
			||||||
			OPENSSL_free(sess);
 | 
					 | 
				
			||||||
			return;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		prev = sess;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
static void init_session_cache_ctx(SSL_CTX *sctx)
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	SSL_CTX_set_session_cache_mode(sctx,
 | 
					 | 
				
			||||||
			SSL_SESS_CACHE_NO_INTERNAL|SSL_SESS_CACHE_SERVER);
 | 
					 | 
				
			||||||
	SSL_CTX_sess_set_new_cb(sctx, add_session);
 | 
					 | 
				
			||||||
        SSL_CTX_sess_set_get_cb(sctx, get_session);
 | 
					 | 
				
			||||||
        SSL_CTX_sess_set_remove_cb(sctx, del_session);
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
static void free_sessions(void)
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	simple_ssl_session *sess, *tsess;
 | 
					 | 
				
			||||||
	for (sess = first; sess;)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		OPENSSL_free(sess->id);
 | 
					 | 
				
			||||||
		OPENSSL_free(sess->der);
 | 
					 | 
				
			||||||
		tsess = sess;
 | 
					 | 
				
			||||||
		sess = sess->next;
 | 
					 | 
				
			||||||
		OPENSSL_free(tsess);
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	first = NULL;
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
	
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 
 | 
				
			|||||||
@@ -96,8 +96,7 @@ static struct hostent *GetHostByName(char *name);
 | 
				
			|||||||
static void ssl_sock_cleanup(void);
 | 
					static void ssl_sock_cleanup(void);
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
static int ssl_sock_init(void);
 | 
					static int ssl_sock_init(void);
 | 
				
			||||||
static int init_client_ip(int *sock, const unsigned char ip[4], int port,
 | 
					static int init_client_ip(int *sock,unsigned char ip[4], int port, int type);
 | 
				
			||||||
			  int type);
 | 
					 | 
				
			||||||
static int init_server(int *sock, int port, int type);
 | 
					static int init_server(int *sock, int port, int type);
 | 
				
			||||||
static int init_server_long(int *sock, int port,char *ip, int type);
 | 
					static int init_server_long(int *sock, int port,char *ip, int type);
 | 
				
			||||||
static int do_accept(int acc_sock, int *sock, char **host);
 | 
					static int do_accept(int acc_sock, int *sock, char **host);
 | 
				
			||||||
@@ -233,7 +232,6 @@ int init_client(int *sock, char *host, int port, int type)
 | 
				
			|||||||
	{
 | 
						{
 | 
				
			||||||
	unsigned char ip[4];
 | 
						unsigned char ip[4];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	ip[0] = ip[1] = ip[2] = ip[3] = 0;
 | 
					 | 
				
			||||||
	if (!host_ip(host,&(ip[0])))
 | 
						if (!host_ip(host,&(ip[0])))
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		return(0);
 | 
							return(0);
 | 
				
			||||||
@@ -241,8 +239,7 @@ int init_client(int *sock, char *host, int port, int type)
 | 
				
			|||||||
	return(init_client_ip(sock,ip,port,type));
 | 
						return(init_client_ip(sock,ip,port,type));
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static int init_client_ip(int *sock, const unsigned char ip[4], int port,
 | 
					static int init_client_ip(int *sock, unsigned char ip[4], int port, int type)
 | 
				
			||||||
			  int type)
 | 
					 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
	unsigned long addr;
 | 
						unsigned long addr;
 | 
				
			||||||
	struct sockaddr_in them;
 | 
						struct sockaddr_in them;
 | 
				
			||||||
@@ -324,7 +321,7 @@ static int init_server_long(int *sock, int port, char *ip, int type)
 | 
				
			|||||||
	{
 | 
						{
 | 
				
			||||||
	int ret=0;
 | 
						int ret=0;
 | 
				
			||||||
	struct sockaddr_in server;
 | 
						struct sockaddr_in server;
 | 
				
			||||||
	int s= -1;
 | 
						int s= -1,i;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (!ssl_sock_init()) return(0);
 | 
						if (!ssl_sock_init()) return(0);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -363,6 +360,7 @@ static int init_server_long(int *sock, int port, char *ip, int type)
 | 
				
			|||||||
		}
 | 
							}
 | 
				
			||||||
	/* Make it 128 for linux */
 | 
						/* Make it 128 for linux */
 | 
				
			||||||
	if (type==SOCK_STREAM && listen(s,128) == -1) goto err;
 | 
						if (type==SOCK_STREAM && listen(s,128) == -1) goto err;
 | 
				
			||||||
 | 
						i=0;
 | 
				
			||||||
	*sock=s;
 | 
						*sock=s;
 | 
				
			||||||
	ret=1;
 | 
						ret=1;
 | 
				
			||||||
err:
 | 
					err:
 | 
				
			||||||
@@ -380,7 +378,7 @@ static int init_server(int *sock, int port, int type)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
static int do_accept(int acc_sock, int *sock, char **host)
 | 
					static int do_accept(int acc_sock, int *sock, char **host)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
	int ret;
 | 
						int ret,i;
 | 
				
			||||||
	struct hostent *h1,*h2;
 | 
						struct hostent *h1,*h2;
 | 
				
			||||||
	static struct sockaddr_in from;
 | 
						static struct sockaddr_in from;
 | 
				
			||||||
	int len;
 | 
						int len;
 | 
				
			||||||
@@ -403,7 +401,6 @@ redoit:
 | 
				
			|||||||
	if (ret == INVALID_SOCKET)
 | 
						if (ret == INVALID_SOCKET)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
#if defined(OPENSSL_SYS_WINDOWS) || (defined(OPENSSL_SYS_NETWARE) && !defined(NETWARE_BSDSOCK))
 | 
					#if defined(OPENSSL_SYS_WINDOWS) || (defined(OPENSSL_SYS_NETWARE) && !defined(NETWARE_BSDSOCK))
 | 
				
			||||||
		int i;
 | 
					 | 
				
			||||||
		i=WSAGetLastError();
 | 
							i=WSAGetLastError();
 | 
				
			||||||
		BIO_printf(bio_err,"accept error %d\n",i);
 | 
							BIO_printf(bio_err,"accept error %d\n",i);
 | 
				
			||||||
#else
 | 
					#else
 | 
				
			||||||
@@ -458,6 +455,7 @@ redoit:
 | 
				
			|||||||
			BIO_printf(bio_err,"gethostbyname failure\n");
 | 
								BIO_printf(bio_err,"gethostbyname failure\n");
 | 
				
			||||||
			return(0);
 | 
								return(0);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
 | 
							i=0;
 | 
				
			||||||
		if (h2->h_addrtype != AF_INET)
 | 
							if (h2->h_addrtype != AF_INET)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			BIO_printf(bio_err,"gethostbyname addr is not AF_INET\n");
 | 
								BIO_printf(bio_err,"gethostbyname addr is not AF_INET\n");
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -90,7 +90,6 @@ int MAIN(int, char **);
 | 
				
			|||||||
int MAIN(int argc, char **argv)
 | 
					int MAIN(int argc, char **argv)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
	SSL_SESSION *x=NULL;
 | 
						SSL_SESSION *x=NULL;
 | 
				
			||||||
	X509 *peer = NULL;
 | 
					 | 
				
			||||||
	int ret=1,i,num,badops=0;
 | 
						int ret=1,i,num,badops=0;
 | 
				
			||||||
	BIO *out=NULL;
 | 
						BIO *out=NULL;
 | 
				
			||||||
	int informat,outformat;
 | 
						int informat,outformat;
 | 
				
			||||||
@@ -164,17 +163,16 @@ bad:
 | 
				
			|||||||
	ERR_load_crypto_strings();
 | 
						ERR_load_crypto_strings();
 | 
				
			||||||
	x=load_sess_id(infile,informat);
 | 
						x=load_sess_id(infile,informat);
 | 
				
			||||||
	if (x == NULL) { goto end; }
 | 
						if (x == NULL) { goto end; }
 | 
				
			||||||
	peer = SSL_SESSION_get0_peer(x);
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if(context)
 | 
						if(context)
 | 
				
			||||||
	    {
 | 
						    {
 | 
				
			||||||
	    size_t ctx_len = strlen(context);
 | 
						    x->sid_ctx_length=strlen(context);
 | 
				
			||||||
	    if(ctx_len > SSL_MAX_SID_CTX_LENGTH)
 | 
						    if(x->sid_ctx_length > SSL_MAX_SID_CTX_LENGTH)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		BIO_printf(bio_err,"Context too long\n");
 | 
							BIO_printf(bio_err,"Context too long\n");
 | 
				
			||||||
		goto end;
 | 
							goto end;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	    SSL_SESSION_set1_id_context(x, (unsigned char *)context, ctx_len);
 | 
						    memcpy(x->sid_ctx,context,x->sid_ctx_length);
 | 
				
			||||||
	    }
 | 
						    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef undef
 | 
					#ifdef undef
 | 
				
			||||||
@@ -233,10 +231,10 @@ bad:
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
		if (cert)
 | 
							if (cert)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (peer == NULL)
 | 
								if (x->peer == NULL)
 | 
				
			||||||
				BIO_puts(out,"No certificate present\n");
 | 
									BIO_puts(out,"No certificate present\n");
 | 
				
			||||||
			else
 | 
								else
 | 
				
			||||||
				X509_print(out,peer);
 | 
									X509_print(out,x->peer);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -255,12 +253,12 @@ bad:
 | 
				
			|||||||
			goto end;
 | 
								goto end;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	else if (!noout && (peer != NULL)) /* just print the certificate */
 | 
						else if (!noout && (x->peer != NULL)) /* just print the certificate */
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		if 	(outformat == FORMAT_ASN1)
 | 
							if 	(outformat == FORMAT_ASN1)
 | 
				
			||||||
			i=(int)i2d_X509_bio(out,peer);
 | 
								i=(int)i2d_X509_bio(out,x->peer);
 | 
				
			||||||
		else if (outformat == FORMAT_PEM)
 | 
							else if (outformat == FORMAT_PEM)
 | 
				
			||||||
			i=PEM_write_bio_X509(out,peer);
 | 
								i=PEM_write_bio_X509(out,x->peer);
 | 
				
			||||||
		else	{
 | 
							else	{
 | 
				
			||||||
			BIO_printf(bio_err,"bad output format specified for outfile\n");
 | 
								BIO_printf(bio_err,"bad output format specified for outfile\n");
 | 
				
			||||||
			goto end;
 | 
								goto end;
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										38
									
								
								apps/smime.c
									
									
									
									
									
								
							
							
						
						
									
										38
									
								
								apps/smime.c
									
									
									
									
									
								
							@@ -93,7 +93,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	const char *inmode = "r", *outmode = "w";
 | 
						const char *inmode = "r", *outmode = "w";
 | 
				
			||||||
	char *infile = NULL, *outfile = NULL;
 | 
						char *infile = NULL, *outfile = NULL;
 | 
				
			||||||
	char *signerfile = NULL, *recipfile = NULL;
 | 
						char *signerfile = NULL, *recipfile = NULL;
 | 
				
			||||||
	STACK_OF(OPENSSL_STRING) *sksigners = NULL, *skkeys = NULL;
 | 
						STACK_OF(STRING) *sksigners = NULL, *skkeys = NULL;
 | 
				
			||||||
	char *certfile = NULL, *keyfile = NULL, *contfile=NULL;
 | 
						char *certfile = NULL, *keyfile = NULL, *contfile=NULL;
 | 
				
			||||||
	const EVP_CIPHER *cipher = NULL;
 | 
						const EVP_CIPHER *cipher = NULL;
 | 
				
			||||||
	PKCS7 *p7 = NULL;
 | 
						PKCS7 *p7 = NULL;
 | 
				
			||||||
@@ -260,13 +260,13 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			if (signerfile)
 | 
								if (signerfile)
 | 
				
			||||||
				{
 | 
									{
 | 
				
			||||||
				if (!sksigners)
 | 
									if (!sksigners)
 | 
				
			||||||
					sksigners = sk_OPENSSL_STRING_new_null();
 | 
										sksigners = sk_STRING_new_null();
 | 
				
			||||||
				sk_OPENSSL_STRING_push(sksigners, signerfile);
 | 
									sk_STRING_push(sksigners, signerfile);
 | 
				
			||||||
				if (!keyfile)
 | 
									if (!keyfile)
 | 
				
			||||||
					keyfile = signerfile;
 | 
										keyfile = signerfile;
 | 
				
			||||||
				if (!skkeys)
 | 
									if (!skkeys)
 | 
				
			||||||
					skkeys = sk_OPENSSL_STRING_new_null();
 | 
										skkeys = sk_STRING_new_null();
 | 
				
			||||||
				sk_OPENSSL_STRING_push(skkeys, keyfile);
 | 
									sk_STRING_push(skkeys, keyfile);
 | 
				
			||||||
				keyfile = NULL;
 | 
									keyfile = NULL;
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
			signerfile = *++args;
 | 
								signerfile = *++args;
 | 
				
			||||||
@@ -302,12 +302,12 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
					goto argerr;
 | 
										goto argerr;
 | 
				
			||||||
					}
 | 
										}
 | 
				
			||||||
				if (!sksigners)
 | 
									if (!sksigners)
 | 
				
			||||||
					sksigners = sk_OPENSSL_STRING_new_null();
 | 
										sksigners = sk_STRING_new_null();
 | 
				
			||||||
				sk_OPENSSL_STRING_push(sksigners, signerfile);
 | 
									sk_STRING_push(sksigners, signerfile);
 | 
				
			||||||
				signerfile = NULL;
 | 
									signerfile = NULL;
 | 
				
			||||||
				if (!skkeys)
 | 
									if (!skkeys)
 | 
				
			||||||
					skkeys = sk_OPENSSL_STRING_new_null();
 | 
										skkeys = sk_STRING_new_null();
 | 
				
			||||||
				sk_OPENSSL_STRING_push(skkeys, keyfile);
 | 
									sk_STRING_push(skkeys, keyfile);
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
			keyfile = *++args;
 | 
								keyfile = *++args;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
@@ -389,13 +389,13 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		if (signerfile)
 | 
							if (signerfile)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (!sksigners)
 | 
								if (!sksigners)
 | 
				
			||||||
				sksigners = sk_OPENSSL_STRING_new_null();
 | 
									sksigners = sk_STRING_new_null();
 | 
				
			||||||
			sk_OPENSSL_STRING_push(sksigners, signerfile);
 | 
								sk_STRING_push(sksigners, signerfile);
 | 
				
			||||||
			if (!skkeys)
 | 
								if (!skkeys)
 | 
				
			||||||
				skkeys = sk_OPENSSL_STRING_new_null();
 | 
									skkeys = sk_STRING_new_null();
 | 
				
			||||||
			if (!keyfile)
 | 
								if (!keyfile)
 | 
				
			||||||
				keyfile = signerfile;
 | 
									keyfile = signerfile;
 | 
				
			||||||
			sk_OPENSSL_STRING_push(skkeys, keyfile);
 | 
								sk_STRING_push(skkeys, keyfile);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		if (!sksigners)
 | 
							if (!sksigners)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
@@ -671,7 +671,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		{
 | 
							{
 | 
				
			||||||
		if (!(store = setup_verify(bio_err, CAfile, CApath)))
 | 
							if (!(store = setup_verify(bio_err, CAfile, CApath)))
 | 
				
			||||||
			goto end;
 | 
								goto end;
 | 
				
			||||||
		X509_STORE_set_verify_cb(store, smime_cb);
 | 
							X509_STORE_set_verify_cb_func(store, smime_cb);
 | 
				
			||||||
		if (vpm)
 | 
							if (vpm)
 | 
				
			||||||
			X509_STORE_set1_param(store, vpm);
 | 
								X509_STORE_set1_param(store, vpm);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
@@ -707,10 +707,10 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			}
 | 
								}
 | 
				
			||||||
		else
 | 
							else
 | 
				
			||||||
			flags |= PKCS7_REUSE_DIGEST;
 | 
								flags |= PKCS7_REUSE_DIGEST;
 | 
				
			||||||
		for (i = 0; i < sk_OPENSSL_STRING_num(sksigners); i++)
 | 
							for (i = 0; i < sk_STRING_num(sksigners); i++)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			signerfile = sk_OPENSSL_STRING_value(sksigners, i);
 | 
								signerfile = sk_STRING_value(sksigners, i);
 | 
				
			||||||
			keyfile = sk_OPENSSL_STRING_value(skkeys, i);
 | 
								keyfile = sk_STRING_value(skkeys, i);
 | 
				
			||||||
			signer = load_cert(bio_err, signerfile,FORMAT_PEM, NULL,
 | 
								signer = load_cert(bio_err, signerfile,FORMAT_PEM, NULL,
 | 
				
			||||||
					e, "signer certificate");
 | 
										e, "signer certificate");
 | 
				
			||||||
			if (!signer)
 | 
								if (!signer)
 | 
				
			||||||
@@ -807,9 +807,9 @@ end:
 | 
				
			|||||||
	if (vpm)
 | 
						if (vpm)
 | 
				
			||||||
		X509_VERIFY_PARAM_free(vpm);
 | 
							X509_VERIFY_PARAM_free(vpm);
 | 
				
			||||||
	if (sksigners)
 | 
						if (sksigners)
 | 
				
			||||||
		sk_OPENSSL_STRING_free(sksigners);
 | 
							sk_STRING_free(sksigners);
 | 
				
			||||||
	if (skkeys)
 | 
						if (skkeys)
 | 
				
			||||||
		sk_OPENSSL_STRING_free(skkeys);
 | 
							sk_STRING_free(skkeys);
 | 
				
			||||||
	X509_STORE_free(store);
 | 
						X509_STORE_free(store);
 | 
				
			||||||
	X509_free(cert);
 | 
						X509_free(cert);
 | 
				
			||||||
	X509_free(recip);
 | 
						X509_free(recip);
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										116
									
								
								apps/speed.c
									
									
									
									
									
								
							
							
						
						
									
										116
									
								
								apps/speed.c
									
									
									
									
									
								
							@@ -183,20 +183,9 @@
 | 
				
			|||||||
#ifndef OPENSSL_NO_ECDH
 | 
					#ifndef OPENSSL_NO_ECDH
 | 
				
			||||||
#include <openssl/ecdh.h>
 | 
					#include <openssl/ecdh.h>
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
#include <openssl/modes.h>
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef HAVE_FORK
 | 
					#if !defined(OPENSSL_SYS_VMS) && !defined(OPENSSL_SYS_WINDOWS) && !defined(OPENSSL_SYS_MACINTOSH_CLASSIC) && !defined(OPENSSL_SYS_OS2) && !defined(OPENSSL_SYS_NETWARE)
 | 
				
			||||||
# if defined(OPENSSL_SYS_VMS) || defined(OPENSSL_SYS_WINDOWS) || defined(OPENSSL_SYS_MACINTOSH_CLASSIC) || defined(OPENSSL_SYS_OS2) || defined(OPENSSL_SYS_NETWARE)
 | 
					# define HAVE_FORK 1
 | 
				
			||||||
#  define HAVE_FORK 0
 | 
					 | 
				
			||||||
# else
 | 
					 | 
				
			||||||
#  define HAVE_FORK 1
 | 
					 | 
				
			||||||
# endif
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#if HAVE_FORK
 | 
					 | 
				
			||||||
#undef NO_FORK
 | 
					 | 
				
			||||||
#else
 | 
					 | 
				
			||||||
#define NO_FORK
 | 
					 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#undef BUFSIZE
 | 
					#undef BUFSIZE
 | 
				
			||||||
@@ -211,11 +200,11 @@ static void print_message(const char *s,long num,int length);
 | 
				
			|||||||
static void pkey_print_message(const char *str, const char *str2,
 | 
					static void pkey_print_message(const char *str, const char *str2,
 | 
				
			||||||
	long num, int bits, int sec);
 | 
						long num, int bits, int sec);
 | 
				
			||||||
static void print_result(int alg,int run_no,int count,double time_used);
 | 
					static void print_result(int alg,int run_no,int count,double time_used);
 | 
				
			||||||
#ifndef NO_FORK
 | 
					#ifdef HAVE_FORK
 | 
				
			||||||
static int do_multi(int multi);
 | 
					static int do_multi(int multi);
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define ALGOR_NUM	30
 | 
					#define ALGOR_NUM	29
 | 
				
			||||||
#define SIZE_NUM	5
 | 
					#define SIZE_NUM	5
 | 
				
			||||||
#define RSA_NUM		4
 | 
					#define RSA_NUM		4
 | 
				
			||||||
#define DSA_NUM		3
 | 
					#define DSA_NUM		3
 | 
				
			||||||
@@ -230,15 +219,11 @@ static const char *names[ALGOR_NUM]={
 | 
				
			|||||||
  "aes-128 cbc","aes-192 cbc","aes-256 cbc",
 | 
					  "aes-128 cbc","aes-192 cbc","aes-256 cbc",
 | 
				
			||||||
  "camellia-128 cbc","camellia-192 cbc","camellia-256 cbc",
 | 
					  "camellia-128 cbc","camellia-192 cbc","camellia-256 cbc",
 | 
				
			||||||
  "evp","sha256","sha512","whirlpool",
 | 
					  "evp","sha256","sha512","whirlpool",
 | 
				
			||||||
  "aes-128 ige","aes-192 ige","aes-256 ige","ghash" };
 | 
					  "aes-128 ige","aes-192 ige","aes-256 ige"};
 | 
				
			||||||
static double results[ALGOR_NUM][SIZE_NUM];
 | 
					static double results[ALGOR_NUM][SIZE_NUM];
 | 
				
			||||||
static int lengths[SIZE_NUM]={16,64,256,1024,8*1024};
 | 
					static int lengths[SIZE_NUM]={16,64,256,1024,8*1024};
 | 
				
			||||||
#ifndef OPENSSL_NO_RSA
 | 
					 | 
				
			||||||
static double rsa_results[RSA_NUM][2];
 | 
					static double rsa_results[RSA_NUM][2];
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
#ifndef OPENSSL_NO_DSA
 | 
					 | 
				
			||||||
static double dsa_results[DSA_NUM][2];
 | 
					static double dsa_results[DSA_NUM][2];
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
#ifndef OPENSSL_NO_ECDSA
 | 
					#ifndef OPENSSL_NO_ECDSA
 | 
				
			||||||
static double ecdsa_results[EC_NUM][2];
 | 
					static double ecdsa_results[EC_NUM][2];
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
@@ -288,11 +273,9 @@ static DWORD WINAPI sleepy(VOID *arg)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
static double Time_F(int s)
 | 
					static double Time_F(int s)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
	double ret;
 | 
					 | 
				
			||||||
	static HANDLE thr;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if (s == START)
 | 
						if (s == START)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
 | 
							HANDLE	thr;
 | 
				
			||||||
		schlock = 0;
 | 
							schlock = 0;
 | 
				
			||||||
		thr = CreateThread(NULL,4096,sleepy,NULL,0,NULL);
 | 
							thr = CreateThread(NULL,4096,sleepy,NULL,0,NULL);
 | 
				
			||||||
		if (thr==NULL)
 | 
							if (thr==NULL)
 | 
				
			||||||
@@ -301,25 +284,17 @@ static double Time_F(int s)
 | 
				
			|||||||
			BIO_printf(bio_err,"unable to CreateThread (%d)",ret);
 | 
								BIO_printf(bio_err,"unable to CreateThread (%d)",ret);
 | 
				
			||||||
			ExitProcess(ret);
 | 
								ExitProcess(ret);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
 | 
							CloseHandle(thr);		/* detach the thread	*/
 | 
				
			||||||
		while (!schlock) Sleep(0);	/* scheduler spinlock	*/
 | 
							while (!schlock) Sleep(0);	/* scheduler spinlock	*/
 | 
				
			||||||
		ret = app_tminterval(s,usertime);
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	else
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		ret = app_tminterval(s,usertime);
 | 
					 | 
				
			||||||
		if (run) TerminateThread(thr,0);
 | 
					 | 
				
			||||||
		CloseHandle(thr);
 | 
					 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	return ret;
 | 
						return app_tminterval(s,usertime);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
#else
 | 
					#else
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static double Time_F(int s)
 | 
					static double Time_F(int s)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
	double ret = app_tminterval(s,usertime);
 | 
						return app_tminterval(s,usertime);
 | 
				
			||||||
	if (s == STOP) alarm(0);
 | 
					 | 
				
			||||||
	return ret;
 | 
					 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -345,6 +320,9 @@ int MAIN(int, char **);
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
int MAIN(int argc, char **argv)
 | 
					int MAIN(int argc, char **argv)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
 | 
					#ifndef OPENSSL_NO_ENGINE
 | 
				
			||||||
 | 
						ENGINE *e = NULL;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
	unsigned char *buf=NULL,*buf2=NULL;
 | 
						unsigned char *buf=NULL,*buf2=NULL;
 | 
				
			||||||
	int mret=1;
 | 
						int mret=1;
 | 
				
			||||||
	long count=0,save_count=0;
 | 
						long count=0,save_count=0;
 | 
				
			||||||
@@ -438,6 +416,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	unsigned char DES_iv[8];
 | 
						unsigned char DES_iv[8];
 | 
				
			||||||
	unsigned char iv[2*MAX_BLOCK_SIZE/8];
 | 
						unsigned char iv[2*MAX_BLOCK_SIZE/8];
 | 
				
			||||||
#ifndef OPENSSL_NO_DES
 | 
					#ifndef OPENSSL_NO_DES
 | 
				
			||||||
 | 
						DES_cblock *buf_as_des_cblock = NULL;
 | 
				
			||||||
	static DES_cblock key ={0x12,0x34,0x56,0x78,0x9a,0xbc,0xde,0xf0};
 | 
						static DES_cblock key ={0x12,0x34,0x56,0x78,0x9a,0xbc,0xde,0xf0};
 | 
				
			||||||
	static DES_cblock key2={0x34,0x56,0x78,0x9a,0xbc,0xde,0xf0,0x12};
 | 
						static DES_cblock key2={0x34,0x56,0x78,0x9a,0xbc,0xde,0xf0,0x12};
 | 
				
			||||||
	static DES_cblock key3={0x56,0x78,0x9a,0xbc,0xde,0xf0,0x12,0x34};
 | 
						static DES_cblock key3={0x56,0x78,0x9a,0xbc,0xde,0xf0,0x12,0x34};
 | 
				
			||||||
@@ -480,7 +459,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
#define D_IGE_128_AES   26
 | 
					#define D_IGE_128_AES   26
 | 
				
			||||||
#define D_IGE_192_AES   27
 | 
					#define D_IGE_192_AES   27
 | 
				
			||||||
#define D_IGE_256_AES   28
 | 
					#define D_IGE_256_AES   28
 | 
				
			||||||
#define D_GHASH         29
 | 
					 | 
				
			||||||
	double d=0.0;
 | 
						double d=0.0;
 | 
				
			||||||
	long c[ALGOR_NUM][SIZE_NUM];
 | 
						long c[ALGOR_NUM][SIZE_NUM];
 | 
				
			||||||
#define	R_DSA_512	0
 | 
					#define	R_DSA_512	0
 | 
				
			||||||
@@ -609,7 +587,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	const EVP_CIPHER *evp_cipher=NULL;
 | 
						const EVP_CIPHER *evp_cipher=NULL;
 | 
				
			||||||
	const EVP_MD *evp_md=NULL;
 | 
						const EVP_MD *evp_md=NULL;
 | 
				
			||||||
	int decrypt=0;
 | 
						int decrypt=0;
 | 
				
			||||||
#ifndef NO_FORK
 | 
					#ifdef HAVE_FORK
 | 
				
			||||||
	int multi=0;
 | 
						int multi=0;
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -652,6 +630,9 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		BIO_printf(bio_err,"out of memory\n");
 | 
							BIO_printf(bio_err,"out of memory\n");
 | 
				
			||||||
		goto end;
 | 
							goto end;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					#ifndef OPENSSL_NO_DES
 | 
				
			||||||
 | 
						buf_as_des_cblock = (DES_cblock *)buf;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
	if ((buf2=(unsigned char *)OPENSSL_malloc((int)BUFSIZE)) == NULL)
 | 
						if ((buf2=(unsigned char *)OPENSSL_malloc((int)BUFSIZE)) == NULL)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		BIO_printf(bio_err,"out of memory\n");
 | 
							BIO_printf(bio_err,"out of memory\n");
 | 
				
			||||||
@@ -726,7 +707,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
				BIO_printf(bio_err,"no engine given\n");
 | 
									BIO_printf(bio_err,"no engine given\n");
 | 
				
			||||||
				goto end;
 | 
									goto end;
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
                        setup_engine(bio_err, *argv, 0);
 | 
					                        e = setup_engine(bio_err, *argv, 0);
 | 
				
			||||||
			/* j will be increased again further down.  We just
 | 
								/* j will be increased again further down.  We just
 | 
				
			||||||
			   don't want speed to confuse an engine with an
 | 
								   don't want speed to confuse an engine with an
 | 
				
			||||||
			   algorithm, especially when none is given (which
 | 
								   algorithm, especially when none is given (which
 | 
				
			||||||
@@ -734,7 +715,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			j--;
 | 
								j--;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
#ifndef NO_FORK
 | 
					#ifdef HAVE_FORK
 | 
				
			||||||
		else if	((argc > 0) && (strcmp(*argv,"-multi") == 0))
 | 
							else if	((argc > 0) && (strcmp(*argv,"-multi") == 0))
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			argc--;
 | 
								argc--;
 | 
				
			||||||
@@ -906,10 +887,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			doit[D_CBC_192_AES]=1;
 | 
								doit[D_CBC_192_AES]=1;
 | 
				
			||||||
			doit[D_CBC_256_AES]=1;
 | 
								doit[D_CBC_256_AES]=1;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else if (strcmp(*argv,"ghash") == 0)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			doit[D_GHASH]=1;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		else
 | 
							else
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
#ifndef OPENSSL_NO_CAMELLIA
 | 
					#ifndef OPENSSL_NO_CAMELLIA
 | 
				
			||||||
@@ -1126,7 +1103,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			BIO_printf(bio_err,"-evp e          use EVP e.\n");
 | 
								BIO_printf(bio_err,"-evp e          use EVP e.\n");
 | 
				
			||||||
			BIO_printf(bio_err,"-decrypt        time decryption instead of encryption (only EVP).\n");
 | 
								BIO_printf(bio_err,"-decrypt        time decryption instead of encryption (only EVP).\n");
 | 
				
			||||||
			BIO_printf(bio_err,"-mr             produce machine readable output.\n");
 | 
								BIO_printf(bio_err,"-mr             produce machine readable output.\n");
 | 
				
			||||||
#ifndef NO_FORK
 | 
					#ifdef HAVE_FORK
 | 
				
			||||||
			BIO_printf(bio_err,"-multi n        run n benchmarks in parallel.\n");
 | 
								BIO_printf(bio_err,"-multi n        run n benchmarks in parallel.\n");
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
			goto end;
 | 
								goto end;
 | 
				
			||||||
@@ -1136,7 +1113,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		j++;
 | 
							j++;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef NO_FORK
 | 
					#ifdef HAVE_FORK
 | 
				
			||||||
	if(multi && do_multi(multi))
 | 
						if(multi && do_multi(multi))
 | 
				
			||||||
		goto show_res;
 | 
							goto show_res;
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
@@ -1152,14 +1129,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			rsa_doit[i]=1;
 | 
								rsa_doit[i]=1;
 | 
				
			||||||
		for (i=0; i<DSA_NUM; i++)
 | 
							for (i=0; i<DSA_NUM; i++)
 | 
				
			||||||
			dsa_doit[i]=1;
 | 
								dsa_doit[i]=1;
 | 
				
			||||||
#ifndef OPENSSL_NO_ECDSA
 | 
					 | 
				
			||||||
		for (i=0; i<EC_NUM; i++)
 | 
					 | 
				
			||||||
			ecdsa_doit[i]=1;
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
#ifndef OPENSSL_NO_ECDH
 | 
					 | 
				
			||||||
		for (i=0; i<EC_NUM; i++)
 | 
					 | 
				
			||||||
			ecdh_doit[i]=1;
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	for (i=0; i<ALGOR_NUM; i++)
 | 
						for (i=0; i<ALGOR_NUM; i++)
 | 
				
			||||||
		if (doit[i]) pr_header++;
 | 
							if (doit[i]) pr_header++;
 | 
				
			||||||
@@ -1246,8 +1215,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		count*=2;
 | 
							count*=2;
 | 
				
			||||||
		Time_F(START);
 | 
							Time_F(START);
 | 
				
			||||||
		for (it=count; it; it--)
 | 
							for (it=count; it; it--)
 | 
				
			||||||
			DES_ecb_encrypt((DES_cblock *)buf,
 | 
								DES_ecb_encrypt(buf_as_des_cblock,buf_as_des_cblock,
 | 
				
			||||||
				(DES_cblock *)buf,
 | 
					 | 
				
			||||||
				&sch,DES_ENCRYPT);
 | 
									&sch,DES_ENCRYPT);
 | 
				
			||||||
		d=Time_F(STOP);
 | 
							d=Time_F(STOP);
 | 
				
			||||||
		} while (d <3);
 | 
							} while (d <3);
 | 
				
			||||||
@@ -1280,7 +1248,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	c[D_IGE_128_AES][0]=count;
 | 
						c[D_IGE_128_AES][0]=count;
 | 
				
			||||||
	c[D_IGE_192_AES][0]=count;
 | 
						c[D_IGE_192_AES][0]=count;
 | 
				
			||||||
	c[D_IGE_256_AES][0]=count;
 | 
						c[D_IGE_256_AES][0]=count;
 | 
				
			||||||
	c[D_GHASH][0]=count;
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	for (i=1; i<SIZE_NUM; i++)
 | 
						for (i=1; i<SIZE_NUM; i++)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
@@ -1475,7 +1442,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
# error "You cannot disable DES on systems without SIGALRM."
 | 
					# error "You cannot disable DES on systems without SIGALRM."
 | 
				
			||||||
#endif /* OPENSSL_NO_DES */
 | 
					#endif /* OPENSSL_NO_DES */
 | 
				
			||||||
#else
 | 
					#else
 | 
				
			||||||
#define COND(c)	(run && count<0x7fffffff)
 | 
					#define COND(c)	(run)
 | 
				
			||||||
#define COUNT(d) (count)
 | 
					#define COUNT(d) (count)
 | 
				
			||||||
#ifndef _WIN32
 | 
					#ifndef _WIN32
 | 
				
			||||||
	signal(SIGALRM,sig_done);
 | 
						signal(SIGALRM,sig_done);
 | 
				
			||||||
@@ -1574,11 +1541,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			print_message(names[D_SHA1],c[D_SHA1][j],lengths[j]);
 | 
								print_message(names[D_SHA1],c[D_SHA1][j],lengths[j]);
 | 
				
			||||||
			Time_F(START);
 | 
								Time_F(START);
 | 
				
			||||||
			for (count=0,run=1; COND(c[D_SHA1][j]); count++)
 | 
								for (count=0,run=1; COND(c[D_SHA1][j]); count++)
 | 
				
			||||||
#if 0
 | 
					 | 
				
			||||||
				EVP_Digest(buf,(unsigned long)lengths[j],&(sha[0]),NULL,EVP_sha1(),NULL);
 | 
									EVP_Digest(buf,(unsigned long)lengths[j],&(sha[0]),NULL,EVP_sha1(),NULL);
 | 
				
			||||||
#else
 | 
					 | 
				
			||||||
				SHA1(buf,lengths[j],sha);
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
			d=Time_F(STOP);
 | 
								d=Time_F(STOP);
 | 
				
			||||||
			print_result(D_SHA1,j,count,d);
 | 
								print_result(D_SHA1,j,count,d);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
@@ -1775,22 +1738,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			print_result(D_IGE_256_AES,j,count,d);
 | 
								print_result(D_IGE_256_AES,j,count,d);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	if (doit[D_GHASH])
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		GCM128_CONTEXT *ctx = CRYPTO_gcm128_new(&aes_ks1,(block128_f)AES_encrypt);
 | 
					 | 
				
			||||||
		CRYPTO_gcm128_setiv (ctx,(unsigned char *)"0123456789ab",12);
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
		for (j=0; j<SIZE_NUM; j++)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			print_message(names[D_GHASH],c[D_GHASH][j],lengths[j]);
 | 
					 | 
				
			||||||
			Time_F(START);
 | 
					 | 
				
			||||||
			for (count=0,run=1; COND(c[D_GHASH][j]); count++)
 | 
					 | 
				
			||||||
				CRYPTO_gcm128_aad(ctx,buf,lengths[j]);
 | 
					 | 
				
			||||||
			d=Time_F(STOP);
 | 
					 | 
				
			||||||
			print_result(D_GHASH,j,count,d);
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		CRYPTO_gcm128_release(ctx);
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
#ifndef OPENSSL_NO_CAMELLIA
 | 
					#ifndef OPENSSL_NO_CAMELLIA
 | 
				
			||||||
@@ -2376,7 +2324,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		}
 | 
							}
 | 
				
			||||||
	if (rnd_fake) RAND_cleanup();
 | 
						if (rnd_fake) RAND_cleanup();
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
#ifndef NO_FORK
 | 
					#ifdef HAVE_FORK
 | 
				
			||||||
show_res:
 | 
					show_res:
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
	if(!mr)
 | 
						if(!mr)
 | 
				
			||||||
@@ -2602,7 +2550,7 @@ static void print_result(int alg,int run_no,int count,double time_used)
 | 
				
			|||||||
	results[alg][run_no]=((double)count)/time_used*lengths[run_no];
 | 
						results[alg][run_no]=((double)count)/time_used*lengths[run_no];
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef NO_FORK
 | 
					#ifdef HAVE_FORK
 | 
				
			||||||
static char *sstrsep(char **string, const char *delim)
 | 
					static char *sstrsep(char **string, const char *delim)
 | 
				
			||||||
    {
 | 
					    {
 | 
				
			||||||
    char isdelim[256];
 | 
					    char isdelim[256];
 | 
				
			||||||
@@ -2644,11 +2592,7 @@ static int do_multi(int multi)
 | 
				
			|||||||
	fds=malloc(multi*sizeof *fds);
 | 
						fds=malloc(multi*sizeof *fds);
 | 
				
			||||||
	for(n=0 ; n < multi ; ++n)
 | 
						for(n=0 ; n < multi ; ++n)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		if (pipe(fd) == -1)
 | 
							pipe(fd);
 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			fprintf(stderr, "pipe failure\n");
 | 
					 | 
				
			||||||
			exit(1);
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		fflush(stdout);
 | 
							fflush(stdout);
 | 
				
			||||||
		fflush(stderr);
 | 
							fflush(stderr);
 | 
				
			||||||
		if(fork())
 | 
							if(fork())
 | 
				
			||||||
@@ -2660,11 +2604,7 @@ static int do_multi(int multi)
 | 
				
			|||||||
			{
 | 
								{
 | 
				
			||||||
			close(fd[0]);
 | 
								close(fd[0]);
 | 
				
			||||||
			close(1);
 | 
								close(1);
 | 
				
			||||||
			if (dup(fd[1]) == -1)
 | 
								dup(fd[1]);
 | 
				
			||||||
				{
 | 
					 | 
				
			||||||
				fprintf(stderr, "dup failed\n");
 | 
					 | 
				
			||||||
				exit(1);
 | 
					 | 
				
			||||||
				}
 | 
					 | 
				
			||||||
			close(fd[1]);
 | 
								close(fd[1]);
 | 
				
			||||||
			mr=1;
 | 
								mr=1;
 | 
				
			||||||
			usertime=0;
 | 
								usertime=0;
 | 
				
			||||||
@@ -2747,7 +2687,6 @@ static int do_multi(int multi)
 | 
				
			|||||||
				else
 | 
									else
 | 
				
			||||||
					rsa_results[k][1]=d;
 | 
										rsa_results[k][1]=d;
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
#ifndef OPENSSL_NO_DSA
 | 
					 | 
				
			||||||
			else if(!strncmp(buf,"+F3:",4))
 | 
								else if(!strncmp(buf,"+F3:",4))
 | 
				
			||||||
				{
 | 
									{
 | 
				
			||||||
				int k;
 | 
									int k;
 | 
				
			||||||
@@ -2769,7 +2708,6 @@ static int do_multi(int multi)
 | 
				
			|||||||
				else
 | 
									else
 | 
				
			||||||
					dsa_results[k][1]=d;
 | 
										dsa_results[k][1]=d;
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
#ifndef OPENSSL_NO_ECDSA
 | 
					#ifndef OPENSSL_NO_ECDSA
 | 
				
			||||||
			else if(!strncmp(buf,"+F4:",4))
 | 
								else if(!strncmp(buf,"+F4:",4))
 | 
				
			||||||
				{
 | 
									{
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										763
									
								
								apps/srp.c
									
									
									
									
									
								
							
							
						
						
									
										763
									
								
								apps/srp.c
									
									
									
									
									
								
							@@ -1,763 +0,0 @@
 | 
				
			|||||||
/* apps/srp.c */
 | 
					 | 
				
			||||||
/* Written by Peter Sylvester (peter.sylvester@edelweb.fr)  
 | 
					 | 
				
			||||||
 * for the EdelKey project and contributed to the OpenSSL project 2004.
 | 
					 | 
				
			||||||
 */
 | 
					 | 
				
			||||||
/* ====================================================================
 | 
					 | 
				
			||||||
 * Copyright (c) 2004 The OpenSSL Project.  All rights reserved.
 | 
					 | 
				
			||||||
 *
 | 
					 | 
				
			||||||
 * 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 above 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 acknowledgment:
 | 
					 | 
				
			||||||
 *    "This product includes software developed by the OpenSSL Project
 | 
					 | 
				
			||||||
 *    for use in the OpenSSL Toolkit. (http://www.OpenSSL.org/)"
 | 
					 | 
				
			||||||
 *
 | 
					 | 
				
			||||||
 * 4. The names "OpenSSL Toolkit" and "OpenSSL Project" must not be used to
 | 
					 | 
				
			||||||
 *    endorse or promote products derived from this software without
 | 
					 | 
				
			||||||
 *    prior written permission. For written permission, please contact
 | 
					 | 
				
			||||||
 *    licensing@OpenSSL.org.
 | 
					 | 
				
			||||||
 *
 | 
					 | 
				
			||||||
 * 5. Products derived from this software may not be called "OpenSSL"
 | 
					 | 
				
			||||||
 *    nor may "OpenSSL" appear in their names without prior written
 | 
					 | 
				
			||||||
 *    permission of the OpenSSL Project.
 | 
					 | 
				
			||||||
 *
 | 
					 | 
				
			||||||
 * 6. Redistributions of any form whatsoever must retain the following
 | 
					 | 
				
			||||||
 *    acknowledgment:
 | 
					 | 
				
			||||||
 *    "This product includes software developed by the OpenSSL Project
 | 
					 | 
				
			||||||
 *    for use in the OpenSSL Toolkit (http://www.OpenSSL.org/)"
 | 
					 | 
				
			||||||
 *
 | 
					 | 
				
			||||||
 * THIS SOFTWARE IS PROVIDED BY THE OpenSSL PROJECT ``AS IS'' AND ANY
 | 
					 | 
				
			||||||
 * EXPRESSED 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 OpenSSL PROJECT OR
 | 
					 | 
				
			||||||
 * ITS 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.
 | 
					 | 
				
			||||||
 * ====================================================================
 | 
					 | 
				
			||||||
 *
 | 
					 | 
				
			||||||
 * This product includes cryptographic software written by Eric Young
 | 
					 | 
				
			||||||
 * (eay@cryptsoft.com).  This product includes software written by Tim
 | 
					 | 
				
			||||||
 * Hudson (tjh@cryptsoft.com).
 | 
					 | 
				
			||||||
 *
 | 
					 | 
				
			||||||
 */
 | 
					 | 
				
			||||||
#include <openssl/opensslconf.h>
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifndef OPENSSL_NO_SRP
 | 
					 | 
				
			||||||
#include <stdio.h>
 | 
					 | 
				
			||||||
#include <stdlib.h>
 | 
					 | 
				
			||||||
#include <string.h>
 | 
					 | 
				
			||||||
#include <openssl/conf.h>
 | 
					 | 
				
			||||||
#include <openssl/bio.h>
 | 
					 | 
				
			||||||
#include <openssl/err.h>
 | 
					 | 
				
			||||||
#include <openssl/txt_db.h>
 | 
					 | 
				
			||||||
#include <openssl/buffer.h>
 | 
					 | 
				
			||||||
#include <openssl/srp.h>
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#include "apps.h"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#undef PROG
 | 
					 | 
				
			||||||
#define PROG srp_main
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#define BASE_SECTION	"srp"
 | 
					 | 
				
			||||||
#define CONFIG_FILE "openssl.cnf"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#define ENV_RANDFILE		"RANDFILE"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#define ENV_DATABASE		"srpvfile"
 | 
					 | 
				
			||||||
#define ENV_DEFAULT_SRP		"default_srp"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
static char *srp_usage[]={
 | 
					 | 
				
			||||||
"usage: srp [args] [user] \n",
 | 
					 | 
				
			||||||
"\n",
 | 
					 | 
				
			||||||
" -verbose        Talk alot while doing things\n",
 | 
					 | 
				
			||||||
" -config file    A config file\n",
 | 
					 | 
				
			||||||
" -name arg       The particular srp definition to use\n",
 | 
					 | 
				
			||||||
" -srpvfile arg   The srp verifier file name\n",
 | 
					 | 
				
			||||||
" -add            add an user and srp verifier\n",
 | 
					 | 
				
			||||||
" -modify         modify the srp verifier of an existing user\n",
 | 
					 | 
				
			||||||
" -delete         delete user from verifier file\n",
 | 
					 | 
				
			||||||
" -list           list user\n",
 | 
					 | 
				
			||||||
" -gn arg         g and N values to be used for new verifier\n",
 | 
					 | 
				
			||||||
" -userinfo arg   additional info to be set for user\n",
 | 
					 | 
				
			||||||
" -passin arg     input file pass phrase source\n",
 | 
					 | 
				
			||||||
" -passout arg    output file pass phrase source\n",
 | 
					 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
" -engine e         - use engine e, possibly a hardware device.\n",
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
NULL
 | 
					 | 
				
			||||||
};
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifdef EFENCE
 | 
					 | 
				
			||||||
extern int EF_PROTECT_FREE;
 | 
					 | 
				
			||||||
extern int EF_PROTECT_BELOW;
 | 
					 | 
				
			||||||
extern int EF_ALIGNMENT;
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
static CONF *conf=NULL;
 | 
					 | 
				
			||||||
static char *section=NULL;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#define VERBOSE if (verbose) 
 | 
					 | 
				
			||||||
#define VVERBOSE if (verbose>1) 
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
int MAIN(int, char **);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
static int get_index(CA_DB *db, char* id, char type)
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	char ** pp;
 | 
					 | 
				
			||||||
	int i;
 | 
					 | 
				
			||||||
	if (id == NULL) return -1;
 | 
					 | 
				
			||||||
	if (type == DB_SRP_INDEX) 
 | 
					 | 
				
			||||||
	for (i = 0; i < sk_OPENSSL_PSTRING_num(db->db->data); i++)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		pp=sk_OPENSSL_PSTRING_value(db->db->data,i);
 | 
					 | 
				
			||||||
		if (pp[DB_srptype][0] == DB_SRP_INDEX  && !strcmp(id,pp[DB_srpid])) 
 | 
					 | 
				
			||||||
			return i;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	else for (i = 0; i < sk_OPENSSL_PSTRING_num(db->db->data); i++)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		pp=sk_OPENSSL_PSTRING_value(db->db->data,i);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		if (pp[DB_srptype][0] != DB_SRP_INDEX && !strcmp(id,pp[DB_srpid])) 
 | 
					 | 
				
			||||||
			return i;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	return -1 ; 
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
static void print_entry(CA_DB *db, BIO * bio, int indx, int verbose, char * s)
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	if (indx >= 0 && verbose)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		int j;
 | 
					 | 
				
			||||||
		char **pp=sk_OPENSSL_PSTRING_value(db->db->data,indx);
 | 
					 | 
				
			||||||
		BIO_printf(bio,"%s \"%s\"\n",s,pp[DB_srpid]);
 | 
					 | 
				
			||||||
		for (j = 0; j < DB_NUMBER; j++)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			BIO_printf(bio_err,"  %d = \"%s\"\n",j,pp[j]);
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
static void print_index(CA_DB *db, BIO * bio, int indexindex, int verbose)
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	print_entry(db,bio,indexindex, verbose, "g N entry") ;
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
static void print_user(CA_DB *db, BIO * bio, int userindex, int verbose)
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	if (verbose > 0)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		char **pp= sk_OPENSSL_PSTRING_value(db->db->data,userindex);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		if (pp[DB_srptype][0] != 'I')
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			print_entry(db,bio,userindex, verbose, "User entry");
 | 
					 | 
				
			||||||
			print_entry(db,bio,get_index(db, pp[DB_srpgN],'I'),verbose,"g N entry") ;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
static int update_index(CA_DB *db, BIO * bio, char ** row)
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	char ** irow;
 | 
					 | 
				
			||||||
	int i;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if ((irow=(char **)OPENSSL_malloc(sizeof(char *)*(DB_NUMBER+1))) == NULL)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		BIO_printf(bio_err,"Memory allocation failure\n");
 | 
					 | 
				
			||||||
		return 0;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	for (i=0; i<DB_NUMBER; i++)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		irow[i]=row[i];
 | 
					 | 
				
			||||||
		row[i]=NULL;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	irow[DB_NUMBER]=NULL;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if (!TXT_DB_insert(db->db,irow))
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		BIO_printf(bio,"failed to update srpvfile\n");
 | 
					 | 
				
			||||||
		BIO_printf(bio,"TXT_DB error number %ld\n",db->db->error);
 | 
					 | 
				
			||||||
		OPENSSL_free(irow);
 | 
					 | 
				
			||||||
		return 0;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	return 1;
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
static void lookup_fail(const char *name, const char *tag)
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	BIO_printf(bio_err,"variable lookup failed for %s::%s\n",name,tag);
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
static char *srp_verify_user(const char *user, const char *srp_verifier,
 | 
					 | 
				
			||||||
							 char *srp_usersalt, const char *g,
 | 
					 | 
				
			||||||
							 const char * N, const char *passin, BIO *bio,
 | 
					 | 
				
			||||||
							 int verbose)
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
 	char password[1024];
 | 
					 | 
				
			||||||
	PW_CB_DATA cb_tmp;
 | 
					 | 
				
			||||||
	char *verifier = NULL;
 | 
					 | 
				
			||||||
	char *gNid = NULL;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	cb_tmp.prompt_info = user;
 | 
					 | 
				
			||||||
	cb_tmp.password = passin;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 	if (password_callback(password, 1024, 0, &cb_tmp) >0)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		VERBOSE BIO_printf(bio,"Validating\n   user=\"%s\"\n srp_verifier=\"%s\"\n srp_usersalt=\"%s\"\n g=\"%s\"\n N=\"%s\"\n",user,srp_verifier,srp_usersalt,g,N);
 | 
					 | 
				
			||||||
		BIO_printf(bio,"Pass %s\n",password);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		OPENSSL_assert(srp_usersalt != NULL);
 | 
					 | 
				
			||||||
		if (!(gNid=SRP_create_verifier(user, password, &srp_usersalt, &verifier,
 | 
					 | 
				
			||||||
									   N, g)))
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			BIO_printf(bio,"Internal error validating SRP verifier\n");
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		else
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if (strcmp(verifier, srp_verifier))
 | 
					 | 
				
			||||||
				gNid = NULL;
 | 
					 | 
				
			||||||
			OPENSSL_free(verifier);
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	return gNid;
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
static char *srp_create_user(char * user, char **srp_verifier,
 | 
					 | 
				
			||||||
							 char **srp_usersalt,char *g, char *N,
 | 
					 | 
				
			||||||
							 char *passout, BIO *bio, int verbose)
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
 	char password[1024];
 | 
					 | 
				
			||||||
        PW_CB_DATA cb_tmp;
 | 
					 | 
				
			||||||
	char *gNid = NULL;
 | 
					 | 
				
			||||||
	char *salt = NULL;
 | 
					 | 
				
			||||||
        cb_tmp.prompt_info = user;
 | 
					 | 
				
			||||||
        cb_tmp.password = passout;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if (password_callback(password,1024,1,&cb_tmp) >0)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		VERBOSE BIO_printf(bio,"Creating\n user=\"%s\"\n g=\"%s\"\n N=\"%s\"\n",user,g,N);
 | 
					 | 
				
			||||||
		if (!(gNid =SRP_create_verifier(user, password, &salt, srp_verifier, N, g)))
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			BIO_printf(bio,"Internal error creating SRP verifier\n");
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		else 
 | 
					 | 
				
			||||||
			*srp_usersalt = salt;
 | 
					 | 
				
			||||||
		VVERBOSE BIO_printf(bio,"gNid=%s salt =\"%s\"\n verifier =\"%s\"\n", gNid,salt, *srp_verifier);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	return gNid;
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
int MAIN(int argc, char **argv)
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	int add_user = 0;
 | 
					 | 
				
			||||||
	int list_user= 0;
 | 
					 | 
				
			||||||
	int delete_user= 0;
 | 
					 | 
				
			||||||
	int modify_user= 0;
 | 
					 | 
				
			||||||
	char * user = NULL;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	char *passargin = NULL, *passargout = NULL;
 | 
					 | 
				
			||||||
	char *passin = NULL, *passout = NULL;
 | 
					 | 
				
			||||||
        char * gN = NULL;
 | 
					 | 
				
			||||||
	int gNindex = -1;
 | 
					 | 
				
			||||||
	char ** gNrow = NULL;
 | 
					 | 
				
			||||||
	int maxgN = -1;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	char * userinfo = NULL;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	int badops=0;
 | 
					 | 
				
			||||||
	int ret=1;
 | 
					 | 
				
			||||||
	int errors=0;
 | 
					 | 
				
			||||||
	int verbose=0;
 | 
					 | 
				
			||||||
	int doupdatedb=0;
 | 
					 | 
				
			||||||
	char *configfile=NULL;
 | 
					 | 
				
			||||||
	char *dbfile=NULL;
 | 
					 | 
				
			||||||
	CA_DB *db=NULL;
 | 
					 | 
				
			||||||
	char **pp ;
 | 
					 | 
				
			||||||
	int i;
 | 
					 | 
				
			||||||
	long errorline = -1;
 | 
					 | 
				
			||||||
	char *randfile=NULL;
 | 
					 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
	char *engine = NULL;
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	char *tofree=NULL;
 | 
					 | 
				
			||||||
	DB_ATTR db_attr;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifdef EFENCE
 | 
					 | 
				
			||||||
EF_PROTECT_FREE=1;
 | 
					 | 
				
			||||||
EF_PROTECT_BELOW=1;
 | 
					 | 
				
			||||||
EF_ALIGNMENT=0;
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	apps_startup();
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	conf = NULL;
 | 
					 | 
				
			||||||
	section = NULL;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if (bio_err == NULL)
 | 
					 | 
				
			||||||
		if ((bio_err=BIO_new(BIO_s_file())) != NULL)
 | 
					 | 
				
			||||||
			BIO_set_fp(bio_err,stderr,BIO_NOCLOSE|BIO_FP_TEXT);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	argc--;
 | 
					 | 
				
			||||||
	argv++;
 | 
					 | 
				
			||||||
	while (argc >= 1 && badops == 0)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		if	(strcmp(*argv,"-verbose") == 0)
 | 
					 | 
				
			||||||
			verbose++;
 | 
					 | 
				
			||||||
		else if	(strcmp(*argv,"-config") == 0)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
					 | 
				
			||||||
			configfile= *(++argv);
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-name") == 0)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
					 | 
				
			||||||
			section= *(++argv);
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		else if	(strcmp(*argv,"-srpvfile") == 0)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
					 | 
				
			||||||
			dbfile= *(++argv);
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-add") == 0)
 | 
					 | 
				
			||||||
			add_user=1;
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-delete") == 0)
 | 
					 | 
				
			||||||
			delete_user=1;
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-modify") == 0)
 | 
					 | 
				
			||||||
			modify_user=1;
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-list") == 0)
 | 
					 | 
				
			||||||
			list_user=1;
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-gn") == 0)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
					 | 
				
			||||||
			gN= *(++argv);
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-userinfo") == 0)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
					 | 
				
			||||||
			userinfo= *(++argv);
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-passin") == 0)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
					 | 
				
			||||||
			passargin= *(++argv);
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-passout") == 0)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
					 | 
				
			||||||
			passargout= *(++argv);
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-engine") == 0)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
					 | 
				
			||||||
			engine= *(++argv);
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		else if (**argv == '-')
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
bad:
 | 
					 | 
				
			||||||
			BIO_printf(bio_err,"unknown option %s\n",*argv);
 | 
					 | 
				
			||||||
			badops=1;
 | 
					 | 
				
			||||||
			break;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		else 
 | 
					 | 
				
			||||||
			break;
 | 
					 | 
				
			||||||
	
 | 
					 | 
				
			||||||
		argc--;
 | 
					 | 
				
			||||||
		argv++;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if (dbfile && configfile)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		BIO_printf(bio_err,"-dbfile and -configfile cannot be specified together.\n");
 | 
					 | 
				
			||||||
		badops = 1;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	if (add_user+delete_user+modify_user+list_user != 1)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		BIO_printf(bio_err,"Exactly one of the options -add, -delete, -modify -list must be specified.\n");
 | 
					 | 
				
			||||||
		badops = 1;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	if (delete_user+modify_user+delete_user== 1 && argc <= 0)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		BIO_printf(bio_err,"Need at least one user for options -add, -delete, -modify. \n");
 | 
					 | 
				
			||||||
		badops = 1;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	if ((passin || passout) && argc != 1 )
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		BIO_printf(bio_err,"-passin, -passout arguments only valid with one user.\n");
 | 
					 | 
				
			||||||
		badops = 1;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if (badops)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		for (pp=srp_usage; (*pp != NULL); pp++)
 | 
					 | 
				
			||||||
			BIO_printf(bio_err,"%s",*pp);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		BIO_printf(bio_err," -rand file%cfile%c...\n", LIST_SEPARATOR_CHAR, LIST_SEPARATOR_CHAR);
 | 
					 | 
				
			||||||
		BIO_printf(bio_err,"                 load the file (or the files in the directory) into\n");
 | 
					 | 
				
			||||||
		BIO_printf(bio_err,"                 the random number generator\n");
 | 
					 | 
				
			||||||
		goto err;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	ERR_load_crypto_strings();
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
	setup_engine(bio_err, engine, 0);
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if(!app_passwd(bio_err, passargin, passargout, &passin, &passout))
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		BIO_printf(bio_err, "Error getting passwords\n");
 | 
					 | 
				
			||||||
		goto err;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        if (!dbfile)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	/*****************************************************************/
 | 
					 | 
				
			||||||
		tofree=NULL;
 | 
					 | 
				
			||||||
		if (configfile == NULL) configfile = getenv("OPENSSL_CONF");
 | 
					 | 
				
			||||||
		if (configfile == NULL) configfile = getenv("SSLEAY_CONF");
 | 
					 | 
				
			||||||
		if (configfile == NULL)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			const char *s=X509_get_default_cert_area();
 | 
					 | 
				
			||||||
			size_t len;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifdef OPENSSL_SYS_VMS
 | 
					 | 
				
			||||||
			len = strlen(s)+sizeof(CONFIG_FILE);
 | 
					 | 
				
			||||||
			tofree=OPENSSL_malloc(len);
 | 
					 | 
				
			||||||
			strcpy(tofree,s);
 | 
					 | 
				
			||||||
#else
 | 
					 | 
				
			||||||
			len = strlen(s)+sizeof(CONFIG_FILE)+1;
 | 
					 | 
				
			||||||
			tofree=OPENSSL_malloc(len);
 | 
					 | 
				
			||||||
			BUF_strlcpy(tofree,s,len);
 | 
					 | 
				
			||||||
			BUF_strlcat(tofree,"/",len);
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
			BUF_strlcat(tofree,CONFIG_FILE,len);
 | 
					 | 
				
			||||||
			configfile=tofree;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		VERBOSE BIO_printf(bio_err,"Using configuration from %s\n",configfile);
 | 
					 | 
				
			||||||
		conf = NCONF_new(NULL);
 | 
					 | 
				
			||||||
		if (NCONF_load(conf,configfile,&errorline) <= 0)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if (errorline <= 0)
 | 
					 | 
				
			||||||
				BIO_printf(bio_err,"error loading the config file '%s'\n",
 | 
					 | 
				
			||||||
					configfile);
 | 
					 | 
				
			||||||
			else
 | 
					 | 
				
			||||||
				BIO_printf(bio_err,"error on line %ld of config file '%s'\n"
 | 
					 | 
				
			||||||
					,errorline,configfile);
 | 
					 | 
				
			||||||
			goto err;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		if(tofree)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			OPENSSL_free(tofree);
 | 
					 | 
				
			||||||
			tofree = NULL;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		if (!load_config(bio_err, conf))
 | 
					 | 
				
			||||||
			goto err;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	/* Lets get the config section we are using */
 | 
					 | 
				
			||||||
		if (section == NULL)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			VERBOSE BIO_printf(bio_err,"trying to read " ENV_DEFAULT_SRP " in \" BASE_SECTION \"\n");
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
			section=NCONF_get_string(conf,BASE_SECTION,ENV_DEFAULT_SRP);
 | 
					 | 
				
			||||||
			if (section == NULL)
 | 
					 | 
				
			||||||
				{
 | 
					 | 
				
			||||||
				lookup_fail(BASE_SECTION,ENV_DEFAULT_SRP);
 | 
					 | 
				
			||||||
				goto err;
 | 
					 | 
				
			||||||
				}
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
         
 | 
					 | 
				
			||||||
		if (randfile == NULL && conf)
 | 
					 | 
				
			||||||
	        	randfile = NCONF_get_string(conf, BASE_SECTION, "RANDFILE");
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	
 | 
					 | 
				
			||||||
		VERBOSE BIO_printf(bio_err,"trying to read " ENV_DATABASE " in section \"%s\"\n",section);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		if ((dbfile=NCONF_get_string(conf,section,ENV_DATABASE)) == NULL)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			lookup_fail(section,ENV_DATABASE);
 | 
					 | 
				
			||||||
			goto err;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        	}
 | 
					 | 
				
			||||||
	if (randfile == NULL)
 | 
					 | 
				
			||||||
		ERR_clear_error();
 | 
					 | 
				
			||||||
       	else 
 | 
					 | 
				
			||||||
		app_RAND_load_file(randfile, bio_err, 0);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	VERBOSE BIO_printf(bio_err,"Trying to read SRP verifier file \"%s\"\n",dbfile);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	db = load_index(dbfile, &db_attr);
 | 
					 | 
				
			||||||
	if (db == NULL) goto err;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	/* Lets check some fields */
 | 
					 | 
				
			||||||
	for (i=0; i < sk_OPENSSL_PSTRING_num(db->db->data); i++)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		pp=sk_OPENSSL_PSTRING_value(db->db->data, i);
 | 
					 | 
				
			||||||
	
 | 
					 | 
				
			||||||
		if (pp[DB_srptype][0] == DB_SRP_INDEX)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			maxgN = i;
 | 
					 | 
				
			||||||
			if (gNindex < 0 && gN != NULL && !strcmp(gN, pp[DB_srpid]))
 | 
					 | 
				
			||||||
				gNindex = i;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
			print_index(db, bio_err, i, verbose > 1) ;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	
 | 
					 | 
				
			||||||
	VERBOSE BIO_printf(bio_err,"Database initialised\n");
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if (gNindex >= 0)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		gNrow=sk_OPENSSL_PSTRING_value(db->db->data,gNindex);
 | 
					 | 
				
			||||||
		print_entry(db,bio_err,gNindex,verbose>1,"Default g and N") ;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	else if (maxgN > 0 && !SRP_get_default_gN(gN))
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		BIO_printf(bio_err,"No g and N value for index \"%s\"\n",gN);
 | 
					 | 
				
			||||||
		goto err;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	else
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		VERBOSE BIO_printf(bio_err,"Database has no g N information.\n");
 | 
					 | 
				
			||||||
		gNrow = NULL;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	VVERBOSE BIO_printf(bio_err,"Starting user processing\n");
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if (argc > 0)
 | 
					 | 
				
			||||||
		user = *(argv++) ;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	while (list_user || user)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		int userindex = -1;
 | 
					 | 
				
			||||||
		if (user) 
 | 
					 | 
				
			||||||
			VVERBOSE BIO_printf(bio_err, "Processing user \"%s\"\n",user);
 | 
					 | 
				
			||||||
		if ((userindex = get_index(db, user, 'U')) >= 0)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			print_user(db,bio_err,userindex,(verbose > 0) || list_user) ;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		
 | 
					 | 
				
			||||||
		if (list_user)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if (user == NULL)
 | 
					 | 
				
			||||||
				{
 | 
					 | 
				
			||||||
				BIO_printf(bio_err,"List all users\n");
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
				for (i=0; i < sk_OPENSSL_PSTRING_num(db->db->data); i++)
 | 
					 | 
				
			||||||
					{
 | 
					 | 
				
			||||||
					print_user(db,bio_err,i,1) ;
 | 
					 | 
				
			||||||
					}
 | 
					 | 
				
			||||||
				list_user = 0;
 | 
					 | 
				
			||||||
				}
 | 
					 | 
				
			||||||
			else if (userindex < 0)
 | 
					 | 
				
			||||||
				{
 | 
					 | 
				
			||||||
				BIO_printf(bio_err, "user \"%s\" does not exist, ignored. t\n",
 | 
					 | 
				
			||||||
						   user);
 | 
					 | 
				
			||||||
				errors++;
 | 
					 | 
				
			||||||
				}
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		else if (add_user)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if (userindex >= 0)
 | 
					 | 
				
			||||||
				{
 | 
					 | 
				
			||||||
				/* reactivation of a new user */
 | 
					 | 
				
			||||||
				char **row = sk_OPENSSL_PSTRING_value(db->db->data, userindex);
 | 
					 | 
				
			||||||
				BIO_printf(bio_err,"user \"%s\" reactivated.\n", user);
 | 
					 | 
				
			||||||
				row[DB_srptype][0] = 'V' ;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
				doupdatedb = 1;
 | 
					 | 
				
			||||||
				}
 | 
					 | 
				
			||||||
			else
 | 
					 | 
				
			||||||
				{
 | 
					 | 
				
			||||||
				char *row[DB_NUMBER] ; char * gNid;
 | 
					 | 
				
			||||||
				row[DB_srpverifier] = NULL;
 | 
					 | 
				
			||||||
				row[DB_srpsalt] = NULL;
 | 
					 | 
				
			||||||
				row[DB_srpinfo] = NULL;
 | 
					 | 
				
			||||||
				if (!(gNid = srp_create_user(user,&(row[DB_srpverifier]), &(row[DB_srpsalt]),gNrow?gNrow[DB_srpsalt]:gN,gNrow?gNrow[DB_srpverifier]:NULL, passout, bio_err,verbose)))
 | 
					 | 
				
			||||||
					{
 | 
					 | 
				
			||||||
						BIO_printf(bio_err,"Cannot create srp verifier for user \"%s\", operation abandoned .\n",user);
 | 
					 | 
				
			||||||
						errors++ ;
 | 
					 | 
				
			||||||
						goto err;
 | 
					 | 
				
			||||||
					}
 | 
					 | 
				
			||||||
				row[DB_srpid] = BUF_strdup(user);
 | 
					 | 
				
			||||||
				row[DB_srptype] = BUF_strdup("v");
 | 
					 | 
				
			||||||
				row[DB_srpgN] = BUF_strdup(gNid);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
				if (!row[DB_srpid] || !row[DB_srpgN] || !row[DB_srptype] || !row[DB_srpverifier] || !row[DB_srpsalt] ||
 | 
					 | 
				
			||||||
					(userinfo && (!(row[DB_srpinfo] = BUF_strdup(userinfo)))) || 
 | 
					 | 
				
			||||||
					!update_index(db, bio_err, row))
 | 
					 | 
				
			||||||
					{
 | 
					 | 
				
			||||||
					if (row[DB_srpid]) OPENSSL_free(row[DB_srpid]);
 | 
					 | 
				
			||||||
					if (row[DB_srpgN]) OPENSSL_free(row[DB_srpgN]);
 | 
					 | 
				
			||||||
					if (row[DB_srpinfo]) OPENSSL_free(row[DB_srpinfo]);
 | 
					 | 
				
			||||||
					if (row[DB_srptype]) OPENSSL_free(row[DB_srptype]);
 | 
					 | 
				
			||||||
					if (row[DB_srpverifier]) OPENSSL_free(row[DB_srpverifier]);
 | 
					 | 
				
			||||||
					if (row[DB_srpsalt]) OPENSSL_free(row[DB_srpsalt]);
 | 
					 | 
				
			||||||
					goto err;
 | 
					 | 
				
			||||||
					}
 | 
					 | 
				
			||||||
				doupdatedb = 1;
 | 
					 | 
				
			||||||
				}
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		else if (modify_user)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if (userindex<0)
 | 
					 | 
				
			||||||
				{
 | 
					 | 
				
			||||||
				BIO_printf(bio_err,"user \"%s\" does not exist, operation ignored.\n",user);
 | 
					 | 
				
			||||||
				errors++ ;
 | 
					 | 
				
			||||||
				}
 | 
					 | 
				
			||||||
			else
 | 
					 | 
				
			||||||
				{
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
				char **row=sk_OPENSSL_PSTRING_value(db->db->data, userindex);
 | 
					 | 
				
			||||||
				char type = row[DB_srptype][0] ;
 | 
					 | 
				
			||||||
				if (type == 'v')
 | 
					 | 
				
			||||||
					{
 | 
					 | 
				
			||||||
					BIO_printf(bio_err,"user \"%s\" already updated, operation ignored.\n",user);
 | 
					 | 
				
			||||||
					errors++ ;
 | 
					 | 
				
			||||||
					}
 | 
					 | 
				
			||||||
				else
 | 
					 | 
				
			||||||
					{
 | 
					 | 
				
			||||||
					char * gNid ;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
					if (row[DB_srptype][0] == 'V')
 | 
					 | 
				
			||||||
						{
 | 
					 | 
				
			||||||
						int user_gN ;
 | 
					 | 
				
			||||||
						char ** irow = NULL;
 | 
					 | 
				
			||||||
						VERBOSE BIO_printf(bio_err,"Verifying password for user \"%s\"\n",user);
 | 
					 | 
				
			||||||
						if ( (user_gN = get_index(db, row[DB_srpgN],DB_SRP_INDEX)) >= 0)
 | 
					 | 
				
			||||||
							irow = sk_OPENSSL_PSTRING_value(db->db->data,
 | 
					 | 
				
			||||||
															userindex);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 						if (!srp_verify_user(user,row[DB_srpverifier], row[DB_srpsalt],irow?irow[DB_srpsalt]:row[DB_srpgN], irow?irow[DB_srpverifier]:NULL, passin, bio_err,verbose))
 | 
					 | 
				
			||||||
							{
 | 
					 | 
				
			||||||
							BIO_printf(bio_err,"Invalid password for user \"%s\", operation abandoned.\n",user);
 | 
					 | 
				
			||||||
							errors++ ;
 | 
					 | 
				
			||||||
							goto err;
 | 
					 | 
				
			||||||
							}
 | 
					 | 
				
			||||||
						} 
 | 
					 | 
				
			||||||
					VERBOSE BIO_printf(bio_err,"Password for user \"%s\" ok.\n",user);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
					if (!(gNid=srp_create_user(user,&(row[DB_srpverifier]), &(row[DB_srpsalt]),gNrow?gNrow[DB_srpsalt]:NULL, gNrow?gNrow[DB_srpverifier]:NULL, passout, bio_err,verbose)))
 | 
					 | 
				
			||||||
						{
 | 
					 | 
				
			||||||
							BIO_printf(bio_err,
 | 
					 | 
				
			||||||
									   "Cannot create srp verifier for user "
 | 
					 | 
				
			||||||
									   "\"%s\", operation abandonned .\n",
 | 
					 | 
				
			||||||
									   user);
 | 
					 | 
				
			||||||
							errors++;
 | 
					 | 
				
			||||||
							goto err;
 | 
					 | 
				
			||||||
						}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
					row[DB_srptype][0] = 'v';
 | 
					 | 
				
			||||||
					row[DB_srpgN] = BUF_strdup(gNid);
 | 
					 | 
				
			||||||
 
 | 
					 | 
				
			||||||
					if (!row[DB_srpid] || !row[DB_srpgN] || !row[DB_srptype] || !row[DB_srpverifier] || !row[DB_srpsalt] ||
 | 
					 | 
				
			||||||
						(userinfo && (!(row[DB_srpinfo] = BUF_strdup(userinfo)))))  
 | 
					 | 
				
			||||||
						goto err;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
					doupdatedb = 1;
 | 
					 | 
				
			||||||
					}
 | 
					 | 
				
			||||||
				}
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		else if (delete_user)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if (userindex < 0)
 | 
					 | 
				
			||||||
				{
 | 
					 | 
				
			||||||
				BIO_printf(bio_err, "user \"%s\" does not exist, operation ignored. t\n", user);
 | 
					 | 
				
			||||||
				errors++;
 | 
					 | 
				
			||||||
				}
 | 
					 | 
				
			||||||
			else
 | 
					 | 
				
			||||||
				{
 | 
					 | 
				
			||||||
				char ** xpp = sk_OPENSSL_PSTRING_value(db->db->data,userindex);
 | 
					 | 
				
			||||||
				BIO_printf(bio_err,"user \"%s\" revoked. t\n",user);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
				xpp[DB_srptype][0] = 'R' ;
 | 
					 | 
				
			||||||
				
 | 
					 | 
				
			||||||
				doupdatedb = 1;
 | 
					 | 
				
			||||||
				}
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		if (--argc > 0)
 | 
					 | 
				
			||||||
			user = *(argv++) ;
 | 
					 | 
				
			||||||
		else
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			user = NULL;
 | 
					 | 
				
			||||||
			list_user = 0;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	VERBOSE BIO_printf(bio_err,"User procession done.\n");
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if (doupdatedb)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		/* Lets check some fields */
 | 
					 | 
				
			||||||
		for (i=0; i < sk_OPENSSL_PSTRING_num(db->db->data); i++)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			pp=sk_OPENSSL_PSTRING_value(db->db->data,i);
 | 
					 | 
				
			||||||
	
 | 
					 | 
				
			||||||
			if (pp[DB_srptype][0] == 'v')
 | 
					 | 
				
			||||||
				{
 | 
					 | 
				
			||||||
				pp[DB_srptype][0] = 'V';
 | 
					 | 
				
			||||||
				print_user(db,bio_err,i,verbose) ;
 | 
					 | 
				
			||||||
				}
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		VERBOSE BIO_printf(bio_err,"Trying to update srpvfile.\n");
 | 
					 | 
				
			||||||
		if (!save_index(dbfile,"new",db)) goto err;
 | 
					 | 
				
			||||||
				
 | 
					 | 
				
			||||||
		VERBOSE BIO_printf(bio_err,"Temporary srpvfile created.\n");
 | 
					 | 
				
			||||||
		if (!rotate_index(dbfile,"new","old")) goto err;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		VERBOSE BIO_printf(bio_err,"srpvfile updated.\n");
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	ret = (errors != 0);
 | 
					 | 
				
			||||||
err:
 | 
					 | 
				
			||||||
	if (errors != 0)
 | 
					 | 
				
			||||||
	VERBOSE BIO_printf(bio_err,"User errors %d.\n",errors);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	VERBOSE BIO_printf(bio_err,"SRP terminating with code %d.\n",ret);
 | 
					 | 
				
			||||||
	if(tofree)
 | 
					 | 
				
			||||||
		OPENSSL_free(tofree);
 | 
					 | 
				
			||||||
	if (ret) ERR_print_errors(bio_err);
 | 
					 | 
				
			||||||
	if (randfile) app_RAND_write_file(randfile, bio_err);
 | 
					 | 
				
			||||||
	if (conf) NCONF_free(conf);
 | 
					 | 
				
			||||||
	if (db) free_index(db);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	OBJ_cleanup();
 | 
					 | 
				
			||||||
	apps_shutdown();
 | 
					 | 
				
			||||||
	OPENSSL_EXIT(ret);
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
@@ -165,9 +165,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		BIO_set_fp(bio_err, stderr, BIO_NOCLOSE | BIO_FP_TEXT);
 | 
							BIO_set_fp(bio_err, stderr, BIO_NOCLOSE | BIO_FP_TEXT);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (!load_config(bio_err, NULL))
 | 
					 | 
				
			||||||
		goto cleanup;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	for (argc--, argv++; argc > 0; argc--, argv++)
 | 
						for (argc--, argv++; argc > 0; argc--, argv++)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		if (strcmp(*argv, "-config") == 0)
 | 
							if (strcmp(*argv, "-config") == 0)
 | 
				
			||||||
@@ -649,7 +646,7 @@ static ASN1_INTEGER *create_nonce(int bits)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	/* Generating random byte sequence. */
 | 
						/* Generating random byte sequence. */
 | 
				
			||||||
	if (len > (int)sizeof(buf)) goto err;
 | 
						if (len > (int)sizeof(buf)) goto err;
 | 
				
			||||||
	if (RAND_bytes(buf, len) <= 0) goto err;
 | 
						if (!RAND_bytes(buf, len)) goto err;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/* Find the first non-zero byte and creating ASN1_INTEGER object. */
 | 
						/* Find the first non-zero byte and creating ASN1_INTEGER object. */
 | 
				
			||||||
	for (i = 0; i < len && !buf[i]; ++i);
 | 
						for (i = 0; i < len && !buf[i]; ++i);
 | 
				
			||||||
@@ -1083,7 +1080,7 @@ static X509_STORE *create_cert_store(char *ca_path, char *ca_file)
 | 
				
			|||||||
	cert_ctx = X509_STORE_new();
 | 
						cert_ctx = X509_STORE_new();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/* Setting the callback for certificate chain verification. */
 | 
						/* Setting the callback for certificate chain verification. */
 | 
				
			||||||
	X509_STORE_set_verify_cb(cert_ctx, verify_cb);
 | 
						X509_STORE_set_verify_cb_func(cert_ctx, verify_cb);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/* Adding a trusted certificate directory source. */
 | 
						/* Adding a trusted certificate directory source. */
 | 
				
			||||||
	if (ca_path)
 | 
						if (ca_path)
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										13
									
								
								apps/tsget
									
									
									
									
									
								
							
							
						
						
									
										13
									
								
								apps/tsget
									
									
									
									
									
								
							@@ -1,13 +1,13 @@
 | 
				
			|||||||
#!/usr/bin/perl -w
 | 
					#!/usr/bin/perl -w
 | 
				
			||||||
# Written by Zoltan Glozik <zglozik@stones.com>.
 | 
					# Written by Zoltan Glozik <zglozik@stones.com>.
 | 
				
			||||||
# Copyright (c) 2002 The OpenTSA Project.  All rights reserved.
 | 
					# Copyright (c) 2002 The OpenTSA Project.  All rights reserved.
 | 
				
			||||||
$::version = '$Id: tsget,v 1.3 2009/09/07 17:57:18 steve Exp $';
 | 
					$::version = '$Id: tsget,v 1.1 2006/02/12 23:11:21 ulf Exp $';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
use strict;
 | 
					use strict;
 | 
				
			||||||
use IO::Handle;
 | 
					use IO::Handle;
 | 
				
			||||||
use Getopt::Std;
 | 
					use Getopt::Std;
 | 
				
			||||||
use File::Basename;
 | 
					use File::Basename;
 | 
				
			||||||
use WWW::Curl::Easy;
 | 
					use WWW::Curl::easy;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
use vars qw(%options);
 | 
					use vars qw(%options);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -37,7 +37,7 @@ sub create_curl {
 | 
				
			|||||||
    my $url = shift;
 | 
					    my $url = shift;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    # Create Curl object.
 | 
					    # Create Curl object.
 | 
				
			||||||
    my $curl = WWW::Curl::Easy::new();
 | 
					    my $curl = WWW::Curl::easy::new();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    # Error-handling related options.
 | 
					    # Error-handling related options.
 | 
				
			||||||
    $curl->setopt(CURLOPT_VERBOSE, 1) if $options{d};
 | 
					    $curl->setopt(CURLOPT_VERBOSE, 1) if $options{d};
 | 
				
			||||||
@@ -49,7 +49,7 @@ sub create_curl {
 | 
				
			|||||||
    $curl->setopt(CURLOPT_CUSTOMREQUEST, "POST");
 | 
					    $curl->setopt(CURLOPT_CUSTOMREQUEST, "POST");
 | 
				
			||||||
    $curl->setopt(CURLOPT_HTTPHEADER,
 | 
					    $curl->setopt(CURLOPT_HTTPHEADER,
 | 
				
			||||||
		["Content-Type: application/timestamp-query",
 | 
							["Content-Type: application/timestamp-query",
 | 
				
			||||||
		"Accept: application/timestamp-reply,application/timestamp-response"]);
 | 
							"Accept: application/timestamp-reply"]);
 | 
				
			||||||
    $curl->setopt(CURLOPT_READFUNCTION, \&read_body);
 | 
					    $curl->setopt(CURLOPT_READFUNCTION, \&read_body);
 | 
				
			||||||
    $curl->setopt(CURLOPT_HEADERFUNCTION, sub { return length($_[0]); });
 | 
					    $curl->setopt(CURLOPT_HEADERFUNCTION, sub { return length($_[0]); });
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -102,8 +102,7 @@ sub get_timestamp {
 | 
				
			|||||||
	$error_string .= " ($::error_buf)" if defined($::error_buf);
 | 
						$error_string .= " ($::error_buf)" if defined($::error_buf);
 | 
				
			||||||
    } else {
 | 
					    } else {
 | 
				
			||||||
        my $ct = $curl->getinfo(CURLINFO_CONTENT_TYPE);
 | 
					        my $ct = $curl->getinfo(CURLINFO_CONTENT_TYPE);
 | 
				
			||||||
	if (lc($ct) ne "application/timestamp-reply"
 | 
						if (lc($ct) ne "application/timestamp-reply") {
 | 
				
			||||||
	    && lc($ct) ne "application/timestamp-response") {
 | 
					 | 
				
			||||||
	    $error_string = "unexpected content type returned: $ct";
 | 
						    $error_string = "unexpected content type returned: $ct";
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
@@ -193,4 +192,4 @@ REQUEST: foreach (@ARGV) {
 | 
				
			|||||||
    STDERR->printflush(", $output written.\n") if $options{v};
 | 
					    STDERR->printflush(", $output written.\n") if $options{v};
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
$curl->cleanup();
 | 
					$curl->cleanup();
 | 
				
			||||||
WWW::Curl::Easy::global_cleanup();
 | 
					WWW::Curl::easy::global_cleanup();
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										186
									
								
								apps/verify.c
									
									
									
									
									
								
							
							
						
						
									
										186
									
								
								apps/verify.c
									
									
									
									
									
								
							@@ -70,9 +70,8 @@
 | 
				
			|||||||
#define PROG	verify_main
 | 
					#define PROG	verify_main
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static int MS_CALLBACK cb(int ok, X509_STORE_CTX *ctx);
 | 
					static int MS_CALLBACK cb(int ok, X509_STORE_CTX *ctx);
 | 
				
			||||||
static int check(X509_STORE *ctx, char *file,
 | 
					static int check(X509_STORE *ctx, char *file, STACK_OF(X509) *uchain, STACK_OF(X509) *tchain, int purpose, ENGINE *e);
 | 
				
			||||||
		STACK_OF(X509) *uchain, STACK_OF(X509) *tchain,
 | 
					static STACK_OF(X509) *load_untrusted(char *file);
 | 
				
			||||||
		STACK_OF(X509_CRL) *crls, ENGINE *e);
 | 
					 | 
				
			||||||
static int v_verbose=0, vflags = 0;
 | 
					static int v_verbose=0, vflags = 0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
int MAIN(int, char **);
 | 
					int MAIN(int, char **);
 | 
				
			||||||
@@ -81,10 +80,10 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	{
 | 
						{
 | 
				
			||||||
	ENGINE *e = NULL;
 | 
						ENGINE *e = NULL;
 | 
				
			||||||
	int i,ret=1, badarg = 0;
 | 
						int i,ret=1, badarg = 0;
 | 
				
			||||||
 | 
						int purpose = -1;
 | 
				
			||||||
	char *CApath=NULL,*CAfile=NULL;
 | 
						char *CApath=NULL,*CAfile=NULL;
 | 
				
			||||||
	char *untfile = NULL, *trustfile = NULL, *crlfile = NULL;
 | 
						char *untfile = NULL, *trustfile = NULL;
 | 
				
			||||||
	STACK_OF(X509) *untrusted = NULL, *trusted = NULL;
 | 
						STACK_OF(X509) *untrusted = NULL, *trusted = NULL;
 | 
				
			||||||
	STACK_OF(X509_CRL) *crls = NULL;
 | 
					 | 
				
			||||||
	X509_STORE *cert_ctx=NULL;
 | 
						X509_STORE *cert_ctx=NULL;
 | 
				
			||||||
	X509_LOOKUP *lookup=NULL;
 | 
						X509_LOOKUP *lookup=NULL;
 | 
				
			||||||
	X509_VERIFY_PARAM *vpm = NULL;
 | 
						X509_VERIFY_PARAM *vpm = NULL;
 | 
				
			||||||
@@ -94,7 +93,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	cert_ctx=X509_STORE_new();
 | 
						cert_ctx=X509_STORE_new();
 | 
				
			||||||
	if (cert_ctx == NULL) goto end;
 | 
						if (cert_ctx == NULL) goto end;
 | 
				
			||||||
	X509_STORE_set_verify_cb(cert_ctx,cb);
 | 
						X509_STORE_set_verify_cb_func(cert_ctx,cb);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	ERR_load_crypto_strings();
 | 
						ERR_load_crypto_strings();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -140,11 +139,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
				if (argc-- < 1) goto end;
 | 
									if (argc-- < 1) goto end;
 | 
				
			||||||
				trustfile= *(++argv);
 | 
									trustfile= *(++argv);
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
			else if (strcmp(*argv,"-CRLfile") == 0)
 | 
					 | 
				
			||||||
				{
 | 
					 | 
				
			||||||
				if (argc-- < 1) goto end;
 | 
					 | 
				
			||||||
				crlfile= *(++argv);
 | 
					 | 
				
			||||||
				}
 | 
					 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					#ifndef OPENSSL_NO_ENGINE
 | 
				
			||||||
			else if (strcmp(*argv,"-engine") == 0)
 | 
								else if (strcmp(*argv,"-engine") == 0)
 | 
				
			||||||
				{
 | 
									{
 | 
				
			||||||
@@ -198,34 +192,26 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	ERR_clear_error();
 | 
						ERR_clear_error();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if(untfile)
 | 
						if(untfile) {
 | 
				
			||||||
		{
 | 
							if(!(untrusted = load_untrusted(untfile))) {
 | 
				
			||||||
		untrusted = load_certs(bio_err, untfile, FORMAT_PEM,
 | 
								BIO_printf(bio_err, "Error loading untrusted file %s\n", untfile);
 | 
				
			||||||
					NULL, e, "untrusted certificates");
 | 
								ERR_print_errors(bio_err);
 | 
				
			||||||
		if(!untrusted)
 | 
					 | 
				
			||||||
			goto end;
 | 
								goto end;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if(trustfile)
 | 
						if(trustfile) {
 | 
				
			||||||
		{
 | 
							if(!(trusted = load_untrusted(trustfile))) {
 | 
				
			||||||
		trusted = load_certs(bio_err, trustfile, FORMAT_PEM,
 | 
								BIO_printf(bio_err, "Error loading untrusted file %s\n", trustfile);
 | 
				
			||||||
					NULL, e, "trusted certificates");
 | 
								ERR_print_errors(bio_err);
 | 
				
			||||||
		if(!trusted)
 | 
					 | 
				
			||||||
			goto end;
 | 
								goto end;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if(crlfile)
 | 
						if (argc < 1) check(cert_ctx, NULL, untrusted, trusted, purpose, e);
 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		crls = load_crls(bio_err, crlfile, FORMAT_PEM,
 | 
					 | 
				
			||||||
					NULL, e, "other CRLs");
 | 
					 | 
				
			||||||
		if(!crls)
 | 
					 | 
				
			||||||
			goto end;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if (argc < 1) check(cert_ctx, NULL, untrusted, trusted, crls, e);
 | 
					 | 
				
			||||||
	else
 | 
						else
 | 
				
			||||||
		for (i=0; i<argc; i++)
 | 
							for (i=0; i<argc; i++)
 | 
				
			||||||
			check(cert_ctx,argv[i], untrusted, trusted, crls, e);
 | 
								check(cert_ctx,argv[i], untrusted, trusted, purpose, e);
 | 
				
			||||||
	ret=0;
 | 
						ret=0;
 | 
				
			||||||
end:
 | 
					end:
 | 
				
			||||||
	if (ret == 1) {
 | 
						if (ret == 1) {
 | 
				
			||||||
@@ -234,39 +220,23 @@ end:
 | 
				
			|||||||
		BIO_printf(bio_err," [-engine e]");
 | 
							BIO_printf(bio_err," [-engine e]");
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
		BIO_printf(bio_err," cert1 cert2 ...\n");
 | 
							BIO_printf(bio_err," cert1 cert2 ...\n");
 | 
				
			||||||
 | 
					 | 
				
			||||||
		BIO_printf(bio_err,"recognized usages:\n");
 | 
							BIO_printf(bio_err,"recognized usages:\n");
 | 
				
			||||||
		for(i = 0; i < X509_PURPOSE_get_count(); i++)
 | 
							for(i = 0; i < X509_PURPOSE_get_count(); i++) {
 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			X509_PURPOSE *ptmp;
 | 
								X509_PURPOSE *ptmp;
 | 
				
			||||||
			ptmp = X509_PURPOSE_get0(i);
 | 
								ptmp = X509_PURPOSE_get0(i);
 | 
				
			||||||
			BIO_printf(bio_err, "\t%-10s\t%s\n",
 | 
								BIO_printf(bio_err, "\t%-10s\t%s\n", X509_PURPOSE_get0_sname(ptmp),
 | 
				
			||||||
					X509_PURPOSE_get0_sname(ptmp),
 | 
													X509_PURPOSE_get0_name(ptmp));
 | 
				
			||||||
					X509_PURPOSE_get0_name(ptmp));
 | 
							}
 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		BIO_printf(bio_err,"recognized verify names:\n");
 | 
					 | 
				
			||||||
		for(i = 0; i < X509_VERIFY_PARAM_get_count(); i++)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			const X509_VERIFY_PARAM *vptmp;
 | 
					 | 
				
			||||||
			vptmp = X509_VERIFY_PARAM_get0(i);
 | 
					 | 
				
			||||||
			BIO_printf(bio_err, "\t%-10s\n",
 | 
					 | 
				
			||||||
					X509_VERIFY_PARAM_get0_name(vptmp));
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	if (vpm) X509_VERIFY_PARAM_free(vpm);
 | 
						if (vpm) X509_VERIFY_PARAM_free(vpm);
 | 
				
			||||||
	if (cert_ctx != NULL) X509_STORE_free(cert_ctx);
 | 
						if (cert_ctx != NULL) X509_STORE_free(cert_ctx);
 | 
				
			||||||
	sk_X509_pop_free(untrusted, X509_free);
 | 
						sk_X509_pop_free(untrusted, X509_free);
 | 
				
			||||||
	sk_X509_pop_free(trusted, X509_free);
 | 
						sk_X509_pop_free(trusted, X509_free);
 | 
				
			||||||
	sk_X509_CRL_pop_free(crls, X509_CRL_free);
 | 
					 | 
				
			||||||
	apps_shutdown();
 | 
						apps_shutdown();
 | 
				
			||||||
	OPENSSL_EXIT(ret);
 | 
						OPENSSL_EXIT(ret);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static int check(X509_STORE *ctx, char *file,
 | 
					static int check(X509_STORE *ctx, char *file, STACK_OF(X509) *uchain, STACK_OF(X509) *tchain, int purpose, ENGINE *e)
 | 
				
			||||||
		STACK_OF(X509) *uchain, STACK_OF(X509) *tchain,
 | 
					 | 
				
			||||||
		STACK_OF(X509_CRL) *crls, ENGINE *e)
 | 
					 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
	X509 *x=NULL;
 | 
						X509 *x=NULL;
 | 
				
			||||||
	int i=0,ret=0;
 | 
						int i=0,ret=0;
 | 
				
			||||||
@@ -290,8 +260,7 @@ static int check(X509_STORE *ctx, char *file,
 | 
				
			|||||||
		goto end;
 | 
							goto end;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	if(tchain) X509_STORE_CTX_trusted_stack(csc, tchain);
 | 
						if(tchain) X509_STORE_CTX_trusted_stack(csc, tchain);
 | 
				
			||||||
	if (crls)
 | 
						if(purpose >= 0) X509_STORE_CTX_set_purpose(csc, purpose);
 | 
				
			||||||
		X509_STORE_CTX_set0_crls(csc, crls);
 | 
					 | 
				
			||||||
	i=X509_verify_cert(csc);
 | 
						i=X509_verify_cert(csc);
 | 
				
			||||||
	X509_STORE_CTX_free(csc);
 | 
						X509_STORE_CTX_free(csc);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -309,53 +278,90 @@ end:
 | 
				
			|||||||
	return(ret);
 | 
						return(ret);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static STACK_OF(X509) *load_untrusted(char *certfile)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						STACK_OF(X509_INFO) *sk=NULL;
 | 
				
			||||||
 | 
						STACK_OF(X509) *stack=NULL, *ret=NULL;
 | 
				
			||||||
 | 
						BIO *in=NULL;
 | 
				
			||||||
 | 
						X509_INFO *xi;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if(!(stack = sk_X509_new_null())) {
 | 
				
			||||||
 | 
							BIO_printf(bio_err,"memory allocation failure\n");
 | 
				
			||||||
 | 
							goto end;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if(!(in=BIO_new_file(certfile, "r"))) {
 | 
				
			||||||
 | 
							BIO_printf(bio_err,"error opening the file, %s\n",certfile);
 | 
				
			||||||
 | 
							goto end;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						/* This loads from a file, a stack of x509/crl/pkey sets */
 | 
				
			||||||
 | 
						if(!(sk=PEM_X509_INFO_read_bio(in,NULL,NULL,NULL))) {
 | 
				
			||||||
 | 
							BIO_printf(bio_err,"error reading the file, %s\n",certfile);
 | 
				
			||||||
 | 
							goto end;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						/* scan over it and pull out the certs */
 | 
				
			||||||
 | 
						while (sk_X509_INFO_num(sk))
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
							xi=sk_X509_INFO_shift(sk);
 | 
				
			||||||
 | 
							if (xi->x509 != NULL)
 | 
				
			||||||
 | 
								{
 | 
				
			||||||
 | 
								sk_X509_push(stack,xi->x509);
 | 
				
			||||||
 | 
								xi->x509=NULL;
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							X509_INFO_free(xi);
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						if(!sk_X509_num(stack)) {
 | 
				
			||||||
 | 
							BIO_printf(bio_err,"no certificates in file, %s\n",certfile);
 | 
				
			||||||
 | 
							sk_X509_free(stack);
 | 
				
			||||||
 | 
							goto end;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						ret=stack;
 | 
				
			||||||
 | 
					end:
 | 
				
			||||||
 | 
						BIO_free(in);
 | 
				
			||||||
 | 
						sk_X509_INFO_free(sk);
 | 
				
			||||||
 | 
						return(ret);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static int MS_CALLBACK cb(int ok, X509_STORE_CTX *ctx)
 | 
					static int MS_CALLBACK cb(int ok, X509_STORE_CTX *ctx)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
	int cert_error = X509_STORE_CTX_get_error(ctx);
 | 
						char buf[256];
 | 
				
			||||||
	X509 *current_cert = X509_STORE_CTX_get_current_cert(ctx);
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (!ok)
 | 
						if (!ok)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		if (current_cert)
 | 
							if (ctx->current_cert)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			X509_NAME_print_ex_fp(stdout,
 | 
								X509_NAME_oneline(
 | 
				
			||||||
				X509_get_subject_name(current_cert),
 | 
									X509_get_subject_name(ctx->current_cert),buf,
 | 
				
			||||||
				0, XN_FLAG_ONELINE);
 | 
									sizeof buf);
 | 
				
			||||||
			printf("\n");
 | 
								printf("%s\n",buf);
 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		printf("%serror %d at %d depth lookup:%s\n",
 | 
					 | 
				
			||||||
			X509_STORE_CTX_get0_parent_ctx(ctx) ? "[CRL path]" : "",
 | 
					 | 
				
			||||||
			cert_error,
 | 
					 | 
				
			||||||
			X509_STORE_CTX_get_error_depth(ctx),
 | 
					 | 
				
			||||||
			X509_verify_cert_error_string(cert_error));
 | 
					 | 
				
			||||||
		switch(cert_error)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			case X509_V_ERR_NO_EXPLICIT_POLICY:
 | 
					 | 
				
			||||||
				policies_print(NULL, ctx);
 | 
					 | 
				
			||||||
			case X509_V_ERR_CERT_HAS_EXPIRED:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
			/* since we are just checking the certificates, it is
 | 
					 | 
				
			||||||
			 * ok if they are self signed. But we should still warn
 | 
					 | 
				
			||||||
			 * the user.
 | 
					 | 
				
			||||||
			 */
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
			case X509_V_ERR_DEPTH_ZERO_SELF_SIGNED_CERT:
 | 
					 | 
				
			||||||
			/* Continue after extension errors too */
 | 
					 | 
				
			||||||
			case X509_V_ERR_INVALID_CA:
 | 
					 | 
				
			||||||
			case X509_V_ERR_INVALID_NON_CA:
 | 
					 | 
				
			||||||
			case X509_V_ERR_PATH_LENGTH_EXCEEDED:
 | 
					 | 
				
			||||||
			case X509_V_ERR_INVALID_PURPOSE:
 | 
					 | 
				
			||||||
			case X509_V_ERR_CRL_HAS_EXPIRED:
 | 
					 | 
				
			||||||
			case X509_V_ERR_CRL_NOT_YET_VALID:
 | 
					 | 
				
			||||||
			case X509_V_ERR_UNHANDLED_CRITICAL_EXTENSION:
 | 
					 | 
				
			||||||
			ok = 1;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
 | 
							printf("error %d at %d depth lookup:%s\n",ctx->error,
 | 
				
			||||||
 | 
								ctx->error_depth,
 | 
				
			||||||
 | 
								X509_verify_cert_error_string(ctx->error));
 | 
				
			||||||
 | 
							if (ctx->error == X509_V_ERR_CERT_HAS_EXPIRED) ok=1;
 | 
				
			||||||
 | 
							/* since we are just checking the certificates, it is
 | 
				
			||||||
 | 
							 * ok if they are self signed. But we should still warn
 | 
				
			||||||
 | 
							 * the user.
 | 
				
			||||||
 | 
					 		 */
 | 
				
			||||||
 | 
							if (ctx->error == X509_V_ERR_DEPTH_ZERO_SELF_SIGNED_CERT) ok=1;
 | 
				
			||||||
 | 
							/* Continue after extension errors too */
 | 
				
			||||||
 | 
							if (ctx->error == X509_V_ERR_INVALID_CA) ok=1;
 | 
				
			||||||
 | 
							if (ctx->error == X509_V_ERR_INVALID_NON_CA) ok=1;
 | 
				
			||||||
 | 
							if (ctx->error == X509_V_ERR_PATH_LENGTH_EXCEEDED) ok=1;
 | 
				
			||||||
 | 
							if (ctx->error == X509_V_ERR_INVALID_PURPOSE) ok=1;
 | 
				
			||||||
 | 
							if (ctx->error == X509_V_ERR_DEPTH_ZERO_SELF_SIGNED_CERT) ok=1;
 | 
				
			||||||
 | 
							if (ctx->error == X509_V_ERR_CRL_HAS_EXPIRED) ok=1;
 | 
				
			||||||
 | 
							if (ctx->error == X509_V_ERR_CRL_NOT_YET_VALID) ok=1;
 | 
				
			||||||
 | 
							if (ctx->error == X509_V_ERR_UNHANDLED_CRITICAL_EXTENSION) ok=1;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							if (ctx->error == X509_V_ERR_NO_EXPLICIT_POLICY)
 | 
				
			||||||
 | 
								policies_print(NULL, ctx);
 | 
				
			||||||
		return ok;
 | 
							return ok;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	if (cert_error == X509_V_OK && ok == 2)
 | 
						if ((ctx->error == X509_V_OK) && (ok == 2))
 | 
				
			||||||
		policies_print(NULL, ctx);
 | 
							policies_print(NULL, ctx);
 | 
				
			||||||
	if (!v_verbose)
 | 
						if (!v_verbose)
 | 
				
			||||||
		ERR_clear_error();
 | 
							ERR_clear_error();
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,188 +0,0 @@
 | 
				
			|||||||
#if defined( __VMS) && !defined( OPENSSL_NO_DECC_INIT) && \
 | 
					 | 
				
			||||||
 defined( __DECC) && !defined( __VAX) && (__CRTL_VER >= 70301000)
 | 
					 | 
				
			||||||
# define USE_DECC_INIT 1
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifdef USE_DECC_INIT
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
/*
 | 
					 | 
				
			||||||
 * 2010-04-26 SMS.
 | 
					 | 
				
			||||||
 *
 | 
					 | 
				
			||||||
 *----------------------------------------------------------------------
 | 
					 | 
				
			||||||
 *
 | 
					 | 
				
			||||||
 *       decc_init()
 | 
					 | 
				
			||||||
 *
 | 
					 | 
				
			||||||
 *    On non-VAX systems, uses LIB$INITIALIZE to set a collection of C
 | 
					 | 
				
			||||||
 *    RTL features without using the DECC$* logical name method.
 | 
					 | 
				
			||||||
 *
 | 
					 | 
				
			||||||
 *----------------------------------------------------------------------
 | 
					 | 
				
			||||||
 */
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#include <stdio.h>
 | 
					 | 
				
			||||||
#include <stdlib.h>
 | 
					 | 
				
			||||||
#include <unixlib.h>
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
/* Global storage. */
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
/* Flag to sense if decc_init() was called. */
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
int decc_init_done = -1;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
/* Structure to hold a DECC$* feature name and its desired value. */
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
typedef struct
 | 
					 | 
				
			||||||
{
 | 
					 | 
				
			||||||
    char *name;
 | 
					 | 
				
			||||||
    int value;
 | 
					 | 
				
			||||||
} decc_feat_t;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
/* Array of DECC$* feature names and their desired values.
 | 
					 | 
				
			||||||
 * Note: DECC$ARGV_PARSE_STYLE is the urgent one.
 | 
					 | 
				
			||||||
 */
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
decc_feat_t decc_feat_array[] =
 | 
					 | 
				
			||||||
{
 | 
					 | 
				
			||||||
 /* Preserve command-line case with SET PROCESS/PARSE_STYLE=EXTENDED */
 | 
					 | 
				
			||||||
 { "DECC$ARGV_PARSE_STYLE", 1 },
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 /* Preserve case for file names on ODS5 disks. */
 | 
					 | 
				
			||||||
 { "DECC$EFS_CASE_PRESERVE", 1 },
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 /* Enable multiple dots (and most characters) in ODS5 file names,
 | 
					 | 
				
			||||||
  * while preserving VMS-ness of ";version".
 | 
					 | 
				
			||||||
  */
 | 
					 | 
				
			||||||
 { "DECC$EFS_CHARSET", 1 },
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 /* List terminator. */
 | 
					 | 
				
			||||||
 { (char *)NULL, 0 }
 | 
					 | 
				
			||||||
};
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
/* LIB$INITIALIZE initialization function. */
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
static void decc_init( void)
 | 
					 | 
				
			||||||
{
 | 
					 | 
				
			||||||
    char *openssl_debug_decc_init;
 | 
					 | 
				
			||||||
    int verbose = 0;
 | 
					 | 
				
			||||||
    int feat_index;
 | 
					 | 
				
			||||||
    int feat_value;
 | 
					 | 
				
			||||||
    int feat_value_max;
 | 
					 | 
				
			||||||
    int feat_value_min;
 | 
					 | 
				
			||||||
    int i;
 | 
					 | 
				
			||||||
    int sts;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    /* Get debug option. */
 | 
					 | 
				
			||||||
    openssl_debug_decc_init = getenv( "OPENSSL_DEBUG_DECC_INIT");
 | 
					 | 
				
			||||||
    if (openssl_debug_decc_init != NULL)
 | 
					 | 
				
			||||||
    {
 | 
					 | 
				
			||||||
        verbose = strtol( openssl_debug_decc_init, NULL, 10);
 | 
					 | 
				
			||||||
        if (verbose <= 0)
 | 
					 | 
				
			||||||
        {
 | 
					 | 
				
			||||||
            verbose = 1;
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    /* Set the global flag to indicate that LIB$INITIALIZE worked. */
 | 
					 | 
				
			||||||
    decc_init_done = 1;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    /* Loop through all items in the decc_feat_array[]. */
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    for (i = 0; decc_feat_array[ i].name != NULL; i++)
 | 
					 | 
				
			||||||
    {
 | 
					 | 
				
			||||||
        /* Get the feature index. */
 | 
					 | 
				
			||||||
        feat_index = decc$feature_get_index( decc_feat_array[ i].name);
 | 
					 | 
				
			||||||
        if (feat_index >= 0)
 | 
					 | 
				
			||||||
        {
 | 
					 | 
				
			||||||
            /* Valid item.  Collect its properties. */
 | 
					 | 
				
			||||||
            feat_value = decc$feature_get_value( feat_index, 1);
 | 
					 | 
				
			||||||
            feat_value_min = decc$feature_get_value( feat_index, 2);
 | 
					 | 
				
			||||||
            feat_value_max = decc$feature_get_value( feat_index, 3);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
            /* Check the validity of our desired value. */
 | 
					 | 
				
			||||||
            if ((decc_feat_array[ i].value >= feat_value_min) &&
 | 
					 | 
				
			||||||
             (decc_feat_array[ i].value <= feat_value_max))
 | 
					 | 
				
			||||||
            {
 | 
					 | 
				
			||||||
                /* Valid value.  Set it if necessary. */
 | 
					 | 
				
			||||||
                if (feat_value != decc_feat_array[ i].value)
 | 
					 | 
				
			||||||
                {
 | 
					 | 
				
			||||||
                    sts = decc$feature_set_value( feat_index,
 | 
					 | 
				
			||||||
                     1,
 | 
					 | 
				
			||||||
                     decc_feat_array[ i].value);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
                     if (verbose > 1)
 | 
					 | 
				
			||||||
                     {
 | 
					 | 
				
			||||||
                         fprintf( stderr, " %s = %d, sts = %d.\n",
 | 
					 | 
				
			||||||
                          decc_feat_array[ i].name,
 | 
					 | 
				
			||||||
                          decc_feat_array[ i].value,
 | 
					 | 
				
			||||||
                          sts);
 | 
					 | 
				
			||||||
                     }
 | 
					 | 
				
			||||||
                }
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
            else
 | 
					 | 
				
			||||||
            {
 | 
					 | 
				
			||||||
                /* Invalid DECC feature value. */
 | 
					 | 
				
			||||||
                fprintf( stderr,
 | 
					 | 
				
			||||||
                 " INVALID DECC$FEATURE VALUE, %d: %d <= %s <= %d.\n",
 | 
					 | 
				
			||||||
                 feat_value,
 | 
					 | 
				
			||||||
                 feat_value_min, decc_feat_array[ i].name, feat_value_max);
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        else
 | 
					 | 
				
			||||||
        {
 | 
					 | 
				
			||||||
            /* Invalid DECC feature name. */
 | 
					 | 
				
			||||||
            fprintf( stderr,
 | 
					 | 
				
			||||||
             " UNKNOWN DECC$FEATURE: %s.\n", decc_feat_array[ i].name);
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    if (verbose > 0)
 | 
					 | 
				
			||||||
    {
 | 
					 | 
				
			||||||
        fprintf( stderr, " DECC_INIT complete.\n");
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
/* Get "decc_init()" into a valid, loaded LIB$INITIALIZE PSECT. */
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#pragma nostandard
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
/* Establish the LIB$INITIALIZE PSECTs, with proper alignment and
 | 
					 | 
				
			||||||
 * other attributes.  Note that "nopic" is significant only on VAX.
 | 
					 | 
				
			||||||
 */
 | 
					 | 
				
			||||||
#pragma extern_model save
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#if __INITIAL_POINTER_SIZE == 64
 | 
					 | 
				
			||||||
# define PSECT_ALIGN 3
 | 
					 | 
				
			||||||
#else
 | 
					 | 
				
			||||||
# define PSECT_ALIGN 2
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#pragma extern_model strict_refdef "LIB$INITIALIZ" PSECT_ALIGN, nopic, nowrt
 | 
					 | 
				
			||||||
const int spare[ 8] = { 0 };
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#pragma extern_model strict_refdef "LIB$INITIALIZE" PSECT_ALIGN, nopic, nowrt
 | 
					 | 
				
			||||||
void (*const x_decc_init)() = decc_init;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#pragma extern_model restore
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
/* Fake reference to ensure loading the LIB$INITIALIZE PSECT. */
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#pragma extern_model save
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
int LIB$INITIALIZE( void);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#pragma extern_model strict_refdef
 | 
					 | 
				
			||||||
int dmy_lib$initialize = (int) LIB$INITIALIZE;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#pragma extern_model restore
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#pragma standard
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#else /* def USE_DECC_INIT */
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
/* Dummy code to avoid a %CC-W-EMPTYFILE complaint. */
 | 
					 | 
				
			||||||
int decc_init_dummy( void);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#endif /* def USE_DECC_INIT */
 | 
					 | 
				
			||||||
							
								
								
									
										110
									
								
								apps/x509.c
									
									
									
									
									
								
							
							
						
						
									
										110
									
								
								apps/x509.c
									
									
									
									
									
								
							@@ -99,13 +99,7 @@ static const char *x509_usage[]={
 | 
				
			|||||||
" -passin arg     - private key password source\n",
 | 
					" -passin arg     - private key password source\n",
 | 
				
			||||||
" -serial         - print serial number value\n",
 | 
					" -serial         - print serial number value\n",
 | 
				
			||||||
" -subject_hash   - print subject hash value\n",
 | 
					" -subject_hash   - print subject hash value\n",
 | 
				
			||||||
#ifndef OPENSSL_NO_MD5
 | 
					 | 
				
			||||||
" -subject_hash_old   - print old-style (MD5) subject hash value\n",
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
" -issuer_hash    - print issuer hash value\n",
 | 
					" -issuer_hash    - print issuer hash value\n",
 | 
				
			||||||
#ifndef OPENSSL_NO_MD5
 | 
					 | 
				
			||||||
" -issuer_hash_old    - print old-style (MD5) issuer hash value\n",
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
" -hash           - synonym for -subject_hash\n",
 | 
					" -hash           - synonym for -subject_hash\n",
 | 
				
			||||||
" -subject        - print subject DN\n",
 | 
					" -subject        - print subject DN\n",
 | 
				
			||||||
" -issuer         - print issuer DN\n",
 | 
					" -issuer         - print issuer DN\n",
 | 
				
			||||||
@@ -157,10 +151,9 @@ static int MS_CALLBACK callb(int ok, X509_STORE_CTX *ctx);
 | 
				
			|||||||
static int sign (X509 *x, EVP_PKEY *pkey,int days,int clrext, const EVP_MD *digest,
 | 
					static int sign (X509 *x, EVP_PKEY *pkey,int days,int clrext, const EVP_MD *digest,
 | 
				
			||||||
						CONF *conf, char *section);
 | 
											CONF *conf, char *section);
 | 
				
			||||||
static int x509_certify (X509_STORE *ctx,char *CAfile,const EVP_MD *digest,
 | 
					static int x509_certify (X509_STORE *ctx,char *CAfile,const EVP_MD *digest,
 | 
				
			||||||
			 X509 *x,X509 *xca,EVP_PKEY *pkey,
 | 
								 X509 *x,X509 *xca,EVP_PKEY *pkey,char *serial,
 | 
				
			||||||
			 STACK_OF(OPENSSL_STRING) *sigopts,
 | 
								 int create,int days, int clrext, CONF *conf, char *section,
 | 
				
			||||||
			 char *serial, int create ,int days, int clrext,
 | 
											ASN1_INTEGER *sno);
 | 
				
			||||||
			 CONF *conf, char *section, ASN1_INTEGER *sno);
 | 
					 | 
				
			||||||
static int purpose_print(BIO *bio, X509 *cert, X509_PURPOSE *pt);
 | 
					static int purpose_print(BIO *bio, X509 *cert, X509_PURPOSE *pt);
 | 
				
			||||||
static int reqfile=0;
 | 
					static int reqfile=0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -173,8 +166,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	X509_REQ *req=NULL;
 | 
						X509_REQ *req=NULL;
 | 
				
			||||||
	X509 *x=NULL,*xca=NULL;
 | 
						X509 *x=NULL,*xca=NULL;
 | 
				
			||||||
	ASN1_OBJECT *objtmp;
 | 
						ASN1_OBJECT *objtmp;
 | 
				
			||||||
	STACK_OF(OPENSSL_STRING) *sigopts = NULL;
 | 
						EVP_PKEY *Upkey=NULL,*CApkey=NULL;
 | 
				
			||||||
	EVP_PKEY *Upkey=NULL,*CApkey=NULL, *fkey = NULL;
 | 
					 | 
				
			||||||
	ASN1_INTEGER *sno = NULL;
 | 
						ASN1_INTEGER *sno = NULL;
 | 
				
			||||||
	int i,num,badops=0;
 | 
						int i,num,badops=0;
 | 
				
			||||||
	BIO *out=NULL;
 | 
						BIO *out=NULL;
 | 
				
			||||||
@@ -183,14 +175,10 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	int informat,outformat,keyformat,CAformat,CAkeyformat;
 | 
						int informat,outformat,keyformat,CAformat,CAkeyformat;
 | 
				
			||||||
	char *infile=NULL,*outfile=NULL,*keyfile=NULL,*CAfile=NULL;
 | 
						char *infile=NULL,*outfile=NULL,*keyfile=NULL,*CAfile=NULL;
 | 
				
			||||||
	char *CAkeyfile=NULL,*CAserial=NULL;
 | 
						char *CAkeyfile=NULL,*CAserial=NULL;
 | 
				
			||||||
	char *fkeyfile=NULL;
 | 
					 | 
				
			||||||
	char *alias=NULL;
 | 
						char *alias=NULL;
 | 
				
			||||||
	int text=0,serial=0,subject=0,issuer=0,startdate=0,enddate=0;
 | 
						int text=0,serial=0,subject=0,issuer=0,startdate=0,enddate=0;
 | 
				
			||||||
	int next_serial=0;
 | 
						int next_serial=0;
 | 
				
			||||||
	int subject_hash=0,issuer_hash=0,ocspid=0;
 | 
						int subject_hash=0,issuer_hash=0,ocspid=0;
 | 
				
			||||||
#ifndef OPENSSL_NO_MD5
 | 
					 | 
				
			||||||
	int subject_hash_old=0,issuer_hash_old=0;
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	int noout=0,sign_flag=0,CA_flag=0,CA_createserial=0,email=0;
 | 
						int noout=0,sign_flag=0,CA_flag=0,CA_createserial=0,email=0;
 | 
				
			||||||
	int ocsp_uri=0;
 | 
						int ocsp_uri=0;
 | 
				
			||||||
	int trustout=0,clrtrust=0,clrreject=0,aliasout=0,clrext=0;
 | 
						int trustout=0,clrtrust=0,clrreject=0,aliasout=0,clrext=0;
 | 
				
			||||||
@@ -237,7 +225,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	ctx=X509_STORE_new();
 | 
						ctx=X509_STORE_new();
 | 
				
			||||||
	if (ctx == NULL) goto end;
 | 
						if (ctx == NULL) goto end;
 | 
				
			||||||
	X509_STORE_set_verify_cb(ctx,callb);
 | 
						X509_STORE_set_verify_cb_func(ctx,callb);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	argc--;
 | 
						argc--;
 | 
				
			||||||
	argv++;
 | 
						argv++;
 | 
				
			||||||
@@ -274,22 +262,13 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
			CAkeyformat=str2fmt(*(++argv));
 | 
								CAkeyformat=str2fmt(*(++argv));
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else if (strcmp(*argv,"-sigopt") == 0)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if (--argc < 1)
 | 
					 | 
				
			||||||
				goto bad;
 | 
					 | 
				
			||||||
			if (!sigopts)
 | 
					 | 
				
			||||||
				sigopts = sk_OPENSSL_STRING_new_null();
 | 
					 | 
				
			||||||
			if (!sigopts || !sk_OPENSSL_STRING_push(sigopts, *(++argv)))
 | 
					 | 
				
			||||||
				goto bad;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-days") == 0)
 | 
							else if (strcmp(*argv,"-days") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
			days=atoi(*(++argv));
 | 
								days=atoi(*(++argv));
 | 
				
			||||||
			if (days == 0)
 | 
								if (days == 0)
 | 
				
			||||||
				{
 | 
									{
 | 
				
			||||||
				BIO_printf(bio_err,"bad number of days\n");
 | 
									BIO_printf(STDout,"bad number of days\n");
 | 
				
			||||||
				goto bad;
 | 
									goto bad;
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
@@ -348,11 +327,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			if (!(sno = s2i_ASN1_INTEGER(NULL, *(++argv))))
 | 
								if (!(sno = s2i_ASN1_INTEGER(NULL, *(++argv))))
 | 
				
			||||||
				goto bad;
 | 
									goto bad;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else if (strcmp(*argv,"-force_pubkey") == 0)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
					 | 
				
			||||||
			fkeyfile= *(++argv);
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-addtrust") == 0)
 | 
							else if (strcmp(*argv,"-addtrust") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
@@ -423,16 +397,8 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		else if (strcmp(*argv,"-hash") == 0
 | 
							else if (strcmp(*argv,"-hash") == 0
 | 
				
			||||||
			|| strcmp(*argv,"-subject_hash") == 0)
 | 
								|| strcmp(*argv,"-subject_hash") == 0)
 | 
				
			||||||
			subject_hash= ++num;
 | 
								subject_hash= ++num;
 | 
				
			||||||
#ifndef OPENSSL_NO_MD5
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-subject_hash_old") == 0)
 | 
					 | 
				
			||||||
			subject_hash_old= ++num;
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-issuer_hash") == 0)
 | 
							else if (strcmp(*argv,"-issuer_hash") == 0)
 | 
				
			||||||
			issuer_hash= ++num;
 | 
								issuer_hash= ++num;
 | 
				
			||||||
#ifndef OPENSSL_NO_MD5
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-issuer_hash_old") == 0)
 | 
					 | 
				
			||||||
			issuer_hash_old= ++num;
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-subject") == 0)
 | 
							else if (strcmp(*argv,"-subject") == 0)
 | 
				
			||||||
			subject= ++num;
 | 
								subject= ++num;
 | 
				
			||||||
		else if (strcmp(*argv,"-issuer") == 0)
 | 
							else if (strcmp(*argv,"-issuer") == 0)
 | 
				
			||||||
@@ -523,13 +489,6 @@ bad:
 | 
				
			|||||||
		goto end;
 | 
							goto end;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (fkeyfile)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		fkey = load_pubkey(bio_err, fkeyfile, keyformat, 0,
 | 
					 | 
				
			||||||
						NULL, e, "Forced key");
 | 
					 | 
				
			||||||
		if (fkey == NULL) goto end;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if ((CAkeyfile == NULL) && (CA_flag) && (CAformat == FORMAT_PEM))
 | 
						if ((CAkeyfile == NULL) && (CA_flag) && (CAformat == FORMAT_PEM))
 | 
				
			||||||
		{ CAkeyfile=CAfile; }
 | 
							{ CAkeyfile=CAfile; }
 | 
				
			||||||
	else if ((CA_flag) && (CAkeyfile == NULL))
 | 
						else if ((CA_flag) && (CAkeyfile == NULL))
 | 
				
			||||||
@@ -580,6 +539,7 @@ bad:
 | 
				
			|||||||
	if (reqfile)
 | 
						if (reqfile)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		EVP_PKEY *pkey;
 | 
							EVP_PKEY *pkey;
 | 
				
			||||||
 | 
							X509_CINF *ci;
 | 
				
			||||||
		BIO *in;
 | 
							BIO *in;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if (!sign_flag && !CA_flag)
 | 
							if (!sign_flag && !CA_flag)
 | 
				
			||||||
@@ -647,6 +607,7 @@ bad:
 | 
				
			|||||||
		print_name(bio_err, "subject=", X509_REQ_get_subject_name(req), nmflag);
 | 
							print_name(bio_err, "subject=", X509_REQ_get_subject_name(req), nmflag);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if ((x=X509_new()) == NULL) goto end;
 | 
							if ((x=X509_new()) == NULL) goto end;
 | 
				
			||||||
 | 
							ci=x->cert_info;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if (sno == NULL)
 | 
							if (sno == NULL)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
@@ -665,15 +626,11 @@ bad:
 | 
				
			|||||||
		if (!X509_set_subject_name(x,req->req_info->subject)) goto end;
 | 
							if (!X509_set_subject_name(x,req->req_info->subject)) goto end;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		X509_gmtime_adj(X509_get_notBefore(x),0);
 | 
							X509_gmtime_adj(X509_get_notBefore(x),0);
 | 
				
			||||||
	        X509_time_adj_ex(X509_get_notAfter(x),days, 0, NULL);
 | 
						        X509_gmtime_adj(X509_get_notAfter(x),(long)60*60*24*days);
 | 
				
			||||||
		if (fkey)
 | 
					
 | 
				
			||||||
			X509_set_pubkey(x, fkey);
 | 
							pkey = X509_REQ_get_pubkey(req);
 | 
				
			||||||
		else
 | 
							X509_set_pubkey(x,pkey);
 | 
				
			||||||
			{
 | 
							EVP_PKEY_free(pkey);
 | 
				
			||||||
			pkey = X509_REQ_get_pubkey(req);
 | 
					 | 
				
			||||||
			X509_set_pubkey(x,pkey);
 | 
					 | 
				
			||||||
			EVP_PKEY_free(pkey);
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	else
 | 
						else
 | 
				
			||||||
		x=load_cert(bio_err,infile,informat,NULL,e,"Certificate");
 | 
							x=load_cert(bio_err,infile,informat,NULL,e,"Certificate");
 | 
				
			||||||
@@ -781,14 +738,14 @@ bad:
 | 
				
			|||||||
			else if ((email == i) || (ocsp_uri == i))
 | 
								else if ((email == i) || (ocsp_uri == i))
 | 
				
			||||||
				{
 | 
									{
 | 
				
			||||||
				int j;
 | 
									int j;
 | 
				
			||||||
				STACK_OF(OPENSSL_STRING) *emlst;
 | 
									STACK_OF(STRING) *emlst;
 | 
				
			||||||
				if (email == i)
 | 
									if (email == i)
 | 
				
			||||||
					emlst = X509_get1_email(x);
 | 
										emlst = X509_get1_email(x);
 | 
				
			||||||
				else
 | 
									else
 | 
				
			||||||
					emlst = X509_get1_ocsp(x);
 | 
										emlst = X509_get1_ocsp(x);
 | 
				
			||||||
				for (j = 0; j < sk_OPENSSL_STRING_num(emlst); j++)
 | 
									for (j = 0; j < sk_STRING_num(emlst); j++)
 | 
				
			||||||
					BIO_printf(STDout, "%s\n",
 | 
										BIO_printf(STDout, "%s\n",
 | 
				
			||||||
						   sk_OPENSSL_STRING_value(emlst, j));
 | 
											   sk_STRING_value(emlst, j));
 | 
				
			||||||
				X509_email_free(emlst);
 | 
									X509_email_free(emlst);
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
			else if (aliasout == i)
 | 
								else if (aliasout == i)
 | 
				
			||||||
@@ -802,22 +759,10 @@ bad:
 | 
				
			|||||||
				{
 | 
									{
 | 
				
			||||||
				BIO_printf(STDout,"%08lx\n",X509_subject_name_hash(x));
 | 
									BIO_printf(STDout,"%08lx\n",X509_subject_name_hash(x));
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
#ifndef OPENSSL_NO_MD5
 | 
					 | 
				
			||||||
			else if (subject_hash_old == i)
 | 
					 | 
				
			||||||
				{
 | 
					 | 
				
			||||||
				BIO_printf(STDout,"%08lx\n",X509_subject_name_hash_old(x));
 | 
					 | 
				
			||||||
				}
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
			else if (issuer_hash == i)
 | 
								else if (issuer_hash == i)
 | 
				
			||||||
				{
 | 
									{
 | 
				
			||||||
				BIO_printf(STDout,"%08lx\n",X509_issuer_name_hash(x));
 | 
									BIO_printf(STDout,"%08lx\n",X509_issuer_name_hash(x));
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
#ifndef OPENSSL_NO_MD5
 | 
					 | 
				
			||||||
			else if (issuer_hash_old == i)
 | 
					 | 
				
			||||||
				{
 | 
					 | 
				
			||||||
				BIO_printf(STDout,"%08lx\n",X509_issuer_name_hash_old(x));
 | 
					 | 
				
			||||||
				}
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
			else if (pprint == i)
 | 
								else if (pprint == i)
 | 
				
			||||||
				{
 | 
									{
 | 
				
			||||||
				X509_PURPOSE *ptmp;
 | 
									X509_PURPOSE *ptmp;
 | 
				
			||||||
@@ -929,7 +874,7 @@ bad:
 | 
				
			|||||||
				}
 | 
									}
 | 
				
			||||||
			else if (text == i)
 | 
								else if (text == i)
 | 
				
			||||||
				{
 | 
									{
 | 
				
			||||||
				X509_print_ex(STDout,x,nmflag, certflag);
 | 
									X509_print_ex(out,x,nmflag, certflag);
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
			else if (startdate == i)
 | 
								else if (startdate == i)
 | 
				
			||||||
				{
 | 
									{
 | 
				
			||||||
@@ -998,8 +943,7 @@ bad:
 | 
				
			|||||||
				
 | 
									
 | 
				
			||||||
				assert(need_rand);
 | 
									assert(need_rand);
 | 
				
			||||||
				if (!x509_certify(ctx,CAfile,digest,x,xca,
 | 
									if (!x509_certify(ctx,CAfile,digest,x,xca,
 | 
				
			||||||
					CApkey, sigopts,
 | 
										CApkey, CAserial,CA_createserial,days, clrext,
 | 
				
			||||||
					CAserial,CA_createserial,days, clrext,
 | 
					 | 
				
			||||||
					extconf, extsect, sno))
 | 
										extconf, extsect, sno))
 | 
				
			||||||
					goto end;
 | 
										goto end;
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
@@ -1016,7 +960,7 @@ bad:
 | 
				
			|||||||
				else
 | 
									else
 | 
				
			||||||
					{
 | 
										{
 | 
				
			||||||
					pk=load_key(bio_err,
 | 
										pk=load_key(bio_err,
 | 
				
			||||||
						keyfile, keyformat, 0,
 | 
											keyfile, FORMAT_PEM, 0,
 | 
				
			||||||
						passin, e, "request key");
 | 
											passin, e, "request key");
 | 
				
			||||||
					if (pk == NULL) goto end;
 | 
										if (pk == NULL) goto end;
 | 
				
			||||||
					}
 | 
										}
 | 
				
			||||||
@@ -1110,9 +1054,6 @@ end:
 | 
				
			|||||||
	X509_free(xca);
 | 
						X509_free(xca);
 | 
				
			||||||
	EVP_PKEY_free(Upkey);
 | 
						EVP_PKEY_free(Upkey);
 | 
				
			||||||
	EVP_PKEY_free(CApkey);
 | 
						EVP_PKEY_free(CApkey);
 | 
				
			||||||
	EVP_PKEY_free(fkey);
 | 
					 | 
				
			||||||
	if (sigopts)
 | 
					 | 
				
			||||||
		sk_OPENSSL_STRING_free(sigopts);
 | 
					 | 
				
			||||||
	X509_REQ_free(rq);
 | 
						X509_REQ_free(rq);
 | 
				
			||||||
	ASN1_INTEGER_free(sno);
 | 
						ASN1_INTEGER_free(sno);
 | 
				
			||||||
	sk_ASN1_OBJECT_pop_free(trust, ASN1_OBJECT_free);
 | 
						sk_ASN1_OBJECT_pop_free(trust, ASN1_OBJECT_free);
 | 
				
			||||||
@@ -1163,11 +1104,8 @@ static ASN1_INTEGER *x509_load_serial(char *CAfile, char *serialfile, int create
 | 
				
			|||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static int x509_certify(X509_STORE *ctx, char *CAfile, const EVP_MD *digest,
 | 
					static int x509_certify(X509_STORE *ctx, char *CAfile, const EVP_MD *digest,
 | 
				
			||||||
	     		X509 *x, X509 *xca, EVP_PKEY *pkey,
 | 
						     X509 *x, X509 *xca, EVP_PKEY *pkey, char *serialfile, int create,
 | 
				
			||||||
			STACK_OF(OPENSSL_STRING) *sigopts,
 | 
						     int days, int clrext, CONF *conf, char *section, ASN1_INTEGER *sno)
 | 
				
			||||||
	  		char *serialfile, int create,
 | 
					 | 
				
			||||||
	     		int days, int clrext, CONF *conf, char *section,
 | 
					 | 
				
			||||||
			ASN1_INTEGER *sno)
 | 
					 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
	int ret=0;
 | 
						int ret=0;
 | 
				
			||||||
	ASN1_INTEGER *bs=NULL;
 | 
						ASN1_INTEGER *bs=NULL;
 | 
				
			||||||
@@ -1192,7 +1130,6 @@ static int x509_certify(X509_STORE *ctx, char *CAfile, const EVP_MD *digest,
 | 
				
			|||||||
	/* NOTE: this certificate can/should be self signed, unless it was
 | 
						/* NOTE: this certificate can/should be self signed, unless it was
 | 
				
			||||||
	 * a certificate request in which case it is not. */
 | 
						 * a certificate request in which case it is not. */
 | 
				
			||||||
	X509_STORE_CTX_set_cert(&xsc,x);
 | 
						X509_STORE_CTX_set_cert(&xsc,x);
 | 
				
			||||||
	X509_STORE_CTX_set_flags(&xsc, X509_V_FLAG_CHECK_SS_SIGNATURE);
 | 
					 | 
				
			||||||
	if (!reqfile && X509_verify_cert(&xsc) <= 0)
 | 
						if (!reqfile && X509_verify_cert(&xsc) <= 0)
 | 
				
			||||||
		goto end;
 | 
							goto end;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -1209,7 +1146,7 @@ static int x509_certify(X509_STORE *ctx, char *CAfile, const EVP_MD *digest,
 | 
				
			|||||||
		goto end;
 | 
							goto end;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/* hardwired expired */
 | 
						/* hardwired expired */
 | 
				
			||||||
	if (X509_time_adj_ex(X509_get_notAfter(x),days, 0, NULL) == NULL)
 | 
						if (X509_gmtime_adj(X509_get_notAfter(x),(long)60*60*24*days) == NULL)
 | 
				
			||||||
		goto end;
 | 
							goto end;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (clrext)
 | 
						if (clrext)
 | 
				
			||||||
@@ -1226,8 +1163,7 @@ static int x509_certify(X509_STORE *ctx, char *CAfile, const EVP_MD *digest,
 | 
				
			|||||||
                if (!X509V3_EXT_add_nconf(conf, &ctx2, section, x)) goto end;
 | 
					                if (!X509V3_EXT_add_nconf(conf, &ctx2, section, x)) goto end;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (!do_X509_sign(bio_err, x, pkey, digest, sigopts))
 | 
						if (!X509_sign(x,pkey,digest)) goto end;
 | 
				
			||||||
		goto end;
 | 
					 | 
				
			||||||
	ret=1;
 | 
						ret=1;
 | 
				
			||||||
end:
 | 
					end:
 | 
				
			||||||
	X509_STORE_CTX_cleanup(&xsc);
 | 
						X509_STORE_CTX_cleanup(&xsc);
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										126
									
								
								config
									
									
									
									
									
								
							
							
						
						
									
										126
									
								
								config
									
									
									
									
									
								
							@@ -48,10 +48,10 @@ done
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
# First get uname entries that we use below
 | 
					# First get uname entries that we use below
 | 
				
			||||||
 | 
					
 | 
				
			||||||
[ "$MACHINE" ] || MACHINE=`(uname -m) 2>/dev/null` || MACHINE="unknown"
 | 
					MACHINE=`(uname -m) 2>/dev/null` || MACHINE="unknown"
 | 
				
			||||||
[ "$RELEASE" ] || RELEASE=`(uname -r) 2>/dev/null` || RELEASE="unknown"
 | 
					RELEASE=`(uname -r) 2>/dev/null` || RELEASE="unknown"
 | 
				
			||||||
[ "$SYSTEM" ] || SYSTEM=`(uname -s) 2>/dev/null`  || SYSTEM="unknown"
 | 
					SYSTEM=`(uname -s) 2>/dev/null`  || SYSTEM="unknown"
 | 
				
			||||||
[ "$BUILD" ] || VERSION=`(uname -v) 2>/dev/null` || VERSION="unknown"
 | 
					VERSION=`(uname -v) 2>/dev/null` || VERSION="unknown"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Now test for ISC and SCO, since it is has a braindamaged uname.
 | 
					# Now test for ISC and SCO, since it is has a braindamaged uname.
 | 
				
			||||||
@@ -370,10 +370,6 @@ case "${SYSTEM}:${RELEASE}:${VERSION}:${MACHINE}" in
 | 
				
			|||||||
    NONSTOP_KERNEL*)
 | 
					    NONSTOP_KERNEL*)
 | 
				
			||||||
       echo "nsr-tandem-nsk"; exit 0;
 | 
					       echo "nsr-tandem-nsk"; exit 0;
 | 
				
			||||||
       ;;
 | 
					       ;;
 | 
				
			||||||
 | 
					 | 
				
			||||||
    vxworks*)
 | 
					 | 
				
			||||||
       echo "${MACHINE}-whatever-vxworks"; exit 0;
 | 
					 | 
				
			||||||
       ;;
 | 
					 | 
				
			||||||
esac
 | 
					esac
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
@@ -411,18 +407,23 @@ exit 0
 | 
				
			|||||||
# this is where the translation occurs into SSLeay terms
 | 
					# this is where the translation occurs into SSLeay terms
 | 
				
			||||||
# ---------------------------------------------------------------------------
 | 
					# ---------------------------------------------------------------------------
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					GCCVER=`(gcc -dumpversion) 2>/dev/null`
 | 
				
			||||||
 | 
					if [ "$GCCVER" != "" ]; then
 | 
				
			||||||
 | 
					  # then strip off whatever prefix egcs prepends the number with...
 | 
				
			||||||
 | 
					  # Hopefully, this will work for any future prefixes as well.
 | 
				
			||||||
 | 
					  GCCVER=`echo $GCCVER | LC_ALL=C sed 's/^[a-zA-Z]*\-//'`
 | 
				
			||||||
 | 
					  # Since gcc 3.1 gcc --version behaviour has changed.  gcc -dumpversion
 | 
				
			||||||
 | 
					  # does give us what we want though, so we use that.  We just just the
 | 
				
			||||||
 | 
					  # major and minor version numbers.
 | 
				
			||||||
 | 
					  # peak single digit before and after first dot, e.g. 2.95.1 gives 29
 | 
				
			||||||
 | 
					  GCCVER=`echo $GCCVER | sed 's/\([0-9]\)\.\([0-9]\).*/\1\2/'`
 | 
				
			||||||
 | 
					fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Only set CC if not supplied already
 | 
					# Only set CC if not supplied already
 | 
				
			||||||
if [ -z "$CROSS_COMPILE$CC" ]; then
 | 
					if [ -z "$CC" ]; then
 | 
				
			||||||
  GCCVER=`sh -c "gcc -dumpversion" 2>/dev/null`
 | 
					# figure out if gcc is available and if so we use it otherwise
 | 
				
			||||||
 | 
					# we fallback to whatever cc does on the system
 | 
				
			||||||
  if [ "$GCCVER" != "" ]; then
 | 
					  if [ "$GCCVER" != "" ]; then
 | 
				
			||||||
    # then strip off whatever prefix egcs prepends the number with...
 | 
					 | 
				
			||||||
    # Hopefully, this will work for any future prefixes as well.
 | 
					 | 
				
			||||||
    GCCVER=`echo $GCCVER | LC_ALL=C sed 's/^[a-zA-Z]*\-//'`
 | 
					 | 
				
			||||||
    # Since gcc 3.1 gcc --version behaviour has changed.  gcc -dumpversion
 | 
					 | 
				
			||||||
    # does give us what we want though, so we use that.  We just just the
 | 
					 | 
				
			||||||
    # major and minor version numbers.
 | 
					 | 
				
			||||||
    # peak single digit before and after first dot, e.g. 2.95.1 gives 29
 | 
					 | 
				
			||||||
    GCCVER=`echo $GCCVER | sed 's/\([0-9]\)\.\([0-9]\).*/\1\2/'`
 | 
					 | 
				
			||||||
    CC=gcc
 | 
					    CC=gcc
 | 
				
			||||||
  else
 | 
					  else
 | 
				
			||||||
    CC=cc
 | 
					    CC=cc
 | 
				
			||||||
@@ -495,12 +496,6 @@ echo Operating system: $GUESSOS
 | 
				
			|||||||
# script above so we end up with values in vars but that would take
 | 
					# script above so we end up with values in vars but that would take
 | 
				
			||||||
# more time that I want to waste at the moment
 | 
					# more time that I want to waste at the moment
 | 
				
			||||||
case "$GUESSOS" in
 | 
					case "$GUESSOS" in
 | 
				
			||||||
  uClinux*64*)
 | 
					 | 
				
			||||||
    OUT=uClinux-dist64
 | 
					 | 
				
			||||||
	;;
 | 
					 | 
				
			||||||
  uClinux*)
 | 
					 | 
				
			||||||
    OUT=uClinux-dist
 | 
					 | 
				
			||||||
	;;
 | 
					 | 
				
			||||||
  mips2-sgi-irix)
 | 
					  mips2-sgi-irix)
 | 
				
			||||||
	CPU=`(hinv -t cpu) 2>/dev/null | head -1 | sed 's/^CPU:[^R]*R\([0-9]*\).*/\1/'`
 | 
						CPU=`(hinv -t cpu) 2>/dev/null | head -1 | sed 's/^CPU:[^R]*R\([0-9]*\).*/\1/'`
 | 
				
			||||||
	CPU=${CPU:-0}
 | 
						CPU=${CPU:-0}
 | 
				
			||||||
@@ -538,7 +533,7 @@ case "$GUESSOS" in
 | 
				
			|||||||
  ppc-apple-rhapsody) OUT="rhapsody-ppc-cc" ;;
 | 
					  ppc-apple-rhapsody) OUT="rhapsody-ppc-cc" ;;
 | 
				
			||||||
  ppc-apple-darwin*)
 | 
					  ppc-apple-darwin*)
 | 
				
			||||||
	ISA64=`(sysctl -n hw.optional.64bitops) 2>/dev/null`
 | 
						ISA64=`(sysctl -n hw.optional.64bitops) 2>/dev/null`
 | 
				
			||||||
	if [ "$ISA64" = "1" -a -z "$KERNEL_BITS" ]; then
 | 
						if [ "$ISA64" = "1" ]; then
 | 
				
			||||||
	    echo "WARNING! If you wish to build 64-bit library, then you have to"
 | 
						    echo "WARNING! If you wish to build 64-bit library, then you have to"
 | 
				
			||||||
	    echo "         invoke './Configure darwin64-ppc-cc' *manually*."
 | 
						    echo "         invoke './Configure darwin64-ppc-cc' *manually*."
 | 
				
			||||||
	    if [ "$TEST" = "false" -a -t 1 ]; then
 | 
						    if [ "$TEST" = "false" -a -t 1 ]; then
 | 
				
			||||||
@@ -546,14 +541,10 @@ case "$GUESSOS" in
 | 
				
			|||||||
	      (trap "stty `stty -g`" 2 0; stty -icanon min 0 time 50; read waste) <&1
 | 
						      (trap "stty `stty -g`" 2 0; stty -icanon min 0 time 50; read waste) <&1
 | 
				
			||||||
	    fi
 | 
						    fi
 | 
				
			||||||
	fi
 | 
						fi
 | 
				
			||||||
	if [ "$ISA64" = "1" -a "$KERNEL_BITS" = "64" ]; then
 | 
						OUT="darwin-ppc-cc" ;;
 | 
				
			||||||
	    OUT="darwin64-ppc-cc"
 | 
					 | 
				
			||||||
	else
 | 
					 | 
				
			||||||
	    OUT="darwin-ppc-cc"
 | 
					 | 
				
			||||||
	fi ;;
 | 
					 | 
				
			||||||
  i?86-apple-darwin*)
 | 
					  i?86-apple-darwin*)
 | 
				
			||||||
	ISA64=`(sysctl -n hw.optional.x86_64) 2>/dev/null`
 | 
						ISA64=`(sysctl -n hw.optional.x86_64) 2>/dev/null`
 | 
				
			||||||
	if [ "$ISA64" = "1" -a -z "$KERNEL_BITS" ]; then
 | 
						if [ "$ISA64" = "1" ]; then
 | 
				
			||||||
	    echo "WARNING! If you wish to build 64-bit library, then you have to"
 | 
						    echo "WARNING! If you wish to build 64-bit library, then you have to"
 | 
				
			||||||
	    echo "         invoke './Configure darwin64-x86_64-cc' *manually*."
 | 
						    echo "         invoke './Configure darwin64-x86_64-cc' *manually*."
 | 
				
			||||||
	    if [ "$TEST" = "false" -a -t 1 ]; then
 | 
						    if [ "$TEST" = "false" -a -t 1 ]; then
 | 
				
			||||||
@@ -561,17 +552,7 @@ case "$GUESSOS" in
 | 
				
			|||||||
	      (trap "stty `stty -g`" 2 0; stty -icanon min 0 time 50; read waste) <&1
 | 
						      (trap "stty `stty -g`" 2 0; stty -icanon min 0 time 50; read waste) <&1
 | 
				
			||||||
	    fi
 | 
						    fi
 | 
				
			||||||
	fi
 | 
						fi
 | 
				
			||||||
	if [ "$ISA64" = "1" -a "$KERNEL_BITS" = "64" ]; then
 | 
						OUT="darwin-i386-cc" ;;
 | 
				
			||||||
	    OUT="darwin64-x86_64-cc"
 | 
					 | 
				
			||||||
	else
 | 
					 | 
				
			||||||
	    OUT="darwin-i386-cc"
 | 
					 | 
				
			||||||
	fi ;;
 | 
					 | 
				
			||||||
  armv6+7-*-iphoneos)
 | 
					 | 
				
			||||||
	options="$options -arch%20armv6 -arch%20armv7"
 | 
					 | 
				
			||||||
	OUT="iphoneos-cross" ;;
 | 
					 | 
				
			||||||
  *-*-iphoneos)
 | 
					 | 
				
			||||||
	options="$options -arch%20${MACHINE}"
 | 
					 | 
				
			||||||
	OUT="iphoneos-cross" ;;
 | 
					 | 
				
			||||||
  alpha-*-linux2)
 | 
					  alpha-*-linux2)
 | 
				
			||||||
        ISA=`awk '/cpu model/{print$4;exit(0);}' /proc/cpuinfo`
 | 
					        ISA=`awk '/cpu model/{print$4;exit(0);}' /proc/cpuinfo`
 | 
				
			||||||
	case ${ISA:-generic} in
 | 
						case ${ISA:-generic} in
 | 
				
			||||||
@@ -596,11 +577,6 @@ case "$GUESSOS" in
 | 
				
			|||||||
	OUT="linux-ppc"
 | 
						OUT="linux-ppc"
 | 
				
			||||||
	;;
 | 
						;;
 | 
				
			||||||
  ppc-*-linux2) OUT="linux-ppc" ;;
 | 
					  ppc-*-linux2) OUT="linux-ppc" ;;
 | 
				
			||||||
  ppc60x-*-vxworks*) OUT="vxworks-ppc60x" ;;
 | 
					 | 
				
			||||||
  ppcgen-*-vxworks*) OUT="vxworks-ppcgen" ;;
 | 
					 | 
				
			||||||
  pentium-*-vxworks*) OUT="vxworks-pentium" ;;
 | 
					 | 
				
			||||||
  simlinux-*-vxworks*) OUT="vxworks-simlinux" ;;
 | 
					 | 
				
			||||||
  mips-*-vxworks*) OUT="vxworks-mips";;
 | 
					 | 
				
			||||||
  ia64-*-linux?) OUT="linux-ia64" ;;
 | 
					  ia64-*-linux?) OUT="linux-ia64" ;;
 | 
				
			||||||
  sparc64-*-linux2)
 | 
					  sparc64-*-linux2)
 | 
				
			||||||
	echo "WARNING! If you *know* that your GNU C supports 64-bit/V9 ABI"
 | 
						echo "WARNING! If you *know* that your GNU C supports 64-bit/V9 ABI"
 | 
				
			||||||
@@ -642,24 +618,12 @@ case "$GUESSOS" in
 | 
				
			|||||||
	options="$options -DB_ENDIAN -mschedule=$CPUSCHEDULE -march=$CPUARCH"
 | 
						options="$options -DB_ENDIAN -mschedule=$CPUSCHEDULE -march=$CPUARCH"
 | 
				
			||||||
	OUT="linux-generic32" ;;
 | 
						OUT="linux-generic32" ;;
 | 
				
			||||||
  armv[1-3]*-*-linux2) OUT="linux-generic32" ;;
 | 
					  armv[1-3]*-*-linux2) OUT="linux-generic32" ;;
 | 
				
			||||||
  armv[7-9]*-*-linux2) OUT="linux-armv4"; options="$options -march=armv7-a" ;;
 | 
					 | 
				
			||||||
  arm*-*-linux2) OUT="linux-armv4" ;;
 | 
					  arm*-*-linux2) OUT="linux-armv4" ;;
 | 
				
			||||||
  sh*b-*-linux2) OUT="linux-generic32"; options="$options -DB_ENDIAN" ;;
 | 
					  sh*b-*-linux2) OUT="linux-generic32"; options="$options -DB_ENDIAN" ;;
 | 
				
			||||||
  sh*-*-linux2)  OUT="linux-generic32"; options="$options -DL_ENDIAN" ;;
 | 
					  sh*-*-linux2)  OUT="linux-generic32"; options="$options -DL_ENDIAN" ;;
 | 
				
			||||||
  m68k*-*-linux2) OUT="linux-generic32"; options="$options -DB_ENDIAN" ;;
 | 
					  m68k*-*-linux2) OUT="linux-generic32"; options="$options -DB_ENDIAN" ;;
 | 
				
			||||||
  s390-*-linux2) OUT="linux-generic32"; options="$options -DB_ENDIAN" ;;
 | 
					  s390-*-linux2) OUT="linux-generic32"; options="$options -DB_ENDIAN" ;;
 | 
				
			||||||
  s390x-*-linux2)
 | 
					  s390x-*-linux2) OUT="linux-s390x" ;;
 | 
				
			||||||
	# To be uncommented when glibc bug is fixed, see Configure...
 | 
					 | 
				
			||||||
	#if egrep -e '^features.* highgprs' /proc/cpuinfo >/dev/null ; then
 | 
					 | 
				
			||||||
	#  echo "WARNING! If you wish to build \"highgprs\" 32-bit library, then you"
 | 
					 | 
				
			||||||
	#  echo "         have to invoke './Configure linux32-s390x' *manually*."
 | 
					 | 
				
			||||||
	#  if [ "$TEST" = "false" -a -t -1 ]; then
 | 
					 | 
				
			||||||
	#    echo "         You have about 5 seconds to press Ctrl-C to abort."
 | 
					 | 
				
			||||||
	#    (trap "stty `stty -g`" 2 0; stty -icanon min 0 time 50; read waste) <&1
 | 
					 | 
				
			||||||
	#  fi
 | 
					 | 
				
			||||||
	#fi
 | 
					 | 
				
			||||||
	OUT="linux64-s390x"
 | 
					 | 
				
			||||||
	;;
 | 
					 | 
				
			||||||
  x86_64-*-linux?) OUT="linux-x86_64" ;;
 | 
					  x86_64-*-linux?) OUT="linux-x86_64" ;;
 | 
				
			||||||
  *86-*-linux2) OUT="linux-elf"
 | 
					  *86-*-linux2) OUT="linux-elf"
 | 
				
			||||||
	if [ "$GCCVER" -gt 28 ]; then
 | 
						if [ "$GCCVER" -gt 28 ]; then
 | 
				
			||||||
@@ -678,7 +642,7 @@ case "$GUESSOS" in
 | 
				
			|||||||
  sun4[uv]*-*-solaris2)
 | 
					  sun4[uv]*-*-solaris2)
 | 
				
			||||||
	OUT="solaris-sparcv9-$CC"
 | 
						OUT="solaris-sparcv9-$CC"
 | 
				
			||||||
	ISA64=`(isalist) 2>/dev/null | grep sparcv9`
 | 
						ISA64=`(isalist) 2>/dev/null | grep sparcv9`
 | 
				
			||||||
	if [ "$ISA64" != "" -a "$KERNEL_BITS" = "" ]; then
 | 
						if [ "$ISA64" != "" ]; then
 | 
				
			||||||
	    if [ "$CC" = "cc" -a $CCVER -ge 50 ]; then
 | 
						    if [ "$CC" = "cc" -a $CCVER -ge 50 ]; then
 | 
				
			||||||
		echo "WARNING! If you wish to build 64-bit library, then you have to"
 | 
							echo "WARNING! If you wish to build 64-bit library, then you have to"
 | 
				
			||||||
		echo "         invoke './Configure solaris64-sparcv9-cc' *manually*."
 | 
							echo "         invoke './Configure solaris64-sparcv9-cc' *manually*."
 | 
				
			||||||
@@ -708,16 +672,13 @@ case "$GUESSOS" in
 | 
				
			|||||||
		fi
 | 
							fi
 | 
				
			||||||
	    fi
 | 
						    fi
 | 
				
			||||||
	fi
 | 
						fi
 | 
				
			||||||
	if [ "$ISA64" != "" -a "$KERNEL_BITS" = "64" ]; then
 | 
					 | 
				
			||||||
	    OUT="solaris64-sparcv9-$CC"
 | 
					 | 
				
			||||||
	fi
 | 
					 | 
				
			||||||
	;;
 | 
						;;
 | 
				
			||||||
  sun4m-*-solaris2)	OUT="solaris-sparcv8-$CC" ;;
 | 
					  sun4m-*-solaris2)	OUT="solaris-sparcv8-$CC" ;;
 | 
				
			||||||
  sun4d-*-solaris2)	OUT="solaris-sparcv8-$CC" ;;
 | 
					  sun4d-*-solaris2)	OUT="solaris-sparcv8-$CC" ;;
 | 
				
			||||||
  sun4*-*-solaris2)	OUT="solaris-sparcv7-$CC" ;;
 | 
					  sun4*-*-solaris2)	OUT="solaris-sparcv7-$CC" ;;
 | 
				
			||||||
  *86*-*-solaris2)
 | 
					  *86*-*-solaris2)
 | 
				
			||||||
	ISA64=`(isalist) 2>/dev/null | grep amd64`
 | 
						ISA64=`(isalist) 2>/dev/null | grep amd64`
 | 
				
			||||||
	if [ "$ISA64" != "" -a ${KERNEL_BITS:-64} -eq 64 ]; then
 | 
						if [ "$ISA64" != "" ]; then
 | 
				
			||||||
	    OUT="solaris64-x86_64-$CC"
 | 
						    OUT="solaris64-x86_64-$CC"
 | 
				
			||||||
	else
 | 
						else
 | 
				
			||||||
	    OUT="solaris-x86-$CC"
 | 
						    OUT="solaris-x86-$CC"
 | 
				
			||||||
@@ -769,17 +730,20 @@ case "$GUESSOS" in
 | 
				
			|||||||
	if [ $CC = "gcc" -a $GCC_BITS = "64" ]; then
 | 
						if [ $CC = "gcc" -a $GCC_BITS = "64" ]; then
 | 
				
			||||||
	    OUT="hpux64-parisc2-gcc"
 | 
						    OUT="hpux64-parisc2-gcc"
 | 
				
			||||||
	fi
 | 
						fi
 | 
				
			||||||
	[ "$KERNEL_BITS" ] || KERNEL_BITS=`(getconf KERNEL_BITS) 2>/dev/null`
 | 
						KERNEL_BITS=`(getconf KERNEL_BITS) 2>/dev/null`
 | 
				
			||||||
	KERNEL_BITS=${KERNEL_BITS:-32}
 | 
						KERNEL_BITS=${KERNEL_BITS:-32}
 | 
				
			||||||
	CPU_VERSION=`(getconf CPU_VERSION) 2>/dev/null`
 | 
						CPU_VERSION=`(getconf CPU_VERSION) 2>/dev/null`
 | 
				
			||||||
	CPU_VERSION=${CPU_VERSION:-0}
 | 
						CPU_VERSION=${CPU_VERSION:-0}
 | 
				
			||||||
	# See <sys/unistd.h> for further info on CPU_VERSION.
 | 
						# See <sys/unistd.h> for further info on CPU_VERSION.
 | 
				
			||||||
	if   [ $CPU_VERSION -ge 768 ]; then	# IA-64 CPU
 | 
						if   [ $CPU_VERSION -ge 768 ]; then	# IA-64 CPU
 | 
				
			||||||
	     if [ $KERNEL_BITS -eq 64 -a "$CC" = "cc" ]; then
 | 
						     echo "WARNING! 64-bit ABI is the default configured ABI on HP-UXi."
 | 
				
			||||||
	        OUT="hpux64-ia64-cc"
 | 
						     echo "         If you wish to build 32-bit library, the you have to"
 | 
				
			||||||
             else
 | 
						     echo "         invoke './Configure hpux-ia64-cc' *manually*."
 | 
				
			||||||
	        OUT="hpux-ia64-cc"
 | 
						     if [ "$TEST" = "false" -a -t 1 ]; then
 | 
				
			||||||
             fi
 | 
							echo "         You have about 5 seconds to press Ctrl-C to abort."
 | 
				
			||||||
 | 
							(trap "stty `stty -g`" 2 0; stty -icanon min 0 time 50; read waste) <&1
 | 
				
			||||||
 | 
						     fi
 | 
				
			||||||
 | 
						     OUT="hpux64-ia64-cc"
 | 
				
			||||||
	elif [ $CPU_VERSION -ge 532 ]; then	# PA-RISC 2.x CPU
 | 
						elif [ $CPU_VERSION -ge 532 ]; then	# PA-RISC 2.x CPU
 | 
				
			||||||
	     OUT=${OUT:-"hpux-parisc2-${CC}"}
 | 
						     OUT=${OUT:-"hpux-parisc2-${CC}"}
 | 
				
			||||||
	     if [ $KERNEL_BITS -eq 64 -a "$CC" = "cc" ]; then
 | 
						     if [ $KERNEL_BITS -eq 64 -a "$CC" = "cc" ]; then
 | 
				
			||||||
@@ -800,15 +764,11 @@ case "$GUESSOS" in
 | 
				
			|||||||
	options="$options -D_REENTRANT" ;;
 | 
						options="$options -D_REENTRANT" ;;
 | 
				
			||||||
  *-hpux)	OUT="hpux-parisc-$CC" ;;
 | 
					  *-hpux)	OUT="hpux-parisc-$CC" ;;
 | 
				
			||||||
  *-aix)
 | 
					  *-aix)
 | 
				
			||||||
	[ "$KERNEL_BITS" ] || KERNEL_BITS=`(getconf KERNEL_BITMODE) 2>/dev/null`
 | 
						KERNEL_BITS=`(getconf KERNEL_BITMODE) 2>/dev/null`
 | 
				
			||||||
	KERNEL_BITS=${KERNEL_BITS:-32}
 | 
						KERNEL_BITS=${KERNEL_BITS:-32}
 | 
				
			||||||
	OBJECT_MODE=${OBJECT_MODE:-32}
 | 
						OBJECT_MODE=${OBJECT_MODE:-32}
 | 
				
			||||||
	if [ "$CC" = "gcc" ]; then
 | 
						if [ "$CC" = "gcc" ]; then
 | 
				
			||||||
	    OUT="aix-gcc"
 | 
						    OUT="aix-gcc"
 | 
				
			||||||
          if [ $OBJECT_MODE -eq 64 ]; then
 | 
					 | 
				
			||||||
            echo 'Your $OBJECT_MODE was found to be set to 64'
 | 
					 | 
				
			||||||
            OUT="aix64-gcc"
 | 
					 | 
				
			||||||
          fi
 | 
					 | 
				
			||||||
	elif [ $OBJECT_MODE -eq 64 ]; then
 | 
						elif [ $OBJECT_MODE -eq 64 ]; then
 | 
				
			||||||
	    echo 'Your $OBJECT_MODE was found to be set to 64' 
 | 
						    echo 'Your $OBJECT_MODE was found to be set to 64' 
 | 
				
			||||||
	    OUT="aix64-cc"
 | 
						    OUT="aix64-cc"
 | 
				
			||||||
@@ -838,10 +798,6 @@ case "$GUESSOS" in
 | 
				
			|||||||
  j90-cray-unicos) OUT="cray-j90" ;;
 | 
					  j90-cray-unicos) OUT="cray-j90" ;;
 | 
				
			||||||
  nsr-tandem-nsk) OUT="tandem-c89" ;;
 | 
					  nsr-tandem-nsk) OUT="tandem-c89" ;;
 | 
				
			||||||
  beos-*) OUT="$GUESSOS" ;;
 | 
					  beos-*) OUT="$GUESSOS" ;;
 | 
				
			||||||
  x86pc-*-qnx6) OUT="QNX6-i386" ;;
 | 
					 | 
				
			||||||
  *-*-qnx6) OUT="QNX6" ;;
 | 
					 | 
				
			||||||
  x86-*-android|i?86-*-android) OUT="android-x86" ;;
 | 
					 | 
				
			||||||
  armv[7-9]*-*-android) OUT="android-armv7" ;;
 | 
					 | 
				
			||||||
  *) OUT=`echo $GUESSOS | awk -F- '{print $3}'`;;
 | 
					  *) OUT=`echo $GUESSOS | awk -F- '{print $3}'`;;
 | 
				
			||||||
esac
 | 
					esac
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -857,16 +813,6 @@ esac
 | 
				
			|||||||
#  options="$options -DATALLA"
 | 
					#  options="$options -DATALLA"
 | 
				
			||||||
#fi
 | 
					#fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if [ -n "$CONFIG_OPTIONS" ]; then
 | 
					 | 
				
			||||||
  options="$options $CONFIG_OPTIONS"
 | 
					 | 
				
			||||||
fi
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
if expr "$options" : '.*no\-asm' > /dev/null; then :; else
 | 
					 | 
				
			||||||
  sh -c "$CROSS_COMPILE${CC:-gcc} -Wa,--help -c -o /tmp/null.$$.o -x assembler /dev/null && rm /tmp/null.$$.o" 2>&1 | \
 | 
					 | 
				
			||||||
  grep \\--noexecstack >/dev/null && \
 | 
					 | 
				
			||||||
  options="$options -Wa,--noexecstack"
 | 
					 | 
				
			||||||
fi
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# gcc < 2.8 does not support -march=ultrasparc
 | 
					# gcc < 2.8 does not support -march=ultrasparc
 | 
				
			||||||
if [ "$OUT" = solaris-sparcv9-gcc -a $GCCVER -lt 28 ]
 | 
					if [ "$OUT" = solaris-sparcv9-gcc -a $GCCVER -lt 28 ]
 | 
				
			||||||
then
 | 
					then
 | 
				
			||||||
 
 | 
				
			|||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user